/* ============================ КАДР, стили ============================== */
: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)}}

/* --- анимация клика: вдавливание + волна --- */
button{transition:transform .12s ease}
button:active:not(:disabled){transform:scale(.94)}
.balance-pill,.pack{cursor:pointer;transition:transform .12s ease}
.balance-pill:active,.pack:active{transform:scale(.97)}
.btn,.send-btn,.gen-btn,.topup-btn,.submit,.model-btn,.chip,.icon-btn,.logout,.avatar,
.toggle button,.filters button,.rail button,.bottomnav button,.menu button,.balance-pill{position:relative;overflow:hidden}
.rp{position:absolute;border-radius:50%;background:rgba(255,255,255,.35);pointer-events:none;
  transform:translate(-50%,-50%) scale(0);animation:ripple .5s ease-out forwards}
@keyframes ripple{to{transform:translate(-50%,-50%) scale(2.5);opacity:0}}

/* --------------------------------- layout ----------------------------- */
.app{position:relative;height:100vh;height:100dvh;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:7.5px;
  background:url("/static/favicon.svg") center/cover no-repeat;box-shadow:0 4px 16px rgba(124,92,255,.45)}
.brand .logo i{display:none}
.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,#7c5cff,#3d2a8a);
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;
  cursor:pointer;box-shadow:0 4px 14px rgba(124,92,255,.4)}

.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,.92);backdrop-filter:blur(12px);
  padding-bottom:env(safe-area-inset-bottom)}
.bottomnav button{flex:1;padding:6px 0 7px;font-size:9.5px;gap:3px}
.bottomnav button svg{width:19px;height:19px}
.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)}
/* у экрана генерации внутри рамки только абсолютные элементы → задаём размер явно,
   иначе рамка схлопывается в тонкую полоску и анимации не видно */
#gen-running .frame{width:min(82vw,420px);height:min(46vh,300px)}
.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);transition:border-color .15s,box-shadow .15s}
.composer.dragover{border-color:rgba(124,92,255,.6);box-shadow:0 0 0 2px rgba(124,92,255,.35),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:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 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-name{flex:1;min-width:0;font-size:13.5px;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.menu .m-row .m-cost{flex:none;font-family:var(--mono);font-size:11.5px;color:var(--accent-text)}
.m-ic{flex:none;width:24px;height:24px;border-radius:7px;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;color:#fff;background:#7c5cff}
.model-btn .m-ic{width:20px;height:20px;border-radius:6px;font-size:11px}
/* ползунок длительности */
.dur-pop{left:auto;right:0;width:232px;padding:13px 14px}
.dur-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;font-size:12px;color:var(--muted)}
.dur-num{width:58px;height:30px;padding:0 8px;border:1px solid var(--line2);border-radius:8px;background:rgba(0,0,0,.25);
  color:var(--text);font-family:var(--mono);font-size:13px;outline:none;text-align:center}
.dur-num:focus{border-color:rgba(124,92,255,.5)}
.dur-range{width:100%;accent-color:var(--accent);cursor:pointer}
.dur-scale{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-top:6px;font-family:var(--mono)}
.input-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}
.attachments{display:flex;gap:8px;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;
  animation:attIn .22s ease both}
.att.att-zoom{cursor:zoom-in}
.att.loading{filter:brightness(.5)}
.att-spin{width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.25);
  border-top-color:#a48cff;animation:spin .7s linear infinite}
@keyframes attIn{from{opacity:0;transform:scale(.82)}to{opacity:1;transform:none}}
.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;z-index:2}
.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{width:100%;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}
.gen-cost{font-family:var(--mono);font-size:12px;font-weight:600;opacity:.82}
.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}

/* визуализация соотношения сторон (в чипе и в списке) */
.ar-box{display:inline-block;flex:none;border:1.5px solid currentColor;border-radius:2px;opacity:.85}
.menu button.opt-row{display:flex;align-items:center;gap:9px}

/* ---- композер: большое поле + строка инструментов ---- */
.composer.studio{display:flex;flex-direction:column;padding:0}
.composer.studio .controls{border-bottom:1px solid var(--line);flex-wrap:nowrap}
.composer.studio .toggle{flex:none}
.composer.studio .model-dd{margin-left:auto;min-width:0}
.composer.studio .model-btn{min-width:0;max-width:100%}
.composer.studio #model-name{display:block;min-width:0;max-width:200px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.composer.studio .input-col.big{padding:14px 16px 4px}
.composer.studio .input-col.big textarea{width:100%;min-height:88px;max-height:220px;resize:none;
  padding:6px 8px;border:none;background:transparent;color:var(--text);font-size:16px;line-height:1.5;outline:none}
.composer.studio .input-col.big textarea::placeholder{color:#6a6a73}
.composer.studio .toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 12px;border-top:1px solid var(--line)}
.composer.studio .toolbar .params{margin-left:0;gap:7px}
/* скрепка и чипы — одинаковой высоты */
.composer.studio .toolbar .chip{height:34px;padding:0 11px}
.composer.studio .toolbar .icon-btn{width:34px;height:34px;border-radius:9px}
.composer.studio .toolbar .send-col{margin-left:auto;flex-direction:row;align-items:center;gap:10px}
.gen-cost-out{font-family:var(--mono);font-size:12.5px;color:var(--muted);white-space:nowrap}
.send-btn{flex:none;width:38px;height:38px;border:none;border-radius:50%;cursor:pointer;color:#fff;
  background:linear-gradient(135deg,#7c5cff,#5e40d8);box-shadow:0 5px 14px rgba(124,92,255,.4);
  display:flex;align-items:center;justify-content:center;transition:filter .12s,transform .12s}
.send-btn:not(:disabled):hover{filter:brightness(1.1)}
.send-btn:disabled{background:rgba(255,255,255,.07);box-shadow:none;opacity:.5;cursor:not-allowed}

/* запрос пользователя во время генерации (текст + исходники) */
.req-preview{width:100%;max-width:min(86vw,560px);display:flex;flex-direction:column;align-items:center;gap:10px}
.req-sources{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.req-src{width:46px;height:46px;border-radius:10px;background-size:cover;background-position:center;
  background-color:#1a1a20;border:1px solid var(--line2);display:flex;align-items:center;justify-content:center;font-size:18px}
.req-text{max-width:100%;text-align:center;font-size:14px;line-height:1.5;color:#cfcdd6;
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px;padding:10px 14px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* -------------------------------- 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:16px;padding:clamp(14px,3vw,18px) clamp(16px,3vw,22px);
  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:220px;height:220px;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:12px;color:var(--accent-text);font-weight:600}
.balance-hero .big{font-family:var(--mono);font-size:clamp(30px,6vw,40px);font-weight:600;line-height:1;color:#fff}
.section-title{font-size:15px;font-weight:700;margin:20px 0 12px}
.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 .disc{position:absolute;top:-9px;right:14px;padding:3px 9px;border-radius:999px;
  background:#1faa5c;border:1px solid rgba(46,204,113,.7);color:#eafff2;
  font-size:10px;font-weight:700;letter-spacing:.02em;box-shadow:0 4px 12px rgba(31,170,92,.35)}
.pack .tk{font-family:var(--mono);font-size:25px;font-weight:600;color:#fff;line-height:1.1}
.pack .tk small{display:block;font-family:'Manrope';font-size:12px;color:var(--muted);font-weight:500;margin-top:3px}
.pack .price{display:flex;align-items:center;justify-content:center;gap:5px;height:40px;border-radius:11px;
  background:rgba(255,255,255,.05);border:1px solid var(--line2);font-size:14px;font-weight:700;
  font-family:'Manrope';color:#fff}
.pack button.price{cursor:pointer;width:100%}
.pack button.price:hover{border-color:rgba(124,92,255,.55);background:rgba(124,92,255,.12)}
/* кнопка оплаты на карточках пакетов (это div) — ховер + нажатие, десктоп и тач */
.pack:not(.pack-custom):not(.pack-promo) .price{transition:background .15s ease,border-color .15s ease,color .15s ease,transform .12s ease}
.pack:not(.pack-custom):not(.pack-promo):hover .price{border-color:rgba(124,92,255,.55);background:rgba(124,92,255,.16);color:#fff}
.pack:not(.pack-custom):not(.pack-promo):active .price{background:rgba(124,92,255,.28);border-color:rgba(124,92,255,.7);transform:scale(.96)}
/* загрузка: пока генерится ссылка оплаты — спиннер вместо цены */
.price.loading{color:transparent !important;pointer-events:none;position:relative}
.price.loading > *{visibility:hidden}
.price.loading::after{content:'';position:absolute;left:50%;top:50%;width:16px;height:16px;margin:-8px 0 0 -8px;
  border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
.pack.popular .price.loading::after{border-color:rgba(124,92,255,.35);border-top-color:#fff}
/* карточка «свой объём» */
.pack-custom{cursor:default;gap:11px}
.pack-custom .tk{font-family:'Manrope';font-size:16px;line-height:1.2}
.pack .cust-inp{width:100%;height:40px;padding:0 13px;border:1px solid var(--line2);border-radius:11px;
  background:rgba(0,0,0,.25);color:#fff;font-family:var(--mono);font-size:16px;outline:none}
.pack .cust-inp:focus{border-color:rgba(124,92,255,.5)}
.pack .cust-inp::placeholder{color:#5a5a64;font-family:'Manrope';font-size:14px}
.pack-custom .cust-inp.bad{border-color:rgba(255,120,120,.7);animation:shake .5s}
.pack-custom .price.muted{color:var(--muted);background:rgba(255,255,255,.04);font-weight:600}
/* карточка «промокод» — как «свой объём», кнопка акцентная */
.pack-promo{cursor:default;gap:11px}
.pack-promo .tk{font-family:'Manrope';font-size:16px;line-height:1.2}
.pack-promo .cust-inp{text-transform:uppercase;letter-spacing:.06em}
.pack-promo .cust-inp::placeholder{text-transform:none;letter-spacing:normal}
.pack-promo button.price{background:var(--accent);border-color:transparent;color:#fff}
.pack-promo button.price:hover{background:var(--accent2);border-color:transparent}
.pack-promo button.price:disabled{opacity:.55;cursor:default}
.cust-min{display:none;font-size:11.5px;color:#ff9a9a;font-weight:600;text-align:center;margin-top:-3px}
.cust-min.show{display:block;animation:minPop .3s ease both}
@keyframes shake{10%,90%{transform:translateX(-1px)}20%,80%{transform:translateX(2px)}
  30%,50%,70%{transform:translateX(-5px)}40%,60%{transform:translateX(5px)}}
@keyframes minPop{from{opacity:0;transform:translateY(-3px) scale(.96)}to{opacity:1;transform:none}}
/* предупреждение про icloud на входе — та же анимация, что у «минимум 50» */
.mail-warn{display:none;font-size:12.5px;color:#ffb38a;line-height:1.45;margin:9px 2px 2px;text-align:left}
.mail-warn b{color:#ffd0b0;font-weight:700}
.mail-warn.show{display:block;animation:minPop .3s ease both}
#email.mailbad{border-color:rgba(255,160,90,.85);animation:shake .5s}
/* убираем стрелки у числовых полей */
input[type=number]{-moz-appearance:textfield;appearance:textfield}
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.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 .id-text{min-width:0}
.identity .nm{font-size:18px;font-weight:700;overflow-wrap:anywhere;word-break:break-word;line-height:1.25}
.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}
.detail-media{border-radius:14px;overflow:hidden;background:#0d0d11;border:1px solid var(--line);margin-bottom:14px}
.detail-media img,.detail-media video{width:100%;display:block;max-height:70vh;object-fit:contain;background:#0d0d11}
.detail-media a{display:block;cursor:zoom-in}
.detail-section-title{font-size:14px;font-weight:700;margin:24px 0 12px}
.src-grid{display:flex;gap:10px;flex-wrap:wrap}
.src-item{width:88px;height:88px;border-radius:10px;overflow:hidden;border:1px solid var(--line2);
  display:flex;align-items:center;justify-content:center;background:#15151a;cursor:pointer}
.src-item:hover{border-color:rgba(124,92,255,.5)}
.src-item img{width:100%;height:100%;object-fit:cover}
.src-item.src-file{font-size:30px}
.hd-empty{padding:40px 20px;text-align:center;color:var(--muted);font-family:var(--mono);font-size:13px}
.detail-head{display:flex;align-items:center;gap:11px;margin-bottom:16px}
.detail-head .m-ic{width:32px;height:32px;border-radius:9px;font-size:15px}
.detail-title{font-size:18px;font-weight:700}
/* лайтбокс */
.lightbox{position:fixed;inset:0;z-index:95;background:rgba(4,4,6,.93);display:flex;align-items:center;justify-content:center;
  padding:28px;cursor:zoom-out;animation:fadeUp .2s ease both}
.lightbox.hidden{display:none}
.lightbox img{max-width:100%;max-height:100%;border-radius:10px;object-fit:contain;box-shadow:0 30px 90px rgba(0,0,0,.6)}
.lb-close{position:absolute;top:18px;right:22px;width:40px;height:40px;border:1px solid var(--line2);border-radius:50%;
  background:rgba(20,20,25,.7);color:#fff;font-size:22px;line-height:1;cursor:pointer}
.lb-close:hover{background:rgba(40,40,48,.9)}
.hd-row{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.hd-row:last-child{border-bottom:none}
.hd-row .k{flex:none;width:92px;font-size:13px;color:var(--muted)}
.hd-row .v{flex:1;min-width:0;font-size:13.5px;color:#e7e6ec;word-break:break-word;white-space:pre-wrap}
/* уведомления — плавающая карточка сверху по центру */
.toast{position:fixed;top:max(14px,env(safe-area-inset-top));left:50%;z-index:120;
  max-width:min(92vw,440px);display:flex;align-items:center;gap:11px;
  padding:13px 18px 13px 15px;border-radius:14px;
  background:rgba(22,22,28,.85);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);
  border:1px solid var(--line2);color:#f3f2f6;font-size:14px;font-weight:500;line-height:1.35;
  box-shadow:0 18px 50px rgba(0,0,0,.55);
  opacity:0;visibility:hidden;pointer-events:none;transform:translate(-50%,-16px);
  transition:opacity .26s ease,transform .32s cubic-bezier(.18,.9,.32,1.2),visibility .26s}
.toast.show{opacity:1;visibility:visible;transform:translate(-50%,0)}
.toast::before{content:'';flex:none;width:9px;height:9px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 12px var(--accent)}
.toast.ok::before{background:var(--good);box-shadow:0 0 12px var(--good)}
.toast.err::before{background:var(--bad);box-shadow:0 0 12px var(--bad)}

/* ------------------------------- auth --------------------------------- */
.auth{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;
  padding:24px;padding-bottom:max(24px,env(safe-area-inset-bottom));
  background:radial-gradient(140% 100% at 50% -10%,#101016 0%,#08080a 58%)}
.auth-card{width:100%;max-width:400px;margin:auto 0;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-foot{flex:none;display:flex;gap:6px 16px;flex-wrap:wrap;justify-content:center;padding-top:14px}
.auth-foot a{color:var(--muted2);text-decoration:none;font-size:11.5px;white-space:nowrap}
.auth-foot a:hover{color:var(--accent-text)}
.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:not([type="checkbox"]){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:not([type="checkbox"]):focus{border-color:rgba(124,92,255,.5)}
.code-input{text-align:center;font-family:var(--mono);font-size:26px;letter-spacing:12px;font-weight:600}
.code-input::placeholder{letter-spacing:8px;color:#3a3a42}
.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}
/* ввод кода: 6 отдельных полей */
.otp{display:flex;gap:9px;justify-content:center;margin-top:6px}
.otp-box{width:100%;max-width:50px;height:58px;padding:0;text-align:center;border:1px solid var(--line2);
  border-radius:13px;background:rgba(0,0,0,.28);color:#fff;font-family:var(--mono);font-size:26px;
  font-weight:600;outline:none;transition:border-color .12s,box-shadow .12s;-moz-appearance:textfield}
.otp-box::-webkit-outer-spin-button,.otp-box::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.otp-box:focus{border-color:rgba(124,92,255,.65);box-shadow:0 0 0 3px rgba(124,92,255,.18)}
.spam-hint{text-align:center;color:var(--muted2);font-size:12.5px;line-height:1.5;margin:18px 0 0}
.resend-form{text-align:center;margin-top:6px}
.linkbtn{border:none;background:none;color:var(--accent-text);font-size:13.5px;font-weight:600;
  cursor:pointer;padding:4px;font-family:inherit}
.linkbtn:hover{text-decoration:underline}

/* ----------------------------- мобильные ------------------------------ */
@media(max-width:640px){
  /* экран «Создать»: компактнее */
  .canvas{padding:18px 14px}
  .idle h1{font-size:25px;margin-bottom:9px}
  .orb-wrap{width:88px;height:88px;margin-bottom:20px}
  .composer-wrap{padding:0 10px 10px}
  .composer{border-radius:18px}
  .controls{gap:7px;padding:10px 11px}

  /* верхняя строка: тублер + модель всегда в одну строку (имя обрезается) */
  .composer.studio .controls{gap:8px}
  .composer.studio .model-dd{flex:1 1 auto}
  .composer.studio .model-btn{width:100%}
  .composer.studio #model-name{max-width:none;flex:1}

  /* композер: инструменты в один ряд, поле большое */
  .composer.studio .input-col.big{padding:12px 12px 2px}
  .composer.studio .input-col.big textarea{min-height:74px}
  .composer.studio .toolbar{gap:7px;padding:9px 10px}
  /* скрепка строго того же размера, что и чипы рядом */
  .composer.studio .toolbar .chip{height:30px;padding:0 9px;font-size:11.5px}
  .composer.studio .toolbar .icon-btn{width:30px;height:30px}
  .composer.studio .toolbar .icon-btn svg{width:16px;height:16px}
  .composer.studio .toolbar .send-col .topup-btn{height:38px;padding:0 12px}

  /* список моделей: нижняя «шторка» во всю ширину, чтобы видеть стоимость */
  #model-menu{position:fixed;left:10px;right:10px;width:auto;max-width:none;
    top:auto;bottom:calc(env(safe-area-inset-bottom) + 12px);max-height:62vh;z-index:60}

  /* кошелёк: компактнее, чтобы все пакеты влезали без скролла */
  .page{padding:14px 12px 72px}
  .balance-hero{padding:11px 14px;border-radius:14px}
  .balance-hero .big{font-size:26px}
  .packs{gap:9px}
  .pack{padding:13px;gap:9px}
  .pack .tk{font-size:21px}
  .pack .price{height:36px}
  .pack-custom{gap:9px}
  .pack-custom .cust-inp{height:36px}

  /* профиль: длинная почта не ломает карточку */
  .identity{padding:16px;gap:13px}
  .identity .av{width:52px;height:52px;font-size:18px}
  .identity .nm{font-size:15px}

  /* вход: 6 полей помещаются на узком экране */
  .auth-card{padding:26px 20px}
  .otp{gap:6px}
  .otp-box{height:52px;font-size:22px;border-radius:11px;max-width:46px}
}

/* =============================== юр-комплаенс =========================== */
/* публичные страницы оферты/политики/согласия */
.legal-wrap{max-width:820px;margin:0 auto;padding:22px clamp(16px,4vw,32px) 60px;min-height:100dvh}
.legal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:6px 0 18px;border-bottom:1px solid var(--line);margin-bottom:24px}
.legal-brand{display:flex;align-items:center;gap:10px;font-size:17px;letter-spacing:.16em;font-weight:800;text-decoration:none;color:var(--text)}
.logo-sm{width:26px;height:26px;border-radius:7px;background:url("/static/favicon.svg") center/cover no-repeat;flex:none}
.legal-back{font-size:14px;color:var(--accent-text);text-decoration:none;font-weight:600;white-space:nowrap}
.legal-back:hover{text-decoration:underline}
.legal-doc{color:#d7d6df;font-size:15px;line-height:1.7}
.legal-doc h1{font-size:clamp(21px,4vw,27px);font-weight:800;line-height:1.25;margin:0 0 6px;color:#fff}
.legal-doc .legal-ver{color:var(--muted);font-size:13px;margin:0 0 26px}
.legal-doc h2{font-size:18px;font-weight:700;color:#fff;margin:30px 0 10px}
.legal-doc p{margin:0 0 11px}
.legal-doc strong{color:#fff;font-weight:600}
.legal-doc blockquote{margin:0 0 12px;padding:2px 0 2px 16px;border-left:2px solid var(--line2)}
.legal-doc blockquote p{margin:0 0 6px;color:#bdbcc7;font-size:14px}
.legal-doc a{color:var(--accent-text)}
.legal-footer{margin-top:42px;padding-top:20px;border-top:1px solid var(--line);text-align:center}
.legal-footer .lf-links{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-bottom:10px}
.legal-footer .lf-links a{color:var(--accent-text);text-decoration:none;font-size:13.5px}
.legal-footer .lf-links a:hover{text-decoration:underline}
.legal-footer .lf-req{font-size:12px;color:var(--muted2);line-height:1.5}

/* cookie-баннер */
.cookie-banner{position:fixed;left:14px;right:14px;bottom:14px;z-index:100;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:center;
  padding:14px 18px;border-radius:16px;border:1px solid var(--line2);
  background:rgba(18,18,23,.97);backdrop-filter:blur(12px);box-shadow:0 16px 50px rgba(0,0,0,.6);
  padding-bottom:max(14px,env(safe-area-inset-bottom))}
.cookie-banner .cc-text{flex:1;min-width:240px;font-size:13px;color:#cfcdd6;line-height:1.5}
.cookie-banner .cc-text a{color:var(--accent-text)}
.cookie-banner .cc-actions{display:flex;gap:10px;flex:none}
.cc-btn{padding:9px 16px;border-radius:10px;border:1px solid var(--line2);background:rgba(255,255,255,.04);
  color:#e7e6ec;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}
.cc-btn:hover{border-color:rgba(255,255,255,.3)}
.cc-btn.cc-primary{border:none;background:linear-gradient(135deg,#7c5cff,#5e40d8);color:#fff}

/* галочки согласий при регистрации */
.consent{display:flex;flex-direction:column;gap:8px;margin:14px 0 2px}
/* галочки согласий — обычный нативный чекбокс */
.cbx{display:flex;gap:9px;align-items:flex-start;cursor:pointer;font-size:12px;line-height:1.45;color:#aeadb8}
.cbx input{flex:none;margin:2px 0 0;accent-color:var(--accent);cursor:pointer}
.cbx a{color:var(--accent-text)}
.req-star{color:#ff9a9a;font-weight:700}

/* подпись про ПДн у поля запроса */
.pd-hint{font-size:11px;color:var(--muted2);padding:3px 8px 0}

/* пункты настроек профиля как ссылки */
.settings a.item{text-decoration:none;color:#e7e6ec}
.settings a.item:hover{background:rgba(255,255,255,.03)}
/* «Поддержка» — кнопка, но выглядит как пункт-ссылка */
.settings button.item{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);
  font:inherit;color:#e7e6ec;cursor:pointer;text-align:left}
.settings button.item:last-child{border-bottom:none}
.settings button.item:hover{background:rgba(255,255,255,.03)}

/* окно поддержки */
.support-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.support-p{font-size:14px;color:#c9c8d2;line-height:1.55;margin:0 0 10px}
.support-mail{display:inline-block;font-family:var(--mono);font-size:16px;color:var(--accent-text);text-decoration:none;
  padding:9px 15px;border:1px solid var(--line2);border-radius:11px;background:rgba(124,92,255,.08)}
.support-mail:hover{border-color:rgba(124,92,255,.5)}
.support-sub{margin-top:16px}
.support-list{margin:0 0 18px;padding-left:18px;color:#a9a8b3;font-size:13.5px;line-height:1.7}
.support-write{width:100%;justify-content:center}

/* ============================== АДМИНКА =============================== */
.adm{max-width:1100px;margin:0 auto;padding:22px clamp(14px,3vw,28px) 60px;font-family:'Manrope',sans-serif}
.adm-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.adm-brand{font-size:18px;font-weight:800;letter-spacing:.02em}
.adm-top-right{display:flex;align-items:center;gap:14px}
.adm-email{font-size:13px;color:var(--muted)}
.adm-link{font-size:13px;color:var(--accent-text);text-decoration:none}
.adm-link:hover{color:#fff}
.adm-tabs{display:flex;gap:8px;border-bottom:1px solid var(--line);margin-bottom:20px;flex-wrap:wrap}
.adm-tabs button{background:none;border:none;color:var(--muted);font:inherit;font-size:14px;font-weight:600;padding:10px 12px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.adm-tabs button.active{color:#fff;border-bottom-color:var(--accent)}
.adm-tabs button:hover{color:#fff}
.adm-sec.hidden{display:none}
.adm-subtitle{font-size:14px;font-weight:700;color:#e7e6ec;margin:22px 0 12px}
.adm-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:13px}
.adm-card{border:1px solid var(--line2);border-radius:14px;background:rgba(255,255,255,.02);padding:16px 18px}
.adm-card .lbl{font-size:12.5px;color:var(--muted);font-weight:500}
.adm-card .big{font-size:26px;font-weight:700;color:#fff;margin-top:6px;font-family:var(--mono);line-height:1.1}
.adm-card .big.err{font-size:18px;color:var(--bad);font-family:'Manrope'}
.adm-card .sub{font-size:12px;color:var(--muted);margin-top:6px}
.adm-card.or{border-color:rgba(124,92,255,.5);background:rgba(124,92,255,.1)}
.adm-card.or .big{color:#c8b8ff}
.adm-tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.adm-tbl th{text-align:left;font-weight:600;color:var(--muted);font-size:12px;padding:8px 10px;border-bottom:1px solid var(--line)}
.adm-tbl td{padding:10px;border-bottom:1px solid var(--line);color:#e7e6ec;vertical-align:middle}
.adm-tbl tr:last-child td{border-bottom:none}
.adm .r{text-align:right}
.adm .mono{font-family:var(--mono)}
.adm .muted{color:var(--muted)}
.adm .ok{color:var(--good)}
.adm .warn{color:#e0a93d}
.adm-bar{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.adm-count{font-size:12.5px;color:var(--muted)}
.adm-inp{height:40px;padding:0 13px;border:1px solid var(--line2);border-radius:10px;background:rgba(0,0,0,.25);color:#fff;font:inherit;font-size:14px;outline:none}
.adm-inp:focus{border-color:rgba(124,92,255,.5)}
.adm-inp.mono{font-family:var(--mono);text-transform:uppercase}
.adm-bar .adm-inp{flex:1;max-width:320px}
.adm-form{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:8px}
.adm-form .adm-inp{flex:1;min-width:120px}
.adm-btn{height:40px;padding:0 20px;border:none;border-radius:10px;background:var(--accent);color:#fff;font:inherit;font-size:14px;font-weight:700;cursor:pointer}
.adm-btn:hover{background:var(--accent2)}
.adm-mini{padding:5px 11px;border:1px solid var(--line2);border-radius:8px;background:transparent;color:var(--accent-text);font:inherit;font-size:12.5px;cursor:pointer;white-space:nowrap}
.adm-mini:hover{border-color:rgba(124,92,255,.55);background:rgba(124,92,255,.1)}
.adm-empty{padding:30px;text-align:center;color:var(--muted);font-size:13px}
