/* ============================ КАДР — стили ============================== */
:root{
  --bg:#08080a; --bg2:#101016; --panel:rgba(20,20,25,.82); --panel2:#16161b;
  --text:#f3f2f6; --muted:#8a8a93; --muted2:#6a6a73;
  --line:rgba(255,255,255,.08); --line2:rgba(255,255,255,.1);
  --accent:#7c5cff; --accent2:#5e40d8; --accent-soft:rgba(124,92,255,.16);
  --accent-text:#b9a6ff; --good:#6dd1a3; --bad:#ff8a8a;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:'Manrope',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:rgba(124,92,255,.32);color:#fff}
textarea{font-family:inherit}
button{font-family:inherit}
a{color:inherit}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:9px}
::-webkit-scrollbar-track{background:transparent}

@keyframes auroraA{0%,100%{transform:translate(-8%,-6%) scale(1)}50%{transform:translate(10%,8%) scale(1.25)}}
@keyframes auroraB{0%,100%{transform:translate(12%,10%) scale(1.1)}50%{transform:translate(-6%,-8%) scale(.92)}}
@keyframes orbPulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.08);opacity:.92}}
@keyframes ring{0%{transform:scale(.6);opacity:.5}100%{transform:scale(1.9);opacity:0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes scanSweep{0%{transform:translateY(-30%);opacity:0}12%{opacity:1}88%{opacity:1}100%{transform:translateY(560%);opacity:0}}
@keyframes resultIn{from{opacity:0;filter:blur(14px);transform:scale(1.04)}to{opacity:1;filter:blur(0);transform:scale(1)}}

/* --------------------------------- layout ----------------------------- */
.app{position:relative;height:100vh;min-height:560px;display:flex;flex-direction:column;
  background:radial-gradient(140% 100% at 50% -10%,#101016 0%,#08080a 58%);overflow:hidden}
.topbar{position:relative;z-index:30;flex:none;height:64px;display:flex;align-items:center;
  justify-content:space-between;padding:0 clamp(14px,3vw,28px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:11px}
.brand .logo{width:30px;height:30px;border-radius:9px;background:linear-gradient(150deg,#7c5cff,#5a3fd6);
  display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(124,92,255,.45)}
.brand .logo i{width:11px;height:11px;border-radius:3px;background:#0a0a0c;display:block}
.brand .name{font-weight:800;font-size:18px;letter-spacing:.16em}
.top-right{display:flex;align-items:center;gap:clamp(8px,2vw,16px)}
.balance-pill{display:flex;align-items:center;gap:10px;padding:7px 8px 7px 14px;border:1px solid var(--line2);
  border-radius:999px;background:rgba(255,255,255,.03)}
.balance-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}
.balance-pill .val{font-family:var(--mono);font-size:14px;font-weight:600;white-space:nowrap}
.balance-pill .unit{font-size:12px;color:var(--muted);margin-left:-3px}
.balance-pill .plus{width:26px;height:26px;border:none;border-radius:50%;background:var(--accent-soft);
  color:var(--accent-text);font-size:17px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.balance-pill .plus:hover{background:rgba(124,92,255,.3)}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(140deg,#2a2a32,#15151a);
  border:1px solid var(--line2);display:flex;align-items:center;justify-content:center;font-size:12px;
  font-weight:700;color:#cfcdd6;cursor:pointer}

.body{position:relative;z-index:20;flex:1;min-height:0;display:flex}
.rail{flex:none;width:84px;padding:18px 0;display:flex;flex-direction:column;align-items:center;gap:6px;
  border-right:1px solid var(--line)}
.rail button,.bottomnav button{display:flex;flex-direction:column;align-items:center;gap:5px;border:none;
  cursor:pointer;background:transparent;color:#85858e}
.rail button{width:64px;padding:11px 0;border-radius:13px;font-size:10.5px;font-weight:600}
.rail button:hover{background:rgba(255,255,255,.05)}
.rail button.active{background:var(--accent-soft);color:#c8b8ff}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.screen{flex:1;min-height:0;display:flex;flex-direction:column}
.screen.hidden{display:none}

.bottomnav{position:relative;z-index:30;flex:none;display:none;border-top:1px solid var(--line);
  background:rgba(12,12,15,.9)}
.bottomnav button{flex:1;padding:10px 0 12px;font-size:10px}
.bottomnav button.active{color:#b9a6ff}

@media(max-width:880px){
  .rail{display:none}
  .bottomnav{display:flex}
}

/* ------------------------------- generate ----------------------------- */
.canvas{position:relative;flex:1;min-height:0;overflow:hidden;display:flex;align-items:center;
  justify-content:center;padding:clamp(16px,4vw,48px)}
.aurora{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.aurora .a{position:absolute;top:8%;left:18%;width:46vw;height:46vw;max-width:620px;max-height:620px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,92,255,.34),rgba(124,92,255,0) 62%);filter:blur(28px);animation:auroraA 18s ease-in-out infinite}
.aurora .b{position:absolute;bottom:2%;right:14%;width:40vw;height:40vw;max-width:540px;max-height:540px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,92,255,.16),rgba(124,92,255,0) 64%);filter:blur(34px);animation:auroraB 22s ease-in-out infinite}

.idle{position:relative;text-align:center;max-width:620px;animation:fadeUp .5s ease both}
.orb-wrap{position:relative;width:118px;height:118px;margin:0 auto 30px}
.orb{position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 38% 32%,#a690ff,#6a48e0 55%,#3d2a8a);
  box-shadow:0 0 60px rgba(124,92,255,.5),inset 0 0 28px rgba(255,255,255,.18);animation:orbPulse 4.5s ease-in-out infinite}
.orb-ring{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(124,92,255,.4);animation:ring 4.5s ease-out infinite}
.idle h1{margin:0 0 12px;font-size:clamp(26px,4.4vw,40px);font-weight:800;letter-spacing:-.02em;line-height:1.05}
.idle p{margin:0 auto;max-width:440px;font-size:clamp(14px,2vw,16px);line-height:1.5;color:#8f8f99}
.idle p b{color:#cfcdd6;font-weight:600}
.chips{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;margin-top:26px}
.chips button{padding:9px 15px;border:1px solid var(--line2);border-radius:999px;background:rgba(255,255,255,.03);
  color:#c9c8d2;font-size:12.5px;font-weight:500;cursor:pointer;text-align:left;line-height:1.3}
.chips button:hover{border-color:rgba(124,92,255,.5);color:#fff}

.stage{position:relative;display:flex;flex-direction:column;align-items:center;gap:18px;animation:fadeUp .4s ease both;max-width:100%}
.frame{position:relative;border-radius:16px;overflow:hidden;border:1px solid rgba(124,92,255,.25);
  box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 50px rgba(124,92,255,.18);background:#0d0d11;
  height:min(50vh,440px);max-width:min(82vw,780px);display:flex;align-items:center;justify-content:center}
.frame.done{border-color:rgba(255,255,255,.1);box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 0 1px rgba(124,92,255,.12)}
.frame .latent{position:absolute;inset:-25%;background:
  radial-gradient(38% 38% at 28% 32%,rgba(124,92,255,.55),transparent 68%),
  radial-gradient(34% 34% at 72% 68%,rgba(110,80,230,.42),transparent 70%);animation:auroraA 6.5s ease-in-out infinite}
.frame .scan{position:absolute;left:0;right:0;top:0;height:18%;pointer-events:none;
  background:linear-gradient(180deg,rgba(124,92,255,0),rgba(167,140,255,.45) 70%,rgba(255,255,255,.9));
  mix-blend-mode:screen;animation:scanSweep 1.9s cubic-bezier(.6,0,.3,1) infinite}
.frame .vignette{position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 90px rgba(0,0,0,.55)}
.frame img,.frame video{width:100%;height:100%;object-fit:cover;display:block;animation:resultIn .7s ease both}
.status-chip{position:absolute;left:13px;top:12px;display:flex;align-items:center;gap:8px;padding:6px 11px;
  border-radius:999px;background:rgba(8,8,10,.55);border:1px solid var(--line2)}
.status-chip .sp{width:14px;height:14px;border-radius:50%;border:2px solid rgba(124,92,255,.25);
  border-top-color:#a48cff;animation:spin .8s linear infinite}
.status-chip span{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:#c8b8ff;text-transform:uppercase}
.progress-wrap{position:absolute;left:13px;right:13px;bottom:12px}
.progress-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.progress-row .lbl{font-family:var(--mono);font-size:11px;color:#d8d6e0}
.progress-row .pct{font-family:var(--mono);font-size:15px;font-weight:600;color:#fff}
.progress-bar{height:4px;border-radius:99px;background:rgba(255,255,255,.18);overflow:hidden}
.progress-bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,#7c5cff,#b6a4ff);
  box-shadow:0 0 12px rgba(124,92,255,.8);transition:width .25s ease;width:0}
.meta-chip{position:absolute;left:14px;bottom:13px;font-family:var(--mono);font-size:11px;color:#b7b6c0;
  background:rgba(8,8,10,.5);padding:4px 9px;border-radius:6px}
.hint{font-size:12.5px;color:var(--muted2)}
.result-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}
.result-actions .cost{font-family:var(--mono);font-size:13px;color:var(--muted)}
.result-actions .cost b{color:var(--text)}
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:999px;font-size:13px;
  font-weight:600;cursor:pointer;border:1px solid var(--line2);background:rgba(255,255,255,.04);color:#e7e6ec}
.btn:hover{border-color:rgba(255,255,255,.3)}
.btn.primary{background:#f3f2f6;color:#0a0a0c;border:none;font-weight:700}
.btn.primary:hover{background:#fff}
.btn.ghost{background:transparent;color:#9a9aa3}
.btn.ghost:hover{color:#fff}

/* ------------------------------- composer ----------------------------- */
.composer-wrap{position:relative;z-index:25;flex:none;padding:0 clamp(12px,3vw,28px) clamp(14px,3vw,24px)}
.composer{position:relative;max-width:940px;margin:0 auto;border:1px solid var(--line2);border-radius:20px;
  background:var(--panel);backdrop-filter:blur(20px);box-shadow:0 24px 70px rgba(0,0,0,.5)}
.controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px 14px;border-bottom:1px solid var(--line)}
.toggle{display:flex;padding:3px;border-radius:11px;background:rgba(0,0,0,.3);border:1px solid var(--line)}
.toggle button{display:flex;align-items:center;gap:6px;padding:7px 14px;border:none;border-radius:8px;font-size:13px;
  font-weight:600;cursor:pointer;background:transparent;color:#9a9aa3}
.toggle button.active{background:rgba(124,92,255,.9);color:#fff;box-shadow:0 2px 10px rgba(124,92,255,.4)}
.dd{position:relative}
.model-btn{display:flex;align-items:center;gap:9px;padding:8px 13px;border:1px solid var(--line2);border-radius:11px;
  background:rgba(255,255,255,.03);color:#e7e6ec;font-size:13px;font-weight:600;cursor:pointer}
.model-btn:hover{border-color:rgba(255,255,255,.2)}
.tag{font-family:var(--mono);font-size:10px;padding:2px 6px;border-radius:5px;background:var(--accent-soft);color:var(--accent-text)}
.chip{display:flex;align-items:center;gap:5px;padding:7px 11px;border:1px solid var(--line2);border-radius:9px;
  background:rgba(255,255,255,.03);color:#cfcdd6;font-family:var(--mono);font-size:12px;font-weight:500;cursor:pointer}
.chip:hover{border-color:rgba(255,255,255,.2)}
.params{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-left:auto}
.menu{position:absolute;bottom:calc(100% + 8px);left:0;min-width:110px;padding:5px;border:1px solid rgba(255,255,255,.12);
  border-radius:11px;background:var(--panel2);box-shadow:0 16px 40px rgba(0,0,0,.6);z-index:40;display:none}
.menu.open{display:block}
.menu.wide{width:300px;max-height:330px;overflow-y:auto;padding:6px;border-radius:14px}
.menu button{display:block;width:100%;text-align:left;padding:8px 11px;border:none;border-radius:7px;cursor:pointer;
  font-family:var(--mono);font-size:12.5px;background:transparent;color:#cfcdd6}
.menu button:hover{background:rgba(255,255,255,.05)}
.menu button.active{background:var(--accent-soft);color:#c8b8ff}
.menu .m-row{display:block;width:100%;text-align:left;padding:10px 11px;border:none;border-radius:9px;cursor:pointer;
  background:transparent;font-family:inherit}
.menu .m-row:hover{background:rgba(255,255,255,.05)}
.menu .m-row.active{background:rgba(124,92,255,.12)}
.menu .m-row .m-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.menu .m-row .m-name{font-size:13.5px;font-weight:600;color:var(--text)}
.menu .m-row .m-desc{font-size:11.5px;color:var(--muted);margin-top:3px}
.attachments{display:flex;gap:8px;padding:10px 14px 0;overflow-x:auto}
.att{position:relative;flex:none;width:46px;height:46px;border-radius:9px;overflow:hidden;border:1px solid var(--line2);
  background-size:cover;background-position:center;background-color:#1a1a20;display:flex;align-items:center;justify-content:center}
.att .rm{position:absolute;top:2px;right:2px;width:16px;height:16px;border:none;border-radius:50%;
  background:rgba(8,8,10,.8);color:#fff;font-size:11px;line-height:1;cursor:pointer}
.input-row{display:flex;align-items:flex-end;gap:10px;padding:12px 14px}
.icon-btn{flex:none;width:40px;height:40px;border:1px solid var(--line2);border-radius:11px;background:rgba(255,255,255,.03);
  color:#b6b5bf;cursor:pointer;display:flex;align-items:center;justify-content:center}
.icon-btn:hover{border-color:rgba(255,255,255,.24);color:#fff}
.input-row textarea{flex:1;min-height:40px;max-height:120px;resize:none;padding:10px 12px;border:1px solid var(--line2);
  border-radius:11px;background:rgba(0,0,0,.25);color:var(--text);font-size:14.5px;line-height:1.4;outline:none}
.input-row textarea:focus{border-color:rgba(124,92,255,.5)}
.send-col{flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.cost-est{font-family:var(--mono);font-size:11.5px;color:var(--muted);white-space:nowrap}
.cost-est.bad{color:var(--bad)}
.gen-btn{display:flex;align-items:center;gap:7px;height:40px;padding:0 18px;border:none;border-radius:11px;font-size:14px;
  font-weight:700;cursor:pointer;color:#fff;background:linear-gradient(135deg,#7c5cff,#5e40d8);
  box-shadow:0 6px 20px rgba(124,92,255,.45);white-space:nowrap}
.gen-btn:disabled{background:rgba(255,255,255,.07);box-shadow:none;opacity:.55;cursor:not-allowed}
.topup-btn{height:40px;padding:0 18px;border:1px solid rgba(124,92,255,.5);border-radius:11px;background:rgba(124,92,255,.12);
  color:#c8b8ff;font-size:13.5px;font-weight:700;cursor:pointer;white-space:nowrap}
.legal{text-align:center;margin-top:9px;font-size:11px;color:#54545c}
.legal a{color:#7d7d86;text-decoration:underline;cursor:pointer}

/* -------------------------------- pages ------------------------------- */
.page{flex:1;min-height:0;overflow-y:auto;padding:clamp(20px,4vw,40px) clamp(16px,4vw,40px) 80px}
.page-inner{max-width:1040px;margin:0 auto}
.page-inner.narrow{max-width:760px}
.page-inner.narrow2{max-width:680px}
h1.page-title{margin:0 0 22px;font-size:clamp(24px,4vw,32px);font-weight:800;letter-spacing:-.02em}
.hist-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:22px}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.filters button{padding:8px 16px;border-radius:999px;border:1px solid var(--line2);background:rgba(255,255,255,.03);
  color:#9a9aa3;font-size:13px;font-weight:600;cursor:pointer}
.filters button.active{border-color:rgba(124,92,255,.5);background:var(--accent-soft);color:#c8b8ff}
.hist-day{font-size:13px;font-weight:600;color:#76767f;margin:0 0 13px}
.hist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;margin-bottom:30px}
.hcard{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#0d0d11}
.hcard .thumb{position:relative;aspect-ratio:4/3;overflow:hidden;background:#15151a;display:flex;align-items:center;justify-content:center}
.hcard .thumb img,.hcard .thumb video{width:100%;height:100%;object-fit:cover}
.hcard .badge{position:absolute;top:9px;left:9px;padding:4px 9px;border-radius:999px;background:rgba(8,8,10,.6);
  border:1px solid var(--line2);font-size:10.5px;font-weight:700;letter-spacing:.04em;color:#e7e6ec}
.hcard .st{position:absolute;bottom:9px;right:10px;font-family:var(--mono);font-size:11px;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.6)}
.hcard .info{padding:11px 13px 13px}
.hcard .info .m{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hcard .info .row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:5px}
.hcard .info .meta{font-family:var(--mono);font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hcard .info .cost{font-family:var(--mono);font-size:11.5px;color:var(--accent-text)}
.empty{text-align:center;padding:70px 20px;color:var(--muted2)}
.empty .t{font-size:15px;font-weight:600;color:#9a9aa3}

/* wallet */
.balance-hero{position:relative;overflow:hidden;border-radius:20px;padding:clamp(22px,4vw,30px);
  border:1px solid rgba(124,92,255,.28);background:linear-gradient(135deg,rgba(124,92,255,.18),rgba(124,92,255,.04))}
.balance-hero .glow{position:absolute;top:-40%;right:-10%;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,92,255,.34),transparent 65%);filter:blur(20px);pointer-events:none}
.balance-hero .lbl{font-size:13px;color:var(--accent-text);font-weight:600}
.balance-hero .big{font-family:var(--mono);font-size:clamp(38px,8vw,52px);font-weight:600;line-height:1;color:#fff}
.section-title{font-size:15px;font-weight:700;margin:28px 0 14px}
.packs{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:13px}
.pack{position:relative;display:flex;flex-direction:column;gap:14px;padding:18px;border-radius:16px;
  border:1px solid var(--line2);background:rgba(255,255,255,.02);cursor:pointer}
.pack:hover{border-color:rgba(124,92,255,.55)}
.pack.popular{border-color:rgba(124,92,255,.45);background:rgba(124,92,255,.08)}
.pack .star{position:absolute;top:-9px;left:18px;padding:3px 9px;border-radius:999px;background:#7c5cff;color:#fff;
  font-size:10px;font-weight:700;letter-spacing:.04em}
.pack .tk{font-family:var(--mono);font-size:26px;font-weight:600;color:#fff}
.pack .tk small{font-family:'Manrope';font-size:13px;color:var(--muted);font-weight:500}
.pack .price{display:flex;align-items:center;justify-content:center;height:40px;border-radius:11px;
  background:rgba(255,255,255,.05);border:1px solid var(--line2);font-size:14px;font-weight:700}
.custom-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-top:14px}
.field{flex:1;min-width:160px}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}
.field input{width:100%;height:44px;padding:0 14px;border:1px solid var(--line2);border-radius:11px;
  background:rgba(0,0,0,.25);color:var(--text);font-size:15px;font-family:var(--mono);outline:none}
.field input:focus{border-color:rgba(124,92,255,.5)}
.tx{border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.02);overflow:hidden}
.tx .row{display:flex;align-items:center;gap:13px;padding:14px 16px;border-bottom:1px solid var(--line)}
.tx .row:last-child{border-bottom:none}
.tx .ic{flex:none;width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.05);color:#cfcdd6}
.tx .lbl{flex:1;min-width:0}
.tx .lbl .t{font-size:13.5px;font-weight:600;color:#e7e6ec;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tx .lbl .w{font-size:11.5px;color:#76767f;margin-top:2px}
.tx .amt{font-family:var(--mono);font-size:14px;font-weight:600;white-space:nowrap}
.amt.pos{color:var(--good)}.amt.neg{color:#cfcdd6}

/* profile */
.identity{display:flex;align-items:center;gap:16px;padding:20px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.02)}
.identity .av{flex:none;width:64px;height:64px;border-radius:50%;background:linear-gradient(140deg,#7c5cff,#3d2a8a);
  display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;box-shadow:0 8px 24px rgba(124,92,255,.4)}
.identity .nm{font-size:18px;font-weight:700}
.identity .em{font-size:13px;color:var(--muted);margin-top:4px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}
.stat{padding:16px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.02);text-align:center}
.stat .n{font-family:var(--mono);font-size:24px;font-weight:600;color:#fff}
.stat .l{font-size:11.5px;color:var(--muted);margin-top:4px}
.settings{margin-top:24px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.02);overflow:hidden}
.settings .item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line);font-size:14px;color:#e7e6ec}
.settings .item:last-child{border-bottom:none}
.logout{width:100%;margin-top:16px;padding:14px;border-radius:13px;border:1px solid rgba(255,120,120,.25);
  background:rgba(255,120,120,.06);color:#ff9a9a;font-size:14px;font-weight:600;cursor:pointer}
.logout:hover{background:rgba(255,120,120,.12)}

/* modal */
.modal{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:clamp(14px,4vw,28px)}
.modal.hidden{display:none}
.modal .scrim{position:absolute;inset:0;background:rgba(4,4,6,.7);backdrop-filter:blur(6px)}
.modal .box{position:relative;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;border-radius:22px;
  border:1px solid var(--line2);background:#121217;box-shadow:0 30px 80px rgba(0,0,0,.6);
  padding:22px clamp(18px,4vw,26px);animation:fadeUp .3s ease both}
.modal h2{font-size:18px;font-weight:800;margin:0}
.modal .x{width:32px;height:32px;border:1px solid var(--line2);border-radius:50%;background:transparent;color:#9a9aa3;
  font-size:18px;cursor:pointer}
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:90;padding:12px 18px;border-radius:12px;
  background:#16161b;border:1px solid var(--line2);color:#e7e6ec;font-size:13.5px;box-shadow:0 12px 40px rgba(0,0,0,.5);
  display:none}
.toast.show{display:block;animation:fadeUp .25s ease both}

/* ------------------------------- auth --------------------------------- */
.auth{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(140% 100% at 50% -10%,#101016 0%,#08080a 58%)}
.auth-card{width:100%;max-width:400px;border:1px solid var(--line2);border-radius:22px;background:var(--panel);
  backdrop-filter:blur(20px);padding:30px 28px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.auth-card .brand{justify-content:center;margin-bottom:22px}
.auth-card h1{margin:0 0 6px;font-size:22px;font-weight:800;text-align:center}
.auth-card .sub{text-align:center;color:var(--muted);font-size:13.5px;margin:0 0 22px}
.auth-card label{display:block;font-size:12.5px;color:var(--muted);margin:14px 0 6px}
.auth-card input{width:100%;height:46px;padding:0 14px;border:1px solid var(--line2);border-radius:12px;
  background:rgba(0,0,0,.25);color:var(--text);font-size:15px;outline:none}
.auth-card input:focus{border-color:rgba(124,92,255,.5)}
.auth-card .submit{width:100%;height:48px;margin-top:22px;border:none;border-radius:12px;
  background:linear-gradient(135deg,#7c5cff,#5e40d8);color:#fff;font-size:15px;font-weight:700;cursor:pointer;
  box-shadow:0 8px 24px rgba(124,92,255,.45)}
.auth-card .submit:hover{filter:brightness(1.08)}
.auth-card .alt{text-align:center;margin-top:18px;font-size:13.5px;color:var(--muted)}
.auth-card .alt a{color:var(--accent-text);text-decoration:none;font-weight:600}
.auth-err{margin-top:14px;padding:11px 14px;border-radius:11px;background:rgba(255,120,120,.1);
  border:1px solid rgba(255,120,120,.25);color:#ff9a9a;font-size:13px}
