/* ── SHUBIQ Business OS ── main.css ── */
:root {
  --c0:#031930;--c1:#223A59;--c2:#3684DB;--c3:#B3D6F9;--c4:#758BA5;--c5:#D1DDED;
  --bg:#020F1E;--bg2:#061525;--bg3:#0A1D2E;
  --surface:#0D2237;--surface2:#112840;--surface3:#162f4a;
  --border:rgba(54,132,219,0.15);--border2:rgba(54,132,219,0.25);--border3:rgba(54,132,219,0.4);
  --text:#E8F4FF;--text2:#B3D6F9;--text3:#758BA5;--text4:#4a6278;
  --accent:#3684DB;--accent-light:#5a9de0;--accent-glow:rgba(54,132,219,0.25);
  --green:#22C55E;--green-glow:rgba(34,197,94,0.2);
  --red:#EF4444;--red-glow:rgba(239,68,68,0.2);
  --amber:#F59E0B;--amber-glow:rgba(245,158,11,0.2);
  --purple:#8B5CF6;--purple-glow:rgba(139,92,246,0.2);
  --font-display:'Syne',sans-serif;--font-body:'DM Sans',sans-serif;
  --radius:12px;--radius-lg:18px;--radius-xl:24px;
  --sidebar-w:248px;--topbar-h:56px;
  --trans:0.2s cubic-bezier(0.4,0,0.2,1);
  --glass:rgba(13,34,55,0.7);--glass-border:rgba(54,132,219,0.18);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
::selection{background:rgba(54,132,219,0.3);color:var(--text)}

/* ── LAYOUT ── */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"sidebar topbar""sidebar main";min-height:100vh}
.main{grid-area:main;overflow-y:auto;background:var(--bg)}
.page{display:none;padding:28px;min-height:calc(100vh - var(--topbar-h));animation:fadeIn 0.3s ease}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── TOPBAR ── */
.topbar{grid-area:topbar;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:rgba(6,21,37,0.95);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}
.topbar-left{display:flex;align-items:center;gap:12px}
.topbar-right{display:flex;align-items:center;gap:8px}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:0.8rem;color:var(--text3)}
.breadcrumb span{color:var(--text3)}
.breadcrumb .current{color:var(--text2);font-weight:500}
.topbar-search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:0 12px;height:34px;width:220px;transition:var(--trans);cursor:text}
.topbar-search:focus-within{border-color:var(--border2);background:var(--surface2);width:260px}
.topbar-search input{background:none;border:none;outline:none;color:var(--text);font-family:var(--font-body);font-size:0.8rem;width:100%}
.topbar-search input::placeholder{color:var(--text4)}
.tbtn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--trans);flex-shrink:0}
.tbtn:hover{border-color:var(--border2);color:var(--text);background:var(--surface2)}
.tbtn svg{width:16px;height:16px}
.notif-dot{position:relative}
.notif-dot::after{content:'';position:absolute;top:6px;right:6px;width:6px;height:6px;background:var(--accent);border-radius:50%;border:1px solid var(--bg2)}
.status-indicator{display:flex;align-items:center;gap:6px;font-size:0.75rem;color:var(--text3);padding:0 8px;border:1px solid var(--border);border-radius:8px;height:34px;background:var(--surface)}
.sdot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green-glow)}

/* ── SIDEBAR ── */
.sidebar{grid-area:sidebar;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:60}
.brand{height:var(--topbar-h);display:flex;align-items:center;padding:0 18px;border-bottom:1px solid var(--border);gap:10px;flex-shrink:0}
.brand-mark{width:32px;height:32px;background:linear-gradient(135deg,var(--accent) 0%,#1655a0 100%);border-radius:9px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:13px;color:#fff;flex-shrink:0;box-shadow:0 4px 12px rgba(54,132,219,0.35)}
.brand-text{display:flex;flex-direction:column}
.brand-name{font-family:var(--font-display);font-weight:800;font-size:0.9rem;color:var(--text);letter-spacing:0.04em;line-height:1.1}
.brand-sub{font-size:0.6rem;color:var(--text4);letter-spacing:0.1em;text-transform:uppercase;margin-top:1px}
.snav{flex:1;padding:10px 8px;overflow-y:auto}
.nlabel{font-size:0.62rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--text4);padding:12px 10px 5px}
.nitem{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:9px;cursor:pointer;transition:var(--trans);color:var(--text3);font-size:0.84rem;font-weight:400;position:relative;user-select:none;white-space:nowrap}
.nitem:hover{background:var(--surface);color:var(--text2)}
.nitem.active{background:rgba(54,132,219,0.12);color:var(--accent);font-weight:500}
.nitem.active::before{content:'';position:absolute;left:0;top:7px;bottom:7px;width:2.5px;background:var(--accent);border-radius:0 3px 3px 0}
.nitem svg{width:16px;height:16px;flex-shrink:0}
.nbadge{margin-left:auto;background:rgba(54,132,219,0.15);color:var(--accent);font-size:0.62rem;font-weight:600;padding:2px 6px;border-radius:20px;border:1px solid rgba(54,132,219,0.25)}
.nbadge.amber{background:rgba(245,158,11,0.15);color:var(--amber);border-color:rgba(245,158,11,0.25)}
.nbadge.red{background:rgba(239,68,68,0.15);color:var(--red);border-color:rgba(239,68,68,0.25)}
.sfooter{padding:10px 8px;border-top:1px solid var(--border);flex-shrink:0}
.user-card{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:9px;background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:var(--trans)}
.user-card:hover{border-color:var(--border2);background:var(--surface2)}
.uavatar{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,var(--c1),var(--c2));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:11px;color:#fff;flex-shrink:0}
.uname{font-size:0.8rem;font-weight:600;color:var(--text);line-height:1.1}
.urole{font-size:0.67rem;color:var(--text4);margin-top:1px}

/* ── SECTION HEADER ── */
.sec-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.sec-title{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--text);line-height:1.2}
.sec-sub{font-size:0.82rem;color:var(--text3);margin-top:3px}
.sec-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:0 16px;height:36px;border-radius:9px;font-family:var(--font-body);font-size:0.82rem;font-weight:500;cursor:pointer;transition:var(--trans);border:1px solid transparent;white-space:nowrap;flex-shrink:0}
.btn svg{width:14px;height:14px}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 12px rgba(54,132,219,0.3)}
.btn-primary:hover{background:var(--accent-light);box-shadow:0 4px 16px rgba(54,132,219,0.4)}
.btn-ghost{background:transparent;color:var(--text3);border-color:var(--border)}
.btn-ghost:hover{background:var(--surface);color:var(--text);border-color:var(--border2)}
.btn-danger{background:rgba(239,68,68,0.1);color:var(--red);border-color:rgba(239,68,68,0.2)}
.btn-danger:hover{background:rgba(239,68,68,0.2)}
.btn-success{background:rgba(34,197,94,0.1);color:var(--green);border-color:rgba(34,197,94,0.2)}
.btn-success:hover{background:rgba(34,197,94,0.2)}
.btn-sm{height:30px;padding:0 12px;font-size:0.78rem;border-radius:7px}
.btn-sm svg{width:12px;height:12px}
.btn-icon{width:34px;height:34px;padding:0;justify-content:center}
.btn-icon.sm{width:28px;height:28px}

/* ── CARDS ── */
.card{background:var(--glass);backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:20px}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-title{font-family:var(--font-display);font-size:0.88rem;font-weight:700;color:var(--text2);letter-spacing:0.01em}
.client-card{padding:22px 22px 18px;background:linear-gradient(180deg,rgba(10,25,45,0.92),rgba(9,20,38,0.92));border:1px solid rgba(68,94,128,0.35);box-shadow:0 12px 30px rgba(3,9,20,0.35);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.client-card:hover{transform:translateY(-2px);border-color:rgba(90,126,170,0.55);box-shadow:0 18px 40px rgba(3,9,20,0.45)}
.client-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.client-avatar{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:14px;flex-shrink:0}
.client-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.client-sub{font-size:0.78rem;color:var(--text4);margin-top:2px}
.client-meta{display:grid;gap:6px}
.client-meta .meta-row{display:flex;align-items:center;gap:8px;font-size:0.8rem;color:var(--text3)}
.client-meta .meta-row a{color:var(--accent);text-decoration:none}
.client-meta .meta-row svg{width:13px;height:13px;color:var(--text4);flex-shrink:0}
.client-address{font-size:0.75rem;color:var(--text4);margin-top:6px;line-height:1.3}
.card-sub{font-size:0.75rem;color:var(--text3);margin-top:2px}

/* ── STAT CARDS ── */
.stats-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}
.stat{background:var(--glass);backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:20px 22px;position:relative;overflow:hidden;transition:var(--trans)}
.stat:hover{border-color:var(--border2);transform:translateY(-1px)}
.stat::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 50%,rgba(54,132,219,0.03));pointer-events:none}
.stat-label{font-size:0.72rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--text4);margin-bottom:10px}
.stat-value{font-family:var(--font-display);font-size:1.65rem;font-weight:700;color:var(--text);line-height:1;margin-bottom:8px}
.stat-value.green{color:var(--green)}
.stat-value.red{color:var(--red)}
.stat-value.amber{color:var(--amber)}
.stat-change{display:inline-flex;align-items:center;gap:4px;font-size:0.72rem;font-weight:500;padding:3px 8px;border-radius:20px}
.stat-change.up{background:var(--green-glow);color:var(--green)}
.stat-change.down{background:var(--red-glow);color:var(--red)}
.stat-change.neutral{background:rgba(117,139,165,0.15);color:var(--text3)}
.stat-icon{position:absolute;right:16px;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;opacity:0.8}
.stat-icon svg{width:20px;height:20px}
.stat-icon.blue{background:rgba(54,132,219,0.12);color:var(--accent)}
.stat-icon.green{background:var(--green-glow);color:var(--green)}
.stat-icon.red{background:var(--red-glow);color:var(--red)}
.stat-icon.amber{background:var(--amber-glow);color:var(--amber)}
.stat-icon.purple{background:var(--purple-glow);color:var(--purple)}

/* ── GRID LAYOUTS ── */
.grid-2{display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}
.grid-3{display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}
.grid-4{display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}
.col-span-2{grid-column:span 2}
.col-span-3{grid-column:span 3}

/* ── TABLES ── */
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--glass-border)}
.table-top{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap;background:rgba(6,21,37,0.5)}
.table-top-left{display:flex;align-items:center;gap:10px}
.table-title{font-family:var(--font-display);font-size:0.85rem;font-weight:700;color:var(--text2)}
.tbl-search{display:flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:0 10px;height:32px}
.tbl-search input{background:none;border:none;outline:none;color:var(--text);font-family:var(--font-body);font-size:0.78rem;width:140px}
.tbl-search input::placeholder{color:var(--text4)}
.tbl-search svg{width:13px;height:13px;color:var(--text4);flex-shrink:0}
table{width:100%;border-collapse:collapse;font-size:0.82rem;background:var(--glass)}
thead th{padding:11px 16px;text-align:left;font-size:0.7rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--text4);border-bottom:1px solid var(--border);white-space:nowrap;background:rgba(6,21,37,0.4);cursor:pointer;user-select:none}
thead th:hover{color:var(--text3)}
thead th svg{display:inline;width:11px;height:11px;margin-left:4px;opacity:0.5}
tbody tr{border-bottom:1px solid rgba(54,132,219,0.07);transition:var(--trans)}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:rgba(54,132,219,0.04)}
tbody td{padding:12px 16px;color:var(--text2);vertical-align:middle}
.td-main{font-weight:600;color:var(--text)}
.td-sub{font-size:0.72rem;color:var(--text4);margin-top:2px}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:0.7rem;font-weight:600;letter-spacing:0.02em;white-space:nowrap}
.badge::before{content:'';width:5px;height:5px;border-radius:50%}
.badge-green{background:rgba(34,197,94,0.12);color:var(--green);border:1px solid rgba(34,197,94,0.2)}
.badge-green::before{background:var(--green)}
.badge-red{background:rgba(239,68,68,0.12);color:var(--red);border:1px solid rgba(239,68,68,0.2)}
.badge-red::before{background:var(--red)}
.badge-amber{background:rgba(245,158,11,0.12);color:var(--amber);border:1px solid rgba(245,158,11,0.2)}
.badge-amber::before{background:var(--amber)}
.badge-blue{background:rgba(54,132,219,0.12);color:var(--accent);border:1px solid rgba(54,132,219,0.2)}
.badge-blue::before{background:var(--accent)}
.badge-purple{background:rgba(139,92,246,0.12);color:var(--purple);border:1px solid rgba(139,92,246,0.2)}
.badge-purple::before{background:var(--purple)}
.badge-gray{background:rgba(117,139,165,0.12);color:var(--text3);border:1px solid rgba(117,139,165,0.2)}
.badge-gray::before{background:var(--text3)}
.badge.no-dot::before{display:none}

/* ── PROGRESS ── */
.progress{background:rgba(54,132,219,0.08);border-radius:99px;height:5px;overflow:hidden}
.progress-fill{height:100%;border-radius:99px;transition:width 0.6s ease}
.progress-fill.blue{background:var(--accent)}
.progress-fill.green{background:var(--green)}
.progress-fill.amber{background:var(--amber)}
.progress-fill.red{background:var(--red)}

/* ── FORMS ── */
.form-group{margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
label{display:block;font-size:0.75rem;font-weight:600;color:var(--text3);margin-bottom:6px;letter-spacing:0.03em}
input,select,textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:0 12px;height:38px;color:var(--text);font-family:var(--font-body);font-size:0.84rem;outline:none;transition:var(--trans)}
textarea{height:auto;padding:10px 12px;resize:vertical;min-height:80px}
input:focus,select:focus,textarea:focus{border-color:var(--border2);background:var(--surface2);box-shadow:0 0 0 3px rgba(54,132,219,0.08)}
input::placeholder,textarea::placeholder{color:var(--text4)}
select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23758BA5' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
select option{background:var(--bg3)}
.form-hint{font-size:0.72rem;color:var(--text4);margin-top:5px}

/* ── MODALS ── */
.modal-overlay{position:fixed;inset:0;background:rgba(2,15,30,0.7);backdrop-filter:blur(8px);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.2s ease;padding:20px}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-xl);padding:0;max-height:90vh;overflow-y:auto;transform:scale(0.96) translateY(8px);transition:transform 0.25s cubic-bezier(0.4,0,0.2,1);width:100%;max-width:600px}
.modal-overlay.open .modal{transform:scale(1) translateY(0)}
.modal-lg{max-width:820px}
.modal-xl{max-width:1000px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}
.modal-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text)}
.modal-body{padding:24px}
.modal-foot{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border)}

/* ── TOAST ── */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;flex-direction:column;gap:8px}
.toast{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:12px 16px;font-size:0.82rem;color:var(--text);box-shadow:0 8px 24px rgba(0,0,0,0.4);transform:translateX(120%);transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);max-width:320px}
.toast.show{transform:translateX(0)}
.toast-icon{width:20px;height:20px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.toast.success .toast-icon{background:var(--green-glow);color:var(--green)}
.toast.error .toast-icon{background:var(--red-glow);color:var(--red)}
.toast.info .toast-icon{background:var(--accent-glow);color:var(--accent)}

/* ── CHART WRAPPERS ── */
.chart-wrap{position:relative;width:100%}
.chart-legend{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}
.cleg-item{display:flex;align-items:center;gap:5px;font-size:0.72rem;color:var(--text3)}
.cleg-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}

/* ── TABS ── */
.tabs{display:flex;align-items:center;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:3px;margin-bottom:20px}
.tab{padding:6px 14px;border-radius:7px;font-size:0.8rem;font-weight:500;color:var(--text3);cursor:pointer;transition:var(--trans);white-space:nowrap}
.tab.active{background:var(--surface3);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,0.2)}
.tab:hover:not(.active){color:var(--text2)}

/* ── FILTER BAR ── */
.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.filter-pill{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text3);font-size:0.75rem;cursor:pointer;transition:var(--trans)}
.filter-pill:hover{border-color:var(--border2);color:var(--text2)}
.filter-pill.active{background:rgba(54,132,219,0.12);border-color:rgba(54,132,219,0.3);color:var(--accent)}
.filter-pill svg{width:12px;height:12px}

/* ── INVOICE PREVIEW ── */
.invoice-preview{background:#fff;color:#111;border-radius:var(--radius-lg);padding:40px;font-family:'DM Sans',sans-serif;max-width:760px;margin:0 auto}
.invoice-preview h1{font-family:'Syne',sans-serif;font-size:2rem;font-weight:800;color:#1a1a2e}
.inv-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid #e8f4ff}
.inv-meta{text-align:right}
.inv-meta .inv-num{font-family:'Syne',sans-serif;font-size:1.1rem;font-weight:700;color:#3684DB}
.inv-status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:0.72rem;font-weight:600;background:#f0f9ff;color:#3684DB;border:1px solid #bfdbfe;margin-top:6px}
.inv-section{margin-bottom:24px}
.inv-section-title{font-size:0.7rem;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:#94a3b8;margin-bottom:8px}
.inv-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.inv-label{font-size:0.72rem;color:#94a3b8;margin-bottom:2px}
.inv-value{font-size:0.88rem;font-weight:500;color:#1e293b}
table.inv-table{width:100%;border-collapse:collapse}
table.inv-table thead th{background:#f8fafc;padding:10px 14px;text-align:left;font-size:0.72rem;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:#64748b;border-bottom:1px solid #e2e8f0}
table.inv-table tbody td{padding:12px 14px;border-bottom:1px solid #f1f5f9;font-size:0.85rem;color:#374151}
.inv-totals{margin-left:auto;max-width:280px;margin-top:16px}
.inv-total-row{display:flex;justify-content:space-between;padding:6px 0;font-size:0.85rem;color:#64748b;border-bottom:1px solid #f1f5f9}
.inv-total-row.grand{font-size:1rem;font-weight:700;color:#1e293b;border-bottom:none;padding-top:10px;border-top:2px solid #3684DB;margin-top:4px}
.inv-footer{margin-top:32px;padding-top:20px;border-top:1px solid #e2e8f0;font-size:0.78rem;color:#94a3b8}
.inv-bank{background:#f8fafc;border-radius:8px;padding:14px;margin-top:12px;font-size:0.82rem}
.inv-bank-title{font-weight:600;color:#374151;margin-bottom:6px;font-size:0.8rem}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:60px 20px;color:var(--text3)}
.empty-state svg{width:48px;height:48px;opacity:0.3;margin:0 auto 14px;display:block;color:var(--text3)}
.empty-state h3{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text2);margin-bottom:6px}
.empty-state p{font-size:0.82rem;color:var(--text4)}

/* ── DIVIDER ── */
.divider{height:1px;background:var(--border);margin:20px 0}

/* ── QUICK METRIC ── */
.qm-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(54,132,219,0.07)}
.qm-row:last-child{border-bottom:none}
.qm-label{font-size:0.8rem;color:var(--text3)}
.qm-value{font-size:0.85rem;font-weight:600;color:var(--text)}

/* ── DOT MARKER ── */
.dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ── ACTIVITY ITEM ── */
.activity-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid rgba(54,132,219,0.07)}
.activity-item:last-child{border-bottom:none}
.act-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.act-icon svg{width:14px;height:14px}
.act-text{font-size:0.8rem;color:var(--text2);line-height:1.4}
.act-time{font-size:0.7rem;color:var(--text4);margin-top:2px}

/* ── HOVER ROW ── */
.hover-row{display:flex;align-items:center;justify-content:space-between;padding:10px;border-radius:9px;cursor:pointer;transition:var(--trans)}
.hover-row:hover{background:var(--surface)}

/* ── SETTINGS ── */
.settings-section{margin-bottom:32px}
.settings-section-title{font-family:var(--font-display);font-size:0.9rem;font-weight:700;color:var(--text2);margin-bottom:4px}
.settings-section-sub{font-size:0.78rem;color:var(--text4);margin-bottom:18px}
.settings-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:22px}

/* ── LOGIN PAGE ── */
#login-page{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}
.login-card{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-xl);padding:40px;max-width:400px;width:100%;text-align:center}
.login-logo{width:48px;height:48px;background:linear-gradient(135deg,var(--accent),#1655a0);border-radius:14px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:18px;color:#fff;margin:0 auto 20px;box-shadow:0 6px 20px rgba(54,132,219,0.35)}
.login-title{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:4px}
.login-sub{font-size:0.82rem;color:var(--text3);margin-bottom:28px}
.login-card input{margin-bottom:12px;text-align:left}
.login-error{font-size:0.78rem;color:var(--red);margin-top:8px;min-height:18px}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .app{grid-template-columns:0 1fr;grid-template-areas:"topbar topbar""main main"}
  .sidebar{position:fixed;left:-100%;width:260px;transition:left 0.3s ease;z-index:100}
  .sidebar.open{left:0}
  .topbar{padding:0 16px}
  .page{padding:16px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .col-span-2,.col-span-3{grid-column:span 1}
  .form-row,.form-row-3{grid-template-columns:1fr}
  #mobile-menu-btn{display:flex!important}
}
@media(max-width:600px){
  .stats-grid{grid-template-columns:1fr}
  .topbar-search{display:none}
}
#mobile-menu-btn{display:none}
#mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:99}
#mobile-overlay.show{display:block}

/* ── PRINT STYLES ── */
@media print{
  #login-page,#toast-container,.modal-overlay,#printBtn,.topbar,.sidebar{display:none!important}
  body{background:#fff!important;color:#111!important}
  .invoice-preview{box-shadow:none!important;border:none!important;padding:0!important}
  a{color:#3684DB!important;text-decoration:underline!important}
}

/* ---- PRINT STYLES ---- */
.print-only{display:none}
@media print{
  @page{margin:16mm}
  body{background:#fff;color:#111}
  .app{display:block}
  .sidebar,.topbar,.sec-actions,.tbtn,.btn,.chart-wrap,.nitem,.sfooter,.snav,.topbar-search,.breadcrumb,.status-indicator,.notif-dot{display:none !important}
  .page{display:block !important;min-height:auto;padding:0}
  #page-pnl{padding:0}
  .card{background:transparent;border:none;box-shadow:none}
  .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:12px 0 16px}
  .stat{border:1px solid #e5e7eb;background:#fff}
  .stat-label{color:#555}
  .stat-value{color:#111}
  .stat-change{color:#666}
  .print-only{display:flex}
  .print-header{justify-content:space-between;align-items:flex-end;border-bottom:2px solid #111;padding-bottom:10px;margin-bottom:14px}
  .print-title{font-family:var(--font-display);font-size:18pt;font-weight:700;color:#111}
  .print-sub{font-size:10pt;color:#444;margin-top:2px}
  .print-right{text-align:right}
  .print-biz{font-weight:700;font-size:11pt;color:#111}
  .print-date{font-size:9pt;color:#666;margin-top:4px}
  .print-footer{justify-content:space-between;align-items:center;border-top:1px solid #e5e7eb;margin-top:12px;padding-top:8px;font-size:9pt;color:#666}
  .print-page::after{content:counter(page)}
  #pnl-table table{width:100%;border-collapse:collapse}
  #pnl-table th,#pnl-table td{border-bottom:1px solid #e5e7eb;padding:6px 4px;font-size:9pt}
  #pnl-table th{color:#111;text-transform:uppercase;letter-spacing:0.04em;font-size:8pt}
  #pnl-table tr:last-child td{border-bottom:0}
}

/* --- PRODUCT INTERACTION + PREMIUM DETAIL --- */
.product-card{cursor:pointer;transition:transform 0.2s ease, box-shadow 0.2s ease,border-color 0.2s ease}
.product-card:hover{transform:translateY(-2px);border-color:var(--border3);box-shadow:0 10px 30px rgba(2,10,20,0.25)}
.modal-premium{border:1px solid var(--glass-border);background:linear-gradient(180deg,rgba(8,23,38,0.96),rgba(8,23,38,0.92));box-shadow:0 30px 80px rgba(0,0,0,0.45)}
.product-detail-card{padding:18px;border:1px solid rgba(54,132,219,0.18);background:linear-gradient(135deg,rgba(10,30,50,0.95),rgba(12,34,55,0.9));box-shadow:inset 0 1px 0 rgba(255,255,255,0.03)}
.product-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.product-title{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--text)}
.product-meta{font-size:0.8rem;color:var(--text4);margin-top:2px}
.product-desc{margin-top:8px;font-size:0.9rem;color:var(--text3);line-height:1.6}
.product-status .badge{padding:6px 12px;font-size:0.72rem;border-radius:20px}
.product-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}
.metric{background:rgba(7,22,37,0.7);border:1px solid rgba(54,132,219,0.2);border-radius:12px;padding:12px}
.metric-label{font-size:0.68rem;color:var(--text4);text-transform:uppercase;letter-spacing:0.08em}
.metric-value{font-size:1.05rem;font-weight:700;color:var(--text);margin-top:6px}
.product-foot{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:10px;border-top:1px dashed rgba(54,132,219,0.18)}
.product-launch{font-size:0.78rem;color:var(--text4)}
.product-rev{font-size:0.95rem;font-weight:700;color:var(--green)}
.product-tx-card{margin-top:12px}
.table{width:100%;border-collapse:separate;border-spacing:0}
.table thead th{text-align:left;font-size:0.7rem;text-transform:uppercase;letter-spacing:0.06em;color:var(--text4);padding:8px 10px;border-bottom:1px solid var(--border)}
.table tbody td{padding:10px;border-bottom:1px solid rgba(54,132,219,0.08);font-size:0.82rem;color:var(--text2)}
.table tbody tr:hover td{background:rgba(54,132,219,0.06)}

/* --- PRODUCT DETAILS ACTIONS --- */
#productDetailModal .modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:14px 18px;border-top:1px solid rgba(54,132,219,0.15);background:linear-gradient(180deg,rgba(8,23,38,0.65),rgba(8,23,38,0.9));border-bottom-left-radius:18px;border-bottom-right-radius:18px}
#productDetailModal .modal-actions .btn{min-width:90px}

/* --- P&L Period Button --- */
.pnl-period{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  height:36px;
  padding:0 34px 0 12px;
  border-radius:10px;
  border:1px solid var(--border2);
  background:linear-gradient(180deg,rgba(12,36,60,0.9),rgba(9,28,48,0.95));
  color:var(--text);
  font-size:0.8rem;
  font-weight:600;
  letter-spacing:0.01em;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.05);
  position:relative;
}
.pnl-period:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(54,132,219,0.25)}
.pnl-period{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23B3D6F9' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;
  background-position:right 10px center;
  background-size:14px 14px;
}


/* --- P&L Year Selector --- */
.pnl-year-only{display:flex;align-items:center;gap:8px;background:rgba(10,28,46,0.9);border:1px solid var(--border2);border-radius:12px;padding:6px 10px;color:var(--text3);font-size:0.78rem}
.pnl-year-only span{color:var(--text4)}
.pnl-year{height:30px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:0.78rem;padding:0 8px}
