.elementor-3142 .elementor-element.elementor-element-b80b070{--display:flex;}.elementor-widget-theme-post-title .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-size:var( --e-global-typography-primary-font-size );font-weight:var( --e-global-typography-primary-font-weight );color:var( --e-global-color-primary );}.elementor-3142 .elementor-element.elementor-element-73825829{text-align:center;}body.elementor-page-3142:not(.elementor-motion-effects-element-type-background), body.elementor-page-3142 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}@media(max-width:1024px){.elementor-widget-theme-post-title .elementor-heading-title{font-size:var( --e-global-typography-primary-font-size );}}@media(max-width:767px){.elementor-widget-theme-post-title .elementor-heading-title{font-size:var( --e-global-typography-primary-font-size );}}/* Start custom CSS *//* =========================================================
   ZIVILISTEN-PORTAL – PREMIUM / AMTLICH / RUHIG
   Gilt für Shortcode-Ausgabe [civil_portal]
   ========================================================= */

.pc-portal{
  max-width:1100px;
  margin:32px auto;
  padding:0 16px;
  font-family:"Noto Sans",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  color:#111827;
}

/* Karten */
.pc-box{
  background:#fff;
  border-radius:18px;
  padding:22px 24px;
  margin:0 0 22px 0;
  border:1px solid #eef0f2;
  box-shadow:0 10px 30px rgba(0,0,0,.06);
}

/* Headline */
.pc-box h3{
  margin:0 0 14px 0;
  font-size:20px;
  font-weight:800;
  letter-spacing:.2px;
  color:#111827;
  padding-bottom:10px;
  border-bottom:2px solid #f1f5f9;
}

/* Info/Success */
.pc-note{
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-left:4px solid #c9ad6a;
  padding:10px 14px;
  border-radius:12px;
  font-size:14px;
  color:#374151;
  margin:0 0 14px 0;
}

/* Tabellen (Registerdaten, Protokoll, Beschwerden) */
.pc-mini-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  font-size:15px;
  overflow:hidden;
  border-radius:14px;
  border:1px solid #eef0f2;
}

.pc-mini-table thead th{
  text-align:left;
  padding:12px 14px;
  background:#0f172a;         /* ruhiges „amtliches“ Dunkel */
  color:#fff;
  font-weight:700;
  font-size:14px;
  letter-spacing:.3px;
}

.pc-mini-table tbody th{
  text-align:left;
  width:28%;
  padding:12px 14px;
  background:#f8fafc;
  color:#374151;
  font-weight:700;
  border-top:1px solid #eef0f2;
  vertical-align:top;
}

.pc-mini-table tbody td{
  padding:12px 14px;
  border-top:1px solid #eef0f2;
  color:#111827;
  background:#fff;
}

/* Zebra + Hover */
.pc-mini-table tbody tr:nth-child(even) td{
  background:#fbfdff;
}
.pc-mini-table tbody tr:hover td,
.pc-mini-table tbody tr:hover th{
  background:#f7f7f7;
  transition:background .15s ease;
}

/* Formulare */
.pc-form{
  margin-top:10px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px 14px;
}

.pc-form label{
  grid-column:1 / -1;
  display:block;
  margin:0;
  font-weight:700;
  font-size:13px;
  letter-spacing:.2px;
  color:#374151;
}

.pc-form input,
.pc-form textarea{
  grid-column:1 / -1;
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid #d1d5db;
  background:#fff;
  font-size:15px;
  transition:border-color .15s ease, box-shadow .15s ease;
}

.pc-form textarea{
  resize:vertical;
  min-height:90px;
}

.pc-form input:focus,
.pc-form textarea:focus{
  outline:none;
  border-color:#c9ad6a;
  box-shadow:0 0 0 4px rgba(201,173,106,.18);
}

/* Buttons */
.pc-form button,
.pc-btn{
  grid-column:1 / -1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 18px;
  border:0;
  border-radius:14px;
  background:linear-gradient(135deg,#c9ad6a,#b7944e);
  color:#fff;
  font-weight:800;
  font-size:15px;
  cursor:pointer;
  text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease, filter .12s ease;
}

.pc-form button:hover,
.pc-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 22px rgba(0,0,0,.14);
  filter:saturate(1.05);
}

.pc-form button:active,
.pc-btn:active{
  transform:translateY(0);
  box-shadow:none;
}

/* Kleine Hinweise */
.pc-box small{
  color:#6b7280;
  font-size:13px;
}

/* Link-Stil in Listen (Zweckbetriebe) */
.pc-box a{
  color:#0f172a;
  font-weight:700;
  text-decoration:none;
}
.pc-box a:hover{
  text-decoration:underline;
}

/* Mobile: alles sauber stapeln */
@media (max-width:768px){
  .pc-box{
    padding:18px 16px;
    border-radius:16px;
  }
  .pc-box h3{
    font-size:18px;
  }

  .pc-form{
    grid-template-columns:1fr;
    gap:12px;
  }

  /* Tabellen auf Mobile: Labels/Values blockig */
  .pc-mini-table thead{
    display:none;
  }
  .pc-mini-table,
  .pc-mini-table tbody,
  .pc-mini-table tr,
  .pc-mini-table th,
  .pc-mini-table td{
    display:block;
    width:100%;
  }
  .pc-mini-table{
    border-radius:14px;
  }
  .pc-mini-table tr{
    border-top:1px solid #eef0f2;
  }
  .pc-mini-table tbody th{
    width:100%;
    border-top:none;
    padding:12px 14px 6px 14px;
    background:#f8fafc;
  }
  .pc-mini-table tbody td{
    padding:0 14px 12px 14px;
    border-top:none;
  }
}

/* =========================================================
   OPTIONAL: Passwort-Gate etwas edler machen
   (Gate-Seite nutzt Inline-CSS, dieses hier ist nur Zusatz)
   ========================================================= */
.pc-gate-card{
  border-radius:20px;
}
.pc-req-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.pc-req-card{border:1px solid #eef0f2;background:#fff;border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.06);overflow:hidden}
.pc-req-head{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:#0f172a;color:#fff}
.pc-req-type{font-weight:800;letter-spacing:.2px}
.pc-req-body{padding:12px 14px;font-size:14px;color:#111827}
.pc-req-row{margin:0 0 10px}

.pc-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-weight:800;font-size:12px;line-height:1}
.pc-badge-check{background:rgba(201,173,106,.18);color:#c9ad6a;border:1px solid rgba(201,173,106,.35)}
.pc-badge-work{background:rgba(59,130,246,.14);color:#3b82f6;border:1px solid rgba(59,130,246,.28)}
.pc-badge-done{background:rgba(16,185,129,.14);color:#10b981;border:1px solid rgba(16,185,129,.28)}

@media (max-width:768px){.pc-req-grid{grid-template-columns:1fr}}
.pc-badge-reject{
  background:rgba(239,68,68,.14);
  color:#ef4444;
  border:1px solid rgba(239,68,68,.28);
}
.pc-zb-list{
  margin:0;
  padding-left:18px;
}
.pc-zb-list li{
  margin:8px 0;
}
.pc-zb-list a{
  color:#c9ad6a;
  font-weight:700;
  text-decoration:none;
}
.pc-zb-list a:hover{ text-decoration:underline; }/* End custom CSS */