:root{
  --paper:#f5f0e6;--paper-2:#efe8da;--ink:#22201b;--ink-soft:#5c564c;
  --line:#d8cfbd;--line-strong:#c3b8a1;--green:#2f5d50;--green-soft:#e3ece6;
  --rust:#a4472b;--rust-soft:#f1e2da;--gold:#b58a3c;--card:#fbf8f1;
  --shadow:0 1px 2px rgba(34,32,27,.06),0 6px 22px rgba(34,32,27,.07);--radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Public Sans',-apple-system,sans-serif;color:var(--ink);
  background:radial-gradient(120% 80% at 100% 0,rgba(181,138,60,.07),transparent 60%),
    radial-gradient(100% 70% at 0 100%,rgba(47,93,80,.06),transparent 55%),var(--paper);
  -webkit-font-smoothing:antialiased;font-variant-numeric:tabular-nums;min-height:100%}
.num{font-variant-numeric:tabular-nums}

/* Header */
header{border-bottom:1px solid var(--line);background:linear-gradient(180deg,rgba(251,248,241,.9),rgba(245,240,230,.6));backdrop-filter:blur(6px);position:sticky;top:0;z-index:30}
.head-inner{max-width:1180px;margin:0 auto;padding:16px 26px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:13px;margin-right:auto}
.mark{width:42px;height:42px;border-radius:11px;flex:0 0 auto;background:var(--green);color:#f5f0e6;display:grid;place-items:center;font-family:'Fraunces',serif;font-weight:600;font-size:22px;box-shadow:var(--shadow)}
.mark.big{width:60px;height:60px;font-size:30px;border-radius:15px;margin:0 auto 16px}
.brand h1{font-family:'Fraunces',serif;font-weight:600;font-size:24px;letter-spacing:-.01em;line-height:1}
.brand p{font-size:12.5px;color:var(--ink-soft);margin-top:3px}
.head-stat{display:flex;flex-direction:column;align-items:flex-end;padding:0 16px;border-left:1px solid var(--line)}
.head-stat .k{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.head-stat .v{font-family:'Fraunces',serif;font-size:21px;font-weight:600;margin-top:2px}
.v.pos{color:var(--green)} .v.neg{color:var(--rust)}
.user-box{display:flex;align-items:center;gap:10px;padding-left:16px;border-left:1px solid var(--line)}
.who{font-size:13px;color:var(--ink-soft);font-weight:600}

/* Nav */
nav{max-width:1180px;margin:0 auto;padding:0 26px;display:flex;gap:4px;overflow-x:auto}
.tab{appearance:none;border:0;background:none;cursor:pointer;font-family:inherit;padding:13px 15px 11px;font-size:14.5px;font-weight:600;color:var(--ink-soft);border-bottom:2.5px solid transparent;white-space:nowrap;transition:.18s}
.tab:hover{color:var(--ink)} .tab.active{color:var(--green);border-color:var(--green)}

/* Layout */
main{max-width:1180px;margin:0 auto;padding:30px 26px 80px}
.section-head{display:flex;align-items:flex-end;gap:14px;margin-bottom:22px;flex-wrap:wrap}
.section-head h2{font-family:'Fraunces',serif;font-weight:600;font-size:27px;letter-spacing:-.01em}
.section-head p{color:var(--ink-soft);font-size:14px;margin-bottom:3px}
.spacer{margin-left:auto}

/* Buttons */
.btn{appearance:none;font-family:inherit;font-weight:600;font-size:14px;cursor:pointer;border-radius:10px;padding:10px 16px;border:1px solid var(--line-strong);background:var(--card);color:var(--ink);transition:.15s;display:inline-flex;align-items:center;gap:7px}
.btn:hover{border-color:var(--ink-soft);transform:translateY(-1px)}
.btn.primary{background:var(--green);border-color:var(--green);color:#f5f0e6}
.btn.primary:hover{background:#264c41}
.btn.danger{color:var(--rust);border-color:var(--rust-soft)}
.btn.danger:hover{background:var(--rust-soft);border-color:var(--rust)}
.btn.sm{padding:6px 11px;font-size:13px}
.btn.ghost{border-color:transparent;background:transparent}
.btn.ghost:hover{background:var(--paper-2)}
.btn.block{width:100%;justify-content:center;margin-top:8px}

/* KPI */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:30px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}
.kpi .k{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-soft)}
.kpi .v{font-family:'Fraunces',serif;font-size:30px;font-weight:600;margin-top:8px;line-height:1}
.kpi .sub{font-size:12.5px;color:var(--ink-soft);margin-top:7px}
.kpi.accent{background:linear-gradient(135deg,var(--green),#27433a);border-color:var(--green)}
.kpi.accent .k,.kpi.accent .sub{color:rgba(245,240,230,.72)} .kpi.accent .v{color:#f5f0e6}

/* Panel & Table */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;margin-bottom:24px}
.panel-head{padding:15px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.panel-head h3{font-family:'Fraunces',serif;font-size:18px;font-weight:600}
table{width:100%;border-collapse:collapse;font-size:14px}
th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);font-weight:600;padding:12px 16px;border-bottom:1px solid var(--line);background:var(--paper-2)}
td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
tr:last-child td{border-bottom:0}
tbody tr{transition:.12s} tbody tr:hover{background:var(--paper-2)}
td.r,th.r{text-align:right} td.c,th.c{text-align:center}
.money-pos{color:var(--green);font-weight:600} .money-neg{color:var(--rust);font-weight:600}
.pill{display:inline-block;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600}
.pill.green{background:var(--green-soft);color:var(--green)} .pill.rust{background:var(--rust-soft);color:var(--rust)}
.pill.gray{background:var(--paper-2);color:var(--ink-soft)} .pill.gold{background:#f4ead2;color:#7a5c20}
.row-actions{display:flex;gap:6px;justify-content:flex-end}
.icon-btn{appearance:none;border:0;background:none;cursor:pointer;color:var(--ink-soft);padding:5px;border-radius:7px;font-size:13px;font-weight:600}
.icon-btn:hover{background:var(--paper);color:var(--ink)} .icon-btn.del:hover{color:var(--rust)}
.empty{padding:46px 20px;text-align:center;color:var(--ink-soft)}
.empty .big{font-family:'Fraunces',serif;font-size:19px;color:var(--ink);margin-bottom:6px}

/* Forms */
.filters{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
select,input,textarea{font-family:inherit;font-size:14px;color:var(--ink);background:var(--paper);border:1px solid var(--line-strong);border-radius:9px;padding:9px 11px;width:100%}
select{cursor:pointer} input:focus,select:focus,textarea:focus{outline:2px solid var(--green);outline-offset:0;border-color:var(--green)}
.inline-select{width:auto;min-width:150px;padding:8px 11px}
textarea{resize:vertical;min-height:64px}

/* Modal */
.overlay{position:fixed;inset:0;background:rgba(34,32,27,.42);backdrop-filter:blur(3px);z-index:50;display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.overlay.show{display:flex}
.modal{background:var(--card);border-radius:18px;width:100%;max-width:560px;box-shadow:0 24px 70px rgba(34,32,27,.3);border:1px solid var(--line);animation:pop .22s ease}
@keyframes pop{from{transform:translateY(14px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-head{padding:20px 24px;border-bottom:1px solid var(--line);display:flex;align-items:center}
.modal-head h3{font-family:'Fraunces',serif;font-size:21px;font-weight:600}
.modal-body{padding:22px 24px;display:grid;grid-template-columns:1fr 1fr;gap:15px}
.modal-body .full{grid-column:1/-1}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.modal-foot{padding:16px 24px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}
.close-x{margin-left:auto;appearance:none;border:0;background:none;font-size:22px;cursor:pointer;color:var(--ink-soft);line-height:1}
.close-x:hover{color:var(--ink)}

/* Login */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:36px 34px;width:100%;max-width:380px;box-shadow:0 18px 60px rgba(34,32,27,.12);text-align:center}
.login-card h1{font-family:'Fraunces',serif;font-size:30px;font-weight:600}
.login-sub{color:var(--ink-soft);font-size:14px;margin:4px 0 22px}
.login-card .field{text-align:left;margin-bottom:14px}
.login-error{background:var(--rust-soft);border:1px solid var(--rust);color:var(--rust);padding:11px;border-radius:10px;font-size:13.5px;margin-bottom:16px}

/* Detail / Notes */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:8px}
.dl{display:flex;flex-direction:column;gap:3px;padding:12px 14px;background:var(--paper-2);border-radius:10px}
.dl .k{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
.dl .v{font-size:15px;font-weight:600}
.note-card{padding:14px 16px;border-bottom:1px solid var(--line)}
.note-card:last-child{border-bottom:0}
.note-card .nt{font-weight:600} .note-card .nd{font-size:12px;color:var(--ink-soft)}
.note-card .nc{font-size:14px;color:var(--ink-soft);margin-top:5px;white-space:pre-wrap}
.back-link{cursor:pointer;color:var(--green);font-weight:600;font-size:14px;border:0;background:none;padding:0;margin-bottom:6px}
.checkrow{display:flex;align-items:center;gap:8px;padding:7px 0}
.checkrow input{width:auto}
@media(max-width:620px){
  .modal-body,.detail-grid{grid-template-columns:1fr}
  .head-stat,.who{display:none}
  main,nav,.head-inner{padding-left:14px;padding-right:14px}
  table{font-size:13px} th,td{padding:10px 11px}
}

/* Objekt-Titelfoto */
.obj-hero{display:block;width:100%;max-height:360px;object-fit:cover}
.obj-thumb{width:46px;height:46px;border-radius:9px;object-fit:cover;flex:0 0 auto;border:1px solid var(--line)}

/* Dokumenten-Ordner (Reiter) */
.fchips{display:flex;flex-wrap:wrap;gap:8px;padding:14px 16px;border-bottom:1px solid var(--line)}
.fchip{appearance:none;border:1px solid var(--line-strong);background:var(--paper);color:var(--ink-soft);
  border-radius:99px;padding:6px 13px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:7px;font-family:inherit}
.fchip:hover{border-color:var(--ink-soft);color:var(--ink)}
.fchip.active{background:var(--green);border-color:var(--green);color:#f5f0e6}
.fcount{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;border-radius:99px;background:rgba(0,0,0,.08);font-size:11px}
.fchip.active .fcount{background:rgba(255,255,255,.25)}
