/* ═══════════════ NimarkoVPN Billing — EDITORIAL CLEAN · hairline cards · restrained red · light + dark ═══════════════ */
:root{
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,'SF Mono',Menlo,Consolas,'Liberation Mono',monospace;
  --maxw:1180px; --gutter:24px;
  --r-xs:8px; --r-sm:10px; --r:12px; --r-lg:16px; --r-xl:22px; --r-2xl:28px;
  --ease:cubic-bezier(.4,0,.2,1); --ease-out:cubic-bezier(.16,1,.3,1); --spring:cubic-bezier(.22,1,.36,1);
  /* single theme-crossfade token — every theme-able surface eases by the SAME curve & length,
     whether it animates via the View-Transition snapshot or via --tcol on the fallback path */
  --t-theme:.30s;
  --tcol:background-color var(--t-theme) var(--ease),border-color var(--t-theme) var(--ease),color var(--t-theme) var(--ease);
  color-scheme:dark;
  --bg:#0b0c10; --bg-2:#0e1015; --surface:#13151b; --surface-2:#181b22; --surface-3:#212530;
  --fg:#f4f5f7; --fg2:#a6abb6; --fg3:#787e8c;
  --line:rgba(255,255,255,.09); --line-2:rgba(255,255,255,.14); --line-3:rgba(255,255,255,.20);
  --accent:#ff5765; --accent-2:#ff7a78; --accent-text:#ff6e78; --accent-ink:#fff;
  --accent-soft:rgba(255,87,101,.14); --accent-line:rgba(255,87,101,.32); --accent-ring:rgba(255,87,101,.40);
  --grad:linear-gradient(135deg,#ff4d5e,#e5384d); --grad-deep:linear-gradient(135deg,#f0394e,#c81d3a);
  --glow:0 8px 22px -10px rgba(255,77,94,.50);
  --ok:#34d399; --ok-bg:rgba(52,211,153,.14); --ok-line:rgba(52,211,153,.30);
  --warn:#fbbf45; --warn-bg:rgba(251,191,69,.13); --warn-line:rgba(251,191,69,.30);
  --err:#ff7a85; --err-bg:rgba(255,90,110,.15); --err-line:rgba(255,90,110,.42);
  --info:#7aa2ff; --info-bg:rgba(122,162,255,.14); --info-line:rgba(122,162,255,.30);
  --scrim:rgba(4,5,8,.66); --glass-bg:rgba(13,15,20,.72); --glass-hi:rgba(255,255,255,.06);
  --shadow-sm:0 1px 2px rgba(0,0,0,.34);
  --shadow:0 1px 2px rgba(0,0,0,.3),0 12px 28px -18px rgba(0,0,0,.6);
  --shadow-lg:0 26px 64px -28px rgba(0,0,0,.7),0 8px 24px -16px rgba(0,0,0,.5);
  --fx-1:rgba(255,77,94,.12); --fx-2:rgba(120,90,255,.07); --fx-3:rgba(255,120,90,.07);
}
[data-theme="light"]{
  color-scheme:light;
  --bg:#f7f8fa; --bg-2:#eef0f4; --surface:#ffffff; --surface-2:#f3f4f7; --surface-3:#e9ebf0;
  --fg:#11141a; --fg2:#5a6170; --fg3:#737a88;
  --line:rgba(17,20,26,.09); --line-2:rgba(17,20,26,.15); --line-3:rgba(17,20,26,.18);
  --accent:#e11d36; --accent-2:#f0394e; --accent-text:#c81530; --accent-ink:#fff;
  --accent-soft:rgba(225,29,54,.08); --accent-line:rgba(225,29,54,.24); --accent-ring:rgba(225,29,54,.24);
  --grad:linear-gradient(135deg,#e5283f,#c4162e); --grad-deep:linear-gradient(135deg,#d61f36,#b1142a);
  --glow:0 8px 20px -10px rgba(204,28,51,.38);
  --ok:#067a45; --ok-bg:rgba(6,122,69,.09); --ok-line:rgba(6,122,69,.26);
  --warn:#a35c06; --warn-bg:rgba(163,92,6,.09); --warn-line:rgba(163,92,6,.26);
  --err:#c4162e; --err-bg:rgba(196,22,46,.07); --err-line:rgba(196,22,46,.28);
  --info:#2f5fd6; --info-bg:rgba(47,95,214,.08); --info-line:rgba(47,95,214,.26);
  --scrim:rgba(20,24,34,.40); --glass-bg:rgba(255,255,255,.80); --glass-hi:rgba(255,255,255,.7);
  --shadow-sm:0 1px 2px rgba(20,24,34,.05);
  --shadow:0 1px 2px rgba(20,24,34,.05),0 12px 26px -18px rgba(20,24,34,.16);
  --shadow-lg:0 24px 56px -26px rgba(20,24,34,.22),0 8px 20px -14px rgba(20,24,34,.12);
  --fx-1:rgba(225,29,54,.07); --fx-2:rgba(80,110,220,.05); --fx-3:rgba(225,29,54,.04);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scrollbar-gutter:stable;overflow-x:clip;-webkit-text-size-adjust:100%}
html,body{margin:0;padding:0;min-height:100%}
body{font-family:var(--font);background:var(--bg);color:var(--fg);font-size:15px;line-height:1.55;letter-spacing:-.006em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;position:relative;overflow-x:clip;transition:var(--tcol)}
a{color:var(--accent-text);text-decoration:none;cursor:pointer;font-weight:600}
a:hover{text-decoration:underline;text-underline-offset:2px}
.linklike{display:inline;padding:0;border:none;background:none;color:var(--accent-text);font:inherit;font-weight:600;cursor:pointer}
.linklike:hover{text-decoration:underline;text-underline-offset:2px}
.linklike:focus-visible{outline:2px solid var(--accent-text);outline-offset:2px;border-radius:3px}
button{font-family:inherit}
img{max-width:100%}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.mono{font-family:var(--mono);font-size:.86em}
.muted{color:var(--fg2)}
.dim{color:var(--fg3)}
.center{text-align:center}
/* twemoji flag images — crisp vector flags on EVERY platform (incl. Windows desktop). Sized per host below. */
img.emoji{height:1.05em;width:auto;display:inline-block;vertical-align:-.16em;margin:0;object-fit:contain}
.ic{width:18px;height:18px;flex:none;display:inline-block;vertical-align:middle}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:8px}
.btn:focus-visible,.mchip:focus-visible,.nav-btn:focus-visible,.seg-btn:focus-visible,.cattab:focus-visible,.catsub:focus-visible,.theme-toggle:focus-visible,.ccard:focus-visible{outline-offset:3px}
.input:focus-visible{outline:none}
.bg-fx{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden;background:radial-gradient(120% 90% at 100% -10%,var(--bg-2),transparent 55%),var(--bg);transition:background-color var(--t-theme) var(--ease)}
.bg-fx::before{content:"";position:absolute;left:50%;top:-42vh;width:120vw;height:82vh;translate:-50% 0;background:radial-gradient(50% 50% at 50% 50%,var(--fx-1),transparent 70%);filter:blur(72px)}
.bg-fx::after{content:"";position:absolute;right:-30vw;bottom:-30vh;width:80vw;height:70vh;background:radial-gradient(50% 50% at 50% 50%,var(--fx-2),transparent 70%);filter:blur(92px)}
.bg-fx i{position:absolute;left:-22vw;top:34vh;width:58vw;height:54vh;background:radial-gradient(50% 50% at 50% 50%,var(--fx-3),transparent 72%);filter:blur(82px)}
.bg-fx b{display:none}
.glass{background:var(--glass-bg);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%)}
@supports not ((backdrop-filter:blur(2px)) or (-webkit-backdrop-filter:blur(2px))){.glass{background:var(--bg)}}
.topbar{position:sticky;top:0;z-index:50}
.topbar-inner{border-bottom:1px solid var(--line);transition:var(--tcol)}
.topbar-row{display:flex;align-items:center;gap:12px;min-height:60px;padding-block:8px}
.brand{display:flex;align-items:center;gap:11px;font-weight:750;font-size:18px;letter-spacing:-.02em;cursor:pointer;min-width:0;flex:none}
.brand .logo{flex:none;width:34px;height:34px;border-radius:10px;background:var(--grad);display:grid;place-items:center;color:#fff;overflow:hidden;box-shadow:var(--glow),inset 0 1px 0 rgba(255,255,255,.4)}
.brand .logo svg{width:19px;height:19px}
.brand .logo img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
.brand .logo:has(img){background:none;box-shadow:var(--shadow-sm)}
.brand .wordmark{white-space:nowrap;color:var(--fg)}
.brand b{font-weight:750;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.topbar-ctrls{flex:none;display:flex;align-items:center;gap:8px;margin-left:auto}
.logout-btn{color:var(--fg2)}
.nav{flex:0 1 auto;display:flex;align-items:center;justify-content:center;gap:2px;min-width:0;overflow-x:auto;margin:0 auto;scrollbar-width:none;-ms-overflow-style:none}
.nav:empty{flex:1 1 auto}
.nav::-webkit-scrollbar{display:none}
#botnav{display:none}
.nav-btn{flex:none;display:inline-flex;align-items:center;gap:7px;padding:8px 13px;min-height:38px;border-radius:9px;color:var(--fg2);font-weight:600;font-size:14px;cursor:pointer;border:none;background:none;white-space:nowrap;transition:var(--tcol)}
.nav-btn .ic{width:17px;height:17px;opacity:.8}
@media (hover:hover){.nav-btn:hover{background:var(--surface-2);color:var(--fg)}}
.nav-btn.active{color:var(--accent-text);background:var(--accent-soft)}
.nav-btn.active .ic{opacity:1}
.theme-toggle{flex:none;display:inline-grid;place-items:center;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--fg2);cursor:pointer;transition:var(--tcol)}
@media (hover:hover){.theme-toggle:hover{color:var(--fg);border-color:var(--line-2)}}
.theme-toggle:active{translate:0 1px}
.theme-toggle svg{width:18px;height:18px;display:block}
.theme-toggle .ic-sun{display:none}
.theme-toggle .ic-moon{display:block}
[data-theme="light"] .theme-toggle .ic-moon{display:none}
[data-theme="light"] .theme-toggle .ic-sun{display:block}
main{flex:1 0 auto;padding:22px 0 80px}
.view{animation:fade .42s var(--ease-out) both;view-transition-name:appview}
/* View Transitions — ровный плавный кроссфейд (смена темы/категории/тарифа в листе) */
::view-transition-old(root),::view-transition-new(root){animation-duration:var(--t-theme);animation-timing-function:var(--ease)}
/* per-view / per-list swaps get a contained, snappier crossfade so navigation feels LIGHT
   while theme-toggle keeps the full-page root dissolve above */
::view-transition-group(appview),::view-transition-old(appview),::view-transition-new(appview),
::view-transition-group(catpane),::view-transition-old(catpane),::view-transition-new(catpane){animation-duration:.24s;animation-timing-function:var(--ease-out)}
/* during a THEME toggle every named group must animate at the SAME length/curve as root, so the
   crossfade is perfectly even (no group settling 60ms before the background) */
html.theming::view-transition-group(appview),html.theming::view-transition-old(appview),html.theming::view-transition-new(appview),
html.theming::view-transition-group(catpane),html.theming::view-transition-old(catpane),html.theming::view-transition-new(catpane),
html.theming::view-transition-group(sheetbody),html.theming::view-transition-old(sheetbody),html.theming::view-transition-new(sheetbody){animation-duration:var(--t-theme);animation-timing-function:var(--ease)}
@keyframes fade{from{opacity:0;translate:0 10px}to{opacity:1;translate:0 0}}
/* fallback (no View-Transitions) content-swap fade — JS re-triggers via reflow on each data load */
.swap-in{animation:swapin .24s var(--ease-out) both}
@keyframes swapin{from{opacity:0;translate:0 6px}to{opacity:1;translate:0 0}}
h1{font-size:34px;font-weight:780;letter-spacing:-.035em;margin:0 0 10px;line-height:1.1;color:var(--fg)}
h2{font-size:21px;font-weight:700;letter-spacing:-.02em;margin:0;color:var(--fg)}
h3{margin:0;color:var(--fg)}
.lead{color:var(--fg2);font-size:16px;line-height:1.55;margin:0 0 30px;max-width:64ch}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
/* HERO — centered, balanced, never edge-pinned */
.hero{position:relative;text-align:center;display:flex;flex-direction:column;align-items:center;max-width:760px;margin:0 auto 20px;padding:0 var(--gutter)}
.hero .eyebrow{margin:0 auto 22px}
.hero h1{font-size:clamp(30px,5.4vw,52px);line-height:1.07;margin:0 0 12px;max-width:14ch}
.hero .lead{margin:0 auto 14px;max-width:54ch;font-size:clamp(15px,2vw,18px);color:var(--fg2)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;max-width:100%;padding:7px 15px;border-radius:99px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);font-size:12.5px;font-weight:650;letter-spacing:.02em;color:var(--fg2);white-space:nowrap;overflow:hidden}
.eyebrow .ic{width:15px;height:15px;flex:none;color:var(--accent-text)}
.eyebrow>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.trust{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;align-items:stretch;margin:0 auto;width:100%}
.trust .chip{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:99px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);font-size:13px;font-weight:600;color:var(--fg);white-space:nowrap}
.trust .chip .ic{width:16px;height:16px;flex:none;color:var(--accent-text)}
.card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow);transition:var(--tcol),translate .2s var(--spring),box-shadow .24s var(--ease)}
/* CATALOG IA tabs */
.cattabs{display:flex;width:fit-content;max-width:100%;gap:4px;margin:0 auto 14px;padding:4px;border-radius:13px;background:var(--surface-2);border:1px solid var(--line)}
.cattab{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 20px;min-height:42px;border:0;background:transparent;color:var(--fg2);font-family:inherit;font-weight:640;font-size:14.5px;border-radius:9px;cursor:pointer;transition:var(--tcol),box-shadow .18s var(--ease)}
.cattab .ic{width:17px;height:17px;opacity:.8;flex:none}
.cattab span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media (hover:hover){.cattab:not(.on):hover{color:var(--fg)}}
.cattab.on{background:var(--surface);color:var(--fg);box-shadow:var(--shadow-sm)}
.cattab.on .ic{opacity:1;color:var(--accent-text)}
.catsubs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:4px auto 18px}
.catsub{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;min-height:40px;border:1px solid var(--line);background:var(--surface);color:var(--fg2);font-family:inherit;font-weight:600;font-size:13.5px;border-radius:99px;cursor:pointer;transition:var(--tcol),translate .12s var(--spring)}
.catsub .ic{width:16px;height:16px;opacity:.85;flex:none}
@media (hover:hover){.catsub:not(.on):hover{border-color:var(--line-2);color:var(--fg)}}
.catsub:active{scale:.98}
.catsub.on{background:var(--accent-soft);color:var(--accent-text);border-color:var(--accent-line)}
.catsub.on .ic{opacity:1;color:var(--accent-text)}
@media (max-width:640px){.catsub{min-height:46px}}
.cat-hint{font-size:14px;color:var(--fg3);text-align:center;margin:0 auto 20px;max-width:62ch}
#cat-pane{animation:fade .26s var(--ease-out) both;view-transition-name:catpane}
/* admin body: mirror #cat-pane — fallback fade for no-VT browsers; VT path crossfades via vt() */
#adm-body{animation:fade .26s var(--ease-out) both}
/* COUNTRY GRID — perfectly aligned, IDENTICAL cards (fixed 3-zone grid; tags never reflow vertical) */
.ccgrid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.ccard{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;column-gap:16px;width:100%;text-align:left;font-family:inherit;color:var(--fg);padding:18px 20px;min-height:88px;border-radius:var(--r-lg);cursor:pointer;position:relative;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);animation:rise .42s var(--ease-out) both;animation-delay:calc(var(--i,0)*32ms);transition:var(--tcol),translate .18s var(--spring),box-shadow .22s var(--ease),border-color .2s var(--ease)}
@media (hover:hover){.ccard:hover{translate:0 -2px;border-color:var(--line-2);box-shadow:var(--shadow)}}
.ccard:active{translate:0 0;scale:.99}
.ccard-flag{flex:none;width:34px;height:34px;display:grid;place-items:center;border-radius:8px;background:var(--surface-2);border:1px solid var(--line);overflow:hidden}
.ccard-flag img.emoji{width:24px;height:18px;vertical-align:0;border-radius:3px;box-shadow:0 1px 2px rgba(0,0,0,.25)}
.ccard-body{min-width:0;display:flex;flex-direction:column;gap:7px;justify-content:center}
.ccard-name{font-size:16px;font-weight:680;letter-spacing:-.01em;line-height:1.2;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ccard-tags{display:flex;flex-flow:row nowrap;gap:6px;min-height:22px;overflow:hidden}
.ccard-sub{font-size:12.5px;color:var(--fg3);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}
.ccard-t{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:99px;font-size:11px;font-weight:620;background:var(--surface-2);color:var(--fg2);border:1px solid var(--line);white-space:nowrap;flex:none}
.ccard-t .ic{width:12px;height:12px;color:var(--fg3);opacity:.9}
.ccard-t.fam{background:var(--ok-bg);color:var(--ok);border-color:var(--ok-line)}
.ccard-t.fam .ic{color:var(--ok)}
.ccard-foot{flex:none;display:flex;align-items:center;gap:14px;justify-self:end}
.ccard-from{display:flex;flex-direction:column;align-items:flex-end;gap:1px;font-size:11.5px;color:var(--fg3);font-weight:500;white-space:nowrap;line-height:1.15;text-align:right}
.ccard-from b{font-size:17px;font-weight:760;color:var(--fg);letter-spacing:-.02em;margin:0}
.ccard-from .per{font-size:11px}
.ccard-go{flex:none;display:grid;place-items:center;width:30px;height:30px;border-radius:8px;background:var(--surface-2);color:var(--fg3);border:1px solid var(--line);transition:var(--tcol),translate .18s var(--spring)}
.ccard-go .ic{width:16px;height:16px;rotate:-90deg}
@media (hover:hover){.ccard:hover .ccard-go{background:var(--accent-soft);color:var(--accent-text);border-color:var(--accent-line);translate:2px 0}}
@keyframes rise{from{opacity:0;translate:0 12px}to{opacity:1;translate:0 0}}
.cat-section{margin-top:44px}
.cat-section:first-of-type{margin-top:8px}
.cat-head{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.cat-ic{flex:none;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-text);border:1px solid var(--accent-line)}
.cat-ic .ic{width:18px;height:18px}
.cat-head h2{flex:0 1 auto;min-width:0}
.cat-count{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:99px;font-size:12px;font-weight:640;background:var(--surface-2);color:var(--fg2);border:1px solid var(--line)}
.cat-count .ic{width:14px;height:14px}
.cap{font-size:11px;font-weight:680;letter-spacing:.08em;text-transform:uppercase;color:var(--fg3);margin:0 0 9px}
.seg{display:flex;gap:3px;padding:3px;border-radius:11px;background:var(--surface-2);border:1px solid var(--line)}
.seg-btn{flex:1;min-width:0;min-height:42px;border:0;background:transparent;color:var(--fg2);font-weight:620;font-size:13px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 10px;transition:var(--tcol),box-shadow .18s var(--ease),scale .14s var(--spring)}
.seg-btn .ic{width:15px;height:15px;opacity:.75;flex:none}
.seg-btn span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media (hover:hover){.seg-btn:not(.on):not(:disabled):hover{color:var(--fg)}}
.seg-btn:active:not(:disabled){scale:.97}
.seg-btn.on{background:var(--surface);color:var(--fg);box-shadow:var(--shadow-sm)}
.seg-btn.on .ic{opacity:1;color:var(--accent-text)}
.seg-btn:disabled{opacity:.4;cursor:not-allowed}
/* padding reserves the «выгодно» badge overhang UNCONDITIONALLY so the row never reflows when the recommended chip moves */
.months{display:flex;gap:9px;flex-wrap:wrap;padding-top:9px;padding-right:7px}
.mchip{position:relative;display:inline-flex;align-items:center;gap:6px;padding:8px 14px;min-height:42px;border-radius:10px;border:1px solid var(--line);background:var(--surface-2);color:var(--fg2);font-size:13px;font-weight:620;cursor:pointer;transition:var(--tcol),box-shadow .2s var(--ease),translate .12s var(--spring)}
/* selected-state gradient lives on a pseudo so it can FADE (gradient images aren't interpolable);
   opacity is GPU-cheap → the chip cross-fades to red instead of snapping */
.mchip::before{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--grad-deep);opacity:0;transition:opacity .2s var(--ease);pointer-events:none}
@media (hover:hover){.mchip:not(.on):hover{border-color:var(--line-2);color:var(--fg)}}
.mchip:active{scale:.97}
.mchip>*{position:relative;z-index:1}                 /* keep label/disc above the gradient pseudo */
.mchip.on{color:#fff;border-color:transparent;box-shadow:var(--glow)}
.mchip.on::before{opacity:1}
.mchip .disc{font-style:normal;font-size:10px;font-weight:760;color:var(--ok)}
.mchip.on .disc{color:#fff;opacity:.95}
.mchip.best{border-color:var(--accent-line)}
.mchip .best-flag{position:absolute;top:-9px;right:-6px;font-style:normal;font-size:9px;font-weight:800;letter-spacing:.02em;text-transform:uppercase;line-height:1;padding:3px 6px;border-radius:99px;background:var(--grad);color:#fff;box-shadow:var(--shadow-sm);pointer-events:none;white-space:nowrap}
.mchip.on .best-flag{background:#fff;color:var(--accent-text)}
.cc-head{display:flex;align-items:center;gap:12px}
.cc-flag{flex:none;width:34px;height:34px;display:grid;place-items:center;border-radius:8px;background:var(--surface-2);border:1px solid var(--line);overflow:hidden}
.cc-flag img.emoji{width:24px;height:18px;vertical-align:0;border-radius:3px;box-shadow:0 1px 2px rgba(0,0,0,.25)}
.cc-titles{min-width:0}
.cc-name{font-size:16px;font-weight:680;letter-spacing:-.01em;color:var(--fg);line-height:1.2;overflow:hidden;text-overflow:ellipsis}
.cc-sub{font-size:12px;color:var(--fg3);margin-top:2px;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.cc-meta{display:flex;flex-wrap:wrap;gap:6px 14px;font-size:12.5px;color:var(--fg2)}
.cc-meta span{display:inline-flex;align-items:center;gap:6px}
.cc-meta .ic{width:14px;height:14px;color:var(--accent-text)}
.cc-desc{font-size:13.5px;color:var(--fg2);line-height:1.5}
.cc-price{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-top:2px}
.cc-final{font-size:26px;font-weight:780;letter-spacing:-.025em;color:var(--fg);line-height:1}
.cc-per{font-size:13px;color:var(--fg3);font-weight:520}
.cc-gross{font-size:14px;color:var(--fg3);text-decoration:line-through;font-weight:500}
.cc-disc{font-size:11.5px;font-weight:720;color:var(--accent-text);background:var(--accent-soft);border:1px solid var(--accent-line);padding:3px 8px;border-radius:99px}
.plugin-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.lock-banner{display:flex;align-items:center;gap:8px;padding:10px 13px;border-radius:10px;background:var(--warn-bg);border:1px solid var(--warn-line);color:var(--warn);font-size:12.5px;font-weight:620}
.lock-banner .ic{width:16px;height:16px;flex:none}
.country-card.locked{opacity:.96}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;min-height:46px;border-radius:var(--r);border:1px solid var(--line-2);background:var(--surface);color:var(--fg);font-size:14.5px;font-weight:640;cursor:pointer;text-align:center;text-decoration:none;transition:var(--tcol),translate .12s var(--spring),box-shadow .2s var(--ease)}
.btn .ic{width:17px;height:17px;flex:none}
@media (hover:hover){.btn:hover{border-color:var(--line-2);background:var(--surface-2);translate:0 -1px;color:var(--fg)}}
.btn:active{translate:0 0;opacity:.92}
.btn.primary{background:var(--grad-deep);color:#fff;border-color:transparent;box-shadow:var(--glow),inset 0 1px 0 rgba(255,255,255,.22)}
@media (hover:hover){.btn.primary:hover{filter:brightness(1.06);background:var(--grad-deep)}}
.btn.ghost{background:transparent;border-color:var(--line)}
@media (hover:hover){.btn.ghost:hover{background:var(--surface-2)}}
.btn.sm{padding:7px 13px;min-height:40px;font-size:13px;border-radius:10px}
.btn.sm .ic{width:15px;height:15px}
.btn.full{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;translate:0!important;filter:none}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}
.btn-row .btn{flex:1 1 auto}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:620;color:var(--fg2);margin-bottom:6px}
.input{width:100%;padding:12px 15px;min-height:48px;border-radius:var(--r);border:1px solid var(--line-3);background:var(--surface);color:var(--fg);font-size:16px;font-family:inherit;outline:none;transition:border-color .18s var(--ease),box-shadow .18s var(--ease),background-color var(--t-theme) var(--ease),color var(--t-theme) var(--ease)}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}
.input::placeholder{color:var(--fg3)}
.field-hint{display:block;margin-top:6px;font-size:12px;color:var(--fg3)}
/* жёсткая блокировка фона на мобиле: overflow:hidden не держит iOS — фиксируем body (позицию восстанавливаем в JS) */
body.modal-open{position:fixed;left:0;right:0;width:100%;overflow:hidden}
#cap{min-height:78px;display:flex;justify-content:center}
.grid{display:grid;gap:16px}
.grid.subs{grid-template-columns:repeat(auto-fill,minmax(330px,1fr))}
.country-card{position:relative;display:flex;flex-direction:column;gap:13px;padding:22px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:var(--tcol),box-shadow .22s var(--ease)}
@media (hover:hover){.country-card:hover{box-shadow:var(--shadow)}}
.sub{gap:12px}
.sub .shead,.fam-card .shead,.fam-invite .shead{display:flex;align-items:center;justify-content:space-between;gap:10px}
.sub .sname,.fam-card .sname,.fam-invite .sname{font-weight:680;font-size:16px;color:var(--fg);display:flex;align-items:center;gap:10px;min-width:0}
.sub .sflag,.fam-card .sflag,.fam-invite .sflag{flex:none;width:28px;height:28px;display:grid;place-items:center;border-radius:7px;background:var(--surface-2);border:1px solid var(--line);overflow:hidden}
.sub .sflag img.emoji,.fam-card .sflag img.emoji,.fam-invite .sflag img.emoji{width:20px;height:15px;vertical-align:0;border-radius:2px}
.sub .sname span.txt,.fam-card .sname span.txt,.fam-invite .sname span.txt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fam-card .shead>.tag,.fam-invite .shead>.tag{flex:none}
.exp{font-size:13px;font-weight:640;color:var(--fg2);display:inline-flex;align-items:center;gap:6px}
.exp .ic{width:15px;height:15px}
.exp.ok{color:var(--ok)} .exp.soon{color:var(--warn)} .exp.eternal{color:var(--accent-text)}
.bar{height:6px;border-radius:99px;background:var(--surface-2);overflow:hidden;border:1px solid var(--line)}
.bar i{display:block;height:100%;background:var(--grad);border-radius:99px;transition:width .6s var(--ease-out)}
.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:99px;font-size:11px;font-weight:680;letter-spacing:.01em}
.tag .ic{width:13px;height:13px}
.tag.bypass{background:var(--warn-bg);color:var(--warn);border:1px solid var(--warn-line)}
.tag.family{background:var(--ok-bg);color:var(--ok);border:1px solid var(--ok-line)}
.tag.awg{background:var(--accent-soft);color:var(--accent-text);border:1px solid var(--accent-line)}
.tag.plugin{background:var(--info-bg);color:var(--info);border:1px solid var(--info-line)}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.stat{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm);transition:var(--tcol)}
.stat .shd{display:flex;align-items:center;gap:8px;color:var(--fg2);font-size:13px;font-weight:600;margin-bottom:10px}
.stat .shd .ic{width:16px;height:16px;color:var(--accent-text)}
.stat .val{font-size:27px;font-weight:760;letter-spacing:-.025em;color:var(--fg);line-height:1.15}
.stat .lbl{font-size:13px;color:var(--fg3);margin-top:4px}
.lvl{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:99px;background:var(--accent-soft);color:var(--accent-text);font-weight:680;font-size:14px;border:1px solid var(--accent-line)}
.wallet-cols{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:18px}
.wallet-cols .card{padding:22px}
.wallet-cols h2{font-size:17px;margin-bottom:16px;display:inline-flex;align-items:center;gap:8px}
.wallet-cols h2 .ic{width:18px;height:18px;color:var(--accent-text)}
.modal-bg{position:fixed;inset:0;z-index:100;background:var(--scrim);backdrop-filter:blur(6px) saturate(120%);-webkit-backdrop-filter:blur(6px) saturate(120%);display:grid;place-items:center;padding:20px;overscroll-behavior:contain;animation:fade .22s var(--ease) both}
.modal{position:relative;width:100%;max-width:460px;border-radius:var(--r-xl);padding:28px;background:var(--glass-bg);border:1px solid var(--line-2);backdrop-filter:blur(26px) saturate(170%);-webkit-backdrop-filter:blur(26px) saturate(170%);box-shadow:var(--shadow-lg);animation:pop .32s var(--spring) both;max-height:92vh;max-height:calc(100dvh - 40px);overflow:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
@supports not ((backdrop-filter:blur(2px)) or (-webkit-backdrop-filter:blur(2px))){.modal{background:var(--surface)}}
@keyframes pop{from{opacity:0;translate:0 14px;scale:.98}to{opacity:1;translate:0 0;scale:1}}
/* анимация ЗАКРЫТИЯ (крестик/клик по фону) */
.modal-bg.closing{animation:fadeout .2s var(--ease) forwards}
/* confirmModal — красивое подтверждение вместо браузерного confirm() */
.cf-msg{margin:14px 0 4px;color:var(--fg2);line-height:1.55;font-size:14.5px}
.cf-actions{display:flex;gap:10px;margin-top:24px}
.cf-actions .btn{flex:1}
.join-note{display:flex;gap:9px;align-items:center;background:var(--accent-soft);border-radius:12px;padding:11px 14px;margin:0 0 16px;font-size:13px;color:var(--fg);line-height:1.4}
.join-note svg{flex:none;width:18px;height:18px;color:var(--accent)}
.inv-link{word-break:break-all;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-top:6px;font-size:12.5px;color:var(--fg2);font-family:ui-monospace,Menlo,monospace}
.modal-bg.closing .modal{animation:popout .2s var(--ease) forwards}
@keyframes fadeout{to{opacity:0}}
@keyframes popout{to{opacity:0;translate:0 14px;scale:.98}}
.modal h3{margin:0 0 4px;font-size:22px;font-weight:740;letter-spacing:-.02em;display:flex;align-items:center;gap:10px;padding-right:46px;min-width:0}
.modal h3>span:not(.bmflag):not(.ic),.modal h3 .txt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.modal h3 .ic{flex:none;color:var(--accent-text)}
.modal .x{position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--fg2);cursor:pointer;display:grid;place-items:center;transition:var(--tcol)}
.modal .x .ic{width:18px;height:18px}
@media (hover:hover){.modal .x:hover{color:var(--fg);border-color:var(--line-2)}}
.bmflag{flex:none;display:inline-grid;place-items:center;width:30px;height:30px;border-radius:7px;background:var(--surface-2);border:1px solid var(--line);overflow:hidden}
.bmflag img.emoji{width:22px;height:16px;vertical-align:0;border-radius:3px}
.buy-sum{margin:6px 0 18px}
.buy-price{font-size:24px;font-weight:760;letter-spacing:-.02em;color:var(--fg);display:flex;align-items:baseline;gap:9px;flex-wrap:wrap}
.qr{display:block;width:208px;height:208px;margin:0 auto;border-radius:var(--r);background:#fff;padding:10px;box-shadow:var(--shadow)}
.confbox{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);padding:14px;font-family:var(--mono);font-size:11.5px;white-space:pre-wrap;word-break:break-all;max-height:190px;overflow:auto;color:var(--fg2)}
.sheet-cap{font-size:13px;margin:2px 0 20px}
.sheet-type{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:99px;background:var(--surface-2);color:var(--fg2);border:1px solid var(--line);font-size:12.5px;font-weight:620}
.sheet-type .ic{width:14px;height:14px;color:var(--accent-text)}
.ssec{margin-bottom:18px}
.seg-wrap .seg-btn{padding:0 8px}.seg-wrap .seg-btn span{font-size:12.5px}
.sheet-feat{display:flex;align-items:flex-start;gap:8px;font-size:13.5px;color:var(--fg2);line-height:1.45;margin:6px 0 16px}
.sheet-feat .ic{width:16px;height:16px;color:var(--accent-text);flex:none;margin-top:2px}
.sheet-fam{display:flex;align-items:flex-start;gap:7px;font-size:12.5px;line-height:1.45;margin:10px 0 16px}
.sheet-fam .ic{width:15px;height:15px;flex:none;margin-top:1px;color:var(--accent-text)}
.sheet-price{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin:0 0 14px}
.sheet-price .cc-final{font-size:30px}
#sheet-body{animation:fade .2s var(--ease) both;view-transition-name:sheetbody}
/* contained, snappy crossfade for тариф/срок repaints — not a heavy whole-page root dissolve */
::view-transition-group(sheetbody),::view-transition-old(sheetbody),::view-transition-new(sheetbody){animation-duration:.22s;animation-timing-function:var(--ease-out)}
.sheet-pay{margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.pname-field{margin-bottom:16px}
.pay-row{display:flex;flex-wrap:wrap;gap:10px}
.pay-row .pay-cta{flex:2 1 200px}
.pay-row #paybal{flex:1 1 130px;width:auto}
.pay-cta{gap:9px}
.pay-cta span{flex:1 1 auto;min-width:0;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pay-cta b{flex:none;font-weight:780;letter-spacing:-.01em;font-size:15.5px}
.sheet-price.bump{animation:pricebump .32s var(--spring)}
@keyframes pricebump{0%{translate:0 0;scale:1}30%{translate:0 -2px;scale:1.03}100%{translate:0 0;scale:1}}
.notice{display:flex;gap:9px;align-items:flex-start;background:var(--accent-soft);border:1px solid var(--accent-line);border-radius:var(--r);padding:13px 15px;font-size:13.5px;color:var(--fg);line-height:1.5}
.notice .ic{width:18px;height:18px;flex:none;margin-top:1px;color:var(--accent-text)}
.notice.warn{background:var(--warn-bg);border-color:var(--warn-line)}
.notice.warn .ic{color:var(--warn)}
.toast{position:fixed;left:50%;bottom:max(24px,env(safe-area-inset-bottom));translate:-50% 0;z-index:200;display:flex;align-items:center;gap:9px;max-width:90vw;padding:13px 18px;border-radius:var(--r);background:var(--glass-bg);border:1px solid var(--line-2);backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);box-shadow:var(--shadow-lg);font-weight:620;font-size:14px;color:var(--fg);animation:toastin .36s var(--spring) both}
@supports not ((backdrop-filter:blur(2px)) or (-webkit-backdrop-filter:blur(2px))){.toast{background:var(--surface)}}
.toast .ic{width:19px;height:19px;flex:none;color:var(--ok)}
.toast.err{border-color:var(--err-line)}
.toast.err .ic{color:var(--err)}
@keyframes toastin{from{opacity:0;translate:-50% 12px}to{opacity:1;translate:-50% 0}}
/* toast exit — was nuked instantly; now eases out (GPU opacity/translate) */
.toast.out{animation:toastout .2s var(--ease) forwards}
@keyframes toastout{to{opacity:0;translate:-50% 8px}}
.spinner{width:16px;height:16px;border:2px solid var(--accent-soft);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;display:inline-block;vertical-align:-3px;flex:none}
.btn .spinner,.pay-cta span.spinner,.btn span.spinner{flex:0 0 18px!important;width:18px;height:18px;box-sizing:border-box}
.btn .btn-load{flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@keyframes spin{to{rotate:360deg}}
.empty{grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--fg2)}
/* скелетон загрузки — заглушки той же высоты, что карточки (без скачка), мягкое мерцание (gated reduced-motion) */
.skels{grid-column:1/-1;display:grid;gap:12px}
.skel{min-height:88px;border-radius:var(--r-lg);background:var(--surface-2);border:1px solid var(--line);position:relative;overflow:hidden}
@media (prefers-reduced-motion:no-preference){
  .skel::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 15%,var(--glass-hi) 50%,transparent 85%);translate:-60% 0;animation:shimmer 1.5s var(--ease) infinite}
  @keyframes shimmer{to{translate:160% 0}}
}
.empty .big{width:60px;height:60px;margin:0 auto 16px;border-radius:16px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-text);border:1px solid var(--accent-line)}
.empty .big .ic{width:28px;height:28px}
footer{flex:none;padding:28px 0;border-top:1px solid var(--line);text-align:center;color:var(--fg3);font-size:13px}
footer a{color:var(--fg2)}
.confbox::-webkit-scrollbar,.modal::-webkit-scrollbar,.adm-profs::-webkit-scrollbar{width:8px;height:8px}
.confbox::-webkit-scrollbar-thumb,.modal::-webkit-scrollbar-thumb,.adm-profs::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:99px}
.adm-tabs{display:flex;gap:4px;flex-wrap:wrap;margin:0 0 26px;padding:4px;border-radius:13px;background:var(--surface-2);border:1px solid var(--line)}
.adm-tab{flex:1 1 auto;min-width:118px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 14px;min-height:42px;border:0;background:transparent;color:var(--fg2);font-weight:620;font-size:13.5px;border-radius:9px;cursor:pointer;transition:var(--tcol),box-shadow .18s var(--ease)}
.adm-tab .ic{width:16px;height:16px;opacity:.8;flex:none}
@media (hover:hover){.adm-tab:not(.on):hover{color:var(--fg)}}
.adm-tab.on{background:var(--surface);color:var(--fg);box-shadow:var(--shadow-sm)}
.adm-tab.on .ic{opacity:1;color:var(--accent-text)}
.adm-stats{margin-bottom:6px}
.adm-search{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.adm-search-field{flex:1 1 240px;display:flex;align-items:center;gap:9px;padding:0 14px;background:var(--surface);border:1px solid var(--line-3);border-radius:var(--r);transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}
.adm-search-field:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}
.adm-search-field>.ic{width:18px;height:18px;color:var(--fg3);flex:none}
.adm-search-field .input,.fam-inv-field .input{border:0;background:none;min-height:46px;padding-left:0;padding-right:0}
.adm-search-field .input:focus,.fam-inv-field .input:focus{box-shadow:none}
.adm-list{display:flex;flex-direction:column;gap:8px}
.adm-row{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:14px 16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);color:var(--fg);cursor:pointer;box-shadow:var(--shadow-sm);font-family:inherit;transition:var(--tcol),translate .14s var(--spring),box-shadow .2s var(--ease)}
.adm-row.static{cursor:default}
@media (hover:hover){.adm-row:not(.static):hover{border-color:var(--line-2);translate:0 -1px;box-shadow:var(--shadow)}}
.adm-row>.ic{width:18px;height:18px;color:var(--fg3);flex:none}
.adm-row-main{flex:1 1 auto;min-width:0}
.adm-row-email{font-weight:640;font-size:14.5px;color:var(--fg);display:flex;align-items:center;gap:7px;flex-wrap:wrap;min-width:0}
.adm-row-sub{font-size:12.5px;color:var(--fg3);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.adm-row-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex:none;font-weight:640;font-size:14px;color:var(--fg)}
.adm-row-meta .dim{font-weight:520;font-size:12px}
.adm-pager{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:18px;font-size:13px;flex-wrap:wrap}
.adm-pager .btn.sm .ic{width:14px;height:14px}
.adm-pager .btn.sm:first-child .ic{rotate:90deg}
.adm-pager .btn.sm:last-child .ic{rotate:-90deg}
.adm-cols{display:grid;gap:16px;grid-template-columns:minmax(280px,360px) 1fr;align-items:start}
.adm-grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 12px}
.adm-promo-form h2{font-size:17px;margin-bottom:18px;display:inline-flex;align-items:center;gap:8px}
.adm-promo-form h2 .ic{width:18px;height:18px;color:var(--accent-text)}
.adm-promo{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm)}
.adm-promo.off{opacity:.6}
.adm-promo-main{flex:1 1 auto;min-width:0}
.adm-promo-code{font-weight:700;font-size:15px;color:var(--fg);letter-spacing:.03em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.adm-promo-side{display:flex;align-items:center;gap:8px;flex:none}
.adm-mini-stats{grid-template-columns:1fr 1fr}
.adm-profs{display:flex;flex-direction:column;gap:7px;max-height:230px;overflow:auto}
.adm-prof{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 13px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;font-size:13.5px}
.adm-prof-name{font-weight:600;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.adm-prof-exp{font-size:12.5px;font-weight:640;flex:none}
.adm-prof-exp.ok{color:var(--ok)}
/* admin: universal manager (lookup + grant/days) */
.btn.xs{padding:5px 10px;min-height:32px;font-size:12px;border-radius:9px;gap:6px}
.btn.xs .ic{width:14px;height:14px}
.adm-lookup-card .adm-mini-stats{margin-top:0}
.adm-lookup-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}
.adm-manage-acts{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.adm-manage-acts .btn{flex:1 1 auto}
.adm-prof.manage{flex-direction:column;align-items:stretch;gap:8px}
.adm-prof-head{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0}
.adm-prof.manage .adm-prof-name{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.adm-prof-acts{display:flex;gap:8px;flex-wrap:wrap}
.adm-check{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--fg2);cursor:pointer;line-height:1.45}
.adm-check input{flex:none;width:18px;height:18px;margin-top:1px;accent-color:var(--accent)}
/* email notifications opt-in toggle */
.notif-card h2 .ic{width:18px;height:18px;color:var(--accent-text)}
.notif-toggle{display:inline-flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface-2);color:var(--fg);font-family:inherit;font-size:14px;font-weight:620;cursor:pointer;text-align:left;transition:var(--tcol),box-shadow .2s var(--ease)}
@media (hover:hover){.notif-toggle:hover{border-color:var(--line-2)}}
.notif-toggle-track{flex:none;position:relative;width:46px;height:27px;border-radius:99px;background:var(--surface-3);border:1px solid var(--line-2);transition:background-color .2s var(--ease),border-color .2s var(--ease)}
.notif-toggle-thumb{position:absolute;top:2px;left:2px;width:21px;height:21px;border-radius:50%;background:var(--fg3);box-shadow:var(--shadow-sm);transition:translate .2s var(--spring),background-color .2s var(--ease)}
.notif-toggle.on .notif-toggle-track{background:var(--accent-soft);border-color:var(--accent-line)}
.notif-toggle.on .notif-toggle-thumb{translate:19px 0;background:var(--accent)}
.notif-toggle-label{flex:1 1 auto;min-width:0}
.notif-recent{margin-top:4px}
.notif-item{display:flex;align-items:center;gap:11px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;font-size:13px;margin-bottom:7px}
.notif-item-ic{flex:none;display:grid;place-items:center;width:26px;height:26px;border-radius:7px}
.notif-item-ic .ic{width:15px;height:15px}
.notif-item-ic.sent{background:var(--ok-bg);color:var(--ok);border:1px solid var(--ok-line)}
.notif-item-ic.queued{background:var(--warn-bg);color:var(--warn);border:1px solid var(--warn-line)}
.notif-item-body{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}
.notif-item-subj{font-weight:620;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.notif-item-meta{font-size:11.5px;color:var(--fg3);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* family: advanced add-by-id */
.fam-adv{margin-top:4px;border-top:1px solid var(--line);padding-top:12px}
.fam-adv summary{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:620;color:var(--fg3);cursor:pointer;list-style:none}
.fam-adv summary::-webkit-details-marker{display:none}
.fam-adv summary .ic{width:15px;height:15px}
@media (hover:hover){.fam-adv summary:hover{color:var(--fg2)}}
.country-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.fam-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}
.fam-card,.fam-invite{gap:14px}
.fam-members{display:flex;flex-direction:column;gap:7px}
.fam-members .cap{margin:0 0 1px}
.fam-member{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;font-size:13.5px}
.fam-member-ic{flex:none;display:grid;place-items:center;width:26px;height:26px;border-radius:7px;background:var(--accent-soft);color:var(--accent-text);border:1px solid var(--accent-line)}
.fam-member-ic .ic{width:15px;height:15px}
.fam-member-label{flex:1 1 auto;min-width:0;font-weight:600;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fam-x{flex:none;display:grid;place-items:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:var(--surface);color:var(--fg3);cursor:pointer;transition:var(--tcol)}
.fam-x .ic{width:15px;height:15px}
@media (hover:hover){.fam-x:hover{color:var(--err);border-color:var(--err-line)}}
.fam-inv-form{display:flex;gap:9px;flex-wrap:wrap}
.fam-inv-field{flex:1 1 180px;display:flex;align-items:center;gap:8px;padding:0 13px;background:var(--surface);border:1px solid var(--line-3);border-radius:var(--r);transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}
.fam-inv-field:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}
.fam-inv-field>.ic{width:17px;height:17px;color:var(--fg3);flex:none}
.fam-inv-form .btn{flex:none}
@media (max-width:900px){.adm-cols{grid-template-columns:1fr}}
@media (max-width:760px){:root{--gutter:18px}.ccgrid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}
@media (max-width:640px){
  :root{--gutter:16px}
  main{padding:28px 0 60px}
  h1{font-size:27px}
  h2{font-size:18px}
  .lead{font-size:15px;margin-bottom:24px}
  .hero{margin:0 auto 14px;padding-top:0}
  .ccgrid,.plugin-grid,.grid.subs,.fam-grid{grid-template-columns:1fr;gap:12px}
  .card{padding:20px}
  .country-card{padding:20px}
  .modal{padding:22px;border-radius:var(--r-xl)}
  .brand{font-size:16px}
  .brand .logo{width:32px;height:32px}
  .cattabs{display:flex;width:100%}
  .cattab{flex:1 1 0}
  .topbar .nav{display:none}
  #botnav:not(:empty){display:flex;position:fixed;left:0;right:0;bottom:0;top:auto;z-index:60;align-items:stretch;justify-content:space-around;gap:2px;padding:7px 6px calc(7px + env(safe-area-inset-bottom,0px));background:var(--glass-bg);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border-top:1px solid var(--line);box-shadow:0 -10px 30px -20px rgba(0,0,0,.5);overflow:visible;transition:var(--tcol)}
  @supports not ((backdrop-filter:blur(2px)) or (-webkit-backdrop-filter:blur(2px))){#botnav:not(:empty){background:var(--surface)}}
  #botnav .nav-btn{flex:1 1 0;flex-direction:column;gap:3px;padding:6px 2px;font-size:10.5px;font-weight:600;border-radius:10px;min-height:48px;background:none;color:var(--fg2)}
  #botnav .nav-btn span{font-size:10.5px;line-height:1.05}
  #botnav .nav-btn .ic{width:21px;height:21px;opacity:.8}
  #botnav .nav-btn.active{color:var(--accent-text);background:none}
  #botnav .nav-btn.active .ic{opacity:1}
  body:has(#botnav:not(:empty)) main{padding-bottom:84px}
  body:has(#botnav:not(:empty)) .toast{bottom:calc(78px + env(safe-area-inset-bottom,0px))}
  .nav-btn,.mchip,.seg-btn{min-height:48px}
  .theme-toggle{width:44px;height:44px}
  .modal .x{width:44px;height:44px}
  .btn.sm{min-height:44px}
  .fam-x{width:44px;height:44px}
  .pay-row{flex-direction:column}
  .pay-row .pay-cta,.pay-row #paybal{flex:1 1 auto;width:100%}
  .adm-cols>*{min-width:0}
  .adm-tab{min-width:0;flex:1 1 40%;font-size:12.5px}
  .adm-tab,.adm-row{min-height:44px}
}
@media (max-width:420px){
  .stats{grid-template-columns:1fr}
  .cc-final{font-size:24px}
  .stat .val{font-size:24px}
  .ccard{padding:16px;min-height:80px;column-gap:12px}
  .ccard-name{font-size:15.5px}
  .ccard-foot{gap:10px}
  .ccard-from b{font-size:16px}
  .sheet-price .cc-final{font-size:27px}
}
@media (max-width:360px){.ccard-foot .ccard-from{display:none}}
@media(max-width:640px){.input,.field input{font-size:16px}.toast{bottom:calc(16px + env(safe-area-inset-bottom,0px))}}
@media (max-width:560px){
  .modal-bg{place-items:end stretch;padding:0;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
  .modal{max-width:none;width:100%;border-radius:var(--r-2xl) var(--r-2xl) 0 0;padding:24px 20px calc(24px + env(safe-area-inset-bottom,0px));max-height:calc(100dvh - 28px);animation:sheetup .4s var(--spring) both}
  .modal .x{top:14px;right:14px}
}
@keyframes sheetup{from{translate:0 100%}to{translate:0 0}}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;animation-delay:0ms!important;transition-duration:.05ms!important;scroll-behavior:auto!important}
  .ccard:hover,.mchip:hover,.btn:hover{translate:none!important}
  .ccard:active,.mchip:active,.seg-btn:active,.sheet-price.bump{scale:none!important;translate:none!important}
}
