*{margin:0;padding:0;box-sizing:border-box;}
/* Hide login screen immediately if a session token exists (prevents flash on refresh) */
html.has-token body.login-open #loginScreen{display:none!important;}
html.has-token body.login-open #appWrap{display:block!important;}
html.has-token body.login-open{position:static;overflow:auto;}
:root{
  --red:#D0111B;--rd:#a80e16;
  --blk:#0a0a0a;--d1:#111;--d2:#181818;--d3:#242424;
  --wh:#fff;--wh3:rgba(255,255,255,.3);--wh4:rgba(255,255,255,.4);--wh5:rgba(255,255,255,.5);--wh6:rgba(255,255,255,.6);
  --wh08:rgba(255,255,255,.08);--wh05:rgba(255,255,255,.05);
}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
html{max-width:100vw;overflow-x:hidden;-webkit-text-size-adjust:100%;text-size-adjust:100%;overscroll-behavior:none;}
body{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;background:var(--blk);color:var(--wh);min-height:600px;max-width:100vw;overflow-x:hidden;}
.topbar{background:var(--d1);border-bottom:1px solid var(--wh08);padding:0 1.5rem;height:56px;display:flex;align-items:center;justify-content:space-between;}
.topbar-left{display:flex;align-items:center;gap:1.5rem;}
.logo-pill{display:flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--red);}
.logo-pill span{width:7px;height:7px;background:var(--red);border-radius:50%;display:inline-block;}
.topbar-logo{height:30px;width:auto;display:block;}
.topbar-year-progress{display:flex;align-items:center;gap:.75rem;margin-right:1.3rem;}
.typ-ring-wrap{position:relative;width:40px;height:40px;flex-shrink:0;}
.typ-svg{width:40px;height:40px;transform:rotate(-90deg);}
.typ-track{stroke:rgba(255,255,255,.07);stroke-width:2.5;}
.typ-arc{stroke:var(--red);stroke-width:2.5;stroke-linecap:round;stroke-dasharray:94.25;stroke-dashoffset:94.25;transition:stroke-dashoffset 1s linear;filter:drop-shadow(0 0 5px rgba(208,17,27,.55));}
.typ-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:1px;}
.typ-center span:first-child{font-size:.74rem;font-weight:700;color:var(--wh);font-variant-numeric:tabular-nums;line-height:1;}
.typ-sym{font-size:.48rem;color:var(--wh4);margin-top:2px;line-height:1;}
.typ-info{display:flex;flex-direction:column;gap:2px;}
.typ-info-label{font-size:.58rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--wh4);line-height:1.3;max-width:52px;}
.typ-info-year{font-size:.82rem;font-weight:700;color:var(--wh6);letter-spacing:.04em;}
.topbar-clock{display:flex;flex-direction:column;align-items:flex-end;gap:1px;margin-right:1.2rem;}
.topbar-clock-time{font-size:.95rem;font-weight:600;color:var(--wh);letter-spacing:.06em;font-variant-numeric:tabular-nums;}
.topbar-clock-date{font-size:.65rem;font-weight:400;color:var(--wh4);letter-spacing:.04em;}
.topbar-right{display:flex;align-items:center;gap:.7rem;}
/* ── Global search ─────────────────────────────────────────────────────────── */
.topbar-search-wrap{position:relative;display:flex;align-items:center;background:rgba(255,255,255,.06);border:1px solid var(--wh08);border-radius:980px;padding:.3rem .85rem;gap:.5rem;transition:border-color .15s;min-width:220px;}
.topbar-search-wrap:focus-within{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.09);}
.topbar-search-icon{color:var(--wh4);flex-shrink:0;}
.topbar-search-input{background:none;border:none;outline:none;font-size:.8rem;color:var(--wh);font-family:inherit;flex:1;min-width:0;}
.topbar-search-input::placeholder{color:rgba(255,255,255,.3);}
.topbar-search-clear{background:none;border:none;color:var(--wh4);cursor:pointer;font-size:.75rem;padding:0;line-height:1;display:flex;align-items:center;transition:color .15s;}
.topbar-search-clear:hover{color:var(--wh);}
.global-search-results{position:fixed;top:56px;left:50%;transform:translateX(-50%);width:min(680px,calc(100vw - 2rem));background:var(--d2);border:1px solid rgba(255,255,255,.12);border-radius:16px;box-shadow:0 16px 48px rgba(0,0,0,.6);z-index:900;max-height:70vh;overflow-y:auto;animation:slideDown .15s ease;}
.gs-section-label{font-size:.58rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--wh4);padding:.75rem 1.1rem .35rem;}
.gs-item{display:flex;align-items:center;gap:.85rem;padding:.7rem 1.1rem;cursor:pointer;transition:background .12s;}
.gs-item:hover{background:rgba(255,255,255,.05);}
.gs-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.gs-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;color:#fff;flex-shrink:0;}
.gs-inv-icon{width:26px;height:26px;display:flex;align-items:center;justify-content:center;color:var(--wh4);flex-shrink:0;}
.gs-item-main{flex:1;min-width:0;}
.gs-item-name{font-size:.84rem;font-weight:500;color:var(--wh);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.gs-item-meta{font-size:.72rem;color:var(--wh4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.1rem;}
.gs-item-tag{font-size:.58rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--wh4);background:rgba(255,255,255,.07);padding:.2rem .6rem;border-radius:980px;white-space:nowrap;flex-shrink:0;}
.gs-empty{padding:2rem 1.2rem;text-align:center;color:var(--wh4);font-size:.85rem;}
.btn-sm{font-size:.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:.44rem 1rem;border-radius:980px;border:none;cursor:pointer;transition:all .2s;font-family:inherit;}
.btn-red{background:var(--red);color:#fff;}
.btn-red:hover{background:var(--rd);transform:translateY(-1px);box-shadow:0 4px 14px rgba(208,17,27,.35);}
.btn-ghost{background:transparent;color:var(--wh4);border:1px solid var(--wh08);}
.btn-ghost:hover{color:var(--wh);border-color:rgba(255,255,255,.25);background:var(--wh05);}
.nav-bar{background:var(--d1);border-bottom:1px solid var(--wh08);padding:0 1.5rem;display:flex;align-items:center;overflow-x:auto;}
.nav-tab{font-size:.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:.62rem 1.1rem;cursor:pointer;color:var(--wh4);border-bottom:2px solid transparent;transition:all .18s;background:none;border-top:none;border-left:none;border-right:none;font-family:inherit;white-space:nowrap;flex-shrink:0;}
.nav-tab.active{color:var(--wh);border-bottom-color:var(--red);}
.nav-tab:hover:not(.active){color:var(--wh6);}
.nav-sep{width:1px;height:16px;background:var(--wh08);margin:0 .3rem;flex-shrink:0;}
#nav-pinned{display:contents;}
.nav-tab-client.active{border-bottom-color:var(--client-color,var(--red));color:var(--wh);}
.nav-tab-client:hover:not(.active){color:var(--wh6);}
.nav-tab-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px;vertical-align:middle;flex-shrink:0;}
.pin-btn{opacity:.55;transition:opacity .15s,color .15s;display:inline-flex;align-items:center;gap:4px;}
.pin-btn:hover{opacity:1;}
.pin-btn.pinned{opacity:1;color:var(--red);}
.client-badge{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px;vertical-align:middle;}
.view{display:none;}
.view.active{display:block;animation:fadeUp .22s ease;}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:1.4rem 1.5rem;}
.year-switcher{display:flex;align-items:center;gap:.4rem;padding:1.1rem 1.5rem .6rem;}
.year-btn{font-size:.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:.38rem .9rem;border-radius:980px;border:1px solid var(--wh08);background:none;color:var(--wh4);cursor:pointer;transition:background .2s,border-color .2s,color .2s,box-shadow .2s,transform .1s;font-family:inherit;}
.year-btn:hover{color:var(--wh);border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.04);}
.year-btn:active{transform:scale(.95);}
.year-btn.active{background:var(--red);border-color:var(--red);color:#fff;box-shadow:0 0 0 3px rgba(208,17,27,.18);}
.fade-in{animation:fadeUp .18s ease;}
.stat-card{background:var(--d2);border:1px solid var(--wh08);border-radius:14px;padding:1.1rem 1.3rem;transition:border-color .2s,transform .2s,box-shadow .2s;}
.stat-card:hover{border-color:rgba(208,17,27,.35);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.25);}
.stat-label{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--wh4);margin-bottom:.5rem;}
.stat-val{font-size:1.7rem;font-weight:700;letter-spacing:-.03em;}
.stat-val.red{color:var(--red);}
.stat-sub{font-size:.7rem;color:var(--wh4);margin-top:.25rem;}
.client-page-header{padding:1.5rem 1.5rem 0;}
.cp-banner{background:var(--d2);border:1px solid var(--wh08);border-radius:16px;padding:1.5rem 1.7rem;display:flex;align-items:center;gap:1.2rem;margin-bottom:1.2rem;}
.cp-avatar{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:#fff;flex-shrink:0;}
.cp-name{font-size:1.25rem;font-weight:700;letter-spacing:-.03em;}
.cp-meta{font-size:.8rem;color:var(--wh4);margin-top:.25rem;}
.cp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-left:auto;}
.cp-stat{text-align:right;}
.cp-stat-val{font-size:1.15rem;font-weight:700;letter-spacing:-.02em;}
.cp-stat-val.red{color:var(--red);}
.cp-stat-label{font-size:.63rem;letter-spacing:.1em;text-transform:uppercase;color:var(--wh4);margin-top:.15rem;}
.month-section{margin:0 1.5rem 1rem;background:var(--d2);border:1px solid var(--wh08);border-radius:14px;overflow:hidden;transition:border-color .2s,background .2s;}
.month-section:hover{border-color:rgba(255,255,255,.14);}
.month-current{border-color:rgba(208,17,27,.3);}
.month-current:hover{border-color:rgba(208,17,27,.45);}
.month-section.drag-over{border-color:rgba(208,17,27,.7) !important;background:rgba(208,17,27,.06);}
.t-row[draggable]{cursor:grab;}
.t-row[draggable]:active{cursor:grabbing;}
.t-row.dragging{opacity:.35;pointer-events:none;}
.month-header{display:flex;align-items:center;gap:.9rem;cursor:pointer;user-select:none;padding:1rem 1.3rem;background:var(--d3);}
.month-toggle{width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.month-toggle svg{width:10px;height:10px;stroke:rgba(255,255,255,.3);fill:none;stroke-width:2;transition:transform .22s;}
.month-toggle.open svg{transform:rotate(90deg);}
.month-name{font-size:.76rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--wh);}
.month-current .month-name{color:var(--red);}
.month-spacer{flex:1;}
.month-meta{display:flex;align-items:center;gap:.65rem;flex-shrink:0;}
.month-count{font-size:.72rem;font-weight:500;color:var(--wh4);letter-spacing:.02em;}
.month-sep-dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.18);flex-shrink:0;}
.month-sum{font-size:.92rem;font-weight:700;color:var(--wh);letter-spacing:-.02em;min-width:56px;text-align:right;}
.month-empty{font-size:.75rem;color:rgba(255,255,255,.18);padding:.75rem 1.1rem;font-style:italic;border-top:1px solid var(--wh08);}
.table-wrap{background:var(--d2);border:1px solid var(--wh08);border-radius:16px;overflow:hidden;}
.month-section .table-wrap{border:none;border-radius:0;border-top:1px solid var(--wh08);}
.t-head{display:grid;grid-template-columns:1.7fr 1.2fr 1.4fr 1.5fr .85fr 1.1fr .28fr;padding:.68rem 1.1rem;border-bottom:1px solid var(--wh08);background:var(--d3);}
.t-head span{font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--wh4);}
.t-row{display:grid;grid-template-columns:1.7fr 1.2fr 1.4fr 1.5fr .85fr 1.1fr .28fr;padding:1rem 1.1rem;border-bottom:1px solid var(--wh08);align-items:center;transition:background .15s;}
.t-row:nth-child(even){background:rgba(255,255,255,.03);}
.t-row:last-child{border-bottom:none;}
.t-row:hover{background:rgba(255,255,255,.07);}
.t-footer{display:grid;grid-template-columns:1.7fr 1.2fr 1.4fr 1.5fr .85fr 1.1fr .28fr;padding:.72rem 1.1rem;background:var(--d3);border-top:1px solid var(--wh08);}
.proj-cell{display:flex;align-items:center;gap:9px;min-width:0;}
.cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.cat-dot-btn{cursor:pointer;transition:transform .15s,box-shadow .15s;width:12px;height:12px;}
.cat-dot-btn:hover{transform:scale(1.45);box-shadow:0 0 0 4px rgba(255,255,255,.1);}
.proj-name-wrap{display:flex;flex-direction:column;gap:3px;min-width:0;}
.proj-name-text{font-size:1rem;font-weight:500;color:var(--wh);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;transition:opacity .15s;}
.proj-name-text:hover{opacity:.7;}
.proj-notes{font-size:.71rem;color:rgba(255,255,255,.3);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s;line-height:1.3;}
.proj-notes:hover{color:rgba(255,255,255,.65);}
.proj-notes-empty{color:rgba(255,255,255,.15);font-style:italic;}
.proj-notes-empty:hover{color:rgba(255,255,255,.38);}
.date-txt{font-size:.92rem;color:var(--wh6);cursor:pointer;white-space:nowrap;transition:color .15s;}
.date-txt:hover{color:var(--wh);}
.date-empty{font-size:.88rem;color:rgba(255,255,255,.18);cursor:pointer;font-style:italic;transition:color .15s;}
.date-empty:hover{color:rgba(255,255,255,.4);}
.addr-txt{font-size:.9rem;color:var(--wh4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:155px;cursor:pointer;display:block;transition:color .15s;}
.addr-txt:hover{color:var(--wh6);}
.addr-empty{font-size:.88rem;color:rgba(255,255,255,.18);cursor:pointer;font-style:italic;transition:color .15s;}
.addr-empty:hover{color:rgba(255,255,255,.4);}
.umsatz-wrap{display:inline-flex;align-items:center;gap:.3rem;}
.umsatz-txt{font-size:.96rem;font-weight:600;cursor:pointer;transition:opacity .15s;}
.umsatz-txt:hover{opacity:.7;}
.umsatz-clear{display:none;background:none;border:none;color:rgba(255,255,255,.35);font-size:.78rem;cursor:pointer;padding:0 .1rem;line-height:1;transition:color .15s;}
.umsatz-wrap:hover .umsatz-clear{display:inline;}
.umsatz-clear:hover{color:rgba(255,255,255,.7);}
.umsatz-empty{font-size:.88rem;color:rgba(255,255,255,.18);cursor:pointer;transition:color .15s;}
.umsatz-empty:hover{color:rgba(255,255,255,.4);}
.status-pill,.r-pill{display:inline-block;font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.45rem 1rem;border-radius:980px;white-space:nowrap;cursor:pointer;user-select:none;text-align:center;transition:filter .15s,transform .1s;}
.t-row > div > .status-pill{display:block;width:9.5rem;}
.t-row > div > .r-pill{display:block;width:12rem;}
.status-pill:hover,.r-pill:hover{filter:brightness(1.15);transform:scale(1.04);}
.s-erledigt{background:#16a34a;color:#fff;}
.s-produktion{background:#D0111B;color:#fff;}
.s-postprod{background:#fb923c;color:#fff;}
.s-offen{background:var(--d3);color:var(--wh4);border:1px solid rgba(255,255,255,.12);}
.r-bezahlt{background:#16a34a;color:#fff;}
.r-zahlung{background:#d97706;color:#fff;}
.r-ausstehend{background:#D0111B;color:#fff;}
.r-leer{font-size:.76rem;color:rgba(255,255,255,.22);cursor:pointer;padding:.3rem .4rem;transition:color .15s;}
.r-leer:hover{color:rgba(255,255,255,.55);}
.cell-input{background:var(--d3);border:1px solid var(--red);border-radius:7px;padding:.33rem .6rem;font-size:.84rem;color:var(--wh);font-family:inherit;outline:none;}
.cell-textarea{background:var(--d3);border:1px solid var(--red);border-radius:7px;padding:.4rem .7rem;font-size:.84rem;color:var(--wh);font-family:inherit;outline:none;width:100%;resize:vertical;line-height:1.5;}
/* ── Notes modal ─────────────────────────────────────────────────────────── */
.notes-modal{padding:0;overflow:hidden;display:flex;flex-direction:column;width:580px;max-height:74vh;}
.notes-modal-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.3rem;border-bottom:1px solid var(--wh08);flex-shrink:0;}
.notes-modal-title{font-size:.65rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--red);}
.notes-modal-close{background:var(--d3);border:1px solid var(--wh08);border-radius:8px;color:var(--wh4);cursor:pointer;display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0;transition:background .15s,color .15s;}
.notes-modal-close:hover{background:rgba(255,255,255,.06);color:var(--wh);}
.notes-toolbar{display:flex;align-items:center;gap:3px;padding:.45rem .85rem;background:var(--d3);border-bottom:1px solid var(--wh08);flex-shrink:0;}
.notes-tool{background:none;border:1px solid transparent;border-radius:7px;color:var(--wh5);cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:600;line-height:1;padding:.35rem .6rem;display:inline-flex;align-items:center;justify-content:center;min-width:32px;transition:background .15s,color .15s,border-color .15s;}
.notes-tool:hover{background:rgba(255,255,255,.07);border-color:var(--wh08);color:var(--wh);}
.notes-tool-sep{width:1px;height:18px;background:var(--wh08);margin:0 4px;flex-shrink:0;}
.notes-editor{flex:1;height:0;min-height:240px;padding:1.2rem 1.4rem;overflow-y:auto;outline:none;font-size:.9rem;line-height:1.72;color:var(--wh);}
.notes-editor:empty::before{content:attr(data-placeholder);color:var(--wh3);pointer-events:none;}
.notes-editor ul,.notes-editor ol{padding-left:1.5rem;margin:.25rem 0;}
.notes-editor li{margin:.2rem 0;}
.notes-modal-footer{display:flex;justify-content:flex-end;gap:.7rem;padding:.85rem 1.3rem;border-top:1px solid var(--wh08);background:var(--d3);flex-shrink:0;}

/* ── Project detail modal ────────────────────────────────────────────────── */
.pd-modal{background:var(--d2);border:1px solid rgba(255,255,255,.1);border-radius:20px;width:900px;max-width:calc(100vw - 2rem);max-height:90vh;display:flex;flex-direction:column;animation:scaleIn .22s ease;overflow:hidden;}
.pd-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.2rem 1.6rem 1rem;border-bottom:1px solid var(--wh08);flex-shrink:0;}
.pd-name-input{background:none;border:none;border-bottom:1px solid transparent;outline:none;font-size:1.15rem;font-weight:700;color:var(--wh);font-family:inherit;flex:1;min-width:0;transition:border-color .15s;padding-bottom:2px;}
.pd-name-input:hover{border-bottom-color:rgba(255,255,255,.2);}
.pd-name-input:focus{border-bottom-color:var(--red);}
.pd-name-input::placeholder{color:var(--wh3);}
.pd-header-meta{display:flex;align-items:center;gap:.75rem;flex-shrink:0;}
.pd-month-badge{font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--red);background:rgba(208,17,27,.12);padding:.28rem .75rem;border-radius:980px;}
.pd-body{display:flex;flex:1;min-height:0;overflow:hidden;}
.pd-main{flex:1;min-width:0;padding:1.4rem 1.6rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.2rem;}
.pd-sidebar{width:280px;flex-shrink:0;border-left:1px solid var(--wh08);overflow-y:auto;padding:1.4rem 1.2rem;}
.pd-pills-row{display:flex;gap:1rem;flex-wrap:wrap;}
.pd-field-group{display:flex;flex-direction:column;gap:.35rem;min-width:120px;}
.pd-label{font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--wh4);}
/* custom dropdown buttons */
.pd-dd-btn{display:inline-flex;align-items:center;gap:.45rem;background:var(--d3);border:1px solid var(--wh08);border-radius:10px;color:var(--wh);font-family:inherit;font-size:.84rem;padding:.45rem .8rem;cursor:pointer;transition:border-color .15s,background .15s;white-space:nowrap;text-align:left;}
.pd-dd-btn:hover{border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.04);}
.pd-dd-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.pd-dd-chev{color:var(--wh4);flex-shrink:0;}
.pd-dd-btn-wide{max-width:200px;overflow:hidden;}
.pd-dd-btn-wide span:not(.pd-dd-dot):not(.pd-dd-chev){overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
/* date picker */
.pd-date-wrap{position:relative;}
.pd-calendar{position:absolute;top:calc(100% + 6px);left:0;background:var(--d2);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:.8rem;z-index:700;display:none;box-shadow:0 20px 60px rgba(0,0,0,.75);min-width:248px;}
.pd-calendar.open{display:block;animation:slideDown .15s ease;}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.65rem;padding:0 .1rem;}
.cal-title{font-size:.83rem;font-weight:600;color:var(--wh);}
.cal-nav{background:none;border:none;color:var(--wh5);cursor:pointer;font-size:1.3rem;line-height:1;padding:.1rem .45rem;border-radius:8px;transition:background .15s,color .15s;}
.cal-nav:hover{background:rgba(255,255,255,.07);color:var(--wh);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.cal-day-name{font-size:.62rem;color:var(--wh4);text-align:center;padding:.15rem 0 .4rem;font-weight:600;letter-spacing:.04em;}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--wh6);border-radius:8px;cursor:pointer;transition:background .12s,color .12s;}
.cal-day:hover{background:rgba(255,255,255,.09);color:var(--wh);}
.cal-day:empty{cursor:default;pointer-events:none;}
.cal-today{color:var(--red);font-weight:700;}
.cal-sel{background:var(--red) !important;color:#fff !important;font-weight:700;}
/* fields */
.pd-fields{display:flex;flex-direction:column;gap:.7rem;}
.pd-field-row{display:flex;align-items:center;gap:.65rem;}
.pd-field-icon{width:16px;height:16px;flex-shrink:0;color:var(--wh3);}
.pd-input{background:var(--d3);border:1px solid var(--wh08);border-radius:9px;color:var(--wh);font-family:inherit;font-size:.86rem;padding:.45rem .75rem;outline:none;transition:border-color .15s;min-width:0;}
.pd-input:focus{border-color:rgba(255,255,255,.22);}
.pd-input-time{width:90px;flex-shrink:0;}
.pd-input-wide{flex:1;}
.pd-currency{font-size:.88rem;font-weight:600;color:var(--wh5);flex-shrink:0;}
.pd-notes-section{display:flex;flex-direction:column;flex:1;}
.pd-section-label{font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--wh4);margin-bottom:.5rem;}
.pd-notes-toolbar{display:flex;align-items:center;gap:3px;padding:.4rem .6rem;background:var(--d3);border:1px solid var(--wh08);border-radius:10px 10px 0 0;border-bottom:none;}
.pd-notes-editor{flex:1;height:0;min-height:160px;padding:1rem 1rem;background:var(--d3);border:1px solid var(--wh08);border-radius:0 0 10px 10px;outline:none;font-size:.88rem;line-height:1.72;color:var(--wh);overflow-y:auto;}
.pd-notes-editor:empty::before{content:attr(data-placeholder);color:var(--wh3);pointer-events:none;}
.pd-notes-editor ul,.pd-notes-editor ol{padding-left:1.5rem;margin:.25rem 0;}
.pd-notes-editor li{margin:.2rem 0;}
.pd-client-card{display:flex;flex-direction:column;gap:.9rem;}
.pd-no-client{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2rem 0;color:var(--wh3);font-size:.85rem;text-align:center;}
.pd-client-hero{display:flex;align-items:center;gap:.85rem;}
.pd-client-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:#fff;flex-shrink:0;}
.pd-client-name{font-size:.95rem;font-weight:600;color:var(--wh);}
.pd-client-branch{font-size:.78rem;color:var(--wh4);margin-top:.1rem;}
.pd-client-info{display:flex;flex-direction:column;gap:.5rem;}
.pd-client-row{display:flex;align-items:flex-start;gap:.5rem;font-size:.82rem;color:var(--wh6);}
.pd-client-row svg{flex-shrink:0;margin-top:.12rem;color:var(--wh3);}
.pd-client-notes-preview{font-size:.8rem;color:var(--wh5);line-height:1.6;border-top:1px solid var(--wh05);padding-top:.75rem;max-height:120px;overflow-y:auto;}
.pd-footer{display:flex;justify-content:flex-end;gap:.7rem;padding:.9rem 1.6rem;border-top:1px solid var(--wh08);background:var(--d3);flex-shrink:0;}

.dropdown-popup{position:fixed;background:#1e1e1e;border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:6px;z-index:600;min-width:260px;display:none;box-shadow:0 16px 48px rgba(0,0,0,.7);}
.dropdown-popup.show{display:block;animation:slideDown .15s ease;}
.dp-search-wrap{padding:4px 4px 5px;}
.dp-search{width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:9px;padding:.42rem .85rem;font-size:.84rem;color:var(--wh);font-family:inherit;outline:none;transition:border-color .15s;}
.dp-search:focus{border-color:rgba(255,255,255,.28);}
.dp-search::placeholder{color:rgba(255,255,255,.28);}
.dp-items{max-height:260px;overflow-y:auto;}
.dp-empty{padding:.6rem 1rem;font-size:.8rem;color:rgba(255,255,255,.28);font-style:italic;}
.dp-item{padding:.55rem 1rem;border-radius:8px;cursor:pointer;font-size:.84rem;font-weight:500;transition:background .12s;display:flex;align-items:center;gap:.75rem;color:var(--wh6);}
.dp-item:hover{background:rgba(255,255,255,.07);color:var(--wh);}
.dp-item.sel{background:rgba(255,255,255,.06);}
.dp-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.del-btn{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.2);font-size:14px;padding:4px 6px;border-radius:4px;transition:all .18s;line-height:1;}
.del-btn:hover{color:#f87171;background:rgba(248,113,113,.1);}
.inv-list-actions{display:flex;align-items:center;gap:.25rem;}
.inv-dl-btn{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.2);padding:4px 6px;border-radius:4px;transition:all .18s;display:flex;align-items:center;}
.inv-dl-btn:hover{color:#60a5fa;background:rgba(96,165,250,.1);}
.inv-dl-btn:disabled{opacity:.4;cursor:wait;}
.add-row{padding:.72rem 1.1rem;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:background .18s;border-top:1px solid var(--wh05);}
.add-row:hover{background:rgba(208,17,27,.06);}
.add-row span{font-size:.78rem;color:var(--wh4);transition:color .18s;}
.add-row:hover span{color:var(--red);}
.add-icon{width:18px;height:18px;border-radius:4px;background:var(--d3);border:1px solid var(--wh08);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--wh4);line-height:1;}
.legend{display:flex;flex-wrap:wrap;gap:.55rem;padding:.9rem 1.5rem 0;}
.leg-item{display:flex;align-items:center;gap:.45rem;font-size:.7rem;color:var(--wh4);}
.leg-dot{width:8px;height:8px;border-radius:50%;}
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:none;align-items:flex-start;justify-content:center;z-index:500;padding-top:40px;}
.modal-bg.show{display:flex;animation:fadeIn .2s ease;}
.modal-bg.hide{animation:fadeOut .18s ease forwards;}
@keyframes fadeOut{to{opacity:0;}}
.modal{background:var(--d2);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;width:480px;max-width:calc(100% - 2rem);max-height:88vh;overflow-y:auto;animation:scaleIn .22s ease;}
.modal-title{font-size:.76rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;}
.modal-title::before{content:'';width:16px;height:1.5px;background:var(--red);}
.form-row{margin-bottom:1.1rem;position:relative;}
.form-row label{display:block;font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;color:var(--wh4);margin-bottom:.45rem;}
.form-row input,.form-row select,.form-row textarea{width:100%;background:var(--d3);border:1px solid var(--wh08);border-radius:9px;padding:.62rem .9rem;font-size:.88rem;color:var(--wh);font-family:inherit;outline:none;transition:border-color .18s;-webkit-appearance:none;resize:none;color-scheme:dark;}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--red);}
.form-row select option{background:var(--d3);color:var(--wh);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;}
.form-section{font-size:.65rem;letter-spacing:.13em;text-transform:uppercase;color:var(--red);margin:1.3rem 0 .85rem;display:flex;align-items:center;gap:.5rem;}
.form-section::before{content:'';width:12px;height:1px;background:var(--red);}
.modal-btns{display:flex;gap:.7rem;margin-top:1.6rem;justify-content:flex-end;}
.color-picker-row{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap;margin-top:.45rem;}
.color-swatch{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .15s,border-color .15s;flex-shrink:0;}
.color-swatch:hover{transform:scale(1.18);}
.color-swatch.selected{border-color:#fff;transform:scale(1.1);}
.color-custom{width:26px;height:26px;border-radius:50%;border:1.5px dashed rgba(255,255,255,.3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--wh4);overflow:hidden;flex-shrink:0;}
.color-custom input[type=color]{opacity:0;width:100%;height:100%;cursor:pointer;border:none;padding:0;}
.confirm-modal{background:var(--d2);border:1px solid rgba(208,17,27,.2);border-radius:20px;padding:2rem;width:380px;max-width:calc(100% - 2rem);animation:scaleIn .22s ease;}
.confirm-icon{width:46px;height:46px;border-radius:50%;background:rgba(208,17,27,.1);border:1px solid rgba(208,17,27,.2);display:flex;align-items:center;justify-content:center;margin-bottom:1.3rem;}
.confirm-icon svg{width:20px;height:20px;stroke:#f87171;fill:none;stroke-width:2;}
.confirm-title{font-size:.95rem;font-weight:600;margin-bottom:.55rem;}
.confirm-sub{font-size:.82rem;color:var(--wh4);line-height:1.65;margin-bottom:1.6rem;}
.btn-danger{background:var(--red);color:#fff;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.45rem 1.1rem;border-radius:980px;border:none;cursor:pointer;font-family:inherit;transition:background .2s;}
.btn-danger:hover{background:var(--rd);}
.app-wrap{position:relative;min-height:700px;width:100%;overflow-x:hidden;}

/* ── Login ───────────────────────────────────────────────────────────────── */
body.login-open{position:fixed;top:0;left:0;right:0;overflow:hidden;}
.login-screen{position:fixed;inset:0;background:var(--blk);display:flex;align-items:center;justify-content:center;z-index:9999;overflow:hidden;touch-action:none;overscroll-behavior:none;}
.login-card{background:var(--d2);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:2.8rem 3rem;width:420px;max-width:calc(100% - 2rem);}
.login-logo{width:100%;height:auto;display:block;margin-bottom:.5rem;}
.login-divider{height:1px;background:var(--wh08);margin:1.8rem 0;}
.login-error{font-size:.72rem;color:#f87171;margin-bottom:.8rem;display:none;}
.login-btn{width:100%;background:var(--red);color:#fff;border:none;border-radius:980px;padding:.7rem;font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;font-family:inherit;transition:background .2s;}
.login-btn:hover{background:var(--rd);}

/* ── Board search ────────────────────────────────────────────────────────── */
.board-search-bar{padding:.6rem 1.5rem .25rem;}
.board-search{width:100%;max-width:420px;background:var(--d3);border:1px solid var(--wh08);border-radius:9px;padding:.52rem 1rem;font-size:.88rem;color:var(--wh);font-family:inherit;outline:none;transition:border-color .18s;box-sizing:border-box;}
.board-search:focus{border-color:rgba(255,255,255,.22);}
.board-search::placeholder{color:var(--wh4);}
.search-results-wrap{padding:0 1.5rem;}
.search-result-count{font-size:.72rem;color:var(--wh4);letter-spacing:.08em;text-transform:uppercase;padding:.6rem 0 .4rem;}
.search-flat-list{background:var(--d2);border:1px solid var(--wh08);border-radius:14px;overflow:hidden;}
.search-flat-list .t-head{padding:.55rem 1.2rem;border-bottom:1px solid var(--wh05);}
.search-flat-list .t-row{border-bottom:1px solid var(--wh05);}
.search-flat-list .t-row:last-child{border-bottom:none;}
.search-empty{padding:2rem 1.5rem;color:var(--wh4);font-size:.88rem;}

/* ── Layout helpers ──────────────────────────────────────────────────────── */
.view-spacer{height:1rem;}
.btn-logout{color:rgba(255,255,255,.3);}
.btn-settings{color:rgba(255,255,255,.3);padding:.35rem .5rem;}
.btn-settings:hover{color:rgba(255,255,255,.7);}
/* ── Settings modal ──────────────────────────────────────────────────────── */
.settings-modal-bg{display:none;position:fixed;inset:0;z-index:4000;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);align-items:center;justify-content:center;}
.settings-modal-bg.show{display:flex;}
.settings-modal{background:var(--d2);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:1.5rem;width:min(420px,92vw);box-shadow:0 24px 64px rgba(0,0,0,.6);}
.settings-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;font-size:.95rem;font-weight:600;color:var(--wh);}
.settings-modal-close{background:none;border:none;color:rgba(255,255,255,.3);font-size:1rem;cursor:pointer;padding:.2rem .4rem;border-radius:6px;}
.settings-modal-close:hover{color:var(--wh);background:rgba(255,255,255,.06);}
.settings-section-title{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:.75rem;}
.settings-2fa-status{font-size:.85rem;color:rgba(255,255,255,.6);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem;}
.settings-hint{font-size:.8rem;color:rgba(255,255,255,.45);margin-bottom:.75rem;line-height:1.5;}
.settings-qr{width:160px;height:160px;border-radius:12px;border:2px solid rgba(255,255,255,.1);display:block;}
.totp-badge{font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:.2rem .55rem;border-radius:6px;}
.totp-on{background:rgba(22,163,74,.2);color:#4ade80;border:1px solid rgba(22,163,74,.3);}
.totp-off{background:rgba(255,255,255,.05);color:rgba(255,255,255,.35);border:1px solid rgba(255,255,255,.1);}
.totp-input-row{display:flex;align-items:center;gap:.75rem;}
.totp-input-row input{flex:1;}
.totp-timer{position:relative;width:52px;height:52px;flex-shrink:0;}
.totp-timer-svg{width:100%;height:100%;transform:rotate(-90deg);}
.totp-timer-bg{fill:none;stroke:rgba(255,255,255,.08);stroke-width:3;}
.totp-timer-ring{fill:none;stroke:var(--red);stroke-width:3;stroke-linecap:round;stroke-dasharray:138.23;stroke-dashoffset:0;transition:stroke-dashoffset .9s linear,stroke .4s;}
.totp-timer-ring.warn{stroke:#d97706;}
.totp-timer-num{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.72rem;font-weight:600;color:var(--wh);line-height:1;}
.totp-status-row{display:flex;align-items:center;gap:.75rem;}
.totp-status-row .totp-timer{width:44px;height:44px;}
.settings-divider{border:none;border-top:1px solid rgba(255,255,255,.07);margin:1.25rem 0;}
.pw-success-msg{font-size:.82rem;color:#4ade80;padding:.4rem 0;}
.stats-row-3{grid-template-columns:repeat(3,1fr);}
.stat-val-sm{font-size:1rem;}

/* ── Client book layout ──────────────────────────────────────────────────── */
#viewClients.active{display:flex;flex-direction:column;height:calc(100vh - 100px);overflow:hidden;}
#viewClients .stats-row{flex-shrink:0;}
.kb-layout{padding:0 1.5rem 1.5rem;display:grid;grid-template-columns:1fr 1.6fr;gap:16px;align-items:stretch;flex:1;min-height:0;}
.kb-panel{background:var(--d2);border:1px solid var(--wh08);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;}
#clientList{flex:1;overflow-y:auto;min-height:0;}
#clientDetail{overflow-y:auto;}
.kb-panel-header{padding:.85rem 1.2rem;background:var(--d3);border-bottom:1px solid var(--wh08);font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;color:var(--wh6);font-weight:600;display:flex;align-items:center;justify-content:space-between;}
.kb-year-select{font-size:.68rem;font-weight:500;background:var(--d2);border:1px solid var(--wh08);color:var(--wh6);border-radius:6px;padding:.22rem .5rem;cursor:pointer;font-family:inherit;outline:none;letter-spacing:0;text-transform:none;transition:border-color .18s,color .18s;}
.kb-year-select:hover{border-color:rgba(255,255,255,.22);color:var(--wh);}
.kb-year-select option{background:var(--d2);color:var(--wh);}
.kb-empty{padding:3rem 1.4rem;text-align:center;}
.kb-empty p{font-size:.88rem;color:var(--wh4);}

/* ── Client search ───────────────────────────────────────────────────────── */
.kb-search-wrap{padding:.7rem 1rem;border-bottom:1px solid var(--wh05);}
.kb-search{width:100%;background:var(--d3);border:1px solid var(--wh08);border-radius:9px;padding:.5rem .85rem;font-size:.88rem;color:var(--wh);font-family:inherit;outline:none;transition:border-color .18s;box-sizing:border-box;}
.kb-search:focus{border-color:rgba(255,255,255,.22);}
.kb-search::placeholder{color:var(--wh4);}

/* ── Client list item ────────────────────────────────────────────────────── */
.cl-item{display:flex;align-items:center;gap:.9rem;padding:.95rem 1.2rem;border-bottom:1px solid var(--wh05);cursor:pointer;transition:background .2s;}
.cl-item:hover{background:rgba(255,255,255,.04);transform:translateX(2px);}
.cl-item{transition:background .15s,transform .18s,border-color .18s;}
.cl-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:700;color:#fff;flex-shrink:0;}
.cl-name{font-size:.95rem;font-weight:600;margin-bottom:.18rem;}
.cl-meta{font-size:.75rem;color:var(--wh4);}
.cl-revenue{margin-left:auto;text-align:right;}
.cl-revenue-val{font-size:.92rem;font-weight:700;}
.cl-revenue-pct{font-size:.72rem;margin-top:.1rem;}

/* ── Client detail panel ─────────────────────────────────────────────────── */
.cd-header{padding:1.6rem 1.6rem 1.2rem;border-bottom:1px solid var(--wh08);display:flex;align-items:center;gap:1.2rem;}
.cd-avatar{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:#fff;flex-shrink:0;}
.cd-name{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;}
.cd-branch{font-size:.8rem;color:var(--wh4);margin-top:.3rem;}
.cd-actions{margin-left:auto;display:flex;gap:.5rem;}
.cd-delete-btn{color:rgba(248,113,113,.6);border-color:rgba(248,113,113,.2);}
.cd-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--wh08);}
.cd-stat-cell{background:var(--d2);padding:1.1rem 1.2rem;}
.cd-stat-cell-label{font-size:.65rem;letter-spacing:.13em;text-transform:uppercase;color:var(--wh4);margin-bottom:.4rem;}
.cd-stat-cell-val{font-size:1.3rem;font-weight:700;}
.cd-revenue-bar{padding:1rem 1.6rem;border-bottom:1px solid var(--wh08);}
.cd-revenue-label{font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;color:var(--wh4);margin-bottom:.6rem;}
.cd-bar-track{height:7px;background:var(--d3);border-radius:4px;overflow:hidden;}
.cd-bar-fill{height:100%;border-radius:4px;}
.cd-info-section{padding:1rem 1.6rem;border-bottom:1px solid var(--wh08);}
.cd-projects-section{padding:1rem 1.6rem;}
.cd-projects-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.cd-projects-actions{display:flex;align-items:center;gap:.5rem;}
.cd-year-switcher{display:flex;gap:.25rem;}
.cd-year-switcher .year-btn{font-size:.7rem;padding:.2rem .55rem;}
.cd-projects-label{font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;color:var(--wh4);}
.cd-add-proj-btn{font-size:.72rem;padding:.25rem .65rem;}
.cd-proj-group{margin-bottom:1.2rem;}
.cd-proj-group-header{font-size:.62rem;letter-spacing:.13em;text-transform:uppercase;color:var(--wh4);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem;}
.cd-proj-count{background:rgba(255,255,255,.08);border-radius:20px;padding:.1rem .5rem;font-size:.65rem;font-weight:600;}
.cd-project-row{display:flex;align-items:center;gap:.8rem;padding:.7rem .4rem;border-bottom:1px solid var(--wh05);cursor:pointer;border-radius:7px;transition:background .15s;margin:0 -.4rem;}
.cd-project-row:hover{background:rgba(255,255,255,.04);}
.cd-proj-info{flex:1;min-width:0;}
.cd-project-name{display:block;font-size:.88rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cd-project-date{display:block;font-size:.72rem;color:var(--wh4);margin-top:.15rem;}
.cd-proj-badges{display:flex;gap:.35rem;flex-wrap:wrap;flex-shrink:0;}
.cd-project-amount{font-size:.88rem;font-weight:700;min-width:65px;text-align:right;flex-shrink:0;}
.cd-no-projects{font-size:.85rem;color:var(--wh4);}
.cd-proj-search-wrap{margin-bottom:.75rem;}
.cd-proj-search{font-size:.82rem;padding:.4rem .75rem;}
.cd-info-label{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--wh4);margin-bottom:.2rem;}
.cd-info-val{font-size:.92rem;color:var(--wh6);}
.cd-info-row{display:flex;align-items:flex-start;gap:.75rem;padding:.65rem 0;border-bottom:1px solid var(--wh05);}
.cd-info-row:last-child{border-bottom:none;}
.cd-info-icon{width:34px;height:34px;border-radius:8px;background:var(--d3);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cd-info-icon svg{width:15px;height:15px;stroke:var(--wh4);fill:none;stroke-width:2;}
.r-pill-sm{pointer-events:none;font-size:.55rem;}

/* ── Table footer sum ────────────────────────────────────────────────────── */
.t-footer-sum{color:var(--red);font-size:1rem;font-weight:700;}
.t-footer-sum-label{display:block;font-size:.6rem;color:rgba(255,255,255,.3);font-weight:400;}

/* ── Modals ──────────────────────────────────────────────────────────────── */
.modal-wide{width:680px;}
.modal-2col{display:grid;grid-template-columns:1fr 1fr;gap:0 1.8rem;}
.confirm-actions{display:flex;gap:.7rem;justify-content:flex-end;}

/* ── Address Autocomplete Dropdown ───────────────────────────────────────── */
.places-dropdown{display:none;position:absolute;top:100%;left:0;right:0;background:#1e1e1e;border:1px solid rgba(255,255,255,.12);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.5);margin-top:4px;overflow:hidden;z-index:9999;}
.places-item{padding:.6rem .95rem;font-size:.88rem;color:rgba(255,255,255,.75);cursor:pointer;border-top:1px solid rgba(255,255,255,.06);}
.places-item:first-child{border-top:none;}
.places-item:hover{background:rgba(255,255,255,.07);color:#fff;}

/* ── Client page (pinned tab) ────────────────────────────────────────────── */
.cp-wrap{max-width:1300px;margin:0 auto;}
.cp-hero{display:flex;align-items:center;gap:1.5rem;background:var(--d2);border:1px solid var(--wh08);border-left:3px solid var(--cc,var(--red));border-radius:16px;padding:1.4rem 1.8rem;flex-wrap:wrap;gap:1.2rem;margin:1.5rem 1.5rem 0;}
.cp-hero-left{display:flex;align-items:center;gap:1.1rem;flex:0 0 auto;}
.cp-hero-avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;color:#fff;flex-shrink:0;}
.cp-hero-name{font-size:1.35rem;font-weight:700;letter-spacing:-.03em;}
.cp-hero-branch{font-size:.74rem;color:var(--wh4);margin-top:.2rem;}
.cp-hero-kpis{display:flex;gap:1.8rem;flex:1;justify-content:center;flex-wrap:wrap;}
.cp-kpi{text-align:center;}
.cp-kpi-label{font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--wh4);margin-bottom:.3rem;}
.cp-kpi-val{font-size:1.1rem;font-weight:700;letter-spacing:-.025em;}
.cp-hero-actions{display:flex;gap:.5rem;flex:0 0 auto;flex-wrap:wrap;align-items:center;}
.cp-content{display:flex;flex-direction:column;gap:0;margin-top:1.2rem;}
.cp-projects-col{min-width:0;}
.cp-sidebar{display:flex;flex-direction:row;flex-wrap:wrap;gap:1.2rem;padding:1.2rem 1.5rem 1.5rem;}
.cp-sidebar .dash-panel{flex:1;min-width:260px;}
.cp-no-projs{padding:2.5rem 1.4rem;text-align:center;color:var(--wh3);font-size:.88rem;}
.cp-contact-body{padding:.9rem 1.4rem;display:flex;flex-direction:column;gap:.75rem;}
.cp-info-item{display:flex;align-items:flex-start;gap:.7rem;font-size:.85rem;color:var(--wh7);}
.cp-info-item svg{flex-shrink:0;margin-top:1px;opacity:.55;}
.cp-client-notes{padding:.9rem 1.4rem;font-size:.85rem;color:var(--wh6);line-height:1.65;}

/* ── Finance view ────────────────────────────────────────────────────────── */
.fin-yoy-card{background:var(--d2);border:1px solid var(--wh08);border-radius:14px;padding:1.1rem 1.4rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;margin-bottom:1.5rem;}
.fin-yoy-left{flex:1;}
.fin-yoy-label{font-size:.63rem;letter-spacing:.13em;text-transform:uppercase;color:var(--wh4);margin-bottom:.4rem;}
.fin-yoy-val{font-size:1.8rem;font-weight:700;letter-spacing:-.03em;line-height:1;}
.fin-yoy-val.pos{color:#16a34a;}
.fin-yoy-val.neg{color:var(--red);}
.fin-yoy-sub{font-size:.7rem;color:var(--wh4);margin-top:.3rem;}
.fin-yoy-cols{display:flex;align-items:center;gap:1.2rem;}
.fin-yoy-col{text-align:right;}
.fin-yoy-col-label{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--wh4);margin-bottom:.2rem;}
.fin-yoy-col-val{font-size:1rem;font-weight:700;}
.fin-yoy-col-val.muted{color:var(--wh4);}
.fin-yoy-divider{width:1px;height:32px;background:var(--wh08);}
.fin-tva-panel{border:1px solid rgba(208,17,27,.25) !important;background:rgba(208,17,27,.06) !important;padding:1.4rem;}
.fin-tva-title{font-size:.65rem;letter-spacing:.13em;text-transform:uppercase;color:var(--red);margin-bottom:.6rem;}
.fin-tva-amount{font-size:2.4rem;font-weight:800;color:var(--red);letter-spacing:-.03em;line-height:1;}
.fin-tva-sub{font-size:.78rem;color:var(--wh4);margin-top:.4rem;margin-bottom:1.2rem;}
.fin-tva-breakdown{border-top:1px solid rgba(255,255,255,.08);padding-top:.9rem;display:flex;flex-direction:column;gap:.45rem;}
.fin-tva-row{display:flex;justify-content:space-between;font-size:.85rem;color:var(--wh6);}
.fin-tva-total{border-top:1px solid rgba(255,255,255,.1);padding-top:.45rem;font-weight:700;color:var(--wh);}
.fin-inv-row{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.4rem;border-bottom:1px solid var(--wh05);}
.fin-inv-row:last-child{border-bottom:none;}
.fin-inv-amount{font-size:.92rem;font-weight:700;}
.fin-table{width:100%;}
.fin-table-head{display:grid;grid-template-columns:1.4fr .7fr 1fr 1fr 1fr 1fr;padding:.6rem 1.4rem;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--wh4);border-bottom:1px solid var(--wh08);}
.fin-table-row{display:grid;grid-template-columns:1.4fr .7fr 1fr 1fr 1fr 1fr;padding:.75rem 1.4rem;border-bottom:1px solid var(--wh05);font-size:.88rem;align-items:center;}
.fin-table-row:hover{background:rgba(255,255,255,.025);}
.fin-table-footer{display:grid;grid-template-columns:1.4fr .7fr 1fr 1fr 1fr 1fr;padding:.75rem 1.4rem;background:var(--d3);border-top:1px solid var(--wh08);font-size:.88rem;font-weight:700;}
.fin-month{font-weight:600;}
.fin-tva-cell{color:var(--red);}
.fin-paid-cell{color:#16a34a;}

/* ── Dashboard ───────────────────────────────────────────────────────────── */
.dashboard{padding:1.5rem;}

/* KPI row */
.dash-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:1.5rem;}
.dash-kpi-card{background:var(--d2);border:1px solid var(--wh08);border-radius:16px;padding:1.5rem 1.7rem;transition:border-color .2s,transform .2s,box-shadow .2s;}
.dash-kpi-card:hover{border-color:rgba(208,17,27,.3);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.25);}
.dash-kpi-card.accent{border-left:3px solid var(--red);}
.dash-kpi-label{font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;color:var(--wh4);margin-bottom:.65rem;}
.dash-kpi-val{font-size:2.1rem;font-weight:700;letter-spacing:-.04em;line-height:1;}
.dash-kpi-val.red{color:var(--red);}
.dash-kpi-sub{font-size:.7rem;color:var(--wh4);margin-top:.5rem;}

/* Two-column rows */
.dash-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:1.5rem;}

/* Panel card */
.dash-panel{background:var(--d2);border:1px solid var(--wh08);border-radius:16px;overflow:hidden;}
.dash-panel-header{padding:.72rem 1.2rem;background:var(--d3);border-bottom:1px solid var(--wh08);display:flex;align-items:center;justify-content:space-between;}
.dash-panel-title{font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--wh4);}
.dash-panel-count{font-size:.62rem;color:var(--wh4);background:var(--d2);border:1px solid var(--wh08);padding:.15rem .55rem;border-radius:980px;}

/* List items inside panels */
.dash-item{display:flex;align-items:center;gap:.75rem;padding:.68rem 1.2rem;border-bottom:1px solid var(--wh05);}
.dash-item:last-child{border-bottom:none;}
.dash-item-main{flex:1;min-width:0;}
.dash-item-name{font-size:.82rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dash-item-meta{font-size:.68rem;color:var(--wh4);margin-top:.15rem;}
.dash-item-amount{font-size:.82rem;font-weight:700;text-align:right;min-width:72px;flex-shrink:0;}
.dash-empty{padding:2.2rem;text-align:center;font-size:.78rem;color:rgba(255,255,255,.2);font-style:italic;}

/* Client bar in top clients panel */
.dash-client-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;color:#fff;flex-shrink:0;}
.dash-client-bar{height:3px;border-radius:2px;margin-top:.35rem;min-width:4px;}

/* Clickable states */
.dash-kpi-card[data-action]{cursor:pointer;}
.dash-item[data-action]{cursor:pointer;transition:background .15s;}
.dash-item[data-action]:hover{background:rgba(255,255,255,.04);transform:translateX(3px);}
.dash-item{transition:background .15s,transform .18s;}

/* ── Dashboard mini calendar ─────────────────────────────────────────────── */
.dcal-panel{margin-bottom:1.5rem;}
.dcal-header{justify-content:center;gap:1.2rem;}
.dcal-nav{font-size:1.2rem;padding:.05rem .45rem;line-height:1;}
.dcal-body{display:flex;min-height:0;}
.dcal-grid-wrap{padding:1rem 1.1rem;border-right:1px solid var(--wh08);flex-shrink:0;}
.dcal-grid{display:grid;grid-template-columns:repeat(7,34px);gap:2px;}
.dcal-dn{font-size:.6rem;color:var(--wh4);text-align:center;padding:.1rem 0 .5rem;font-weight:600;letter-spacing:.05em;}
.dcal-cell{display:flex;flex-direction:column;align-items:center;gap:3px;padding:.35rem .1rem;border-radius:9px;min-height:44px;cursor:pointer;transition:background .15s;}
.dcal-cell:hover{background:rgba(208,17,27,.12);}
.dcal-cell:hover .dcal-num{color:var(--wh);}
.dcal-busy:hover{background:rgba(208,17,27,.18);}
.dcal-today .dcal-num{background:var(--red);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-weight:700;}
.dcal-num{font-size:.78rem;color:var(--wh6);line-height:1;}
.dcal-dots{display:flex;gap:2px;justify-content:center;flex-wrap:wrap;}
.dcal-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;}
.dcal-more{font-size:.48rem;color:var(--wh4);line-height:1;}
.dcal-events-list{flex:1;padding:.6rem .9rem;display:flex;flex-direction:column;gap:.25rem;}
.dcal-event{display:flex;align-items:center;gap:.7rem;padding:.55rem .65rem;border-radius:11px;transition:background .15s;}
.dcal-event:hover{background:rgba(255,255,255,.04);}
.dcal-event-date{display:flex;flex-direction:column;align-items:center;min-width:28px;flex-shrink:0;text-align:center;}
.dcal-event-d{font-size:.88rem;font-weight:700;color:var(--wh);line-height:1.1;}
.dcal-event-dow{font-size:.58rem;color:var(--wh4);letter-spacing:.04em;white-space:nowrap;}
.dcal-event-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.dcal-event-main{flex:1;min-width:0;}
.dcal-event-name{font-size:.84rem;color:var(--wh);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dcal-event-meta{display:flex;gap:.5rem;align-items:baseline;margin-top:.15rem;flex-wrap:wrap;}
.dcal-event-client{font-size:.7rem;color:var(--wh4);white-space:nowrap;}
.dcal-event-addr{font-size:.68rem;color:var(--wh3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dcal-event-umsatz{font-size:.75rem;font-weight:600;color:var(--wh5);white-space:nowrap;flex-shrink:0;margin-right:.3rem;}

/* ── Invoice list view ───────────────────────────────────────────────────────*/
.inv-view{padding:1.5rem;}
.inv-view-header{margin-bottom:1.5rem;}
.inv-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.inv-kpi{background:var(--d2);border:1px solid var(--wh08);border-radius:16px;padding:1.2rem 1.5rem;}
.inv-kpi-label{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--wh4);margin-bottom:.5rem;}
.inv-kpi-val{font-size:1.7rem;font-weight:700;letter-spacing:-.03em;}
.inv-kpi-val.green{color:#22c55e;}
.inv-empty{padding:3rem;text-align:center;color:var(--wh4);font-size:.85rem;}
.inv-table-wrap{background:var(--d2);border:1px solid var(--wh08);border-radius:16px;overflow:hidden;margin-top:1.5rem;}
.inv-list-head{display:grid;grid-template-columns:1.2fr 1.2fr 1.2fr 1.6fr .9fr .9fr 1fr 1fr .4fr;padding:.65rem 1.2rem;background:var(--d3);border-bottom:1px solid var(--wh08);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--wh4);}
.inv-list-row{display:grid;grid-template-columns:1.2fr 1.2fr 1.2fr 1.6fr .9fr .9fr 1fr 1fr .4fr;padding:.8rem 1.2rem;border-bottom:1px solid var(--wh08);align-items:center;cursor:pointer;transition:background .15s;}
.inv-list-row:last-child{border-bottom:none;}
.inv-list-row:hover{background:rgba(255,255,255,.03);}
.inv-list-number{font-size:.78rem;font-weight:600;color:var(--wh);}
.inv-list-client,.inv-list-subject,.inv-list-project{font-size:.78rem;color:var(--wh6);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:.5rem;}
.inv-list-project{color:var(--wh4);font-style:italic;}
.inv-list-date,.inv-list-due{font-size:.75rem;color:var(--wh4);}
.inv-list-amount{font-size:.82rem;font-weight:600;color:var(--wh);}
.inv-status-pill{display:inline-block;font-size:.58rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .7rem;border-radius:980px;white-space:nowrap;cursor:pointer;transition:opacity .15s;}
.inv-status-pill:hover{opacity:.75;}
.inv-status-draft{background:rgba(255,255,255,.08);color:rgba(255,255,255,.5);}
.inv-status-sent{background:rgba(234,179,8,.15);color:#fbbf24;}
.inv-status-paid{background:rgba(34,197,94,.15);color:#22c55e;}
.inv-status-void{background:rgba(239,68,68,.12);color:#f87171;}

/* ── Invoice view header ─────────────────────────────────────────────────────*/
.inv-view-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.4rem;}
.inv-view-title{font-size:1.4rem;font-weight:700;letter-spacing:-.03em;color:var(--wh);}
.inv-view-sub{font-size:.72rem;color:var(--wh4);margin-top:.15rem;}
.inv-new-btn{font-size:.78rem;padding:.55rem 1.3rem;display:flex;align-items:center;}
.inv-import-btn{font-size:.78rem;padding:.55rem 1.1rem;display:flex;align-items:center;}
.inv-import-btn[data-importing]{opacity:.5;pointer-events:none;}
.inv-imported-badge{display:inline-block;font-size:.5rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.4);border-radius:4px;padding:.15rem .45rem;margin-left:.4rem;vertical-align:middle;}
.import-toast{position:fixed;bottom:5rem;left:50%;transform:translateX(-50%) translateY(12px);background:var(--d2);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:.65rem 1.2rem;font-size:.8rem;color:var(--wh);z-index:9000;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none;white-space:nowrap;box-shadow:0 8px 32px rgba(0,0,0,.5);}
.import-toast.import-toast-show{opacity:1;transform:translateX(-50%) translateY(0);}
.import-toast.import-toast-error{border-color:rgba(208,17,27,.35);color:#f87171;}
.import-toast.import-toast-warn{border-color:rgba(217,119,6,.35);color:#fbbf24;}
.inv-kpi-val.amber{color:#f59e0b;}
.inv-empty-state{padding:3rem;text-align:center;color:var(--wh4);font-size:.85rem;display:flex;flex-direction:column;align-items:center;border:1px dashed var(--wh08);border-radius:16px;margin-bottom:1.5rem;}

/* ── Invoice custom dropdown buttons ────────────────────────────────────────*/
.inv-dd-btn{display:flex;align-items:center;gap:.45rem;background:var(--d3);border:1px solid var(--wh08);border-radius:8px;padding:.45rem .7rem;color:var(--wh);font-size:.82rem;font-family:inherit;cursor:pointer;transition:border-color .15s;width:100%;text-align:left;}
.inv-dd-btn:hover{border-color:rgba(255,255,255,.2);}
.inv-dd-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:rgba(255,255,255,.2);}
.inv-dd-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.inv-dd-chev{flex-shrink:0;color:var(--wh4);}
.inv-date-wrap{position:relative;}
.inv-calendar{position:absolute;top:calc(100% + 6px);left:0;background:var(--d2);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:.8rem;z-index:700;display:none;box-shadow:0 20px 60px rgba(0,0,0,.75);min-width:248px;}
.inv-calendar.open{display:block;animation:slideDown .15s ease;}

/* ── Servicekatalog ──────────────────────────────────────────────────────────*/
.inv-catalog{background:var(--d2);border:1px solid var(--wh08);border-radius:16px;overflow:hidden;margin-top:1.5rem;}
.inv-catalog-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.2rem;background:var(--d3);border-bottom:1px solid var(--wh08);}
.inv-catalog-title{font-size:.82rem;font-weight:700;color:var(--wh);margin-right:.6rem;}
.inv-catalog-sub{font-size:.65rem;color:var(--wh4);}
.inv-catalog-add-btn{font-size:.72rem;flex-shrink:0;}
.inv-catalog-head{display:grid;grid-template-columns:1.5fr 2.5fr 1.2fr .6fr;padding:.5rem 1.2rem;font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--wh4);border-bottom:1px solid var(--wh08);}
.inv-catalog-row{display:grid;grid-template-columns:1.5fr 2.5fr 1.2fr .6fr;padding:.7rem 1.2rem;border-bottom:1px solid var(--wh08);align-items:center;}
.inv-catalog-row:last-child{border-bottom:none;}
.inv-catalog-row:hover{background:rgba(255,255,255,.02);}
.inv-catalog-name{font-size:.82rem;font-weight:600;color:var(--wh);}
.inv-catalog-desc{font-size:.76rem;color:var(--wh4);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:.5rem;}
.inv-catalog-price{font-size:.82rem;font-weight:600;color:var(--wh);text-align:right;}
.inv-catalog-actions{display:flex;gap:.3rem;justify-content:flex-end;}
.inv-catalog-edit{background:none;border:none;color:rgba(255,255,255,.3);font-size:.8rem;cursor:pointer;padding:.2rem .4rem;border-radius:4px;transition:color .15s,background .15s;}
.inv-catalog-edit:hover{color:var(--wh);background:rgba(255,255,255,.06);}
.inv-product-form{padding:.9rem 1.2rem;border-top:1px solid var(--wh08);background:rgba(255,255,255,.02);}
.inv-product-form-fields{display:grid;grid-template-columns:1.5fr 2fr 1fr;gap:.7rem;margin-bottom:.75rem;}
.inv-product-input{background:var(--d2);border:1px solid var(--wh08);border-radius:8px;padding:.42rem .65rem;color:var(--wh);font-size:.82rem;font-family:inherit;transition:border-color .15s;width:100%;}
.inv-product-input:focus{outline:none;border-color:rgba(208,17,27,.5);}
.inv-product-form-btns{display:flex;gap:.5rem;justify-content:flex-end;}
.inv-catalog-pick{width:28px;height:28px;flex-shrink:0;background:none;border:1px solid var(--wh08);border-radius:6px;color:var(--wh4);font-size:.72rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s;}
.inv-catalog-pick:hover{color:var(--wh);border-color:rgba(255,255,255,.2);}

/* ── Invoice editor modal ────────────────────────────────────────────────────*/
.inv-editor-modal{background:var(--d2);border:1px solid var(--wh08);border-radius:20px;width:min(1280px,98vw);max-height:96vh;display:flex;flex-direction:column;overflow:hidden;}
.inv-editor-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.4rem;background:var(--d3);border-bottom:1px solid var(--wh08);flex-shrink:0;}
.inv-editor-title{font-size:.95rem;font-weight:600;color:var(--wh);}
.inv-editor-split{flex:1;display:grid;grid-template-columns:1fr 380px;overflow:hidden;min-height:0;}
.inv-editor-body{overflow-y:auto;padding:1.4rem;display:flex;flex-direction:column;gap:.9rem;}
.inv-editor-preview{background:#0e0e0e;border-left:1px solid var(--wh08);display:flex;flex-direction:column;align-items:center;padding:.8rem .8rem 0;overflow-y:auto;}
.inv-preview-label{font-size:.65rem;color:rgba(255,255,255,.25);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.6rem;flex-shrink:0;}
.inv-preview-wrap{width:100%;position:relative;overflow:hidden;}
#invPreviewFrame{width:794px;height:1123px;border:none;transform-origin:top left;display:block;background:#fff;border-radius:2px;box-shadow:0 4px 32px rgba(0,0,0,.6);}
.inv-editor-footer{display:flex;align-items:center;gap:.6rem;padding:.9rem 1.4rem;background:var(--d3);border-top:1px solid var(--wh08);flex-shrink:0;}
/* PDF download button */
.btn-pdf{background:rgba(255,255,255,.07);color:var(--wh6);border:1px solid var(--wh08);display:flex;align-items:center;gap:.4rem;}
.btn-pdf:hover{background:rgba(255,255,255,.12);color:var(--wh);border-color:rgba(255,255,255,.2);}
/* Meta rows */
.inv-editor-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;}
.inv-editor-meta-cp{grid-template-columns:2fr 1fr;gap:.8rem;}
.inv-editor-field{display:flex;flex-direction:column;gap:.35rem;}
.inv-editor-field-client{grid-column:1;/* first col in 2fr grid */}
.inv-editor-field-subject{/* full width naturally */}
.inv-editor-field-notes{/* full width naturally */}
.inv-editor-field label{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--wh4);}
.inv-editor-field input,.inv-editor-field select,.inv-editor-field textarea{background:var(--d3);border:1px solid var(--wh08);border-radius:8px;padding:.45rem .7rem;color:var(--wh);font-size:.82rem;font-family:inherit;transition:border-color .15s;width:100%;}
.inv-editor-field input:focus,.inv-editor-field select:focus,.inv-editor-field textarea:focus{outline:none;border-color:rgba(208,17,27,.5);}
.inv-editor-field textarea{resize:vertical;}
.inv-client-input::placeholder{color:var(--wh4);}
/* Items — grid layout so columns stay aligned */
.inv-items-header{display:grid;grid-template-columns:minmax(0,3fr) 30px minmax(60px,1fr) minmax(80px,1.2fr) minmax(80px,1.2fr) 26px;align-items:center;gap:.5rem;padding:.35rem .4rem;font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--wh4);border-bottom:1px solid var(--wh08);}
.inv-ih-qty,.inv-ih-price,.inv-ih-total{text-align:right;}
.inv-item-row{display:grid;grid-template-columns:minmax(0,3fr) 30px minmax(60px,1fr) minmax(80px,1.2fr) minmax(80px,1.2fr) 26px;align-items:center;gap:.5rem;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.04);}
.inv-item-desc{min-width:0;display:flex;flex-direction:column;gap:.25rem;}
.inv-item-input{background:var(--d3);border:1px solid var(--wh08);border-radius:7px;padding:.35rem .55rem;color:var(--wh);font-size:.78rem;font-family:inherit;width:100%;min-width:0;transition:border-color .15s;}
.inv-item-input:focus{outline:none;border-color:rgba(208,17,27,.4);}
.inv-item-detail{font-size:.72rem;color:var(--wh4);}
.inv-item-qty,.inv-item-price{text-align:right;}
.inv-item-total{text-align:right;font-size:.8rem;font-weight:600;color:var(--wh);white-space:nowrap;}
.inv-item-del{width:22px;height:22px;flex-shrink:0;background:none;border:none;color:rgba(255,255,255,.25);font-size:.7rem;cursor:pointer;border-radius:4px;transition:color .15s,background .15s;}
.inv-item-del:hover{color:var(--red);background:rgba(208,17,27,.1);}
.inv-add-line{margin-top:.2rem;background:none;border:1px dashed var(--wh08);border-radius:8px;color:var(--wh4);font-size:.74rem;padding:.4rem 1rem;cursor:pointer;width:100%;transition:border-color .15s,color .15s;}
.inv-add-line:hover{border-color:rgba(255,255,255,.2);color:var(--wh6);}
/* Totals */
.inv-totals{margin-top:1rem;display:flex;flex-direction:column;align-items:flex-end;gap:.3rem;padding-top:.8rem;border-top:1px solid var(--wh08);}
.inv-totals-row{display:flex;gap:2rem;font-size:.8rem;}
.inv-totals-row span:first-child{color:var(--wh4);min-width:100px;text-align:right;}
.inv-totals-row span:last-child{min-width:90px;text-align:right;font-weight:600;}
.inv-totals-total{font-size:.95rem;padding-top:.3rem;border-top:1px solid var(--wh08);}

/* ── Invoice print template (screen: hidden) ─────────────────────────────────*/
.inv-print-area{display:none;}

/* ── Print styles ────────────────────────────────────────────────────────────*/
@media print {
  body > *:not(#invoicePrintArea){display:none !important;}
  #invoicePrintArea{display:block !important;}
  .inv-print-area{display:block;}
  .inv-print{
    font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;
    font-size:10pt;color:#1a1a1a;
    padding:18mm 16mm;
    max-width:210mm;margin:0 auto;
  }
  /* Top row: logo+from / title block */
  .inv-print-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12mm;}
  .inv-print-from{display:flex;align-items:flex-start;gap:8mm;}
  .inv-print-logo{width:52mm;height:auto;}
  .inv-print-from-details{font-size:8.5pt;color:#333;line-height:1.6;}
  .inv-print-from-details strong{color:#1a1a1a;font-size:9pt;}
  .inv-print-title-block{text-align:right;}
  .inv-print-h1{font-size:32pt;font-weight:300;color:#1a1a1a;letter-spacing:-.02em;line-height:1;}
  .inv-print-num{font-size:9pt;color:#555;margin-top:1mm;}
  .inv-print-balance-label{font-size:7.5pt;color:#555;margin-top:4mm;}
  .inv-print-balance{font-size:18pt;font-weight:700;color:#1a1a1a;}
  /* Info row */
  .inv-print-info-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8mm;}
  .inv-print-bill-to-label{font-size:8pt;color:#555;margin-bottom:1.5mm;}
  .inv-print-bill-to{font-size:9pt;line-height:1.6;}
  .inv-print-bill-to strong{font-size:10pt;}
  .inv-print-meta-table{font-size:8.5pt;border-collapse:collapse;}
  .inv-print-meta-table td{padding:.8mm 0 .8mm 6mm;color:#333;}
  .inv-print-meta-table td:first-child{color:#555;text-align:right;white-space:nowrap;}
  /* Subject */
  .inv-print-subject{font-size:9pt;margin-bottom:6mm;}
  .inv-print-subject-label{color:#555;margin-right:2mm;}
  /* Items table */
  .inv-print-table{width:100%;border-collapse:collapse;margin-bottom:6mm;}
  .inv-print-table thead tr{background:#1a1a1a;color:#fff;}
  .inv-print-table thead th{padding:2.5mm 3mm;font-size:8pt;font-weight:600;text-align:left;}
  .inv-print-table tbody tr{border-bottom:1px solid #e5e5e5;}
  .inv-print-table tbody td{padding:3mm 3mm;font-size:9pt;vertical-align:top;}
  .inv-item-detail-print{font-size:8pt;color:#555;}
  .inv-col-num{width:8mm;text-align:center;}
  .inv-col-qty,.inv-col-up,.inv-col-total{text-align:right;width:22mm;}
  /* Tfoot */
  .inv-print-table tfoot td{padding:2mm 3mm;font-size:9pt;}
  .inv-tf-sub td,.inv-tf-tva td{color:#333;}
  .inv-tf-total td,.inv-tf-due td{font-size:10pt;border-top:1px solid #ccc;padding-top:3mm;}
  .inv-tf-total td:last-child,.inv-tf-due td:last-child{font-weight:700;}
  /* Remarks */
  .inv-print-remarks{margin-top:10mm;padding-top:5mm;border-top:1px solid #e5e5e5;}
  .inv-print-remarks-title{font-size:9pt;font-weight:600;margin-bottom:2mm;}
  .inv-print-remarks p{font-size:7.5pt;color:#555;line-height:1.6;margin-bottom:1mm;}
  /* Footer */
  .inv-print-footer{position:fixed;bottom:10mm;left:0;right:0;text-align:center;font-size:7pt;color:#888;border-top:1px solid #e5e5e5;padding-top:3mm;}
}

/* =============================================================================
   MOBILE / RESPONSIVE — Breakpoints
   768px  = Tablet-Portrait (nav collapses)
   640px  = Mobile (board switches to card layout)
   480px  = Small mobile
   ============================================================================= */

/* ── Hamburger button (hidden on desktop) ───────────────────────────────────── */
.hamburger{display:none;background:none;border:none;cursor:pointer;color:var(--wh6);padding:.3rem;flex-shrink:0;}
.hamburger svg{display:block;}

/* ── Mobile FAB (hidden on desktop) ─────────────────────────────────────────── */
.mobile-fab{display:none;position:fixed;bottom:1.5rem;right:1.5rem;z-index:700;width:52px;height:52px;border-radius:50%;background:var(--red);border:none;color:#fff;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(208,17,27,.45);transition:transform .15s,box-shadow .15s;}
.mobile-fab:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(208,17,27,.55);}

/* ── Mobile nav overlay ─────────────────────────────────────────────────────── */
.nav-mobile-open .nav-bar{
  position:fixed;top:56px;left:0;right:0;z-index:800;
  flex-direction:column;align-items:flex-start;
  background:var(--d1);border-bottom:1px solid var(--wh08);
  padding:.5rem 0;gap:0;max-height:calc(100vh - 56px);overflow-y:auto;
}
.nav-mobile-open .nav-tab{width:100%;padding:.85rem 1.5rem;border-bottom:none;border-left:2px solid transparent;}
.nav-mobile-open .nav-tab.active{border-left-color:var(--red);}
.nav-mobile-open .nav-sep{width:calc(100% - 3rem);height:1px;margin:.3rem 1.5rem;}
.nav-mobile-open .mobile-fab{display:none;}
body.modal-open .mobile-fab{display:none!important;}

@media (max-width: 768px) {
  /* Topbar — hide text buttons, keep only search + hamburger + logout */
  .topbar{padding:0 .75rem;gap:.5rem;overflow:hidden;}
  .topbar-left{flex-shrink:0;}
  .topbar-logo{height:20px;width:auto;max-width:90px;}
  .topbar-year-progress{display:none;}
  .topbar-clock{display:none;}
  .topbar-search-wrap{min-width:0;flex:1;}
  .topbar-right{gap:.4rem;}
  .topbar-right .btn-ghost:not(.btn-logout):not(.btn-settings){display:none;}
  #mainAddBtn{display:none;}
  .hamburger{display:flex;}

  /* FAB visible on mobile */
  .mobile-fab{display:flex;}

  /* Year-switcher wraps instead of overflowing */
  .year-switcher{flex-wrap:wrap;padding:.75rem .75rem .4rem;}
  .year-btn{font-size:.68rem;padding:.3rem .75rem;}

  /* Status pills inside calendar events — don't force min-width */
  .dcal-event .status-pill{min-width:0;font-size:.56rem;padding:.18rem .55rem;}

  /* Modal dropdown buttons — smaller on mobile */
  .pd-dd-btn{font-size:.78rem;padding:.35rem .65rem;}

  /* Dashboard open invoices — compact pills */
  .dash-item .r-pill{min-width:0;font-size:.58rem;padding:.25rem .6rem;}

  /* Add bottom padding so FAB doesn't cover last content */
  .dashboard{padding-bottom:5rem;}
  .inv-view{padding-bottom:5rem;}
  .view-spacer{height:5rem;}

  /* Nav becomes hidden by default, toggled via .nav-mobile-open on body */
  .nav-bar{display:none;}
  .nav-mobile-open .nav-bar{display:flex;}

  /* Main content / dashboard padding */
  .dashboard{padding:.75rem;}

  /* Dashboard KPI grid → 2 columns */
  .dash-kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:1rem;}

  /* Dashboard panels → single column stack */
  .dash-row{grid-template-columns:1fr;gap:10px;margin-bottom:1rem;}

  /* Calendar → full width */
  .dcal-body{flex-direction:column;}
  .dcal-grid-wrap{border-right:none;width:100%;box-sizing:border-box;}
  .dcal-grid{grid-template-columns:repeat(7,1fr);}
  .dcal-cell{min-height:40px;}
  .dcal-events-list{border-top:1px solid var(--wh08);}

  /* Dashboard KPI card text sizes */
  .dash-kpi-val{font-size:1.3rem;}

  /* Stats */
  .stats-row{grid-template-columns:repeat(2,1fr);gap:8px;padding:1rem;}

  /* Invoice KPI row → 2 columns */
  .inv-kpi-row{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:1rem;}

  /* Invoice view — re-enable inline add button (mainAddBtn hidden on mobile) */
  .inv-new-btn{display:flex;}

  /* Project detail modal — stack sidebar below main content */
  .pd-body{flex-direction:column;overflow-y:auto;}
  .pd-main{overflow-y:visible;}
  .pd-sidebar{width:100%;border-left:none;border-top:1px solid var(--wh08);overflow-y:visible;}

  /* Invoice view padding */
  .inv-view{padding:.75rem;}

  /* Finance YoY card → stack vertically */
  .fin-yoy-card{flex-direction:column;align-items:flex-start;gap:1rem;}
  .fin-yoy-cols{width:100%;justify-content:flex-start;}

  /* Finance table → fewer columns */
  .fin-table-head{grid-template-columns:1.8fr .8fr 1fr 1fr;padding:.5rem .9rem;}
  .fin-table-row{grid-template-columns:1.8fr .8fr 1fr 1fr;padding:.6rem .9rem;}
  .fin-table-footer{grid-template-columns:1.8fr .8fr 1fr 1fr;padding:.6rem .9rem;}
  .fin-table-head span:nth-child(5),
  .fin-table-row span:nth-child(5),
  .fin-table-footer span:nth-child(5),
  .fin-table-head span:nth-child(6),
  .fin-table-row span:nth-child(6),
  .fin-table-footer span:nth-child(6){display:none;}

  /* Global search results */
  .global-search-results{top:56px;left:.75rem;right:.75rem;width:auto;transform:none;}

  /* Client page hero + wrap */
  .cp-hero{margin:.75rem .75rem 0;}
  .cp-sidebar{padding:.9rem .75rem 1rem;}

  /* Prevent iOS Safari from zooming in when tapping inputs (< 16px triggers zoom) */
  .form-row input,.form-row select,.form-row textarea,
  .topbar-search-input,.board-search,.pd-input,
  .pd-name-input,.notes-editor{font-size:16px;}
}

@media (max-width: 640px) {
  /* Project table → stacked cards */
  .t-head{display:none;}
  .t-row{
    display:flex;flex-direction:column;gap:.5rem;
    padding:.9rem 1rem;position:relative;
  }
  .t-row > div:not(.proj-cell):not(:last-child){font-size:.8rem;}

  /* Project cell — name + dot row */
  .proj-cell{gap:8px;}

  /* Hide less important columns on small screens */
  .t-row > div:nth-child(4),   /* Adresse */
  .t-row > div:nth-child(5)    /* Umsatz label */
  {display:none;}

  /* Pills: compact inline tags, not full-width blocks */
  .t-row > div > .status-pill,
  .t-row > div > .r-pill{display:inline-block;padding:.25rem .65rem;font-size:.58rem;}

  /* Delete button absolute top-right */
  .t-row > div:last-child{position:absolute;top:.7rem;right:.7rem;}

  /* Finance table — further hide columns */
  .fin-table-head span:nth-child(4),
  .fin-table-row span:nth-child(4),
  .fin-table-footer span:nth-child(4){display:none;}
  .fin-table-head{grid-template-columns:2fr .9fr 1fr;}
  .fin-table-row{grid-template-columns:2fr .9fr 1fr;}
  .fin-table-footer{grid-template-columns:2fr .9fr 1fr;}

  /* Modals full-screen — remove modal-bg padding so height:100dvh isn't pushed below viewport */
  .modal-bg{padding-top:0;align-items:stretch;}
  .pd-modal,.inv-modal{width:100vw;max-width:100vw;height:100dvh;max-height:100dvh;border-radius:0;}
  /* Safe area for iPhone home bar */
  .pd-footer{padding-bottom:max(.9rem, env(safe-area-inset-bottom));}
  .inv-modal-footer{padding-bottom:max(.9rem, env(safe-area-inset-bottom));}

  /* Invoice list → hide less critical columns */
  .inv-list-head span:nth-child(3),
  .inv-list-row span:nth-child(3),
  .inv-list-head span:nth-child(4),
  .inv-list-row span:nth-child(4),
  .inv-list-head span:nth-child(5),
  .inv-list-row span:nth-child(5),
  .inv-list-head span:nth-child(6),
  .inv-list-row span:nth-child(6){display:none;}
  .inv-list-head{grid-template-columns:1fr 1.2fr 1fr 1fr .4fr;}
  .inv-list-row{grid-template-columns:1fr 1.2fr 1fr 1fr .4fr;}

  /* Invoice catalog table → simpler */
  .inv-catalog-head span:nth-child(2),
  .inv-catalog-row span:nth-child(2){display:none;}
  .inv-catalog-head{grid-template-columns:2fr 1.4fr .6fr;}
  .inv-catalog-row{grid-template-columns:2fr 1.4fr .6fr;}

  /* Finance inv-row panels stacked */
  .fin-tva-panel{margin-bottom:.75rem;}
}

@media (max-width: 480px) {
  .stats-row{grid-template-columns:1fr 1fr;gap:6px;padding:.75rem;}
  .stat-val{font-size:1.4rem;}
  .topbar{height:50px;}
  .topbar-logo{height:18px;}
  .global-search-results{top:50px;}
  .dash-kpi-val{font-size:1.1rem;}
  .inv-kpi-val{font-size:1.1rem;}
  .fin-yoy-val{font-size:1.4rem;}
}

/* ── Bank / Kontoauszug ──────────────────────────────────────────────────────── */
.bank-panel{margin-top:1.5rem;}
.bank-panel .dash-panel-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;}
.bank-import-btn{margin-left:auto;}

.bank-month-summary{border-bottom:1px solid var(--wh08);padding:.5rem .25rem;}
.bank-month-head{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:.5rem 1rem;padding:.3rem .25rem;font-size:.63rem;letter-spacing:.1em;text-transform:uppercase;color:var(--wh4);}
.bank-month-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:.5rem 1rem;padding:.4rem .25rem;font-size:.82rem;border-top:1px solid var(--wh08);}
.bank-month-label{font-weight:500;}

.bank-tx-list{display:flex;flex-direction:column;gap:0;}
.bank-tx-row{display:grid;grid-template-columns:90px 1fr 50px 110px;align-items:start;gap:.5rem 1rem;padding:.65rem .25rem;border-bottom:1px solid var(--wh08);}
.bank-tx-row:last-child{border-bottom:none;}
.bank-tx-in{background:transparent;}
.bank-tx-out{opacity:.7;}

.bank-tx-date{font-size:.8rem;color:var(--wh4);white-space:nowrap;padding-top:2px;}
.bank-tx-desc{min-width:0;}
.bank-tx-name{font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bank-tx-ref{font-size:.75rem;color:var(--wh4);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bank-tx-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;margin-top:.4rem;}
.bank-tx-type{font-size:.75rem;color:var(--wh4);padding-top:2px;}
.bank-tx-amt{font-size:.875rem;font-weight:600;text-align:right;white-space:nowrap;padding-top:2px;}
.bank-amt-pos{color:#16a34a;}
.bank-amt-neg{color:#f87171;}

.bank-match-badge{font-size:.72rem;padding:1px 6px;border-radius:4px;background:#16a34a22;color:#16a34a;font-weight:500;white-space:nowrap;}
.bank-match-miss{background:#f59e0b22;color:#d97706;}

.bank-match-select{font-size:.75rem;padding:.3rem .6rem;border:1px solid var(--wh08);border-radius:8px;background:var(--d3);color:var(--wh);cursor:pointer;max-width:200px;font-family:inherit;outline:none;-webkit-appearance:none;transition:border-color .15s;}
.bank-match-select:focus{border-color:var(--red);}
.bank-match-select option{background:var(--d3);color:var(--wh);}
.bank-unmatch-btn,.bank-dismiss-btn{font-size:.72rem;}

.bank-dismissed-note{text-align:center;font-size:.78rem;color:var(--wh4);padding:.5rem 0 .25rem;}

@media (max-width: 640px) {
  .bank-tx-row{grid-template-columns:70px 1fr 80px;gap:.35rem .5rem;}
  .bank-tx-type{display:none;}
}
