@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Manrope:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* ── OLED Black ── */
  --bg:            #000000;
  --bg-2:          #09080a;

  /* ── Glass surfaces ── */
  --card:          rgba(255, 255, 255, 0.042);
  --card-hi:       rgba(255, 255, 255, 0.072);
  --glass:         rgba(255, 255, 255, 0.028);
  --glass-hover:   rgba(255, 255, 255, 0.06);

  /* ── Gold accent ── */
  --accent:        #d49810;
  --accent-dim:    #b07a09;
  --accent-glow:   rgba(212, 152, 16, 0.22);
  --accent-bg:     rgba(212, 152, 16, 0.10);
  --accent-border: rgba(212, 152, 16, 0.28);

  /* ── Secondary (silver-white) ── */
  --violet:        rgba(255, 255, 255, 0.65);
  --violet-dim:    rgba(255, 255, 255, 0.38);
  --violet-bg:     rgba(255, 255, 255, 0.04);
  --violet-border: rgba(255, 255, 255, 0.13);

  /* ── Text ── */
  --text:          #ffffff;
  --text-dim:      rgba(255, 255, 255, 0.72);
  --muted:         rgba(255, 255, 255, 0.42);

  /* ── Status ── */
  --green:         #3de89a;
  --green-bg:      rgba(61, 232, 154, 0.07);
  --green-border:  rgba(61, 232, 154, 0.2);
  --green-glow:    rgba(61, 232, 154, 0.12);

  --red:           #ff5757;
  --red-bg:        rgba(255, 87, 87, 0.07);
  --red-border:    rgba(255, 87, 87, 0.2);

  --amber:         #f5c842;
  --amber-bg:      rgba(245, 200, 66, 0.07);
  --amber-border:  rgba(245, 200, 66, 0.2);

  /* ── Glass borders ── */
  --border:        rgba(255, 255, 255, 0.07);
  --border-md:     rgba(255, 255, 255, 0.11);
  --border-hi:     rgba(255, 255, 255, 0.2);

  --radius:    18px;
  --radius-sm: 12px;
  --radius-lg: 26px;
  --radius-xl: 32px;

  --t:  0.22s cubic-bezier(.23,1,.32,1);
  --t2: 0.38s cubic-bezier(.23,1,.32,1);
}

/* ── Base ── */
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Manrope', sans-serif;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* Ambient dark blobs — имитируют объёмные сферы как на скриншоте */
body::before {
  content: '';
  position: fixed;
  top: -280px; right: -180px;
  width: 640px; height: 640px;
  border-radius: 50%;
  background: radial-gradient(ellipse,
    rgba(50, 42, 18, 0.75) 0%,
    rgba(20, 16, 6, 0.4) 45%,
    transparent 72%);
  filter: blur(48px);
  pointer-events: none; z-index: 0;
}
body::after {
  content: '';
  position: fixed;
  bottom: -260px; left: -180px;
  width: 700px; height: 700px;
  border-radius: 50%;
  background: radial-gradient(ellipse,
    rgba(40, 34, 14, 0.65) 0%,
    rgba(16, 13, 5, 0.35) 45%,
    transparent 70%);
  filter: blur(60px);
  pointer-events: none; z-index: 0;
}
.navbar, main, footer { position: relative; z-index: 1; }
h1, h2, h3, h4 { font-family: 'Syne', sans-serif; }

/* ── Navbar ── */
.navbar {
  position: sticky; top: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: .875rem 2rem;
  background: rgba(0, 0, 0, 0.72);
  backdrop-filter: blur(32px) saturate(160%);
  -webkit-backdrop-filter: blur(32px) saturate(160%);
  border-bottom: 1px solid var(--border);
}
.brand {
  font-family: 'Syne', sans-serif;
  font-size: 1.22rem; font-weight: 800;
  color: #fff; text-decoration: none;
  letter-spacing: -.02em;
  display: flex; align-items: center; gap: .52rem;
  flex-shrink: 0; transition: opacity var(--t);
}
.brand:hover { opacity: .72; }
.brand-logo {
  width: 30px; height: 30px; border-radius: 9px;
  background: var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem;
  box-shadow: 0 0 14px rgba(212,152,16,.35);
  flex-shrink: 0;
}
.nav-links { display: flex; gap: .2rem; align-items: center; }
.nav-links a {
  color: var(--text-dim); text-decoration: none;
  font-size: .875rem; font-weight: 500;
  padding: .42rem .88rem; border-radius: var(--radius-sm);
  transition: color var(--t), background var(--t); white-space: nowrap;
}
.nav-links a:hover { color: var(--text); background: var(--glass-hover); }

/* Hamburger */
.nav-burger {
  display: none;
  flex-direction: column; gap: 5px;
  width: 36px; height: 36px;
  align-items: center; justify-content: center;
  border: none; background: none; cursor: pointer;
  border-radius: var(--radius-sm); padding: 0;
  transition: background var(--t);
}
.nav-burger:hover { background: var(--glass-hover); }
.nav-burger span {
  display: block; width: 20px; height: 2px;
  background: var(--text-dim); border-radius: 2px;
  transition: transform .3s, opacity .3s, background var(--t);
}
.nav-burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); background: var(--accent); }
.nav-burger.open span:nth-child(2) { opacity: 0; }
.nav-burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); background: var(--accent); }

.nav-mobile {
  display: none;
  position: fixed; top: 57px; left: 0; right: 0;
  background: rgba(0,0,0,.96);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  border-bottom: 1px solid var(--border);
  padding: .75rem 1.25rem 1rem;
  flex-direction: column; gap: .2rem;
  z-index: 199; animation: slideDown .22s ease;
}
.nav-mobile.open { display: flex; }
.nav-mobile a {
  color: var(--text-dim); text-decoration: none;
  font-size: .95rem; font-weight: 500;
  padding: .72rem 1rem; border-radius: var(--radius-sm);
  transition: color var(--t), background var(--t);
}
.nav-mobile a:hover { color: var(--text); background: var(--glass-hover); }
.mob-divider { height: 1px; background: var(--border); margin: .35rem 0; }
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Layout ── */
main { flex: 1; padding: 2rem; max-width: 1080px; margin: 0 auto; width: 100%; }
footer {
  text-align: center; padding: 1.5rem;
  color: var(--muted); font-size: .8rem;
  border-top: 1px solid var(--border);
  position: relative; z-index: 1;
}
footer a { color: var(--muted); text-decoration: none; transition: color var(--t); }
footer a:hover { color: var(--text-dim); }

/* ── Shared glass base ── */
.glass-base {
  background: var(--card);
  backdrop-filter: blur(24px) saturate(140%);
  -webkit-backdrop-filter: blur(24px) saturate(140%);
  border: 1px solid var(--border-md);
  box-shadow: 0 2px 40px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.07);
}

/* ── Buttons ── */
.btn-primary {
  display: inline-flex; align-items: center; justify-content: center; gap: .4rem;
  padding: .65rem 1.45rem; border-radius: var(--radius-sm);
  border: none; cursor: pointer;
  font-family: 'Manrope', sans-serif; font-size: .9rem; font-weight: 700;
  text-decoration: none; background: var(--accent); color: #000;
  transition: all var(--t); white-space: nowrap;
}
.btn-primary:hover {
  background: var(--accent-dim);
  box-shadow: 0 0 28px rgba(212,152,16,.35); transform: translateY(-1px);
}
.btn-gradient {
  display: inline-flex; align-items: center; justify-content: center; gap: .4rem;
  padding: .65rem 1.45rem; border-radius: var(--radius-sm);
  border: none; cursor: pointer;
  font-family: 'Manrope', sans-serif; font-size: .9rem; font-weight: 700;
  text-decoration: none;
  background: var(--accent);
  color: #000; transition: all var(--t2); white-space: nowrap;
  position: relative; overflow: hidden;
}
.btn-gradient:hover {
  box-shadow: 0 0 36px rgba(212,152,16,.38);
  transform: translateY(-2px); filter: brightness(1.08);
}
.btn-outline {
  display: inline-flex; align-items: center; justify-content: center; gap: .4rem;
  padding: .58rem 1.2rem; border-radius: var(--radius-sm);
  border: 1px solid var(--border-md); background: transparent; color: var(--text-dim);
  font-family: 'Manrope', sans-serif; font-size: .88rem; font-weight: 500;
  text-decoration: none; transition: all var(--t); white-space: nowrap; cursor: pointer;
}
.btn-outline:hover {
  border-color: var(--accent-border); color: var(--accent);
  background: var(--accent-bg); box-shadow: 0 0 18px rgba(212,152,16,.1);
}
.btn-ghost {
  display: inline-flex; align-items: center; justify-content: center; gap: .4rem;
  padding: .65rem 1.45rem; border-radius: var(--radius-sm);
  background: transparent; border: none; color: var(--text-dim);
  font-family: 'Manrope', sans-serif; font-size: .9rem; font-weight: 600;
  text-decoration: none; transition: all var(--t); cursor: pointer;
}
.btn-ghost:hover { color: var(--text); background: var(--glass-hover); }
.btn-sm    { padding: .38rem .88rem !important; font-size: .82rem !important; }
.btn-lg    { padding: .88rem 2.25rem !important; font-size: 1rem !important; }
.btn-block { width: 100%; justify-content: center; }

.btn-copy {
  display: inline-flex; align-items: center; gap: .3rem;
  background: var(--glass); border: 1px solid var(--border-md);
  color: var(--text-dim); padding: .3rem .7rem; border-radius: 7px;
  font-family: 'Manrope', sans-serif; font-size: .75rem; font-weight: 600;
  cursor: pointer; transition: all var(--t); white-space: nowrap;
}
.btn-copy:hover { background: var(--glass-hover); color: var(--text); border-color: var(--border-hi); }
.btn-copy.copied { background: var(--green-bg); border-color: var(--green-border); color: var(--green); }

/* Telegram button */
.btn-tg {
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  width: 100%; padding: .88rem 1.25rem; border-radius: var(--radius-sm);
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border-md);
  color: #fff; font-family: 'Manrope', sans-serif;
  font-size: .95rem; font-weight: 700;
  cursor: pointer; transition: all var(--t2);
  text-decoration: none;
  backdrop-filter: blur(12px);
}
.btn-tg:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,.1);
  border-color: var(--border-hi);
}

/* ── Badges ── */
.badge {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .28rem .75rem; border-radius: 20px;
  font-size: .7rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
}
.badge-green  { background: var(--green-bg);  color: var(--green);  border: 1px solid var(--green-border); }
.badge-red    { background: var(--red-bg);    color: var(--red);    border: 1px solid var(--red-border); }
.badge-accent { background: var(--accent-bg); color: var(--accent); border: 1px solid var(--accent-border); }
.badge-amber  { background: var(--amber-bg);  color: var(--amber);  border: 1px solid var(--amber-border); }
.pulse-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor; animation: pulseDot 2s ease-in-out infinite;
}
@keyframes pulseDot {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.4; transform:scale(.6); }
}

/* ── Progress ── */
.progress-wrap { display: flex; align-items: center; gap: .5rem; margin: .25rem 0; }
.progress-bar { flex: 1; height: 4px; background: rgba(255,255,255,.06); border-radius: 2px; overflow: hidden; }
.progress-fill { height: 100%; border-radius: 2px; transition: width .5s ease; width: var(--pct, 0%); }
.progress-fill.green { background: var(--green); }
.progress-fill.amber { background: var(--amber); }
.progress-fill.red   { background: var(--red); }
.progress-label { font-size: .74rem; color: var(--text-dim); flex-shrink: 0; }

/* ── Auth ── */
.auth-wrap {
  min-height: calc(100vh - 58px - 56px);
  display: flex; align-items: center; justify-content: center;
  padding: 2rem 1rem;
}
.auth-box {
  width: 100%; max-width: 440px;
  background: rgba(255, 255, 255, 0.042);
  backdrop-filter: blur(36px) saturate(140%);
  -webkit-backdrop-filter: blur(36px) saturate(140%);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-xl);
  padding: 2.75rem 2.5rem;
  box-shadow: 0 32px 80px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.08);
  position: relative; overflow: hidden;
}
/* Top shimmer line */
.auth-box::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
  pointer-events: none;
}
/* Corner gold glow */
.auth-box::after {
  content: '';
  position: absolute; bottom: -80px; right: -80px;
  width: 220px; height: 220px;
  background: radial-gradient(ellipse, rgba(212,152,16,.06) 0%, transparent 70%);
  pointer-events: none;
}
.auth-logo {
  width: 50px; height: 50px;
  background: var(--accent);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; margin-bottom: 1.25rem;
  box-shadow: 0 8px 28px rgba(212,152,16,.28);
}
.auth-box h1 { font-size: 1.65rem; font-weight: 800; letter-spacing: -.03em; margin-bottom: .3rem; color: #fff; }
.auth-subtitle { color: var(--text-dim); font-size: .88rem; margin-bottom: 1.75rem; line-height: 1.5; }
.auth-form { display: flex; flex-direction: column; gap: .85rem; }

.auth-box input[type="email"],
.auth-box input[type="password"],
.auth-box input[type="text"] {
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border-md);
  border-radius: var(--radius-sm);
  padding: .78rem 1rem;
  color: #fff; font-size: .93rem; font-family: 'Manrope', sans-serif;
  width: 100%; outline: none;
  transition: border-color var(--t), box-shadow var(--t), background var(--t);
}
.auth-box input:focus {
  border-color: rgba(212,152,16,.45);
  box-shadow: 0 0 0 3px rgba(212,152,16,.08);
  background: rgba(212,152,16,.025);
}
.auth-box input::placeholder { color: var(--muted); }

.password-field { position: relative; display: flex; align-items: center; }
.password-field input { padding-right: 3rem; }
.pw-input-row { position: relative; display: flex; align-items: center; }
.pw-input-row input { padding-right: 3rem; width: 100%; }
/* Контейнер с полосой силы внутри */
.pw-bar-wrap {
  border: 1px solid var(--border-md);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.05);
  display: flex; flex-direction: column;
  overflow: hidden;
  transition: border-color var(--t), box-shadow var(--t), background var(--t);
}
.pw-bar-wrap:focus-within {
  border-color: rgba(212,152,16,.45);
  box-shadow: 0 0 0 3px rgba(212,152,16,.08);
  background: rgba(212,152,16,.025);
}
.pw-bar-wrap input[type="password"],
.pw-bar-wrap input[type="text"] {
  background: transparent; border: none; border-radius: 0; box-shadow: none; outline: none;
}
.pw-bar-wrap input[type="password"]:focus,
.pw-bar-wrap input[type="text"]:focus {
  background: transparent; border: none; box-shadow: none;
}
.pw-bar-wrap .pw-strength-wrap { margin: 0; background: rgba(255,255,255,.06); }
.toggle-password {
  position: absolute; right: .78rem;
  background: none; border: none; cursor: pointer;
  color: var(--muted); font-size: 1rem; padding: .25rem;
  transition: color var(--t); line-height: 1;
}
.toggle-password:hover { color: var(--text-dim); }

.divider {
  display: flex; align-items: center; gap: .9rem;
  margin: .5rem 0; color: var(--muted);
  font-size: .76rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
}
.divider::before, .divider::after { content: ''; flex: 1; border-top: 1px solid var(--border); }

.tg-login { display: flex; justify-content: center; }
.auth-link { text-align: center; margin-top: 1rem; color: var(--text-dim); font-size: .88rem; }
.auth-link a { color: var(--accent); text-decoration: none; font-weight: 700; }
.auth-link a:hover { text-decoration: underline; }
.form-error {
  color: var(--red); font-size: .84rem; padding: .6rem .9rem;
  background: var(--red-bg); border: 1px solid var(--red-border); border-radius: var(--radius-sm);
}
.cf-turnstile { display: flex; justify-content: center; }

/* ── Hero ── */
.hero { text-align: center; padding: 5.5rem 1rem 4rem; max-width: 760px; margin: 0 auto; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--accent-bg); border: 1px solid var(--accent-border);
  color: var(--accent); padding: .35rem 1.1rem; border-radius: 50px;
  font-size: .75rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; margin-bottom: 1.75rem;
  box-shadow: 0 0 18px var(--accent-glow);
}
.hero h1 {
  font-size: clamp(2.3rem, 5.5vw, 3.8rem);
  font-weight: 800; line-height: 1.07;
  letter-spacing: -.04em; margin-bottom: 1.3rem; color: #fff;
}
.gradient-text {
  background: linear-gradient(135deg, #f5cc44 0%, #d49810 45%, #c07a08 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero p {
  font-size: 1.08rem; color: var(--text-dim); line-height: 1.68;
  margin-bottom: 2.5rem; max-width: 540px; margin-left: auto; margin-right: auto;
}
.hero-buttons { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; margin-bottom: 3.5rem; }
.hero-stats {
  display: flex; justify-content: center; gap: 3rem; flex-wrap: wrap;
  border-top: 1px solid var(--border); padding-top: 2.5rem;
}
.stat { text-align: center; }
.stat-n { display: block; font-family: 'Syne', sans-serif; font-size: 2rem; font-weight: 800; color: var(--accent); line-height: 1.1; }
.stat-l { font-size: .72rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: .1em; margin-top: .2rem; }

/* ── Sections ── */
.section-eyebrow {
  text-align: center; font-size: .75rem; font-weight: 700;
  color: var(--accent); letter-spacing: .1em; text-transform: uppercase; margin-bottom: .75rem;
}
.section-title { font-size: clamp(1.5rem, 3.5vw, 2rem); font-weight: 800; letter-spacing: -.03em; margin-bottom: .45rem; text-align: center; color: #fff; }
.section-sub { color: var(--text-dim); font-size: .93rem; text-align: center; margin-bottom: 2.25rem; max-width: 480px; margin-left: auto; margin-right: auto; }

/* ── Feature cards ── */
.features-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.25rem; margin: 2.5rem 0; }
.feature-card {
  background: var(--card);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--border); border-radius: var(--radius); padding: 1.75rem 1.6rem;
  box-shadow: 0 2px 32px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
  transition: all var(--t2); position: relative; overflow: hidden;
}
.feature-card:hover {
  border-color: var(--accent-border);
  box-shadow: 0 0 36px rgba(212,152,16,.07), 0 16px 48px rgba(0,0,0,.5);
  transform: translateY(-4px);
}
.feature-icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--accent-bg); border: 1px solid var(--accent-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.25rem; margin-bottom: 1rem;
}
.feature-card h3 { font-size: 1rem; font-weight: 700; margin-bottom: .45rem; color: #fff; }
.feature-card p  { font-size: .86rem; color: var(--text-dim); line-height: 1.6; }

/* ── Steps ── */
.how-section { padding: 3rem 0 1.5rem; }
.steps-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 1.25rem; }
.step-card {
  background: var(--card);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border); border-radius: var(--radius); padding: 1.6rem;
  box-shadow: 0 2px 28px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.05);
  transition: border-color var(--t2), transform var(--t2);
}
.step-card:hover { border-color: var(--border-hi); transform: translateY(-3px); }
.step-num { font-family: 'Syne', sans-serif; font-size: 2.2rem; font-weight: 800; color: var(--accent); opacity: .3; line-height: 1; margin-bottom: .7rem; }
.step-card h3 { font-size: .95rem; font-weight: 700; margin-bottom: .35rem; color: #fff; }
.step-card p  { font-size: .84rem; color: var(--text-dim); line-height: 1.55; }

/* ── Dashboard ── */
.dash-header { margin-bottom: 2.5rem; }
.dash-title { font-size: 1.9rem; font-weight: 800; letter-spacing: -.03em; margin-bottom: .25rem; color: #fff; }
.dash-sub   { color: var(--text-dim); font-size: .9rem; }
.dash-actions-row { display: flex; align-items: center; gap: .75rem; margin-top: 1rem; flex-wrap: wrap; }

/* ── Subscription cards ── */
.subs-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.5rem; margin-bottom: 2.5rem; }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.sub-card {
  background: var(--card);
  backdrop-filter: blur(22px); -webkit-backdrop-filter: blur(22px);
  border: 1px solid var(--border-md); border-radius: var(--radius); padding: 1.5rem;
  display: flex; flex-direction: column; gap: 1.1rem;
  box-shadow: 0 2px 36px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.07);
  transition: all var(--t2); animation: fadeUp .38s ease both;
  animation-delay: var(--delay, 0s);
}
.sub-card.active { border-color: rgba(61,232,154,.15); }
.sub-card.active:hover {
  border-color: rgba(61,232,154,.28);
  box-shadow: 0 0 44px rgba(61,232,154,.07), 0 12px 40px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.07);
  transform: translateY(-3px);
}
.sub-card.expired { opacity: .48; }
.sub-card-top { display: flex; justify-content: space-between; align-items: flex-start; }
.sub-card-label { font-size: .7rem; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; margin-top: .15rem; }
.sub-rows { display: flex; flex-direction: column; gap: 0; }
.sub-row {
  display: flex; justify-content: space-between; align-items: center;
  font-size: .87rem; padding: .5rem 0; border-bottom: 1px solid var(--border);
}
.sub-row:last-child { border-bottom: none; }
.sub-row .lbl { color: var(--text-dim); }
.sub-row .val { font-weight: 600; color: #fff; }
.sub-row .val.g { color: var(--green); }
.sub-row .val.a { color: var(--accent); }

.key-box {
  background: rgba(255,255,255,.03); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: .85rem 1rem;
}
.key-box-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: .5rem; }
.key-lbl { font-size: .7rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: .08em; font-weight: 600; }
.key-val {
  font-family: 'JetBrains Mono', monospace; font-size: .76rem;
  color: var(--text-dim); word-break: break-all; line-height: 1.6;
  filter: blur(5px); transition: filter .3s; cursor: pointer; user-select: none;
}
.key-val.shown { filter: none; user-select: text; cursor: text; }
.key-hint { font-size: .68rem; color: var(--muted); margin-top: .3rem; }

.sub-card-foot { display: flex; gap: .6rem; margin-top: auto; }
.sub-card-foot .btn-primary,
.sub-card-foot .btn-outline { flex: 1; }

/* ── Empty state ── */
.empty-state { text-align: center; padding: 5rem 1.5rem; animation: fadeUp .5s ease both; }
.empty-icon  { font-size: 3.5rem; margin-bottom: 1rem; opacity: .3; }
.empty-state h2 { font-size: 1.45rem; font-weight: 700; margin-bottom: .55rem; color: #fff; }
.empty-state p  { color: var(--text-dim); margin-bottom: 2rem; font-size: .95rem; }

/* ── Quick actions (legacy) ── */
.quick-actions { display: flex; gap: .875rem; flex-wrap: wrap; margin-top: 1rem; }
.action-card {
  background: var(--card); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem 1.4rem;
  text-decoration: none; color: var(--text);
  display: flex; align-items: center; gap: .65rem;
  font-size: .88rem; font-weight: 600; transition: all var(--t2);
}
.action-card:hover {
  border-color: var(--accent-border); color: var(--accent);
  background: var(--accent-bg); transform: translateY(-2px);
}
.action-icon { font-size: 1.1rem; }

/* ── Connect guide ── */
.connect-guide {
  background: var(--card); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border); border-radius: var(--radius); padding: 1.6rem; margin-top: 2rem;
  box-shadow: 0 2px 32px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
}
.connect-guide h2 { font-size: 1.1rem; font-weight: 700; margin-bottom: 1.35rem; color: #fff; }
.connect-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.1rem; }
.connect-step { display: flex; gap: .75rem; align-items: flex-start; }
.connect-num {
  flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%;
  background: var(--accent-bg); border: 1px solid var(--accent-border);
  color: var(--accent); font-size: .74rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.connect-body h4 { font-size: .86rem; font-weight: 700; margin-bottom: .2rem; color: #fff; }
.connect-body p  { font-size: .8rem; color: var(--text-dim); line-height: 1.5; }
.connect-body a  { color: var(--accent); text-decoration: none; font-weight: 600; }
.connect-body a:hover { text-decoration: underline; }

/* ── Buy page ── */
.buy-hero { text-align: center; padding: 3rem 0 2.5rem; }
.buy-hero h1 { font-size: clamp(1.8rem, 4vw, 2.2rem); font-weight: 800; letter-spacing: -.04em; margin-bottom: .5rem; color: #fff; }
.buy-hero p  { color: var(--text-dim); font-size: .95rem; max-width: 480px; margin: 0 auto; }

/* Tariffs carousel */
.tariff-carousel-outer { position: relative; margin-bottom: 2.5rem; }
.tariff-carousel-clip  { overflow: hidden; }
.tariff-carousel-outer .carousel-btn {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.82);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; padding: 0;
  transition: all var(--t2); z-index: 2;
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
}
.tariff-carousel-outer .carousel-btn:hover {
  background: var(--accent-bg); border-color: var(--accent-border); color: var(--accent);
  box-shadow: 0 0 18px var(--accent-glow);
}
.tariff-carousel-outer .carousel-btn:disabled { opacity: .22; pointer-events: none; }
.tariff-carousel-outer .carousel-btn.prev { left: -56px; }
.tariff-carousel-outer .carousel-btn.next { right: -56px; }
@media (max-width: 900px) {
  .tariff-carousel-outer { padding: 0 2.8rem; }
  .tariff-carousel-outer .carousel-btn.prev { left: 0; }
  .tariff-carousel-outer .carousel-btn.next { right: 0; }
}
.tariffs-grid { display: flex; gap: 1.25rem; align-items: stretch; transition: transform 0.44s cubic-bezier(.23,1,.32,1); will-change: transform; }
@keyframes goldShimmer {
  0%   { background-position: 150% 50%, 0 0; }
  100% { background-position: -50% 50%, 0 0; }
}
.tariff-card {
  background:
    linear-gradient(108deg,
      transparent 12%, rgba(212,152,16,.11) 36%,
      rgba(255,220,64,.068) 50%, rgba(212,152,16,.11) 64%, transparent 88%),
    #05070d;
  background-size: 250% 100%, 100% 100%;
  border: 1px solid rgba(212,152,16,0.14);
  border-radius: var(--radius); padding: 1.75rem 1.5rem;
  box-shadow: 0 4px 32px rgba(0,0,0,.78), inset 0 1px 0 rgba(255,255,255,.07);
  display: flex; flex-direction: column;
  position: relative;
  transition: border-color var(--t2), box-shadow var(--t2), transform var(--t2);
  animation: goldShimmer 7s ease-in-out infinite alternate, fadeUp .38s ease both;
}
.tariff-card:nth-child(2) { animation-delay: -1.8s, .07s; }
.tariff-card:nth-child(3) { animation-delay: -3.5s, .14s; }
.tariff-card:nth-child(4) { animation-delay: -5.2s, .21s; }
.tariff-card:nth-child(5) { animation-delay: -2.4s, .28s; }
.tariff-card:hover {
  transform: translateY(-6px);
  border-color: rgba(212,152,16,0.26);
  box-shadow: 0 20px 52px rgba(0,0,0,.84), inset 0 1px 0 rgba(212,152,16,.14);
}
.tariff-card.popular {
  background:
    linear-gradient(108deg,
      transparent 18%, rgba(212,152,16,.082) 40%,
      rgba(255,220,64,.048) 50%, rgba(212,152,16,.082) 60%, transparent 82%),
    #040307;
  background-size: 250% 100%, 100% 100%;
  border: 1px solid rgba(212,152,16,.40);
  box-shadow: 0 0 68px rgba(212,152,16,.14), 0 20px 52px rgba(0,0,0,.86),
              inset 0 1px 0 rgba(212,152,16,.28);
  transform: translateY(-8px);
  animation: goldShimmer 6.5s ease-in-out infinite alternate, fadeUp .38s ease both;
}
.tariff-card.popular:hover {
  transform: translateY(-14px);
  box-shadow: 0 0 92px rgba(212,152,16,.22), 0 28px 64px rgba(0,0,0,.9),
              inset 0 1px 0 rgba(212,152,16,.36);
}
.popular-tag {
  position: absolute; top: -1px; right: 1.4rem;
  background: var(--accent); color: #000;
  font-size: .67rem; font-weight: 800;
  padding: .22rem .72rem; border-radius: 0 0 9px 9px;
  letter-spacing: .08em; text-transform: uppercase;
}
@keyframes badgeShimmer {
  0%   { background-position: 160% 50%; }
  100% { background-position: -60% 50%; }
}
.popular-tag.vip {
  background: linear-gradient(90deg,
    #c07800 0%, #f0b800 22%, #ffe84a 42%,
    #fff0a0 50%, #ffe84a 58%, #f0b800 78%, #c07800 100%);
  background-size: 220% 100%;
  animation: badgeShimmer 2.8s ease-in-out infinite alternate;
  color: #000; box-shadow: 0 2px 18px rgba(255,200,0,.40);
}
@keyframes leaderShimmer {
  0%   { background-position: 160% 50%; }
  100% { background-position: -60% 50%; }
}
@keyframes fireFlicker {
  0%, 100% { transform: scaleY(1)    rotate(-4deg); filter: brightness(1);    }
  20%       { transform: scaleY(1.14) rotate(3deg);  filter: brightness(1.25); }
  45%       { transform: scaleY(0.94) rotate(-2deg); filter: brightness(0.88); }
  70%       { transform: scaleY(1.10) rotate(4deg);  filter: brightness(1.18); }
}
.fire-anim {
  display: inline-block;
  transform-origin: 50% 90%;
  animation: fireFlicker 0.75s ease-in-out infinite;
}
.popular-tag.leader-tag {
  background: linear-gradient(90deg,
    #6b1a00 0%, #c83800 18%, #ff5500 36%,
    #ff9520 50%, #ff5500 64%, #c83800 82%, #6b1a00 100%);
  background-size: 220% 100%;
  animation: leaderShimmer 2.2s ease-in-out infinite alternate;
  color: #fff; box-shadow: 0 2px 18px rgba(200,56,0,.45);
}
.tariff-card.leader {
  border: 1px solid rgba(212,152,16,.17);
  box-shadow: 0 4px 32px rgba(0,0,0,.74), inset 0 1px 0 rgba(255,255,255,.06);
}
.tariff-card.leader:hover {
  transform: translateY(-10px);
  border-color: rgba(212,152,16,0.28);
  box-shadow: 0 20px 52px rgba(0,0,0,.84), inset 0 1px 0 rgba(212,152,16,.14);
}
.tariff-card.leader .btn-buy {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(212,152,16,.34);
  color: #c8a020; font-weight: 700;
  box-shadow: inset 0 1px 0 rgba(255,218,70,.13), inset 0 -1px 0 rgba(0,0,0,.3);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.tariff-card.leader .btn-buy:hover {
  background: rgba(212,152,16,.10);
  border-color: rgba(212,152,16,.48);
  color: #e8c040;
  box-shadow: inset 0 1px 0 rgba(255,218,70,.20), inset 0 -1px 0 rgba(0,0,0,.2);
}

.tariff-period { font-family: 'Syne', sans-serif; font-size: .85rem; font-weight: 700; color: var(--text-dim); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 1rem; }
.tariff-price-row { margin-bottom: 1.2rem; }
.tariff-price    { font-family: 'Syne', sans-serif; font-size: 2.6rem; font-weight: 800; letter-spacing: -.04em; color: #fff; }
.tariff-currency { font-size: 1.2rem; color: var(--text-dim); font-weight: 600; }
.tariff-per-month { margin-top: .3rem; font-size: .8rem; color: var(--text-dim); }
.tariff-save { display: inline-flex; margin-left: .4rem; background: var(--accent-bg); color: var(--accent); border: 1px solid var(--accent-border); border-radius: 6px; font-size: .7rem; font-weight: 700; padding: .14rem .48rem; vertical-align: middle; }
.promo-orig { font-size: .76rem; color: var(--muted); text-decoration: line-through; margin-top: .2rem; }

.tariff-features { list-style: none; display: flex; flex-direction: column; gap: .45rem; flex: 1; margin-bottom: 1.4rem; }
.tariff-features li { display: flex; align-items: center; gap: .5rem; font-size: .85rem; color: var(--text-dim); }
.tariff-features li::before { content: '✓'; color: var(--accent); font-weight: 700; font-size: .72rem; flex-shrink: 0; }

.btn-buy {
  width: 100%; padding: .82rem; border-radius: var(--radius-sm);
  border: none; cursor: pointer;
  font-family: 'Manrope', sans-serif; font-weight: 700; font-size: .9rem;
  transition: all var(--t2);
}
.tariff-card:not(.popular) .btn-buy { background: rgba(255,255,255,.07); color: var(--text); border: 1px solid var(--border-md); }
.tariff-card:not(.popular) .btn-buy:hover { background: var(--accent-bg); border-color: var(--accent-border); color: var(--accent); }
.tariff-card.popular .btn-buy { background: var(--accent); color: #000; }
.tariff-card.popular .btn-buy:hover { filter: brightness(1.08); box-shadow: 0 8px 28px rgba(212,152,16,.3); }

.pay-note { text-align: center; color: var(--muted); font-size: .82rem; display: flex; align-items: center; justify-content: center; gap: .45rem; margin-top: .5rem; }
.buy-error { color: var(--red); font-size: .88rem; padding: .7rem 1.1rem; margin-bottom: 1.75rem; background: var(--red-bg); border: 1px solid var(--red-border); border-radius: var(--radius-sm); text-align: center; }

/* Promo */
.promo-section { max-width: 480px; margin: 0 auto 2.25rem; }
.promo-label { font-size: .78rem; font-weight: 700; color: var(--text-dim); margin-bottom: .5rem; letter-spacing: .04em; text-transform: uppercase; }
.promo-row { display: flex; gap: .5rem; }
.promo-row input {
  flex: 1; padding: .65rem .95rem; border-radius: var(--radius-sm);
  background: rgba(255,255,255,.05); border: 1px solid var(--border-md);
  color: #fff; font-family: 'JetBrains Mono', monospace;
  font-size: .9rem; outline: none; transition: border-color var(--t), box-shadow var(--t);
  text-transform: uppercase; letter-spacing: .06em; backdrop-filter: blur(12px);
}
.promo-row input:focus { border-color: rgba(212,152,16,.42); box-shadow: 0 0 0 2px rgba(212,152,16,.07); }
.btn-promo { padding: .65rem 1.2rem; border-radius: var(--radius-sm); background: var(--accent); color: #000; font-weight: 700; font-size: .86rem; border: none; cursor: pointer; transition: all var(--t); white-space: nowrap; }
.btn-promo:hover { background: var(--accent-dim); box-shadow: 0 0 22px rgba(212,152,16,.28); }
.promo-msg { font-size: .84rem; margin-top: .55rem; min-height: 1.4rem; transition: color var(--t); }
.promo-msg.ok      { color: var(--green); }
.promo-msg.err     { color: var(--red); }
.promo-msg.loading { color: var(--text-dim); }

/* ── Profile ── */
.profile-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.4rem; }
.profile-section {
  background: var(--card); backdrop-filter: blur(22px); -webkit-backdrop-filter: blur(22px);
  border: 1px solid var(--border); border-radius: var(--radius); padding: 1.6rem;
  box-shadow: 0 2px 32px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
}
.profile-section h2 { font-size: .95rem; font-weight: 700; margin-bottom: 1.2rem; padding-bottom: .75rem; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: .45rem; color: #fff; }
.profile-section form { display: flex; flex-direction: column; gap: .75rem; }
.profile-section input {
  background: rgba(255,255,255,.05); border: 1px solid var(--border-md);
  border-radius: var(--radius-sm); padding: .7rem .95rem;
  color: #fff; font-family: 'Manrope', sans-serif; font-size: .9rem; width: 100%;
  transition: border-color var(--t), box-shadow var(--t), background var(--t); outline: none;
}
.profile-section input:focus { border-color: rgba(212,152,16,.42); box-shadow: 0 0 0 3px rgba(212,152,16,.07); background: rgba(212,152,16,.02); }
.profile-section input:disabled { opacity: .35; cursor: not-allowed; }
.profile-section input::placeholder { color: var(--muted); }

.info-list { display: flex; flex-direction: column; }
.info-row { display: flex; justify-content: space-between; align-items: center; font-size: .87rem; padding: .6rem 0; border-bottom: 1px solid var(--border); }
.info-row:last-child { border-bottom: none; }
.info-row .lbl { color: var(--text-dim); flex-shrink: 0; }
.info-row .val { font-weight: 600; max-width: 58%; word-break: break-all; text-align: right; color: #fff; }
.info-row .val.mono { font-family: 'JetBrains Mono', monospace; font-size: .82rem; font-weight: 500; }
.info-row .val.accent { color: var(--accent); }
.info-row .val.green  { color: var(--green); }

.form-msg { font-size: .84rem; padding: .58rem .9rem; border-radius: var(--radius-sm); }
.form-msg.ok  { background: var(--green-bg); color: var(--green); border: 1px solid var(--green-border); }
.form-msg.err { background: var(--red-bg);   color: var(--red);   border: 1px solid var(--red-border); }

/* Toggle */
.toggle-form { margin: .75rem 0; }
.toggle-label { display: flex; align-items: center; justify-content: space-between; cursor: pointer; user-select: none; gap: 1rem; }
.toggle-text { font-size: .9rem; font-weight: 500; color: #fff; }
.toggle-wrap { position: relative; flex-shrink: 0; }
.toggle-wrap input[type=checkbox] { position: absolute; opacity: 0; width: 0; height: 0; }
.toggle-track { display: block; width: 46px; height: 26px; border-radius: 13px; background: rgba(255,255,255,.12); transition: background var(--t); position: relative; cursor: pointer; }
.toggle-thumb { position: absolute; top: 3px; left: 3px; width: 18px; height: 18px; border-radius: 50%; background: rgba(255,255,255,.45); transition: transform var(--t); box-shadow: 0 1px 4px rgba(0,0,0,.4); }
.toggle-wrap input:checked + .toggle-track { background: var(--accent); }
.toggle-wrap input:checked + .toggle-track .toggle-thumb { transform: translateX(20px); background: #000; }

.text-green { color: var(--green); }
.text-muted { color: var(--text-dim); }
.section-hint { font-size: .83rem; color: var(--text-dim); line-height: 1.55; }

/* ── Payments ── */
.payments-table-wrap {
  background: var(--card); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius); border: 1px solid var(--border); overflow: hidden;
  margin-bottom: 2rem; box-shadow: 0 2px 32px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
}
.payments-table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.payments-table th { padding: .8rem 1.1rem; text-align: left; font-size: .74rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--text-dim); border-bottom: 1px solid var(--border); background: rgba(255,255,255,.02); }
.payments-table td { padding: .85rem 1.1rem; border-bottom: 1px solid var(--border); vertical-align: middle; color: #fff; }
.payments-table tbody tr:last-child td { border-bottom: none; }
.payments-table tbody tr:hover { background: var(--glass-hover); }
.payments-table .price-col { font-weight: 700; color: var(--accent); }
.payments-table .pid-col   { font-family: 'JetBrains Mono', monospace; font-size: .76rem; color: var(--text-dim); }

/* ── Flash ── */
.flash { display: flex; align-items: center; gap: .6rem; padding: .78rem 1.1rem; border-radius: var(--radius-sm); font-size: .88rem; font-weight: 600; margin-bottom: 1.25rem; animation: fadeUp .3s ease; }
.flash-ok  { background: var(--green-bg); color: var(--green); border: 1px solid var(--green-border); }
.flash-err { background: var(--red-bg);   color: var(--red);   border: 1px solid var(--red-border); }

/* ── Sync (legacy) ── */
.btn-sync { display: inline-flex; align-items: center; gap: .45rem; padding: .48rem .95rem; border-radius: var(--radius-sm); background: var(--glass-hover); color: var(--text-dim); border: 1px solid var(--border-md); font-size: .84rem; font-weight: 600; text-decoration: none; transition: all var(--t); }
.btn-sync:hover { background: var(--accent-bg); color: var(--accent); border-color: var(--accent-border); }
.sync-icon { font-size: 1rem; line-height: 1; }
.sync-icon.spinning { display: inline-block; animation: spin .8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Misc ── */
.page-fade { animation: fadeIn .3s ease both; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

/* ── Telegram widget button ── */
.tg-widget-wrap { position: relative; }
.tg-btn-custom {
  display: inline-flex !important; align-items: center !important;
  justify-content: center !important; gap: .55rem !important; width: 100% !important;
  padding: .88rem 1.25rem !important; border-radius: var(--radius-sm) !important;
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  color: #fff !important;
  font-family: 'Manrope', sans-serif !important; font-size: .95rem !important;
  font-weight: 700 !important; cursor: pointer !important;
  transition: all var(--t) !important; text-decoration: none !important;
  backdrop-filter: blur(12px) !important;
}
.tg-btn-custom:hover { background: rgba(255,255,255,.1) !important; border-color: rgba(255,255,255,.2) !important; transform: translateY(-2px) !important; }

/* ── Buy Step 2 ── */
.step2-wrap { max-width: 520px; margin: 0 auto; animation: fadeUp .35s ease both; }
.step2-inner { display: flex; flex-direction: column; gap: 1.4rem; }

.back-btn { display: inline-flex; align-items: center; gap: .35rem; background: none; border: 1px solid var(--border-md); border-radius: var(--radius-sm); color: var(--text-dim); font-family: 'Manrope', sans-serif; font-size: .85rem; padding: .45rem .9rem; cursor: pointer; transition: all var(--t); margin-bottom: .5rem; }
.back-btn:hover { border-color: var(--accent-border); color: var(--accent); }

.step2-header { text-align: center; }
.step2-plan-badge { display: inline-block; padding: .25rem .9rem; border-radius: 20px; background: var(--accent-bg); border: 1px solid var(--accent-border); color: var(--accent); font-size: .78rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; margin-bottom: .7rem; }
.step2-title { font-family: 'Syne', sans-serif; font-size: 1.55rem; font-weight: 800; color: #fff; }

/* Glass card standalone */
.glass-card {
  background: var(--card); backdrop-filter: blur(22px); -webkit-backdrop-filter: blur(22px);
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1.5rem 1.6rem;
  box-shadow: 0 2px 32px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
}

/* Device slider */
.device-section { display: flex; flex-direction: column; gap: .85rem; }
.device-header { display: flex; justify-content: space-between; align-items: center; }
.device-label { font-size: .9rem; font-weight: 700; color: #fff; }
.device-count-badge { background: var(--accent); color: #000; font-size: .8rem; font-weight: 800; padding: .2rem .7rem; border-radius: 12px; min-width: 52px; text-align: center; }
.device-slider {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 5px; border-radius: 3px; outline: none;
  background: linear-gradient(to right, var(--accent) 0%, var(--accent) var(--pct, 0%), rgba(255,255,255,.1) var(--pct, 0%), rgba(255,255,255,.1) 100%);
  cursor: pointer;
}
.device-slider::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 20px; height: 20px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 12px rgba(212,152,16,.45); cursor: pointer; border: 2px solid #000; transition: box-shadow var(--t); }
.device-slider::-moz-range-thumb { width: 20px; height: 20px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 12px rgba(212,152,16,.45); cursor: pointer; border: 2px solid #000; }
.device-slider::-webkit-slider-thumb:hover { box-shadow: 0 0 20px rgba(212,152,16,.6); }
.device-slider-labels { display: flex; justify-content: space-between; font-size: .74rem; color: var(--muted); margin-top: -.35rem; }
.device-note { font-size: .82rem; color: var(--text-dim); }
.device-note strong { color: #fff; }

/* Receipt */
.receipt-card { display: flex; flex-direction: column; gap: .8rem; }
.receipt-title { font-size: .78rem; font-weight: 700; color: var(--text-dim); text-transform: uppercase; letter-spacing: .08em; padding-bottom: .7rem; border-bottom: 1px solid var(--border); }
.receipt-row { display: flex; justify-content: space-between; align-items: flex-start; gap: .5rem; font-size: .9rem; }
.receipt-lbl { color: var(--text-dim); flex-shrink: 0; }
.receipt-val { font-weight: 600; text-align: right; color: #fff; }
.receipt-green { color: var(--green); }
.receipt-divider { height: 1px; background: var(--border); margin: .2rem 0; }
.receipt-total-row { display: flex; justify-content: space-between; align-items: center; font-size: 1rem; font-weight: 700; color: #fff; }
.receipt-total { font-family: 'Syne', sans-serif; font-size: 1.5rem; font-weight: 800; color: var(--accent); }
.receipt-order-row { display: flex; justify-content: space-between; align-items: center; padding-top: .6rem; border-top: 1px solid var(--border); }
.receipt-order-lbl { font-size: .8rem; color: var(--muted); }
.receipt-order-val { font-family: 'JetBrains Mono', monospace; font-size: .85rem; color: var(--text-dim); letter-spacing: .04em; }

/* Pay button */
.btn-pay { padding: 1rem 2rem; border-radius: var(--radius-sm); border: none; cursor: pointer; background: var(--accent); color: #000; font-family: 'Manrope', sans-serif; font-size: 1rem; font-weight: 800; letter-spacing: .04em; transition: all var(--t2); box-shadow: 0 4px 24px rgba(212,152,16,.28); }
.btn-pay:hover { filter: brightness(1.1); box-shadow: 0 8px 36px rgba(212,152,16,.38); transform: translateY(-2px); }

/* ── Profile unified card ── */
.profile-card {
  background: var(--card);
  backdrop-filter: blur(28px) saturate(140%);
  -webkit-backdrop-filter: blur(28px) saturate(140%);
  border: 1px solid var(--border-md);
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 52px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.07);
  max-width: 920px;
  overflow: hidden;
  animation: fadeUp .35s ease both;
}
.profile-cols { display: flex; align-items: stretch; }
.profile-col  { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.profile-sep-v { width: 1px; background: var(--border); flex-shrink: 0; }
.profile-block { padding: 1.65rem 2rem; }
.profile-block-title {
  font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--accent); margin-bottom: 1.1rem;
  font-family: 'Manrope', sans-serif;
}
.profile-sep { height: 1px; background: var(--border); }

/* ── Modal ── */
.modal-overlay {
  display: flex; position: fixed; inset: 0; z-index: 500;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  align-items: center; justify-content: center; padding: 1.5rem;
  opacity: 0; pointer-events: none;
  transition: opacity 0.32s cubic-bezier(.23,1,.32,1);
}
.modal-overlay.open { opacity: 1; pointer-events: auto; }
.modal-box {
  background: rgba(8, 10, 15, 0.50);
  backdrop-filter: blur(48px) saturate(200%); -webkit-backdrop-filter: blur(48px) saturate(200%);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: var(--radius-xl); padding: 2rem;
  width: 100%; max-width: 420px;
  box-shadow: 0 32px 80px rgba(0,0,0,.7),
              inset 0 1px 0 rgba(255,255,255,.15),
              inset 0 -1px 0 rgba(255,255,255,.04);
  opacity: 0; transform: scale(0.95) translateY(14px);
  transition: opacity 0.32s cubic-bezier(.23,1,.32,1), transform 0.32s cubic-bezier(.23,1,.32,1);
  position: relative;
}
.modal-overlay.open .modal-box { opacity: 1; transform: scale(1) translateY(0); }
.modal-box::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(212,152,16,.3), transparent);
}
.modal-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.25rem; }
.modal-title { font-family: 'Syne', sans-serif; font-size: 1.15rem; font-weight: 800; color: #fff; }
.modal-close { background: none; border: none; color: var(--text-dim); cursor: pointer; font-size: .95rem; padding: .3rem .55rem; border-radius: 7px; transition: all var(--t); }
.modal-close:hover { color: #fff; background: var(--glass-hover); }
.modal-text { color: var(--text-dim); font-size: .88rem; margin-bottom: 1rem; line-height: 1.58; }
.modal-channels { display: flex; flex-direction: column; gap: .55rem; margin-bottom: 1rem; }
.modal-channel { display: flex; align-items: center; gap: .6rem; background: rgba(255,255,255,.04); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: .6rem .9rem; font-size: .88rem; color: #fff; }
.modal-note { font-size: .78rem; color: var(--muted); margin-bottom: 1.25rem; line-height: 1.5; }
.modal-box input[type="email"],
.modal-box input[type="text"] {
  background: rgba(255,255,255,.05); border: 1px solid var(--border-md);
  border-radius: var(--radius-sm); padding: .78rem 1rem;
  color: #fff; font-size: .93rem; font-family: 'Manrope', sans-serif;
  width: 100%; outline: none; box-sizing: border-box;
  transition: border-color var(--t), box-shadow var(--t), background var(--t);
}
.modal-box input[type="email"]:focus,
.modal-box input[type="text"]:focus {
  border-color: rgba(212,152,16,.45); box-shadow: 0 0 0 3px rgba(212,152,16,.08);
  background: rgba(212,152,16,.025);
}
.modal-box input::placeholder { color: var(--muted); }

/* ── Reset password page ── */
.reset-pw-form { display: flex; flex-direction: column; gap: .85rem; }
.reset-pw-form input[type="password"],
.reset-pw-form input[type="text"] {
  background: rgba(255,255,255,.05); border: 1px solid var(--border-md);
  border-radius: var(--radius-sm); padding: .78rem 1rem;
  color: #fff; font-size: .93rem; font-family: 'Manrope', sans-serif;
  width: 100%; outline: none;
  transition: border-color var(--t), box-shadow var(--t), background var(--t);
}
.reset-pw-form input:focus {
  border-color: rgba(212,152,16,.45); box-shadow: 0 0 0 3px rgba(212,152,16,.08);
  background: rgba(212,152,16,.025);
}
.reset-pw-form .pw-bar-wrap input[type="password"],
.reset-pw-form .pw-bar-wrap input[type="text"],
.auth-form .pw-bar-wrap input[type="password"],
.auth-form .pw-bar-wrap input[type="text"] {
  background: transparent; border: none; border-radius: 0; box-shadow: none; outline: none;
}
.reset-pw-form .pw-bar-wrap input:focus,
.auth-form .pw-bar-wrap input:focus { background: transparent; border: none; box-shadow: none; }
.reset-pw-form input::placeholder { color: var(--muted); }
.pw-group { display: flex; flex-direction: column; gap: .3rem; }
.pw-strength-wrap { height: 3px; border-radius: 2px; background: var(--border); margin-top: .55rem; overflow: hidden; }
.pw-strength-fill { height: 100%; width: 0; border-radius: 2px; transition: width .3s, background .3s; }
.pw-strength-label { font-size: .75rem; min-height: 1.1rem; }
.pw-hint { font-size: .72rem; color: var(--muted); line-height: 1.45; }

/* ── Responsive ── */
@media (max-width: 768px) {
  .nav-links { display: none; }
  .nav-burger { display: flex; }
  main { padding: 1.5rem 1rem; }
  .navbar { padding: .875rem 1.25rem; }
  .hero { padding: 3.5rem 0 2.5rem; }
  .hero h1 { font-size: 2.1rem; }
  .hero-stats { gap: 2rem; }
  .features-grid { grid-template-columns: 1fr; }
  .steps-grid    { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .profile-cols { flex-direction: column; }
  .profile-sep-v { display: none; }
}
@media (max-width: 640px) {
  .auth-box { padding: 2rem 1.5rem; border-radius: var(--radius-lg); }
  .auth-box h1 { font-size: 1.45rem; }
  .auth-wrap { padding: 1.25rem .75rem; }
  .dash-title { font-size: 1.55rem; }
  .buy-hero h1 { font-size: 1.65rem; }
  .subs-grid    { grid-template-columns: 1fr; }
  .tariffs-grid { grid-template-columns: 1fr; }
  .tariff-card.popular { transform: none; }
  .tariff-card.popular:hover { transform: translateY(-6px); }
  .quick-actions { flex-direction: column; }
  .connect-steps { grid-template-columns: 1fr; }
  .profile-grid  { grid-template-columns: 1fr; }
  .promo-section { margin-inline: 0; }
  .payments-table-wrap { overflow-x: auto; }
  .payments-table th, .payments-table td { white-space: nowrap; }
  .hero-buttons { flex-direction: column; align-items: center; }
  .btn-lg { width: 100%; }
}
@media (min-width: 769px) {
  .nav-mobile { display: none !important; }
}
