/* RNO Engine — единый стиль кабинета (ARCHITECTURE §7).
   База — наш дизайн-эталон buy_preview.html: токены, космофон, бренд
   RN◯ Boost со «светлячком». Mobile-first, тап-цели ≥ 44px.
   Один HTML на оба размера: десктоп (≥900px) = sidebar-дашборд,
   мобайл (<900px) = шапка-привет + плавающее нижнее меню. */

/* ============ ШРИФТ (vendored, static/fonts; лицензия OFL рядом) ============ */
@font-face{
  font-family:"Geist";
  src:url("/static/fonts/Geist-Medium.woff2") format("woff2");
  font-weight:500;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Geist";
  src:url("/static/fonts/Geist-Bold.woff2") format("woff2");
  font-weight:700;font-style:normal;font-display:swap;
}

/* ============ ТОКЕНЫ (из buy_preview.html, §7) ============ */
:root{
  --bg-0:#05070d;
  --bg-1:#0a0f1a;
  --panel:rgba(255,255,255,.045);
  --panel-2:rgba(255,255,255,.03);
  --glass:rgba(13,20,35,.55);            /* стекло карточек */
  --glass-border:rgba(255,255,255,.07);
  --border:rgba(255,255,255,.09);
  --border-strong:rgba(255,255,255,.16);
  --cyan:#22d3ee;
  --cyan-soft:rgba(34,211,238,.16);
  --cyan-glow:rgba(34,211,238,.5);
  --violet:#7c3aed;
  --text:#ffffff;
  --muted:#8595ab;
  --muted-2:#aab6c8;
  --green:#34d399;
  --red:#f87171;
  --radius:20px;
  --radius-sm:14px;
  --maxw:480px;
  --shadow:0 24px 60px -24px rgba(0,0,0,.7);
  font-synthesis-weight:none;
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}

/* ============ SPA-НАВИГАЦИЯ (hx-boost): полоска загрузки + переходы ============ */
/* Тонкий прогресс сверху (как в YouTube): htmx вешает .htmx-request на время запроса. */
#progress{
  position:fixed;top:0;left:0;height:2px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--cyan),var(--violet));
  opacity:0;pointer-events:none;
  box-shadow:0 0 8px rgba(34,211,238,.8);
  transition:opacity .25s ease, width .25s ease;
}
#progress.htmx-request{
  opacity:1;width:72%;
  transition:width 1s cubic-bezier(.15,.6,.25,1), opacity .15s ease;
}
/* Смена экрана: View Transitions API — старый <main> растворяется, новый
   всплывает. Шапка/sidebar/нижнее меню вне свопа — стоят как влитые. */
main{view-transition-name:main-vt;}
@keyframes vt-in{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
@keyframes vt-out{from{opacity:1;}to{opacity:0;}}
::view-transition-old(main-vt){animation:vt-out .13s ease both;}
::view-transition-new(main-vt){animation:vt-in .22s ease both;}
/* Фолбэк без View Transitions (Firefox): класс page-enter ставит app.js. */
main.page-enter{animation:vt-in .22s ease both;}
@media (prefers-reduced-motion:reduce){
  ::view-transition-old(main-vt),::view-transition-new(main-vt){animation:none;}
  main.page-enter{animation:none;}
}
html,body{height:100%;}
body{
  font-family:"Geist",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  font-weight:500;
  color:var(--text);
  background:var(--bg-0);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  position:relative;
  min-height:100dvh;
}
a{color:inherit;}

/* ============ КОСМИЧЕСКИЙ ФОН (глубже: 4 radial-glow + звёзды) ============ */
.bg{
  position:fixed;inset:0;z-index:-3;
  background:
    radial-gradient(1100px 720px at 50% -10%, rgba(34,211,238,.15), transparent 55%),
    radial-gradient(900px 620px at 88% 10%, rgba(124,58,237,.17), transparent 58%),
    radial-gradient(820px 560px at 6% 26%, rgba(34,211,238,.08), transparent 55%),
    radial-gradient(940px 720px at 82% 94%, rgba(124,58,237,.10), transparent 62%),
    linear-gradient(180deg, var(--bg-1) 0%, #070b14 52%, var(--bg-0) 100%);
}
.glow-top{
  position:fixed;top:-280px;left:50%;transform:translateX(-50%);
  width:760px;height:760px;border-radius:50%;
  background:radial-gradient(circle at 50% 50%, rgba(34,211,238,.16), rgba(124,58,237,.10) 45%, transparent 66%);
  filter:blur(18px);z-index:-2;pointer-events:none;
}
.stars{
  position:fixed;inset:0;z-index:-2;pointer-events:none;
  background-image:
    radial-gradient(1px 1px at 20px 30px,#fff,transparent),
    radial-gradient(1px 1px at 140px 80px,rgba(255,255,255,.7),transparent),
    radial-gradient(1.4px 1.4px at 260px 160px,#fff,transparent),
    radial-gradient(1px 1px at 80px 220px,rgba(255,255,255,.6),transparent),
    radial-gradient(1.2px 1.2px at 330px 280px,#fff,transparent),
    radial-gradient(1px 1px at 200px 360px,rgba(255,255,255,.55),transparent),
    radial-gradient(1.5px 1.5px at 30px 420px,#fff,transparent),
    radial-gradient(1px 1px at 300px 60px,rgba(255,255,255,.5),transparent),
    radial-gradient(1px 1px at 360px 200px,rgba(255,255,255,.45),transparent);
  background-repeat:repeat;
  background-size:380px 460px;
  opacity:.5;
  animation:twinkle 7s ease-in-out infinite alternate;
}
@keyframes twinkle{from{opacity:.32}to{opacity:.62}}
.earth{
  position:fixed;bottom:-58vw;left:50%;transform:translateX(-50%);
  width:150vw;height:150vw;max-width:1200px;max-height:1200px;border-radius:50%;
  background:radial-gradient(circle at 50% 30%, #0b1320 0%, #070b14 55%, #05070d 72%);
  box-shadow:
    0 -2px 60px 8px rgba(34,211,238,.20),
    inset 0 14px 60px -10px rgba(34,211,238,.32);
  border-top:1px solid rgba(34,211,238,.32);
  z-index:-2;pointer-events:none;
}
@media (prefers-reduced-motion:reduce){
  .stars{animation:none;opacity:.45;}
}

/* ============ КОНТЕЙНЕР ============ */
.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  min-height:100dvh;
  display:flex;flex-direction:column;
  padding:
    calc(20px + env(safe-area-inset-top))
    18px
    calc(24px + env(safe-area-inset-bottom));
  position:relative;z-index:1;
}
.wrap > main{flex:1;}
.top{display:flex;justify-content:center;margin:2px 0 18px;}
/* контент не прячется под плавающим нижним меню */
body.app .wrap{padding-bottom:calc(96px + env(safe-area-inset-bottom));}

/* ============ БРЕНД RN◯ Boost со «светлячком» ============ */
.brand{
  display:flex;align-items:center;justify-content:center;gap:.04em;
  font-size:30px;letter-spacing:-.01em;
  user-select:none;text-decoration:none;
}
.brand .rn{font-weight:700;color:#fff;}
.brand .ring{
  display:inline-block;width:.62em;height:.62em;border-radius:50%;
  border:3px solid #fff;position:relative;margin:0 .05em;
  box-shadow:0 0 10px rgba(34,211,238,.85), 0 0 22px rgba(34,211,238,.45), inset 0 0 6px rgba(34,211,238,.35);
  filter:drop-shadow(0 0 6px rgba(34,211,238,.6));
  animation:ringPulse 3.4s ease-in-out infinite;
}
/* фирменный «светлячок» — точка бежит точно по линии кольца */
.brand .ring .spark{
  position:absolute;top:50%;left:50%;width:.15em;height:.15em;margin:-.075em 0 0 -.075em;
  border-radius:50%;background:#fff;
  box-shadow:0 0 .06em .02em #cfeeff, 0 0 .16em .06em rgba(70,200,255,.9);
  animation:spark-orbit 4s linear infinite;
}
@keyframes spark-orbit{
  from{transform:rotate(0deg) translateY(calc(-0.31em + 1.5px));}
  to{transform:rotate(360deg) translateY(calc(-0.31em + 1.5px));}
}
.brand .boost{font-weight:500;color:var(--muted-2);margin-left:.12em;}
@keyframes ringPulse{
  0%,100%{box-shadow:0 0 10px rgba(34,211,238,.85), 0 0 22px rgba(34,211,238,.45), inset 0 0 6px rgba(34,211,238,.35);}
  50%{box-shadow:0 0 16px rgba(34,211,238,.95), 0 0 30px rgba(34,211,238,.6), inset 0 0 8px rgba(34,211,238,.45);}
}
@media (prefers-reduced-motion:reduce){
  .brand .ring{animation:none;}
  .brand .ring .spark{animation:none;}
}

/* ============ ШАПКА-ПРИВЕТСТВИЕ (аватар + «Привет!» + колокольчик) ============ */
.appbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin:2px 0 18px;
}
.appbar-user{display:flex;align-items:center;gap:11px;min-width:0;}
.avatar{
  width:42px;height:42px;border-radius:50%;flex:0 0 auto;
  object-fit:cover;border:1px solid var(--border-strong);background:var(--panel);
}
.avatar-letter{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:17px;font-weight:700;color:#fff;border:none;
  background:linear-gradient(135deg, var(--cyan) 0%, var(--violet) 100%);
  box-shadow:0 6px 18px -6px rgba(34,211,238,.55);
  user-select:none;
}
.hello{display:flex;flex-direction:column;min-width:0;line-height:1.25;}
.hello-name{
  font-size:16.5px;font-weight:700;letter-spacing:-.01em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.hello-sub{display:none;font-size:12.5px;color:var(--muted);}  /* только десктоп */
.bell{
  position:relative;flex:0 0 auto;
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:var(--radius-sm);
  color:var(--muted-2);text-decoration:none;
  background:var(--panel);border:1px solid var(--border);
  transition:color .2s ease, border-color .2s ease, background .2s ease;
}
.bell svg{width:21px;height:21px;}
.bell:hover{color:#fff;border-color:var(--cyan);background:var(--cyan-soft);}
/* бейдж-точка непрочитанного: класс пока никем не ставится */
.bell.has-unread::after{
  content:"";position:absolute;top:9px;right:10px;width:9px;height:9px;border-radius:50%;
  background:var(--cyan);box-shadow:0 0 8px 2px rgba(34,211,238,.7);
}

/* ============ НИЖНЕЕ МЕНЮ (мобайл): плавающая капсула с blur ============ */
.bottom-nav{
  position:fixed;left:50%;transform:translateX(-50%);
  bottom:calc(12px + env(safe-area-inset-bottom));
  z-index:40;display:flex;gap:4px;
  padding:7px;border-radius:999px;
  background:rgba(10,15,26,.74);
  border:1px solid var(--border);
  -webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);
  box-shadow:0 18px 50px -18px rgba(0,0,0,.85);
}
.bn-item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  min-width:76px;min-height:52px;padding:6px 10px;border-radius:999px;
  color:var(--muted);text-decoration:none;
  font-size:11px;font-weight:600;letter-spacing:.02em;
  transition:color .2s ease, background .2s ease;
}
.bn-item svg{width:21px;height:21px;}
.bn-item.active{
  color:var(--cyan);
  background:rgba(34,211,238,.12);
  text-shadow:0 0 12px rgba(34,211,238,.6);
}
.bn-item.active svg{filter:drop-shadow(0 0 6px rgba(34,211,238,.55));}

/* ============ SIDEBAR (десктоп; на мобайле скрыт) ============ */
.sidebar{display:none;}

/* ============ ОБЩИЕ БЛОКИ ============ */
.page-title{
  text-align:center;font-size:20px;font-weight:700;letter-spacing:-.01em;
  margin:0 0 16px;
}
.section{margin-bottom:14px;}
/* стекло: глубокая rgba-панель + blur + тонкая внутренняя подсветка сверху */
.card{
  padding:22px 18px;border-radius:var(--radius);
  background:var(--glass);border:1px solid var(--glass-border);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  transition:transform .18s ease, border-color .2s ease;
}
.block-label{
  font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;
  color:var(--muted);margin:0 2px 12px;
}

/* ============ КНОПКИ (тап-цели ≥ 44px) ============ */
.btn-primary{
  display:flex;align-items:center;justify-content:center;gap:9px;
  width:100%;min-height:54px;border:none;border-radius:16px;cursor:pointer;
  font-family:inherit;font-size:16.5px;font-weight:700;color:#04141a;
  text-decoration:none;letter-spacing:.01em;
  background:linear-gradient(95deg, #22d3ee 0%, #38e0f5 100%);
  box-shadow:0 0 0 1px rgba(34,211,238,.4) inset, 0 10px 34px -8px rgba(34,211,238,.65), 0 0 60px -14px rgba(34,211,238,.55);
  transition:transform .12s ease, box-shadow .2s ease, filter .2s ease;
}
.btn-primary:hover{filter:brightness(1.05);}
.btn-primary:active{transform:translateY(1px) scale(.99);}
.btn-ghost{
  display:flex;align-items:center;justify-content:center;
  width:100%;min-height:50px;border-radius:16px;cursor:pointer;
  font-family:inherit;font-size:15px;font-weight:700;color:var(--muted-2);
  text-decoration:none;
  background:transparent;border:1.5px solid var(--border-strong);
  transition:border-color .2s ease, color .2s ease, background .2s ease, transform .12s ease;
}
.btn-ghost:hover{border-color:var(--cyan);color:#fff;}
.btn-ghost:active{transform:scale(.98);}
.btn-ghost.copied{border-color:var(--green);color:var(--green);}
.btn-ghost[disabled]{cursor:default;opacity:.55;}
.btn-ghost[disabled]:hover{border-color:var(--border-strong);color:var(--muted-2);}
.btn-ghost[disabled]:active{transform:none;}
.actions{display:flex;flex-direction:column;gap:10px;}

/* ============ ГЛАВНАЯ: СЧЁТЧИК ОСТАТКА + «ПОДКЛЮЧЕНИЕ» ============ */
.home-grid{display:flex;flex-direction:column;gap:14px;}
.sub-card{text-align:center;padding-top:22px;padding-bottom:24px;}
.connect-card{padding-top:18px;}
.connect-card .howto-link{margin-top:16px;}
.countdown{margin:14px 0 2px;}
.cd-label{
  display:block;font-size:12.5px;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted);margin-bottom:10px;
}
.cd-row{
  display:flex;align-items:baseline;justify-content:center;
  gap:14px;flex-wrap:wrap;
}
.cd-part{display:inline-flex;align-items:baseline;gap:5px;}
.cd-num{
  font-size:52px;font-weight:700;letter-spacing:-.04em;line-height:1;
  background:linear-gradient(135deg,#ffffff 20%,var(--cyan) 75%,var(--violet) 115%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:#fff;
  text-shadow:0 0 34px rgba(34,211,238,.22);
}
.cd-unit{font-size:15px;font-weight:600;color:var(--muted);}
.cd-small{font-size:26px;}
.cd-dash{font-size:44px;color:var(--muted);-webkit-text-fill-color:currentColor;background:none;opacity:.7;}
.cd-until{font-size:14px;color:var(--muted-2);margin-top:12px;}

.status-line{
  display:flex;align-items:center;justify-content:center;gap:10px;
  flex-wrap:wrap;margin-bottom:2px;
}
.status-top{margin-bottom:6px;}
.pill{
  display:inline-flex;align-items:center;gap:7px;
  font-size:13px;font-weight:700;letter-spacing:.02em;
  padding:5px 13px;border-radius:999px;
  background:var(--panel);border:1px solid var(--border-strong);color:var(--muted-2);
}
.pill::before{
  content:"";width:7px;height:7px;border-radius:50%;
  background:var(--muted);flex:0 0 auto;
}
.pill-active{
  color:var(--green);border-color:rgba(52,211,153,.35);background:rgba(52,211,153,.10);
}
.pill-active::before{background:var(--green);box-shadow:0 0 8px 1px rgba(52,211,153,.7);}
.pill-expired{
  color:var(--red);border-color:rgba(248,113,113,.35);background:rgba(248,113,113,.08);
}
.pill-expired::before{background:var(--red);box-shadow:0 0 8px 1px rgba(248,113,113,.6);}
.end-date{font-size:14px;color:var(--muted-2);}
.hint-center{font-size:14px;color:var(--muted);margin-top:10px;line-height:1.55;}

.howto-link{text-align:center;margin-top:18px;}
.howto-link a{
  display:inline-block;padding:10px 6px; /* тап-цель ≥ 44px вместе с margin */
  color:var(--muted-2);font-size:14px;font-weight:500;
  text-decoration:none;border-bottom:1px solid rgba(255,255,255,.18);
}
.howto-link a:hover{color:#fff;border-color:var(--cyan);}

/* ============ ТАРИФЫ: КАРТОЧКИ ИЗ БД ============ */
.plans-grid{display:flex;flex-direction:column;gap:12px;margin-top:6px;}
.plan-card{position:relative;text-align:center;padding:24px 18px 20px;}
.plan-best{
  border-color:rgba(34,211,238,.35);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),
             0 0 0 1px rgba(34,211,238,.22),
             0 18px 50px -24px rgba(34,211,238,.5);
}
.badge-best{
  position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  padding:4px 12px;border-radius:999px;color:#04141a;white-space:nowrap;
  background:linear-gradient(90deg, #22d3ee, #7c3aed);
  box-shadow:0 6px 18px -6px rgba(34,211,238,.8);
}
.plan-title{font-size:15px;font-weight:700;color:var(--muted-2);margin-bottom:10px;}
.plan-amount{display:flex;align-items:baseline;justify-content:center;gap:6px;}
.plan-rub{
  font-size:40px;font-weight:700;letter-spacing:-.03em;line-height:1;
  background:linear-gradient(135deg,#ffffff 30%,var(--cyan) 95%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:#fff;
}
.plan-cur{font-size:20px;font-weight:700;color:var(--muted-2);}
.plan-per{font-size:13px;color:var(--muted);margin:6px 0 16px;}
.btn-soon{min-height:46px;}
.plans-note{text-align:center;font-size:13px;color:var(--muted);margin-top:16px;line-height:1.55;}

/* ============ КАК ПОДКЛЮЧИТЬСЯ: 3 ШАГА ============ */
.steps{display:flex;flex-direction:column;gap:12px;margin-top:6px;}
.step-card{display:flex;gap:14px;align-items:flex-start;}
.step-num{
  flex:0 0 auto;width:38px;height:38px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:700;color:#fff;
  background:linear-gradient(135deg, var(--cyan) 0%, var(--violet) 100%);
  box-shadow:0 8px 22px -8px rgba(34,211,238,.7);
  user-select:none;
}
.step-body{min-width:0;}
.step-title{font-size:16px;font-weight:700;margin:7px 0 4px;}
.step-text{font-size:14px;color:var(--muted-2);line-height:1.55;}
.store-links{display:flex;gap:9px;margin-top:12px;flex-wrap:wrap;}
.store-link{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:44px;padding:0 16px;border-radius:12px;
  font-size:13.5px;font-weight:700;color:#fff;text-decoration:none;
  background:var(--panel);border:1.5px solid var(--border-strong);
  transition:border-color .2s ease, background .2s ease;
}
.store-link:hover{border-color:var(--cyan);background:var(--cyan-soft);}

/* ============ УВЕДОМЛЕНИЯ: EMPTY-STATE ============ */
.empty-card{text-align:center;padding:46px 20px 42px;}
.empty-bell{display:flex;justify-content:center;margin-bottom:14px;color:#fff;opacity:.16;}
.empty-bell svg{width:84px;height:84px;}
.empty-title{font-size:17px;font-weight:700;margin-bottom:6px;}
.empty-text{font-size:14px;color:var(--muted);line-height:1.55;}

/* ============ ВХОД ИЗ БРАУЗЕРА ============ */
.login-card{text-align:center;padding:30px 20px;margin-top:8vh;}
.login-card h1{font-size:21px;font-weight:700;margin:0 0 10px;}
.login-hint{font-size:14px;color:var(--muted);margin:0 0 22px;line-height:1.55;}
.login-tg-link{
  display:inline-block;margin-top:14px;padding:10px 6px;
  color:var(--cyan);font-size:14px;font-weight:700;text-decoration:none;
  border-bottom:1px solid rgba(34,211,238,.4);
}
.login-tg-link[hidden]{display:none;}

/* ============ ФУТЕР ============ */
.footer-note{
  text-align:center;font-size:12px;color:#566174;
  margin:26px 0 0;line-height:1.6;
}
.footer-note a{
  display:inline-block;padding:10px 6px; /* тап-цель */
  color:var(--muted);text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,.14);
}
.footer-note a:hover{color:var(--muted-2);}

/* ============ ПОЛНЫЙ ЭКРАН (Telegram Mini App, Bot API 8.0+) ============ */
/* В fullscreen страница уходит ПОД системный статус-бар и кнопки Telegram —
   приподнимаем контент на их высоту (SDK выставляет --tg-*-inset сам). */
.tg-fullscreen .wrap{
  padding-top:calc(
    var(--tg-safe-area-inset-top, 0px) +
    var(--tg-content-safe-area-inset-top, 0px) + 10px
  );
}

/* ============ ПЛАНШЕТ / УЗКИЙ ДЕСКТОП ============ */
@media (min-width:560px){
  .wrap{padding-top:44px;}
  .brand{font-size:34px;}
  .login-card{margin-top:10vh;}
}

/* ============ ДЕСКТОП (≥900px): ПРЕМИУМ-ДАШБОРД С SIDEBAR ============ */
@media (min-width:900px){
  /* sidebar: глубокое стекло слева, бренд + навигация + профиль */
  .sidebar{
    display:flex;flex-direction:column;
    position:fixed;top:0;left:0;bottom:0;width:250px;z-index:20;
    padding:26px 16px calc(20px + env(safe-area-inset-bottom));
    background:rgba(10,15,26,.55);
    border-right:1px solid rgba(255,255,255,.07);
    -webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);
  }
  .sidebar .brand{font-size:25px;justify-content:flex-start;margin:0 8px 28px;}
  .side-nav{display:flex;flex-direction:column;gap:6px;flex:1;}
  .side-link{
    position:relative;display:flex;align-items:center;gap:11px;
    padding:12px 14px;border-radius:var(--radius-sm);
    color:var(--muted-2);font-size:14.5px;font-weight:600;text-decoration:none;
    transition:color .2s ease, background .2s ease;
  }
  .side-link svg{flex:0 0 auto;width:20px;height:20px;}
  .side-link:hover{color:#fff;background:rgba(255,255,255,.05);}
  .side-link.active{
    color:#fff;background:rgba(34,211,238,.10);
    box-shadow:inset 0 0 24px -10px rgba(34,211,238,.45);
  }
  .side-link.active::before{
    content:"";position:absolute;left:-16px;top:11px;bottom:11px;width:3px;
    border-radius:0 3px 3px 0;
    background:var(--cyan);box-shadow:0 0 10px 1px rgba(34,211,238,.8);
  }
  .side-profile{
    display:flex;align-items:center;gap:10px;margin-top:14px;
    padding:11px 12px;border-radius:16px;
    background:var(--panel-2);border:1px solid var(--border);
  }
  .side-profile .avatar{width:38px;height:38px;}
  .side-profile .avatar-letter{font-size:15px;}
  .side-profile-text{display:flex;flex-direction:column;min-width:0;line-height:1.3;}
  .side-name{
    font-size:14px;font-weight:700;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  }
  .side-username{
    font-size:12px;color:var(--muted);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  }

  /* контент правее sidebar; внутри — колонка ~920px */
  body.app .wrap{
    max-width:none;
    margin:0 0 0 250px;
    padding:32px 44px 56px;     /* нижнего меню нет — обычный нижний отступ */
  }
  body.app .appbar,
  body.app .wrap > main{width:100%;max-width:920px;margin-left:auto;margin-right:auto;}

  /* topbar: приветствие + подзаголовок; аватар не нужен (профиль в sidebar) */
  .appbar{
    margin:0 auto 28px;padding-bottom:18px;
    border-bottom:1px solid rgba(255,255,255,.06);
  }
  .appbar .avatar{display:none;}
  .hello-sub{display:block;}
  .hello-name{font-size:22px;}
  .bottom-nav{display:none;}

  .page-title{text-align:left;font-size:24px;margin-bottom:18px;}

  /* hover-подъём карточек — только там, где есть курсор */
  .card:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.13);}

  /* главная: grid 2 колонки — счётчик пошире + «Подключение» */
  .home-grid{
    display:grid;grid-template-columns:1.45fr 1fr;gap:16px;
    align-items:stretch;
  }
  .sub-card{display:flex;flex-direction:column;justify-content:center;}
  .connect-card{display:flex;flex-direction:column;}
  .connect-card .actions{flex:1;justify-content:center;}

  /* тарифы: сетка 2×2 */
  .plans-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:14px;}

  /* Fullscreen Mini App на планшете (iPad репортит platform 'ios',
     Android-планшеты — 'android', и при ширине ≥900px попадают сюда).
     Шорткат padding у body.app .wrap выше перебил бы tg-инсеты —
     возвращаем их в padding-top (специфичность 0,3,1 > 0,2,1).
     Sidebar fixed top:0 — приподнимаем его контент на те же инсеты. */
  .tg-fullscreen body.app .wrap{
    padding-top:calc(
      32px +
      var(--tg-safe-area-inset-top, 0px) +
      var(--tg-content-safe-area-inset-top, 0px)
    );
  }
  .tg-fullscreen .sidebar{
    padding-top:calc(
      26px +
      var(--tg-safe-area-inset-top, 0px) +
      var(--tg-content-safe-area-inset-top, 0px)
    );
  }
}
