/* ══ TOKENS ══════════════════════════════════════════════════ */
:root {
  --void:    #06080d;
  --ink:     #0b0e16;
  --glass:   rgba(255,255,255,.04);
  --glass2:  rgba(255,255,255,.07);
  --rim:     rgba(255,255,255,.08);
  --rim2:    rgba(255,255,255,.14);
  --muted:   #3a4a65;
  --dim:     #546480;
  --mid:     #7a8fb0;
  --text:    #c8d4ec;
  --bright:  #eef2ff;
  --green:   #00f5a0;
  --red:     #ff3d6b;
  --blue:    #3d9fff;
  --gold:    #ffb830;
  --purple:  #a855f7;
  --mono: 'DM Mono', monospace;
  --ui:   'Syne', sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;background:var(--void);color:var(--text);font-family:var(--ui);font-size:14px;overflow:hidden}

/* ══ NOISE TEXTURE OVERLAY ══ */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1000;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
  opacity:.4;
}

/* ══ SPLASH ══ */
#splash{
  position:fixed;inset:0;z-index:500;
  background:var(--void);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;
  transition:opacity .6s ease,transform .6s cubic-bezier(.4,0,.2,1);
}
#splash.gone{opacity:0;transform:scale(.92);pointer-events:none}

.sp-ring{
  width:100px;height:100px;position:relative;margin-bottom:24px;
}
.sp-ring::before{
  content:'';position:absolute;inset:0;border-radius:50%;
  border:1px solid rgba(255,184,48,.3);
  animation:ringPulse 2s ease infinite;
}
.sp-ring::after{
  content:'';position:absolute;inset:8px;border-radius:50%;
  border:1px solid rgba(255,184,48,.15);
  animation:ringPulse 2s ease .3s infinite;
}
@keyframes ringPulse{
  0%,100%{transform:scale(1);opacity:.6}
  50%{transform:scale(1.08);opacity:1}
}
.sp-mark{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:36px;font-weight:500;
  color:var(--gold);
  text-shadow:0 0 30px rgba(255,184,48,.6);
}
.sp-name{
  font-family:var(--ui);font-size:13px;font-weight:800;
  letter-spacing:8px;color:var(--bright);
  text-transform:uppercase;margin-bottom:6px;
}
.sp-sub{font-size:10px;color:var(--dim);letter-spacing:4px;text-transform:uppercase}

/* ══ APP ══ */
#app{display:flex;flex-direction:column;height:100vh;height:100dvh;opacity:0;transition:opacity .4s ease}
#app.on{opacity:1}

/* ══ HEADER ══ */
#hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;
  padding-top:max(14px,env(safe-area-inset-top));
  background:var(--void);
  border-bottom:1px solid var(--rim);
  flex-shrink:0;position:relative;
  backdrop-filter:blur(20px);
}
#hdr::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,184,48,.3),transparent);
}
.hdr-l{display:flex;align-items:center;gap:10px}
.hdr-mark{
  width:34px;height:34px;
  background:linear-gradient(135deg,var(--gold),#ff9500);
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:17px;font-weight:500;color:#000;
  box-shadow:0 4px 16px rgba(255,184,48,.35);
}
.hdr-app{font-family:var(--ui);font-weight:800;font-size:13px;letter-spacing:3px;color:var(--bright)}
.hdr-date{font-size:10px;color:var(--dim);font-family:var(--mono);margin-top:1px}

.add-fab{
  width:38px;height:38px;border-radius:12px;
  background:linear-gradient(135deg,var(--green),#00c97a);
  border:none;color:#000;font-size:22px;font-weight:300;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  box-shadow:0 4px 20px rgba(0,245,160,.3);
  transition:transform .15s,box-shadow .15s;
}
.add-fab:active{transform:scale(.92);box-shadow:0 2px 10px rgba(0,245,160,.2)}

/* ══ STAGE ══ */
#stage{flex:1;overflow:hidden;position:relative}
.view{
  position:absolute;inset:0;overflow-y:auto;
  padding:0 0 90px;
  opacity:0;pointer-events:none;
  transform:translateY(10px);
  transition:opacity .28s ease,transform .28s ease;
}
.view.active{opacity:1;pointer-events:auto;transform:none}
.view::-webkit-scrollbar{display:none}

/* ══ DASHBOARD ══ */

/* Hero gradient band */
.dash-hero{
  background:linear-gradient(180deg,rgba(255,184,48,.06) 0%,transparent 100%);
  padding:20px 18px 16px;
  position:relative;
}
.dash-hero::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,184,48,.4),transparent);
}
.dh-eyebrow{font-size:9px;font-weight:600;letter-spacing:3px;color:var(--dim);text-transform:uppercase;margin-bottom:8px}
.dh-num{
  font-family:var(--mono);font-size:40px;font-weight:500;
  color:var(--bright);letter-spacing:-1.5px;line-height:1;
  margin-bottom:4px;
}
.dh-num span{font-size:18px;color:var(--mid);font-weight:400}
.dh-sub{font-size:11px;color:var(--dim);font-family:var(--mono)}
.dh-badge{
  display:inline-flex;align-items:center;gap:4px;
  background:rgba(0,245,160,.1);border:1px solid rgba(0,245,160,.2);
  border-radius:20px;padding:3px 10px;
  font-size:10px;font-weight:600;color:var(--green);
  margin-top:8px;font-family:var(--mono);
}
.dh-badge.neg{background:rgba(255,61,107,.1);border-color:rgba(255,61,107,.2);color:var(--red)}

/* Ticker strip */
.ticker-strip{
  display:flex;overflow-x:auto;gap:10px;
  padding:0 18px 16px;scrollbar-width:none;
}
.ticker-strip::-webkit-scrollbar{display:none}
.tk-card{
  flex-shrink:0;
  background:var(--glass);
  border:1px solid var(--rim);
  border-radius:14px;
  padding:13px 14px;
  min-width:110px;
  position:relative;overflow:hidden;
}
.tk-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  border-radius:14px 14px 0 0;
}
.tk-card.inc::before{background:linear-gradient(90deg,transparent,var(--green),transparent)}
.tk-card.exp::before{background:linear-gradient(90deg,transparent,var(--red),transparent)}
.tk-card.fx::before{background:linear-gradient(90deg,transparent,var(--blue),transparent)}
.tk-card.sv::before{background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.tk-lbl{font-size:8px;font-weight:600;letter-spacing:2px;color:var(--dim);text-transform:uppercase;margin-bottom:6px}
.tk-val{font-family:var(--mono);font-size:17px;font-weight:500;color:var(--text)}
.tk-val.inc{color:var(--green)}
.tk-val.exp{color:var(--red)}
.tk-val.fx{color:var(--blue)}
.tk-val.sv{color:var(--gold)}
.tk-delta{font-size:9px;margin-top:4px;font-family:var(--mono);color:var(--muted)}
.tk-delta.up{color:var(--green)}
.tk-delta.dn{color:var(--red)}

/* Chart section */
.sect{padding:0 18px;margin-bottom:20px}
.sect-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:12px;
}
.sect-title{font-size:9px;font-weight:600;letter-spacing:2.5px;color:var(--dim);text-transform:uppercase}
.sect-action{font-size:11px;color:var(--mid);font-family:var(--mono)}

/* Year nav inline */
.ynav{display:flex;align-items:center;gap:8px}
.yn-b{background:var(--glass);border:1px solid var(--rim);color:var(--dim);width:24px;height:24px;border-radius:7px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s}
.yn-b:hover{color:var(--text)}
#ynY{font-family:var(--mono);font-size:11px;color:var(--mid)}

/* Bar chart */
.bchart{display:flex;align-items:flex-end;gap:4px;height:64px}
.bc-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer}
.bc-bars{display:flex;gap:1px;align-items:flex-end;height:48px;width:100%}
.bc-b{flex:1;border-radius:2px 2px 0 0;min-height:2px;transition:opacity .2s}
.bc-b.i{background:linear-gradient(180deg,var(--green),rgba(0,245,160,.3));opacity:.7}
.bc-b.e{background:linear-gradient(180deg,var(--red),rgba(255,61,107,.3));opacity:.7}
.bc-col:hover .bc-b{opacity:1}
.bc-lbl{font-size:8px;color:var(--muted);font-family:var(--mono)}
.bc-col.cur .bc-lbl{color:var(--gold)}
.bc-col.cur .bc-b{opacity:1}

/* Category pills */
.cat-grid{display:flex;flex-direction:column;gap:6px}
.cat-row{display:flex;align-items:center;gap:10px}
.cat-e{font-size:14px;width:20px;text-align:center;flex-shrink:0}
.cat-info{flex:1;min-width:0}
.cat-n{font-size:11px;color:var(--text);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cat-track{height:3px;background:rgba(255,255,255,.06);border-radius:2px}
.cat-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--red),rgba(255,61,107,.4))}
.cat-a{font-family:var(--mono);font-size:10px;color:var(--mid);flex-shrink:0}

/* Recent mini */
.recent-item{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--rim);cursor:pointer}
.recent-item:last-child{border-bottom:none}
.ri-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.ri-dot.income{background:var(--green);box-shadow:0 0 8px var(--green)}
.ri-dot.expense{background:var(--red);box-shadow:0 0 8px var(--red)}
.ri-body{flex:1;min-width:0}
.ri-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ri-date{font-size:9px;color:var(--muted);font-family:var(--mono);margin-top:1px}
.ri-amt{font-family:var(--mono);font-size:12px;font-weight:500;flex-shrink:0}
.ri-amt.income{color:var(--green)}
.ri-amt.expense{color:var(--red)}

/* ══ MONTHLY ══ */
.month-hero{
  padding:20px 18px 16px;
  background:linear-gradient(180deg,rgba(61,159,255,.05) 0%,transparent 100%);
  position:relative;margin-bottom:4px;
}
.month-hero::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(61,159,255,.4),transparent);
}
.mnav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.mn-arr{
  background:var(--glass);border:1px solid var(--rim2);color:var(--mid);
  width:36px;height:36px;border-radius:10px;font-size:20px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s;
}
.mn-arr:hover{color:var(--bright);background:var(--glass2)}
.mn-c{text-align:center}
.mn-name{font-family:var(--ui);font-size:22px;font-weight:800;color:var(--bright)}
.mn-year{font-size:11px;color:var(--dim);font-family:var(--mono);margin-top:2px}

.m3kpi{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}
.m3k{
  background:var(--glass);border:1px solid var(--rim);border-radius:12px;
  padding:12px;text-align:center;
}
.m3k-l{font-size:8px;font-weight:600;letter-spacing:2px;color:var(--dim);margin-bottom:5px;text-transform:uppercase}
.m3k-v{font-family:var(--mono);font-size:14px;font-weight:500;color:var(--text)}
.m3k-v.inc{color:var(--green)}
.m3k-v.exp{color:var(--red)}

/* Save ring */
.save-ring-wrap{
  background:var(--glass);border:1px solid var(--rim);border-radius:16px;
  padding:16px;margin-bottom:16px;
  display:flex;align-items:center;gap:16px;
}
.srw-ring{position:relative;flex-shrink:0}
.srw-ring svg{transform:rotate(-90deg)}
.srw-ring-center{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
}
.srw-pct{font-family:var(--mono);font-size:16px;font-weight:500;color:var(--gold)}
.srw-lbl{font-size:8px;color:var(--dim);letter-spacing:1px;margin-top:1px}
.srw-info{flex:1}
.srw-title{font-size:10px;font-weight:600;letter-spacing:1.5px;color:var(--dim);margin-bottom:6px;text-transform:uppercase}
.srw-amt{font-family:var(--mono);font-size:16px;font-weight:500;color:var(--bright);margin-bottom:4px}
.srw-note{font-size:10px;color:var(--muted)}
.srw-note.good{color:var(--green)}
.srw-note.bad{color:var(--red)}

/* ══ TXN BLOCK ══ */
.txb{padding:0 18px;margin-bottom:16px}
.txb-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.txb-title{font-size:9px;font-weight:600;letter-spacing:2.5px;color:var(--dim);text-transform:uppercase}
.txb-cnt{font-family:var(--mono);font-size:11px;font-weight:500}
.txb-cnt.inc{color:var(--green)}
.txb-cnt.exp{color:var(--red)}

/* ══ TXN CARDS ══ */
.txn-list{display:flex;flex-direction:column;gap:5px}
.empty{
  text-align:center;padding:22px 16px;color:var(--muted);font-size:12px;
  border:1px dashed var(--rim2);border-radius:12px;
}
.txn-item{
  display:flex;align-items:center;gap:12px;
  background:var(--glass);border:1px solid var(--rim);
  border-radius:12px;padding:12px 14px;
  cursor:pointer;transition:background .15s,border-color .15s;
  position:relative;overflow:hidden;
}
.txn-item::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:2px;border-radius:2px 0 0 2px;
}
.txn-item.income::before{background:var(--green)}
.txn-item.expense::before{background:var(--red)}
.txn-item.forex-buy::before{background:var(--blue)}
.txn-item.forex-sell::before{background:var(--gold)}
.txn-item:hover{background:var(--glass2);border-color:var(--rim2)}
.ti-body{flex:1;min-width:0}
.ti-cat{font-size:9px;color:var(--dim);letter-spacing:.5px;margin-bottom:2px}
.ti-desc{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ti-note{font-size:10px;color:var(--muted);margin-top:1px}
.ti-right{text-align:right;flex-shrink:0}
.ti-amt{font-family:var(--mono);font-size:13px;font-weight:500}
.ti-amt.income{color:var(--green)}
.ti-amt.expense{color:var(--red)}
.ti-amt.forex-buy{color:var(--blue)}
.ti-amt.forex-sell{color:var(--gold)}
.ti-date{font-size:9px;color:var(--muted);margin-top:2px;font-family:var(--mono)}

/* ══ FOREX ══ */
.forex-hero{
  padding:20px 18px 20px;
  background:linear-gradient(180deg,rgba(61,159,255,.07) 0%,transparent 100%);
  position:relative;margin-bottom:4px;
}
.forex-hero::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(61,159,255,.5),transparent);
}
.fx-title{font-size:9px;font-weight:600;letter-spacing:3px;color:var(--dim);text-transform:uppercase;margin-bottom:10px}
.fx-amount{font-family:var(--mono);font-size:38px;font-weight:500;color:var(--blue);letter-spacing:-1px;margin-bottom:16px;
text-shadow:0 0 40px rgba(61,159,255,.3)}
.fx-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fx-stat{background:var(--glass);border:1px solid var(--rim);border-radius:12px;padding:12px}
.fx-sl{font-size:8px;font-weight:600;letter-spacing:1.5px;color:var(--dim);text-transform:uppercase;margin-bottom:4px}
.fx-sv{font-family:var(--mono);font-size:14px;font-weight:500;color:var(--text)}
.fx-sv.inc{color:var(--green)}
.fx-sv.exp{color:var(--red)}

/* Op tabs */
.op-tabs{display:flex;gap:6px;padding:0 18px;margin-bottom:12px}
.op-tab{
  flex:1;padding:10px;
  background:var(--glass);border:1px solid var(--rim);border-radius:12px;
  color:var(--dim);font-family:var(--ui);font-size:13px;font-weight:600;
  cursor:pointer;transition:all .15s;
}
.op-tab.active{background:var(--glass2);border-color:var(--rim2);color:var(--bright)}

/* Form card */
.form-card{
  margin:0 18px;
  background:var(--glass);border:1px solid var(--rim);border-radius:16px;
  padding:16px;margin-bottom:6px;
}
.form-card.hidden{display:none}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.ff{display:flex;flex-direction:column;gap:5px;margin-bottom:10px}
.ff label{font-size:8px;font-weight:600;letter-spacing:1.5px;color:var(--dim);text-transform:uppercase}
.lbl-sub{color:var(--muted);font-weight:400;letter-spacing:0;text-transform:none;font-size:8px}
.ff input,.ff select{
  background:rgba(255,255,255,.04);border:1px solid var(--rim2);
  border-radius:9px;padding:11px 12px;
  color:var(--bright);font-family:var(--mono);font-size:13px;
  outline:none;transition:border-color .15s,box-shadow .15s;width:100%;
}
.ff input:focus{border-color:rgba(61,159,255,.5);box-shadow:0 0 0 3px rgba(61,159,255,.08)}
.ff select{appearance:none;font-family:var(--ui);color:var(--text)}
.calc-in{color:var(--mid) !important}
.f-btn{
  width:100%;padding:13px;border:none;border-radius:10px;
  font-family:var(--ui);font-size:13px;font-weight:700;letter-spacing:.3px;
  cursor:pointer;transition:opacity .15s,transform .1s;margin-top:4px;
}
.f-btn.buy{background:linear-gradient(135deg,var(--blue),#1a7de8);color:#fff;box-shadow:0 4px 20px rgba(61,159,255,.25)}
.f-btn.sell{background:linear-gradient(135deg,var(--gold),#e8960a);color:#000;box-shadow:0 4px 20px rgba(255,184,48,.25)}
.f-btn.save{background:linear-gradient(135deg,var(--green),#00c97a);color:#000;box-shadow:0 4px 20px rgba(0,245,160,.25)}
.f-btn:active{opacity:.85;transform:scale(.99)}

/* ══ SEARCH / HISTORY ══ */
.srch-wrap{position:relative;padding:0 18px;margin-bottom:10px}
.srch-wrap svg{position:absolute;left:30px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
#srch{
  width:100%;background:var(--glass);border:1px solid var(--rim);
  border-radius:12px;padding:11px 40px;
  color:var(--text);font-family:var(--ui);font-size:13px;
  outline:none;transition:border-color .15s;
}
#srch:focus{border-color:var(--rim2)}
#srch::placeholder{color:var(--muted)}
.srch-x{position:absolute;right:26px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--dim);font-size:16px;cursor:pointer;padding:4px}
.srch-x.hidden{display:none}

.chips{display:flex;gap:6px;padding:0 18px;margin-bottom:10px;flex-wrap:wrap}
.chip{
  padding:5px 13px;border-radius:20px;
  background:var(--glass);border:1px solid var(--rim);
  color:var(--dim);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;
}
.chip.on{background:var(--glass2);border-color:var(--rim2);color:var(--text)}

.hist-meta{display:flex;justify-content:space-between;padding:0 18px;margin-bottom:8px;font-size:10px;color:var(--dim)}
.hm-tot{font-family:var(--mono)}

/* ══ NAV ══ */
#nav{
  display:flex;background:rgba(6,8,13,.95);
  border-top:1px solid var(--rim);
  padding-bottom:env(safe-area-inset-bottom);
  flex-shrink:0;
  backdrop-filter:blur(20px);
  position:relative;
}
#nav::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,184,48,.2),transparent);
}
.nb{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:10px 4px;background:none;border:none;color:var(--muted);
  font-family:var(--ui);font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  cursor:pointer;transition:color .15s;
}
.nb svg{width:20px;height:20px;transition:filter .15s}
.nb.active{color:var(--gold)}
.nb.active svg{filter:drop-shadow(0 0 6px rgba(255,184,48,.5))}
.nb:active{opacity:.7}

/* ══ MODAL ══ */
.mbg{
  position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:100;
  backdrop-filter:blur(8px);transition:opacity .25s;
}
.mbg.hidden{opacity:0;pointer-events:none}
.modal{
  position:fixed;bottom:0;left:0;right:0;
  background:linear-gradient(180deg,#0f1320 0%,var(--ink) 100%);
  border-top:1px solid var(--rim2);
  border-radius:22px 22px 0 0;z-index:101;
  max-height:94vh;overflow-y:auto;
  transform:translateY(100%);
  transition:transform .32s cubic-bezier(.32,1,.46,1);
  padding-bottom:env(safe-area-inset-bottom);
}
.modal::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,184,48,.4),transparent);
}
.modal.open{transform:translateY(0)}
.modal.hidden{display:none}
.m-bar{width:36px;height:4px;background:var(--rim2);border-radius:2px;margin:12px auto 0}
.m-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 10px}
.m-ttl{font-family:var(--ui);font-size:18px;font-weight:800;color:var(--bright)}
.m-x{background:var(--glass2);border:1px solid var(--rim2);color:var(--mid);width:30px;height:30px;border-radius:9px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.type-tabs{display:flex;gap:8px;padding:0 20px 14px}
.tt{
  flex:1;padding:11px;background:var(--glass);border:1px solid var(--rim);
  border-radius:11px;color:var(--dim);font-family:var(--ui);font-size:13px;
  font-weight:700;cursor:pointer;transition:all .18s;
}
.tt.on{border-color:var(--gold);color:var(--bright);background:rgba(255,184,48,.07);
box-shadow:0 0 20px rgba(255,184,48,.1)}
.m-form{padding:0 20px 20px}
.m-form .ff input:focus{border-color:rgba(255,184,48,.5);box-shadow:0 0 0 3px rgba(255,184,48,.08)}
.m-form .ff select:focus{border-color:rgba(255,184,48,.5)}

/* ══ DEL MODAL ══ */
.delbg{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px}
.delbg.hidden{display:none}
.del-box{background:linear-gradient(135deg,#0f1320,var(--ink));border:1px solid var(--rim2);border-radius:18px;padding:26px;width:100%;max-width:300px;animation:popIn .2s ease}
@keyframes popIn{from{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}
.del-t{font-family:var(--ui);font-size:18px;font-weight:800;color:var(--bright);margin-bottom:8px}
.del-s{font-size:13px;color:var(--dim);margin-bottom:22px;line-height:1.6}
.del-btns{display:flex;gap:10px}
.del-no{flex:1;padding:12px;border-radius:10px;background:var(--glass);border:1px solid var(--rim2);color:var(--mid);font-family:var(--ui);font-size:13px;font-weight:700;cursor:pointer}
.del-yes{flex:1;padding:12px;border-radius:10px;background:linear-gradient(135deg,var(--red),#cc1a3a);border:none;color:#fff;font-family:var(--ui);font-size:13px;font-weight:700;cursor:pointer;box-shadow:0 4px 16px rgba(255,61,107,.25)}

/* ══ TOAST ══ */
.toast{
  position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(14px);
  background:var(--glass2);border:1px solid var(--rim2);
  border-radius:22px;padding:10px 20px;font-size:13px;font-weight:600;
  display:flex;align-items:center;gap:8px;
  opacity:0;pointer-events:none;transition:all .26s ease;
  white-space:nowrap;z-index:400;color:var(--bright);
  backdrop-filter:blur(20px);
  box-shadow:0 8px 32px rgba(0,0,0,.4);
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ══ UTIL ══ */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}
input[type=number]{-moz-appearance:textfield}
input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.3) sepia(1) saturate(0)}
