/* SpendWise v5 */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');
:root{
  --green:#1D9E75;--green-lt:#E1F5EE;--green-dk:#0F6E56;
  --gold:#D97706;--gold-lt:#FEF3C7;
  --accent:#7C3AED;
  --red:#E24B4A;--red-lt:#FCEBEB;--amber:#EF9F27;--amber-lt:#FAEEDA;
  --blue:#378ADD;--blue-lt:#E6F1FB;--purple:#7C3AED;--purple-lt:#EDE9FE;
  --bg:#F3F4F6;--surface:#FFFFFF;--surface2:#F0F2F5;
  --border:rgba(0,0,0,0.08);--border-md:rgba(0,0,0,0.14);
  --text:#111827;--text-2:#6B7280;--text-3:#9CA3AF;
  --shadow:0 1px 3px rgba(0,0,0,0.07),0 4px 12px rgba(0,0,0,0.04);
  --shadow-lg:0 8px 30px rgba(0,0,0,0.1),0 2px 8px rgba(0,0,0,0.05);
  --r:12px;--rs:8px;--rl:18px;
  --font:'Outfit',system-ui,sans-serif;--mono:'JetBrains Mono',monospace;
  --ease:all 0.2s cubic-bezier(0.4,0,0.2,1);
  --ease-spring:all 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
[data-theme="dark"]{
  --bg:#0D0F14;--surface:#171923;--surface2:#1E2130;
  --border:rgba(255,255,255,0.07);--border-md:rgba(255,255,255,0.13);
  --text:#E8EDF5;--text-2:#8892A4;--text-3:#4A5568;
  --shadow:0 1px 3px rgba(0,0,0,0.4),0 4px 16px rgba(0,0,0,0.25);
  --shadow-lg:0 8px 32px rgba(0,0,0,0.5);
  --green-lt:rgba(29,158,117,0.14);--red-lt:rgba(226,75,74,0.14);
  --gold:#F59E0B;--gold-lt:rgba(245,158,11,0.14);
  --blue-lt:rgba(55,138,221,0.14);--amber-lt:rgba(239,159,39,0.14);--purple-lt:rgba(124,58,237,0.14);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}
a{color:var(--green);text-decoration:none}
button{font-family:var(--font);cursor:pointer;border:none;background:none}
input,select,textarea{font-family:var(--font)}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:3px}

/* AUTH */
#auth-screen{display:none;align-items:center;justify-content:center;min-height:100vh;padding:1rem;background:linear-gradient(135deg,#064E3B 0%,#1D9E75 60%,#6EE7B7 100%)}
.auth-card{background:var(--surface);border-radius:var(--rl);padding:2.5rem 2rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg);animation:slideUp .4s ease}
.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.brand-icon{width:44px;height:44px;background:var(--green);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px}
.brand-name{font-size:26px;font-weight:700;letter-spacing:-.5px}
.brand-name em{color:var(--green);font-style:normal}
.auth-sub{font-size:13px;color:var(--text-2);margin-bottom:1.5rem}
.tabs{display:flex;background:var(--surface2);border-radius:var(--rs);padding:3px;margin-bottom:1.25rem}
.tab-btn{flex:1;padding:8px;border-radius:6px;font-size:14px;font-weight:500;color:var(--text-2);transition:var(--ease)}
.tab-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.1)}
.field{margin-bottom:12px}
.field label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:5px}
.input{width:100%;padding:11px 14px;border:1.5px solid var(--border-md);border-radius:var(--rs);background:var(--bg);color:var(--text);font-size:14px;outline:none;transition:var(--ease)}
.input:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(29,158,117,.12)}
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:var(--rs);font-size:14px;font-weight:500;transition:var(--ease);white-space:nowrap;cursor:pointer}
.btn-block{width:100%;justify-content:center}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-dk);transform:translateY(-1px);box-shadow:0 4px 12px rgba(29,158,117,.3)}
.btn-green:active{transform:translateY(0);box-shadow:none}
.btn-ghost{background:var(--surface2);color:var(--text)}
.btn-ghost:hover{background:var(--border-md)}
.btn-red{background:var(--red-lt);color:var(--red)}
.btn-red:hover{background:var(--red);color:#fff}
.btn-blue{background:var(--blue-lt);color:var(--blue)}
.btn-blue:hover{background:var(--blue);color:#fff}
.btn-sm{padding:6px 12px;font-size:13px}
.btn-xs{padding:4px 10px;font-size:12px}
.demo-hint{font-size:12px;color:var(--text-3);text-align:center;margin-top:12px}
.demo-hint code{font-family:var(--mono);background:var(--surface2);padding:2px 6px;border-radius:4px;font-size:11px}
.auth-link{font-size:13px;color:var(--green);text-align:center;margin-top:12px;cursor:pointer;display:block}

/* APP */
#app{display:none;min-height:100vh;flex-direction:column}
#app.show{display:flex}
.topbar{position:sticky;top:0;z-index:50;background:var(--surface);border-bottom:1px solid var(--border);height:58px;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;backdrop-filter:blur(12px);transition:background .3s}
.topbar-brand{font-size:20px;font-weight:700;letter-spacing:-.3px}
.topbar-brand em{color:var(--green);font-style:normal}
.topbar-right{display:flex;align-items:center;gap:8px}
.icon-btn{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--surface2);color:var(--text-2);font-size:17px;transition:var(--ease);position:relative}
.icon-btn:hover{background:var(--green-lt);color:var(--green)}
.notif-badge{position:absolute;top:4px;right:4px;width:16px;height:16px;background:var(--red);color:#fff;border-radius:50%;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.add-btn{height:36px;padding:0 16px;border-radius:10px;background:var(--green);color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;gap:5px;transition:var(--ease)}
.add-btn:hover{background:var(--green-dk);transform:translateY(-1px)}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;cursor:pointer;transition:var(--ease-spring)}
.avatar:hover{transform:scale(1.08)}
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--surface);border-top:1px solid var(--border);display:flex;padding-bottom:env(safe-area-inset-bottom);transition:background .3s}
.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;padding:8px 4px 10px;gap:2px;color:var(--text-3);font-size:10px;font-weight:500;transition:var(--ease)}
.nav-btn svg{width:22px;height:22px;transition:var(--ease)}
.nav-btn.active{color:var(--green)}
.nav-btn.active svg{transform:scale(1.1)}
.nav-dot{width:4px;height:4px;border-radius:50%;background:transparent;transition:var(--ease)}
.nav-btn.active .nav-dot{background:var(--green)}
.main{flex:1;padding:1rem;padding-bottom:80px;max-width:980px;margin:0 auto;width:100%}
.page{display:none;animation:pageIn .25s ease}
.page.active{display:block}
@keyframes pageIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* NOTIFICATION DROPDOWN */
.notif-dropdown{position:absolute;top:44px;right:0;width:340px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-lg);z-index:200;overflow:hidden;animation:slideUp .2s ease}
.notif-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);font-size:14px;font-weight:600}
.notif-list{max-height:360px;overflow-y:auto}
.notif-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:var(--ease)}
.notif-item:hover{background:var(--surface2)}
.notif-item.unread{background:var(--green-lt)}
.notif-item:last-child{border-bottom:none}
.notif-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;background:var(--surface2)}
.notif-content{flex:1;min-width:0}
.notif-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-msg{font-size:12px;color:var(--text-2);margin-top:1px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.notif-time{font-size:11px;color:var(--text-3);margin-top:3px}
.notif-footer{padding:10px 16px;text-align:center;font-size:13px;color:var(--green);font-weight:500;cursor:pointer;border-top:1px solid var(--border)}
.notif-footer:hover{background:var(--surface2)}
.notif-empty{padding:2rem;text-align:center;color:var(--text-3);font-size:13px}

/* CARDS */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.125rem 1.25rem;box-shadow:var(--shadow);margin-bottom:1rem;transition:var(--ease)}
.card-title{font-size:11px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.summary-strip{background:linear-gradient(135deg,var(--green-dk),var(--green));border-radius:var(--rl);padding:1.5rem;margin-bottom:1rem;color:#fff;position:relative;overflow:hidden;transition:var(--ease)}
.summary-strip::before{content:'';position:absolute;top:-40px;right:-30px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.07)}
.bal-label{font-size:11px;opacity:.8;letter-spacing:.08em;text-transform:uppercase;font-weight:600}
.bal-val{font-size:38px;font-weight:700;letter-spacing:-1px;font-variant-numeric:tabular-nums;margin:4px 0;transition:all .4s ease}
.bal-pills{display:flex;gap:10px;margin-top:10px}
.bal-pill{flex:1;background:rgba(255,255,255,.13);border-radius:10px;padding:10px 14px;transition:var(--ease)}
.bal-pill:hover{background:rgba(255,255,255,.2)}
.bal-pill-label{font-size:11px;opacity:.8;margin-bottom:2px}
.bal-pill-val{font-size:18px;font-weight:700}
.metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:1rem}
.metric{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px;box-shadow:var(--shadow);transition:var(--ease-spring)}
.metric:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.metric-label{font-size:11px;color:var(--text-2);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.metric-val{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums}
.metric-sub{font-size:12px;color:var(--text-3);margin-top:2px}
.two-col{display:block}

/* CHARTS */
.chart-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.chart-tab{padding:5px 14px;border-radius:20px;font-size:13px;font-weight:500;border:1.5px solid var(--border-md);color:var(--text-2);transition:var(--ease)}
.chart-tab.active{background:var(--green);color:#fff;border-color:var(--green)}
.chart-tab:hover:not(.active){border-color:var(--green);color:var(--green)}
.legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px}
.legend-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-2)}
.ldot{width:10px;height:10px;border-radius:3px;flex-shrink:0}

/* TX LIST */
.tx-item{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border);transition:var(--ease)}
.tx-item:last-child{border-bottom:none}
.tx-item:hover{background:var(--surface2);margin:0 -8px;padding:11px 8px;border-radius:var(--rs)}
.tx-ico{width:42px;height:42px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;transition:var(--ease-spring)}
.tx-item:hover .tx-ico{transform:scale(1.05)}
.tx-body{flex:1;min-width:0}
.tx-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tx-meta{font-size:12px;color:var(--text-3);margin-top:1px;display:flex;gap:8px;flex-wrap:wrap}
.tx-amount{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}
.tx-del{opacity:0;width:32px;height:32px;border-radius:8px;background:var(--red-lt);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:13px;transition:var(--ease);flex-shrink:0;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}
.tx-item:hover .tx-del{opacity:1}
@media(hover:none){.tx-del{opacity:1}}
.badge{padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.b-income{background:var(--green-lt);color:var(--green-dk)}
.b-expense{background:var(--red-lt);color:var(--red)}
.b-recur{background:var(--blue-lt);color:var(--blue)}
.b-open{background:var(--amber-lt);color:#854F0B}
.b-inprog{background:var(--blue-lt);color:var(--blue)}
.b-resolved{background:var(--green-lt);color:var(--green-dk)}
.b-closed{background:var(--surface2);color:var(--text-2)}
.b-low{background:var(--green-lt);color:var(--green-dk)}
.b-medium{background:var(--blue-lt);color:var(--blue)}
.b-high{background:var(--amber-lt);color:#854F0B}
.b-urgent{background:var(--red-lt);color:var(--red)}

/* BUDGETS */
.bgt-item{margin-bottom:16px}
.bgt-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.bgt-cat{font-size:14px;font-weight:500}
.bgt-nums{font-size:12px;color:var(--text-2);font-variant-numeric:tabular-nums}
.bgt-track{height:8px;background:var(--surface2);border-radius:4px;overflow:hidden}
.bgt-fill{height:100%;border-radius:4px;transition:width .8s cubic-bezier(0.4,0,0.2,1)}
.bgt-pct{font-size:11px;color:var(--text-3);margin-top:3px}

/* POPUP */
.overlay{display:none;position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);align-items:flex-end;justify-content:center}
.overlay.open{display:flex;animation:fadeIn .2s ease}
.sheet{background:var(--surface);border-radius:var(--rl) var(--rl) 0 0;width:100%;max-width:560px;padding:1.25rem 1.25rem 2rem;max-height:90vh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}
@media(min-width:640px){.overlay{align-items:center}.sheet{border-radius:var(--rl);max-height:88vh}}
.handle{width:40px;height:4px;background:var(--border-md);border-radius:2px;margin:0 auto 1.25rem}
.sh-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.sh-title{font-size:17px;font-weight:700}
.sh-close{width:32px;height:32px;border-radius:50%;background:var(--surface2);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-size:16px;transition:var(--ease)}
.sh-close:hover{background:var(--border-md);transform:scale(1.1)}
.steps{display:flex;gap:4px;margin-bottom:1.25rem}
.step{height:3px;flex:1;border-radius:2px;background:var(--border-md);transition:background .4s}
.step.done{background:var(--green)}
.type-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:1rem}
.type-btn{padding:1.25rem 1rem;border:2px solid var(--border-md);border-radius:var(--r);background:var(--surface2);text-align:center;transition:var(--ease-spring)}
.type-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.type-btn.income-btn:hover{border-color:var(--green);background:var(--green-lt)}
.type-btn.expense-btn:hover{border-color:var(--red);background:var(--red-lt)}
.type-icon{font-size:28px;margin-bottom:6px}
.type-label{font-size:15px;font-weight:700}
.type-sub{font-size:12px;color:var(--text-2);margin-top:2px}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:1rem}
@media(min-width:380px){.cat-grid{grid-template-columns:repeat(4,1fr)}}
.cat-chip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 6px;border:1.5px solid var(--border-md);border-radius:var(--rs);background:var(--surface2);font-size:12px;font-weight:500;transition:var(--ease-spring)}
.cat-chip .ci{font-size:22px;transition:var(--ease-spring)}
.cat-chip:hover,.cat-chip.sel{border-color:var(--green);background:var(--green-lt);color:var(--green-dk)}
.cat-chip:hover .ci{transform:scale(1.2)}
.amt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.amt-chip{padding:10px;border:1.5px solid var(--border-md);border-radius:var(--rs);background:var(--surface2);font-size:14px;font-weight:600;text-align:center;transition:var(--ease-spring);font-variant-numeric:tabular-nums}
.amt-chip:hover,.amt-chip.sel{border-color:var(--green);background:var(--green-lt);color:var(--green-dk);transform:scale(1.02)}
.sms-box{border:1.5px dashed var(--border-md);border-radius:var(--rs);padding:12px;background:var(--surface2);margin-bottom:12px}
.sms-label{font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:6px}
.sms-ta{width:100%;background:none;border:none;color:var(--text);font-size:13px;resize:none;outline:none;line-height:1.5;font-family:var(--font)}
.sms-parse{margin-top:8px;font-size:12px;color:var(--green);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:var(--ease)}
.sms-parse:hover{color:var(--green-dk)}
.sms-parsed{background:var(--green-lt);border-radius:var(--rs);padding:10px 12px;margin-top:8px;font-size:12px;animation:fadeIn .3s ease}
.sms-row{display:flex;justify-content:space-between;margin-bottom:4px}
.sms-ask{background:var(--amber-lt);border-radius:var(--rs);padding:10px 12px;margin-top:8px;font-size:13px;color:#854F0B}
.toggle-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.toggle-label{font-size:14px;color:var(--text-2)}
.tgl{position:relative;width:42px;height:24px}
.tgl input{opacity:0;width:0;height:0}
.tgl-track{position:absolute;inset:0;border-radius:12px;background:var(--border-md);transition:var(--ease);cursor:pointer}
.tgl-track::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:var(--ease)}
.tgl input:checked+.tgl-track{background:var(--green)}
.tgl input:checked+.tgl-track::after{transform:translateX(18px)}

/* TOAST */
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--text);color:var(--surface);padding:10px 20px;border-radius:24px;font-size:14px;font-weight:500;opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);z-index:300;white-space:nowrap;pointer-events:none;display:flex;align-items:center;gap:8px}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.success{background:var(--green)}
.toast.warning{background:var(--amber);color:#fff}
.toast.danger{background:var(--red)}

/* SETTINGS */
.srow{display:flex;align-items:flex-start;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--border);gap:12px;transition:var(--ease)}
.srow:last-child{border-bottom:none}
.skey{font-size:14px;font-weight:500}
.ssub{font-size:12px;color:var(--text-3);margin-top:1px}
.sinput{background:var(--surface2);border:1.5px solid var(--border-md);border-radius:var(--rs);padding:7px 12px;font-size:14px;color:var(--text);outline:none;transition:var(--ease);width:150px}
.sinput:focus{border-color:var(--green)}
.sinput.wide{width:100%;margin-top:8px}
.ssection{font-size:12px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.08em;margin:16px 0 12px}

/* SEARCH */
.search-wrap{position:relative;margin-bottom:12px}
.search-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}
.search-inp{width:100%;padding:10px 14px 10px 36px;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--rs);font-size:14px;color:var(--text);outline:none;transition:var(--ease)}
.search-inp:focus{border-color:var(--green);background:var(--surface)}
.filter-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.fchip{padding:5px 14px;border-radius:20px;font-size:13px;font-weight:500;border:1.5px solid var(--border-md);color:var(--text-2);transition:var(--ease)}
.fchip.active{background:var(--green);color:#fff;border-color:var(--green)}
.fchip:hover:not(.active){border-color:var(--green);color:var(--green)}

/* ALERTS */
.alert{padding:10px 14px;border-radius:var(--rs);margin-bottom:10px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px;animation:slideIn .3s ease}
.alert-warn{background:var(--amber-lt);color:#854F0B;border:1px solid rgba(239,159,39,.3)}
.alert-danger{background:var(--red-lt);color:var(--red);border:1px solid rgba(226,75,74,.3)}
.alert-info{background:var(--blue-lt);color:var(--blue);border:1px solid rgba(55,138,221,.3)}
.alert-success{background:var(--green-lt);color:var(--green-dk);border:1px solid rgba(29,158,117,.3)}
@keyframes slideIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}

/* EMPTY */
.empty{text-align:center;padding:3rem 1rem;color:var(--text-3)}
.empty-icon{font-size:40px;margin-bottom:10px;animation:bounce 2s infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* ADMIN */
#admin-app{display:none;min-height:100vh}
#admin-app.show{display:flex}
.admin-sidebar{width:240px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:400;transition:transform .3s ease,background .3s}
.admin-sidebar.collapsed{transform:translateX(-240px)}
.sidebar-brand{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--border)}
.admin-badge{font-size:10px;background:var(--red-lt);color:var(--red);padding:2px 8px;border-radius:10px;font-weight:700;margin-left:6px}
.sidebar-nav{flex:1;padding:.75rem 0;overflow-y:auto}
.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 1.25rem;font-size:14px;font-weight:500;color:var(--text-2);transition:var(--ease);cursor:pointer;border-left:3px solid transparent}
.sidebar-link:hover{color:var(--text);background:var(--surface2)}
.sidebar-link.active{color:var(--green);background:var(--green-lt);border-left-color:var(--green)}
.sidebar-link svg{width:18px;height:18px;flex-shrink:0;transition:var(--ease)}
.sidebar-link:hover svg,.sidebar-link.active svg{transform:scale(1.1)}
.sidebar-badge{margin-left:auto;background:var(--red);color:#fff;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:700;animation:pulse 2s infinite}
.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--border)}
.admin-content{flex:1;margin-left:240px;min-height:100vh;display:flex;flex-direction:column;transition:margin .3s ease;min-width:0;overflow-x:hidden}
.admin-topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 1.5rem;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:30;transition:background .3s}
.admin-page-title{font-size:18px;font-weight:700}
.admin-main{flex:1;padding:1.5rem;overflow-x:hidden;min-width:0}
.admin-page{display:none;animation:pageIn .25s ease}
.admin-page.active{display:block}
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:1.5rem}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1rem 1.25rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px;transition:var(--ease-spring)}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.stat-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.stat-body .stat-val{font-size:26px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1}
.stat-body .stat-label{font-size:12px;color:var(--text-2);margin-top:2px}
.admin-table-wrap{overflow-x:auto;border-radius:var(--rs);-webkit-overflow-scrolling:touch;max-width:100%}
.admin-table{width:100%;border-collapse:collapse;font-size:14px}
.admin-table th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-2);background:var(--surface2);border-bottom:1px solid var(--border)}
.admin-table td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle;transition:var(--ease)}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:var(--surface2)}
.action-btns{display:flex;gap:6px;flex-wrap:wrap}
.sidebar-toggle{display:none;position:fixed;top:14px;left:14px;z-index:50;width:36px;height:36px;border-radius:10px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);align-items:center;justify-content:center;font-size:18px}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:35}
.admin-modal-overlay{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.62);backdrop-filter:blur(6px);align-items:center;justify-content:center;padding:1rem;isolation:isolate}
.admin-modal-overlay.open{display:flex;animation:fadeIn .2s ease}
.admin-modal{background:var(--surface);border-radius:var(--rl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .25s cubic-bezier(.34,1.56,.64,1)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem 0}
.modal-head h3{font-size:17px;font-weight:700}
.modal-body{padding:1rem 1.5rem}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid var(--border)}

@media(max-width:768px){
  .admin-sidebar{transform:translateX(-240px)}.admin-sidebar.open{transform:translateX(0)}
  .admin-content{margin-left:0}.sidebar-toggle{display:flex}.sidebar-overlay.vis{display:block}
  .stat-grid{grid-template-columns:1fr 1fr}.two-col{display:block}
}
@media(min-width:769px){
  .metrics{grid-template-columns:repeat(4,1fr)}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
  .stat-grid{grid-template-columns:repeat(4,1fr)}.main{padding:1.5rem;padding-bottom:90px}
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}

/* User search dropdown */
.user-search-dropdown{border-radius:var(--r);animation:slideUp .15s ease}
.user-search-dropdown div:last-child{border-bottom:none !important}

/* ─── MAINTENANCE COUNTDOWN ─────────────────────────────── */
.countdown-block{display:flex;flex-direction:column;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px 20px;min-width:80px;box-shadow:var(--shadow)}
.countdown-num{font-size:42px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1;color:var(--green)}
.countdown-label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}
.countdown-sep{font-size:36px;font-weight:700;color:var(--text-3);margin-top:-8px}
@media(max-width:480px){.countdown-num{font-size:30px}.countdown-block{padding:12px 14px;min-width:60px}}

@keyframes slideFromRight{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* Prevent iOS input zoom - font-size must be >= 16px on mobile */
@media(max-width:768px){
  .input,.sinput,select.input,textarea.input{font-size:16px !important}
  .search-inp{font-size:16px !important}
}

/* Notification panel */
#notif-modal > div{max-width:100vw}
.notif-item{padding:12px 16px}
.notif-content{overflow:hidden}
.notif-title{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:calc(100% - 10px)}
.notif-msg{font-size:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}

/* ─── RESPONSIVE TABLE FIXES ───────────────────────── */
@media(max-width:900px){
  .admin-table th,.admin-table td{padding:8px 10px;font-size:12px}
  .admin-table th:nth-child(5),.admin-table td:nth-child(5){display:none}
  .admin-table th:nth-child(6),.admin-table td:nth-child(6){display:none}
  .action-btns{flex-wrap:wrap;gap:4px}
  .btn-xs{padding:3px 8px;font-size:11px}
}
@media(max-width:600px){
  .admin-table th:nth-child(4),.admin-table td:nth-child(4){display:none}
  .stat-grid{grid-template-columns:1fr 1fr !important}
}
/* Prevent any horizontal scroll on body */
html,body{max-width:100vw;overflow-x:hidden}
.admin-content,.admin-main,.card,.main{max-width:100%;min-width:0}

/* ══ v7 UX Fixes ══════════════════════════════════════════ */

/* Fix user page table overflow on mobile */
.main { overflow-x: hidden; }
.card { overflow-x: hidden; }

/* Admin table - prevent overflow, allow scroll only on table-wrap */
.admin-table-wrap { overflow-x: auto; width: 100%; }
.admin-table { table-layout: auto; min-width: 600px; }

/* Announcement popup - ensure visible above everything */
#ann-popup { isolation: isolate; }

/* Forced reset screen background */
#forced-reset-screen { z-index: 9000; }

/* Admin notification badge */
#admin-notif-badge { display: none; }
#admin-notif-badge.show { display: flex !important; }

/* Better button hover states */
.btn-green:active { transform: scale(0.97); }
.btn-ghost:active { transform: scale(0.97); }

/* Toast position above bottom nav */
.toast { bottom: 90px; }
@media(min-width: 769px) { .toast { bottom: 24px; } }

/* Error table screenshot thumbnail */
#errors-body img { 
  display: inline-block;
  vertical-align: middle;
  transition: transform .2s;
}
#errors-body img:hover { transform: scale(1.05); }

/* Fix action buttons wrapping on small screens */
.action-btns { display: flex; flex-wrap: wrap; gap: 4px; align-items: center; }

/* Improved modal backdrop */
.admin-modal-overlay { background: rgba(0,0,0,0.65); }

/* Fix sheet max-height on very small phones */
@media(max-height: 600px) {
  .sheet { max-height: 95vh; }
}

/* Announcement popup close button */
#ann-popup button { flex-shrink: 0; }

/* User page - transactions table doesn't overflow */
#tx-all, #tx-recent { overflow-x: hidden; }
.tx-item { min-width: 0; }
.tx-name { max-width: 160px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Fix admin topbar on mobile */
@media(max-width: 768px) {
  .admin-topbar { padding: 0 1rem 0 56px; }
  .admin-page-title { font-size: 15px; }
}

/* Better form inputs */
.input:focus-visible { outline: none; }

/* Announcement banner inside app */
#ann-banner .alert { cursor: default; }

/* Smooth page transitions */
.admin-page.active { opacity: 1; }

/* ── Edit button (v7.1) ─────────────────────────────────── */
.tx-edit{opacity:0;width:32px;height:32px;border-radius:8px;background:var(--blue-lt);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:14px;transition:var(--ease);flex-shrink:0;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}
.tx-item:hover .tx-edit,.tx-item:hover .tx-del{opacity:1}
@media(hover:none){.tx-edit{opacity:1}}

/* ── datetime-local input theming ───────────────────────── */
input[type="datetime-local"].input{color:var(--text);background:var(--bg)}
input[type="datetime-local"]::-webkit-calendar-picker-indicator{filter:invert(0.5);cursor:pointer}
[data-theme="dark"] input[type="datetime-local"]::-webkit-calendar-picker-indicator{filter:invert(0.7)}

/* ── Allow PUT method in fetch ───────────────────────────── */

/* ── Markets module ─────────────────────────────────────── */
.skeleton-box{
  background:linear-gradient(90deg,var(--border) 25%,var(--bg) 50%,var(--border) 75%);
  background-size:200% 100%;
  animation:skeleton-shimmer 1.4s ease infinite;
  border-radius:8px;
}
@keyframes skeleton-shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}

/* ── Admin card variant (acard) ─────────────────────────── */
.acard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1rem;box-shadow:var(--shadow);margin-bottom:1rem}
.acard-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:6px}

/* ── table class used in access/pricelog sections ────────── */
.table{width:100%;border-collapse:collapse;font-size:13px}
.table th{padding:8px 10px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-2);background:var(--surface2);border-bottom:1px solid var(--border);white-space:nowrap}
.table td{padding:8px 10px;border-bottom:1px solid var(--border);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tr:hover td{background:var(--surface2)}

/* ── Fix bulk-error-bar: <tr> with flex won't work, use table-row ── */
#bulk-error-bar{display:none}
#bulk-error-bar.show{display:table-row}

/* ── Markets stat cards in price log section ─────────────── */
#pricelog-stats .stat-card,
#access-stats .stat-card{cursor:default}
#pricelog-stats .stat-card:hover,
#access-stats .stat-card:hover{transform:none;box-shadow:var(--shadow)}

/* ── Large card title variant for section headers ────────── */
.card-title-lg{font-size:14px;font-weight:700;color:var(--text);text-transform:none;letter-spacing:0;margin-bottom:0}

