:root{
  --ink:#16202c; --ink-soft:#48566a; --ink-faint:#8693a4;
  --paper:#f5f7f9; --surface:#fff; --line:#e4e8ee; --line-strong:#d3d9e2;
  --paid:#0e8c6b; --paid-soft:#e3f3ed; --owed:#c2731b; --owed-soft:#fbeede;
  --danger:#bb3b2c; --danger-soft:#fbe7e4; --accent:#1f5f8b;
  --radius:14px; --shadow:0 1px 2px rgba(22,32,44,.04),0 8px 24px rgba(22,32,44,.06);
  --serif:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,serif;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.5;-webkit-font-smoothing:antialiased;font-variant-numeric:tabular-nums}
h1,h2,h3{margin:0;font-weight:600;letter-spacing:-.01em}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:1rem}
.faint{color:var(--ink-faint)}.muted{color:var(--ink-soft)}
.spacer{flex:1}

.btn-primary{width:100%;padding:13px;border:none;border-radius:10px;background:var(--ink);color:#fff;font-weight:600;font-size:.98rem}
.btn-primary:hover{opacity:.92}
.btn-soft{background:var(--paper);border:1px solid var(--line);border-radius:9px;padding:8px 13px;font-size:.82rem;font-weight:600;color:var(--ink-soft)}
.btn-soft:hover{border-color:var(--line-strong);color:var(--ink)}

/* ---------- AUTH ---------- */
.auth-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,#1a2735,#0f1822)}
.auth-card{width:100%;max-width:420px;background:var(--surface);border-radius:18px;padding:34px 32px;box-shadow:0 24px 60px rgba(0,0,0,.35)}
.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.auth-brand .mark{width:40px;height:40px;border-radius:10px;background:var(--ink);display:flex;align-items:center;justify-content:center}
.auth-brand b{display:block;font-size:1.1rem}.auth-brand span{font-size:.8rem;color:var(--ink-faint)}
.auth-tabs{display:flex;gap:6px;background:var(--paper);border-radius:10px;padding:4px;margin-bottom:22px}
.auth-tab{flex:1;border:none;background:transparent;padding:9px;border-radius:8px;font-weight:600;font-size:.9rem;color:var(--ink-soft)}
.auth-tab.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}
.auth-form label{display:block;font-size:.8rem;font-weight:600;color:var(--ink-soft);margin:14px 0 6px}
.auth-form input{width:100%;padding:12px 13px;border:1.5px solid var(--line-strong);border-radius:10px}
.auth-form input:focus{outline:none;border-color:var(--accent)}
.auth-form .btn-primary{margin-top:20px}
.auth-err{color:var(--danger);font-size:.85rem;min-height:1.1em;margin-top:10px}
.invite-banner{background:var(--paid-soft);color:var(--paid);border-radius:10px;padding:12px 14px;font-size:.88rem;margin-bottom:20px;font-weight:500}

/* ---------- TOPBAR ---------- */
.topbar{background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.topbar-in{max-width:1120px;margin:0 auto;padding:11px 22px;display:flex;align-items:center;gap:14px}
.brand{display:flex;align-items:center;gap:10px}
.brand .mark{width:32px;height:32px;border-radius:9px;background:var(--ink);display:flex;align-items:center;justify-content:center}
.brand .t{font-weight:600;letter-spacing:-.01em}
@media(max-width:640px){.brand .t{display:none}}

.dropdown{position:relative}
.dd-trigger{display:flex;align-items:center;gap:7px;background:var(--paper);border:1px solid var(--line);border-radius:9px;padding:7px 12px;font-weight:600;font-size:.86rem;color:var(--ink)}
.dd-trigger:hover{border-color:var(--line-strong)}
.dd-trigger.user{padding:4px;border-radius:50%}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem}
.dd-menu{display:none;position:absolute;top:calc(100% + 6px);left:0;min-width:220px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 36px rgba(22,32,44,.16);padding:6px;z-index:40}
.dd-menu.right{left:auto;right:0}
.dd-menu.open{display:block}
.dd-item{display:block;width:100%;text-align:left;border:none;background:transparent;padding:10px 12px;border-radius:8px;font-size:.88rem;color:var(--ink)}
.dd-item:hover{background:var(--paper)}
.dd-item.danger{color:var(--danger)}
.dd-item.active{background:var(--paid-soft);color:var(--paid);font-weight:600}
.dd-head{padding:10px 12px 12px;border-bottom:1px solid var(--line);margin-bottom:6px}
.dd-head b{display:block;font-size:.9rem}.dd-head span{font-size:.78rem}

.mode-toggle{display:flex;background:var(--paper);border:1px solid var(--line);border-radius:9px;padding:3px}
.mode-toggle button{border:none;background:transparent;padding:6px 13px;border-radius:7px;font-size:.82rem;font-weight:600;color:var(--ink-soft)}
.mode-toggle button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}

/* ---------- LAYOUT ---------- */
.wrap{max-width:1120px;margin:0 auto;padding:26px 22px 80px}
.section{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;margin-bottom:22px;box-shadow:var(--shadow)}
.section>h2{font-size:1.12rem;margin-bottom:4px}
.section>.desc{color:var(--ink-soft);font-size:.88rem;margin:0 0 18px}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.sec-head h2{font-size:1.12rem;margin-bottom:2px}.sec-head .desc{margin:0;color:var(--ink-soft);font-size:.88rem}

/* hero */
.hero{background:linear-gradient(150deg,#16202c,#243749);border-radius:var(--radius);padding:30px 32px;color:#eef2f6;display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:center;margin-bottom:22px;overflow:hidden}
.hero .eyebrow{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:#8fa6bd;font-weight:600;margin-bottom:8px}
.hero .freedate{font-family:var(--serif);font-size:2.5rem;line-height:1.05;font-weight:600;margin-bottom:6px}
.hero .freesub{color:#aebfd0;font-size:.95rem}
.horizon{height:110px;position:relative;display:flex;align-items:flex-end}
.horizon .track{position:absolute;inset:auto 0 0 0;height:10px;background:rgba(255,255,255,.12);border-radius:6px;overflow:hidden}
.horizon .fill{height:100%;background:linear-gradient(90deg,var(--paid),#3fc79a);border-radius:6px;transition:width .6s ease}
.horizon .pct{position:absolute;top:0;right:0;text-align:right}
.horizon .pct b{font-size:2.1rem;font-family:var(--serif);font-weight:600;display:block;line-height:1}
.horizon .pct span{font-size:.78rem;color:#aebfd0}

/* budget */
.budget-result{font-size:.9rem;font-weight:600}
.big-input label{display:block;font-size:.78rem;font-weight:600;color:var(--ink-soft);margin-bottom:8px}
.big-input .unit input{font-size:1.6rem;font-weight:600;width:220px;padding:10px 36px 10px 14px;border:1.5px solid var(--line);border-radius:11px;text-align:right}
.big-input .unit input:focus{outline:none;border-color:var(--accent)}
.unit{position:relative;display:inline-block}
.unit::after{content:attr(data-unit);position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--ink-faint);pointer-events:none}
.unit input{text-align:right}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.col-title{font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;display:flex;align-items:center;gap:7px}
.col-title.income{color:var(--paid)}.col-title.expense{color:var(--owed)}
.line-list{display:flex;flex-direction:column;gap:8px}
.line{display:grid;grid-template-columns:1fr 120px auto;gap:8px;align-items:center}
.line input{padding:9px 11px;border:1.5px solid var(--line);border-radius:9px;width:100%}
.line input:focus{outline:none;border-color:var(--accent)}
.line .amt{text-align:right}
.line .del{background:transparent;border:none;color:var(--ink-faint);padding:6px;border-radius:7px;line-height:0}
.line .del:hover{background:var(--danger-soft);color:var(--danger)}
.addline{margin-top:12px;background:transparent;border:1px dashed var(--line-strong);border-radius:9px;padding:9px 14px;font-weight:600;font-size:.85rem;color:var(--ink-soft);width:100%}
.addline.income:hover{border-color:var(--paid);color:var(--paid);background:var(--paid-soft)}
.addline.expense:hover{border-color:var(--owed);color:var(--owed);background:var(--owed-soft)}
.balance-bar{margin-top:22px;padding:16px 18px;border-radius:11px;background:var(--paper);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:.92rem}
.balance-bar b{font-size:1.3rem;font-weight:600}
.balance-bar .pos{color:var(--paid)}.balance-bar .neg{color:var(--danger)}

/* mode-conflict notice */
.mode-notice{background:var(--owed-soft);border:1px solid #f0d6a8;color:#7a4d12;border-radius:11px;padding:12px 15px;margin-bottom:18px;font-size:.88rem;line-height:1.5}
.mode-notice b{color:#5e3a0c}
.mode-notice .acts{margin-top:8px;display:flex;flex-wrap:wrap;gap:8px}
.link-act{background:var(--surface);border:1px solid #e5c98f;color:#7a4d12;border-radius:8px;padding:6px 12px;font-size:.8rem;font-weight:600}
.link-act:hover{background:#fff6e8}
.budget-result .src{color:var(--ink-faint);font-weight:500;font-size:.82rem}

/* cards */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:17px 18px;box-shadow:var(--shadow)}
.card .k{font-size:.76rem;color:var(--ink-soft);font-weight:600;margin-bottom:7px;display:flex;align-items:center;gap:6px}
.card .v{font-size:1.5rem;font-weight:600;letter-spacing:-.02em}.card .v.small{font-size:1.15rem}
.card .sub{font-size:.78rem;color:var(--ink-faint);margin-top:3px}
.dot{width:8px;height:8px;border-radius:50%}.dot.paid{background:var(--paid)}.dot.owed{background:var(--owed)}.dot.budget{background:var(--accent)}.dot.danger{background:var(--danger)}

/* debts */
.debt{display:grid;grid-template-columns:1.4fr .9fr .9fr 1fr auto;gap:12px;align-items:end;padding:14px 0;border-bottom:1px solid var(--line);position:relative}
.debt:first-of-type{padding-top:0}
.debt .fld label{display:block;font-size:.72rem;font-weight:600;color:var(--ink-soft);margin-bottom:5px}
.debt .fld input{width:100%;padding:9px 11px;border:1.5px solid var(--line);border-radius:9px}
.debt .fld input:focus{outline:none;border-color:var(--accent)}
.debt .fld .unit input{padding-right:30px}
.debt .res{font-size:.78rem;color:var(--ink-soft);align-self:center}
.debt .res b{color:var(--ink)}.debt .res.warn b{color:var(--danger)}
.debt .del{background:transparent;border:none;color:var(--ink-faint);padding:8px;border-radius:8px;line-height:0}
.debt .del:hover{background:var(--danger-soft);color:var(--danger)}
.addbtn{margin-top:16px;background:var(--paid-soft);color:var(--paid);border:1px dashed var(--paid);border-radius:10px;padding:11px 16px;font-weight:600;font-size:.9rem}
.addbtn:hover{background:#d7eee5}
.empty{text-align:center;color:var(--ink-faint);padding:26px;font-size:.92rem}

/* extra payments */
.extra{display:grid;grid-template-columns:1.2fr 1.4fr 1fr 1fr auto;gap:12px;align-items:end;padding:13px 0;border-bottom:1px solid var(--line);position:relative}
.extra:first-of-type{padding-top:0}
.extra .fld label{display:block;font-size:.72rem;font-weight:600;color:var(--ink-soft);margin-bottom:5px}
.extra .fld input,.extra .fld select{width:100%;padding:9px 11px;border:1.5px solid var(--line);border-radius:9px;background:var(--surface)}
.extra .fld input:focus,.extra .fld select:focus{outline:none;border-color:var(--accent)}
.extra .fld .unit input{padding-right:30px}
.extra .when{font-size:.78rem;color:var(--ink-soft);align-self:center}
.extra .when b{color:var(--ink)}
.extra .del{background:transparent;border:none;color:var(--ink-faint);padding:8px;border-radius:8px;line-height:0}
.extra .del:hover{background:var(--danger-soft);color:var(--danger)}

/* what-if slider */
.whatif{margin-top:18px;padding:16px 18px;border:1px solid var(--line);border-radius:12px;background:linear-gradient(180deg,#fff,#fafbfc)}
.whatif-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.whatif-head label{font-size:.85rem;font-weight:600;color:var(--ink-soft)}
.whatif-val{font-size:1.15rem;font-weight:600;color:var(--accent)}
#extraSlider{width:100%;accent-color:var(--paid)}
.whatif-out{margin-top:12px;font-size:.86rem;color:var(--ink-soft);min-height:1.2em}
.whatif-out b{color:var(--paid)}

/* table */
.tablewrap{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.tablescroll{max-height:430px;overflow:auto}
table{width:100%;border-collapse:collapse;font-size:.86rem}
thead th{position:sticky;top:0;background:var(--paper);text-align:right;padding:11px 14px;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);font-weight:600;border-bottom:1px solid var(--line);white-space:nowrap}
thead th:first-child{text-align:left}
tbody td{padding:9px 14px;text-align:right;border-bottom:1px solid var(--line);white-space:nowrap}
tbody td:first-child{text-align:left;font-weight:600;color:var(--ink-soft)}
tbody tr:hover{background:var(--paper)}tbody tr.year{background:#fafbfc}
.cell-owed{color:var(--owed)}.cell-neg{color:var(--danger)}.cell-pos{color:var(--paid)}

/* charts */
.chart-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:22px}
.chart-box h3{font-size:.92rem;margin-bottom:12px;color:var(--ink-soft)}

/* strategy */
.strat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.strat{border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.strat.best{border-color:var(--paid);background:var(--paid-soft)}
.strat .name{font-weight:600;font-size:.95rem;display:flex;align-items:center;gap:7px;margin-bottom:4px}
.strat .tag{font-size:.66rem;background:var(--paid);color:#fff;padding:2px 7px;border-radius:20px}
.strat .sub{font-size:.78rem;color:var(--ink-soft);margin-bottom:14px;min-height:2.4em}
.strat .metric{display:flex;justify-content:space-between;font-size:.84rem;padding:4px 0}
.strat-note{font-size:.82rem;color:var(--ink-soft);margin-top:16px;padding:12px 14px;background:var(--paper);border-radius:10px}

/* AI */
.drop{display:block;border:1.5px dashed var(--line-strong);border-radius:12px;padding:18px;text-align:center;color:var(--ink-soft);font-size:.88rem;cursor:pointer}.drop:hover{border-color:var(--accent);background:var(--paper)}
.drop input{display:none}.drop .filename{color:var(--ink);font-weight:600;margin-top:6px}
#aitext{width:100%;min-height:92px;margin-top:14px;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;resize:vertical}
#aitext:focus{outline:none;border-color:var(--accent)}
.btn-primary#runAi{width:auto;background:var(--accent);padding:12px 20px}
.ai-out{margin-top:18px;border:1px solid var(--line);border-radius:12px;padding:16px 18px;background:var(--paper)}
.ai-chip{display:flex;justify-content:space-between;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:9px;padding:9px 13px;font-size:.86rem;margin:8px 0}
.ai-chip .add{background:var(--paid);color:#fff;border:none;border-radius:7px;padding:6px 12px;font-size:.78rem;font-weight:600}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(15,24,34,.5);display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}
.modal{background:var(--surface);border-radius:16px;width:100%;max-width:560px;max-height:86vh;overflow:auto;box-shadow:0 24px 60px rgba(0,0,0,.3)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--surface)}
.close{border:none;background:var(--paper);width:32px;height:32px;border-radius:8px;font-size:1rem;color:var(--ink-soft)}
.modal-body{padding:22px 24px}
.modal-body h3{font-size:.92rem;margin:22px 0 12px;color:var(--ink-soft)}
.modal-body h3:first-child{margin-top:0}
.member,.invite-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 13px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px;font-size:.88rem}
.member .role{font-size:.72rem;background:var(--paper);padding:3px 9px;border-radius:20px;color:var(--ink-soft);font-weight:600}
.member .role.owner{background:var(--paid-soft);color:var(--paid)}
.mini-form{display:flex;gap:8px;margin-top:6px}
.mini-form input,.mini-form select{padding:9px 11px;border:1.5px solid var(--line);border-radius:9px}
.mini-form input{flex:1}
.mini-form button{background:var(--ink);color:#fff;border:none;border-radius:9px;padding:9px 16px;font-weight:600;font-size:.85rem}
.invite-link{font-family:ui-monospace,monospace;font-size:.74rem;background:var(--paper);padding:7px 10px;border-radius:8px;word-break:break-all;margin-top:6px;border:1px solid var(--line)}
.link-btn{background:transparent;border:none;color:var(--accent);font-weight:600;font-size:.78rem;padding:4px}
.xbtn{background:transparent;border:none;color:var(--ink-faint);font-weight:600}
.xbtn:hover{color:var(--danger)}
.field{margin-bottom:14px}
.field label{display:block;font-size:.78rem;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.field input{width:100%;padding:10px 12px;border:1.5px solid var(--line);border-radius:9px}

.disclaimer{font-size:.78rem;color:var(--ink-faint);line-height:1.6;border-top:1px solid var(--line);padding-top:20px}
.disclaimer a{color:var(--accent)}

.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(120%);background:var(--ink);color:#fff;padding:12px 20px;border-radius:11px;font-size:.88rem;box-shadow:0 10px 30px rgba(0,0,0,.25);transition:transform .3s;z-index:60}
.toast.show{transform:translateX(-50%) translateY(0)}

@media(max-width:820px){
  .hero{grid-template-columns:1fr;gap:18px;padding:24px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .chart-grid,.strat-grid,.two-col{grid-template-columns:1fr}
  .debt{grid-template-columns:1fr 1fr;gap:10px}.debt .res{grid-column:1/-1}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* deadlines & debt meta */
.debt-meta{margin-top:5px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.due-badge{font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:20px;background:var(--paper);color:var(--ink-soft);border:1px solid var(--line)}
.due-badge.soon{background:var(--owed-soft);color:#7a4d12;border-color:#f0d6a8}
.due-badge.overdue{background:var(--danger-soft);color:var(--danger);border-color:#f3c4bd}
.debt-note{font-size:.72rem;color:var(--ink-faint);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.next-deadline{font-size:.85rem;color:var(--ink-soft);background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:9px 13px;margin-bottom:16px}
.next-deadline.soon{background:var(--owed-soft);border-color:#f0d6a8;color:#7a4d12}
.next-deadline.overdue{background:var(--danger-soft);border-color:#f3c4bd;color:var(--danger)}
.next-deadline b{color:inherit}

/* AI rich result */
.ai-chip-col{align-items:flex-start}
.ai-deadline{font-size:.78rem;font-weight:600;color:var(--owed);margin-top:3px}
.neg-box{margin-top:16px;border:1px solid var(--line);border-radius:11px;padding:14px 16px;background:var(--surface)}
.neg-box h4{margin:0 0 8px;font-size:.92rem}
.neg-box ul{margin:0 0 12px;padding-left:18px}
.neg-box li{margin:4px 0;font-size:.86rem;color:var(--ink-soft)}
.draft-head{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:.82rem;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.draft{width:100%;min-height:150px;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;resize:vertical;font-size:.86rem;line-height:1.5;background:var(--paper)}

/* ===================== Shell / Sidebar / Views ===================== */
.shell{display:flex;align-items:stretch;min-height:100vh}
.sidebar{width:232px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;padding:18px 14px;z-index:50}
.sidebar .brand{margin:4px 8px 22px}
.nav{display:flex;flex-direction:column;gap:4px}
.nav-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;border:none;background:transparent;padding:11px 12px;border-radius:10px;font-size:.92rem;font-weight:600;color:var(--ink-soft);cursor:pointer}
.nav-item svg{width:19px;height:19px;flex-shrink:0}
.nav-item:hover{background:var(--paper);color:var(--ink)}
.nav-item.active{background:var(--ink);color:#fff}
.sidebar-foot{margin-top:auto;padding:14px 10px 2px;font-size:.72rem;line-height:1.4}
.sidebar-overlay{display:none}
.main-area{flex:1;min-width:0;display:flex;flex-direction:column}
.hamburger{display:none;background:transparent;border:none;color:var(--ink);padding:6px;border-radius:8px;line-height:0;cursor:pointer}
.view-title{font-size:1.5rem;letter-spacing:-.02em;margin:0 0 20px}
.view{display:none}
.view.active{display:block;animation:viewIn .18s ease}
@keyframes viewIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* Topbar/Content an die Sidebar anpassen (überschreibt frühere Regeln) */
.topbar-in{max-width:none;padding:11px 26px}
.wrap{max-width:1080px;margin:0 auto;padding:26px 30px 80px;width:100%}

@media(max-width:900px){
  .sidebar{position:fixed;left:0;top:0;height:100vh;transform:translateX(-100%);transition:transform .22s ease;box-shadow:0 0 50px rgba(0,0,0,.25)}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.42);opacity:0;pointer-events:none;transition:opacity .2s;z-index:45}
  .sidebar-overlay.open{opacity:1;pointer-events:auto}
  .hamburger{display:inline-flex}
  .wrap{padding:20px 16px 70px}
  .topbar-in{padding:10px 14px;gap:10px}
  #tenantBtn{max-width:42vw}
  #tenantName{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
}

/* ===================== Admin ===================== */
.admin-toolbar{display:flex;gap:10px;margin-bottom:16px}
.admin-toolbar input[type=search]{flex:1;padding:10px 13px;border:1.5px solid var(--line-strong);border-radius:10px}
.admin-table{width:100%;border-collapse:collapse;font-size:.85rem;min-width:760px}
.admin-table th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint);padding:8px 10px;border-bottom:1px solid var(--line)}
.admin-table td{padding:10px;border-bottom:1px solid var(--line);vertical-align:middle}
.au-name{font-weight:600}
.au-mail{font-size:.76rem}
.au-input{padding:6px 8px;border:1.5px solid var(--line);border-radius:8px;font-size:.82rem}
.au-num{width:64px;text-align:right}
.au-actions{display:flex;gap:6px;flex-wrap:wrap}
.badge-admin{background:var(--ink);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:20px}
.badge-blocked{background:var(--danger-soft);color:var(--danger);font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:20px}
.danger-btn{color:var(--danger);border-color:#f0c8c2}
.danger-btn:hover{background:var(--danger-soft)}
.invite-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:11px 13px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px}

/* ===================== Multi-Seiten-Upload ===================== */
.up-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.up-btn{display:inline-flex;align-items:center;gap:8px;border:1.5px dashed var(--line-strong);border-radius:11px;padding:12px 16px;font-weight:600;font-size:.9rem;color:var(--ink-soft);cursor:pointer;background:var(--paper)}
.up-btn:hover{border-color:var(--ink);color:var(--ink)}
.pages-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}
.pages-grid:empty{margin:0}
.page-tile{position:relative;width:84px;height:110px;border:1px solid var(--line);border-radius:9px;overflow:hidden;background:var(--paper);box-shadow:var(--shadow)}
.page-tile img{width:100%;height:100%;object-fit:cover;display:block}
.pdf-ico{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--ink-soft);background:var(--surface)}
.pg-num{position:absolute;top:4px;left:4px;background:var(--ink);color:#fff;font-size:.68rem;font-weight:700;border-radius:6px;padding:1px 6px}
.pg-del{position:absolute;top:4px;right:4px;border:none;background:rgba(0,0,0,.55);color:#fff;width:20px;height:20px;border-radius:50%;font-size:.72rem;line-height:1;cursor:pointer;padding:0}
.pg-del:hover{background:var(--danger)}

/* ===================== Gebühren-Check & Versionen ===================== */
.fee-ico{cursor:help;font-weight:700}
.fee-ico.warn{color:var(--danger)} .fee-ico.info{color:#b8791f}
.fee-hint{font-size:.82rem;border-radius:9px;padding:8px 11px;line-height:1.45}
.fee-hint.warn{background:var(--danger-soft);color:#8a2c20;border:1px solid #f0c8c2}
.fee-hint.info{background:var(--owed-soft);color:#7a4d12;border:1px solid #f0d6a8}
.fee-badge{border:1px solid #f0c8c2;background:var(--danger-soft);color:#8a2c20;border-radius:20px;padding:2px 9px;font-size:.72rem;font-weight:700;cursor:pointer}
.fee-badge.info{border-color:#f0d6a8;background:var(--owed-soft);color:#7a4d12}
.hist-btn{background:transparent;border:none;color:var(--ink-faint);font-size:1.05rem;padding:4px 7px;border-radius:7px;cursor:pointer;line-height:1}
.hist-btn:hover{background:var(--paper);color:var(--ink)}
.ai-adopt{display:flex;flex-direction:column;gap:6px;align-items:stretch;min-width:190px}
.ai-adopt .add{white-space:nowrap}
.ver-list{display:flex;flex-direction:column;gap:8px}
.ver-row{border:1px solid var(--line);border-radius:9px;padding:9px 12px}
.ver-form{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;align-items:end}
.ver-form .btn-primary{grid-column:1/-1}
@media(max-width:560px){.ver-form{grid-template-columns:1fr}}
