@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:wght@300;400;500;600&display=swap');

:root{
--g1:#0a0a0f;--g2:#0f0f1a;--g3:#13131f;--g4:#1a1a2e;
--acc:#c9a227;--acc2:#e8c547;--acc3:#f5d876;
--red:#e55353;--grn:#3dd68c;--blu:#4f8ef7;
--txt:#f0ede8;--txt2:#a8a5a0;--txt3:#6b6865;
--bdr:rgba(201,162,39,.15);--bdr2:rgba(201,162,39,.08);
--card:rgba(255,255,255,.03);--card2:rgba(255,255,255,.06);
--shd:0 8px 32px rgba(0,0,0,.4);
--r:14px;--r2:20px;--r3:8px;
--ff:'DM Sans',sans-serif;--fh:'Cormorant Garamond',serif;
--nav:64px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff);background:var(--g1);color:var(--txt);min-height:100vh;line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,select,textarea{font-family:var(--ff);border:none;outline:none}

/* Scrollbar */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--g2)}
::-webkit-scrollbar-thumb{background:var(--acc);border-radius:99px}

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

/* ─── NAV ─── */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav);z-index:999;background:rgba(10,10,15,.92);backdrop-filter:blur(20px);border-bottom:1px solid var(--bdr2);display:flex;align-items:center;padding:0 20px;gap:16px}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:var(--fh);font-size:1.4rem;font-weight:700;color:var(--acc)}
.nav-logo .ico{width:36px;height:36px;background:linear-gradient(135deg,var(--acc),var(--acc2));border-radius:8px;display:flex;align-items:center;justify-content:center;color:#000;font-size:.9rem}
.nav-links{display:none;gap:4px;margin-left:auto}
.nav-links a{padding:8px 14px;border-radius:var(--r3);color:var(--txt2);font-size:.85rem;font-weight:500;transition:.2s}
.nav-links a:hover,.nav-links a.act{color:var(--acc);background:rgba(201,162,39,.1)}
.nav-r{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav-links~.nav-r{margin-left:0}
.nav-ham{width:38px;height:38px;background:var(--card2);border:1px solid var(--bdr2);border-radius:var(--r3);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--txt2);font-size:1rem;transition:.2s}
.nav-ham:hover{color:var(--acc);border-color:var(--bdr)}
.mob-menu{position:fixed;inset:0;background:var(--g1);z-index:998;padding:80px 24px 24px;transform:translateX(-100%);transition:.3s cubic-bezier(.4,0,.2,1)}
.mob-menu.open{transform:none}
.mob-menu a{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--bdr2);color:var(--txt);font-size:1rem;font-weight:500}
.mob-menu a i{width:20px;color:var(--acc);text-align:center}

@media(min-width:768px){
.nav-links{display:flex}
.nav-ham{display:none}
}

/* ─── BTNS ─── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:var(--r3);font-size:.875rem;font-weight:600;cursor:pointer;transition:.2s;white-space:nowrap}
.btn-gold{background:linear-gradient(135deg,var(--acc),var(--acc2));color:#000}
.btn-gold:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(201,162,39,.4)}
.btn-out{border:1px solid var(--bdr);color:var(--txt);background:transparent}
.btn-out:hover{border-color:var(--acc);color:var(--acc)}
.btn-ghost{background:var(--card2);color:var(--txt2);border:1px solid var(--bdr2)}
.btn-ghost:hover{color:var(--txt);border-color:var(--bdr)}
.btn-sm{padding:7px 16px;font-size:.8rem}
.btn-lg{padding:14px 32px;font-size:1rem}
.btn-full{width:100%;justify-content:center}
.btn-red{background:#e55353;color:#fff}
.btn-red:hover{background:#c94545}
.btn-grn{background:#3dd68c;color:#000}

/* ─── LAYOUT ─── */
.pg{padding-top:var(--nav)}
.wrap{max-width:1200px;margin:0 auto;padding:0 20px}
.wrap-sm{max-width:760px;margin:0 auto;padding:0 20px}
.sec{padding:60px 0}
.sec-sm{padding:40px 0}
@media(min-width:768px){.sec{padding:80px 0}}

/* ─── CARDS ─── */
.card{background:var(--card);border:1px solid var(--bdr2);border-radius:var(--r);overflow:hidden}
.card:hover{border-color:var(--bdr);background:var(--card2)}
.card-body{padding:20px}

/* ─── BADGE ─── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:99px;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.badge-gold{background:rgba(201,162,39,.15);color:var(--acc)}
.badge-grn{background:rgba(61,214,140,.12);color:var(--grn)}
.badge-red{background:rgba(229,83,83,.12);color:var(--red)}
.badge-blu{background:rgba(79,142,247,.12);color:var(--blu)}

/* ─── HERO ─── */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(201,162,39,.12),transparent),radial-gradient(ellipse 60% 80% at 80% 100%,rgba(79,142,247,.08),transparent)}
.hero-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,39,.06),transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%)}
.hero-content{position:relative;z-index:1;text-align:center;padding:40px 0}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(201,162,39,.1);border:1px solid var(--bdr);border-radius:99px;padding:6px 16px;font-size:.78rem;font-weight:600;color:var(--acc);letter-spacing:.05em;text-transform:uppercase;margin-bottom:24px}
.hero-title{font-family:var(--fh);font-size:clamp(2.4rem,8vw,5rem);line-height:1.1;font-weight:700;margin-bottom:20px}
.hero-title em{color:var(--acc);font-style:italic}
.hero-sub{font-size:clamp(.95rem,2.5vw,1.15rem);color:var(--txt2);max-width:580px;margin:0 auto 36px;line-height:1.7}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.hero-stats{display:flex;flex-wrap:wrap;justify-content:center;gap:24px 40px;margin-top:56px;padding-top:40px;border-top:1px solid var(--bdr2)}
.hstat{text-align:center}
.hstat-n{font-family:var(--fh);font-size:2rem;font-weight:700;color:var(--acc)}
.hstat-l{font-size:.78rem;color:var(--txt3);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}

/* ─── SECTION HEADINGS ─── */
.sh{text-align:center;margin-bottom:48px}
.sh-tag{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--acc);margin-bottom:12px}
.sh-title{font-family:var(--fh);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;line-height:1.2}
.sh-sub{color:var(--txt2);margin-top:12px;font-size:.95rem;max-width:540px;margin-left:auto;margin-right:auto}

/* ─── GRID ─── */
.grid{display:grid;gap:20px}
.g2{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.g3{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
@media(min-width:640px){.g2-fix{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.g3-fix{grid-template-columns:repeat(3,1fr)}}

/* ─── QUIZ CARD ─── */
.qcard{background:var(--card);border:1px solid var(--bdr2);border-radius:var(--r);overflow:hidden;transition:.25s;cursor:pointer}
.qcard:hover{border-color:var(--bdr);transform:translateY(-2px);box-shadow:var(--shd)}
.qcard-top{padding:18px;border-bottom:1px solid var(--bdr2)}
.qcard-cat{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--acc);margin-bottom:8px}
.qcard-title{font-family:var(--fh);font-size:1.1rem;font-weight:600;line-height:1.35;margin-bottom:10px}
.qcard-meta{display:flex;flex-wrap:wrap;gap:10px}
.qcard-meta span{display:flex;align-items:center;gap:5px;font-size:.75rem;color:var(--txt3)}
.qcard-meta i{font-size:.7rem;color:var(--acc)}
.qcard-bot{padding:14px 18px;display:flex;align-items:center;justify-content:space-between}
.qcard-price{font-family:var(--fh);font-size:1.1rem;font-weight:700;color:var(--acc)}
.qcard-free{font-size:.8rem;font-weight:600;color:var(--grn)}

/* ─── BATCH CARD ─── */
.bcard{background:var(--card);border:1px solid var(--bdr2);border-radius:var(--r2);overflow:hidden;transition:.25s}
.bcard:hover{border-color:var(--bdr);box-shadow:var(--shd)}
.bcard-img{height:160px;background:linear-gradient(135deg,var(--g4),var(--g3));display:flex;align-items:center;justify-content:center;font-size:3rem;position:relative;overflow:hidden}
.bcard-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(10,10,15,.8))}
.bcard-body{padding:18px}
.bcard-title{font-family:var(--fh);font-size:1.2rem;font-weight:600;margin-bottom:8px}
.bcard-desc{font-size:.82rem;color:var(--txt2);line-height:1.5;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.bcard-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.bcard-tag{padding:3px 10px;background:rgba(201,162,39,.08);border:1px solid var(--bdr2);border-radius:99px;font-size:.7rem;color:var(--acc)}
.bcard-bot{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--bdr2)}
.bcard-price{font-family:var(--fh);font-size:1.3rem;font-weight:700;color:var(--acc)}
.bcard-strike{text-decoration:line-through;font-size:.8rem;color:var(--txt3);margin-left:6px;font-family:var(--ff);font-weight:400}

/* ─── FORM ─── */
.form-grp{margin-bottom:18px}
.form-lbl{display:block;font-size:.78rem;font-weight:600;color:var(--txt2);margin-bottom:7px;letter-spacing:.03em}
.form-inp{width:100%;padding:12px 16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r3);color:var(--txt);font-size:.9rem;transition:.2s}
.form-inp:focus{border-color:var(--acc);background:rgba(201,162,39,.05)}
.form-inp::placeholder{color:var(--txt3)}
.form-inp.err{border-color:var(--red)}
.form-err{font-size:.75rem;color:var(--red);margin-top:5px}
.form-hint{font-size:.73rem;color:var(--txt3);margin-top:5px}
textarea.form-inp{resize:vertical;min-height:100px}
select.form-inp option{background:var(--g2)}

/* ─── ALERT ─── */
.alert{padding:12px 16px;border-radius:var(--r3);font-size:.85rem;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px}
.alert-err{background:rgba(229,83,83,.1);border:1px solid rgba(229,83,83,.25);color:#f87171}
.alert-ok{background:rgba(61,214,140,.1);border:1px solid rgba(61,214,140,.25);color:#4ade80}
.alert-info{background:rgba(79,142,247,.1);border:1px solid rgba(79,142,247,.25);color:#93c5fd}
.alert-warn{background:rgba(201,162,39,.1);border:1px solid rgba(201,162,39,.25);color:var(--acc)}

/* ─── AUTH PAGES ─── */
.auth-wrap{min-height:100svh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(ellipse 80% 80% at 50% -20%,rgba(201,162,39,.1),transparent)}
.auth-box{width:100%;max-width:420px;background:var(--g3);border:1px solid var(--bdr2);border-radius:var(--r2);padding:36px 28px}
.auth-logo{text-align:center;margin-bottom:28px}
.auth-logo .lg-ico{width:52px;height:52px;background:linear-gradient(135deg,var(--acc),var(--acc2));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#000;margin:0 auto 12px}
.auth-logo h1{font-family:var(--fh);font-size:1.5rem;font-weight:700}
.auth-logo p{font-size:.82rem;color:var(--txt2);margin-top:4px}
.auth-div{text-align:center;font-size:.82rem;color:var(--txt3);margin-top:20px}
.auth-div a{color:var(--acc)}

/* ─── DASHBOARD ─── */
.stat-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:28px}
@media(min-width:640px){.stat-cards{grid-template-columns:repeat(4,1fr)}}
.stat-c{background:var(--card);border:1px solid var(--bdr2);border-radius:var(--r);padding:18px}
.stat-c-ico{width:36px;height:36px;background:rgba(201,162,39,.1);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--acc);font-size:.9rem;margin-bottom:10px}
.stat-c-n{font-family:var(--fh);font-size:1.6rem;font-weight:700}
.stat-c-l{font-size:.72rem;color:var(--txt3);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}

/* ─── ATTEMPT / EXAM INTERFACE ─── */
.exam-wrap{display:flex;flex-direction:column;min-height:100svh;padding-top:var(--nav);background:var(--g1)}
.exam-header{position:fixed;top:var(--nav);left:0;right:0;height:56px;background:var(--g2);border-bottom:1px solid var(--bdr2);display:flex;align-items:center;padding:0 16px;gap:12px;z-index:99}
.exam-header-title{font-family:var(--fh);font-size:1rem;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.exam-timer{display:flex;align-items:center;gap:6px;background:var(--g3);border:1px solid var(--bdr2);border-radius:var(--r3);padding:6px 12px;font-size:.85rem;font-weight:600;font-variant-numeric:tabular-nums}
.exam-timer.warn{border-color:rgba(201,162,39,.4);color:var(--acc)}
.exam-timer.danger{border-color:rgba(229,83,83,.4);color:var(--red);animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}
.exam-body{margin-top:56px;display:flex;flex:1}
.exam-sidebar{width:280px;background:var(--g2);border-right:1px solid var(--bdr2);height:calc(100svh - var(--nav) - 56px);overflow-y:auto;padding:16px;position:sticky;top:calc(var(--nav)+56px);display:none;flex-direction:column;gap:12px}
@media(min-width:900px){.exam-sidebar{display:flex}}
.qnum-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
.qn-btn{aspect-ratio:1;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;background:var(--g3);border:1px solid var(--bdr2);color:var(--txt2);transition:.15s}
.qn-btn:hover{border-color:var(--acc);color:var(--acc)}
.qn-btn.ans{background:rgba(61,214,140,.15);border-color:rgba(61,214,140,.4);color:var(--grn)}
.qn-btn.mrk{background:rgba(201,162,39,.15);border-color:var(--bdr);color:var(--acc)}
.qn-btn.cur{border-color:var(--blu);color:var(--blu)}
.exam-main{flex:1;overflow-y:auto;padding:24px 16px;max-width:800px;margin:0 auto;width:100%}
.q-card{background:var(--g2);border:1px solid var(--bdr2);border-radius:var(--r);padding:24px;margin-bottom:20px}
.q-no{font-size:.75rem;font-weight:600;color:var(--txt3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}
.q-text{font-size:1rem;line-height:1.7;margin-bottom:20px}
.opts{display:flex;flex-direction:column;gap:10px}
.opt{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-radius:var(--r3);border:1px solid var(--bdr2);background:rgba(255,255,255,.02);cursor:pointer;transition:.2s}
.opt:hover{border-color:rgba(201,162,39,.3);background:rgba(201,162,39,.05)}
.opt.sel{border-color:var(--acc);background:rgba(201,162,39,.1)}
.opt.corr{border-color:var(--grn);background:rgba(61,214,140,.1)}
.opt.wrong{border-color:var(--red);background:rgba(229,83,83,.08)}
.opt-key{width:28px;height:28px;min-width:28px;border-radius:6px;background:var(--g3);border:1px solid var(--bdr2);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;transition:.2s}
.opt.sel .opt-key{background:var(--acc);border-color:var(--acc);color:#000}
.opt.corr .opt-key{background:var(--grn);border-color:var(--grn);color:#000}
.opt.wrong .opt-key{background:var(--red);border-color:var(--red);color:#fff}
.opt-txt{flex:1;font-size:.9rem;line-height:1.55;padding-top:3px}
.q-actions{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}
.q-nav{position:fixed;bottom:0;left:0;right:0;background:var(--g2);border-top:1px solid var(--bdr2);padding:10px 16px;display:flex;gap:10px;z-index:99}
@media(min-width:900px){.q-nav{left:280px}}

/* ─── RESULT ─── */
.result-hero{text-align:center;padding:48px 24px 32px}
.result-ring{width:140px;height:140px;margin:0 auto 20px;position:relative}
.result-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.result-ring .bg-c{fill:none;stroke:var(--g4);stroke-width:10}
.result-ring .fg-c{fill:none;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset 1.2s cubic-bezier(.4,0,.2,1)}
.result-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:1.8rem;font-weight:700}
.result-grade{display:inline-block;padding:4px 18px;border-radius:99px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-top:10px}
.result-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:24px 0}
@media(min-width:540px){.result-stats{grid-template-columns:repeat(4,1fr)}}
.rs{background:var(--g3);border:1px solid var(--bdr2);border-radius:var(--r);padding:16px;text-align:center}
.rs-n{font-family:var(--fh);font-size:1.6rem;font-weight:700;margin-bottom:4px}
.rs-l{font-size:.72rem;color:var(--txt3);text-transform:uppercase;letter-spacing:.05em}

/* ─── PROFILE ─── */
.profile-hero{background:linear-gradient(135deg,var(--g3),var(--g4));border-bottom:1px solid var(--bdr2);padding:40px 20px 32px;text-align:center}
.p-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--acc),var(--acc2));display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:2rem;font-weight:700;color:#000;margin:0 auto 16px;border:3px solid var(--acc)}
.p-name{font-family:var(--fh);font-size:1.6rem;font-weight:700}
.p-role{display:inline-block;padding:3px 12px;background:rgba(201,162,39,.12);border:1px solid var(--bdr);border-radius:99px;font-size:.72rem;color:var(--acc);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-top:6px}

/* ─── TABS ─── */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--bdr2);margin-bottom:24px;overflow-x:auto;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{padding:10px 18px;font-size:.85rem;font-weight:600;color:var(--txt3);cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1px;transition:.2s}
.tab.act{color:var(--acc);border-bottom-color:var(--acc)}
.tab-pane{display:none}.tab-pane.act{display:block}

/* ─── OFFER ─── */
.offer-hero{background:linear-gradient(135deg,rgba(201,162,39,.15),rgba(201,162,39,.05));border:1px solid var(--bdr);border-radius:var(--r2);padding:32px;text-align:center;margin-bottom:32px;position:relative;overflow:hidden}
.offer-hero::before{content:'';position:absolute;top:-30px;right:-30px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,39,.2),transparent 70%)}
.offer-timer{display:flex;gap:12px;justify-content:center;margin:20px 0}
.ot-unit{text-align:center;background:var(--g3);border:1px solid var(--bdr2);border-radius:var(--r3);padding:10px 16px;min-width:64px}
.ot-n{font-family:var(--fh);font-size:1.8rem;font-weight:700;color:var(--acc)}
.ot-l{font-size:.65rem;color:var(--txt3);text-transform:uppercase;letter-spacing:.06em}

/* ─── FOOTER ─── */
.footer{background:var(--g2);border-top:1px solid var(--bdr2);padding:48px 0 28px}
.footer-grid{display:grid;gap:32px;margin-bottom:40px}
@media(min-width:640px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr}}
.footer-brand p{font-size:.85rem;color:var(--txt3);line-height:1.7;margin-top:12px;max-width:280px}
.footer-col h4{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--txt2);margin-bottom:14px}
.footer-col a{display:block;font-size:.85rem;color:var(--txt3);margin-bottom:8px;transition:.15s}
.footer-col a:hover{color:var(--acc)}
.footer-bot{border-top:1px solid var(--bdr2);padding-top:24px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--txt3)}
.footer-bot a{color:var(--txt3)}.footer-bot a:hover{color:var(--acc)}
.devggn-brand{font-size:.72rem;color:var(--txt3)}
.devggn-brand a{color:var(--acc);font-weight:600}

/* ─── TOAST ─── */
.toasts{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--g3);border:1px solid var(--bdr2);border-radius:var(--r3);padding:12px 16px;font-size:.82rem;display:flex;align-items:center;gap:10px;max-width:300px;animation:slideIn .3s ease;box-shadow:var(--shd)}
.toast.ok{border-color:rgba(61,214,140,.3);color:var(--grn)}
.toast.err{border-color:rgba(229,83,83,.3);color:#f87171}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:none;opacity:1}}

/* ─── LOADER ─── */
.loader{display:flex;align-items:center;justify-content:center;padding:60px;flex-direction:column;gap:14px;color:var(--txt3);font-size:.85rem}
.spin{width:32px;height:32px;border:3px solid var(--bdr2);border-top-color:var(--acc);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─── UTILS ─── */
.hide{display:none!important}
.txt-c{text-align:center}
.txt-acc{color:var(--acc)}
.txt-grn{color:var(--grn)}
.txt-red{color:var(--red)}
.txt-muted{color:var(--txt2)}
.fw6{font-weight:600}.fw7{font-weight:700}
.fh{font-family:var(--fh)}
.mt4{margin-top:4px}.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}.mt24{margin-top:24px}.mt32{margin-top:32px}
.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}.mb20{margin-bottom:20px}.mb24{margin-bottom:24px}
.flex{display:flex}.gap8{gap:8px}.gap12{gap:12px}.gap16{gap:16px}.ai-c{align-items:center}.jc-sb{justify-content:space-between}.fw{flex-wrap:wrap}
.separator{height:1px;background:var(--bdr2);margin:24px 0}
.empty-state{text-align:center;padding:60px 20px;color:var(--txt3)}
.empty-state i{font-size:2.5rem;margin-bottom:16px;color:var(--bdr)}
.empty-state h3{font-family:var(--fh);font-size:1.3rem;color:var(--txt2);margin-bottom:8px}
