/* ТОТЕМ — тема панели. Жёлто-синяя, тёмная. Bento + glow-рамка + border-beam. */
:root{
  --bg:#0e1320; --panel:#161d2e; --panel2:#1d2740; --line:#26314d;
  --yellow:#f6c945; --yellow-d:#e0b020; --blue:#3b82f6; --blue-d:#2563eb;
  --txt:#e8edf7; --muted:#8b97b3; --danger:#ef4444; --green:#34d399;
  --radius:18px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  color:var(--txt); font-family:'AppleEmoji',-apple-system,Segoe UI,Roboto,Inter,sans-serif;
  background:
    radial-gradient(1100px 520px at 82% -8%,rgba(59,130,246,.12),transparent 60%),
    radial-gradient(900px 500px at 6% 108%,rgba(246,201,69,.07),transparent 55%),
    var(--bg);
  background-attachment: fixed;
}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}

/* ── App shell: sidebar + main ── */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.side{
  border-right:1px solid var(--line); padding:22px 16px;
  background:linear-gradient(180deg,rgba(22,29,46,.6),transparent);
  position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:6px;
}
.brand{font-family:'Fredoka',-apple-system,Segoe UI,sans-serif;font-size:26px;font-weight:700;letter-spacing:.3px;padding:6px 10px 18px;display:flex;align-items:center;gap:5px}
.brandlogo{width:58px;height:58px;object-fit:contain;flex:0 0 auto}
.badge.badge-link{cursor:pointer;text-decoration:none;transition:box-shadow .2s;
  display:inline-flex;align-items:center;gap:3px;justify-content:center;vertical-align:middle;line-height:1}
.badge.badge-link:hover{box-shadow:0 0 10px 2px rgba(246,201,69,.55),0 0 22px 4px rgba(246,201,69,.2)}
@keyframes gear-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.badge.badge-link:hover .gear-spin{animation:gear-spin .7s linear infinite}
.brand .y{color:var(--yellow)} .brand .b{color:var(--blue)}
.nav{display:flex;flex-direction:column;gap:4px;position:relative}
/* переезжающая пилюля-подсветка под наведённым/активным пунктом */
.nav-hl{position:absolute;left:0;right:0;top:0;height:0;border-radius:12px;pointer-events:none;z-index:0;opacity:0;
  background:linear-gradient(90deg,rgba(59,130,246,.22),rgba(246,201,69,.05));
  box-shadow:inset 2px 0 0 var(--blue),0 8px 22px -10px rgba(59,130,246,.7);
  transition:transform .42s cubic-bezier(.22,.61,.36,1),height .42s cubic-bezier(.22,.61,.36,1),opacity .3s}
.nav a{
  display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:12px;position:relative;z-index:1;
  color:var(--muted);font-size:14px;font-weight:500;
  transition:color .2s,transform .2s cubic-bezier(.2,.7,.2,1);
}
.nav a .ni{font-size:22px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  transition:transform .25s cubic-bezier(.2,.7,.2,1)}
.nav a .ni img.iimg{width:34px;height:34px;object-fit:contain;display:block}
.card .ico img.iimg{width:40px;height:40px;object-fit:contain;display:block}
.iimg{vertical-align:middle}
.nav a:hover{color:var(--txt);transform:translateX(5px)}
.nav a:hover .ni{transform:scale(1.18) rotate(-4deg)}
.nav a.active{color:var(--txt)}
.nav a.active .ni{filter:drop-shadow(0 0 6px rgba(59,130,246,.5))}
.side .spacer{flex:1}
.side .ubox{border-top:1px solid var(--line);padding-top:14px;font-size:13px;color:var(--muted)}
.side .ubox b{color:var(--txt)}

.main{padding:26px 30px;max-width:1180px;position:relative}
.head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.head h1{margin:0;font-size:22px;font-weight:700}
.head .sub{color:var(--muted);font-size:13px;margin-top:3px}
.head .actions{display:flex;gap:10px}

/* ── Bento grid ── */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:140px;gap:16px;position:relative}
.bento .card{z-index:1}

/* Aceternity-style: подсветка-блоб, переезжающая к наведённой карточке */
.bento-hl{position:absolute;top:0;left:0;width:0;height:0;border-radius:var(--radius);
  pointer-events:none;z-index:0;opacity:0;
  background:radial-gradient(120% 120% at 50% 0,rgba(246,201,69,.13),rgba(59,130,246,.10) 60%,transparent);
  box-shadow:0 12px 60px 4px rgba(59,130,246,.20),0 0 34px rgba(246,201,69,.12);
  transition:transform .7s cubic-bezier(.22,.61,.36,1),width .7s cubic-bezier(.22,.61,.36,1),
    height .7s cubic-bezier(.22,.61,.36,1),opacity .4s}

/* Magic UI-style: крупный бледный глиф на фоне карточки */
.card .glyph{position:absolute;right:10px;bottom:6px;font-size:88px;line-height:1;opacity:.07;
  pointer-events:none;transition:transform .4s cubic-bezier(.2,.7,.2,1),opacity .4s;z-index:0}
.card img.glyph{width:100px;height:100px;object-fit:contain}
.card:hover .glyph{opacity:.14;transform:scale(1.06) rotate(-4deg)}
.card>*{position:relative;z-index:1}

/* Magic UI-style: контент приподнимается, снизу проявляется CTA */
/* reveal: контент в потоке, CTA прижат к низу (margin-top:auto), ничего не клипается */
.card.reveal{display:flex;flex-direction:column;padding:16px 18px}
.card.reveal .big{font-size:38px;margin-top:2px}
.card.reveal .sub{margin-top:2px}
.card.reveal .cta{margin-top:auto;font-size:13px;font-weight:600;color:var(--yellow);text-decoration:none;
  opacity:.7;transition:opacity .25s,transform .25s;white-space:nowrap}
.card.reveal:hover .cta{opacity:1;transform:translateX(3px)}
.c-2col{grid-column:span 2}.c-3col{grid-column:span 3}.c-4col{grid-column:span 4}
.c-2row{grid-row:span 2}
@media(max-width:900px){.app{grid-template-columns:1fr}.side{display:none}
  .bento{grid-template-columns:repeat(2,1fr)}.c-3col,.c-4col{grid-column:span 2}}

/* ── Card with cursor glow ── */
.card{
  position:relative;border-radius:var(--radius);padding:20px;overflow:visible;
  background:linear-gradient(180deg,var(--panel),#131a29);border:1px solid var(--line);
  transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s;
}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(300px circle at var(--mx,-200px) var(--my,-200px),
    rgba(246,201,69,.06),transparent 42%);opacity:0;transition:opacity .3s}
.card::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:radial-gradient(220px circle at var(--mx,-200px) var(--my,-200px),
    var(--blue),rgba(59,130,246,.18) 30%,transparent 55%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.32}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -22px rgba(0,0,0,.8)}
.card:hover::before{opacity:1}
.card.flat::after{opacity:.18}
.card h3{margin:0;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}
.card .ico{position:absolute;top:18px;right:18px;font-size:21px;opacity:.85;transition:transform .3s}
.card:hover .ico{transform:scale(1.18) rotate(-6deg)}
.big{font-size:44px;font-weight:800;line-height:1.05;margin-top:8px}
.big.y{color:var(--yellow)}.big.b{color:var(--blue)}
.sub{color:var(--muted);font-size:13px;margin-top:6px}

/* ── Border beam (running arc) ── */
@property --beam{syntax:'<angle>';inherits:false;initial-value:0deg}
.beam::after{
  background:conic-gradient(from var(--beam),
    transparent 0 62%,var(--yellow) 80%,var(--blue) 92%,transparent 100%);
  opacity:1;animation:beamspin 4.5s linear infinite}
@keyframes beamspin{to{--beam:360deg}}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-weight:700;font-size:14px;font-family:'AppleEmoji',-apple-system,Segoe UI,Roboto,Inter,sans-serif;
  border:0;padding:10px 16px;border-radius:11px;background:var(--yellow);color:#1a1200;
  transition:transform .15s,background .2s,filter .2s,box-shadow .2s;
  position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.18);
  opacity:0;transition:opacity .2s;border-radius:inherit}
.btn:hover{background:var(--yellow-d);transform:translateY(-1px);box-shadow:0 6px 20px -6px rgba(246,201,69,.5)}
.btn:hover::after{opacity:1}
.btn:active{transform:scale(.96)}
.btn.blue{background:var(--blue);color:#fff}.btn.blue:hover{background:var(--blue-d)}
.btn.ghost{background:var(--panel2);color:var(--txt);border:1px solid var(--line)}
.btn.ghost:hover{background:var(--line)}
.btn.sm{padding:7px 12px;font-size:13px;border-radius:9px}
.btn.danger{background:transparent;color:#ffb4b4;border:1px solid var(--danger)}
.btn.danger:hover{background:rgba(239,68,68,.12)}

/* ── Аватарки аккаунтов (фото из TG + фоллбэк-инициал) ── */
.ava{position:relative;display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;overflow:hidden;flex:0 0 auto;vertical-align:middle;
  background:linear-gradient(135deg,var(--blue),var(--yellow));box-shadow:0 0 0 1px var(--line)}
.ava-fb{color:#0e1320;font-weight:800;line-height:1;user-select:none}
.ava-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:2}

/* ── Status dots / chips ── */
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:var(--green);box-shadow:0 0 10px var(--green)}
.dot.off{background:#5b6680;box-shadow:none}
.chip{display:inline-flex;align-items:center;gap:7px;background:var(--panel2);border:1px solid var(--line);
  padding:7px 12px;border-radius:999px;font-size:13px}
.badge{display:inline-block;background:var(--blue);color:#fff;border-radius:999px;padding:3px 12px;font-size:12px;font-weight:600}
.badge.admin{background:var(--yellow);color:#1a1200}

/* ── Tooltips (информационные подсказки) ── */
.tip{position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;background:var(--panel2);border:1px solid var(--line);
  color:var(--muted);font-size:13px;font-weight:500;cursor:help;
  transition:border-color .2s,color .2s,transform .2s;flex:0 0 auto;line-height:1;
  font-family:system-ui,-apple-system,sans-serif;vertical-align:middle;margin-left:6px}
.tip:hover{border-color:var(--blue);color:var(--blue);transform:scale(1.15)}
.tip::before{content:'i';font-style:normal;text-transform:lowercase}
.tip-text{position:absolute;
  background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:10px 14px;
  font-size:14px;line-height:1.6;color:var(--txt);font-weight:400;white-space:nowrap;
  pointer-events:none;opacity:0;transition:opacity .2s;
  box-shadow:0 8px 24px -6px rgba(0,0,0,.4);font-style:normal}
.tip-text::after{content:'';position:absolute;left:50%;transform:translateX(-50%);
  border:6px solid transparent}
.tip-text.above::after{top:100%;border-top-color:var(--line)}
.tip-text.below::after{bottom:100%;border-bottom-color:var(--line)}
.tip-text.wide{white-space:normal;max-width:280px;min-width:200px}
.badge.warn{background:rgba(246,201,69,.15);color:var(--yellow);border:1px solid var(--yellow)}

/* ── Table / list ── */
.tbl{width:100%;border-collapse:separate;border-spacing:0 8px}
.tbl th{text-align:left;color:var(--muted);font-size:12px;font-weight:600;text-transform:uppercase;
  letter-spacing:.5px;padding:0 14px 4px}
.tbl td{background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:13px 14px}
.tbl tr td:first-child{border-left:1px solid var(--line);border-radius:12px 0 0 12px}
.tbl tr td:last-child{border-right:1px solid var(--line);border-radius:0 12px 12px 0}
.tbl tbody tr{transition:transform .15s}
.tbl tbody tr:hover td{background:var(--panel2)}

/* ── Forms ── */
label{display:block;color:var(--muted);font-size:13px;margin:14px 0 6px}
input,select,textarea{width:100%;padding:12px 14px;border-radius:11px;border:1px solid var(--line);
  background:var(--panel2);color:var(--txt);font-size:15px;outline:none;font-family:inherit}
input:focus,select:focus,textarea:focus{border-color:var(--blue)}
/* уродские стрелки в number-инпутах — убраны везде */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input[type="number"]{-moz-appearance:textfield}
textarea{min-height:90px;resize:vertical}

/* ── Toggle switch ── */
.tg{position:relative;width:44px;height:25px;display:inline-block;flex:0 0 auto}
.tg input{opacity:0;width:0;height:0;position:absolute}
.tg .tk{position:absolute;inset:0;background:var(--panel2);border:1px solid var(--line);border-radius:999px;transition:.2s;cursor:pointer}
.tg .tk:before{content:"";position:absolute;width:19px;height:19px;left:3px;top:2px;background:var(--muted);border-radius:50%;transition:.2s}
.tg input:checked+.tk{background:rgba(52,211,153,.2);border-color:var(--green)}
.tg input:checked+.tk:before{transform:translateX(18px);background:var(--green)}

/* ── Toolbar / segmented ── */
.seg{display:inline-flex;background:var(--panel2);border:1px solid var(--line);border-radius:11px;padding:3px}
.seg button{border:0;background:transparent;color:var(--muted);padding:8px 14px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600}
.seg button.on{background:transparent;color:#fff}  /* фон = пилюля под кнопкой */

/* ── Emoji picker grid ── */
.emoji-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.emoji-grid .e{font-size:20px;padding:9px 11px;background:var(--panel2);border:1px solid var(--line);
  border-radius:11px;cursor:pointer;transition:transform .15s,border-color .2s}
.emoji-grid .e:hover{transform:translateY(-2px) scale(1.05);border-color:var(--yellow)}
.emoji-grid .e.sel{border-color:var(--yellow);background:rgba(246,201,69,.12)}

/* ── Modal ── */
.modal-bg{position:fixed;inset:0;background:rgba(6,9,16,.7);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;z-index:50;
  opacity:0;transition:opacity .25s}
.modal-bg.open{display:flex}
.modal-bg.open.shown{opacity:1}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;max-width:420px;width:92%;position:relative;
  transform:translateY(16px) scale(.97);transition:transform .28s cubic-bezier(.2,.7,.2,1),opacity .25s;opacity:0}
.modal-bg.open.shown .modal{transform:none;opacity:1}
.modal h2{margin:0 0 6px;font-size:19px}

/* ── Mini bars ── */
.stat{display:flex;align-items:flex-end;gap:6px;height:42px;margin-top:14px}
.bar{flex:1;background:linear-gradient(var(--blue),var(--blue-d));border-radius:4px 4px 0 0;transition:height .5s cubic-bezier(.2,.7,.2,1)}
.card:hover .bar{filter:brightness(1.25)}

/* ── Apple Color Emoji — только для эмодзи-символов ── */
@font-face{
  font-family:'AppleEmoji';
  src:url('/static/fonts/AppleColorEmoji-Windows.ttf') format('truetype');
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
  unicode-range:
    U+00A9,U+00AE,U+203C,U+2049,U+20E3,U+2122,U+2139,
    U+2194-2199,U+21A9-21AA,U+231A-231B,U+2328,U+23CF,
    U+23E9-23F3,U+23F8-23FA,U+24C2,U+25AA-25AB,U+25B6,
    U+25C0,U+25FB-25FE,U+2600-2604,U+260E,U+2611,
    U+2614-2615,U+2618,U+261D,U+2620,U+2622-2623,
    U+2626,U+262A,U+262E-262F,U+2638-263A,U+2640,
    U+2642,U+2648-2653,U+265F-2660,U+2663,U+2665-2666,
    U+2668,U+267B,U+267E-267F,U+2692-2697,U+2699,
    U+269B-269C,U+26A0-26A1,U+26A7,U+26AA-26AB,
    U+26B0-26B1,U+26BD-26BE,U+26C4-26C5,U+26CE-26CF,
    U+26D1,U+26D3-26D4,U+26E9-26EA,U+26F0-26F5,
    U+26F7-26FA,U+26FD,U+2702,U+2705,U+2708-270D,
    U+270F,U+2712,U+2714,U+2716,U+271D,U+2721,
    U+2728,U+2733-2734,U+2744,U+2747,U+274C,U+274E,
    U+2753-2755,U+2757,U+2763-2764,U+2795-2797,
    U+27A1,U+27B0,U+27BF,U+2934-2935,U+2B05-2B07,
    U+2B1B-2B1C,U+2B50,U+2B55,U+3030,U+303D,
    U+3297,U+3299,
    U+1F000-1F02F,U+1F0A0-1F0FF,U+1F100-1F1FF,
    U+1F200-1F2FF,U+1F300-1F5FF,U+1F600-1F64F,
    U+1F650-1F67F,U+1F680-1F6FF,U+1F700-1F77F,
    U+1F780-1F7FF,U+1F800-1F8FF,U+1F900-1F9FF,
    U+1FA00-1FA6F,U+1FA70-1FAFF,U+FE00-FE0F,
    U+1F3FB-1F3FF,U+200D,U+20E3,U+FE0F;

/* ── Telegram username links ── */
a.tg-link{color:inherit;text-decoration:none;border-bottom:1px solid rgba(139,151,179,.5);
  transition:border-color .2s,color .2s}
a.tg-link:hover{color:var(--txt);border-bottom-color:var(--blue)}

/* ── Entrance animation (stagger via inline delay) ── */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.rise{animation:rise .5s cubic-bezier(.2,.7,.2,1) both}

/* ── Login redesign ── */
#net{position:fixed;inset:0;z-index:0;pointer-events:none}
.login-scene{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;
  gap:24px;padding:24px;
  min-height:100vh;justify-content:center}
.robot-wrap{
  position:relative;width:300px;height:300px;
  filter:drop-shadow(0 0 32px rgba(246,201,69,.22)) drop-shadow(0 0 70px rgba(59,130,246,.14));
  user-select:none}
.robot-img{width:100%;height:100%;object-fit:contain;display:block}
.eye{
  position:absolute;width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
  background:radial-gradient(circle,#0a1830 60%,#0e2040);
  box-shadow:inset 0 0 12px rgba(59,130,246,.4),0 0 16px rgba(59,130,246,.3)}
.eye-l{top:40%;left:20%}
.eye-r{top:40%;right:20%}
.pupil{
  width:22px;height:22px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#7dd3fc,#3b82f6 50%,#1d4ed8);
  box-shadow:0 0 10px rgba(59,130,246,.8);
  will-change:transform}
.lform{
  width:340px;
  background:rgba(22,29,46,.88);
  backdrop-filter:blur(20px);
  border:1px solid var(--line);
  border-radius:20px;padding:24px 22px}
.lform label:first-child{margin-top:0}
.lform .btn{width:100%;justify-content:center;margin-top:18px}
.lhint{font-size:11px;color:rgba(59,130,246,.65);margin:0;letter-spacing:.2px}
.lhint a{color:rgba(59,130,246,.9);border-bottom:1px solid rgba(59,130,246,.25);transition:color .2s,border-color .2s}
.lhint a:hover{color:#93c5fd;border-bottom-color:#93c5fd}
.lform .err{margin-top:14px;background:rgba(239,68,68,.12);border:1px solid var(--danger);color:#ffb4b4;border-radius:11px;padding:10px 14px;font-size:14px}
