/* Sanierungs-PM — Dark Theme, mobil-first */
:root {
  --bg: #0f1217;
  --bg-2: #13161c;
  --surface: #1a1f27;
  --surface-2: #212732;
  --border: #2b323d;
  --text: #e6e9ef;
  --text-dim: #9aa4b2;
  --muted: #6b7585;
  --primary: #4c8dff;
  --primary-600: #3b78e0;
  --ok: #34c759;
  --warn: #ffb020;
  --err: #ff5d5d;
  --info: #4c8dff;
  --radius: 12px;
  --radius-sm: 8px;
  --shadow: 0 6px 24px rgba(0,0,0,.35);
  --maxw: 1100px;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--primary); text-decoration: none; }
h1, h2, h3 { line-height: 1.25; margin: 0 0 .5rem; }
h1 { font-size: 1.5rem; }
.muted { color: var(--muted); }
code { background: var(--surface-2); padding: .1em .4em; border-radius: 4px; font-size: .9em; }

/* Topbar */
.topbar {
  position: sticky; top: 0; z-index: 20;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: .7rem 1rem;
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
  padding-top: calc(.7rem + env(safe-area-inset-top));
}
.brand { display: flex; align-items: center; gap: .55rem; color: var(--text); font-weight: 700; }
.brand-mark { color: var(--primary); font-size: 1.2rem; letter-spacing: -2px; }
.brand-name { font-size: 1.02rem; }
.topnav { display: flex; align-items: center; gap: .75rem; }
.who { color: var(--text-dim); font-size: .9rem; }
.inline { display: inline; margin: 0; }

/* Container */
.container { max-width: var(--maxw); margin: 0 auto; padding: 1.1rem 1rem 4rem; }
.page-head { display: flex; align-items: center; gap: .75rem; margin-bottom: 1rem; }

/* Flash */
.flash { padding: .7rem .9rem; border-radius: var(--radius-sm); margin-bottom: 1rem; border: 1px solid var(--border); font-size: .95rem; }
.flash-ok { background: rgba(52,199,89,.12); border-color: rgba(52,199,89,.4); }
.flash-err { background: rgba(255,93,93,.12); border-color: rgba(255,93,93,.4); }
.flash-info { background: rgba(76,141,255,.12); border-color: rgba(76,141,255,.4); }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .6rem 1rem; border-radius: var(--radius-sm); border: 1px solid var(--border);
  background: var(--surface-2); color: var(--text); font-size: .95rem; font-weight: 600;
  cursor: pointer; transition: background .15s, border-color .15s; -webkit-tap-highlight-color: transparent;
}
.btn:hover { background: var(--surface); }
.btn-primary { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn-primary:hover { background: var(--primary-600); }
.btn-ghost { background: transparent; }
.btn-sm { padding: .35rem .7rem; font-size: .85rem; }
.btn-block { display: flex; width: 100%; margin-top: .4rem; }

/* Forms */
.form { display: flex; flex-direction: column; gap: .9rem; margin-top: 1rem; }
.field { display: flex; flex-direction: column; gap: .35rem; }
.field > span { font-size: .85rem; color: var(--text-dim); }
input, select, textarea {
  width: 100%; padding: .65rem .75rem; font-size: 1rem;
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--radius-sm);
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--primary); }

/* Cards / grid */
.grid { display: grid; grid-template-columns: 1fr; gap: .9rem; }
@media (min-width: 620px) { .grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 920px) { .grid { grid-template-columns: repeat(3, 1fr); } }
.card {
  display: block; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1rem; color: var(--text); box-shadow: var(--shadow);
}
.card:hover { border-color: #3a4250; }
.card-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: .4rem; }
.card-foot { margin-top: .7rem; font-size: .85rem; }
.ve-nr { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; color: var(--text-dim); font-size: .85rem; }
.project-card h3 { margin: .2rem 0; }

/* Badges */
.badge { display: inline-block; padding: .15rem .55rem; border-radius: 999px; font-size: .75rem; font-weight: 600; border: 1px solid var(--border); color: var(--text-dim); }
.badge-soft { background: var(--surface-2); }
.status-aktiv { color: var(--ok); border-color: rgba(52,199,89,.4); }
.status-pausiert { color: var(--warn); border-color: rgba(255,176,32,.4); }
.status-abgeschlossen { color: var(--muted); }

/* Empty */
.empty { text-align: center; padding: 3rem 1rem; border: 1px dashed var(--border); border-radius: var(--radius); }

/* Guest (login/setup) */
.guest { display: flex; min-height: 100vh; min-height: 100dvh; }
.guest-wrap { margin: auto; width: 100%; max-width: 400px; padding: 1.5rem; }
.guest-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.6rem; box-shadow: var(--shadow); }
.guest-brand { display: flex; align-items: center; gap: .6rem; justify-content: center; margin-bottom: 1rem; font-weight: 700; }
.guest-title { text-align: center; font-size: 1.3rem; }

/* Checklist (setup) */
.checklist { list-style: none; padding: 0; margin: 1rem 0; display: flex; flex-direction: column; gap: .5rem; }
.checklist li { padding: .6rem .8rem; border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--bg); }
.checklist li small { display: block; color: var(--muted); font-size: .8rem; margin-top: .15rem; }
.checklist li.ok { border-color: rgba(52,199,89,.4); }
.checklist li.err { border-color: rgba(255,93,93,.4); }

.trace { background: #0b0d11; border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 1rem; overflow: auto; font-size: .8rem; color: #ffb3b3; }

/* ---- M2/M3: Projekt, Gewerke, Angebote ---- */
.page-head-actions { margin-left: auto; display: flex; gap: .5rem; align-items: center; }
.section-head { display: flex; align-items: center; justify-content: space-between; gap: .75rem; margin: 1.6rem 0 .8rem; }
.section-head h2 { margin: 0; font-size: 1.1rem; }
.mt { margin-top: 1rem; }
.push-right { margin-left: auto; }

/* Tiles */
.tiles { display: grid; grid-template-columns: repeat(2, 1fr); gap: .7rem; margin: 1rem 0; }
@media (min-width: 620px) { .tiles { grid-template-columns: repeat(4, 1fr); } }
.tile { display: flex; flex-direction: column; gap: .15rem; padding: .9rem 1rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); color: var(--text); }
.tile-num { font-size: 1.6rem; font-weight: 700; line-height: 1; }
.tile-lbl { font-size: .8rem; color: var(--muted); }
a.tile:hover { border-color: #3a4250; }

/* Listen */
.list { display: flex; flex-direction: column; gap: .4rem; }
.list-row { display: flex; align-items: center; gap: .7rem; padding: .7rem .9rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); }
a.list-row:hover { border-color: #3a4250; }
.list-row.static { cursor: default; }
.list-main { flex: 1 1 auto; min-width: 0; }
.list-meta { color: var(--muted); font-size: .82rem; white-space: nowrap; }
.sub { font-size: .8rem; color: var(--muted); margin-top: .15rem; }

/* Tabellen / Vergleich */
.table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: var(--radius); }
.table { width: 100%; border-collapse: collapse; font-size: .92rem; min-width: 560px; }
.table th, .table td { padding: .55rem .7rem; text-align: left; border-bottom: 1px solid var(--border); vertical-align: top; }
.table thead th { background: var(--surface-2); color: var(--text-dim); font-size: .78rem; text-transform: uppercase; letter-spacing: .03em; }
.table .num { text-align: right; white-space: nowrap; font-variant-numeric: tabular-nums; }
.table tbody tr:last-child td { border-bottom: none; }
.compare tr.is-rec td { background: rgba(76,141,255,.08); }
.compare tr.is-rejected td { opacity: .55; }
.compare .star { color: var(--warn); }
.compare .note-row td { background: var(--bg-2); color: var(--text-dim); font-size: .85rem; padding-top: .3rem; }
.note-label { color: var(--muted); }
.actions-cell { white-space: nowrap; }
.row-actions { display: flex; gap: .25rem; justify-content: flex-end; }
.tag { display: inline-block; margin-left: .4rem; padding: .05rem .4rem; border-radius: 4px; font-size: .68rem; font-weight: 700; }
.tag-min { background: rgba(52,199,89,.18); color: var(--ok); }

/* Buttons Ergänzung */
.btn-danger { background: transparent; border-color: rgba(255,93,93,.5); color: var(--err); }
.btn-danger:hover { background: rgba(255,93,93,.12); }
.btn-xs { padding: .2rem .45rem; font-size: .8rem; line-height: 1; }

/* Formular-Layout */
.form-narrow { max-width: 640px; }
.form-row { display: grid; grid-template-columns: 1fr; gap: .9rem; }
@media (min-width: 560px) { .form-row { grid-template-columns: repeat(2, 1fr); } .form-row:has(.field:nth-child(3)) { grid-template-columns: repeat(3, 1fr); } }
.form-actions { display: flex; gap: .6rem; align-items: center; margin-top: .4rem; }
.field.check { flex-direction: row; align-items: center; gap: .5rem; }
.field.check input { width: auto; }

/* Projekt-Subnav */
.projbar { position: sticky; top: 49px; z-index: 15; background: var(--bg-2); border-bottom: 1px solid var(--border); }
.projbar-inner { max-width: var(--maxw); margin: 0 auto; padding: .5rem 1rem; display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.projbar-title { color: var(--text); font-weight: 600; font-size: .92rem; }
.subnav { display: flex; gap: .3rem; margin-left: auto; overflow-x: auto; }
.subnav a { padding: .3rem .7rem; border-radius: 999px; color: var(--text-dim); font-size: .88rem; white-space: nowrap; }
.subnav a:hover { background: var(--surface-2); }
.subnav a.is-active { background: var(--primary); color: #fff; }

/* Details/Panel */
.panel, .ref { border: 1px solid var(--border); border-radius: var(--radius); margin-top: 1rem; background: var(--surface); }
.panel > summary, .ref > summary { padding: .8rem 1rem; cursor: pointer; font-weight: 600; }
.panel[open] > summary, .ref[open] > summary { border-bottom: 1px solid var(--border); }
.panel > form { padding: 1rem; }
.ref-body { padding: 0 1rem 1rem; }
.kv { display: grid; grid-template-columns: max-content 1fr; gap: .2rem .9rem; margin: .3rem 0 1rem; font-size: .9rem; }
.kv dt { color: var(--muted); }
.kv dd { margin: 0; }

/* Status-Badges */
.gstatus-offen, .astatus-eingegangen, .bstatus-kein_mangel { color: var(--text-dim); }
.gstatus-in_ausschreibung, .gstatus-angebote, .astatus-empfohlen, .prio-Pruefen { color: var(--info); border-color: rgba(76,141,255,.4); }
.gstatus-vergeben, .gstatus-abgeschlossen, .astatus-beauftragt, .bstatus-erledigt, .prio-Erledigt { color: var(--ok); border-color: rgba(52,199,89,.4); }
.gstatus-in_arbeit, .astatus-in_pruefung, .bstatus-teilgeklaert, .prio-Mittel { color: var(--warn); border-color: rgba(255,176,32,.4); }
.astatus-abgelehnt { color: var(--muted); }
.bstatus-offen, .prio-Hoch { color: var(--err); border-color: rgba(255,93,93,.4); }
.prio-KeinMangel { color: var(--muted); }

/* ---- M5/M6: Dokumente, Bautagebuch, Freigaben ---- */
.container-narrow { max-width: 720px; }

/* Filter-Chips */
.filterbar { display: flex; gap: .4rem; flex-wrap: wrap; margin: 1rem 0; }
.chip { padding: .25rem .7rem; border-radius: 999px; border: 1px solid var(--border); background: var(--surface); color: var(--text-dim); font-size: .85rem; }
.chip:hover { border-color: #3a4250; }
.chip.is-active { background: var(--primary); border-color: var(--primary); color: #fff; }

/* Galerie */
.gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: .7rem; }
@media (min-width: 560px) { .gallery { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 860px) { .gallery { grid-template-columns: repeat(4, 1fr); } }
.doc-card { position: relative; display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; color: var(--text); }
.doc-thumb { display: flex; align-items: center; justify-content: center; aspect-ratio: 4 / 3; background: var(--bg-2); overflow: hidden; }
.doc-thumb img { width: 100%; height: 100%; object-fit: cover; }
.doc-ext { font-family: ui-monospace, Menlo, monospace; color: var(--text-dim); font-weight: 700; font-size: .95rem; letter-spacing: .05em; }
.doc-meta { padding: .55rem .65rem; display: flex; flex-direction: column; gap: .25rem; min-width: 0; }
.doc-name { font-size: .85rem; font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.doc-sub { font-size: .72rem; display: flex; gap: .4rem; align-items: center; flex-wrap: wrap; }
.doc-del { position: absolute; top: .3rem; right: .3rem; margin: 0; }
.doc-del button { background: rgba(0,0,0,.55); border-color: transparent; }

/* Timeline (Bautagebuch) */
.timeline { display: flex; flex-direction: column; gap: .8rem; }
.tl-item { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: .9rem 1rem; }
.tl-head { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.tl-date { font-weight: 700; }
.tl-title { font-weight: 600; margin-top: .4rem; }
.tl-text { margin-top: .25rem; color: var(--text-dim); font-size: .95rem; }
.tl-foot { margin-top: .5rem; font-size: .78rem; }
.tl-fotos { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: .6rem; }
.tl-foto { width: 92px; height: 92px; border-radius: var(--radius-sm); overflow: hidden; background: var(--bg-2); display: flex; align-items: center; justify-content: center; border: 1px solid var(--border); }
.tl-foto img { width: 100%; height: 100%; object-fit: cover; }

/* Freigabe-Links */
.share-row { align-items: flex-start; }
.share-link { display: flex; gap: .4rem; margin-top: .5rem; }
.share-link input { font-size: .8rem; padding: .35rem .5rem; font-family: ui-monospace, Menlo, monospace; }
.share-head { margin-bottom: 1rem; }

/* PDF-Import: Unterformulare */
.subform { border: 1px solid var(--border); border-radius: var(--radius-sm); padding: .8rem; background: var(--bg-2); }
details.subform > summary { cursor: pointer; font-size: .9rem; color: var(--text-dim); }
details.subform[open] > summary { margin-bottom: .6rem; }

/* Akquise / Firmenliste */
.akstatus-offen { color: var(--text-dim); }
.akstatus-interesse { color: var(--info); border-color: rgba(76,141,255,.4); }
.akstatus-zurueckgestellt { color: var(--warn); border-color: rgba(255,176,32,.4); }
.akstatus-absage { color: var(--muted); }
.akstatus-angebot { color: var(--ok); border-color: rgba(52,199,89,.4); }
.table .nowrap-s { font-size: .82rem; white-space: nowrap; }
.table td.bem { font-size: .85rem; color: var(--text-dim); max-width: 22rem; }

/* Termine */
.termin { display: flex; gap: .8rem; align-items: flex-start; }
.termin-date { flex: 0 0 auto; width: 3rem; text-align: center; background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: .3rem 0; }
.termin-date .d { display: block; font-size: 1.3rem; font-weight: 700; line-height: 1; }
.termin-date .m { display: block; font-size: .72rem; color: var(--muted); text-transform: uppercase; }
.termin-body { flex: 1 1 auto; min-width: 0; }
.termin .dep { color: var(--info); font-size: .82rem; }
.timeline.dimmed .tl-item { opacity: .65; }
.termin.is-off strong { text-decoration: line-through; }
.ttyp-besichtigung { color: var(--info); border-color: rgba(76,141,255,.4); }
.ttyp-massnahme { color: var(--warn); border-color: rgba(255,176,32,.4); }
.ttyp-sonstiges { color: var(--text-dim); }
.tstatus-geplant { color: var(--text-dim); }
.tstatus-bestaetigt { color: var(--info); border-color: rgba(76,141,255,.4); }
.tstatus-erledigt { color: var(--ok); border-color: rgba(52,199,89,.4); }
.tstatus-abgesagt { color: var(--err); border-color: rgba(255,93,93,.4); }

/* Gantt / Zeitplan */
.gantt { border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; background: var(--surface); margin-top: .8rem; }
.gantt-toolbar { display: flex; flex-wrap: wrap; gap: .4rem .9rem; align-items: center; padding: .55rem .7rem; border-bottom: 1px solid var(--border); background: var(--bg-2); }
.g-leg { display: inline-flex; align-items: center; gap: .35rem; font-size: .82rem; cursor: pointer; user-select: none; }
.g-leg input { width: auto; margin: 0; }
.g-swatch { width: .8rem; height: .8rem; border-radius: 3px; display: inline-block; }
.g-zoom { margin-left: auto; display: flex; align-items: center; gap: .3rem; font-size: .82rem; color: var(--muted); }
.gantt-main { display: flex; align-items: flex-start; }
.gantt-labels { flex: 0 0 auto; width: 170px; background: var(--surface); border-right: 1px solid var(--border); }
.g-axis-spacer { height: 30px; border-bottom: 1px solid var(--border); }
.g-label { height: 34px; line-height: 34px; padding: 0 .6rem; font-size: .8rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; border-bottom: 1px solid var(--border); color: var(--text-dim); }
.gantt-time { flex: 1 1 auto; overflow-x: auto; }
.gantt-canvas { position: relative; }
.g-grid { position: absolute; width: 1px; background: var(--border); opacity: .45; }
.g-monthlbl { position: absolute; top: 7px; font-size: .7rem; color: var(--muted); white-space: nowrap; }
.g-row { position: absolute; left: 0; height: 34px; border-bottom: 1px solid var(--border); }
.g-bar { position: absolute; height: 16px; border-radius: 4px; color: #fff; font-size: .68rem; line-height: 16px; padding: 0 5px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; box-shadow: 0 1px 2px rgba(0,0,0,.35); text-shadow: 0 1px 1px rgba(0,0,0,.4); cursor: default; }
.g-ms { position: absolute; width: 12px; height: 12px; transform: rotate(45deg); border-radius: 2px; box-shadow: 0 1px 2px rgba(0,0,0,.45); cursor: default; }
.g-line { position: absolute; top: 0; width: 0; }
.g-line.today { border-left: 2px solid var(--primary); }
.g-line.eck { border-left: 1px dashed #ff5d5d; opacity: .75; }
.g-linelbl { position: absolute; top: 7px; font-size: .64rem; white-space: nowrap; pointer-events: none; }

/* Abhängigkeiten / Verzug */
.tl-item .conflict { color: var(--err); font-size: .82rem; }
/* Kalkulation */
.kbudget { max-width: 8rem; text-align: right; padding: .35rem .5rem; }
.kdiff.over { color: var(--err); }
.kdiff.under { color: var(--ok); }
.table tfoot th { border-top: 2px solid var(--border); background: var(--surface-2); }

/* Dashboard-Erinnerungen */
.reminders { display: flex; flex-direction: column; gap: .4rem; margin: 1rem 0; }
.rem { padding: .55rem .8rem; border-radius: var(--radius-sm); border: 1px solid var(--border); font-size: .9rem; }
.rem-warn { background: rgba(255,176,32,.1); border-color: rgba(255,176,32,.4); }
.rem-info { background: rgba(76,141,255,.1); border-color: rgba(76,141,255,.35); }

/* Befund / Mangel Listen */
.befund-row { align-items: flex-start; }
.befund-actions { display: flex; flex-direction: column; gap: .4rem; align-items: flex-end; }
.befund-desc { font-size: .9rem; color: var(--text-dim); margin-top: .35rem; }
.befund-antwort { font-size: .9rem; margin-top: .3rem; }
.status-select { font-size: .8rem; padding: .25rem .4rem; width: auto; border-radius: 999px; }
.status-select.bstatus-offen, .status-select.mstatus-offen { border-color: rgba(255,93,93,.5); }
.status-select.bstatus-erledigt, .status-select.mstatus-abgenommen { border-color: rgba(52,199,89,.5); }
.mprio-hoch { color: var(--err); border-color: rgba(255,93,93,.4); }
.mprio-mittel { color: var(--warn); border-color: rgba(255,176,32,.4); }
.mprio-niedrig { color: var(--text-dim); }

/* Druckansicht (Strg+P -> PDF): hell, ohne Navigation/Buttons */
@media print {
  body { background: #fff !important; color: #000 !important; }
  .topbar, .projbar, .page-head-actions, .filterbar, .btn, form.inline, .doc-del,
  details.panel > summary, .form-actions, .reminders .rem-info { display: none !important; }
  .container { max-width: 100%; padding: 0; }
  .card, .tile, .list-row, .table-wrap, .panel, .gantt { background: #fff !important; border-color: #ccc !important; box-shadow: none !important; }
  .table th, .table td { border-color: #ccc !important; }
  * { color: #000 !important; }
  a { text-decoration: none; }
}
