: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;padding-right:30px}

.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;padding-right:30px}
.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 .8fr .9fr .9fr;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{grid-column:1/-1;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:.78rem;color:var(--ink-soft);padding-top:8px;margin-top:2px;border-top:1px dashed var(--line)}
.debt .res .res-main{flex:1 1 auto;min-width:120px}
.debt .res b{color:var(--ink)}.debt .res.warn b{color:var(--danger)}
.debt .res .debt-meta{flex-basis:100%;margin-top:2px}
.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)}
.overlay.wide .modal{max-width:940px}
.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,.field textarea{width:100%;padding:10px 12px;border:1.5px solid var(--line);border-radius:9px;background:var(--surface);color:var(--ink)}
.field select{width:100%;padding:10px 36px 10px 12px;border:1.5px solid var(--line);border-radius:9px;background:var(--surface);color:var(--ink);appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%23667' stroke-width='1.6'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent,#0e8c6b)}

.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}}

/* Auth: Inline-Link & Hinweis */
.link-inline{display:block;width:100%;background:transparent;border:none;color:var(--ink-soft);font-size:.84rem;font-weight:600;margin-top:10px;cursor:pointer;text-align:center}
.link-inline:hover{color:var(--ink);text-decoration:underline}
.auth-msg{background:var(--paper);border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-size:.84rem;color:var(--ink-soft);margin-top:6px}

/* ===================== Onboarding-Wizard ===================== */
.ob-overlay{position:fixed;inset:0;background:rgba(22,32,44,.55);display:flex;align-items:center;justify-content:center;z-index:80;padding:18px}
.ob-card{width:100%;max-width:560px;max-height:92vh;overflow:auto;background:var(--surface);border-radius:18px;padding:26px 28px;box-shadow:0 24px 70px rgba(0,0,0,.4)}
.ob-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.ob-steps{display:flex;align-items:center;gap:8px}
.ob-dot{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;background:var(--paper);color:var(--ink-faint);border:1px solid var(--line)}
.ob-dot.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.ob-line{width:26px;height:2px;background:var(--line)}
.ob-step h2{font-size:1.3rem;margin-bottom:6px}
.ob-step .big-input{margin-top:14px}
.ob-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:22px}
.ob-w{width:auto;min-width:150px;padding:12px 22px}
.ob-claim{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:10px;padding:9px 12px;margin-bottom:8px}
.ob-pick{flex:1;display:flex;align-items:center;gap:9px;font-size:.88rem;cursor:pointer}
.ob-pick input{width:17px;height:17px;flex-shrink:0}
.ob-claim .au-input{max-width:46%}
@media(max-width:560px){.ob-claim{flex-direction:column;align-items:stretch}.ob-claim .au-input{max-width:none}}

/* ===================== Dringlichkeit, Analyse, Hinweise ===================== */
.urg-badge{font-size:.7rem;font-weight:700;padding:2px 9px;border-radius:20px;border:1px solid var(--line)}
.urg-badge.warn{background:var(--danger-soft);color:#8a2c20;border-color:#f0c8c2}
.urg-badge.info{background:var(--owed-soft);color:#7a4d12;border-color:#f0d6a8}
.urg-badge.ok{background:var(--paper);color:var(--ink-soft)}
.debt-meta .debt-note{flex:1 1 200px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ai-chip-title{word-break:break-word}
.info-note{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--accent,#0e8c6b);border-radius:10px;padding:11px 14px;font-size:.86rem;color:var(--ink-soft);line-height:1.5;margin-bottom:14px}
.prio-list{display:flex;flex-direction:column;gap:8px;margin-bottom:6px}
.prio-row{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line);border-radius:10px;padding:11px 13px}
.prio-num{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--ink);color:#fff;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.tip-list{margin:0 0 4px;padding-left:18px}
.tip-list li{margin:5px 0;font-size:.88rem;color:var(--ink-soft)}

/* Scan-Ergebnis-Karte: auf schmalen Screens stapeln statt quetschen */
@media(max-width:600px){
  .ai-chip-col{flex-direction:column;align-items:stretch}
  .ai-chip-col .ai-adopt{flex-direction:row;min-width:0;width:100%}
  .ai-chip-col .ai-adopt .au-input{flex:1;min-width:0}
  .ai-chip-col .ai-adopt .add{flex-shrink:0}
}

/* Fortschritt laufende Rate */
.paid-prog{flex-basis:100%;display:flex;align-items:center;gap:10px;margin-top:6px;font-size:.78rem}
.paid-bar{flex:1;max-width:220px;height:7px;background:var(--paper);border:1px solid var(--line);border-radius:20px;overflow:hidden}
.paid-bar span{display:block;height:100%;background:var(--paid,#1a9c73);border-radius:20px;transition:width .3s}

/* Handlungsmöglichkeiten in der Analyse */
.lever-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.lever-btn{background:var(--surface);border:1px solid var(--line-strong,#d8d2c4);color:var(--ink);border-radius:8px;padding:5px 10px;font-size:.78rem;font-weight:600;cursor:pointer}
.lever-btn:hover{border-color:var(--accent,#0e8c6b);color:var(--accent,#0e8c6b)}
.field textarea{width:100%;padding:9px 11px;border:1.5px solid var(--line);border-radius:9px;resize:vertical;font-size:.95rem}
.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent,#0e8c6b)}

/* Opt-in: Erfahrungswerte teilen */
.share-opt{display:flex;gap:10px;align-items:flex-start;border:1px solid var(--line);border-radius:10px;padding:11px 13px;margin-bottom:14px;cursor:pointer}
.share-opt input{width:18px;height:18px;flex-shrink:0;margin-top:2px}

/* "Original archivieren"-Option */
.arch-opt{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--ink-soft);margin-top:10px;cursor:pointer}
.arch-opt input{width:16px;height:16px;flex-shrink:0}

/* Analyse-Verlauf & Vergleich */
.ana-list{display:flex;flex-direction:column;gap:8px}
.ana-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;cursor:pointer;background:var(--card);transition:border-color .15s,background .15s}
.ana-row:hover{border-color:var(--accent)}
.ana-row.active{border-color:var(--accent);background:var(--accent-soft,rgba(0,0,0,.03))}
.ana-row.sel{border-color:var(--accent)}
.ana-row .ana-main{flex:1;min-width:0}
.ana-row .del{margin-left:auto}
.cmp-table{width:100%;border-collapse:collapse;font-size:.9rem}
.cmp-table th,.cmp-table td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
.cmp-table th{font-weight:600;color:var(--ink-soft)}
.cmp-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
.cmp-cols h4{margin:0 0 6px;font-size:.92rem}
.cmp-cols p{margin:0;font-size:.9rem}
.cmp-ol{margin:0;padding-left:20px;font-size:.88rem}
.cmp-ol li{margin:2px 0}
@media (max-width:680px){.cmp-cols{grid-template-columns:1fr}}

/* Zahlung-Button in der Forderungszeile */
.hist-btn.pay-btn{font-size:.82rem;font-weight:600;color:var(--accent,#16623a);white-space:nowrap}

/* Status-Badges */
.st-badge{display:inline-block;font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:999px;border:1px solid transparent}
.st-offen{background:#eef0f3;color:#555;border-color:#e0e3e8}
.st-brief{background:#e7f0fb;color:#1c5fae;border-color:#cfe1f7}
.st-antwort{background:#fff3e0;color:#9a5b00;border-color:#ffe2b8}
.st-verein{background:#ece8fb;color:#5b3fae;border-color:#dcd4f7}
.st-laeuft{background:#e6f5ec;color:#16623a;border-color:#c8e9d6}
.st-erledigt{background:#e9efe9;color:#3a6b46;border-color:#cfe0d2;opacity:.85}

/* Übersicht: Fristen */
.fr-list{display:flex;flex-direction:column;gap:8px}
.fr-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;cursor:pointer;background:var(--card)}
.fr-row:hover{border-color:var(--accent)}
.fr-row.over{border-left:4px solid var(--danger,#c0392b)}
.fr-row.soon{border-left:4px solid #e0a92b}

/* Soll/Ist */
.si-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.si-card{border:1px solid var(--line);border-radius:12px;padding:12px 14px;background:var(--card)}
.si-k{font-size:.8rem;color:var(--ink-soft)}
.si-v{font-size:1.3rem;font-weight:700;margin-top:2px}
@media (max-width:560px){.si-grid{grid-template-columns:1fr 1fr}}

/* Gebühren-Check */
.fee-check{border:1px solid var(--line);border-radius:10px;padding:12px 14px;background:var(--paper);font-size:.86rem;line-height:1.5}
.fee-flag{margin-top:8px;padding:8px 10px;border-radius:8px;background:#fdeced;color:#a3271f;border:1px solid #f3c7c4;font-size:.84rem}

/* Pfändungsschutz-Rechner */
.pf-result{margin-top:6px}
.pf-guar{border:1px solid var(--accent);border-radius:12px;padding:14px 16px;background:var(--paper)}
.pf-guar .pf-k{font-size:.84rem;color:var(--ink-soft)}
.pf-guar .pf-v{font-size:1.7rem;font-weight:800;color:var(--accent);margin-top:2px}

/* Stapel-/Ordner-/ZIP-Import */
.batch-box{margin-top:20px;border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:var(--card)}
.batch-box>summary{cursor:pointer;font-weight:600;color:var(--ink)}
.batch-box[open]>summary{margin-bottom:6px}
.batch-files{display:flex;flex-wrap:wrap;gap:6px}
.batch-file{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:3px 6px 3px 10px}
.batch-file button{border:none;background:none;cursor:pointer;color:var(--ink-soft);font-size:.9rem;line-height:1}
.batch-actions{display:flex;gap:10px;margin-top:12px}
.batch-result{border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-bottom:8px;background:var(--paper)}
.batch-result-head{font-size:.9rem;margin-bottom:4px}
.batch-claim{display:flex;align-items:center;gap:8px;font-size:.86rem;padding:3px 0}

/* Gefahrenzone */
.danger-zone{border:1px solid #f3c7c4;border-radius:12px;padding:4px 14px;background:#fdf6f5}
.danger-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 0;border-bottom:1px solid #f3c7c4}
.danger-row:last-child{border-bottom:none}
.btn-danger{background:#c0392b;color:#fff;border:none;border-radius:8px;padding:9px 16px;font-weight:600;cursor:pointer;white-space:nowrap}
.btn-danger:hover{background:#a3271f}

/* Hinweis-Boxen (Leistbarkeit) */
.note-warn{padding:8px 10px;border-radius:8px;background:#fff6e5;color:#8a5a00;border:1px solid #f3dca6;font-size:.86rem}
.note-ok{padding:8px 10px;border-radius:8px;background:#eaf7ee;color:#1c6b39;border:1px solid #bfe6cb;font-size:.86rem}

/* Batch-Dedup-Auswahl */
.batch-claim .batch-tgt{font-size:.78rem;max-width:46%;padding:4px 6px;border:1px solid var(--line);border-radius:6px;background:var(--paper)}

/* Empfehlung aus der Analyse direkt in der Schuldenliste */
.debt-advice{flex-basis:100%;width:100%;margin-top:6px;font-size:.84rem;color:#3a4a2e;background:#f3f7ec;border:1px solid #d9e6c6;border-radius:8px;padding:7px 10px;line-height:1.45}
.debt-advice .link-inline{font-weight:600}

/* ---- Schulden als klickbare Karten (statt Inline-Formular) ---- */
.debt-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin-bottom:14px;cursor:pointer;transition:box-shadow .15s,border-color .15s}
.debt-toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.debt-toolbar input[type="search"]{flex:1;min-width:200px;padding:10px 12px;border:1.5px solid var(--line);border-radius:9px;background:var(--surface);color:var(--ink);font:inherit}
.debt-toolbar select{padding:10px 34px 10px 12px;border:1.5px solid var(--line);border-radius:9px;background:var(--surface);color:var(--ink);font:inherit;appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%23667' stroke-width='1.6'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.debt-toolbar input[type="search"]:focus,.debt-toolbar select:focus{outline:none;border-color:var(--accent)}
.debt-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.dc-grid{display:grid;grid-template-columns:1.9fr 1fr;gap:20px;align-items:start}
.dc-left{min-width:0}
.dc-name{font-weight:700;font-size:1.12rem;color:var(--ink);line-height:1.3}
.dc-sub{font-size:.88rem;color:var(--ink-soft);margin-top:4px}
.dc-sub .warn{color:var(--danger);font-weight:600}
.dc-note{font-size:.82rem;color:var(--ink-soft);margin-top:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.debt-card .debt-meta{margin-top:10px}
.dc-right{display:flex;flex-direction:column;gap:10px;align-items:stretch;border-left:1px solid var(--line);padding-left:18px}
.dc-amount{font-weight:800;font-size:1.5rem;color:var(--ink);text-align:right;line-height:1}
.dc-right .debt-advice{margin:0;width:100%;flex-basis:auto}
.dc-actions{display:flex;flex-direction:column;gap:7px;margin-top:2px}
.dc-actions .btn-soft.sm{width:100%;padding:9px 12px;font-size:.86rem;text-align:center}
.dc-del{appearance:none;background:none;border:none;color:var(--ink-faint);font:inherit;font-size:.82rem;cursor:pointer;padding:4px;align-self:flex-end}
.dc-del:hover{color:var(--danger)}
/* Tilgungs-/Zahlungs-Balken über volle Breite */
.paid-prog2{margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.pp-track{display:flex;height:12px;width:100%;background:var(--paper);border:1px solid var(--line);border-radius:20px;overflow:hidden}
.pp-seg{display:block;height:100%}
.pp-seg.a{background:var(--paid,#1a9c73)}
.pp-seg.b{background:#3fbe93}
.pp-label{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:7px;font-size:.8rem;color:var(--ink-soft)}
@media(max-width:640px){.dc-grid{grid-template-columns:1fr}.dc-right{border-left:none;border-top:1px solid var(--line);padding-left:0;padding-top:14px}.dc-amount{text-align:left}}

/* E-Mail-Eingang: Klartext der Nachricht */
.mail-text{white-space:pre-wrap;word-break:break-word;font-family:var(--sans);font-size:.84rem;line-height:1.5;background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:10px 12px;margin:8px 0 0;max-height:340px;overflow:auto}
.ib-att{margin-top:10px;font-size:.85rem}
.ib-att b{display:block;margin-bottom:4px}
.ib-att a{color:var(--accent);text-decoration:none}
.ib-att a:hover{text-decoration:underline}
.ib-att div{margin-top:3px}

/* ---- Detail-Modal: Tabs, sauberes Raster, Kommunikations-Timeline ---- */
.dt-tabs{display:flex;gap:4px;flex-wrap:wrap;border-bottom:1px solid var(--line);margin:-4px 0 18px;position:sticky;top:0;background:var(--surface);z-index:2;padding-top:4px}
.dt-tab{appearance:none;background:none;border:none;border-bottom:2px solid transparent;padding:9px 13px;font:inherit;font-size:.9rem;font-weight:600;color:var(--ink-soft);cursor:pointer;white-space:nowrap}
.dt-tab:hover{color:var(--ink)}
.dt-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.dt-panel{animation:fadein .12s ease}
@keyframes fadein{from{opacity:.4}to{opacity:1}}
.dt-sep{border:none;border-top:1px solid var(--line);margin:20px 0}
/* sauberes Formular-Raster (kein verschachteltes Grid mehr) */
.detail-form{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px;align-items:end}
.detail-form .span2{grid-column:1/-1}
.span2{grid-column:1/-1}
.detail-form .field{margin:0}
@media(max-width:560px){.detail-form{grid-template-columns:1fr}}
/* Kommunikations-Timeline */
.comm-tl{display:flex;flex-direction:column;gap:8px}
.comm-row{display:grid;grid-template-columns:92px 1fr auto;gap:10px;align-items:start;padding:10px 12px;border:1px solid var(--line);border-radius:10px;border-left-width:3px}
.comm-row.out{border-left-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,transparent)}
.comm-row.in{border-left-color:#c98a2b;background:#fbf4e8}
.comm-tag{font-size:.74rem;font-weight:700;color:var(--ink-soft);padding-top:2px}
.comm-date{font-size:.78rem;white-space:nowrap}
@media(max-width:560px){.comm-row{grid-template-columns:1fr auto}.comm-tag{grid-column:1/-1}}

/* ---- Nav-Badge + E-Mail-Eingang ---- */
.nav-badge{margin-left:auto;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--danger);color:#fff;font-size:.72rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center}
.inbox-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin-bottom:12px}
.inbox-card.unseen{border-left:3px solid var(--accent)}
.ib-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.ib-head b{font-size:1rem;color:var(--ink)}
.ib-new{font-size:.72rem;font-weight:700;color:#fff;background:var(--accent);border-radius:8px;padding:2px 8px;white-space:nowrap}
.ib-assign{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:10px;font-size:.85rem;color:var(--ink-soft)}
.ib-assign select{padding:6px 10px;border:1px solid var(--line);border-radius:8px;font:inherit;background:var(--paper)}
.ib-body{margin-top:8px}

/* ---- Forderungs-Detailseite: Breadcrumb + Karte ---- */
.crumb{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:.95rem;flex-wrap:wrap}
.crumb-link{appearance:none;background:none;border:none;padding:0;font:inherit;color:var(--accent);cursor:pointer;font-weight:600}
.crumb-link:hover{text-decoration:underline}
.crumb-sep{color:var(--ink-faint)}
.crumb-cur{font-weight:700;color:var(--ink);font-size:1.15rem}
.crumb-amount{margin-left:auto;font-weight:700;color:var(--ink);font-size:1.15rem}
.detail-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px}
.detail-card .dt-tabs{position:static;margin-top:-2px}
.detail-card .dt-panel{max-width:none}
.detail-card .dt-panel>h3:first-child{margin-top:0}
.komm-actions{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 4px}
.komm-actions .btn-primary,.komm-actions .btn-soft{width:auto;padding:10px 18px}
.link-inline.danger{color:var(--danger)}
.link-inline.danger:hover{color:var(--danger)}
.comm-body .link-inline{display:inline;width:auto;margin:6px 12px 0 0;text-align:left}
@media(max-width:560px){.detail-card{padding:14px 14px}}
.sig-box{border:1px solid var(--line);border-radius:10px;padding:12px;background:var(--paper)}
.sig-preview{max-width:280px;max-height:90px;display:block;background:#fff;border:1px solid var(--line);border-radius:6px;padding:4px}
.sig-pad{width:100%;max-width:560px;height:150px;background:#fff;border:1px dashed var(--line-strong);border-radius:8px;touch-action:none;cursor:crosshair}
.sig-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:10px}
.sig-actions .btn-soft.sm{width:auto;padding:7px 12px;font-size:.84rem}
