/* ============================================================
   Übergabeprotokoll · YES Immobilien
   Gestaltung: minimalistisch & edel — Hellgrau, Schwarz,
   YES-Rot #962030 als einziger Akzent.
   ============================================================ */

@font-face { font-family:'Public Sans'; font-weight:400; font-style:normal; font-display:swap;
  src:url('assets/fonts/public-sans-latin-400-normal.woff2') format('woff2'); }
@font-face { font-family:'Public Sans'; font-weight:500; font-style:normal; font-display:swap;
  src:url('assets/fonts/public-sans-latin-500-normal.woff2') format('woff2'); }
@font-face { font-family:'Public Sans'; font-weight:600; font-style:normal; font-display:swap;
  src:url('assets/fonts/public-sans-latin-600-normal.woff2') format('woff2'); }
@font-face { font-family:'Public Sans'; font-weight:700; font-style:normal; font-display:swap;
  src:url('assets/fonts/public-sans-latin-700-normal.woff2') format('woff2'); }

:root {
  --bg:           #f4f4f5;
  --bg-deep:      #ebebed;
  --card:         #ffffff;
  --ink:          #141414;
  --ink-soft:     #5b5b5e;
  --ink-faint:    #9b9b9f;
  --line:         #e3e3e6;
  --line-strong:  #c8c8cc;
  --brand:        #962030;
  --brand-deep:   #6f1622;
  --brand-wash:   #f7ecee;
  --ok:           #3e6b48;
  --ok-wash:      #e4ecdf;
  --shadow-card:  0 1px 2px rgba(0,0,0,.04), 0 8px 24px -14px rgba(0,0,0,.10);
  --radius: 12px;
  --font-ui: 'Public Sans', -apple-system, 'Helvetica Neue', sans-serif;
}

* { box-sizing:border-box; margin:0; padding:0; -webkit-tap-highlight-color:transparent; }
/* iOS färbt Button-Text sonst blau (Abschnittsköpfe, Auswahlkarten) */
button { color:inherit; font-family:inherit; -webkit-appearance:none; appearance:none; }
html { font-size:16px; }
body {
  font-family:var(--font-ui); color:var(--ink); background:var(--bg);
  min-height:100vh; -webkit-font-smoothing:antialiased;
  padding-bottom:env(safe-area-inset-bottom);
}
.hidden { display:none !important; }
.accent { color:var(--brand); }

/* ---------- Buttons ---------- */
.btn {
  font-family:var(--font-ui); font-size:1rem; font-weight:600; letter-spacing:.01em;
  border:1.5px solid transparent; border-radius:10px; padding:.7rem 1.15rem;
  min-height:46px; cursor:pointer; transition:transform .08s ease, background .15s ease;
  touch-action:manipulation; user-select:none; -webkit-user-select:none;
}
.btn:active { transform:scale(.97); }
.btn-primary { background:var(--brand); color:#fff; }
.btn-primary:active { background:var(--brand-deep); }
.btn-outline { background:transparent; color:var(--brand); border-color:var(--brand); }
.btn-ghost { background:transparent; color:var(--ink-soft); }
.btn-ghost:active { background:var(--bg-deep); }
.btn-big { font-size:1.05rem; padding:.85rem 1.5rem; border-radius:12px; }
.btn-small { min-height:38px; font-size:.88rem; padding:.4rem .85rem; }
.btn-danger { background:transparent; color:var(--brand); }
.btn-add {
  background:var(--card); border:1.5px dashed var(--line-strong); color:var(--ink-soft);
  width:100%; font-weight:600;
}
.btn-add:active { border-color:var(--ink); color:var(--ink); }
.btn[disabled] { opacity:.45; pointer-events:none; }

/* ---------- Inputs ---------- */
.input, textarea.input, select.input {
  font-family:var(--font-ui); font-size:1rem; color:var(--ink);
  background:var(--card); border:1.5px solid var(--line); border-radius:9px;
  padding:.65rem .8rem; min-height:46px; width:100%;
  transition:border-color .15s ease, box-shadow .15s ease;
  -webkit-appearance:none; appearance:none;
}
.input:focus, textarea.input:focus { outline:none; border-color:var(--brand); box-shadow:0 0 0 3px rgba(150,32,48,.12); }
textarea.input { min-height:72px; resize:vertical; line-height:1.45; }
.input::placeholder { color:var(--ink-faint); }
label.fld { display:block; }
label.fld > span, .fld-label {
  display:block; font-size:.72rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.08em; color:var(--ink-soft); margin-bottom:.3rem;
}
.fld-row { display:flex; gap:.7rem; flex-wrap:wrap; }
.fld-row > * { flex:1 1 160px; }
.fld-row > .narrow { flex:0 1 130px; }

/* ---------- Segmented control ---------- */
.seg { display:inline-flex; background:var(--bg-deep); border:1px solid var(--line); border-radius:10px; padding:3px; gap:2px; }
.seg-btn {
  font-family:var(--font-ui); font-size:.9rem; font-weight:600; color:var(--ink-soft);
  background:transparent; border:none; border-radius:7px; padding:.45rem .9rem; min-height:40px;
  cursor:pointer; transition:all .12s ease; white-space:nowrap;
}
.seg-btn.active { background:var(--card); color:var(--ink); box-shadow:0 1px 3px rgba(0,0,0,.14); }
.seg-btn.active.is-mangel { background:var(--brand); color:#fff; }
.seg-btn.active.is-ok { background:var(--ok); color:#fff; }

/* ---------- Badges ---------- */
.badge {
  display:inline-block; font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em;
  border-radius:999px; padding:.28em .85em; vertical-align:middle;
}
.badge-entwurf { background:var(--bg-deep); color:var(--ink-soft); border:1px solid var(--line-strong); }
.badge-abgeschlossen { background:var(--ok-wash); color:var(--ok); border:1px solid #bccfb3; }
.badge-art { background:var(--brand-wash); color:var(--brand); border:1px solid #e8ccd1; }

/* ============================================================
   START / ARCHIV
   ============================================================ */
.view { max-width:1060px; margin:0 auto; padding:0 clamp(1rem, 3vw, 2.5rem); }

.home-head {
  display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap;
  padding:clamp(1.2rem,3vw,2rem) 0 1.4rem;
  border-bottom:1px solid var(--line-strong);
}
.home-logo { height:clamp(48px, 6vw, 64px); width:auto; }

.home-body { padding:1.4rem 0 2rem; }
.archive-toolbar { display:flex; gap:.9rem; flex-wrap:wrap; align-items:center; margin-bottom:1.2rem; }
.search-input { flex:1 1 260px; max-width:430px; }

.archive-list { display:grid; grid-template-columns:repeat(auto-fill, minmax(310px, 1fr)); gap:1rem; }
.archive-card {
  position:relative; background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow-card); padding:1.1rem 1.2rem 1rem; cursor:pointer;
  transition:transform .12s ease; overflow:hidden;
}
.archive-card:active { transform:scale(.985); }
.archive-card::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:var(--line-strong);
}
.archive-card.is-abgeschlossen::before { background:var(--ok); }
.ac-top { display:flex; justify-content:space-between; gap:.6rem; align-items:flex-start; margin-bottom:.45rem; }
.ac-addr { font-weight:700; font-size:1.08rem; line-height:1.3; letter-spacing:-.01em; }
.ac-meta { color:var(--ink-soft); font-size:.86rem; line-height:1.5; }
.ac-badges { display:flex; gap:.4rem; flex-direction:column; align-items:flex-end; }

.archive-empty { text-align:center; padding:4rem 1rem; color:var(--ink-soft); line-height:1.7; }
.empty-stamp {
  font-size:2.6rem; font-weight:700; color:var(--brand);
  width:88px; height:88px; line-height:84px; margin:0 auto 1rem;
  border:2px solid var(--line-strong); border-radius:50%;
}
.home-foot {
  display:flex; justify-content:space-between; padding:1rem 0 1.6rem;
  border-top:1px solid var(--line); color:var(--ink-faint); font-size:.8rem;
}

/* ============================================================
   EDITOR
   ============================================================ */
#view-editor { max-width:880px; }
.editor-head {
  position:sticky; top:0; z-index:30; display:flex; align-items:center; gap:.7rem;
  padding:.65rem 0; margin:0 -.5rem; padding-left:.5rem; padding-right:.5rem;
  background:linear-gradient(var(--bg) 86%, transparent);
  backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
}
.editor-head-title { flex:1; min-width:0; display:flex; align-items:center; gap:.6rem; }
#editor-title {
  font-weight:700; font-size:1.1rem; letter-spacing:-.01em;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.editor-head-actions { display:flex; gap:.4rem; }
.readonly-note {
  display:flex; align-items:center; gap:.8rem; flex-wrap:wrap;
  background:var(--ok-wash); border:1px solid #bccfb3; color:var(--ok);
  font-weight:600; font-size:.92rem; border-radius:10px; padding:.7rem 1rem; margin:.4rem 0 .8rem;
}
.editor-body { padding:.6rem 0 5rem; display:flex; flex-direction:column; gap:1rem; }
.editor-body.readonly section.sheet { opacity:.92; }
.editor-body.readonly :is(.input, .seg-btn, .btn-add, .gw-seg, .sig-pad) { pointer-events:none; }
.editor-body.readonly :is(.btn-row-del, .btn-add, .sig-actions) { display:none !important; }

/* --- Abschnitts-„Blätter“ --- */
section.sheet {
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow-card); overflow:hidden;
}
.sheet-head {
  display:flex; align-items:center; gap:.9rem; width:100%;
  padding:1rem 1.2rem; background:transparent; border:none; cursor:pointer; text-align:left;
}
.sheet-num {
  font-weight:700; font-size:.9rem; color:var(--brand);
  border:1.5px solid var(--line-strong); border-radius:7px; min-width:40px; height:34px;
  display:grid; place-items:center; letter-spacing:.02em; flex-shrink:0;
}
.sheet-title { font-weight:700; font-size:1.1rem; letter-spacing:-.01em; flex:1; }
.sheet-hint { color:var(--ink-faint); font-size:.85rem; font-weight:500; margin-right:.3rem; white-space:nowrap; }
.sheet-chev { color:var(--ink-faint); transition:transform .2s ease; font-size:.9rem; }
section.sheet.open .sheet-chev { transform:rotate(90deg); }
.sheet-body { display:none; padding:.2rem 1.2rem 1.3rem; border-top:1px solid var(--line); }
section.sheet.open .sheet-body { display:block; }
.sheet-body > * + * { margin-top:.9rem; }

/* --- Art der Übergabe --- */
.art-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(180px,1fr)); gap:.8rem; }
.art-card {
  border:1.5px solid var(--line); border-radius:10px; background:var(--bg);
  padding:1rem; text-align:left; cursor:pointer; font-family:var(--font-ui);
  transition:all .15s ease;
}
.art-card .art-name { font-weight:700; font-size:1.05rem; display:block; letter-spacing:-.01em; }
.art-card .art-desc { color:var(--ink-soft); font-size:.84rem; line-height:1.45; margin-top:.3rem; display:block; }
.art-card.active { border-color:var(--brand); background:var(--brand-wash); box-shadow:inset 0 0 0 1px var(--brand); }
.art-card.active .art-name { color:var(--brand); }

/* --- Personen / Listenzeilen --- */
.row-list { display:flex; flex-direction:column; gap:.7rem; }
.list-row {
  display:flex; gap:.6rem; align-items:flex-start; flex-wrap:wrap;
  background:var(--bg); border:1px solid var(--line); border-radius:10px; padding:.75rem;
}
.list-row .grow { flex:2 1 180px; }
.list-row .mid { flex:1.4 1 150px; }
.list-row .small { flex:1 1 110px; }
.list-row .tiny { flex:0 1 86px; }
.btn-row-del {
  flex:0 0 auto; width:42px; height:46px; border-radius:9px; border:none;
  background:transparent; color:var(--ink-faint); font-size:1.25rem; cursor:pointer;
}
.btn-row-del:active { color:var(--brand); }
.subhead {
  font-weight:700; font-size:.95rem; color:var(--ink); letter-spacing:-.005em;
  display:flex; align-items:center; gap:.6rem; margin-top:1.2rem;
}
.subhead::after { content:''; flex:1; border-top:1px solid var(--line); }

/* --- Räume --- */
.room-tpl-bar { display:flex; gap:.5rem; flex-wrap:wrap; }
.chip {
  font-family:var(--font-ui); font-size:.86rem; font-weight:600; color:var(--ink-soft);
  background:var(--bg); border:1.5px solid var(--line-strong); border-radius:999px;
  padding:.45rem 1rem; min-height:40px; cursor:pointer; transition:all .12s ease;
}
.chip:active { background:var(--bg-deep); color:var(--ink); border-color:var(--ink); }
.room-card { border:1px solid var(--line); border-radius:10px; background:var(--bg); overflow:hidden; }
.room-head { display:flex; align-items:center; gap:.7rem; padding:.7rem .9rem; cursor:pointer; }
.room-name { font-weight:700; font-size:1rem; flex:1; letter-spacing:-.01em; }
.room-state { font-size:.8rem; font-weight:600; }
.room-state.ok { color:var(--ok); }
.room-state.mangel { color:var(--brand); }
.room-body { display:none; padding:.6rem .9rem 1rem; border-top:1px solid var(--line); background:var(--card); }
.room-card.open .room-body { display:block; }
.gw-row {
  display:flex; align-items:center; gap:.7rem; flex-wrap:wrap;
  padding:.5rem 0; border-bottom:1px solid var(--bg-deep);
}
.gw-name { flex:1 1 110px; font-weight:600; font-size:.95rem; }
.gw-seg { flex-shrink:0; }
.gw-mangel-text { flex-basis:100%; }
.gw-alt {
  flex-basis:100%; font-size:.8rem; color:var(--ink-soft); background:var(--bg-deep);
  border-radius:7px; padding:.35rem .6rem;
}
.photo-grid { display:flex; gap:.6rem; flex-wrap:wrap; margin-top:.6rem; }
.photo-thumb {
  position:relative; width:96px; height:96px; border-radius:9px; overflow:hidden;
  border:1px solid var(--line-strong); background:var(--bg-deep);
}
.photo-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.photo-del {
  position:absolute; top:4px; right:4px; width:26px; height:26px; border-radius:50%;
  background:rgba(20,20,20,.75); color:#fff; border:none; font-size:.85rem; cursor:pointer; line-height:1;
}
.photo-add {
  width:96px; height:96px; border-radius:9px; border:1.5px dashed var(--line-strong);
  background:transparent; color:var(--ink-faint); font-size:1.6rem; cursor:pointer;
}

/* --- Zähler / Schlüssel Tabellenoptik --- */
.row-photos { flex-basis:100%; }
.row-photos .fld-label { margin-top:.2rem !important; }
.row-photos .photo-thumb, .row-photos .photo-add { width:72px; height:72px; }
.row-flag { display:flex; align-items:center; gap:.5rem; font-size:.9rem; font-weight:600; color:var(--ink-soft); min-height:46px; }
.row-flag input[type=checkbox] { width:22px; height:22px; accent-color:var(--brand); }

/* --- Unterlagen --- */
.check-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:.45rem; }
.check-item {
  display:flex; align-items:center; gap:.7rem; background:var(--bg);
  border:1px solid var(--line); border-radius:9px; padding:.55rem .75rem; min-height:48px;
  font-size:.94rem; font-weight:500; cursor:pointer;
}
.check-item input { width:22px; height:22px; accent-color:var(--ok); flex-shrink:0; }
.check-item.checked { border-color:var(--ok); background:var(--ok-wash); }

/* --- Unterschriften --- */
.sig-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:1rem; }
.sig-card { border:1px solid var(--line); border-radius:10px; background:var(--bg); padding:.9rem; }
.sig-role { font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--brand); }
.sig-name { font-weight:700; font-size:1rem; margin:.15rem 0 .6rem; letter-spacing:-.01em; }
.sig-pad {
  width:100%; height:150px; background:#fff; border:1.5px solid var(--line-strong);
  border-radius:9px; touch-action:none; display:block;
}
.sig-pad.signed { border-color:var(--ok); }
.sig-line { border-top:1px solid var(--ink-faint); margin-top:-26px; pointer-events:none; position:relative; }
.sig-actions { display:flex; gap:.5rem; margin-top:.55rem; align-items:center; flex-wrap:wrap; }
.sig-refused { background:var(--brand-wash); border:1px solid #e8ccd1; border-radius:9px; padding:.6rem; margin-top:.6rem; }

/* --- Hinweisboxen --- */
.note-box {
  background:var(--bg-deep); border:1px solid var(--line-strong); border-radius:9px;
  padding:.7rem .9rem; font-size:.9rem; color:var(--ink-soft); line-height:1.5;
}
.note-box.gold { background:var(--bg-deep); border-color:var(--line-strong); color:var(--ink-soft); }

/* ============================================================
   MODAL & TOAST
   ============================================================ */
.modal-backdrop {
  position:fixed; inset:0; background:rgba(20,20,20,.45); z-index:100;
  display:grid; place-items:center; padding:1.2rem; backdrop-filter:blur(3px);
  animation:fadeIn .18s ease;
}
.modal {
  background:var(--card); border-radius:14px; box-shadow:0 24px 70px -20px rgba(0,0,0,.45);
  width:min(560px, 100%); max-height:86vh; overflow:auto; padding:1.4rem;
  animation:popIn .22s cubic-bezier(.2,1.4,.5,1);
}
.modal h3 { font-weight:700; font-size:1.25rem; margin-bottom:.4rem; letter-spacing:-.01em; }
.modal p { color:var(--ink-soft); line-height:1.55; font-size:.95rem; }
.modal-actions { display:flex; gap:.6rem; justify-content:flex-end; margin-top:1.2rem; flex-wrap:wrap; }
.modal .pick-list { display:flex; flex-direction:column; gap:.5rem; margin-top:.9rem; }
.pick-item {
  text-align:left; background:var(--bg); border:1.5px solid var(--line); border-radius:9px;
  padding:.7rem .9rem; cursor:pointer; font-family:var(--font-ui); font-size:.95rem;
}
.pick-item:active { border-color:var(--brand); }
.pick-item .pi-main { font-weight:600; display:block; }
.pick-item .pi-sub { color:var(--ink-soft); font-size:.83rem; }

.toast {
  position:fixed; left:50%; bottom:max(1.4rem, env(safe-area-inset-bottom)); transform:translateX(-50%);
  background:var(--ink); color:#fff; font-weight:600; font-size:.95rem;
  border-radius:999px; padding:.75rem 1.5rem; z-index:200; box-shadow:0 10px 30px -8px rgba(0,0,0,.4);
  animation:toastIn .25s cubic-bezier(.2,1.4,.5,1); max-width:90vw; text-align:center;
}

/* --- Sync-Status --- */
.sync-status { display:inline-flex; align-items:center; gap:.4rem; font-size:.8rem; color:var(--ink-soft); }
.sync-dot { font-size:.9em; }
.sync-dot.aus { color:var(--ink-faint); }
.sync-dot.laeuft { color:var(--brand); animation:syncPulse 1.1s ease infinite; }
.sync-dot.aktuell { color:var(--ok); }
.sync-dot.offline { color:var(--ink-faint); }
.sync-dot.fehler { color:var(--brand); }
@keyframes syncPulse { 50% { opacity:.35; } }

@keyframes fadeIn { from { opacity:0; } }
@keyframes popIn { from { opacity:0; transform:scale(.92) translateY(10px); } }
@keyframes toastIn { from { opacity:0; transform:translateX(-50%) translateY(14px); } }

@media (max-width:640px) {
  .editor-head { flex-wrap:wrap; }
  .editor-head-title { order:3; flex-basis:100%; padding-top:.2rem; }
  .home-head { gap:1rem; }
}
