/* Arcanum Nexus — мережа Minecraft серверів. Стиль: містична темна магія + бурштин */
:root{
  --bg-0:#06030c;
  --bg-1:#0e0820;
  --bg-2:#16102b;
  --bg-3:#22142d;
  --line:rgba(200,159,255,.12);
  --line-strong:rgba(200,159,255,.25);
  --violet:#c89fff;
  --violet-2:#a855f7;
  --violet-3:#67188c;
  --amber:#ffb347;
  --amber-2:#ffd27a;
  --frost:#efe3ff;
  --lav:#bda9d6;
  --rose:#ff7b93;
  --red:#ff6b7a;
  --green:#84e1a3;
  --shadow-glow:0 0 60px rgba(200,159,255,.18), 0 0 120px rgba(255,179,71,.08);
  --r-sm:8px;
  --r-md:14px;
  --r-lg:22px;
  --container:1200px;
  --header-h:68px;
}

*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none!important}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--bg-0);
  color:var(--frost);
  font-family:"Inter","Segoe UI","Helvetica Neue",system-ui,sans-serif;
  font-size:16px;
  line-height:1.55;
  overflow-x:hidden;
  min-height:100vh;
}
img,svg{display:block;max-width:100%}
a{color:var(--violet);text-decoration:none;transition:color .2s}
a:hover{color:var(--amber)}
button{font-family:inherit}

/* ── Stardust фон ─────────────────────────────── */
.stardust{
  position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(ellipse at 20% 10%, rgba(103,24,140,.35) 0%, transparent 55%),
    radial-gradient(ellipse at 85% 20%, rgba(168,85,247,.2) 0%, transparent 55%),
    radial-gradient(ellipse at 50% 90%, rgba(255,179,71,.08) 0%, transparent 55%),
    linear-gradient(180deg, #06030c 0%, #0a0614 60%, #06030c 100%);
}
.stardust::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(1px 1px at 12% 22%, #fff 1px, transparent 1.5px),
    radial-gradient(1px 1px at 28% 65%, #d6c1ff 1px, transparent 1.5px),
    radial-gradient(1px 1px at 47% 14%, #fff 1px, transparent 1.5px),
    radial-gradient(1.5px 1.5px at 63% 78%, #ffd27a 1px, transparent 2px),
    radial-gradient(1px 1px at 81% 36%, #fff 1px, transparent 1.5px),
    radial-gradient(1px 1px at 91% 88%, #c89fff 1px, transparent 1.5px),
    radial-gradient(1.5px 1.5px at 9% 80%, #fff 1px, transparent 2px),
    radial-gradient(1px 1px at 35% 92%, #d6c1ff 1px, transparent 1.5px);
  opacity:.7;animation:twinkle 8s ease-in-out infinite alternate;
}
@keyframes twinkle{from{opacity:.4}to{opacity:.85}}

/* ── Header ───────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:50;
  height:var(--header-h);
  display:flex;align-items:center;
  background:rgba(8,4,16,.78);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.header-inner{
  width:100%;max-width:var(--container);
  margin:0 auto;padding:0 20px;
  display:flex;align-items:center;gap:16px;
}
.brand{display:flex;align-items:center;gap:10px;flex:0 0 auto;text-decoration:none}
.brand-mark{width:34px;height:34px;flex:0 0 auto}
.brand-name{
  font-family:"Cinzel","Georgia",serif;font-weight:700;
  font-size:18px;letter-spacing:.06em;
  background:linear-gradient(90deg,#c89fff,#ffd27a);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  white-space:nowrap;
}
.tabs{
  flex:1 1 auto;display:flex;gap:4px;
  overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;
  scroll-snap-type:x proximity;
}
.tabs::-webkit-scrollbar{display:none}
.tab{
  appearance:none;border:0;background:transparent;color:var(--lav);
  padding:10px 14px;border-radius:var(--r-sm);
  font-size:14px;font-weight:500;cursor:pointer;
  white-space:nowrap;letter-spacing:.02em;
  transition:background .2s,color .2s;
  scroll-snap-align:start;
}
.tab:hover{color:var(--frost);background:rgba(200,159,255,.06)}
.tab[aria-selected="true"]{
  color:var(--frost);
  background:linear-gradient(180deg,rgba(168,85,247,.18),rgba(168,85,247,.04));
  box-shadow:inset 0 -2px 0 var(--violet);
}
.discord-btn{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:8px;
  background:#5865F2;color:#fff;border:0;
  padding:9px 14px;border-radius:var(--r-sm);
  font-weight:600;font-size:14px;cursor:pointer;
  transition:transform .15s,box-shadow .2s,background .2s;
  text-decoration:none;
}
.discord-btn:hover{background:#6d77ff;transform:translateY(-1px);box-shadow:0 8px 24px rgba(88,101,242,.4);color:#fff}
.discord-btn svg{width:18px;height:18px}

/* Burger for mobile */
.burger{
  display:none;
  background:transparent;border:1px solid var(--line-strong);
  width:40px;height:40px;border-radius:var(--r-sm);cursor:pointer;
  flex:0 0 auto;align-items:center;justify-content:center;flex-direction:column;
  gap:5px;padding:11px 10px;transition:border-color .15s,background .15s;
  -webkit-tap-highlight-color:rgba(200,159,255,.3);
}
.burger:hover{border-color:var(--violet);background:rgba(200,159,255,.06)}
.burger span{
  display:block;width:18px;height:2px;border-radius:1px;
  background:linear-gradient(90deg,var(--violet),var(--amber));
  transition:transform .25s ease,opacity .15s ease;
}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile navigation dropdown */
.mobnav{
  display:none;position:absolute;top:100%;left:0;right:0;
  background:linear-gradient(180deg,rgba(8,4,16,.98),rgba(14,8,32,.98));
  border-bottom:1px solid var(--line-strong);
  box-shadow:0 12px 40px rgba(0,0,0,.55), inset 0 1px 0 rgba(200,159,255,.06);
  backdrop-filter:blur(16px);overflow:hidden;
  max-height:0;transition:max-height .25s ease;
  z-index:60;
}
.mobnav[data-open="true"]{display:block;max-height:calc(100vh - var(--header-h))}
.mobnav__pane{
  display:flex;flex-direction:column;padding:8px 0;
  max-height:calc(100vh - var(--header-h));overflow-y:auto;
}
.mobnav__pane--cascade{
  background:radial-gradient(ellipse at 100% 0%, rgba(168,85,247,.12) 0%, transparent 55%);
}
.mobnav__pane[hidden]{display:none}

.mobnav__item{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 20px;font-size:15px;color:var(--lav);font-weight:500;
  background:transparent;border:0;border-radius:0;cursor:pointer;
  text-align:left;text-decoration:none;
  border-bottom:1px solid var(--line);
  transition:background .12s,color .15s;
}
.mobnav__item:last-child{border-bottom:0}
.mobnav__item:hover, .mobnav__item:active{
  color:var(--frost);background:rgba(200,159,255,.08);
}
.mobnav__item[aria-selected="true"]{
  color:var(--frost);background:rgba(168,85,247,.12);
  box-shadow:inset 3px 0 0 var(--violet);
}
.mobnav__item svg{width:18px;height:18px;flex:0 0 auto;color:var(--lav)}
.mobnav__item:hover svg, .mobnav__item--cabinet svg{color:var(--violet)}
.mobnav__item--link{color:var(--lav)}
.mobnav__item--discord{color:#9aa6ff}
.mobnav__item--discord:hover{color:#fff;background:rgba(88,101,242,.18)}
.mobnav__item--discord svg{color:#5865F2}
.mobnav__item--cabinet{
  font-weight:600;color:var(--frost);
  background:linear-gradient(90deg,rgba(168,85,247,.1),transparent);
}
/* "Світи" cascade button — softer on mobile, no harsh white text */
.mobnav__item--cascade{
  color:var(--lav); font-weight:500;
}
.mobnav__item--cascade:hover, .mobnav__item--cascade:active{
  color:var(--violet); background:rgba(168,85,247,.10);
}
.mobnav__item--cascade .mobnav__chev{ opacity:.7 }
.mobnav__chev{width:16px;height:16px;color:var(--violet);flex:0 0 auto}

.mobnav__badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:20px;height:20px;padding:0 6px;border-radius:10px;
  background:linear-gradient(135deg,var(--violet-2),var(--amber));
  color:#fff;font-size:11px;font-weight:700;
}
.mobnav__sep{
  border:0;border-top:1px solid var(--line);
  margin:4px 16px;opacity:.6;
}

.mobnav__back{
  display:flex;align-items:center;gap:10px;
  padding:14px 20px;font-family:"Cinzel",serif;font-size:15px;
  color:var(--violet);font-weight:600;letter-spacing:.04em;
  background:transparent;border:0;cursor:pointer;width:100%;text-align:left;
  border-bottom:1px solid var(--line-strong);
}
.mobnav__back:hover{color:var(--amber);background:rgba(200,159,255,.05)}
.mobnav__back svg{width:18px;height:18px;color:inherit}

.mobnav__world{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 20px;background:transparent;border:0;cursor:pointer;
  text-align:left;border-bottom:1px solid var(--line);
}
.mobnav__world:hover, .mobnav__world:active{
  background:rgba(200,159,255,.06);
}
.mobnav__world-name{color:var(--frost);font-size:15px;font-weight:500}
.mobnav__world-meta{
  display:inline-flex;align-items:center;gap:8px;flex:0 0 auto;
  color:var(--lav);font-size:13px;
}
.mobnav__world-dot{
  width:8px;height:8px;border-radius:50%;background:var(--red);
  box-shadow:0 0 6px rgba(255,107,122,.4);
}
.mobnav__world[data-online="true"] .mobnav__world-dot{
  background:var(--green);box-shadow:0 0 8px rgba(132,225,163,.6);
}
.mobnav__world-count{
  font-family:"JetBrains Mono",monospace;color:var(--frost);
  font-weight:600;min-width:24px;text-align:right;
}

.mobnav__backdrop{
  position:fixed;inset:var(--header-h) 0 0 0;
  background:rgba(6,3,12,.55);backdrop-filter:blur(2px);
  z-index:55;
  opacity:0;transition:opacity .2s;pointer-events:none;
}
.mobnav__backdrop[data-open="true"]{opacity:1;pointer-events:auto}

@media (max-width:720px){
  .burger{display:inline-flex}
  .tabs{display:none}
  /* Discord button collapses to icon-only on mobile; messenger/cabinet stay */
  .discord-btn span{display:none}
  .discord-btn{padding:8px 11px;min-width:38px;justify-content:center}
}
@media (max-width:480px){
  .msg-btn .msg-btn__name{display:none}
  .cabinet-btn .cabinet-btn__name{display:none}
  .header-inner{gap:8px;padding:0 12px}
  .msg-btn,.cabinet-btn{padding:8px 11px;min-width:38px;justify-content:center}
}

/* ── Layout ───────────────────────────────────── */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 20px}
.panel{display:none;animation:fadein .4s ease}
.panel.active{display:block}
@keyframes fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── Dev warning ──────────────────────────────── */
.dev-warning{
  background:linear-gradient(90deg,rgba(255,107,122,.18),rgba(255,123,147,.08));
  border-top:1px solid rgba(255,107,122,.4);
  border-bottom:1px solid rgba(255,107,122,.4);
  padding:12px 0;
}
.dev-warning .container{display:flex;align-items:center;gap:12px;justify-content:center;flex-wrap:wrap}
.dev-warning__icon{width:22px;height:22px;flex:0 0 auto;color:var(--red);filter:drop-shadow(0 0 8px rgba(255,107,122,.6));animation:pulse 2s ease-in-out infinite}
.dev-warning__text{color:var(--red);font-weight:600;font-size:14px;letter-spacing:.02em;text-align:center}
@keyframes pulse{0%,100%{opacity:.85}50%{opacity:1}}

/* ── HERO ─────────────────────────────────────── */
.hero{position:relative;padding:80px 0 60px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,440px);gap:48px;align-items:center}
.eyebrow{
  display:inline-block;font-size:12px;font-weight:600;
  text-transform:uppercase;letter-spacing:.18em;
  color:var(--amber);
  padding:6px 12px;border:1px solid rgba(255,179,71,.3);border-radius:999px;
  background:rgba(255,179,71,.06);
}
.hero h1{
  font-family:"Cinzel","Georgia",serif;font-weight:700;
  font-size:clamp(36px,6vw,68px);
  line-height:1.05;margin:18px 0 18px;letter-spacing:-.01em;
}
.hero h1 .grad{
  background:linear-gradient(120deg,#c89fff 0%,#ffd27a 50%,#c89fff 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shimmer 6s linear infinite;
}
@keyframes shimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}
.hero p.lead{font-size:18px;color:var(--lav);max-width:620px;margin:0 0 28px}

/* IP block */
.ip-card{
  display:flex;align-items:stretch;gap:0;
  background:linear-gradient(180deg,rgba(34,20,45,.85),rgba(14,8,32,.85));
  border:1px solid var(--line-strong);
  border-radius:var(--r-md);
  overflow:hidden;max-width:520px;
  box-shadow:var(--shadow-glow);
}
.ip-card__label{padding:14px 18px;border-right:1px solid var(--line);display:flex;flex-direction:column;justify-content:center;font-size:12px;color:var(--lav);text-transform:uppercase;letter-spacing:.14em}
.ip-card__label strong{color:var(--frost);font-size:11px}
.ip-card__addr{
  flex:1 1 auto;display:flex;align-items:center;
  padding:14px 18px;
  font-family:"JetBrains Mono","Consolas",monospace;
  font-size:18px;color:var(--frost);font-weight:600;
  letter-spacing:.02em;
  user-select:all;
}
.ip-card__copy{
  appearance:none;border:0;border-left:1px solid var(--line);
  background:rgba(200,159,255,.05);color:var(--violet);
  padding:0 20px;cursor:pointer;font-weight:600;font-size:14px;
  transition:background .15s,color .15s;
  display:flex;align-items:center;gap:8px;
}
.ip-card__copy:hover{background:rgba(200,159,255,.15);color:var(--frost)}
.ip-card__copy svg{width:16px;height:16px}
.ip-card__copy.copied{color:var(--green)}
.version-pill{display:inline-block;margin-top:14px;padding:5px 12px;font-size:13px;color:var(--violet);background:rgba(200,159,255,.1);border-radius:999px;font-family:monospace}

.cta-row{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}
.btn{
  appearance:none;border:0;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 24px;border-radius:var(--r-md);
  font-size:15px;font-weight:600;letter-spacing:.02em;
  transition:transform .15s,box-shadow .2s,background .2s,color .2s,border-color .2s;
  text-decoration:none;
}
.btn-primary{
  background:linear-gradient(135deg,#67188c 0%,#a855f7 50%,#ffb347 130%);
  color:#fff;
  box-shadow:0 6px 24px rgba(168,85,247,.4);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(168,85,247,.55);color:#fff}
.btn-ghost{background:transparent;color:var(--frost);border:1px solid var(--line-strong)}
.btn-ghost:hover{border-color:var(--violet);color:var(--violet);background:rgba(200,159,255,.06)}
.btn-discord{background:#5865F2;color:#fff;box-shadow:0 6px 24px rgba(88,101,242,.4)}
.btn-discord:hover{background:#6d77ff;color:#fff;transform:translateY(-2px)}
.btn svg{width:18px;height:18px}

/* Hero portal SVG */
.hero-art{position:relative;width:100%;aspect-ratio:1/1;max-width:440px;margin-left:auto}
.hero-art svg{width:100%;height:100%;filter:drop-shadow(0 0 50px rgba(200,159,255,.4))}
.hero-art .ring{transform-origin:50% 50%;animation:rotate 60s linear infinite}
.hero-art .ring--rev{animation:rotate 90s linear infinite reverse}
@keyframes rotate{to{transform:rotate(360deg)}}

/* ── Section ──────────────────────────────────── */
.section{padding:64px 0}
.section-head{text-align:center;max-width:760px;margin:0 auto 48px}
.section-head h2{
  font-family:"Cinzel","Georgia",serif;font-weight:700;
  font-size:clamp(28px,4.5vw,44px);
  margin:14px 0 12px;letter-spacing:-.01em;
}
.section-head h2 .grad{
  background:linear-gradient(120deg,#c89fff,#ffd27a);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-head p{color:var(--lav);font-size:17px;margin:0}
.lyric{
  font-style:italic;color:var(--violet);
  font-family:"Spectral","Georgia",serif;font-size:18px;
  max-width:680px;margin:0 auto 16px;
  border-left:2px solid rgba(200,159,255,.4);padding-left:16px;text-align:left;
  position:relative;
}
.lyric::before{
  content:"❝";position:absolute;left:8px;top:-12px;
  color:var(--amber);font-size:26px;font-style:normal;
  background:var(--bg-0);padding:0 4px;
}

/* Server hero */
.server-hero{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,360px);
  gap:36px;align-items:center;
  background:linear-gradient(135deg,rgba(34,20,45,.7),rgba(14,8,32,.7));
  border:1px solid var(--line-strong);
  border-radius:var(--r-lg);
  padding:36px;margin-bottom:40px;
  position:relative;overflow:hidden;
}
.server-hero::before{
  content:"";position:absolute;inset:-1px;
  background:radial-gradient(circle at 90% 0%, rgba(168,85,247,.18), transparent 60%);
  pointer-events:none;
}
.server-hero__art{position:relative;aspect-ratio:1/1;max-width:340px;margin:0 auto}
.server-hero__art svg{width:100%;height:100%}
.server-hero__title{
  font-family:"Cinzel","Georgia",serif;font-weight:700;
  font-size:clamp(28px,4vw,40px);margin:8px 0 14px;
  background:linear-gradient(120deg,#efe3ff 0%,#c89fff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.server-hero__desc{font-size:16px;color:var(--lav);margin:0}
.server-hero__meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 11px;border-radius:999px;font-size:12px;font-weight:500;
  background:rgba(200,159,255,.08);color:var(--violet);
  border:1px solid rgba(200,159,255,.2);
}
.chip--amber{color:var(--amber);background:rgba(255,179,71,.06);border-color:rgba(255,179,71,.25)}

/* Feature grid */
.features{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}
.feature{
  background:linear-gradient(180deg,rgba(34,20,45,.55),rgba(14,8,32,.55));
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:22px;
  transition:transform .2s,border-color .2s,box-shadow .25s;
  position:relative;overflow:hidden;
}
.feature:hover{transform:translateY(-3px);border-color:rgba(200,159,255,.35);box-shadow:0 12px 40px rgba(103,24,140,.25)}
.feature__icon{width:38px;height:38px;color:var(--amber);margin-bottom:12px;filter:drop-shadow(0 0 8px rgba(255,179,71,.35))}
.feature h3{margin:0 0 8px;font-size:17px;color:var(--frost);font-weight:600}
.feature p{margin:0;font-size:14px;color:var(--lav);line-height:1.6}

/* CTA panel */
.cta-card{
  text-align:center;padding:40px 24px;margin-top:36px;
  background:linear-gradient(135deg,rgba(103,24,140,.35),rgba(255,179,71,.1));
  border:1px solid rgba(200,159,255,.25);
  border-radius:var(--r-lg);
}
.cta-card h3{font-family:"Cinzel","Georgia",serif;font-size:24px;margin:0 0 8px;color:var(--frost)}
.cta-card p{color:var(--lav);margin:0 0 22px}

/* ── Live status ──────────────────────────────── */
.network-status{
  display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
  background:linear-gradient(180deg,rgba(34,20,45,.85),rgba(14,8,32,.85));
  border:1px solid var(--line-strong);border-radius:var(--r-md);
  padding:14px 22px;margin:24px auto 0;max-width:560px;
}
.network-status__pulse{position:relative;width:14px;height:14px;flex:0 0 auto}
.network-status__pulse::before,
.network-status__pulse::after{
  content:"";position:absolute;inset:0;border-radius:50%;
}
.network-status__pulse::before{background:var(--green);box-shadow:0 0 14px var(--green)}
.network-status__pulse::after{
  background:var(--green);opacity:.5;animation:ping 1.6s ease-out infinite;
}
.network-status[data-state="offline"] .network-status__pulse::before{background:var(--red);box-shadow:0 0 14px var(--red)}
.network-status[data-state="offline"] .network-status__pulse::after{background:var(--red);animation:none;opacity:0}
.network-status[data-state="loading"] .network-status__pulse::before{background:var(--lav);box-shadow:none}
.network-status[data-state="loading"] .network-status__pulse::after{background:var(--lav);opacity:.4}
@keyframes ping{
  0%{transform:scale(1);opacity:.6}
  100%{transform:scale(2.5);opacity:0}
}
.network-status__text{color:var(--frost);font-weight:500}
.network-status__text strong{color:var(--green);font-weight:700;margin:0 4px}
.network-status[data-state="offline"] .network-status__text strong{color:var(--red)}
.network-status[data-state="loading"] .network-status__text strong{color:var(--lav)}

.servers-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;
  margin:36px 0 0;
}
.server-card{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;border-radius:var(--r-md);
  background:linear-gradient(180deg,rgba(34,20,45,.55),rgba(14,8,32,.55));
  border:1px solid var(--line);
  transition:border-color .2s,transform .15s;
  cursor:pointer;
}
.server-card:hover{border-color:rgba(200,159,255,.4);transform:translateY(-2px)}
.server-card__dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto;background:var(--lav);box-shadow:0 0 10px transparent}
.server-card[data-online="true"]  .server-card__dot{background:var(--green);box-shadow:0 0 10px var(--green)}
.server-card[data-online="false"] .server-card__dot{background:var(--red);  box-shadow:0 0 10px var(--red)}
.server-card__body{flex:1 1 auto;min-width:0}
.server-card__name{font-weight:600;color:var(--frost);font-size:15px;letter-spacing:.01em}
.server-card__sub{font-size:12px;color:var(--lav);margin-top:2px}
.server-card[data-online="false"] .server-card__sub{color:var(--rose)}

.live-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 12px;border-radius:999px;font-size:12px;font-weight:600;
  border:1px solid;
}
.live-chip[data-online="true"]{
  color:var(--green);background:rgba(132,225,163,.08);border-color:rgba(132,225,163,.32);
}
.live-chip[data-online="false"]{
  color:var(--red);  background:rgba(255,107,122,.08);border-color:rgba(255,107,122,.32);
}
.live-chip[data-online="loading"]{
  color:var(--lav);  background:rgba(189,169,214,.08);border-color:rgba(189,169,214,.25);
}
.live-chip__dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex:0 0 auto}
.live-chip[data-online="true"] .live-chip__dot{box-shadow:0 0 8px currentColor}

/* ── Cabinet sub-nav (Огляд / Команди / Вікі) ─── */
.cabinet-nav{
  display:flex;gap:6px;flex-wrap:wrap;
  margin:24px 0;padding:6px;
  background:rgba(6,3,12,.4);border:1px solid var(--line);border-radius:var(--r-md);
}
.cabinet-nav__btn{
  flex:1 1 0;min-width:120px;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:transparent;color:var(--lav);border:0;
  padding:11px 14px;border-radius:var(--r-sm);
  font-family:inherit;font-size:14px;font-weight:600;
  cursor:pointer;letter-spacing:.02em;
  transition:background .15s,color .15s;
}
.cabinet-nav__btn:hover{color:var(--frost);background:rgba(200,159,255,.06)}
.cabinet-nav__btn[aria-selected="true"]{
  color:var(--frost);
  background:linear-gradient(180deg,rgba(168,85,247,.22),rgba(168,85,247,.06));
  box-shadow:inset 0 0 0 1px rgba(200,159,255,.3);
}
.cabinet-nav__btn svg{width:16px;height:16px;flex:0 0 auto}

.cabinet-view{animation:fadein .25s ease}

/* ── Commands list ─────────────────────────────── */
.commands-toolbar{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin-bottom:16px;
}
.commands-search{
  flex:1 1 280px;display:flex;align-items:center;gap:10px;
  padding:0 14px;
  background:rgba(6,3,12,.6);border:1px solid var(--line-strong);border-radius:var(--r-sm);
}
.commands-search svg{width:16px;height:16px;color:var(--lav);flex:0 0 auto}
.commands-search input{
  flex:1 1 0;background:transparent;border:0;outline:none;
  color:var(--frost);font-family:inherit;font-size:14px;
  padding:11px 0;
}
.commands-meta{font-size:12px;color:var(--lav);font-weight:500;text-align:right}

.commands-empty{
  padding:48px 24px;text-align:center;color:var(--lav);
  background:linear-gradient(180deg,rgba(34,20,45,.4),rgba(14,8,32,.4));
  border:1px dashed var(--line-strong);border-radius:var(--r-lg);
}
.commands-empty__title{font-family:"Cinzel",serif;font-size:22px;color:var(--frost);margin-bottom:6px}
.commands-empty__sub{font-size:14px;color:var(--lav);max-width:480px;margin:0 auto}

.commands-group{margin-bottom:18px}
.commands-group__head{
  display:flex;align-items:baseline;gap:10px;
  font-family:"Cinzel",serif;font-size:14px;color:var(--violet);
  text-transform:uppercase;letter-spacing:.14em;
  margin:0 0 8px;padding-left:6px;
}
.commands-group__count{
  color:var(--lav);font-family:"Inter",sans-serif;font-size:11px;
  text-transform:none;letter-spacing:.02em;font-weight:500;
}
.commands-group__scope{
  display:inline-block;font-size:10px;font-family:"Inter";font-weight:600;
  padding:2px 8px;border-radius:99px;
  background:rgba(255,179,71,.1);color:var(--amber);
  border:1px solid rgba(255,179,71,.3);
  text-transform:none;letter-spacing:.04em;
}

.cmd-row{
  background:linear-gradient(180deg,rgba(34,20,45,.55),rgba(14,8,32,.55));
  border:1px solid var(--line);border-radius:var(--r-md);
  margin-bottom:6px;overflow:hidden;
  transition:border-color .15s;
}
.cmd-row:hover{border-color:rgba(200,159,255,.25)}
.cmd-row__head{
  display:flex;align-items:center;gap:14px;
  padding:11px 16px;cursor:pointer;user-select:none;
}
.cmd-row__cmd{
  font-family:"JetBrains Mono",monospace;font-weight:600;
  color:var(--frost);font-size:14px;flex:0 0 auto;
}
.cmd-row__desc{
  flex:1 1 0;color:var(--lav);font-size:13px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  min-width:0;
}
.cmd-row__chev{
  width:18px;height:18px;color:var(--lav);flex:0 0 auto;
  transition:transform .2s;
}
.cmd-row[data-open="true"] .cmd-row__chev{transform:rotate(180deg)}
.cmd-row__body{
  display:none;padding:0 16px 14px;
  border-top:1px solid var(--line);
  background:rgba(6,3,12,.35);
}
.cmd-row[data-open="true"] .cmd-row__body{display:block;animation:fadein .2s ease}
.cmd-row__usage{
  font-family:"JetBrains Mono",monospace;font-size:13px;
  color:var(--violet);
  background:rgba(6,3,12,.6);
  padding:8px 12px;border-radius:var(--r-sm);
  margin:14px 0 8px;
  white-space:pre-wrap;word-break:break-word;
}
.cmd-row__full{margin:8px 0 0;color:var(--frost);font-size:14px;line-height:1.55}
.cmd-row__perm{font-family:monospace;font-size:11px;color:var(--lav);margin-top:6px}
.cmd-row__perm code{color:var(--amber);background:rgba(255,179,71,.06);padding:1px 5px;border-radius:3px}

/* ── Wiki ──────────────────────────────────────── */
.cabinet-view[data-cabinet-view-pane="wiki"]{
  display:grid;grid-template-columns:240px minmax(0,1fr);gap:20px;
}
.wiki-side{
  background:linear-gradient(180deg,rgba(34,20,45,.55),rgba(14,8,32,.55));
  border:1px solid var(--line);border-radius:var(--r-md);
  padding:8px;align-self:start;position:sticky;top:80px;max-height:calc(100vh - 110px);overflow-y:auto;
}
.wiki-side__btn{
  display:flex;width:100%;align-items:center;gap:10px;
  background:transparent;border:0;color:var(--lav);
  padding:10px 12px;border-radius:var(--r-sm);
  font-family:inherit;font-size:13px;text-align:left;cursor:pointer;
  transition:background .15s,color .15s;
}
.wiki-side__btn:hover{color:var(--frost);background:rgba(200,159,255,.06)}
.wiki-side__btn[aria-selected="true"]{
  color:var(--frost);
  background:linear-gradient(180deg,rgba(168,85,247,.18),rgba(168,85,247,.04));
  box-shadow:inset 0 0 0 1px rgba(200,159,255,.3);
}
.wiki-side__icon{font-size:14px;flex:0 0 auto;color:var(--amber)}
.wiki-side__title{font-weight:600}
.wiki-side__sub{font-size:11px;color:var(--lav);margin-top:1px}
.wiki-side__btn[aria-selected="true"] .wiki-side__sub{color:var(--violet)}

.wiki-content{
  background:linear-gradient(180deg,rgba(34,20,45,.55),rgba(14,8,32,.55));
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:32px;line-height:1.65;color:var(--frost);
}
.wiki-content h2{font-family:"Cinzel",serif;font-size:32px;margin:0 0 8px;
  background:linear-gradient(120deg,#c89fff,#ffd27a);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.wiki-content h3{font-family:"Cinzel",serif;font-size:20px;color:var(--frost);margin:24px 0 8px}
.wiki-content p{margin:0 0 12px;color:var(--frost)}
.wiki-content p.lede{font-size:16px;color:var(--lav);font-style:italic;margin-bottom:18px}
.wiki-content code{font-family:"JetBrains Mono",monospace;font-size:12px;
  background:rgba(6,3,12,.7);padding:2px 6px;border-radius:4px;color:var(--amber)}
.wiki-content pre{
  background:rgba(6,3,12,.7);padding:14px 16px;border-radius:var(--r-sm);
  border:1px solid var(--line);overflow-x:auto;
  font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--frost);line-height:1.5;
}
.wiki-content pre code{background:transparent;padding:0;color:inherit}
.wiki-content ul{margin:8px 0 16px;padding-left:22px}
.wiki-content li{margin-bottom:4px}
.wiki-content blockquote.wiki-quote{
  margin:14px 0;padding:14px 18px;
  background:rgba(168,85,247,.08);border-left:3px solid var(--violet);
  border-radius:0 var(--r-sm) var(--r-sm) 0;
  font-style:italic;color:var(--violet);
}
.wiki-content .muted{color:var(--lav);font-size:13px}
table.wiki-table{
  width:100%;border-collapse:collapse;font-size:13px;margin:8px 0 18px;
}
.wiki-table th, .wiki-table td{
  text-align:left;padding:8px 12px;
  border-bottom:1px solid var(--line);
}
.wiki-table th{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--lav)}
.wiki-table td{color:var(--frost)}

@media (max-width: 720px){
  .cabinet-view[data-cabinet-view-pane="wiki"]{grid-template-columns:1fr}
  .wiki-side{position:static;max-height:none}
  .wiki-content{padding:22px 18px}
  .commands-toolbar{flex-direction:column;align-items:stretch}
  .commands-meta{text-align:left}
}

/* ══ Messenger ═════════════════════════════════ */
.cabinet-nav__badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 6px;margin-left:6px;
  background:linear-gradient(135deg,#ff7b93,#ffb347);
  color:#0e0820;font-size:10px;font-weight:700;border-radius:99px;
  box-shadow:0 0 10px rgba(255,123,147,.5);
}

.msg-shell{
  display:grid;grid-template-columns:320px minmax(0,1fr);gap:18px;
  height:calc(100vh - 240px);min-height:520px;
}

.msg-side{
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,rgba(34,20,45,.6),rgba(14,8,32,.6));
  border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;
}
.msg-tabs{
  display:flex;border-bottom:1px solid var(--line);
}
.msg-tab{
  flex:1 1 0;display:flex;align-items:center;justify-content:center;gap:6px;
  background:transparent;border:0;color:var(--lav);
  padding:14px 8px;cursor:pointer;font-family:inherit;font-weight:600;font-size:12px;
  transition:background .15s,color .15s;
  border-bottom:2px solid transparent;
}
.msg-tab svg{width:14px;height:14px}
.msg-tab:hover{color:var(--frost);background:rgba(200,159,255,.05)}
.msg-tab[aria-selected="true"]{
  color:var(--frost);border-bottom-color:var(--violet);
  background:linear-gradient(180deg,rgba(168,85,247,.15),transparent);
}
.msg-side__body{flex:1 1 0;overflow:hidden;display:flex;flex-direction:column;min-height:0}
.msg-pane{flex:1 1 0;display:flex;flex-direction:column;min-height:0}
.msg-pane[hidden]{display:none!important}

.msg-search{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;border-bottom:1px solid var(--line);
}
.msg-search svg{width:14px;height:14px;color:var(--lav);flex:0 0 auto}
.msg-search input{
  flex:1 1 0;background:transparent;border:0;outline:none;
  color:var(--frost);font-family:inherit;font-size:13px;padding:6px 0;
}
.msg-newchat-btn{
  background:linear-gradient(135deg,#67188c,#ffb347);
  border:0;color:#fff;cursor:pointer;
  width:30px;height:30px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;flex:0 0 auto;
  transition:transform .12s;
}
.msg-newchat-btn:hover{transform:scale(1.08)}
.msg-newchat-btn svg{width:14px;height:14px}

.msg-contacts{
  list-style:none;margin:0;padding:6px 6px 0;
  overflow-y:auto;flex:1 1 0;
}
.msg-contact{
  display:flex;align-items:center;gap:11px;
  padding:9px 10px;border-radius:var(--r-sm);cursor:pointer;
  transition:background .12s;margin-bottom:1px;
}
.msg-contact:hover{background:rgba(200,159,255,.06)}
.msg-contact.active{background:linear-gradient(180deg,rgba(168,85,247,.22),rgba(168,85,247,.06))}
.msg-contact__face{
  width:38px;height:38px;border-radius:8px;flex:0 0 auto;
  position:relative;background:rgba(6,3,12,.5);
  image-rendering:pixelated;
}
.msg-contact__face::after{
  content:"";position:absolute;bottom:-2px;right:-2px;
  width:11px;height:11px;border-radius:50%;
  background:transparent;border:2px solid #0e0820;
}
.msg-contact[data-online="true"] .msg-contact__face::after{
  background:var(--green);box-shadow:0 0 8px var(--green);
}
.msg-contact__body{flex:1 1 0;min-width:0}
.msg-contact__name{
  font-weight:600;color:var(--frost);font-size:14px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.msg-contact__preview{
  font-size:12px;color:var(--lav);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-top:1px;
}
.msg-contact__status-tag{
  display:inline-block;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  background:rgba(200,159,255,.12);color:var(--violet);
  padding:1px 5px;border-radius:99px;margin-left:6px;vertical-align:middle;
}
.msg-contact__status-tag[data-status="pending"]{background:rgba(189,169,214,.12);color:var(--lav)}
.msg-contact__unread{
  flex:0 0 auto;
  display:inline-flex;align-items:center;justify-content:center;
  min-width:20px;height:20px;padding:0 6px;
  background:linear-gradient(135deg,#ff7b93,#ffb347);color:#0e0820;
  font-size:10px;font-weight:700;border-radius:99px;
}

.msg-worlds{
  list-style:none;margin:0;padding:6px;overflow-y:auto;flex:1 1 0;
}
.msg-world{
  display:flex;align-items:center;gap:11px;
  padding:11px 12px;border-radius:var(--r-sm);cursor:pointer;
  margin-bottom:2px;transition:background .12s;
}
.msg-world:hover{background:rgba(200,159,255,.06)}
.msg-world.active{background:linear-gradient(180deg,rgba(168,85,247,.22),rgba(168,85,247,.06))}
.msg-world__icon{
  width:38px;height:38px;border-radius:8px;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-size:20px;
  background:linear-gradient(135deg,#67188c,#ffb347);color:#fff;
}
.msg-world__body{flex:1 1 0;min-width:0}
.msg-world__name{font-weight:600;color:var(--frost);font-size:14px}
.msg-world__sub{font-size:11px;color:var(--lav);margin-top:1px;display:flex;align-items:center;gap:6px}
.msg-world__dot{width:7px;height:7px;border-radius:50%;background:var(--lav)}
.msg-world[data-online="true"] .msg-world__dot{background:var(--green);box-shadow:0 0 6px var(--green)}
.msg-world[data-online="false"] .msg-world__dot{background:var(--red);box-shadow:0 0 6px var(--red)}

.msg-discord-stub{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:32px 24px;text-align:center;gap:12px;
}
.msg-discord-stub h3{font-family:"Cinzel",serif;color:var(--frost);margin:0}
.msg-discord-stub p{color:var(--lav);font-size:13px;margin:0;max-width:240px}
.msg-stub-tag{
  margin-top:8px;font-size:11px;color:var(--amber);
  background:rgba(255,179,71,.08);padding:5px 12px;border-radius:99px;
  border:1px solid rgba(255,179,71,.3);
}

/* ── Chat thread ─────────────────────────────── */
.msg-thread{
  display:flex;flex-direction:column;min-height:0;
  background:linear-gradient(180deg,rgba(34,20,45,.5),rgba(14,8,32,.5));
  border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;
}
.msg-empty{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:var(--lav);text-align:center;padding:32px;gap:14px;
}
.msg-empty p{margin:0;font-size:14px}
.msg-thread__head{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;border-bottom:1px solid var(--line);
  background:rgba(6,3,12,.4);
}
.msg-thread__face{
  width:42px;height:42px;border-radius:8px;flex:0 0 auto;position:relative;
  image-rendering:pixelated;background:rgba(6,3,12,.5);
}
.msg-thread__face::after{
  content:"";position:absolute;bottom:-2px;right:-2px;
  width:12px;height:12px;border-radius:50%;
  background:transparent;border:2px solid #0e0820;
}
.msg-thread__face[data-online="true"]::after{background:var(--green);box-shadow:0 0 8px var(--green)}
.msg-thread__name{font-family:"Cinzel",serif;font-size:17px;color:var(--frost);margin:0}
.msg-thread__sub{font-size:12px;color:var(--lav);margin-top:2px;display:flex;align-items:center;gap:6px}
.msg-thread__sub-dot{width:7px;height:7px;border-radius:50%}
.msg-thread__sub[data-online="true"] .msg-thread__sub-dot{background:var(--green);box-shadow:0 0 6px var(--green)}
.msg-thread__sub[data-online="false"] .msg-thread__sub-dot{background:var(--red);box-shadow:0 0 6px var(--red)}

.msg-thread__body{
  flex:1 1 0;overflow-y:auto;padding:20px;
  display:flex;flex-direction:column;gap:8px;
}
.msg-bubble{
  max-width:75%;padding:9px 14px;border-radius:14px;
  font-size:14px;line-height:1.45;word-wrap:break-word;
  position:relative;
}
.msg-bubble--in{
  align-self:flex-start;
  background:rgba(200,159,255,.1);border:1px solid rgba(200,159,255,.2);
  color:var(--frost);border-bottom-left-radius:4px;
}
.msg-bubble--out{
  align-self:flex-end;
  background:linear-gradient(135deg,#67188c,#a855f7);
  color:#fff;border-bottom-right-radius:4px;
}
.msg-bubble__meta{
  display:block;font-size:10px;opacity:.7;margin-top:3px;
  font-family:"JetBrains Mono",monospace;
}
.msg-bubble--out .msg-bubble__meta{color:rgba(255,255,255,.7)}
.msg-bubble__src-tag{
  display:inline-block;font-size:9px;font-weight:700;
  padding:1px 5px;border-radius:99px;margin-left:5px;
  background:rgba(255,179,71,.2);color:var(--amber);
  letter-spacing:.04em;text-transform:uppercase;
}

.msg-thread__compose{
  border-top:1px solid var(--line);padding:12px 14px;
  display:flex;gap:10px;align-items:flex-end;
  background:rgba(6,3,12,.4);
}
.msg-thread__compose textarea{
  flex:1;resize:none;min-height:36px;max-height:120px;
  background:rgba(6,3,12,.6);border:1px solid var(--line);
  color:var(--frost);font-family:inherit;font-size:14px;line-height:1.5;
  padding:9px 13px;border-radius:10px;outline:none;
}
.msg-thread__compose textarea:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(200,159,255,.15)}
.msg-thread__compose button{
  flex:0 0 auto;background:linear-gradient(135deg,#67188c,#a855f7,#ffb347);
  color:#fff;border:0;cursor:pointer;width:40px;height:40px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  transition:transform .12s;
}
.msg-thread__compose button svg{width:18px;height:18px}
.msg-thread__compose button:hover{transform:translateY(-1px)}
.msg-thread__compose button:disabled{opacity:.5;cursor:not-allowed}

.msg-thread__error{
  padding:10px 18px;background:rgba(255,107,122,.1);
  border-top:1px solid rgba(255,107,122,.3);
  color:var(--red);font-size:12px;text-align:center;
  display:none;
}
.msg-thread__error[data-shown="true"]{display:block}

@media (max-width: 920px){
  .msg-shell{grid-template-columns:1fr;height:auto}
  .msg-side{height:300px}
}

/* ── Nick/displayname section ──────────────── */
.nick-current{
  display:flex;align-items:baseline;gap:10px;
  background:rgba(6,3,12,.4);
  border:1px solid var(--line);border-radius:var(--r-sm);
  padding:12px 16px;margin-bottom:14px;
}
.nick-current__label{font-size:12px;color:var(--lav);text-transform:uppercase;letter-spacing:.06em}
.nick-current__value{font-family:"Cinzel",Georgia,serif;font-size:18px;color:var(--frost)}
[data-nick-counter]{display:block;font-size:11px;color:var(--lav);margin-top:4px;text-align:right}
.nick-locked{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px 16px;margin-top:14px;
  background:linear-gradient(180deg,rgba(189,169,214,.08),rgba(189,169,214,.02));
  border:1px solid var(--line-strong);border-radius:var(--r-sm);
  color:var(--lav);font-size:13px;line-height:1.55;
}
.nick-locked svg{width:22px;height:22px;flex:0 0 auto;color:var(--lav)}
.nick-locked strong{color:var(--amber)}

.nick-actions{
  display:flex;gap:10px;flex-wrap:wrap;margin-top:14px;
}
.nick-actions .btn{
  flex:1 1 200px;min-width:0;justify-content:center;
  padding:12px 16px;font-size:14px;min-height:44px;
}
.nick-actions__apply svg{width:16px;height:16px}
.nick-actions__clear{
  color:var(--lav);
}
.nick-actions__clear:hover{color:var(--rose);border-color:rgba(255,123,147,.5)}
.nick-actions__clear svg{width:15px;height:15px}
.nick-actions__hint{
  margin:8px 0 0;font-size:12px;color:var(--lav);opacity:.75;line-height:1.5;
}
@media (max-width:520px){
  .nick-actions{flex-direction:column;gap:8px}
  .nick-actions .btn{flex:1 1 100%;width:100%}
}

/* ── Top nav: updates badge ──────────────────── */
.tab-badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 5px;margin-left:6px;
  background:linear-gradient(135deg,#ff7b93,#ffb347);
  color:#0e0820;font-size:10px;font-weight:700;border-radius:99px;
  box-shadow:0 0 10px rgba(255,123,147,.5);
}

/* ── Updates feed ──────────────────────────────── */
.updates-stream{
  display:flex;flex-direction:column;gap:16px;
  max-width:920px;margin:0 auto;
}
.update-card{
  background:linear-gradient(180deg,rgba(34,20,45,.6),rgba(14,8,32,.6));
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:24px 28px;
  position:relative;
  transition:border-color .2s,transform .15s;
}
.update-card::before{
  content:"";position:absolute;left:-1px;top:24px;width:3px;height:32px;
  background:linear-gradient(180deg,#c89fff,#ffb347);
  border-radius:0 3px 3px 0;
}
.update-card.is-new::before{background:linear-gradient(180deg,#ff7b93,#ffb347);box-shadow:0 0 12px rgba(255,123,147,.5)}
.update-card:hover{border-color:rgba(200,159,255,.3)}

.update-head{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin-bottom:14px;
}
.update-version{
  font-family:"JetBrains Mono",monospace;font-size:13px;font-weight:700;
  color:var(--violet);background:rgba(168,85,247,.12);
  padding:5px 12px;border-radius:8px;border:1px solid rgba(168,85,247,.4);
  letter-spacing:.02em;
}
.update-date{
  font-family:"JetBrains Mono",monospace;font-size:12px;
  color:var(--amber);background:rgba(255,179,71,.08);
  padding:4px 10px;border-radius:99px;border:1px solid rgba(255,179,71,.25);
}
.update-title{
  font-family:"Cinzel",Georgia,serif;font-size:20px;
  background:linear-gradient(120deg,#c89fff,#ffd27a);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin:0;line-height:1.2;
}
.update-new-tag{
  background:linear-gradient(135deg,#ff7b93,#ffb347);
  color:#0e0820;font-size:10px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;padding:3px 9px;border-radius:99px;
}

.update-body{color:var(--frost);font-size:14px;line-height:1.65}
.update-body h3{font-family:"Cinzel",Georgia,serif;font-size:16px;color:var(--frost);
  margin:18px 0 8px;letter-spacing:.02em}
.update-body h3:first-child{margin-top:6px}
.update-body p{margin:0 0 10px;color:var(--lav)}
.update-body strong{color:var(--frost);font-weight:600}
.update-body code{
  font-family:"JetBrains Mono",monospace;font-size:12px;
  background:rgba(6,3,12,.7);padding:2px 6px;border-radius:4px;color:var(--amber);
}
.update-body pre{
  background:rgba(6,3,12,.7);padding:12px 14px;border-radius:8px;
  border:1px solid var(--line);overflow-x:auto;
  font-family:"JetBrains Mono",monospace;font-size:11px;line-height:1.5;
}
.update-body pre code{background:transparent;padding:0;color:var(--frost)}
.update-body ul,.update-body ol{padding-left:20px;margin:6px 0 12px}
.update-body li{margin-bottom:4px}
.update-body table{border-collapse:collapse;width:100%;margin:6px 0 12px;font-size:13px;display:block;overflow-x:auto}
.update-body th,.update-body td{padding:6px 10px;text-align:left;border-bottom:1px solid var(--line)}
.update-body th{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--lav)}

.update-subs{
  display:flex;flex-wrap:wrap;gap:6px;margin:0 0 14px;
}
.update-sub-chip{
  display:inline-block;
  padding:2px 9px;border-radius:99px;
  font-size:11px;color:var(--violet);
  background:rgba(200,159,255,.08);border:1px solid rgba(200,159,255,.25);
}

/* ── Top nav dropdown (Світи) ──────────────────── */
.tab-dropdown{position:relative}
.tab-dropdown__trigger{display:inline-flex;align-items:center;gap:6px}
.tab-dropdown__chev{width:14px;height:14px;transition:transform .2s}
.tab-dropdown[data-open="true"] .tab-dropdown__chev{transform:rotate(180deg)}
.tab-dropdown__menu{
  display:none;position:fixed;
  min-width:280px;max-width:calc(100vw - 28px);z-index:1100;
  background:linear-gradient(180deg,#16102b,#0e0820);
  border:1px solid var(--line-strong);border-radius:var(--r-md);
  padding:6px;box-shadow:0 18px 48px rgba(0,0,0,.55),0 0 32px rgba(200,159,255,.12);
  animation:fadein .15s ease;
}
.tab-dropdown[data-open="true"] .tab-dropdown__menu{display:block}
.tab-dropdown__item{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  width:100%;padding:9px 12px;border:0;background:transparent;
  color:var(--frost);font-family:inherit;font-size:14px;
  border-radius:var(--r-sm);cursor:pointer;text-align:left;
  transition:background .15s;
}
.tab-dropdown__item:hover{background:rgba(200,159,255,.08)}
.tab-dropdown__name{font-weight:600}
.tab-dropdown__status{display:inline-flex;align-items:center;gap:10px;font-size:12px;color:var(--lav)}
.tab-dropdown__dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--lav);box-shadow:none;
}
.tab-dropdown__status[data-online="true"] .tab-dropdown__dot{background:var(--green);box-shadow:0 0 8px var(--green)}
.tab-dropdown__status[data-online="false"] .tab-dropdown__dot{background:var(--red);box-shadow:0 0 8px var(--red)}
.tab-dropdown__people{display:inline-flex;align-items:center;gap:4px;color:var(--frost);font-weight:600;min-width:34px;justify-content:flex-end}
.tab-dropdown__people svg{width:13px;height:13px;color:var(--violet)}

@media (max-width: 720px){
  .tab-dropdown__menu{min-width:220px;left:auto;right:0}
}

/* ── Leaders ──────────────────────────────────── */
.leaders-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:18px;
}
/* ── News feed (cards on /mc/#news and /vs/#news, fed from /api/news) ──
 * Accordion-style: each card is a clickable header (always visible) plus a
 * collapsible body. The newest post opens by default; clicking the header
 * toggles. CSS grid-template-rows trick gives a smooth height transition
 * even though `details-inner`'s natural height is unknown. */
.news-feed{display:flex;flex-direction:column;gap:14px}
.news-feed .empty{
  padding:42px 24px;text-align:center;color:var(--lav);
  border:1px dashed var(--line);border-radius:14px;font-size:14px;
}

.news-card{
  background:linear-gradient(180deg,rgba(34,20,45,.55),rgba(14,8,32,.55));
  border:1px solid var(--line);border-radius:14px;
  overflow:hidden;transition:border-color .2s, box-shadow .25s;
}
.news-card:hover{border-color:var(--line-strong)}
.news-card--open{
  border-color:var(--line-strong);
  box-shadow:0 8px 30px rgba(168,85,247,.12);
}

.news-card__toggle{
  display:flex;align-items:center;gap:14px;
  width:100%;padding:18px 22px;text-align:left;
  background:transparent;border:0;cursor:pointer;color:inherit;
  font:inherit;
  transition:background .15s;
}
.news-card__toggle:hover{background:rgba(200,159,255,.04)}
.news-card__summary-row{flex:1 1 auto;min-width:0}

.news-card__meta{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-size:11px;color:var(--lav);letter-spacing:.04em;margin-bottom:6px;
}
.news-card__date{
  font-family:"JetBrains Mono",monospace;color:var(--violet);
}
.news-card__pin{font-size:13px;color:var(--amber)}
.news-card__tags{display:flex;gap:4px;flex-wrap:wrap}
.news-card__tag{
  background:rgba(200,159,255,.08);color:var(--violet);
  padding:2px 8px;border-radius:5px;font-size:10px;
  text-transform:uppercase;letter-spacing:.1em;font-weight:700;
}
.news-card__title{
  font-family:"Cinzel",Georgia,serif;font-size:21px;font-weight:700;
  margin:0 0 4px;line-height:1.25;
  background:linear-gradient(120deg,var(--frost),var(--violet),var(--amber));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.news-card__summary{
  font-size:13.5px;color:var(--lav);
  margin:0;line-height:1.5;
}
.news-card__chev{
  width:22px;height:22px;flex:0 0 22px;color:var(--violet);
  transition:transform .3s ease-out;
}
.news-card--open .news-card__chev{transform:rotate(180deg);color:var(--amber)}

/* Smooth height animation via grid template trick — works without JS-measured heights */
.news-card__details{
  display:grid;grid-template-rows:0fr;
  transition:grid-template-rows .35s cubic-bezier(.4,0,.2,1);
}
.news-card--open .news-card__details{grid-template-rows:1fr}
.news-card__details-inner{
  overflow:hidden;
  padding:0 22px;
  /* fade-in body when open */
  opacity:0;transition:opacity .25s ease-out .1s;
}
.news-card--open .news-card__details-inner{opacity:1}
.news-card__details-inner::after{
  content:"";display:block;height:18px;
}

.news-card__hero{
  width:calc(100% + 44px);margin:0 -22px 18px;display:block;
  max-height:280px;object-fit:cover;border-bottom:1px solid var(--line);
}
.news-card__body{font-size:14px;line-height:1.65;color:var(--frost);padding-top:6px}
.news-card__body p{margin:0 0 11px}
.news-card__body p:last-child{margin-bottom:0}
.news-card__body ul{padding-left:22px;margin:0 0 11px;color:var(--frost)}
.news-card__body li{margin-bottom:5px}
.news-card__body code{
  font-family:"JetBrains Mono",monospace;font-size:12.5px;
  background:rgba(200,159,255,.08);padding:1px 6px;border-radius:4px;color:var(--violet);
}
.news-card__body strong{color:var(--frost)}
.news-card__body a{color:var(--violet);border-bottom:1px dotted var(--violet)}
.news-card__body a:hover{color:var(--amber);border-color:var(--amber)}
.news-card__body h2,.news-card__body h3,.news-card__body h4{
  font-family:"Cinzel",Georgia,serif;color:var(--frost);font-weight:700;
  margin:16px 0 7px;
}
.news-card__body h2{font-size:17px}
.news-card__body h3{font-size:15px}
.news-card__body h4{font-size:14px}
.news-card__foot{
  margin-top:14px;font-size:11px;color:var(--lav);opacity:.7;font-family:"JetBrains Mono",monospace;
}
@media (max-width:560px){
  .news-card__toggle{padding:14px 16px;gap:10px}
  .news-card__title{font-size:18px}
  .news-card__details-inner{padding:0 16px}
  .news-card__hero{margin:0 -16px 14px;width:calc(100% + 32px)}
}

.leader-card{
  background:linear-gradient(180deg,rgba(34,20,45,.6),rgba(14,8,32,.6));
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:22px 18px 16px;
}
.leader-card__head{
  display:flex;align-items:center;gap:10px;
  font-family:"Cinzel",serif;font-size:16px;color:var(--frost);
  margin-bottom:14px;padding-bottom:10px;
  border-bottom:1px solid var(--line);
}
.leader-card__icon{
  width:32px;height:32px;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;
  background:linear-gradient(135deg,#67188c,#ffb347);
  border-radius:8px;color:#fff;
}
.leader-row{
  display:flex;align-items:center;gap:10px;
  padding:8px 4px;font-size:14px;
  border-bottom:1px solid rgba(200,159,255,.06);
}
.leader-row:last-child{border-bottom:0}
.leader-row__rank{
  width:26px;flex:0 0 auto;text-align:center;
  font-family:"Cinzel",serif;color:var(--lav);font-size:13px;font-weight:700;
}
.leader-row[data-rank="1"] .leader-row__rank{color:#ffd27a}
.leader-row[data-rank="2"] .leader-row__rank{color:#c89fff}
.leader-row[data-rank="3"] .leader-row__rank{color:#ff7b93}
.leader-row__face{
  width:32px;height:32px;flex:0 0 auto;
  border-radius:6px;background:rgba(6,3,12,.6);
  image-rendering:pixelated;-ms-interpolation-mode:nearest-neighbor;
  border:1px solid var(--line);
}
.leader-row__name{flex:1 1 0;color:var(--frost);font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.leader-row__value{
  flex:0 0 auto;color:var(--amber);font-family:"JetBrains Mono",monospace;
  font-size:13px;font-weight:700;
}

/* Cabinet actions row */
.cabinet-actions{display:flex;gap:8px;flex-wrap:wrap}
.cabinet-actions .btn{padding:9px 14px;font-size:13px}
.cabinet-actions .btn svg{width:14px;height:14px}

/* ── Cabinet entry button ─────────────────────── */
.cabinet-btn{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:7px;
  background:rgba(200,159,255,.08);color:var(--frost);
  border:1px solid var(--line-strong);
  padding:8px 13px;border-radius:var(--r-sm);
  font-weight:600;font-size:14px;cursor:pointer;
  transition:background .2s,border-color .2s,color .2s,transform .1s;
  text-decoration:none;
  touch-action:manipulation;
  -webkit-tap-highlight-color:rgba(200,159,255,.3);
  min-height:38px;
  position:relative;
  z-index:1;
}
.cabinet-btn:active{transform:scale(.96)}
.cabinet-btn:hover{background:rgba(200,159,255,.18);border-color:var(--violet);color:var(--violet)}
.cabinet-btn svg{width:16px;height:16px}
.cabinet-btn[data-state="logged"]{background:linear-gradient(135deg,rgba(103,24,140,.5),rgba(168,85,247,.3));border-color:rgba(200,159,255,.5);color:#fff}
.cabinet-btn .cabinet-btn__name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── Top-nav messenger button ─────────────────── */
.msg-btn{
  flex:0 0 auto;display:none;align-items:center;gap:7px;position:relative;
  background:rgba(200,159,255,.08);color:var(--frost);
  border:1px solid var(--line-strong);
  padding:8px 13px;border-radius:var(--r-sm);
  font-weight:600;font-size:14px;
  transition:background .2s,border-color .2s,color .2s,transform .1s;
  text-decoration:none;min-height:38px;
  -webkit-tap-highlight-color:rgba(200,159,255,.3);
}
.msg-btn:active{transform:scale(.96)}
.msg-btn:hover{background:rgba(200,159,255,.18);border-color:var(--violet);color:var(--violet)}
.msg-btn svg{width:16px;height:16px}
.msg-btn[data-state="visible"]{display:inline-flex}
.msg-btn__badge{
  position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;
  border-radius:9px;background:linear-gradient(135deg,var(--violet-2),var(--amber));
  color:#fff;font-size:11px;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(168,85,247,.5);
}
@media (max-width:520px){
  .msg-btn .msg-btn__name{display:none}
  .msg-btn{padding:9px 11px;min-width:38px;justify-content:center}
}

/* ── Modal ────────────────────────────────────── */
.modal{
  position:fixed;inset:0;z-index:1000;
  display:none;align-items:center;justify-content:center;
  background:rgba(6,3,12,.72);backdrop-filter:blur(8px);
  padding:20px;
}
.modal[data-open="true"]{display:flex;animation:modalin .3s cubic-bezier(.16,.84,.34,1)}
@keyframes modalin{
  from{opacity:0;backdrop-filter:blur(0)}
  to{opacity:1;backdrop-filter:blur(8px)}
}
.modal[data-open="true"] .modal__card{
  animation:modal-card-in .35s cubic-bezier(.2,.9,.32,1.15);
}
@keyframes modal-card-in{
  from{opacity:0;transform:translateY(14px) scale(.94)}
  to  {opacity:1;transform:translateY(0)    scale(1)}
}
.modal__card{
  position:relative;width:100%;max-width:420px;
  background:linear-gradient(180deg,#16102b,#0e0820);
  border:1px solid var(--line-strong);
  border-radius:var(--r-lg);
  padding:34px 28px 28px;
  box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 60px rgba(200,159,255,.12);
  max-height:calc(100vh - 40px);overflow-y:auto;
}
.modal__card--wide{max-width:520px}
.modal__close{
  position:absolute;top:14px;right:14px;
  width:32px;height:32px;border-radius:50%;
  background:transparent;border:1px solid var(--line);color:var(--lav);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,color .2s;
}
.modal__close:hover{border-color:var(--rose);color:var(--rose)}
.modal__close svg{width:14px;height:14px}
.modal h2{
  font-family:"Cinzel",serif;font-size:24px;margin:0 0 6px;
  background:linear-gradient(120deg,#c89fff,#ffd27a);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.modal p.modal__sub{color:var(--lav);font-size:14px;margin:0 0 22px}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:12px;font-weight:600;color:var(--lav);letter-spacing:.06em;text-transform:uppercase}
.field input{
  background:rgba(6,3,12,.7);
  border:1px solid var(--line-strong);
  color:var(--frost);font-size:15px;font-family:inherit;
  padding:11px 14px;border-radius:var(--r-sm);
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(200,159,255,.18)}
.modal__error{
  color:var(--red);background:rgba(255,107,122,.08);
  border:1px solid rgba(255,107,122,.3);
  border-radius:var(--r-sm);
  padding:10px 12px;font-size:13px;margin:0 0 14px;
  display:none;
}
.modal__error[data-shown="true"]{display:block;animation:shake .35s ease}
@keyframes shake{
  10%,90%{transform:translateX(-1px)}
  20%,80%{transform:translateX(2px)}
  30%,50%,70%{transform:translateX(-3px)}
  40%,60%{transform:translateX(3px)}
}
.modal__hint{
  background:rgba(255,179,71,.06);border:1px solid rgba(255,179,71,.25);
  border-radius:var(--r-sm);padding:14px 14px;font-size:13px;color:var(--frost);
  margin:14px 0 0;line-height:1.55;
}
.modal__hint strong{color:var(--amber)}
.modal__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.modal__actions .btn{flex:1 1 0;justify-content:center;padding:12px 16px;font-size:14px}
.modal__link{
  background:transparent;border:0;cursor:pointer;
  color:var(--violet);font-size:13px;text-decoration:underline;
  margin-top:14px;padding:0;
}
.modal__link:hover{color:var(--amber)}

/* ── Cabinet panel ────────────────────────────── */
.cabinet{padding:48px 0 64px}
.cabinet-header{
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  margin-bottom:32px;
}
.cabinet-header__id{display:flex;align-items:center;gap:18px}
.cabinet-skin-wrap{
  display:flex;flex-direction:column;align-items:center;gap:10px;flex:0 0 auto;
}
.cabinet-skin{
  width:180px;height:280px;position:relative;
  background:radial-gradient(ellipse at center, rgba(168,85,247,.18) 0%, transparent 70%);
  border-radius:14px;overflow:visible;
}
.cabinet-skin canvas{display:block;width:100%;height:100%;cursor:grab}
.cabinet-skin canvas:active{cursor:grabbing}
.cabinet-skin__fallback{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--lav);font-size:13px;text-align:center;padding:20px;
  background:linear-gradient(180deg, rgba(34,20,45,.3), rgba(14,8,32,.3));
  border:1px dashed var(--line-strong);border-radius:14px;
}
.cabinet-skin__link{
  position:absolute;bottom:6px;right:6px;
  font-size:10px;font-weight:600;letter-spacing:.1em;
  color:var(--lav);background:rgba(6,3,12,.7);
  padding:3px 7px;border-radius:6px;text-decoration:none;
  border:1px solid var(--line);
  transition:color .15s;
}
.cabinet-skin__link:hover{color:var(--violet)}
.cabinet-skin__hint{
  font-size:11px;color:var(--lav);text-align:center;
  font-style:italic;max-width:180px;display:none;line-height:1.4;
}
.skin-actions{display:flex;flex-direction:column;gap:6px;width:100%}
.btn-skin-change{
  width:100%;justify-content:center;padding:9px 14px;font-size:13px;
}
.btn-skin-change svg{width:14px;height:14px}
.btn-skin-clear{
  width:100%;justify-content:center;padding:7px 14px;font-size:12px;
  color:var(--lav);border-color:var(--line);
}
.btn-skin-clear:hover{color:var(--rose);border-color:rgba(255,123,147,.45)}
.btn-skin-clear svg{width:13px;height:13px}

/* Progress bar replacing the change button while applying */
.skin-progress{
  width:100%;display:flex;flex-direction:column;gap:6px;
  padding:10px 14px;border:1px solid var(--violet);border-radius:var(--r-sm);
  background:linear-gradient(180deg, rgba(168,85,247,.14), rgba(168,85,247,.04));
}
.skin-progress__label{font-size:12px;color:var(--violet);font-weight:600;display:flex;justify-content:space-between;align-items:center}
.skin-progress__bar{
  height:5px;border-radius:99px;background:rgba(34,20,45,.7);overflow:hidden;
  position:relative;
}
.skin-progress__bar::after{
  content:"";position:absolute;inset:0;width:35%;
  background:linear-gradient(90deg, transparent, var(--violet), var(--amber), transparent);
  border-radius:99px;
  animation:skinprog 1.4s linear infinite;
}
@keyframes skinprog{
  0%  {transform:translateX(-50%)}
  100%{transform:translateX(280%)}
}
.cabinet-header__name{display:flex;flex-direction:column;gap:4px;min-width:0}
.cabinet-name{font-family:"Cinzel",serif;font-size:28px;margin:0;color:var(--frost);line-height:1.1}
.cabinet-rank{
  display:inline-flex;align-items:center;gap:6px;
  align-self:flex-start;
  padding:4px 12px 4px 6px;border:1px solid;border-radius:999px;
  font-size:12px;font-weight:600;letter-spacing:.04em;
  background:rgba(189,169,214,.08);color:var(--lav);border-color:rgba(189,169,214,.4);
  text-transform:uppercase;
}
.cabinet-rank__icon{
  height:20px;width:auto;display:block;
  image-rendering:pixelated;-ms-interpolation-mode:nearest-neighbor;
  filter:drop-shadow(0 0 4px currentColor);
}
.cabinet-rank__label{line-height:1.1}
.cabinet-uuid{font-family:monospace;font-size:11px;color:var(--lav);margin-top:4px;word-break:break-all}

/* Skin change form */
/* ── Generic loading progress (register / login submit) ── */
.arc-progress{
  margin-top:12px;height:4px;border-radius:99px;
  background:rgba(34,20,45,.7);overflow:hidden;position:relative;
}
.arc-progress::after{
  content:"";position:absolute;inset:0;width:38%;border-radius:99px;
  background:linear-gradient(90deg, transparent, var(--violet), var(--amber), transparent);
  animation:arcprog 1.3s linear infinite;
}
@keyframes arcprog{
  0%  {transform:translateX(-55%)}
  100%{transform:translateX(265%)}
}
.arc-progress[hidden]{display:none}

/* ── "Check your email" success card (after register / on unverified login) ── */
.arc-check-email{
  display:flex;flex-direction:column;gap:14px;align-items:center;text-align:center;
  margin-top:6px;padding:22px 18px;border-radius:14px;
  background:linear-gradient(180deg, rgba(168,85,247,.10), rgba(168,85,247,.02));
  border:1px solid rgba(200,159,255,.32);
}
.arc-check-email__icon{
  font-size:42px;line-height:1;color:var(--amber);
  text-shadow:0 0 18px rgba(255,179,71,.55);
}
.arc-check-email__title{
  font-family:"Cinzel",serif;font-size:21px;color:var(--frost);
  margin:0;letter-spacing:.01em;
}
.arc-check-email__email{
  font-family:monospace;font-size:14px;color:var(--amber);
  word-break:break-all;padding:6px 12px;border-radius:8px;
  background:rgba(255,179,71,.08);border:1px dashed rgba(255,179,71,.35);
}
.arc-check-email__hint{
  color:var(--lav);font-size:13px;line-height:1.55;margin:0;max-width:34ch;
}
.arc-check-email__spam{
  color:var(--lav);font-size:12px;line-height:1.5;margin:0;
  padding:8px 10px;border-radius:8px;background:rgba(34,20,45,.6);
  border:1px solid rgba(189,169,214,.25);
}
.arc-resend-btn{
  appearance:none;cursor:pointer;font:inherit;
  padding:10px 18px;border-radius:10px;font-weight:600;font-size:14px;
  background:rgba(189,169,214,.10);color:var(--lav);
  border:1px solid rgba(189,169,214,.35);
  transition:background .15s, border-color .15s, color .15s, transform .08s;
}
.arc-resend-btn:hover:not(:disabled){
  background:rgba(168,85,247,.15);color:var(--frost);border-color:rgba(200,159,255,.55);
}
.arc-resend-btn:active:not(:disabled){ transform:scale(.97) }
.arc-resend-btn:disabled{ cursor:not-allowed;opacity:.65 }
.arc-resend-btn[data-state="sending"]{ color:var(--amber);border-color:rgba(255,179,71,.4) }
.arc-resend-btn[data-state="ok"]{ color:var(--green);border-color:rgba(132,225,163,.4) }

.skin-form__modes{
  display:flex;flex-direction:column;gap:8px;
  border:0;padding:0;margin:0 0 14px;
}
.skin-mode{
  display:flex;align-items:flex-start;gap:12px;
  padding:12px 14px;border-radius:var(--r-sm);
  background:rgba(6,3,12,.4);border:1px solid var(--line);
  cursor:pointer;transition:border-color .15s, background .15s;
  font-size:14px;color:var(--frost);
}
.skin-mode:hover{border-color:var(--line-strong)}
.skin-mode input[type="radio"]{accent-color:var(--violet);margin-top:3px;flex:0 0 auto}
.skin-mode:has(input:checked){
  border-color:var(--violet);
  background:linear-gradient(180deg, rgba(168,85,247,.12), rgba(168,85,247,.04));
}
.skin-mode > span{display:flex;flex-direction:column;gap:2px;min-width:0}
.skin-mode > span > strong{font-size:14px;color:var(--frost);font-weight:600}
.skin-mode > span > small{font-size:12px;color:var(--lav);font-weight:400;letter-spacing:0;text-transform:none}

/* Modal tabs (Login / Register) */
.modal__tabs{
  display:flex;gap:6px;margin:-8px -8px 18px;padding:6px;
  background:rgba(6,3,12,.5);border-radius:var(--r-md);
}
.modal__tab{
  flex:1 1 0;background:transparent;border:0;color:var(--lav);
  font-family:inherit;font-size:14px;font-weight:600;
  padding:9px 12px;border-radius:var(--r-sm);cursor:pointer;
  transition:background .15s,color .15s;
}
.modal__tab:hover{color:var(--frost)}
.modal__tab[aria-selected="true"]{
  color:var(--frost);
  background:linear-gradient(180deg,rgba(168,85,247,.22),rgba(168,85,247,.06));
  box-shadow:inset 0 0 0 1px rgba(200,159,255,.3);
}
.modal__pane[hidden]{display:none!important}
.modal__success{
  color:var(--green);background:rgba(132,225,163,.1);
  border:1px solid rgba(132,225,163,.4);
  border-radius:var(--r-sm);padding:11px 13px;font-size:13px;
  margin-bottom:14px;display:none;line-height:1.5;
}
.modal__success[data-shown="true"]{display:block;animation:fadein .25s ease}

.checkbox-row{
  display:flex;align-items:flex-start;gap:10px;
  background:rgba(6,3,12,.4);
  border:1px solid var(--line);border-radius:var(--r-sm);
  padding:11px 14px;margin:6px 0 14px;
  font-size:13px;color:var(--lav);cursor:pointer;
}
.checkbox-row input[type="checkbox"]{accent-color:var(--violet);margin-top:2px;flex:0 0 auto}
.checkbox-row span{color:var(--frost);line-height:1.5}

/* "Already registered" warning at top of register form */
.register-already-warn{
  display:flex;align-items:flex-start;gap:12px;
  margin:0 0 16px;padding:14px 16px;
  background:linear-gradient(180deg,rgba(255,107,122,.18),rgba(255,107,122,.06));
  border:1px solid rgba(255,107,122,.45);border-radius:var(--r-sm);
  color:var(--frost);font-size:13px;line-height:1.55;
}
.register-already-warn > svg{
  width:22px;height:22px;flex:0 0 auto;color:var(--red);
  filter:drop-shadow(0 0 6px rgba(255,107,122,.5));
  animation:pulse 2s ease-in-out infinite;
}
.register-already-warn strong{color:var(--red);font-weight:700}
.register-already-warn code{
  font-family:"JetBrains Mono",monospace;font-size:11px;
  background:rgba(6,3,12,.6);padding:1px 6px;border-radius:4px;color:var(--amber);
}

.cf-turnstile-slot{
  display:flex;justify-content:center;
  margin:14px 0 6px;min-height:68px;
}

/* Cabinet email-bind banner */
.email-banner{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  margin:0 0 24px;padding:18px 22px;
  background:linear-gradient(135deg,rgba(255,179,71,.16),rgba(168,85,247,.1));
  border:1px solid rgba(255,179,71,.4);border-radius:var(--r-lg);
}
.email-banner__icon{
  width:44px;height:44px;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#ffb347,#67188c);
  border-radius:12px;color:#fff;
}
.email-banner__icon svg{width:24px;height:24px}
.email-banner__body{flex:1 1 auto;min-width:200px;display:flex;flex-direction:column;gap:2px}
.email-banner__body strong{color:var(--amber);font-family:"Cinzel",serif;font-size:16px}
.email-banner__body span{color:var(--lav);font-size:13px;line-height:1.5}
.email-banner__actions{display:flex;gap:8px;flex-wrap:wrap}
.email-banner__actions .btn{padding:9px 16px;font-size:13px}

/* TLauncher warning inside skin modal */
.tlauncher-warning{
  display:flex;align-items:flex-start;gap:12px;
  margin:0 0 18px;padding:14px 16px;
  background:linear-gradient(180deg,rgba(255,107,122,.18),rgba(255,107,122,.08));
  border:1px solid rgba(255,107,122,.5);border-radius:var(--r-sm);
  color:var(--frost);font-size:13px;line-height:1.55;
}
.tlauncher-warning > svg{
  width:22px;height:22px;flex:0 0 auto;color:var(--red);
  filter:drop-shadow(0 0 6px rgba(255,107,122,.5));
  animation:pulse 2s ease-in-out infinite;
}
.tlauncher-warning strong{color:var(--red);font-weight:700}
.tlauncher-warning em{color:var(--amber);font-style:normal}

/* Variant pills (Steve / Alex) */
.variant-row{display:flex;gap:10px;margin:4px 0 0}
.variant-pill{
  flex:1 1 0;display:flex;align-items:center;gap:10px;
  padding:10px 14px;border-radius:var(--r-sm);
  background:rgba(6,3,12,.4);border:1px solid var(--line);
  cursor:pointer;font-size:14px;color:var(--frost);
  transition:border-color .15s, background .15s;
}
.variant-pill:hover{border-color:var(--line-strong)}
.variant-pill input[type="radio"]{accent-color:var(--violet);flex:0 0 auto}
.variant-pill:has(input:checked){
  border-color:var(--violet);
  background:linear-gradient(180deg, rgba(168,85,247,.12), rgba(168,85,247,.04));
}
.variant-pill > span{display:flex;flex-direction:column;gap:1px;min-width:0}
.variant-pill > span > strong{font-size:13px;color:var(--frost);font-weight:600}
.variant-pill > span > small{font-size:11px;color:var(--lav);font-weight:400;letter-spacing:0;text-transform:none}
.field small{color:var(--lav);font-size:12px;margin-top:4px;font-weight:400;text-transform:none;letter-spacing:0}
.field input[type="file"]{padding:8px;cursor:pointer}
.skin-form__status{
  margin-top:14px;padding:10px 14px;border-radius:var(--r-sm);
  font-size:13px;display:none;
}
.skin-form__status:not(:empty){display:block}
.skin-form__status[data-kind="ok"]{
  color:var(--green);background:rgba(132,225,163,.1);
  border:1px solid rgba(132,225,163,.35);
}
.skin-form__status[data-kind="err"]{
  color:var(--red);background:rgba(255,107,122,.08);
  border:1px solid rgba(255,107,122,.3);
}
.skin-form__status[data-kind="pending"]{
  color:var(--lav);background:rgba(189,169,214,.08);
  border:1px solid var(--line-strong);
}

.cabinet-header__id{
  display:flex;align-items:flex-start;gap:24px;flex-wrap:wrap;
}

@media (max-width: 720px){
  .cabinet-header__id{flex-direction:column;align-items:center;text-align:center}
  .cabinet-header__name{align-items:center}
  .cabinet-rank{align-self:center}
  .cabinet-skin{width:160px;height:240px}
  .cabinet-name{font-size:22px}
  .modal__card--wide{max-width:100%}
}

.kpi-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:14px;margin-bottom:32px;
}
.kpi{
  background:linear-gradient(180deg,rgba(34,20,45,.55),rgba(14,8,32,.55));
  border:1px solid var(--line);border-radius:var(--r-md);
  padding:18px 18px 16px;
}
.kpi__label{font-size:12px;color:var(--lav);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.kpi__value{font-size:28px;font-weight:700;color:var(--frost);font-family:"Cinzel",serif}
.kpi__hint{font-size:12px;color:var(--violet);margin-top:4px}

.section-card{
  background:linear-gradient(180deg,rgba(34,20,45,.55),rgba(14,8,32,.55));
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:24px;margin-bottom:24px;
}
.section-card h3{
  font-family:"Cinzel",serif;font-size:20px;margin:0 0 16px;
  display:flex;align-items:center;gap:10px;color:var(--frost);
}
.section-card h3 svg{width:20px;height:20px;color:var(--amber)}

/* Currency grid */
.currency-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.currency{
  display:flex;align-items:center;gap:12px;
  background:rgba(6,3,12,.4);
  border:1px solid var(--line);border-radius:var(--r-md);
  padding:14px;
}
.currency__icon{
  width:42px;height:42px;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;font-family:"Cinzel",serif;
  background:linear-gradient(135deg,#67188c,#ffb347);
  border-radius:10px;color:#fff;
}
.currency__body{min-width:0}
.currency__amount{font-size:18px;font-weight:700;color:var(--frost);font-family:monospace}
.currency__label{font-size:13px;color:var(--violet);font-weight:600}
.currency__hint{font-size:11px;color:var(--lav)}

/* Per-server stats table */
.srv-table{width:100%;border-collapse:collapse;font-size:14px}
.srv-table th, .srv-table td{
  text-align:left;padding:10px 12px;
  border-bottom:1px solid var(--line);
}
.srv-table th{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--lav);font-weight:600}
.srv-table td{color:var(--frost)}
.srv-table tbody tr:hover{background:rgba(200,159,255,.04)}
.srv-table .srv-name{font-weight:600;color:var(--violet)}
.srv-wrap{overflow-x:auto;margin:-8px}
.srv-wrap > *{margin:8px}

.empty{padding:24px;text-align:center;color:var(--lav);font-style:italic}

@media (max-width: 720px){
  .modal__card{padding:26px 20px 20px}
  .cabinet-header{flex-direction:column;align-items:flex-start}
  .cabinet-name{font-size:22px}
  .kpi__value{font-size:22px}
  .srv-table th, .srv-table td{padding:8px 10px;font-size:13px}
}

/* ══ Vacancies ════════════════════════════════ */
.vac-precheck{
  margin:0 auto 28px;max-width:760px;
  background:linear-gradient(180deg,rgba(255,179,71,.08),rgba(168,85,247,.06));
  border:1px solid rgba(255,179,71,.35);border-radius:14px;
  padding:16px 22px;display:none;align-items:center;gap:14px;
}
.vac-precheck[data-state]{display:flex}
.vac-precheck__icon{
  flex:0 0 auto;width:36px;height:36px;color:var(--amber);
  filter:drop-shadow(0 0 8px rgba(255,179,71,.5));
}
.vac-precheck__icon svg{width:36px;height:36px}
.vac-precheck__body{flex:1}
.vac-precheck__body strong{display:block;color:var(--frost);margin-bottom:2px;font-size:14px}
.vac-precheck__body span{color:var(--lav);font-size:13px;line-height:1.55}
.vac-precheck__actions{display:flex;gap:8px;flex-wrap:wrap}

.vac-grid{
  display:grid;gap:20px;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
}
.vac-card{
  background:linear-gradient(180deg,rgba(34,20,45,.85),rgba(14,8,32,.85));
  border:1px solid var(--line);border-radius:18px;
  padding:24px 22px 22px;display:flex;flex-direction:column;
  transition:border-color .2s,transform .15s,box-shadow .25s;
  position:relative;overflow:hidden;
}
.vac-card::before{
  content:"";position:absolute;inset:0 0 auto 0;height:3px;
  background:linear-gradient(90deg,transparent,var(--vac-color, var(--violet)),transparent);
  opacity:.65;
}
.vac-card:hover{
  border-color:var(--line-strong);transform:translateY(-3px);
  box-shadow:0 12px 36px rgba(168,85,247,.18);
}
.vac-card__head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.vac-card__icon{
  width:46px;height:46px;border-radius:12px;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
  font-family:"Cinzel",serif;font-size:22px;font-weight:600;
  background:linear-gradient(135deg,rgba(168,85,247,.2),rgba(255,179,71,.12));
  border:1px solid var(--line-strong);
  color:var(--vac-color, var(--violet));
}
.vac-card h3{
  font-family:"Cinzel",serif;font-size:20px;margin:0;color:var(--frost);
}
.vac-card__short{
  color:var(--lav);font-size:13.5px;margin-bottom:14px;line-height:1.55;flex:1;
}
.vac-card__perks{
  display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;
}
.vac-card__perk{
  font-size:11px;color:var(--lav);background:rgba(200,159,255,.07);
  padding:4px 10px;border-radius:10px;border:1px solid var(--line);
}
.vac-card__open{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  width:100%;padding:11px 16px;border-radius:10px;
  background:linear-gradient(135deg,var(--violet-3) 0%,var(--violet-2) 100%);
  color:#fff;font-weight:600;font-size:14px;font-family:inherit;
  border:0;cursor:pointer;transition:transform .12s,box-shadow .2s;
}
.vac-card__open:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(168,85,247,.4)}
.vac-card__open svg{width:16px;height:16px}
.vac-card[data-locked="true"] .vac-card__open{
  background:rgba(200,159,255,.08);color:var(--lav);
  border:1px dashed var(--line-strong);
}
.vac-card[data-locked="true"] .vac-card__open:hover{transform:none;box-shadow:none}

.vac-info{margin-top:32px}

/* Modal: vacancy form fields */
.vac-field{
  display:flex;flex-direction:column;gap:6px;margin-bottom:14px;
}
.vac-field__label{
  font-size:12px;color:var(--lav);font-weight:600;
  letter-spacing:.04em;
}
.vac-field__label .req{color:var(--amber);margin-left:4px}
.vac-field__hint{
  font-size:11.5px;color:var(--lav);opacity:.75;margin-top:-2px;
}
.vac-field input[type="text"],
.vac-field input[type="number"],
.vac-field textarea,
.vac-field select{
  width:100%;background:rgba(6,3,12,.7);border:1px solid var(--line);
  border-radius:10px;padding:10px 13px;color:var(--frost);font-family:inherit;
  font-size:14px;outline:none;transition:border-color .15s,box-shadow .2s;
  resize:vertical;
}
.vac-field input:focus,.vac-field textarea:focus,.vac-field select:focus{
  border-color:var(--violet);box-shadow:0 0 0 3px rgba(200,159,255,.12);
}
.vac-field textarea{min-height:90px;line-height:1.5}
.vac-field__counter{
  font-size:11px;color:var(--lav);text-align:right;opacity:.7;
}

.vac-nonprofit{
  display:flex;gap:14px;align-items:flex-start;
  margin:14px 0 18px;padding:14px 16px;
  background:linear-gradient(180deg,rgba(255,179,71,.14),rgba(255,179,71,.06));
  border:1.5px solid rgba(255,179,71,.5);border-radius:12px;
}
.vac-nonprofit svg{
  width:26px;height:26px;flex:0 0 auto;color:var(--amber);
  filter:drop-shadow(0 0 8px rgba(255,179,71,.4));
  animation:dc-warn-pulse 2.4s ease-in-out infinite;
}
.vac-nonprofit strong{
  display:block;color:var(--amber);font-weight:700;font-size:13.5px;margin-bottom:3px;
  letter-spacing:.02em;
}
.vac-nonprofit span{
  display:block;color:var(--frost);font-size:13px;line-height:1.55;opacity:.92;
}
.vac-nonprofit u{text-decoration:none;color:var(--amber-2);font-weight:600}
.vac-nonprofit--top{
  max-width:760px;margin:0 auto 24px;
}

.vac-consent{
  margin:18px 0 14px;padding:12px 14px;
  background:rgba(168,85,247,.06);border:1px solid var(--line);
  border-radius:10px;
}
.vac-consent .checkbox-row{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--lav)}
.vac-consent code{font-family:"JetBrains Mono",monospace;color:var(--amber);font-size:12.5px}

/* ══ Discord bind ════════════════════════════════ */
.discord-state__placeholder{color:var(--lav);font-size:13px}
.discord-state__row{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
}
.discord-state__avatar{
  width:48px;height:48px;border-radius:12px;flex:0 0 auto;
  background:linear-gradient(135deg,#5865F2,#7289DA);
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(88,101,242,.4);
}
.discord-state__avatar svg{width:26px;height:26px;color:#fff}
.discord-state__avatar img{width:100%;height:100%;border-radius:12px}
.discord-state__body{flex:1;min-width:0}
.discord-state__title{color:var(--frost);font-weight:600;font-size:15px}
.discord-state__sub{color:var(--lav);font-size:13px;margin-top:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.discord-state__title[data-ok="true"]{color:var(--green)}
.discord-state__actions{display:flex;gap:8px;flex-wrap:wrap}

/* Discord-bind modal */
.dc-step{display:block}
.dc-step[hidden]{display:none}
.dc-howto{
  margin:0 0 14px;padding:14px 16px;
  background:rgba(168,85,247,.06);border:1px solid var(--line);
  border-radius:12px;
}
.dc-howto h4{
  font-family:"Cinzel",serif;font-size:14px;margin:0 0 8px;color:var(--frost);
  letter-spacing:.02em;
}
.dc-howto ol{margin:0;padding-left:20px;color:var(--lav);font-size:13px;line-height:1.7}
.dc-howto code{font-family:"JetBrains Mono",monospace;color:var(--amber);
  background:rgba(6,3,12,.5);padding:1px 6px;border-radius:5px;font-size:12px}
.dc-warn{
  display:flex;gap:12px;align-items:flex-start;
  margin:0 0 16px;padding:14px 16px;
  background:linear-gradient(180deg,rgba(255,107,122,.16),rgba(255,107,122,.08));
  border:1.5px solid rgba(255,107,122,.6);border-radius:12px;
}
.dc-warn svg{
  width:24px;height:24px;flex:0 0 auto;color:var(--red);
  filter:drop-shadow(0 0 6px rgba(255,107,122,.45));
  animation:dc-warn-pulse 2.4s ease-in-out infinite;
}
@keyframes dc-warn-pulse{0%,100%{opacity:.95}50%{opacity:.7}}
.dc-warn strong{display:block;color:var(--red);font-weight:700;font-size:13.5px;margin-bottom:3px}
.dc-warn span{display:block;color:var(--frost);font-size:13px;line-height:1.55;opacity:.92}
.dc-warn code{
  font-family:"JetBrains Mono",monospace;color:var(--amber);
  background:rgba(6,3,12,.55);padding:1px 6px;border-radius:5px;
  font-size:11.5px;white-space:nowrap;
}
.dc-warn--soft{
  background:linear-gradient(180deg,rgba(255,179,71,.12),rgba(255,179,71,.05));
  border-color:rgba(255,179,71,.45);
}
.dc-warn--soft svg{color:var(--amber);filter:drop-shadow(0 0 6px rgba(255,179,71,.45))}
.dc-warn--soft strong{color:var(--amber)}
.dc-code{
  display:flex;align-items:center;gap:10px;
  background:rgba(6,3,12,.7);border:1px solid var(--line-strong);
  border-radius:12px;padding:14px 16px;margin:14px 0 6px;
}
.dc-code code{
  flex:1;font-family:"JetBrains Mono",monospace;
  font-size:28px;font-weight:700;letter-spacing:.2em;
  background:linear-gradient(120deg,var(--violet),var(--amber));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-align:center;
}
.dc-code__copy{
  width:40px;height:40px;border-radius:10px;color:var(--lav);
  border:1px solid var(--line);transition:.15s;
  display:flex;align-items:center;justify-content:center;
}
.dc-code__copy:hover{color:var(--frost);border-color:var(--violet)}
.dc-code__copy svg{width:18px;height:18px}
.dc-cmd{
  color:var(--lav);font-size:13px;margin-bottom:8px;
}
.dc-cmd code{
  font-family:"JetBrains Mono",monospace;color:var(--amber);
  background:rgba(6,3,12,.5);padding:2px 8px;border-radius:6px;font-size:12.5px;
}
.dc-status{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;border-radius:10px;
  background:rgba(168,85,247,.08);border:1px solid var(--line);
  color:var(--violet);font-size:13px;margin-top:8px;
}
.dc-status svg{width:18px;height:18px;color:var(--violet)}
.dc-status.spin svg, .dc-status .spin{animation:dc-spin 1.2s linear infinite}
@keyframes dc-spin{to{transform:rotate(360deg)}}

.dc-progress{margin-top:12px}
.dc-progress__track{
  width:100%;height:8px;border-radius:6px;
  background:rgba(6,3,12,.7);
  border:1px solid var(--line);
  overflow:hidden;position:relative;
}
.dc-progress__fill{
  height:100%;
  background:linear-gradient(90deg,var(--violet-2),var(--amber));
  border-radius:6px;
  width:100%;
  transition:width 1s linear, background .25s;
  position:relative;
  box-shadow:0 0 12px rgba(168,85,247,.35);
}
.dc-progress__fill::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,
    transparent 0%, rgba(255,255,255,.18) 50%, transparent 100%);
  animation:dc-shimmer 2s linear infinite;
}
@keyframes dc-shimmer{
  from{transform:translateX(-100%)}
  to{transform:translateX(100%)}
}
.dc-progress__fill[data-state="warn"]{
  background:linear-gradient(90deg,var(--amber),var(--rose));
  box-shadow:0 0 12px rgba(255,179,71,.4);
}
.dc-progress__fill[data-state="critical"]{
  background:linear-gradient(90deg,var(--rose),var(--red));
  box-shadow:0 0 14px rgba(255,107,122,.5);
}
.dc-progress__fill[data-state="expired"]{
  background:rgba(255,107,122,.4);
  box-shadow:none;
}
.dc-progress__fill[data-state="expired"]::after{animation:none}

/* Indeterminate state (while the start-code request is in flight) */
.dc-progress__fill[data-state="loading"]{
  width:100%;
  background:linear-gradient(90deg,
    rgba(168,85,247,.18) 0%,
    var(--violet-2) 40%,
    var(--amber) 60%,
    rgba(255,179,71,.18) 100%);
  background-size:240% 100%;
  background-position:200% 0;
  animation:dc-flame 1.4s ease-in-out infinite;
  box-shadow:0 0 14px rgba(168,85,247,.35), 0 0 22px rgba(255,179,71,.18);
}
.dc-progress__fill[data-state="loading"]::after{
  background:linear-gradient(90deg,
    transparent 0%, rgba(255,255,255,.28) 50%, transparent 100%);
  animation:dc-shimmer 1.1s linear infinite;
}
@keyframes dc-flame{
  0%   { background-position: 200% 0; }
  100% { background-position: -50% 0; }
}
.dc-progress--loading .dc-progress__meta{color:var(--violet)}
.dc-progress--loading .dc-progress__time{
  color:var(--amber);font-size:13px;
  animation:dc-spin 1.4s linear infinite;display:inline-block;
}
.dc-progress__meta{
  display:flex;justify-content:space-between;align-items:center;
  font-size:11.5px;color:var(--lav);margin-top:6px;
  font-family:"JetBrains Mono",monospace;letter-spacing:.04em;
}
.dc-progress__time{font-weight:700;color:var(--frost)}
.dc-progress__time[data-state="warn"]{color:var(--amber)}
.dc-progress__time[data-state="critical"]{color:var(--red)}
.dc-progress__time[data-state="expired"]{color:var(--lav);text-decoration:line-through}
.dc-done{text-align:center;padding:10px 0 0}
.dc-done svg{
  width:60px;height:60px;color:var(--green);
  margin:0 auto 12px;display:block;
  filter:drop-shadow(0 0 14px rgba(132,225,163,.45));
}
.dc-done h3{
  font-family:"Cinzel",serif;font-size:22px;margin-bottom:6px;color:var(--frost);
}
.dc-done p{color:var(--lav);font-size:14px;margin-bottom:18px}
.dc-done code{
  font-family:"JetBrains Mono",monospace;color:var(--violet);
  background:rgba(200,159,255,.08);padding:2px 8px;border-radius:6px;
}

/* ── Mystic Wiki announcement banner ──────────── */
.mw-banner{
  display:flex;align-items:center;gap:22px;
  padding:22px 28px;border-radius:18px;
  background:
    radial-gradient(ellipse at 0% 0%, rgba(168,85,247,.22) 0%, transparent 55%),
    radial-gradient(ellipse at 100% 100%, rgba(255,179,71,.18) 0%, transparent 55%),
    linear-gradient(180deg,rgba(34,20,45,.85),rgba(14,8,32,.85));
  border:1px solid var(--line-strong);
  text-decoration:none;color:var(--frost);
  transition:transform .22s cubic-bezier(.18,.79,.27,1),
             border-color .25s, box-shadow .3s;
  position:relative;overflow:hidden;
}
.mw-banner::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(135deg,transparent 0,transparent 24px,
    rgba(200,159,255,.025) 24px,rgba(200,159,255,.025) 25px);
  pointer-events:none;
}
.mw-banner:hover{
  transform:translateY(-3px);
  border-color:var(--violet);
  box-shadow:0 18px 50px rgba(168,85,247,.22), 0 0 60px rgba(255,179,71,.1);
}
.mw-banner__rune{
  width:64px;height:64px;flex:0 0 auto;
  filter:drop-shadow(0 0 12px rgba(200,159,255,.4));
  animation:rune-pulse 4s ease-in-out infinite;
}
.mw-banner__rune svg{width:64px;height:64px}
@keyframes rune-pulse{
  0%,100%{transform:rotate(0deg) scale(1)}
  50%{transform:rotate(8deg) scale(1.05)}
}
.mw-banner__body{flex:1;min-width:0}
.mw-banner__tag{
  display:inline-block;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--amber);font-weight:700;margin-bottom:4px;
}
.mw-banner__body h3{
  font-family:"Cinzel",serif;font-size:22px;font-weight:700;color:var(--frost);
  margin:0 0 4px;background:linear-gradient(120deg,var(--frost),var(--violet));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.mw-banner__body p{
  color:var(--lav);font-size:13.5px;line-height:1.55;margin:0;
}
.mw-banner__body strong{color:var(--frost)}
.mw-banner__cta{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;border-radius:10px;
  background:linear-gradient(135deg,var(--violet-3) 0%,var(--violet-2) 100%);
  color:#fff;font-weight:600;font-size:13.5px;font-family:"Cinzel",serif;
  letter-spacing:.04em;white-space:nowrap;
  box-shadow:0 6px 22px rgba(168,85,247,.4);
  transition:transform .15s,box-shadow .2s;
}
.mw-banner__cta svg{width:14px;height:14px}
.mw-banner:hover .mw-banner__cta{transform:translateX(2px);box-shadow:0 10px 30px rgba(168,85,247,.55)}
@media (max-width:640px){
  .mw-banner{flex-direction:column;text-align:center;padding:20px 18px;gap:14px}
  .mw-banner__cta{width:100%;justify-content:center}
}

/* ── Footer ───────────────────────────────────── */
.site-footer{
  margin-top:40px;padding:32px 0 26px;
  border-top:1px solid var(--line);
  background:rgba(6,3,12,.6);
  text-align:center;color:var(--lav);font-size:13px;
}
.site-footer a{color:var(--violet)}
.site-footer__brand{
  font-family:"Cinzel","Georgia",serif;font-weight:600;letter-spacing:.05em;
  color:var(--frost);font-size:15px;margin-bottom:6px;display:block;
}

/* ── Responsive ───────────────────────────────── */
@media (max-width: 920px){
  .hero{padding:48px 0 36px}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-art{max-width:300px;margin:0 auto}
  .server-hero{grid-template-columns:1fr;padding:24px;gap:20px}
  .server-hero__art{max-width:240px}
  .section{padding:44px 0}
  .ip-card{flex-direction:column;max-width:100%}
  .ip-card__label{border-right:0;border-bottom:1px solid var(--line);padding:10px 14px}
  .ip-card__copy{border-left:0;border-top:1px solid var(--line);padding:14px;justify-content:center}
}
@media (max-width: 720px){
  .brand-name{display:none}
  .header-inner{padding:0 14px;gap:8px}
  .tab{padding:8px 11px;font-size:13px}
  .discord-btn span{display:none}
  .discord-btn{padding:9px 11px}
  .cabinet-btn .cabinet-btn__name{display:none}
  .cabinet-btn{padding:9px 11px;min-width:38px;min-height:38px;justify-content:center}
  .container{padding:0 14px}
  .feature{padding:18px}
  .hero h1{font-size:42px}
}
@media (max-width: 480px){
  .ip-card__addr{font-size:15px;padding:12px 14px}
  .cta-row{gap:8px}
  .btn{padding:12px 18px;font-size:14px}
  .server-hero{padding:20px}
}
/* ══ Refined animations (2026-05-12) ═══════════════
   Layered polish on existing features. Honours
   prefers-reduced-motion at the bottom. */

/* Smoother panel transitions */
.panel{animation:none}
.panel.active{
  animation:panel-in .42s cubic-bezier(.18,.79,.27,1) both;
}
@keyframes panel-in{
  0%   {opacity:0; transform:translateY(14px); filter:blur(4px)}
  60%  {filter:blur(0)}
  100% {opacity:1; transform:none;            filter:blur(0)}
}

/* Buttons — refined press feedback */
.btn, .tab, .cabinet-btn, .msg-btn, .discord-btn,
.cabinet-nav__btn, .vac-card__open, .compose__send,
.modal__btn--primary, .modal__btn--ghost{
  transition:transform .14s cubic-bezier(.2,.9,.32,1.4),
             box-shadow .25s ease,
             background .2s, border-color .2s, color .2s;
}
.btn:not(:disabled):hover, .vac-card__open:not(:disabled):hover{
  transform:translateY(-2px);
}
.btn:not(:disabled):active{transform:translateY(0) scale(.97)}
.tab:hover{transform:translateY(-1px)}
.tab[aria-selected="true"]{animation:tab-glow .6s ease-out}
@keyframes tab-glow{
  0%   {box-shadow:inset 0 -2px 0 var(--violet), 0 0 0 rgba(168,85,247,0)}
  60%  {box-shadow:inset 0 -2px 0 var(--violet), 0 0 22px rgba(168,85,247,.32)}
  100% {box-shadow:inset 0 -2px 0 var(--violet), 0 0 0 rgba(168,85,247,0)}
}

/* Online status indicators — soft pulse */
.tab-dropdown__dot,
.mobnav__world-dot,
.world-row__dot,
.thread__status-dot,
.contact__dot.online,
.msg-world__dot{
  position:relative;
}
.contact__dot.online::after,
.tab-dropdown__status[data-online="true"] .tab-dropdown__dot::after,
.mobnav__world[data-online="true"] .mobnav__world-dot::after,
.world-row[data-online="true"] .world-row__dot::after,
.thread__status[data-online="true"] .thread__status-dot::after{
  content:"";position:absolute;inset:-3px;border-radius:50%;
  background:inherit;opacity:.55;
  animation:dot-ping 1.7s cubic-bezier(0,0,.2,1) infinite;
  pointer-events:none;
}
@keyframes dot-ping{
  0%   {transform:scale(.6); opacity:.55}
  80%, 100% {transform:scale(2.4); opacity:0}
}

/* Server card hover lift (server hero + feature cards + vacancy cards) */
.feature, .cta-card, .server-hero, .vac-card{
  transition:transform .25s cubic-bezier(.18,.79,.27,1),
             box-shadow .3s, border-color .25s;
}
.feature:hover{transform:translateY(-3px)}
.cta-card:hover{transform:translateY(-2px)}
.vac-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 44px rgba(168,85,247,.22), 0 0 36px rgba(255,179,71,.12);
}

/* KPI tiles — gentle reveal on scroll-in (set up by JS reveal observer) */
.kpi{
  transition:transform .25s cubic-bezier(.2,.9,.32,1), box-shadow .3s;
}
.kpi:hover{transform:translateY(-2px)}
.kpi__value{transition:color .3s}

/* Cabinet sub-nav — smoother active swap */
.cabinet-nav__btn{
  transition:color .2s, background .25s, transform .14s;
}
.cabinet-nav__btn[aria-selected="true"]{
  animation:nav-pulse .5s ease-out;
}
@keyframes nav-pulse{
  0%   {box-shadow:0 0 0 rgba(200,159,255,0)}
  40%  {box-shadow:0 0 22px rgba(200,159,255,.3)}
  100% {box-shadow:0 0 0 rgba(200,159,255,0)}
}

/* Mobile menu — smoother slide */
.mobnav{transition:max-height .32s cubic-bezier(.2,.9,.32,1)}
.mobnav[data-open="true"] .mobnav__item{
  animation:mobnav-item-in .35s cubic-bezier(.2,.9,.32,1) both;
}
.mobnav[data-open="true"] .mobnav__item:nth-child(1){animation-delay:.02s}
.mobnav[data-open="true"] .mobnav__item:nth-child(2){animation-delay:.05s}
.mobnav[data-open="true"] .mobnav__item:nth-child(3){animation-delay:.08s}
.mobnav[data-open="true"] .mobnav__item:nth-child(4){animation-delay:.11s}
.mobnav[data-open="true"] .mobnav__item:nth-child(5){animation-delay:.14s}
.mobnav[data-open="true"] .mobnav__item:nth-child(6){animation-delay:.17s}
.mobnav[data-open="true"] .mobnav__item:nth-child(7){animation-delay:.20s}
@keyframes mobnav-item-in{
  from{opacity:0;transform:translateX(-12px)}
  to  {opacity:1;transform:none}
}

/* Dropdown menus (top-nav «Світи») */
.tab-dropdown__menu{
  transform-origin:top left;
  transition:opacity .18s, transform .22s cubic-bezier(.2,.9,.32,1.05);
}
.tab-dropdown__menu[hidden]{opacity:0;transform:translateY(-8px) scale(.97);pointer-events:none}

/* Live status pulse for network header */
.network-status__pulse{
  animation:net-breath 2.2s ease-in-out infinite;
}
@keyframes net-breath{
  0%,100%{opacity:.55; transform:scale(1)}
  50%    {opacity:1;   transform:scale(1.18)}
}

/* Cabinet skin slot — gentle float when fully loaded */
.cabinet-skin svg{
  animation:skin-float 6s ease-in-out infinite;
}
@keyframes skin-float{
  0%,100%{transform:translateY(0)}
  50%    {transform:translateY(-4px)}
}

/* Cabinet rank chip — slow color cycle */
.cabinet-rank{transition:background-position 1.2s ease, transform .15s}
.cabinet-rank:hover{transform:translateY(-1px)}

/* Email banner — slide in from above */
.email-banner:not([hidden]){
  animation:banner-in .45s cubic-bezier(.2,.9,.32,1) both;
}
@keyframes banner-in{
  from{opacity:0;transform:translateY(-12px)}
  to  {opacity:1;transform:none}
}

/* Currency tiles — subtle hover */
.currency{
  transition:transform .18s, border-color .25s, background .25s;
}
.currency:hover{
  transform:translateY(-2px);
  border-color:var(--line-strong);
  background:rgba(6,3,12,.6);
}

/* Updates feed items */
.update-entry, .update-card{
  transition:transform .2s, border-color .25s;
}
.update-entry:hover, .update-card:hover{
  transform:translateX(2px);
  border-color:var(--line-strong);
}

/* IP-card copy success bounce */
.ip-card__copy.copied{animation:copy-bounce .5s ease-out}
@keyframes copy-bounce{
  0%   {transform:scale(1)}
  35%  {transform:scale(1.18)}
  100% {transform:scale(1)}
}

/* Discord-bind/vacancies status box transitions */
.modal__error[data-shown="true"], .modal__success[data-shown="true"],
.dc-status, .vac-precheck{
  animation:box-in .3s cubic-bezier(.2,.9,.32,1) both;
}
@keyframes box-in{
  from{opacity:0;transform:scale(.96)}
  to  {opacity:1;transform:scale(1)}
}

/* Smooth scroll behaviour globally + safer focus rings */
html{scroll-padding-top:var(--header-h)}
:focus-visible{
  outline:2px solid var(--violet);outline-offset:2px;
  border-radius:var(--r-sm);
  transition:outline-offset .15s;
}

/* Fade-in for images (skin face, contact avatars) */
img{transition:opacity .25s}
img[loading="lazy"]:not(.loaded){opacity:.4}

@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important}
}


/* Minecraft pixel-font subtitle in brand */
.brand-game-tag{
  display:block;
  font-family:"Courier New","Press Start 2P",monospace;
  font-size:9px;
  font-weight:400;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--amber);
  margin-top:2px;
  text-shadow:1px 1px 0 rgba(0,0,0,.7);
  image-rendering:pixelated;
  /* CSS-step gradient to make blocky look without web-font */
  background:linear-gradient(180deg,#84d850 50%,#5a9f30 50%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
