/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;width:100%;transition:background .3s,color .3s;}
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;}
input[type=number]{-moz-appearance:textfield;}
button{font-family:inherit;}

/* ── COLORS: LIGHT THEME (default) ── */
:root{
  --navy:#0B2563;  --navy-mid:#1E40AF; --navy-lt:#3B5FCC;
  --red:#DC2626;   --green:#16A34A;    --amber:#D97706;
  --bg:#F0F2F5;    --white:#FFFFFF;
  --border:#E5E7EB;--border-lt:#F3F4F6;
  --text:#111827;  --text2:#6B7280;    --text3:#9CA3AF;
  --cur-wk:#EFF6FF;
  --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.05);
  --shadow-md:0 2px 8px rgba(0,0,0,.08);
  --header-bg:#0B2563;
  --card-bg:#FFFFFF;
  --nav-bg:#0B2563;
  --tabs-bg:#FFFFFF;
  --ctx-bg:#0B2563;
  --input-bg:#F0F2F5;
  --stripe-color:#DC2626;
  --total-bar:#0B2563;
  --stat-text:rgba(255,255,255,.9);
  --gold:#DC2626;
}
/* ── COLORS: MIDNIGHT BANKING (dark theme) ── */
html[data-theme="dark"]{
  --navy:#C8A951;  --navy-mid:#C8A951; --navy-lt:#F0D080;
  --red:#EF4444;   --green:#10B981;    --amber:#F59E0B;
  --bg:#080F1E;    --white:#0D1829;
  --border:rgba(200,169,81,.18);--border-lt:rgba(200,169,81,.08);
  --text:#E8EDF5;  --text2:#8899BB;    --text3:#4A5F80;
  --cur-wk:rgba(200,169,81,.08);
  --shadow:0 2px 8px rgba(0,0,0,.4);
  --shadow-md:0 4px 16px rgba(0,0,0,.5);
  --header-bg:#090F1C;
  --card-bg:#0D1829;
  --nav-bg:#0A1020;
  --tabs-bg:#0D1829;
  --ctx-bg:#060C16;
  --input-bg:#0A1422;
  --stripe-color:linear-gradient(90deg,#C8A951,#F0D080,#C8A951);
  --total-bar:#060C16;
  --stat-text:rgba(232,237,245,.85);
  --gold:#C8A951;
}

/* ── RED STRIPE ── */
body::before{content:'';position:fixed;top:0;left:0;right:0;height:4px;background:var(--stripe-color);z-index:300;}

/* ── LOGIN ── */
#loginScreen{position:fixed;inset:0;background:var(--navy);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;}
.login-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:2.5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;max-width:360px;width:100%;}
.login-logo{font-size:2rem;color:#fff;font-weight:700;text-align:center;}
.login-sub{color:rgba(255,255,255,.55);font-size:.9rem;text-align:center;line-height:1.6;}
.btn-google{display:flex;align-items:center;gap:.85rem;background:#fff;color:#1a1a1a;border:none;padding:.85rem 1.75rem;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;box-shadow:0 4px 20px rgba(0,0,0,.3);width:100%;justify-content:center;}
.btn-google:hover{transform:translateY(-1px);}
.btn-google svg{width:20px;height:20px;flex-shrink:0;}
.login-note{color:rgba(255,255,255,.3);font-size:.72rem;text-align:center;}

/* ── NAV ── */
#mainNav{height:52px;position:sticky;top:4px;z-index:100;display:none;max-width:100vw;}
.nav-inner{width:100%;max-width:1100px;margin:8px auto 0;padding:0 18px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--nav-bg);box-shadow:0 2px 8px rgba(11,37,99,.25);border-radius:14px 14px 0 0;}
.nav-brand{font-size:15px;font-weight:700;color:#fff;flex-shrink:0;}
.nav-right{display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden;flex-shrink:1;}
.nav-avatar{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.35);object-fit:cover;flex-shrink:0;}
.nav-name{font-size:12px;color:rgba(255,255,255,.7);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;}
.month-select{background:var(--navy-mid);color:#fff;border:1px solid rgba(255,255,255,.25);padding:4px 8px;border-radius:6px;font-family:'DM Mono',monospace;font-size:12px;cursor:pointer;appearance:none;-webkit-appearance:none;padding-right:22px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='white' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;}
.month-select option{background:var(--navy-mid);color:#fff;}
#saveStatus{font-size:11px;color:rgba(255,255,255,.45);font-family:'DM Mono',monospace;white-space:nowrap;}
#saveStatus.saved{color:#86EFAC;}
#saveStatus.saving{color:#FCD34D;}
#saveStatus.error{color:#FCA5A5;}
.btn-signout{background:transparent;color:rgba(255,255,255,.45);border:1px solid rgba(255,255,255,.18);padding:3px 8px;border-radius:5px;font-size:11px;cursor:pointer;white-space:nowrap;}
.btn-theme{background:transparent;border:1px solid rgba(255,255,255,.18);border-radius:5px;padding:3px 7px;font-size:14px;cursor:pointer;line-height:1;flex-shrink:0;}
.btn-theme:hover{background:rgba(255,255,255,.1);}
.btn-signout:hover{color:#fff;}

/* ── NAVY HEADER ── */
#navyHeader{padding:0;display:none;overflow:hidden;transition:background .3s;}
.header-inner{max-width:1100px;margin:0 auto;overflow:hidden;background:var(--header-bg);padding:20px 18px 16px;transition:background .3s;border-radius:0 0 14px 14px;}
.header-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px;gap:12px;flex-wrap:wrap;min-width:0;}
.header-title-group{flex-shrink:0;}
.header-app-label{font-size:11px;color:rgba(255,255,255,.45);letter-spacing:.08em;text-transform:uppercase;margin-bottom:2px;}
.header-month{font-size:22px;font-weight:700;color:#fff;font-family:'DM Mono',monospace;}
.header-stats{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;flex-shrink:0;max-width:calc(100vw - 32px);}
.header-stats::-webkit-scrollbar{display:none;}
.stat-card{flex-shrink:0;border-radius:10px;padding:10px 14px;min-width:96px;border:1px solid rgba(255,255,255,.1);}
.stat-card-label{font-size:9px;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px;}
.stat-card-value{font-size:16px;font-weight:700;font-family:'DM Mono',monospace;}
.header-progress{padding-bottom:14px;}
.header-progress-labels{display:flex;justify-content:space-between;margin-bottom:5px;}
.header-progress-label{font-size:10px;color:rgba(255,255,255,.45);}
.header-progress-count{font-size:10px;color:rgba(255,255,255,.7);font-family:'DM Mono',monospace;}
.header-progress-track{background:rgba(255,255,255,.1);border-radius:99px;height:5px;overflow:hidden;}
.header-progress-fill{background:linear-gradient(90deg,#22C55E,#86EFAC);height:100%;border-radius:99px;transition:width .4s;}

/* ── WEEK TABS ── */
#weekTabs{display:none;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;max-width:100vw;}
#weekTabs::-webkit-scrollbar{display:none;}
.tabs-inner{max-width:1100px;margin:10px auto 0;display:flex;min-width:0;background:var(--tabs-bg);border:1px solid var(--border);transition:background .3s;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);}
.wk-tab{flex-shrink:0;padding:10px 14px;cursor:pointer;border-bottom:3px solid transparent;transition:background .15s;min-width:70px;}
.wk-tab.all-tab{min-width:70px;}
.wk-tab.sel-all{border-bottom-color:var(--red);background:#FFF5F5;}
.wk-tab.sel-wk{border-bottom-color:var(--navy-mid);background:var(--cur-wk);}
.wk-tab-head{display:flex;align-items:center;gap:4px;margin-bottom:2px;}
.wk-tab-label{font-size:10px;font-weight:700;color:var(--text2);letter-spacing:.06em;text-transform:uppercase;}
.wk-tab.sel-all .wk-tab-label{color:var(--red);}
.wk-tab.sel-wk .wk-tab-label{color:var(--navy-mid);}
.wk-tab-now{font-size:7px;background:var(--navy);color:#fff;border-radius:3px;padding:1px 4px;font-weight:700;}
.wk-tab-past{font-size:9px;color:var(--text3);}
.wk-tab-range{font-size:9px;color:var(--text3);margin-bottom:3px;}
.wk-tab-bal{font-size:12px;font-weight:700;font-family:'DM Mono',monospace;}
.wk-tab-owing{font-size:9px;color:var(--amber);margin-top:1px;}
.wk-tab-divider{width:1px;background:var(--border);margin:8px 0;flex-shrink:0;}

/* ── CONTEXT BAR ── */
#ctxBar{display:none;transition:background .3s;}
.ctx-inner{width:100%;max-width:1100px;margin:10px auto 0;padding:12px 18px;display:flex;justify-content:space-between;align-items:center;background:var(--ctx-bg);transition:background .3s;border-radius:14px;}
.ctx-left{}
.ctx-label{font-size:11px;font-weight:700;color:rgba(255,255,255,.6);letter-spacing:.06em;text-transform:uppercase;}
.ctx-sub{font-size:12px;color:rgba(255,255,255,.5);margin-top:2px;}
.ctx-sub .c-paid{color:#86EFAC;}
.ctx-sub .c-total{color:#FCA5A5;}
.ctx-right{text-align:right;}
.ctx-bal-label{font-size:10px;color:rgba(255,255,255,.45);}
.ctx-bal-value{font-size:18px;font-weight:700;font-family:'DM Mono',monospace;}

/* ── BILL CARDS (mobile) ── */
#billCards{padding:12px 12px 0;background:var(--bg);display:none;overflow-x:hidden;transition:background .3s;}
.wk-sep-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.wk-sep-header+.wk-sep-header,.bill-card+.wk-sep-header{margin-top:20px;}
.wk-sep-label{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;}
.wk-sep-badge{font-size:9px;background:var(--navy);color:#fff;border-radius:4px;padding:2px 6px;font-weight:700;}
.wk-sep-past{font-size:9px;color:var(--text3);}
.bill-card{background:var(--card-bg);border-radius:16px;margin-bottom:10px;border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;transition:background .3s;}
.bill-card.paid{opacity:.5;}
.bill-card-top{padding:14px 16px;display:flex;align-items:center;gap:12px;}
.bill-badge{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px;font-weight:700;}
.bill-badge.cur{background:#DBEAFE;color:var(--navy-mid);}
.bill-badge.past{background:#F3F4F6;color:var(--text3);}
.bill-badge.future{background:#DBEAFE;color:var(--navy-mid);}
.bill-day{flex-shrink:0;width:40px;}
.bill-day-num{font-size:20px;font-weight:700;color:var(--text);line-height:1;}
.bill-day-wday{font-size:11px;color:var(--text3);margin-top:1px;}
.bill-info{flex:1;min-width:0;}
.bill-name{font-size:17px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2;}
.bill-date{font-size:12px;color:var(--text3);margin-top:3px;}
.bill-amt{text-align:right;flex-shrink:0;}
.bill-amt-value{font-size:18px;font-weight:700;font-family:'DM Mono',monospace;letter-spacing:-.02em;}
.bill-amt-value.unpaid{color:var(--red);}
.bill-amt-value.paid{color:var(--green);}
.bill-actions{border-top:1px solid var(--border);display:flex;}
.bill-action{flex:1;padding:11px 0;font-size:13px;font-weight:600;cursor:pointer;background:var(--card-bg);border:none;display:flex;align-items:center;justify-content:center;}
.bill-action.mark{flex:2;color:#9CA3AF;transition:background .2s,color .2s;}
.bill-action.mark.is-paid{background:var(--green)!important;color:#fff!important;}
.bill-action.edit-btn{border-left:1px solid var(--border);color:var(--navy-lt);font-size:16px;}
.bill-action.del-btn{border-left:1px solid var(--border);color:#D1D5DB;font-size:16px;}
.bill-total-bar{background:var(--total-bar);border-radius:10px;padding:12px 16px;margin:8px 0 12px;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--border);}
.bill-total-label{font-size:12px;font-weight:700;color:rgba(255,255,255,.6);letter-spacing:.08em;text-transform:uppercase;}
.bill-total-value{font-size:18px;font-weight:700;color:#fff;font-family:'DM Mono',monospace;}
.bills-empty{text-align:center;padding:32px 16px;color:var(--text3);}
.bills-empty-icon{font-size:32px;margin-bottom:8px;}
.bills-empty-title{font-size:14px;font-weight:600;color:var(--text2);}
.bills-empty-sub{font-size:12px;margin-top:4px;}

/* ── EXPENSE TABLE (desktop) ── */
#expenseTable{display:none;padding:14px 0 0;max-width:1100px;margin:0 auto;}
#expenseTable .table-header{padding:0 4px;}
.table-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.table-title{font-size:11px;font-weight:700;color:var(--navy);letter-spacing:.08em;text-transform:uppercase;}
.table-sub{font-size:11px;color:var(--text3);margin-top:2px;}
.table-wrap{background:var(--card-bg);border-radius:14px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-md);}
table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;}
thead tr{background:var(--navy);}
thead th{padding:13px 14px;font-size:10px;font-weight:700;color:rgba(255,255,255,.85);text-align:left;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;}
thead th.amt{text-align:right;}
tbody tr{transition:background .15s;}
tbody td{padding:14px;color:#000;vertical-align:middle;background:#FEF2F2;border-top:1px solid #D1D5DB;border-right:1px solid #D1D5DB;transition:background .15s;}
tbody td:last-child{border-right:none;}
tbody tr:hover td{background:#FEE2E2;}
tbody tr.row-paid td{background:#F0FDF4;}
tbody tr.row-paid:hover td{background:#DCFCE7;}
tbody tr.row-paid .td-name,tbody tr.row-paid .td-amt{text-decoration:line-through;text-decoration-color:rgba(22,163,74,.6);text-decoration-thickness:1.5px;}
tbody tr.row-paid .td-name,tbody tr.row-paid .td-amt,tbody tr.row-paid .td-day,tbody tr.row-paid .td-date,tbody tr.row-paid .td-wday{color:#000;}
.td-wk-badge{background:var(--navy);color:#fff;font-size:9px;font-weight:700;padding:3px 7px;border-radius:5px;font-family:'DM Mono',monospace;letter-spacing:.04em;}
.td-day{font-weight:700;color:#000;font-family:'DM Mono',monospace;font-size:14px;}
.td-date{font-size:12px;color:#000;white-space:nowrap;}
.td-wday{font-size:12px;color:#000;font-style:italic;}
.td-name{font-weight:600;font-size:14px;letter-spacing:-.01em;color:#000;}
.td-cur{font-weight:700;}
.td-amt{font-weight:700;color:#000;text-align:right;font-family:'DM Mono',monospace;white-space:nowrap;font-size:14px;letter-spacing:-.02em;}
.td-actions{text-align:right;white-space:nowrap;}
.sep-row td{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px!important;pointer-events:none;border-top:none!important;}
.sep-cur td{background:#FEE2E2!important;color:#991B1B!important;box-shadow:inset 3px 0 0 var(--red);}
.sep-past td{background:#F3F4F6!important;color:#6B7280!important;box-shadow:inset 3px 0 0 #9CA3AF;}
.sep-future td{background:#DBEAFE!important;color:#1E40AF!important;box-shadow:inset 3px 0 0 var(--navy-mid);}
.btn-paid{border:1px solid var(--border);background:#fff;color:var(--text2);border-radius:99px;padding:5px 14px;font-size:10px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s;letter-spacing:.02em;}
.btn-paid:hover{border-color:var(--navy-lt);color:var(--navy);}
.btn-paid.is-paid{background:var(--green);border-color:var(--green);color:#fff;box-shadow:0 1px 3px rgba(22,163,74,.25);}
.btn-paid.is-paid:hover{background:#15803D;border-color:#15803D;color:#fff;}
.btn-edit{background:transparent;border:none;color:var(--navy-lt);cursor:pointer;font-size:14px;padding:6px 8px;border-radius:6px;transition:background .15s,color .15s;}
.btn-edit:hover{background:var(--cur-wk);color:var(--navy);}
.btn-del{background:transparent;border:none;color:var(--text3);cursor:pointer;font-size:14px;padding:6px 8px;border-radius:6px;transition:background .15s,color .15s;}
.btn-del:hover{background:#FEE2E2;color:var(--red);}
tfoot tr{background:var(--navy);}
tfoot td{padding:14px;font-family:'DM Mono',monospace;color:#fff!important;font-weight:700;border-top:none!important;}
tfoot td.tfoot-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;}
tfoot td.tfoot-amt{font-size:16px;text-align:right;letter-spacing:-.02em;}
.add-btn{background:var(--navy);color:#fff;border:none;padding:7px 18px;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;}
.add-btn:hover{background:var(--navy-mid);}
.undo-btn{background:transparent;color:var(--text2);border:1px solid var(--border);padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;display:none;}
.undo-btn.show{display:inline-block;}

/* ── INCOME SECTION ── */
#incomeSection{display:none;}
.income-wrap{padding:12px 12px 0;}
.income-card{background:var(--card-bg);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;margin-bottom:12px;transition:background .3s;}
.income-card-hdr{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;}
.income-card-hdr-desk{background:#F8FAFC;padding:10px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.income-section-title{font-size:10px;font-weight:700;color:var(--text2);letter-spacing:.08em;text-transform:uppercase;}
.income-section-title-desk{font-size:11px;font-weight:700;color:var(--navy);letter-spacing:.07em;text-transform:uppercase;}
.savings-pill{background:var(--navy);color:#fff;border-radius:6px;padding:5px 14px;font-size:11px;font-weight:700;font-family:'DM Mono',monospace;white-space:nowrap;}
.savings-pill.deficit{background:var(--red);}
.income-body{padding:12px 14px;display:flex;flex-direction:column;gap:12px;}
.income-body-desk{padding:14px 16px;display:flex;flex-direction:column;gap:12px;}
.toggle-row{display:flex;align-items:center;gap:8px;}
.toggle-label{font-size:12px;color:var(--text2);}
.toggle-label.active{font-weight:600;color:var(--text);}
.toggle-switch{position:relative;width:36px;height:20px;flex-shrink:0;}
.toggle-switch input{opacity:0;position:absolute;width:100%;height:100%;cursor:pointer;margin:0;z-index:1;}
.toggle-track{position:absolute;inset:0;background:var(--border);border-radius:99px;transition:background .2s;}
.toggle-thumb{position:absolute;width:14px;height:14px;background:#fff;border-radius:50%;top:3px;left:3px;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2);}
.toggle-switch input:checked~.toggle-track{background:var(--navy);}
.toggle-switch input:checked~.toggle-thumb{left:19px;}
.income-field{background:var(--input-bg);border:1px solid var(--border);border-radius:6px;padding:7px 12px;display:flex;align-items:center;gap:6px;}
.income-field-sym{font-weight:700;color:var(--text2);flex-shrink:0;}
.income-field-input{border:none;background:transparent;font-family:'DM Mono',monospace;font-size:15px;font-weight:700;color:var(--text);outline:none;width:100%;min-width:0;transition:color .3s;}
.income-field-sfx{font-size:10px;color:var(--text3);flex-shrink:0;white-space:nowrap;}
.wk-custom-row{display:flex;align-items:center;gap:8px;}
.wk-custom-row-desk{padding:4px 10px;border-right:1px solid var(--border-lt);}
.wk-custom-label{font-size:10px;font-weight:700;color:var(--navy);letter-spacing:.06em;text-transform:uppercase;width:28px;flex-shrink:0;}
.wk-custom-range{font-size:9px;color:var(--text3);width:72px;flex-shrink:0;}
.wk-custom-range-desk{font-size:9px;color:var(--text3);margin-bottom:6px;}
.wk-custom-grid{display:grid;grid-template-columns:repeat(4,1fr) auto;}
.wk-total-col{padding:4px 10px;background:#F8FAFC;border-left:1px solid var(--border);}
.wk-total-label{font-size:9px;font-weight:700;color:var(--navy);letter-spacing:.06em;text-transform:uppercase;margin-bottom:3px;}
.wk-total-range{font-size:9px;color:var(--text3);margin-bottom:6px;}
.wk-total-value{font-size:15px;font-weight:700;color:var(--navy);font-family:'DM Mono',monospace;margin-top:10px;}
.savings-row{border-radius:8px;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;}
.savings-row.surplus{background:#F0FDF4;}
.savings-row.deficit{background:#FEF2F2;}
.savings-row-label{font-size:12px;font-weight:600;}
.savings-row-label.surplus{color:var(--green);}
.savings-row-label.deficit{color:var(--red);}
.savings-row-sub{font-size:10px;color:var(--text3);margin-top:1px;}
.savings-row-value{font-size:17px;font-weight:700;font-family:'DM Mono',monospace;}
.desk-income-wrap{max-width:1100px;margin:0 auto;padding:14px 0 24px;}
.weekly-same-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.weekly-same-total{font-size:14px;font-weight:700;color:var(--navy);font-family:'DM Mono',monospace;}

/* ── FAB ── */
#fabAdd{position:fixed;bottom:24px;right:20px;width:56px;height:56px;border-radius:50%;background:var(--navy);border:none;color:#fff;font-size:28px;cursor:pointer;box-shadow:0 4px 14px rgba(11,37,99,.4);z-index:200;display:none;align-items:center;justify-content:center;}
#fabAdd:active{transform:scale(.93);}

/* ── BOTTOM SHEET ── */
.sheet-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:400;display:none;}
.sheet-overlay.open{display:block;}
.sheet{position:fixed;left:0;right:0;bottom:0;background:var(--card-bg);border-radius:20px 20px 0 0;border-top:3px solid var(--gold);z-index:401;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);max-width:520px;margin:0 auto;}
.sheet.open{transform:translateY(0);}
.sheet-handle{width:40px;height:4px;background:var(--border);border-radius:99px;margin:12px auto 0;}
.sheet-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 10px;border-bottom:1px solid var(--border-lt);}
.sheet-title{font-size:16px;font-weight:700;color:var(--navy);}
.sheet-close{background:var(--bg);border:1px solid var(--border);color:var(--text2);width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;}
.sheet-body{padding:16px 20px 28px;display:flex;flex-direction:column;gap:14px;max-height:70vh;overflow-y:auto;}
.form-row{display:flex;gap:12px;}
.form-group{display:flex;flex-direction:column;gap:6px;flex:1;}
.form-label{font-size:11px;font-weight:700;color:var(--navy);letter-spacing:.06em;text-transform:uppercase;}
.form-input{background:var(--input-bg);border:1.5px solid var(--border);border-radius:8px;padding:11px 14px;font-family:'Inter',sans-serif;font-size:15px;color:var(--text);outline:none;width:100%;}
.form-input:focus{border-color:var(--navy);background:#fff;}
.form-input::placeholder{color:var(--text3);}
.form-date-preview{font-size:11px;color:var(--navy-lt);font-family:'DM Mono',monospace;min-height:16px;margin-top:3px;}
.form-submit{background:var(--navy);color:#fff;border:none;border-radius:8px;padding:14px;font-size:15px;font-weight:700;cursor:pointer;margin-top:4px;}
.form-submit:hover{background:var(--navy-mid);}
.form-delete{background:#fff;color:var(--red);border:1.5px solid var(--red);border-radius:8px;padding:12px;font-size:14px;font-weight:600;cursor:pointer;}

/* ── TOAST ── */
.toast{position:fixed;bottom:20px;right:20px;background:var(--navy);color:#fff;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:600;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s;pointer-events:none;z-index:999;box-shadow:var(--shadow-md);}
.toast.show{opacity:1;transform:translateY(0);}
.toast.err{background:var(--red);}

/* ── RESPONSIVE ── */
@media(min-width:769px){
  .header-inner{padding:20px 22px 18px;}
  .stat-card{min-width:110px;}
  .stat-card-value{font-size:17px;}
  .wk-tab{min-width:110px;padding:10px 16px;}
  .wk-tab.all-tab{min-width:80px;}
  .wk-tab-label{font-size:10px;}
  .ctx-inner{padding:12px 22px;}
  .nav-inner{padding:0 22px;}
  #billCards{display:none!important;}
  #expenseTable{display:block;}
  .income-wrap{display:none!important;}
  .desk-income-wrap{display:block!important;}
  #fabAdd{display:none!important;}
  .nav-name{display:block;}
}
@media(max-width:768px){
  html,body{overflow-x:hidden;width:100%;max-width:100vw;}
  #expenseTable{display:none!important;}
  #billCards{display:block;}
  .income-wrap{display:block;}
  .desk-income-wrap{display:none!important;}
  #fabAdd{display:flex;}
  .nav-name{display:none;}
  .income-card-hdr-desk,.income-body-desk{display:none!important;}
  #deskWeeklyCustomRow{display:none!important;}
}
@media print{
  #loginScreen,#fabAdd,.sheet-overlay,.sheet,.toast,body::before,
  .btn-del,.btn-edit,.add-btn,.undo-btn,.btn-signout{display:none!important;}
}