/* Portal-spezifische Ergänzungen über suite.css */
.portal-head{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:18px 28px; border-bottom:1px solid var(--line);
}
.portal-brand{ font-weight:700; letter-spacing:.04em; color:var(--brass);
  text-decoration:none; }
.portal-brand:hover{ text-decoration:none; opacity:.85; }
/* Rechte Header-Seite: Home-Button + (auf Admin-Seiten) die Rollen-Navigation. */
.portal-head-right{ display:flex; align-items:center; gap:.6rem; flex-wrap:wrap; justify-content:flex-end; }
.portal-home{ display:inline-flex; align-items:center; gap:.4rem; color:var(--paper);
  text-decoration:none; padding:.4rem .8rem; border:1px solid var(--line); border-radius:9px;
  font-size:.9rem; transition:.16s; }
.portal-home svg{ display:block; }
.portal-home:hover{ border-color:var(--brass); color:var(--paper); text-decoration:none;
  background:rgba(207,154,69,.08); }
/* Rollen-Navigation im Admin-Bereich (Makler/Admin/Eigentümer). */
.portal-nav{ display:flex; gap:.4rem; flex-wrap:wrap; align-items:center; }
.portal-nav a{ color:var(--muted); text-decoration:none; padding:.45rem .8rem;
  border:1px solid transparent; border-radius:9px; font-size:.9rem; transition:.16s; }
.portal-nav a:hover{ color:var(--ink); background:var(--brass); border-color:var(--brass); }
.portal-nav a.on{ color:var(--ink); background:var(--paper); border-color:var(--paper); }
/* Makler-Profil/Verfügbarkeit: schlanke Formulare + Slot-Liste. */
.mk-form{ max-width:560px; }
.mk-form label{ display:block; margin:12px 0 4px; font-weight:600; }
.mk-form input, .mk-form select, .mk-form textarea{ width:100%; box-sizing:border-box; }
.mk-slots{ width:100%; border-collapse:collapse; margin-top:1rem; }
.mk-slots th, .mk-slots td{ padding:.5rem .7rem; border-bottom:1px solid var(--line); text-align:left; }
.mk-ok{ color:var(--sage); margin:.6rem 0; }
.mk-hint{ color:var(--muted); font-size:.86rem; margin:.6rem 0 0; }
/* Wochentag-Auswahl als Toggle-Reihe. */
.mk-weekdays{ display:flex; flex-wrap:wrap; gap:.5rem; margin:.2rem 0 .4rem; }
.mk-wd{ display:inline-flex; align-items:center; gap:.35rem; margin:0; font-weight:500;
  padding:.35rem .6rem; border:1px solid var(--line); border-radius:9px; background:#0f0b07; }
.mk-wd input{ width:auto; }
/* Lage/Street-View-Block beim Makler. */
.mk-media{ margin:0 0 1.2rem; max-width:560px; }
.po-sv-card .po-sv-map{ display:block; width:100%; height:220px; border:0; }
.po-sv-card #po-streetview iframe{ display:block; width:100%; height:320px; border:0; }
/* Terminkalender (/admin/termine) — aufgeräumtes Karten-Layout. */
.tk-objekt{ margin:0 0 2rem; }
.tk-objekt-titel{ border-bottom:1px solid var(--line); padding-bottom:.4rem; }
.tk-slots{ display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:14px; }
.tk-slot{ background:linear-gradient(180deg,var(--ink-2),#1b150e); border:1px solid var(--line);
  border-radius:var(--r); padding:12px 14px 14px; }
.tk-slot-kopf{ display:flex; justify-content:space-between; align-items:baseline; gap:10px;
  margin-bottom:.5rem; }
.tk-slot-zeit{ font-weight:600; color:var(--paper); }
.tk-slot-cap{ font-size:.78rem; color:var(--muted); white-space:nowrap; }
/* Belegungs-Badge X/Y als Pill, farbcodiert: voll=grün, teil=amber, leer=grau. */
.tk-bel{ display:inline-block; font-size:.74rem; font-weight:700; white-space:nowrap;
  padding:.12rem .55rem; border-radius:999px; border:1px solid var(--line); }
.tk-bel.tk-voll{ color:var(--ink); background:var(--sage); border-color:var(--sage); }
.tk-bel.tk-teil{ color:var(--ink); background:var(--amber); border-color:var(--amber); }
.tk-bel.tk-bel-leer{ color:var(--muted); background:transparent; }
.tk-tab{ width:100%; border-collapse:collapse; font-size:.9rem; }
.tk-tab th{ font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted);
  text-align:left; padding:.3rem .4rem; border-bottom:1px solid var(--line); }
.tk-tab td{ padding:.35rem .4rem; border-bottom:1px solid var(--line); }
.tk-score{ font-weight:700; color:var(--amber); }
.tk-leer{ color:var(--muted); font-style:italic; font-size:.88rem; margin:0; }
/* Termine-Drilldown (Task 58): Objekt-Übersicht -> Objekt-Termine -> Bewerber.
   Karten wachsen mit dem Inhalt (min-width:0 + overflow-wrap) -> kein Überlauf. */
.tk-uebersicht{ display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; }
.tk-okarte{ display:block; min-width:0; background:linear-gradient(180deg,var(--ink-2),#1b150e);
  border:1px solid var(--line); border-radius:var(--r); padding:16px 18px; text-decoration:none;
  color:var(--paper); transition:.16s; }
.tk-okarte:hover{ border-color:var(--brass); transform:translateY(-2px); }
.tk-okarte .tk-o-adresse{ font-weight:600; overflow-wrap:anywhere; }
.tk-okarte .tk-o-meta{ color:var(--muted); font-size:.85rem; margin-top:.4rem; line-height:1.5; }
.tk-okarte .tk-o-naechster{ color:var(--amber); }
/* Aufklappbarer Termin-Block (<details>) auf der Objekt-Seite. */
.tk-termin{ min-width:0; background:linear-gradient(180deg,var(--ink-2),#1b150e);
  border:1px solid var(--line); border-radius:var(--r); margin:0 0 12px; overflow:hidden; }
.tk-termin > summary{ cursor:pointer; list-style:none; padding:12px 16px; display:flex;
  justify-content:space-between; align-items:baseline; gap:10px; flex-wrap:wrap; }
.tk-termin > summary::-webkit-details-marker{ display:none; }
.tk-termin > summary::before{ content:"▸"; color:var(--brass); margin-right:.5rem; }
.tk-termin[open] > summary::before{ content:"▾"; }
.tk-termin .tk-t-zeit{ font-weight:600; color:var(--paper); }
.tk-termin .tk-t-cap{ font-size:.8rem; color:var(--muted); white-space:nowrap; }
.tk-termin .tk-t-body{ padding:0 16px 14px; }
.tk-termin .tk-tab{ display:block; overflow-x:auto; }   /* lange Inhalte scrollen statt überlaufen */
/* Auto-Terminverteilung: Aktionszeile + Marker. */
.tk-aktion{ display:flex; align-items:center; gap:10px; margin:.4rem 0 1rem; }
.tk-wunsch{ color:var(--sage); font-weight:700; }       /* Wunsch-erfüllt-Marker */
/* Einzeltermin-Marker: dezentes Pill neben dem Namen. */
.tk-einzel{ display:inline-block; margin-left:.4rem; font-size:.7rem; font-weight:600;
  letter-spacing:.04em; padding:.08rem .5rem; border-radius:999px;
  color:var(--brass); border:1px solid var(--brass); }
.tk-nichtzu{ border:1px solid var(--rust); border-radius:var(--r);
  padding:10px 14px; margin-top:1rem; }
.tk-nichtzu h3{ margin:.1rem 0 .5rem; color:var(--rust); font-size:.8rem;
  letter-spacing:.12em; text-transform:uppercase; }
.portal-main{ max-width:1180px; margin:0 auto; padding:28px; }
/* Bewerber-Detailseite: Abschnitts-Cards mit Definition-Listen. */
.bw-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:16px; }
.bw-card{ background:linear-gradient(180deg,var(--ink-2),#1b150e); border:1px solid var(--line);
  border-radius:var(--r); padding:14px 18px 16px; }
.bw-card h2{ margin:.1rem 0 .6rem; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--brass); border-bottom:1px solid var(--line); padding-bottom:.4rem; }
.bw-dl{ display:grid; grid-template-columns:auto 1fr; gap:.35rem .9rem; margin:0; }
.bw-dl dt{ color:var(--muted); font-size:.86rem; }
.bw-dl dd{ margin:0; color:var(--paper); }
.bw-uploads{ margin:.6rem 0 0; padding-left:1.1rem; }
.portal-form label{ display:block; margin:12px 0 4px; font-weight:600; }
.portal-form input, .portal-form select{ width:100%; box-sizing:border-box; }
.portal-cta{ display:inline-block; margin-top:18px; }
.portal-table{ width:100%; border-collapse:collapse; }
.portal-table th, .portal-table td{ padding:8px 10px; border-bottom:1px solid var(--line); text-align:left; }
.portal-risk{ color:var(--rust); }

/* ============================================================
   Aufwertung: Landing-Redesign (Task 26)
   Premium, parallel ausgerichtet. Dark brass/ink-System aus suite.css.
   ============================================================ */

/* Hero-Galerie */
.po-hero{ position:relative; border-radius:var(--r); overflow:hidden;
  border:1px solid var(--line); box-shadow:var(--shadow); background:#0e0b07; }
.po-hero img{ display:block; width:100%; aspect-ratio:16/9; object-fit:cover; }
.po-hero .po-no-img{ display:flex; align-items:center; justify-content:center;
  aspect-ratio:16/9; color:var(--muted); font-family:'Fraunces',serif; font-style:italic; }
.po-thumbs{ display:flex; gap:8px; flex-wrap:wrap; margin-top:12px; }
.po-thumbs img{ width:104px; height:72px; object-fit:cover; border-radius:8px;
  border:1px solid var(--line); cursor:pointer; transition:.18s; }
.po-thumbs img:hover, .po-thumbs img.on{ border-color:var(--brass); }

.po-address{ color:var(--paper); }
/* Adresse + Eckdaten unter dem Formular-Titel. */
.po-objekt-adresse{ margin:.2rem 0 .8rem; color:var(--paper); font-weight:600; }
/* Eckdaten 3-spaltig nebeneinander (Kaltmiete | Betriebskosten | Kaution),
   mobil untereinander. */
.po-eckdaten{ display:grid; grid-template-columns:repeat(3, 1fr); gap:12px;
  margin:0 0 1.3rem; }
.po-eck{ display:flex; flex-direction:column; gap:.2rem;
  background:linear-gradient(180deg,var(--ink-2),#1b150e);
  border:1px solid var(--line); border-radius:10px; padding:.6rem .8rem; }
.po-eck-label{ font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.po-eck-wert{ font-size:1.05rem; font-weight:600; color:var(--amber); }
@media (max-width:520px){ .po-eckdaten{ grid-template-columns:1fr; } }

/* Maps-Header: breite Karte oben über allem (Kartenansicht/roadmap). */
.po-map-header{ position:relative; border-radius:var(--r); overflow:hidden;
  border:1px solid var(--line); box-shadow:var(--shadow); margin-bottom:22px; }
.po-map-header iframe{ display:block; width:100%; height:320px; border:0; }
.po-map-header-label{ position:absolute; left:0; bottom:0; right:0;
  padding:14px 18px; font-family:'Fraunces',serif; font-size:1.15rem; color:var(--paper);
  background:linear-gradient(0deg, rgba(11,8,5,.85), rgba(11,8,5,0)); }

/* Layout: LINKS prominent das Formular (po-main, breite 1fr-Spalte), RECHTS
   schmale, dezente Medien-Sidebar (po-media). Mobile: Formular zuerst, Medien danach. */
.po-layout{ display:grid; grid-template-columns:minmax(0,1fr) 330px; gap:28px;
  align-items:start; }
.po-main{ min-width:0; }
.po-main > h2{ margin-top:0; }
.po-media{ display:flex; flex-direction:column; gap:14px; position:sticky; top:18px;
  /* dezent: etwas zurückgenommen gegenüber dem Formularbereich */ opacity:.96; }
.po-media-card{ background:linear-gradient(180deg,var(--ink-2),#1b150e);
  border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.po-media-card .po-hero{ margin:0; border:0; border-radius:0; box-shadow:none; }
.po-media-card .po-hero img{ aspect-ratio:4/3; }
.po-media-card .po-thumbs{ margin:0; padding:10px 12px 12px; }

/* Street-View-Karte in der Sidebar — Hochformat (länger nach unten).
   Betrifft NUR die Sidebar-Box; der breite Maps-Header (.po-map-header) bleibt. */
.po-map-card h3{ margin:0; padding:12px 16px; font-size:.74rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--muted); border-bottom:1px solid var(--line); }
.po-map-card iframe{ display:block; width:100%; height:400px; border:0; }
.po-map-fallback{ display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:.6rem; height:400px; color:var(--muted); text-align:center; padding:1rem; }
.po-map-fallback a{ color:var(--amber); }

/* Mobile: einspaltig — Maps-Header oben, dann Formular, dann Medien (Formular im Fokus). */
@media (max-width:860px){
  .po-layout{ grid-template-columns:1fr; }
  .po-media{ position:static; }
  .po-map-header iframe{ height:240px; }
}

/* ============================================================
   Aufwertung: Formular-Redesign 2-Spalten-Raster (Task 27)
   ============================================================ */
.pf-section{ margin:22px 0; border:1px solid var(--line); border-radius:var(--r);
  padding:18px 20px 20px; background:linear-gradient(180deg,var(--ink-2),#1b150e); }
.pf-section > legend, .pf-section > .pf-legend{ font-size:.74rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--brass); padding:0 .4rem; font-weight:700; }
.pf-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px 20px; align-items:end; }
.pf-grid .pf-full{ grid-column:1 / -1; }
.pf-field{ display:flex; flex-direction:column; }
/* Bedingte Folgefelder: [hidden] muss das display:flex von .pf-field überstimmen. */
.pf-field[hidden]{ display:none; }
.pf-field label{ display:block; margin:0 0 4px; font-weight:600; font-size:.9rem; }
.pf-field input, .pf-field select, .pf-field textarea{ width:100%; box-sizing:border-box; }
/* Ja/Nein-Radios sauber ausgerichtet */
/* Frage IMMER über den Ja/Nein-Optionen (gestapelt) -> kann an keiner Breite
   aus der Box laufen. */
.pf-radio{ display:flex; flex-direction:column; align-items:flex-start; gap:.45rem;
  padding:.6rem .8rem; border:1px solid var(--line); border-radius:9px; background:#0f0b07; }
.pf-radio .pf-radio-label{ font-weight:600; font-size:.9rem; }
.pf-radio .pf-radio-opts{ display:flex; flex-wrap:wrap; gap:.5rem 1.4rem; }
.pf-radio .pf-radio-opts label{ display:inline-flex; align-items:center; gap:.4rem; margin:0; font-weight:500; }
/* Freundlicher Hinweis (z.B. Bürge-Aufforderung bei zu wenig Einkommen). */
.pf-hint{ margin:0 0 .5rem; padding:.5rem .7rem; font-size:.86rem; color:var(--paper);
  background:rgba(207,154,69,.1); border:1px solid var(--line); border-left:3px solid var(--brass);
  border-radius:8px; }
@media (max-width:680px){ .pf-grid{ grid-template-columns:1fr; } }

.admin-kennzahlen { display:flex; gap:1rem; margin:1rem 0 1.4rem; flex-wrap:wrap; }
.admin-kennzahlen .kz { background:linear-gradient(180deg,var(--ink-2),#1b150e);
  border:1px solid var(--line); border-radius:10px; padding:.55rem 1rem; color:var(--paper); }
.admin-kennzahlen .kz-warn { background:linear-gradient(180deg,#2a160f,#1b0f0a);
  border-color:var(--rust); color:#f0b9a3; }
.admin-objekte { width:100%; border-collapse:collapse; color:var(--paper); }
.admin-objekte th { text-align:left; padding:.5rem .6rem; vertical-align:bottom;
  font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted);
  border-bottom:1px solid var(--line); }
.admin-objekte td { text-align:left; padding:.6rem; vertical-align:top;
  border-bottom:1px solid var(--line); }
.makler-chips { display:flex; gap:.4rem; flex-wrap:wrap; align-items:center; }
.makler-chips .chip { display:inline-flex; align-items:center; gap:.35rem; background:#0f0b07;
  border:1px solid var(--line); color:var(--paper); border-radius:14px; padding:.18rem .6rem; margin:0; }
.makler-chips .chip button { border:none; background:none; cursor:pointer; color:var(--brass);
  font-weight:bold; padding:0; }
.makler-chips .chip-add select { border:1px dashed var(--line); border-radius:14px;
  padding:.18rem 1.6rem .18rem .5rem; background:#0f0b07; color:var(--paper); }

/* Admin-Benutzerverwaltung + Lead-Import: Passwort-Banner, Fehler */
.pw-banner { background:linear-gradient(180deg,rgba(134,160,106,.14),rgba(134,160,106,.04));
  border:1px solid var(--sage); border-radius:10px; padding:.7rem 1rem; margin:1rem 0; color:var(--paper); }
.pw-banner code { background:#0f0b07; border:1px solid var(--line); color:var(--brass);
  padding:.12rem .45rem; border-radius:5px; font-size:1.1rem; }
.pw-hint { color:var(--muted); font-size:.85rem; }
.form-fehler { background:linear-gradient(180deg,#2a160f,#1b0f0a); color:#f0b9a3;
  border:1px solid var(--rust); border-radius:10px; padding:.6rem 1rem; margin:1rem 0; }

/* ============================================================
   Öffentliche Angebots-Übersicht (Startseite / public_index.html)
   ============================================================ */
.po-index-title{ margin:.2rem 0 .2rem; }
.po-index-sub{ color:var(--muted); margin:0 0 1.4rem; }
.po-index-grid{ display:grid; gap:20px; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); }
.po-index-card{ display:flex; flex-direction:column; overflow:hidden;
  background:linear-gradient(180deg,var(--ink-2),#1b150e); border:1px solid var(--line);
  border-radius:var(--r); box-shadow:var(--shadow); transition:.16s; }
.po-index-card:hover{ border-color:var(--brass); transform:translateY(-2px); }
.po-index-media{ display:block; aspect-ratio:16/10; background:#0e0b07; }
.po-index-media img{ width:100%; height:100%; object-fit:cover; display:block; }
.po-index-media .po-no-img{ display:flex; align-items:center; justify-content:center; height:100%;
  color:var(--muted); font-style:italic; font-family:'Fraunces',serif; }
.po-index-body{ display:flex; flex-direction:column; gap:.7rem; padding:16px 18px 18px; }
.po-index-adresse{ margin:0; font-size:1.15rem; }
.po-index-eck{ display:flex; flex-wrap:wrap; gap:.5rem 1.2rem; }
.po-index-eck > span{ display:flex; flex-direction:column; gap:.1rem; }
.po-index-eck b{ color:var(--amber); font-weight:600; }
.po-index-einheiten{ margin:0; color:var(--muted); font-size:.88rem; }
.po-index-body .btn{ margin-top:.3rem; align-self:flex-start; }
