:root{
  --bg:#0c0e14;--bg2:#111520;--bg3:#171c2b;--bg4:#1d2235;--bg5:#242840;
  --amber:#f5a623;--amber2:#e8941a;--adim:rgba(245,166,35,.13);--adim2:rgba(245,166,35,.22);
  --t1:#eceff8;--t2:#8b96ba;--t3:#505878;
  --bdr:rgba(255,255,255,.06);--bdr2:rgba(255,255,255,.11);--bdr3:rgba(255,255,255,.18);
  --green:#22c55e;--gdim:rgba(34,197,94,.12);
  --red:#ef4444;--rdim:rgba(239,68,68,.12);
  --blue:#3b82f6;--bdim:rgba(59,130,246,.12);
  --purple:#a855f7;--pdim:rgba(168,85,247,.12);
  --cyan:#06b6d4;--cdim:rgba(6,182,212,.12);
  --r:10px;--rs:6px;--rxl:14px;
  --sh:0 4px 24px rgba(0,0,0,.4);
}
body[data-theme="light"]{
  --bg:#f4f1e8;--bg2:#fffdf8;--bg3:#efe8da;--bg4:#e3d8c1;--bg5:#d3c5ab;
  --amber:#b86d1a;--amber2:#9c5c16;--adim:rgba(184,109,26,.12);--adim2:rgba(184,109,26,.2);
  --t1:#211b12;--t2:#6f6657;--t3:#9f927b;
  --bdr:rgba(33,27,18,.08);--bdr2:rgba(33,27,18,.14);--bdr3:rgba(33,27,18,.2);
  --green:#1f8a4c;--gdim:rgba(31,138,76,.12);
  --red:#c14131;--rdim:rgba(193,65,49,.12);
  --blue:#2865c7;--bdim:rgba(40,101,199,.12);
  --purple:#8b5fc7;--pdim:rgba(139,95,199,.12);
  --cyan:#147f98;--cdim:rgba(20,127,152,.12);
  --sh:0 8px 28px rgba(66,48,19,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--bg);color:var(--t1);font-family:'Segoe UI',system-ui,-apple-system,sans-serif;font-size:13.5px;display:flex;overflow:hidden}

/* ── AUTH ── */
#auth-screen{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:999}
.auth-card{background:var(--bg2);border:1px solid var(--bdr2);border-radius:var(--rxl);padding:40px 44px;width:380px;text-align:center}
.auth-logo{width:52px;height:52px;background:var(--amber);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 18px}
.auth-title{font-size:20px;font-weight:800;margin-bottom:4px}
.auth-sub{font-size:13px;color:var(--t3);margin-bottom:28px}
.auth-card input{width:100%;padding:10px 14px;background:var(--bg3);border:1px solid var(--bdr2);border-radius:var(--rs);color:var(--t1);font-size:14px;margin-bottom:12px;font-family:inherit}
.auth-card input:focus{outline:none;border-color:var(--amber)}
.auth-card .btn-primary{width:100%;padding:11px;font-size:14px}
.auth-error{color:var(--red);font-size:12px;margin-top:8px}

/* ── LAYOUT ── */
#sidebar{width:224px;min-width:224px;background:var(--bg2);border-right:1px solid var(--bdr);display:flex;flex-direction:column;transition:width .2s}
#main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}

/* ── SIDEBAR ── */
.sb-logo{padding:17px 15px 14px;border-bottom:1px solid var(--bdr);display:flex;align-items:center;gap:10px}
.sb-logo-icon{width:32px;height:32px;background:var(--amber);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.sb-logo-text{font-size:14px;font-weight:800;letter-spacing:-.3px}
.sb-logo-sub{font-size:9px;color:var(--t3);letter-spacing:.8px;text-transform:uppercase}
nav{flex:1;padding:8px;overflow-y:auto;display:flex;flex-direction:column;gap:1px}
.nav-sec{font-size:9.5px;color:var(--t3);text-transform:uppercase;letter-spacing:1px;padding:10px 8px 4px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--rs);cursor:pointer;color:var(--t2);transition:all .13s;font-size:13px;position:relative;user-select:none}
.nav-item:hover{background:var(--bg3);color:var(--t1)}
.nav-item.active{background:var(--adim);color:var(--amber);font-weight:600}
.nav-icon{font-size:14px;width:16px;text-align:center;flex-shrink:0}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:8px;min-width:16px;text-align:center;line-height:14px}
.nav-badge.amber{background:var(--amber);color:#000}
.nav-badge.green{background:var(--green);color:#000}
.sb-user{padding:11px 15px;border-top:1px solid var(--bdr);display:flex;align-items:center;gap:9px}
.sb-avatar{width:28px;height:28px;border-radius:50%;background:var(--adim2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--amber);flex-shrink:0}
.sb-user-info{flex:1;min-width:0}
.sb-user-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-role{font-size:10px;color:var(--t3)}
.sb-logout{cursor:pointer;color:var(--t3);font-size:13px;padding:4px}.sb-logout:hover{color:var(--red)}

/* ── TOPBAR ── */
.topbar{height:52px;border-bottom:1px solid var(--bdr);display:flex;align-items:center;padding:0 20px;gap:10px;background:var(--bg2);flex-shrink:0}
.page-title{font-size:15px;font-weight:700;flex:1;display:flex;align-items:center;gap:8px}
.page-subtitle{font-size:12px;color:var(--t3);font-weight:400}
.topbar-actions{display:flex;gap:7px;align-items:center}

/* ── CONTENT ── */
.content{flex:1;overflow-y:auto;padding:20px;min-height:0}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border-radius:var(--rs);font-size:12.5px;font-weight:600;cursor:pointer;border:none;transition:all .13s;white-space:nowrap;font-family:inherit;text-decoration:none}
.btn-primary{background:var(--amber);color:#000}.btn-primary:hover{background:var(--amber2);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--bdr2)}.btn-ghost:hover{background:var(--bg3);color:var(--t1)}
.btn-danger{background:var(--rdim);color:var(--red);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:rgba(239,68,68,.2)}
.btn-success{background:var(--gdim);color:var(--green);border:1px solid rgba(34,197,94,.2)}.btn-success:hover{background:rgba(34,197,94,.22)}
.btn-blue{background:var(--bdim);color:var(--blue);border:1px solid rgba(59,130,246,.2)}.btn-blue:hover{background:rgba(59,130,246,.22)}
.btn-purple{background:var(--pdim);color:var(--purple);border:1px solid rgba(168,85,247,.2)}.btn-purple:hover{background:rgba(168,85,247,.22)}
.btn-sm{padding:4px 9px;font-size:11.5px}
.btn-xs{padding:3px 7px;font-size:11px}
.btn-icon{width:30px;height:30px;padding:0;display:inline-flex;align-items:center;justify-content:center}

/* ── STATS ── */
.stats-row{display:grid;gap:12px;margin-bottom:18px}
.stats-4{grid-template-columns:repeat(4,1fr)}
.stats-3{grid-template-columns:repeat(3,1fr)}
.stats-5{grid-template-columns:repeat(5,1fr)}
.stat-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r);padding:14px 16px;position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--amber);opacity:0}
.stat-card.has-accent::before{opacity:1}
.stat-label{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px;font-weight:600}
.stat-val{font-size:22px;font-weight:800;line-height:1}
.stat-sub{font-size:11px;color:var(--t3);margin-top:3px}
.stat-icon{position:absolute;right:14px;top:14px;font-size:20px;opacity:.25}

/* ── CARD ── */
.card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;margin-bottom:14px}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--bdr);gap:10px;flex-wrap:wrap;min-height:46px}
.card-title{font-size:13px;font-weight:700}
.card-body{padding:16px}

/* ── TABLE ── */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;min-width:500px}
thead th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--t3);padding:9px 14px;border-bottom:1px solid var(--bdr);background:var(--bg3);font-weight:600;white-space:nowrap}
tbody tr{border-bottom:1px solid var(--bdr);transition:background .1s;cursor:default}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:rgba(255,255,255,.02)}
td{padding:10px 14px;font-size:13px;color:var(--t2);vertical-align:middle}
td.strong{color:var(--t1);font-weight:600}
td.mono{font-family:monospace;font-size:12px}
.tbl-actions{display:flex;gap:4px;align-items:center;flex-wrap:wrap}

/* ── BADGES ── */
.bdg{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.bdg-green{background:var(--gdim);color:var(--green)}
.bdg-amber{background:var(--adim);color:var(--amber)}
.bdg-red{background:var(--rdim);color:var(--red)}
.bdg-blue{background:var(--bdim);color:var(--blue)}
.bdg-purple{background:var(--pdim);color:var(--purple)}
.bdg-cyan{background:var(--cdim);color:var(--cyan)}
.bdg-gray{background:var(--bg4);color:var(--t3)}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:200;padding:16px;overflow-y:auto}
.modal{background:var(--bg2);border:1px solid var(--bdr2);border-radius:var(--rxl);padding:22px;width:540px;max-width:100%;position:relative;animation:mIn .18s ease}
.modal-md{width:680px}.modal-lg{width:820px}.modal-xl{width:980px}
@keyframes mIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.modal-title{font-size:15px;font-weight:700;margin-bottom:18px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.modal-close{background:none;border:none;color:var(--t3);font-size:20px;cursor:pointer;line-height:1;padding:2px;flex-shrink:0}.modal-close:hover{color:var(--t1)}
.m-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:18px;padding-top:14px;border-top:1px solid var(--bdr)}

/* ── FORMS ── */
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.fg label{font-size:11px;color:var(--t3);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.fg input,.fg select,.fg textarea{background:var(--bg3);border:1px solid var(--bdr2);border-radius:var(--rs);padding:8px 11px;color:var(--t1);font-size:13px;width:100%;font-family:inherit;transition:border-color .13s}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--amber)}
.fg textarea{resize:vertical;min-height:68px}
.fg select option{background:var(--bg3)}
.fg.inline{flex-direction:row;align-items:center;gap:10px}
.fg.inline label{white-space:nowrap;margin:0;min-width:60px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
.form-grid .fg.full{grid-column:1/-1}
.form-row{display:flex;gap:12px}
.form-row .fg{flex:1}

/* ── SEARCH BAR ── */
.search-wrap{display:flex;align-items:center;gap:7px;background:var(--bg3);border:1px solid var(--bdr2);border-radius:var(--rs);padding:6px 11px}
.search-wrap span{color:var(--t3);font-size:13px;flex-shrink:0}
.search-wrap input{background:none;border:none;color:var(--t1);font-size:13px;outline:none;flex:1;min-width:0;font-family:inherit}

/* ── TABS ── */
.tabs{display:flex;gap:1px;background:var(--bg3);border-radius:var(--rs);padding:3px;margin-bottom:16px;width:fit-content}
.tab{padding:6px 14px;border-radius:5px;cursor:pointer;font-size:12.5px;color:var(--t2);transition:all .13s;font-weight:500;white-space:nowrap}
.tab:hover:not(.active){color:var(--t1)}
.tab.active{background:var(--bg2);color:var(--t1);font-weight:700;box-shadow:0 1px 3px rgba(0,0,0,.3)}

/* ── QUOTE / INVOICE BUILDER ── */
.li-header{display:grid;grid-template-columns:2.5fr .8fr 1.1fr 1.1fr .9fr 32px;gap:5px;font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;padding:0 4px;margin-bottom:4px}
.li-row{display:grid;grid-template-columns:2.5fr .8fr 1.1fr 1.1fr .9fr 32px;gap:5px;align-items:center;margin-bottom:5px}
.li-row input{padding:6px 8px;font-size:12.5px}
.li-total-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg3);border-radius:var(--rs);padding:10px 14px;margin-top:10px}
.li-del{background:var(--rdim);border:none;color:var(--red);border-radius:var(--rs);width:28px;height:28px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.li-del:hover{background:rgba(239,68,68,.22)}
.totals-block{display:flex;flex-direction:column;align-items:flex-end;gap:4px;margin-top:10px;padding-right:4px}
.tot-row{display:flex;gap:20px;font-size:13px;color:var(--t2)}
.tot-row span:last-child{min-width:90px;text-align:right}
.tot-row.grand{font-size:15px;font-weight:800;color:var(--amber);border-top:1px solid var(--bdr2);padding-top:5px;margin-top:3px}

/* ── SIGNATURE PAD ── */
.sig-container{border:1px solid var(--bdr2);border-radius:var(--rs);background:#fff;overflow:hidden;margin:8px 0;position:relative}
.sig-canvas{display:block;width:100%;cursor:crosshair;touch-action:none}
.sig-hint{position:absolute;bottom:6px;left:0;right:0;text-align:center;font-size:11px;color:#aaa;pointer-events:none}

/* ── CALENDAR ── */
.cal-wrap{display:flex;flex-direction:column;gap:12px}
.cal-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.cal-title{font-size:16px;font-weight:700}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;gap:0}
.cal-dow{background:var(--bg3);text-align:center;font-size:10px;text-transform:uppercase;color:var(--t3);padding:7px 4px;font-weight:600;letter-spacing:.6px;border-bottom:1px solid var(--bdr)}
.cal-cell{background:var(--bg2);min-height:100px;padding:6px;border-right:1px solid var(--bdr);border-bottom:1px solid var(--bdr);cursor:pointer;transition:background .1s;position:relative}
.cal-cell:nth-child(7n){border-right:none}
.cal-cell:hover{background:var(--bg3)}
.cal-cell.today{background:var(--adim)}
.cal-cell.today .cal-num{color:var(--amber);font-weight:800}
.cal-cell.other-month{opacity:.3}
.cal-num{font-size:12px;color:var(--t2);margin-bottom:3px}
.cal-chip{font-size:10px;padding:2px 5px;border-radius:3px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}
.chip-install{background:var(--adim);color:var(--amber)}
.chip-quote{background:var(--bdim);color:var(--blue)}
.chip-repair{background:var(--gdim);color:var(--green)}
.chip-other{background:var(--bg4);color:var(--t3)}
/* Week view */
.week-grid{display:grid;grid-template-columns:60px repeat(7,1fr);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden}
.week-header{background:var(--bg3);padding:8px 6px;text-align:center;border-right:1px solid var(--bdr);border-bottom:1px solid var(--bdr);font-size:11px;font-weight:600}
.week-time{background:var(--bg3);padding:4px 8px;font-size:10px;color:var(--t3);text-align:right;border-right:1px solid var(--bdr);border-bottom:1px solid var(--bdr)}
.week-cell{min-height:40px;border-right:1px solid var(--bdr);border-bottom:1px solid var(--bdr);cursor:pointer;transition:background .1s;padding:2px}
.week-cell:hover{background:var(--bg3)}

/* ── CUSTOMER PROFILE ── */
.profile-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:18px;background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r);padding:18px}
.profile-avatar{width:52px;height:52px;border-radius:50%;background:var(--adim2);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--amber);flex-shrink:0}
.profile-info{flex:1;min-width:0}
.profile-name{font-size:18px;font-weight:800;margin-bottom:4px}
.profile-meta{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--t2)}
.profile-actions{display:flex;gap:6px;flex-wrap:wrap;flex-shrink:0}

/* ── SEND BAR ── */
.send-bar{display:flex;gap:7px;align-items:center;background:var(--bg3);border-radius:var(--rs);padding:10px 12px;flex-wrap:wrap;margin-top:10px}
.send-bar-label{font-size:11px;color:var(--t3);flex:1}

/* ── INVENTORY ── */
.inv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.inv-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r);padding:14px;position:relative}
.inv-card.low-stock{border-color:rgba(239,68,68,.3);background:var(--rdim)}
.inv-card-name{font-size:14px;font-weight:700;margin-bottom:4px}
.inv-card-sku{font-size:11px;color:var(--t3);margin-bottom:8px;font-family:monospace}
.inv-card-row{display:flex;justify-content:space-between;font-size:12px;margin-bottom:3px}
.inv-card-qty{font-size:22px;font-weight:800;color:var(--amber);margin-bottom:6px}

/* ── LEAD QUEUE ── */
.lead-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r);padding:14px 16px;margin-bottom:8px;transition:border-color .13s}
.lead-card:hover{border-color:var(--bdr3)}
.lead-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.lead-card-name{font-size:14px;font-weight:700}
.lead-card-meta{font-size:12px;color:var(--t2);margin-top:2px}
.lead-card-body{font-size:12px;color:var(--t2);background:var(--bg3);border-radius:var(--rs);padding:8px 10px;margin-bottom:10px;line-height:1.5}
.lead-card-actions{display:flex;gap:6px;flex-wrap:wrap}

/* ── PIPELINE KANBAN ── */
.pipeline{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:18px;overflow-x:auto}
.pipe-col{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r);padding:10px;min-width:150px}
.pipe-col-hdr{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.pipe-count{font-size:11px;background:var(--bg4);border-radius:10px;padding:1px 7px;color:var(--t3);font-weight:600}
.pipe-card{background:var(--bg3);border-radius:var(--rs);padding:9px 10px;margin-bottom:6px;cursor:pointer;border-left:2px solid transparent;transition:all .13s}
.pipe-card:hover{border-left-color:var(--amber);transform:translateX(2px)}
.pipe-card-name{font-size:12.5px;font-weight:600;color:var(--t1);margin-bottom:2px}
.pipe-card-sub{font-size:11px;color:var(--t3)}

/* ── AUTOMATION LOG ── */
.auto-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--bdr);font-size:12px}
.auto-item:last-child{border-bottom:none}
.auto-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* ── DOCUMENT PREVIEW ── */
.doc-preview{background:var(--bg3);border-radius:var(--r);padding:22px}
.doc-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}
.doc-company{font-size:18px;font-weight:800;color:var(--amber)}
.doc-tagline{font-size:11px;color:var(--t3);margin-top:2px}
.doc-type{font-size:26px;font-weight:800;color:var(--t3)}
.doc-num{font-size:13px;color:var(--t3)}
.doc-info{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.doc-block label{display:block;font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px;font-weight:600}
.doc-block p{font-size:13px;line-height:1.5}
.doc-table{width:100%;border-collapse:collapse;margin-bottom:10px}
.doc-table th{text-align:left;font-size:10px;color:var(--t3);padding:6px 8px;border-bottom:1px solid var(--bdr2);text-transform:uppercase;font-weight:600}
.doc-table td{padding:8px 8px;font-size:13px;border-bottom:1px solid var(--bdr)}

/* ── ACTIVITY FEED ── */
.af-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-bottom:1px solid var(--bdr)}
.af-item:last-child{border-bottom:none}
.af-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.af-content{flex:1;min-width:0}
.af-title{font-size:12.5px;color:var(--t1);line-height:1.4}
.af-time{font-size:11px;color:var(--t3);margin-top:1px}

/* ── TOAST ── */
.toast{position:fixed;bottom:20px;right:20px;background:var(--bg2);border:1px solid var(--bdr2);border-radius:var(--r);padding:11px 16px;font-size:13px;z-index:500;display:flex;align-items:center;gap:9px;max-width:340px;box-shadow:var(--sh);animation:slideIn .2s ease}
.toast.success{border-left:3px solid var(--green)}
.toast.error{border-left:3px solid var(--red)}
.toast.info{border-left:3px solid var(--blue)}
@keyframes slideIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ── EMPTY ── */
.empty{text-align:center;padding:52px 20px;color:var(--t3)}
.empty-icon{font-size:36px;margin-bottom:12px}
.empty p{font-size:13px;margin-bottom:16px}

/* ── MISC ── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.divider{height:1px;background:var(--bdr);margin:14px 0}
.tag{display:inline-flex;padding:2px 7px;border-radius:4px;font-size:11px;font-weight:600;background:var(--bg4);color:var(--t2);margin:2px}
.tag-remove{cursor:pointer;margin-left:3px;color:var(--t3)}.tag-remove:hover{color:var(--red)}
.alert{padding:10px 14px;border-radius:var(--rs);font-size:12.5px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.alert-warn{background:var(--adim);border:1px solid rgba(245,166,35,.25);color:var(--amber)}
.alert-err{background:var(--rdim);border:1px solid rgba(239,68,68,.25);color:var(--red)}
.alert-ok{background:var(--gdim);border:1px solid rgba(34,197,94,.25);color:var(--green)}
.tooltip{position:relative}
.tooltip:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 5px);left:50%;transform:translateX(-50%);background:var(--bg5);color:var(--t1);font-size:11px;padding:4px 8px;border-radius:4px;white-space:nowrap;pointer-events:none;z-index:10}
a{color:inherit;text-decoration:none}
.chip{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:600;gap:4px}

/* Scrollbar */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:10px}

/* Print */
@media print{
  #sidebar,#auth-screen,.topbar,.modal-overlay,.send-bar,.m-actions,.tbl-actions,.btn{display:none!important}
  body{overflow:auto;display:block}
  #main{overflow:auto;display:block}
  .content{padding:0}
  .doc-preview{background:#fff;color:#000;padding:30px}
  .doc-company,.doc-type,.doc-num,.doc-block label{color:#000}
  .doc-block p,.doc-table td,.doc-table th,.tot-row{color:#333}
  .tot-row.grand{color:#000}
}
.public-shell{min-height:100vh;background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%);padding:28px 16px}
.public-doc-wrap{max-width:960px;margin:0 auto}
.public-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.public-title{font-size:28px;font-weight:800}
.public-sub{font-size:13px;color:var(--t2);margin-top:6px;line-height:1.5}
.public-actions{display:flex;gap:8px;flex-wrap:wrap}
