*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --blue:#1a56db;--blue-dark:#1040a8;--blue-light:#ebf2ff;--blue-mid:#6096f5;
  --amber:#EF9F27;--coral:#D85A30;--coral-light:#FAECE7;--green:#16a34a;--green-light:#dcfce7;
  --bg:#ffffff;--bg2:#f7f9fc;--bg3:#eef2f8;
  --text:#1a1a2e;--text2:#5a6480;--text3:#9ba3b8;
  --border:rgba(26,86,219,0.1);--border2:rgba(26,86,219,0.2);
  --radius:8px;--radius-lg:12px;
}
/* ── DARK MODE ── */
#screen-bk.dark-mode, #screen-client.dark-mode{
  --bg:#0f1117;--bg2:#1a1d27;--bg3:#13151e;
  --text:#e8eaf0;--text2:#8b92a8;--text3:#555d78;
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.13);
  --blue-light:#162040;--blue-mid:#2d4a8a;
  --coral-light:#2a1510;--green-light:#0f2a18;
  background:#0f1117;
  color:#e8eaf0;
}
#screen-bk.dark-mode .nav, #screen-client.dark-mode .nav{background:#0a0d14;border-bottom:0.5px solid rgba(255,255,255,0.07);}
#screen-bk.dark-mode .card, #screen-client.dark-mode .card{background:var(--bg2);}
#screen-bk.dark-mode input,#screen-bk.dark-mode select,#screen-bk.dark-mode textarea,#screen-client.dark-mode input,#screen-client.dark-mode select,#screen-client.dark-mode textarea{background:var(--bg2);color:var(--text);border-color:var(--border2);}
#screen-bk.dark-mode .login-box, #screen-client.dark-mode .login-box{background:var(--bg2);}
#screen-bk.dark-mode .login-wrap, #screen-client.dark-mode .login-wrap{background:var(--bg3);}
#screen-bk.dark-mode .client-row, #screen-client.dark-mode .client-row{background:var(--bg2);}
#screen-bk.dark-mode .client-row:hover, #screen-client.dark-mode .client-row:hover{background:var(--bg3);}
#screen-bk.dark-mode .ov-kpi, #screen-client.dark-mode .ov-kpi{background:var(--bg2);}
#screen-bk.dark-mode .inv-card, #screen-client.dark-mode .inv-card{background:var(--bg2);}
#screen-bk.dark-mode .chat-messages, #screen-client.dark-mode .chat-messages{background:var(--bg2);}
#screen-bk.dark-mode .msg-bubble.from-acc, #screen-client.dark-mode .msg-bubble.from-acc{background:#1a2a4a;}
#screen-bk.dark-mode .msg-bubble.from-cl, #screen-client.dark-mode .msg-bubble.from-cl{background:var(--bg3);}
#screen-bk.dark-mode .thread-item, #screen-client.dark-mode .thread-item{background:var(--bg2);}
#screen-bk.dark-mode .thread-item:hover, #screen-client.dark-mode .thread-item:hover{background:var(--bg3);}
#screen-bk.dark-mode .btype-btn, #screen-client.dark-mode .btype-btn{background:var(--bg3);border-color:var(--border2);}
#screen-bk.dark-mode .bclient-row, #screen-client.dark-mode .bclient-row{border-color:var(--border);}
#screen-bk.dark-mode .vault-file-row, #screen-client.dark-mode .vault-file-row{background:var(--bg2);}
#screen-bk.dark-mode .vault-sm-row, #screen-client.dark-mode .vault-sm-row{background:var(--bg2);}
#screen-bk.dark-mode #resource-panel,#screen-bk.dark-mode #broadcast-panel,#screen-bk.dark-mode #ov-insights-panel,#screen-bk.dark-mode #ov-invoice-panel,#screen-client.dark-mode #resource-panel,#screen-client.dark-mode #broadcast-panel,#screen-client.dark-mode #ov-insights-panel,#screen-client.dark-mode #ov-invoice-panel{background:var(--bg2);}
#screen-bk.dark-mode .ov-period-row, #screen-client.dark-mode .ov-period-row{background:var(--bg2);}
#screen-bk.dark-mode .ov-period-row:hover, #screen-client.dark-mode .ov-period-row:hover{background:var(--bg3);}
#screen-bk.dark-mode .ov-notes, #screen-client.dark-mode .ov-notes{background:var(--bg2);}
#screen-bk.dark-mode .cl-tile, #screen-client.dark-mode .cl-tile{background:var(--bg2);}
#screen-bk.dark-mode #cl-settings-panel,#screen-bk.dark-mode #cl-grow-panel,#screen-bk.dark-mode #cl-invoice-panel,#screen-bk.dark-mode #cl-vault-panel,#screen-bk.dark-mode #cl-messages-panel,#screen-bk.dark-mode #cl-directory,#screen-client.dark-mode #cl-settings-panel,#screen-client.dark-mode #cl-grow-panel,#screen-client.dark-mode #cl-invoice-panel,#screen-client.dark-mode #cl-vault-panel,#screen-client.dark-mode #cl-messages-panel,#screen-client.dark-mode #cl-directory{background:var(--bg);}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg3);color:var(--text);min-height:100vh;}
.screen{display:none;min-height:100vh;}.screen.active{display:block;}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;}
.login-box{background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:2rem;width:100%;max-width:400px;box-shadow:0 4px 24px rgba(26,86,219,0.08);}
.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:1.75rem;}
.logo-mark{width:36px;height:36px;background:var(--blue);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;}
.logo-mark svg,.nav-logo-mark svg{stroke:white;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;}
.logo-text,.nav-logo-text{font-weight:700;color:#fff;}
.logo-text{font-size:18px;}.nav-logo-text{font-size:14px;}
.logo-text span,.nav-logo-text span{color:#93c5fd;}
.nav-user{font-size:13px;color:rgba(255,255,255,0.7);margin-right:8px;}
.nav-btn{padding:7px 12px;border-radius:var(--radius);border:0.5px solid rgba(255,255,255,0.2);background:transparent;color:rgba(255,255,255,0.85);font-size:13px;cursor:pointer;margin-left:6px;}
.nav-btn:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.4);color:#fff;}
.nav-btn.blue{background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.4);color:#fff;font-weight:600;}
.lang-toggle{display:flex;gap:6px;margin-bottom:1.25rem;}
.lang-btn{padding:5px 14px;border-radius:20px;border:0.5px solid var(--border2);font-size:12px;cursor:pointer;color:var(--text2);background:transparent;transition:all 0.15s;}
.lang-btn.active{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:500;}
.login-title{font-size:15px;font-weight:600;margin-bottom:4px;}
.login-sub{font-size:13px;color:var(--text2);margin-bottom:1.5rem;}
.role-toggle{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:1.25rem;}
.role-btn{padding:9px;border-radius:var(--radius);border:0.5px solid var(--border2);background:transparent;color:var(--text2);font-size:13px;cursor:pointer;transition:all 0.15s;text-align:center;}
.role-btn.active{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:500;}
.lfield{display:flex;flex-direction:column;gap:5px;margin-bottom:12px;}
.lfield label{font-size:12px;color:var(--text2);font-weight:500;}
.lfield input,.lfield select{height:40px;border:0.5px solid var(--border2);border-radius:var(--radius);padding:0 12px;font-size:14px;background:var(--bg);color:var(--text);width:100%;}
.lfield input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,86,219,0.1);}
.btn-full{width:100%;height:42px;border-radius:var(--radius);border:none;background:var(--blue);color:#fff;font-size:14px;font-weight:600;cursor:pointer;}
.btn-full:hover{background:var(--blue-dark);}
.error-msg{font-size:13px;color:var(--coral);margin-top:10px;min-height:18px;}
.nav{display:flex;align-items:center;background:#1e56c8;border-bottom:none;padding:0 1.5rem;position:sticky;top:0;z-index:10;flex-wrap:nowrap;}
.nav-logo{display:flex;align-items:center;gap:8px;padding:12px 0;margin-right:auto;}
.nav-logo-mark{width:28px;height:28px;background:var(--blue);border-radius:6px;display:flex;align-items:center;justify-content:center;}
.nav-tab{padding:0 12px;height:49px;display:flex;align-items:center;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;transition:all 0.15s;white-space:nowrap;}
.nav-tab.active{color:var(--text);border-bottom-color:var(--blue);font-weight:500;}
.nav-tab:hover:not(.active){color:var(--text);}
.badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:9px;background:var(--coral);color:#fff;font-size:10px;font-weight:700;padding:0 4px;margin-left:4px;vertical-align:middle;}
.badge.amber{background:var(--amber);}
.page{max-width:960px;margin:0 auto;padding:1.5rem;}
/* ── ACCOUNTANT DESKTOP LAYOUT ── */
#screen-bk .page{max-width:1400px;padding:1.5rem 2rem;}
#screen-bk .nav{padding:0 2rem;position:relative;}
/* Always show nav-menu on accountant screen regardless of viewport width */
#screen-bk .nav .nav-menu{display:flex !important;}
/* Prevent views from overflowing but not the fixed panels */
#screen-bk .view{max-width:100%;}
/* Overview two-col — right panel fixed, left takes rest */
#screen-bk .ov-two-col{grid-template-columns:1fr 280px;}
@media(min-width:1200px){#screen-bk .ov-two-col{grid-template-columns:1fr 300px;}}
/* Input grid — 3 cols max to prevent overflow */
@media(min-width:1024px){
  #screen-bk .input-grid{grid-template-columns:repeat(3,1fr);}
}
.view{display:none;}.view.active{display:block;}
.section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3);margin-bottom:12px;}
.card{background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:8px;}
h1{font-size:16px;font-weight:600;}
.search-wrap{position:relative;margin-bottom:1rem;}
.search-wrap input{width:100%;height:40px;border:0.5px solid var(--border2);border-radius:var(--radius);padding:0 12px 0 36px;font-size:14px;background:var(--bg);color:var(--text);}
.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:14px;pointer-events:none;}
.input-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:10px;}
.f{display:flex;flex-direction:column;gap:5px;}
.f label{font-size:12px;color:var(--text2);font-weight:500;}
.f input,.f select{height:36px;border:0.5px solid var(--border2);border-radius:var(--radius);padding:0 10px;font-size:14px;background:var(--bg);color:var(--text);width:100%;}
.f textarea{border:0.5px solid var(--border2);border-radius:var(--radius);padding:8px 10px;font-size:14px;background:var(--bg);color:var(--text);width:100%;height:80px;resize:vertical;font-family:inherit;}
.f input:focus,.f select:focus,.f textarea:focus{outline:none;border-color:var(--blue);}
.f input[readonly]{background:var(--blue-light);color:var(--blue-dark);font-weight:600;border-color:var(--blue-mid);}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);border:0.5px solid var(--border2);background:transparent;color:var(--text);font-size:13px;cursor:pointer;white-space:nowrap;}
.btn:hover{background:var(--bg2);}
.btn.primary{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:500;}
.btn.primary:hover{background:var(--blue-dark);}
.btn.sm{padding:5px 12px;font-size:12px;}
.btn-row{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap;align-items:center;}
.hint{font-size:12px;color:var(--text2);line-height:1.6;}
.save-badge{display:none;font-size:12px;color:var(--blue);margin-left:8px;}
.save-badge.show{display:inline;}
.cat-dropdown-wrap{position:relative;margin-bottom:10px;}
.cat-trigger{display:flex;align-items:center;justify-content:space-between;height:36px;border:0.5px solid var(--border2);border-radius:var(--radius);padding:0 10px;font-size:14px;background:var(--bg);color:var(--text);cursor:pointer;user-select:none;}
.cat-trigger.open{border-color:var(--blue);}
.cat-dd{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg);border:0.5px solid var(--border2);border-radius:var(--radius-lg);box-shadow:0 8px 24px rgba(26,86,219,0.12);z-index:50;max-height:280px;overflow-y:auto;}
.cat-dd.open{display:block;}
.cat-dd-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:13px;color:var(--text2);}
.cat-dd-item:hover{background:var(--blue-light);color:var(--blue);}
.cat-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}
.cat-tag{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--blue-light);border:0.5px solid var(--blue-mid);border-radius:20px;font-size:12px;color:var(--blue);font-weight:500;}
.cat-tag-x{cursor:pointer;font-size:14px;color:var(--blue-mid);}
.cat-tag-x:hover{color:var(--coral);}
.client-list{display:flex;flex-direction:column;gap:8px;}
.client-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all 0.15s;}
.client-row:hover{border-color:var(--blue-mid);background:var(--blue-light);}
.c-av{width:40px;height:40px;border-radius:50%;background:var(--blue-light);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--blue-dark);flex-shrink:0;}
.c-info{flex:1;min-width:0;}
.c-name{font-size:14px;font-weight:500;color:var(--text);}
.c-meta{font-size:12px;color:var(--text2);margin-top:2px;}
.c-pin{font-size:11px;color:var(--text3);font-family:monospace;padding:3px 8px;background:var(--bg2);border-radius:var(--radius);}
.c-actions{display:flex;gap:6px;align-items:center;}
.icon-btn{width:30px;height:30px;border-radius:var(--radius);border:0.5px solid var(--border2);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text2);font-size:13px;}
.icon-btn.sm{width:24px;height:24px;font-size:11px;}
.icon-btn:hover{background:var(--bg2);}
.icon-btn.del:hover{background:var(--coral-light);border-color:var(--coral);color:var(--coral);}
.empty-state{text-align:center;padding:3rem 1rem;color:var(--text2);font-size:14px;}
.period-wrap{display:flex;flex-direction:column;gap:6px;margin-top:8px;}
.period-item{display:flex;align-items:center;gap:8px;padding:9px 12px;border:0.5px solid var(--border);border-radius:var(--radius);background:var(--bg);}
.period-item:hover{border-color:var(--blue);background:var(--blue-light);}
.period-item.active-period{border-color:var(--blue);background:var(--blue-light);}
.period-name{flex:1;font-size:13px;color:var(--text);cursor:pointer;}
.period-date{font-size:11px;color:var(--text3);}
.msg-row{padding:14px;background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);margin-bottom:8px;cursor:pointer;}
.msg-row.unread{border-color:var(--blue);background:var(--blue-light);}
.msg-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;}
.msg-from{font-size:13px;font-weight:600;}
.msg-date{font-size:11px;color:var(--text3);}
.msg-subj{font-size:13px;font-weight:500;color:var(--blue);margin-bottom:4px;}
.msg-body{font-size:13px;color:var(--text2);line-height:1.5;}
.todo-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:0.5px solid var(--border);}
.todo-item:last-child{border-bottom:none;}
.todo-cb{width:18px;height:18px;accent-color:var(--blue);cursor:pointer;flex-shrink:0;}
.todo-txt{flex:1;font-size:14px;color:var(--text);}
.todo-txt.done{text-decoration:line-through;color:var(--text3);}
.todo-add{display:flex;gap:8px;margin-top:10px;}
.todo-add input{flex:1;height:36px;border:0.5px solid var(--border2);border-radius:var(--radius);padding:0 10px;font-size:14px;background:var(--bg);color:var(--text);}
.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:1rem;}
@media(max-width:640px){.kpi-grid{grid-template-columns:repeat(2,1fr);}}
.kpi-card{background:var(--bg2);border-radius:var(--radius);padding:1rem;border:0.5px solid var(--border);}
.kpi-card.blue-border{background:var(--bg);border:1.5px solid var(--blue-mid);}
.kpi-label{font-size:11px;color:var(--text2);margin-bottom:6px;font-weight:500;text-transform:uppercase;letter-spacing:0.05em;}
.kpi-value{font-size:22px;font-weight:700;color:var(--text);}
.kpi-sub{font-size:12px;margin-top:4px;font-weight:500;}
.up{color:var(--green);}.down{color:var(--coral);}.neutral{color:var(--text2);}
.arrow-up{display:inline-block;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:7px solid var(--green);}
.arrow-down{display:inline-block;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:7px solid var(--coral);}
.paid-badge{display:inline-block;background:var(--green);color:#fff;border-radius:4px;padding:1px 8px;font-size:11px;font-weight:600;}
.acc-wrap{display:flex;justify-content:flex-end;margin-bottom:1rem;}
.acc-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;border:0.5px solid var(--blue);background:var(--blue-light);color:var(--blue);font-size:12px;font-weight:500;cursor:pointer;}
.acc-btn:hover{background:var(--blue);color:#fff;}
.acc-panel{display:none;background:var(--blue);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.5rem;}
.acc-panel.open{display:block;}
.acc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;}
.acc-card{background:rgba(255,255,255,0.15);border-radius:var(--radius);padding:0.875rem;}
.acc-lbl{font-size:11px;color:rgba(255,255,255,0.7);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.05em;}
.acc-val{font-size:18px;font-weight:700;color:#fff;}
.exp-dd{border:1.5px solid var(--blue-mid);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:1rem;}
.exp-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg2);cursor:pointer;}
.exp-hdr:hover{background:var(--blue-light);}
.exp-hdr-left{display:flex;flex-direction:column;gap:2px;}
.exp-hdr-lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3);}
.exp-hdr-val{font-size:20px;font-weight:700;color:var(--text);}
.exp-chevron{font-size:14px;color:var(--text2);transition:transform 0.2s;}
.exp-chevron.open{transform:rotate(180deg);}
.exp-body{display:none;padding:0 16px 12px;background:var(--bg);}
.exp-body.open{display:block;}
.exp-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:0.5px solid var(--border);font-size:13px;}
.exp-row:last-child{border-bottom:none;}
.exp-row-name{color:var(--text2);display:flex;align-items:center;gap:6px;}
.exp-row-val{font-weight:500;color:var(--text);}
.exp-row-val.paid{color:var(--green);}
.alert-box{border-radius:var(--radius);padding:12px 16px;display:flex;align-items:flex-start;gap:10px;margin-bottom:8px;}
.al-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.appt-card{background:var(--blue-light);border:0.5px solid var(--blue-mid);border-radius:var(--radius-lg);padding:1rem 1.25rem;margin-bottom:1rem;display:flex;align-items:center;gap:12px;}
.appt-icon{width:36px;height:36px;background:var(--blue);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.appt-icon svg{width:18px;height:18px;stroke:white;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.appt-lbl{font-size:11px;color:var(--blue);font-weight:600;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:2px;}
.appt-date{font-size:15px;font-weight:600;color:var(--blue-dark);}
.appt-note{font-size:12px;color:var(--text2);margin-top:2px;}
.notes-card{background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;}
.note-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:0.5px solid var(--border);font-size:13px;color:var(--text2);line-height:1.5;}
.note-item:last-child{border-bottom:none;}
.note-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);flex-shrink:0;margin-top:6px;}
.client-hero{display:flex;align-items:center;gap:14px;margin-bottom:1.5rem;}
.ch-av{width:52px;height:52px;border-radius:50%;background:var(--blue-light);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--blue-dark);flex-shrink:0;border:2px solid var(--blue-mid);}
.period-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:1.5rem;}
.period-chip{padding:5px 14px;border-radius:20px;border:0.5px solid var(--border2);font-size:12px;cursor:pointer;color:var(--text2);background:transparent;}
.period-chip.active{background:var(--blue);border-color:var(--blue);color:#fff;}
.loading-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.3);display:flex;align-items:center;justify-content:center;z-index:100;}
.loading-box{background:var(--bg);border-radius:var(--radius-lg);padding:1.5rem 2rem;display:flex;align-items:center;gap:12px;font-size:14px;}
.spinner{width:20px;height:20px;border:2px solid var(--border2);border-top-color:var(--blue);border-radius:50%;animation:spin 0.7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.loading-overlay.hidden{display:none;}
.status-banner{padding:10px 16px;border-radius:var(--radius);font-size:13px;margin-bottom:1rem;display:none;}
.status-banner.success{background:var(--blue-light);color:var(--blue-dark);border:0.5px solid var(--blue-mid);display:block;}
.status-banner.error{background:var(--coral-light);color:var(--coral);border:0.5px solid var(--coral);display:block;}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:200;align-items:center;justify-content:center;padding:1rem;}
.modal-overlay.open{display:flex;}
.modal-box{background:var(--bg);border-radius:var(--radius-lg);padding:2rem;width:100%;max-width:440px;box-shadow:0 8px 32px rgba(26,86,219,0.15);}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;}
.modal-title{font-size:16px;font-weight:600;}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text2);}

/* ── HAMBURGER MENU ── */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;margin-left:auto;}
.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all 0.2s;}
.nav-menu{display:flex;align-items:center;flex-wrap:nowrap;gap:2px;margin-left:auto;}
.nav-menu-dropdown{display:none;position:fixed;top:49px;right:0;left:0;background:var(--bg);border-bottom:0.5px solid var(--border);z-index:99;flex-direction:column;box-shadow:0 4px 16px rgba(0,0,0,0.1);}
.nav-menu-dropdown.open{display:flex;}
.nav-menu-dropdown .nav-tab{padding:14px 20px;border-bottom:0.5px solid var(--border);width:100%;text-align:left;border-radius:0;}
.nav-menu-dropdown .nav-btn{padding:14px 20px;border-bottom:0.5px solid var(--border);width:100%;text-align:left;border-radius:0;background:none;color:var(--text2);border-left:none;border-right:none;border-top:none;margin-left:0;}
.nav-menu-dropdown .nav-btn:hover{background:var(--bg2);color:var(--text);}
@media(max-width:640px){
  .hamburger{display:flex;}
  .nav-menu{display:none;}
  .nav{flex-wrap:nowrap;padding:0 1rem;}
  .nav-logo{margin-right:auto;}
}
/* ── PASSWORD STRENGTH ── */
.pw-rules{margin-top:8px;display:flex;flex-direction:column;gap:4px;}
.pw-rule{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text3);transition:color 0.2s;}
.pw-rule.pass{color:var(--green);}
.pw-rule-dot{width:8px;height:8px;border-radius:50%;background:var(--border2);flex-shrink:0;transition:background 0.2s;}
.pw-rule.pass .pw-rule-dot{background:var(--green);}
/* ── CONSISTENT CHECKBOXES ── */
input[type=checkbox]{
  width:15px;
  height:15px;
  min-width:15px;
  min-height:15px;
  accent-color:var(--blue);
  cursor:pointer;
  margin:0;
  flex-shrink:0;
}
/* ── MESSAGING / CHAT ── */
.thread-list{display:flex;flex-direction:column;gap:8px;}
.thread-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all 0.15s;}
.thread-row:hover{border-color:var(--blue-mid);background:var(--blue-light);}
.thread-row.has-unread{border-color:var(--blue);background:var(--blue-light);}
.thread-av{width:40px;height:40px;border-radius:50%;background:var(--blue-light);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--blue-dark);flex-shrink:0;border:1.5px solid var(--blue-mid);}
.thread-info{flex:1;min-width:0;}
.thread-name{font-size:14px;font-weight:600;color:var(--text);}
.thread-preview{font-size:12px;color:var(--text2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.thread-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0;}
.thread-time{font-size:11px;color:var(--text3);}
.unread-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);}
/* Chat window */
.chat-wrap{display:flex;flex-direction:column;height:calc(100vh - 120px);max-height:700px;}
.chat-header{display:flex;align-items:center;gap:12px;padding-bottom:14px;border-bottom:0.5px solid var(--border);margin-bottom:0;flex-shrink:0;}
.chat-back{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text2);padding:4px 8px 4px 0;}
.chat-messages{flex:1;overflow-y:auto;padding:16px 0;display:flex;flex-direction:column;gap:10px;}
.chat-bubble-wrap{display:flex;flex-direction:column;}
.chat-bubble-wrap.mine{align-items:flex-end;}
.chat-bubble-wrap.theirs{align-items:flex-start;}
.chat-bubble{max-width:75%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.5;word-break:break-word;}
.chat-bubble.mine{background:var(--blue);color:#fff;border-bottom-right-radius:4px;}
.chat-bubble.theirs{background:var(--bg2);color:var(--text);border:0.5px solid var(--border);border-bottom-left-radius:4px;}
.chat-time{font-size:10px;color:var(--text3);margin-top:3px;padding:0 4px;}
.chat-composer{display:flex;gap:8px;padding-top:14px;border-top:0.5px solid var(--border);flex-shrink:0;}
.chat-input{flex:1;min-height:40px;max-height:120px;border:0.5px solid var(--border2);border-radius:var(--radius);padding:10px 12px;font-size:14px;background:var(--bg);color:var(--text);font-family:inherit;resize:none;line-height:1.4;}
.chat-input:focus{outline:none;border-color:var(--blue);}
.chat-send{height:40px;padding:0 16px;background:var(--blue);border:none;border-radius:var(--radius);color:#fff;font-size:13px;font-weight:600;cursor:pointer;align-self:flex-end;flex-shrink:0;}
.chat-send:hover{background:var(--blue-dark);}
.chat-empty{text-align:center;padding:3rem 1rem;color:var(--text2);font-size:14px;}
/* Client messages tab */
.cl-chat-wrap{display:flex;flex-direction:column;height:calc(100vh - 160px);max-height:650px;}
/* ── ATTACHMENTS ── */
.chat-composer-wrap{display:flex;flex-direction:column;gap:0;border-top:0.5px solid var(--border);flex-shrink:0;}
.attach-preview-row{display:flex;flex-wrap:wrap;gap:8px;padding:10px 12px 0;min-height:0;}
.attach-preview-row:empty{display:none;}
.attach-thumb{position:relative;display:inline-flex;align-items:center;gap:6px;background:var(--bg2);border:0.5px solid var(--border2);border-radius:var(--radius);padding:6px 10px;font-size:12px;color:var(--text2);max-width:200px;}
.attach-thumb img{width:48px;height:48px;object-fit:cover;border-radius:4px;flex-shrink:0;}
.attach-thumb-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;}
.attach-thumb-x{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:var(--coral);color:#fff;border:none;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;line-height:1;}
.chat-composer-row{display:flex;gap:8px;padding:10px 0 0;}
.attach-btn{width:36px;height:40px;border:0.5px solid var(--border2);border-radius:var(--radius);background:transparent;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.attach-btn:hover{background:var(--bg2);color:var(--blue);}
/* Drag-drop overlay */
.drop-overlay{display:none;position:absolute;inset:0;background:rgba(26,86,219,0.08);border:2.5px dashed var(--blue);border-radius:var(--radius-lg);z-index:50;align-items:center;justify-content:center;flex-direction:column;gap:8px;pointer-events:none;}
.drop-overlay.active{display:flex;}
.drop-overlay-icon{font-size:36px;}
.drop-overlay-text{font-size:14px;font-weight:600;color:var(--blue);}
/* Attachment bubbles in chat */
.attach-file-bubble{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:12px;max-width:260px;text-decoration:none;}
.attach-file-bubble.mine{background:rgba(255,255,255,0.2);}
.attach-file-bubble.theirs{background:var(--bg3);border:0.5px solid var(--border);}
.attach-file-icon{font-size:22px;flex-shrink:0;}
.attach-file-info{flex:1;min-width:0;}
.attach-file-name{font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.attach-file-size{font-size:11px;opacity:0.7;margin-top:1px;}
.chat-img-attach{max-width:220px;max-height:200px;border-radius:10px;display:block;cursor:pointer;object-fit:cover;}
.upload-progress{height:3px;background:rgba(255,255,255,0.3);border-radius:2px;margin-top:6px;overflow:hidden;}
.upload-progress-bar{height:100%;background:#fff;border-radius:2px;transition:width 0.2s;}
/* ── CLIENT HOME TILES ── */
.cl-home-wrap{max-width:480px;margin:0 auto;padding:1.25rem 1rem;}
.cl-home-greeting{font-size:18px;font-weight:700;color:var(--text);margin-bottom:2px;text-align:center;}
.cl-home-sub{font-size:12px;color:var(--text2);margin-bottom:1rem;text-align:center;}
.cl-tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* ── PHONE ── */
body.device-phone .cl-home-wrap{max-width:100%;padding:16px 12px;}
body.device-phone .cl-home-greeting{font-size:20px;text-align:center;}
body.device-phone .cl-tiles{grid-template-columns:1fr 1fr;gap:10px;}
body.device-phone .cl-tile{min-height:120px;padding:20px 8px;}
body.device-phone .cl-tile-icon{width:86px;height:86px;font-size:48px;}
body.device-phone .cl-tile-title{font-size:12px;}

/* ── TABLET ── */
body.device-tablet .cl-home-wrap{max-width:720px;padding:24px 20px;}
body.device-tablet .cl-home-greeting{font-size:22px;text-align:center;}
body.device-tablet .cl-tiles{grid-template-columns:1fr 1fr 1fr;gap:14px;}
body.device-tablet .cl-tile{min-height:130px;padding:24px 12px;}
body.device-tablet .cl-tile-icon{width:80px;height:80px;font-size:44px;}
body.device-tablet .cl-tile-title{font-size:13px;}

/* ── DESKTOP ── */
body.device-desktop .cl-home-wrap{max-width:900px;padding:32px 24px;}
body.device-desktop .cl-home-greeting{font-size:24px;text-align:center;}
body.device-desktop .cl-home-sub{font-size:13px;text-align:center;}
body.device-desktop .cl-tiles{grid-template-columns:1fr 1fr 1fr 1fr;gap:16px;}
body.device-desktop .cl-tile{min-height:140px;padding:28px 16px;}
body.device-desktop .cl-tile-icon{width:74px;height:74px;font-size:40px;}
body.device-desktop .cl-tile-title{font-size:13px;}
.cl-tile{background:#f0f4ff;border:1.5px solid #d0dcff;border-radius:var(--radius-lg);padding:20px 12px;cursor:pointer;transition:all 0.2s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;position:relative;overflow:hidden;box-shadow:0 4px 12px rgba(26,86,219,0.08),0 1px 3px rgba(26,86,219,0.06);text-align:center;min-height:120px;}
.cl-tile:hover{border-color:#a0b4ff;box-shadow:0 8px 24px rgba(26,86,219,0.14),0 2px 6px rgba(26,86,219,0.08);transform:translateY(-2px);}
.cl-tile.disabled{cursor:default;opacity:0.7;}
.cl-tile.disabled:hover{transform:none;box-shadow:0 4px 12px rgba(26,86,219,0.08);border-color:#d0dcff;}
.cl-tile-icon{width:86px;height:86px;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:48px;flex-shrink:0;}
.cl-tile-title{font-size:12px;font-weight:700;color:var(--text);line-height:1.3;text-align:center;width:100%;display:block;}
.cl-back-btn{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;font-size:28px;font-weight:300;color:var(--text2);cursor:pointer;font-family:inherit;line-height:1;padding:4px 8px 4px 0;transition:color 0.15s;min-width:32px;}
.cl-back-btn:hover{color:var(--text);}

.cl-tile-desc{display:none;}
.cl-tile-soon{position:absolute;top:8px;right:8px;background:var(--amber);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:20px;letter-spacing:0.04em;}
.cl-tile-badge{position:absolute;top:8px;right:8px;background:var(--coral);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:20px;}
/* ── TREND CHART ── */
.chart-range-btn{padding:4px 10px;border-radius:20px;border:0.5px solid var(--border2);font-size:11px;font-weight:500;cursor:pointer;background:transparent;color:var(--text2);font-family:inherit;transition:all 0.15s;}
.chart-range-btn:hover{border-color:var(--blue-mid);color:var(--blue);}
.chart-range-btn.active{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:600;}
.ov-kpi.chart-active{border-color:var(--blue);box-shadow:0 0 0 2px rgba(26,86,219,0.15);cursor:pointer;}
.ov-kpi{cursor:pointer;}
.ov-kpi:hover{border-color:var(--blue-mid);}
#bk-txn-search,#mybooks-txn-search{outline:none !important;box-shadow:none !important;transition:border-color 0.15s;}
#bk-txn-search:focus,#mybooks-txn-search:focus{outline:none !important;box-shadow:none !important;}
#bk-txn-list,#mybooks-txn-list{width:100%;max-width:100%;overflow:hidden;box-sizing:border-box;}
#bk-txn-list>div,#mybooks-txn-list>div{max-width:100%;box-sizing:border-box;}
/* ── CLIENT OVERVIEW SIDEBAR ── */
.ov-menu-item{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;transition:all 0.15s;border-left:3px solid transparent;}
.ov-menu-item:hover{background:var(--bg2);color:var(--text);}
.ov-menu-item.active-ov-menu{background:var(--blue-light);color:var(--blue);border-left-color:var(--blue);font-weight:700;}
.ov-menu-item span:first-child{font-size:16px;flex-shrink:0;}
/* ── MODULE BUTTONS ── */
.nav-center{position:absolute;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:8px;}
.bk-module-btn{background:rgba(255,255,255,0.12)!important;color:rgba(255,255,255,0.9)!important;border:1px solid rgba(255,255,255,0.3)!important;font-weight:600!important;font-size:14px!important;padding:10px 22px!important;border-radius:var(--radius)!important;cursor:pointer;font-family:inherit;transition:all 0.2s!important;}
.bk-module-btn:hover{background:rgba(255,255,255,0.2)!important;color:#fff!important;}
.bk-module-btn.active-module{background:#fff!important;color:#1e56c8!important;border-color:#fff!important;font-weight:800!important;font-size:16px!important;padding:11px 26px!important;box-shadow:0 2px 16px rgba(0,0,0,0.2)!important;}
/* ── BALANCE SHEET ── */
.bs-section-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3);margin-bottom:10px;}
#bs-balance-check{background:var(--bg2);border:1.5px solid var(--border2);}
#bs-balance-check.balanced{background:#f0fdf4;border-color:#16a34a;color:#16a34a;}
#bs-balance-check.unbalanced{background:#fff5f5;border-color:var(--coral);color:var(--coral);}
/* ── BROADCAST ── */
.btype-btn{background:var(--bg2);border:1.5px solid var(--border2);border-radius:var(--radius-lg);padding:12px;text-align:center;cursor:pointer;transition:all 0.15s;}
.btype-btn:hover{border-color:var(--blue-mid);}
.btype-btn.active{border-color:var(--coral);background:#fff5f5;}
.bclient-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:0.5px solid var(--border);cursor:pointer;transition:background 0.1s;}
.bclient-row:last-child{border-bottom:none;}
.bclient-row:hover{background:var(--bg2);}
.bclient-row input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--coral);}
/* ── INVOICES ── */
.inv-card{background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:10px;transition:border-color 0.15s;}
.inv-card:hover{border-color:var(--blue-mid);}
.inv-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.inv-number{font-size:13px;font-weight:700;color:var(--text);}
.inv-status{font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:0.05em;}
.inv-status.draft{background:#f3f4f6;color:#6b7280;}
.inv-status.sent{background:var(--blue-light);color:var(--blue);}
.inv-status.paid{background:#f0fdf4;color:#16a34a;}
.inv-status.overdue{background:#fff5f5;color:var(--coral);}
.inv-meta{font-size:12px;color:var(--text2);margin-bottom:8px;}
.inv-amount{font-size:20px;font-weight:800;color:var(--text);}
.inv-actions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap;}
.inv-line-row{display:grid;grid-template-columns:1fr 60px 80px 30px;gap:6px;margin-bottom:4px;align-items:center;}
.inv-line-row input{height:32px;border:0.5px solid var(--border2);border-radius:var(--radius);padding:0 8px;font-size:12px;background:var(--bg);color:var(--text);font-family:inherit;width:100%;}
/* ── VAULT ── */
.vault-cat-section{margin-bottom:20px;}
.vault-cat-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3);margin-bottom:8px;padding-bottom:6px;border-bottom:0.5px solid var(--border);}
.vault-file-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);margin-bottom:6px;transition:border-color 0.15s;}
.vault-file-row:hover{border-color:var(--blue-mid);}
.vault-file-icon{width:36px;height:36px;border-radius:8px;background:var(--blue-light);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.vault-file-info{flex:1;min-width:0;}
.vault-file-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.vault-file-meta{font-size:11px;color:var(--text3);margin-top:2px;}
.vault-sm-row{display:flex;align-items:center;gap:8px;padding:7px 12px;border-bottom:0.5px solid var(--border);font-size:12px;}
.vault-sm-row:last-child{border-bottom:none;}
.vault-sm-name{flex:1;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px;}
.vault-sm-cat{font-size:10px;color:var(--text3);flex-shrink:0;}
/* ── GROW YOUR BUSINESS ── */
.res-card{background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all 0.2s;cursor:pointer;}
.res-card:hover{border-color:var(--blue-mid);box-shadow:0 4px 16px rgba(26,86,219,0.1);transform:translateY(-2px);}
.res-thumb{width:100%;height:158px;object-fit:cover;background:var(--bg2);display:block;}
.res-thumb-placeholder{width:100%;height:158px;background:linear-gradient(135deg,var(--blue-light),var(--bg2));display:flex;align-items:center;justify-content:center;font-size:40px;}
.res-body{padding:12px 14px;}
.res-cat-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;margin-bottom:6px;text-transform:uppercase;letter-spacing:0.05em;}
.res-cat-badge.Taxes{background:#fef3c7;color:#92400e;}
.res-cat-badge.Bookkeeping{background:var(--blue-light);color:var(--blue-dark);}
.res-cat-badge.Marketing{background:#fdf4ff;color:#7e22ce;}
.res-cat-badge.Business-Growth{background:#f0fdf4;color:#166534;}
.res-cat-badge.General{background:var(--bg2);color:var(--text2);}
.res-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:6px;}
.res-url{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.res-filter-btn{padding:5px 14px;border-radius:20px;border:0.5px solid var(--border2);font-size:12px;font-weight:500;cursor:pointer;background:var(--bg);color:var(--text2);transition:all 0.15s;}
.res-filter-btn.active{background:var(--blue);border-color:var(--blue);color:#fff;}
.res-mgmt-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);margin-bottom:8px;}
.res-mgmt-thumb{width:48px;height:36px;border-radius:6px;object-fit:cover;background:var(--bg2);flex-shrink:0;}
.res-mgmt-info{flex:1;min-width:0;}
.res-mgmt-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.res-mgmt-meta{font-size:11px;color:var(--text3);}
/* ── OVERVIEW TWO-COLUMN RESPONSIVE ── */
@media(max-width:700px){.ov-two-col{grid-template-columns:1fr!important;}}
/* ── CLIENT OVERVIEW ── */
.ov-header{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);margin-bottom:1rem;}
.ov-av{width:56px;height:56px;border-radius:50%;background:var(--blue-light);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:var(--blue-dark);flex-shrink:0;border:2px solid var(--blue-mid);}
.ov-name{font-size:19px;font-weight:700;color:var(--text);line-height:1.2;}
.ov-meta{font-size:13px;color:var(--text2);margin-top:4px;display:flex;flex-wrap:wrap;gap:12px;}
.ov-meta a{color:var(--blue);text-decoration:none;}
.ov-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:1rem;}
.ov-kpi{background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:12px 14px;min-width:0;overflow:hidden;}
.ov-kpi-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--text3);margin-bottom:6px;}
.ov-kpi-value{font-size:20px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ov-kpi-sub{font-size:11px;color:var(--text2);margin-top:4px;line-height:1.5;}
.ov-kpi.highlight{border-color:var(--blue-mid);background:var(--blue-light);}
.ov-kpi.highlight .ov-kpi-value{color:var(--blue-dark);}
/* Prevent overview columns from overflowing */
.ov-two-col>*{min-width:0;overflow-x:hidden;}
#ov-chat-col{min-width:0;}
.ov-notes{background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:1rem;}
.ov-notes-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.ov-notes-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.07em;color:var(--text3);}
.ov-note-add{width:28px;height:28px;border-radius:50%;background:var(--blue);border:none;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;flex-shrink:0;}
.ov-note-add:hover{background:var(--blue-dark);}
.ov-note-item{display:flex;gap:10px;padding:8px 0;border-bottom:0.5px solid var(--border);}
.ov-note-item:last-child{border-bottom:none;}
.ov-note-date{font-size:11px;color:var(--text3);white-space:nowrap;padding-top:2px;flex-shrink:0;min-width:80px;}
.ov-note-text{flex:1;font-size:13px;color:var(--text);line-height:1.5;outline:none;border:none;background:transparent;font-family:inherit;resize:none;width:100%;}
.ov-note-text:focus{color:var(--text);}
.ov-note-del{background:none;border:none;color:var(--text3);cursor:pointer;font-size:13px;padding:0 2px;flex-shrink:0;}
.ov-note-del:hover{color:var(--coral);}
.ov-note-empty{font-size:13px;color:var(--text3);font-style:italic;}
.ov-period-row{display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);transition:all 0.15s;cursor:pointer;}
.ov-period-row:hover{border-color:var(--blue-mid);background:var(--blue-light);}
.ov-period-row.active-period{border-color:var(--blue);background:var(--blue-light);}
.ov-period-name{font-size:13px;font-weight:600;color:var(--text);}
.ov-period-stats{display:flex;gap:8px;flex-wrap:wrap;}
.ov-period-stat{font-size:11px;color:var(--text2);}
.ov-period-stat strong{color:var(--text);}
/* ── MESSAGE CONTEXT MENU ── */
.msg-ctx-menu{position:fixed;background:var(--bg);border:0.5px solid var(--border2);border-radius:var(--radius-lg);box-shadow:0 8px 24px rgba(0,0,0,0.15);z-index:500;min-width:160px;overflow:hidden;animation:ctxFade 0.1s ease;}
@keyframes ctxFade{from{opacity:0;transform:scale(0.95);}to{opacity:1;transform:scale(1);}}
.msg-ctx-item{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:13px;color:var(--text);cursor:pointer;transition:background 0.1s;}
.msg-ctx-item:hover{background:var(--bg2);}
.msg-ctx-item.danger{color:var(--coral);}
.msg-ctx-item.danger:hover{background:var(--coral-light);}
.msg-ctx-sep{height:0.5px;background:var(--border);margin:4px 0;}
/* ── INSIGHTS ── */
.insight-card{background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;border-left:4px solid var(--blue);}
.insight-card.up{border-left-color:var(--green);}
.insight-card.down{border-left-color:var(--coral);}
.insight-card.warning{border-left-color:var(--amber);}
.insight-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px;}
.insight-title{font-size:15px;font-weight:700;color:var(--text);line-height:1.3;}
.insight-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700;white-space:nowrap;flex-shrink:0;}
.insight-badge.up{background:var(--green-light);color:var(--green);}
.insight-badge.down{background:var(--coral-light);color:var(--coral);}
.insight-badge.warning{background:#fff8e1;color:#b45309;}
.insight-body{font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:12px;}
.insight-body strong{color:var(--text);}
.insight-suggest{background:var(--blue-light);border-radius:var(--radius);padding:10px 14px;font-size:13px;color:var(--blue-dark);line-height:1.6;margin-bottom:14px;}
.insight-suggest::before{content:'💡 ';font-style:normal;}
.insight-contact{display:flex;align-items:center;gap:16px;padding:10px 14px;background:var(--bg2);border-radius:var(--radius);margin-bottom:14px;flex-wrap:wrap;}
.insight-contact-name{font-size:13px;font-weight:600;color:var(--text);}
.insight-contact-meta{font-size:12px;color:var(--text2);}
.insight-contact-phone{font-size:13px;font-weight:600;color:var(--blue);text-decoration:none;}
.insight-contact-phone:hover{text-decoration:underline;}
.insight-actions{display:flex;gap:8px;flex-wrap:wrap;}
.insight-dismiss{padding:7px 16px;background:transparent;border:0.5px solid var(--border2);border-radius:var(--radius);font-size:12px;color:var(--text2);cursor:pointer;font-family:inherit;}
.insight-dismiss:hover{background:var(--bg2);}
.insight-call{padding:7px 16px;background:var(--blue);border:none;border-radius:var(--radius);font-size:12px;font-weight:600;color:#fff;cursor:pointer;font-family:inherit;text-decoration:none;display:inline-flex;align-items:center;gap:5px;}
.insight-call:hover{background:var(--blue-dark);}
.insight-period-tag{font-size:11px;color:var(--text3);margin-bottom:8px;font-weight:500;}
/* Grouped insight client card */
.insight-client-card{background:var(--bg);border:0.5px solid var(--border);border-radius:var(--radius-lg);margin-bottom:12px;overflow:hidden;}
.insight-client-header{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;user-select:none;transition:background 0.15s;}
.insight-client-header:hover{background:var(--bg2);}
.insight-client-av{width:40px;height:40px;border-radius:50%;background:var(--blue-light);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--blue-dark);flex-shrink:0;}
.insight-client-info{flex:1;min-width:0;}
.insight-client-name{font-size:14px;font-weight:600;color:var(--text);}
.insight-client-meta{font-size:12px;color:var(--text2);margin-top:2px;}
.insight-client-badges{display:flex;gap:5px;flex-wrap:wrap;flex-shrink:0;align-items:center;}
.insight-client-chevron{font-size:12px;color:var(--text3);transition:transform 0.2s;flex-shrink:0;margin-left:4px;}
.insight-client-chevron.open{transform:rotate(180deg);}
.insight-client-body{display:none;border-top:0.5px solid var(--border);}
.insight-client-body.open{display:block;}
.insight-client-actions{display:flex;gap:8px;flex-wrap:wrap;padding:12px 16px;border-top:0.5px solid var(--border);background:var(--bg2);}
/* Individual insight row inside client card */
.insight-row{padding:14px 16px;border-bottom:0.5px solid var(--border);border-left:4px solid transparent;}
.insight-row:last-of-type{border-bottom:none;}
.insight-row.up{border-left-color:var(--green);}
.insight-row.down{border-left-color:var(--coral);}
.insight-row.warning{border-left-color:var(--amber);}
.insight-row-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px;}
.insight-row-title{font-size:13px;font-weight:600;color:var(--text);}
.insight-row-body{font-size:12px;color:var(--text2);line-height:1.6;margin-bottom:6px;}
.insight-row-suggest{font-size:12px;color:var(--blue-dark);background:var(--blue-light);border-radius:var(--radius);padding:8px 10px;line-height:1.5;}
.insight-row-suggest::before{content:'💡 ';}
.insight-row-dismiss{font-size:11px;color:var(--text3);background:none;border:none;cursor:pointer;padding:4px 0;text-decoration:underline;}



  .lp-wrap{min-height:100vh;background:#060912;overflow-x:hidden;font-family:'Segoe UI',system-ui,sans-serif;color:#fff;}
  .lp-grid-bg{display:none;}
  .lp-glow1{position:fixed;top:-200px;left:50%;transform:translateX(-50%);width:800px;height:800px;background:radial-gradient(circle,rgba(26,86,219,0.18) 0%,transparent 65%);pointer-events:none;z-index:0;}
  .lp-glow2{position:fixed;bottom:-100px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(99,179,237,0.1) 0%,transparent 65%);pointer-events:none;z-index:0;}
  .lp-nav{position:fixed;top:0;left:0;right:0;z-index:100;height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;background:rgba(6,9,18,0.7);backdrop-filter:blur(20px);border-bottom:1px solid rgba(26,86,219,0.15);}
  .lp-nav-logo{display:flex;align-items:center;gap:10px;}
  .lp-nav-logo-mark{width:30px;height:30px;background:linear-gradient(135deg,#1a56db,#3b82f6);border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px rgba(26,86,219,0.4);}
  .lp-nav-logo-text{font-size:17px;font-weight:800;color:#fff;letter-spacing:-0.02em;}
  .lp-nav-logo-text span{color:#60a5fa;}
  .lp-nav-btns{display:flex;align-items:center;gap:10px;}
  .lp-btn-ghost{padding:7px 16px;background:transparent;border:1px solid rgba(255,255,255,0.12);border-radius:8px;color:rgba(255,255,255,0.7);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:all 0.2s;}
  .lp-btn-ghost:hover{border-color:rgba(26,86,219,0.5);color:#60a5fa;}
  .lp-btn-primary{padding:7px 18px;background:linear-gradient(135deg,#1a56db,#2563eb);border:none;border-radius:8px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;box-shadow:0 0 20px rgba(26,86,219,0.3);transition:all 0.2s;}
  .lp-btn-primary:hover{box-shadow:0 0 30px rgba(26,86,219,0.5);transform:translateY(-1px);}
  .lp-hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:100px 2rem 80px;position:relative;z-index:1;text-align:center;}
  .lp-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(26,86,219,0.12);border:1px solid rgba(26,86,219,0.25);border-radius:100px;padding:5px 16px;margin-bottom:28px;}
  .lp-badge-dot{width:6px;height:6px;border-radius:50%;background:#60a5fa;box-shadow:0 0 8px #60a5fa;animation:pulse 2s infinite;}
  @keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.4;}}
  .lp-badge-text{font-size:11px;font-weight:600;color:#93c5fd;letter-spacing:0.06em;text-transform:uppercase;}
  .lp-h1{font-size:clamp(40px,6.5vw,76px);font-weight:900;line-height:1.05;letter-spacing:-0.03em;margin:0 0 8px;}
  .lp-h1-white{color:#fff;}
  .lp-h1-grad{background:linear-gradient(135deg,#60a5fa,#a78bfa,#60a5fa);background-size:200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 4s linear infinite;}
  @keyframes shimmer{0%{background-position:0%;}100%{background-position:200%;}}
  .lp-sub{font-size:clamp(15px,2vw,19px);color:rgba(255,255,255,0.5);max-width:560px;margin:0 auto 36px;line-height:1.65;}
  .lp-hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:64px;}
  .lp-hero-cta{padding:14px 32px;background:linear-gradient(135deg,#1a56db,#2563eb);border:none;border-radius:10px;color:#fff;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 0 30px rgba(26,86,219,0.35);transition:all 0.2s;display:flex;align-items:center;gap:8px;}
  .lp-hero-cta:hover{transform:translateY(-2px);box-shadow:0 0 40px rgba(26,86,219,0.5);}
  .lp-hero-sec{padding:14px 32px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:10px;color:rgba(255,255,255,0.7);font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.2s;}
  .lp-hero-sec:hover{background:rgba(255,255,255,0.07);border-color:rgba(26,86,219,0.3);}
  .lp-stats{display:flex;gap:0;justify-content:center;border:1px solid rgba(255,255,255,0.07);border-radius:16px;overflow:hidden;background:rgba(255,255,255,0.02);backdrop-filter:blur(10px);}
  .lp-stat{padding:20px 40px;text-align:center;border-right:1px solid rgba(255,255,255,0.07);flex:1;}
  .lp-stat:last-child{border-right:none;}
  .lp-stat-num{font-size:28px;font-weight:800;color:#fff;letter-spacing:-0.02em;}
  .lp-stat-label{font-size:12px;color:rgba(255,255,255,0.35);margin-top:3px;}
  .lp-section{padding:80px 2rem;max-width:1100px;margin:0 auto;position:relative;z-index:1;}
  .lp-section-label{font-size:11px;font-weight:700;letter-spacing:0.12em;color:#60a5fa;text-transform:uppercase;margin-bottom:14px;}
  .lp-section-h2{font-size:clamp(26px,4vw,44px);font-weight:800;color:#fff;margin:0 0 16px;letter-spacing:-0.02em;line-height:1.1;}
  .lp-section-sub{font-size:16px;color:rgba(255,255,255,0.4);margin:0 0 48px;}
  .lp-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;}
  .lp-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:20px;padding:36px;position:relative;overflow:hidden;transition:all 0.3s;}
  .lp-card:hover{border-color:rgba(26,86,219,0.3);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,0.3);}
  .lp-card-glow{position:absolute;top:-60px;right:-60px;width:180px;height:180px;border-radius:50%;pointer-events:none;}
  .lp-card-icon{font-size:36px;margin-bottom:18px;}
  .lp-card-h3{font-size:20px;font-weight:700;color:#fff;margin:0 0 10px;}
  .lp-card-p{font-size:14px;color:rgba(255,255,255,0.45);margin:0 0 24px;line-height:1.6;}
  .lp-check{display:flex;align-items:center;gap:10px;font-size:13px;color:rgba(255,255,255,0.6);margin-bottom:9px;}
  .lp-check-icon{width:18px;height:18px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;}
  .lp-card-btn{margin-top:28px;width:100%;padding:11px;border-radius:9px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.2s;}
  .lp-pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;}
  .lp-price-card{background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.07);border-radius:16px;padding:28px;transition:all 0.2s;}
  .lp-price-card:hover{border-color:rgba(26,86,219,0.25);transform:translateY(-2px);}
  .lp-price-card.featured{background:rgba(26,86,219,0.08);border-color:rgba(26,86,219,0.35);box-shadow:0 0 40px rgba(26,86,219,0.1);}
  .lp-price-tier{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:rgba(255,255,255,0.35);margin-bottom:12px;}
  .lp-price-tier.blue{color:#60a5fa;}
  .lp-price-amount{font-size:36px;font-weight:800;color:#fff;line-height:1;}
  .lp-price-period{font-size:14px;color:rgba(255,255,255,0.3);font-weight:400;}
  .lp-price-desc{font-size:12px;color:rgba(255,255,255,0.35);margin:8px 0 20px;}
  .lp-price-btn{width:100%;padding:10px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.2s;}
  .lp-ai-strip{background:rgba(26,86,219,0.06);border:1px solid rgba(26,86,219,0.15);border-radius:20px;padding:40px;text-align:center;margin:0 2rem;position:relative;z-index:1;overflow:hidden;}
  .lp-ai-strip-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:400px;height:200px;background:radial-gradient(ellipse,rgba(26,86,219,0.12) 0%,transparent 70%);pointer-events:none;}
  .lp-cta-section{padding:100px 2rem;text-align:center;position:relative;z-index:1;}
  .lp-footer{border-top:1px solid rgba(255,255,255,0.06);padding:28px 2rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;max-width:1100px;margin:0 auto;position:relative;z-index:1;}
  @media(max-width:639px){
    .lp-signin-desktop{display:none!important;}
    .lp-hero-btns{flex-direction:column;align-items:stretch;}
    .lp-stats{flex-direction:column;border-radius:12px;}
    .lp-stat{border-right:none;border-bottom:1px solid rgba(255,255,255,0.07);padding:16px 24px;}
    .lp-stat:last-child{border-bottom:none;}
    .lp-section{padding:60px 1.25rem;}
    .lp-ai-strip{margin:0 1.25rem;padding:28px 20px;}
    .lp-footer{flex-direction:column;align-items:center;text-align:center;}
  }.inbox-row:hover{background:var(--bg2)!important;}


/* ── CLIENT PANELS RESPONSIVE WIDTH ── */
/* On phone — full width, minimal padding */
body.device-phone .cl-panel-inner{max-width:100%;padding:16px 12px;}
/* On tablet — 720px max */
body.device-tablet .cl-panel-inner{max-width:720px;padding:20px 16px;}
/* On desktop — 860px max */
body.device-desktop .cl-panel-inner{max-width:860px;padding:24px 20px;}
/* cl-dashboard (Check Finances) */
body.device-phone #cl-dashboard{padding:0 12px;}
body.device-tablet #cl-dashboard .kpi-grid{grid-template-columns:repeat(2,1fr);}
body.device-desktop #cl-dashboard{max-width:860px;margin:0 auto;padding:0 20px;}

/* ── CLIENT PANEL WIDTHS ── */
/* All client sliding panels: constrained width on desktop */
#cl-mybooks-panel > div,
#cl-grow-panel > div,
#cl-vault-panel > div,
#cl-miles-panel > div,
#cl-taxes-panel > div,
#cl-invoice-panel > div,
#cl-settings-panel > div,
#cl-documents-panel > div,
#cl-docform-panel > div,
#cl-directory > div,
#cl-tile-customizer > div{max-width:860px;margin-left:auto;margin-right:auto;}

/* Phone: tighter padding */
body.device-phone #cl-mybooks-panel > div,
body.device-phone #cl-grow-panel > div,
body.device-phone #cl-vault-panel > div,
body.device-phone #cl-miles-panel > div,
body.device-phone #cl-invoice-panel > div,
body.device-phone #cl-settings-panel > div,
body.device-phone #cl-documents-panel > div,
body.device-phone #cl-docform-panel > div{padding-left:12px;padding-right:12px;}
