/* ============================================================
   LikesDrom — Main Stylesheet
   Design: Glassmorphism + Minimal Luxury
   ============================================================ */

/* ── Tokens ────────────────────────────────────────────────── */
:root {
  --c-bg:        #F4F6FB;
  --c-bg2:       #EBEEF7;
  --c-surface:   rgba(255,255,255,0.72);
  --c-surface-s: rgba(255,255,255,0.92);
  --c-border:    rgba(99,102,241,0.12);
  --c-border2:   rgba(99,102,241,0.22);

  --c-primary:   #6C63FF;
  --c-primary-d: #5147E8;
  --c-accent:    #3EC6E0;
  --c-accent2:   #FF6B8A;
  --c-success:   #22C55E;
  --c-warning:   #F59E0B;
  --c-error:     #EF4444;

  --c-text:      #1A1C2E;
  --c-text2:     #5A5F82;
  --c-text3:     #9499BE;

  --radius-sm:   8px;
  --radius:      14px;
  --radius-lg:   22px;
  --radius-xl:   32px;

  --shadow-xs:   0 1px 3px rgba(50,50,120,0.08);
  --shadow-sm:   0 4px 16px rgba(50,50,120,0.10);
  --shadow:      0 8px 32px rgba(50,50,120,0.13);
  --shadow-lg:   0 16px 48px rgba(50,50,120,0.18);
  --shadow-glow: 0 0 40px rgba(108,99,255,0.18);

  --blur:        backdrop-filter: blur(18px) saturate(1.5);
  --transition:  0.25s cubic-bezier(.4,0,.2,1);
  --font-head:   'Space Grotesk', sans-serif;
  --font-body:   'Manrope', sans-serif;
}

/* ── Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  background: var(--c-bg);
  color: var(--c-text);
  line-height: 1.65;
  font-size: 15px;
  min-height: 100vh;
  background-image:
    radial-gradient(ellipse 80% 60% at 15% -10%, rgba(108,99,255,.10) 0%, transparent 55%),
    radial-gradient(ellipse 60% 50% at 90% 110%, rgba(62,198,224,.08) 0%, transparent 50%);
  background-attachment: fixed;
}
img { max-width:100%; display:block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { cursor: pointer; font-family: inherit; }
input, select, textarea { font-family: inherit; }

/* ── Utility ───────────────────────────────────────────────── */
.container { max-width: 1240px; margin: 0 auto; padding: 0 24px; }
.section    { padding: 80px 0; }
.text-center { text-align: center; }
.text-gradient {
  background: linear-gradient(135deg, var(--c-primary), var(--c-accent));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.sr-only { position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0); }

/* ── Glass card ────────────────────────────────────────────── */
.glass {
  background: var(--c-surface);
  backdrop-filter: blur(18px) saturate(1.5);
  -webkit-backdrop-filter: blur(18px) saturate(1.5);
  border: 1px solid var(--c-border2);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
}
.glass-solid {
  background: var(--c-surface-s);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--c-border2);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

/* ── Buttons ───────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 28px; border-radius: 50px; border: none;
  font-weight: 600; font-size: 14px; letter-spacing: .02em;
  transition: all var(--transition);
  white-space: nowrap;
}
.btn-primary {
  background: linear-gradient(135deg, var(--c-primary), var(--c-primary-d));
  color: #fff;
  box-shadow: 0 4px 20px rgba(108,99,255,.35);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(108,99,255,.45);
}
.btn-outline {
  background: var(--c-surface);
  color: var(--c-primary);
  border: 1.5px solid var(--c-primary);
  backdrop-filter: blur(8px);
}
.btn-outline:hover { background: var(--c-primary); color:#fff; }
.btn-ghost {
  background: transparent; color: var(--c-text2);
}
.btn-ghost:hover { background: var(--c-bg2); color: var(--c-primary); }
.btn-sm { padding: 8px 18px; font-size: 13px; }
.btn-lg { padding: 16px 40px; font-size: 16px; }
.btn-full { width: 100%; justify-content: center; }
.btn-danger { background: var(--c-error); color: #fff; }
.btn svg { width:16px;height:16px; }

/* ── Form elements ─────────────────────────────────────────── */
.form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 20px; }
.form-label { font-size: 13px; font-weight: 600; color: var(--c-text2); letter-spacing:.03em; text-transform:uppercase; }
.form-control {
  width: 100%;
  padding: 12px 16px;
  background: rgba(255,255,255,.8);
  border: 1.5px solid var(--c-border2);
  border-radius: var(--radius);
  font-size: 15px; color: var(--c-text);
  transition: all var(--transition);
  outline: none;
}
.form-control:focus {
  border-color: var(--c-primary);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(108,99,255,.12);
}
.form-control::placeholder { color: var(--c-text3); }
select.form-control { appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239499BE' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; padding-right: 42px; }
.form-hint { font-size: 12px; color: var(--c-text3); }
.form-error { font-size: 12px; color: var(--c-error); }

/* ── Alerts ────────────────────────────────────────────────── */
.alert {
  padding: 14px 18px; border-radius: var(--radius); margin-bottom: 20px;
  font-size: 14px; display: flex; align-items: flex-start; gap: 10px;
  border: 1px solid transparent;
}
.alert-success { background: rgba(34,197,94,.1); border-color: rgba(34,197,94,.3); color: #166534; }
.alert-error   { background: rgba(239,68,68,.1);  border-color: rgba(239,68,68,.3);  color: #991b1b; }
.alert-info    { background: rgba(108,99,255,.08); border-color: rgba(108,99,255,.25); color: #3730a3; }
.alert-warning { background: rgba(245,158,11,.1); border-color: rgba(245,158,11,.3); color: #92400e; }

/* ── Badges / Tags ─────────────────────────────────────────── */
.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: 50px; font-size: 11px; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase;
}
.badge-purple  { background: rgba(108,99,255,.12); color: var(--c-primary); }
.badge-blue    { background: rgba(62,198,224,.15); color: #0369a1; }
.badge-green   { background: rgba(34,197,94,.12);  color: #166534; }
.badge-red     { background: rgba(239,68,68,.12);  color: #991b1b; }
.badge-yellow  { background: rgba(245,158,11,.12); color: #92400e; }
.badge-gray    { background: rgba(148,153,190,.15); color: var(--c-text2); }

/* Status badges */
.status-pending    { @extend .badge; background:rgba(245,158,11,.12); color:#92400e; }
.status-processing { background:rgba(62,198,224,.15); color:#0369a1; }
.status-completed  { background:rgba(34,197,94,.12);  color:#166534; }
.status-cancelled  { background:rgba(239,68,68,.12);  color:#991b1b; }
.status-partial    { background:rgba(108,99,255,.12); color:#3730a3; }

/* ── Header ────────────────────────────────────────────────── */
.site-header {
  position: sticky; top: 0; z-index: 900;
  background: rgba(244,246,251,.95);
  backdrop-filter: blur(16px) saturate(1.4);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
  border-bottom: 1px solid var(--c-border2);
  transition: box-shadow var(--transition);
}
.site-header.scrolled { box-shadow: 0 2px 20px rgba(50,50,120,.08); }
.header-inner {
  display: flex; align-items: center; gap: 16px; height: 64px;
}

/* Logo */
.logo { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.logo-icon { display:flex; align-items:center; }
.logo-text { font-family:var(--font-head); font-size:19px; font-weight:800; color:var(--c-text); }
.logo-text span { color:var(--c-primary); }

/* Online badge */
.online-badge {
  display: flex; align-items: center; gap: 5px;
  font-size: 12px; font-weight: 600; color: var(--c-text3);
  background: rgba(34,197,94,.08); border: 1px solid rgba(34,197,94,.18);
  border-radius: 100px; padding: 4px 10px; white-space: nowrap; flex-shrink: 0;
}
.online-dot {
  width: 6px; height: 6px; border-radius: 50%; background: #22C55E; flex-shrink: 0;
  animation: online-pulse 2s infinite;
}

/* Main nav (desktop) */
.main-nav {
  display: flex; align-items: center; gap: 2px; flex-shrink: 0;
}
.nav-link {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 13px; border-radius: 9px;
  font-size: 14px; font-weight: 500; color: var(--c-text2);
  transition: all var(--transition); white-space: nowrap;
}
.nav-link svg { width:15px; height:15px; flex-shrink:0; }
.nav-link:hover  { color: var(--c-primary); background: rgba(108,99,255,.08); }
.nav-link.active { color: var(--c-primary); background: rgba(108,99,255,.1); font-weight:600; }
.nav-link--cta {
  background: var(--c-primary); color: #fff !important;
  padding: 7px 16px; font-weight: 600;
  box-shadow: 0 3px 12px rgba(108,99,255,.28);
}
.nav-link--cta:hover {
  background: var(--c-primary-d) !important;
  box-shadow: 0 5px 18px rgba(108,99,255,.38);
  transform: translateY(-1px);
}
.nav-link--danger { color: var(--c-error) !important; }
.nav-link--danger:hover { background: rgba(239,68,68,.08) !important; }

/* Nav elements only in mobile drawer */
.nav-divider { height: 1px; background: var(--c-border); margin: 8px 0; }
.nav-balance-row {
  display: flex; align-items: center; gap: 8px;
  padding: 11px 13px; font-size: 14px; color: var(--c-text2);
  background: rgba(108,99,255,.06); border-radius: 9px; margin: 2px 0;
}
.nav-balance-row svg { width:15px; height:15px; color:var(--c-primary); flex-shrink:0; }
.nav-balance-row strong { margin-left:auto; font-weight:700; color:var(--c-primary); }

/* Header right */
.header-right {
  display: flex; align-items: center; gap: 6px;
  flex-shrink: 0; margin-left: auto;
}
.header-balance {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 13px; border-radius: 9px;
  font-size: 13px; font-weight: 600; color: var(--c-text);
  border: 1px solid var(--c-border2);
  transition: all var(--transition);
}
.header-balance:hover { border-color: var(--c-primary); color: var(--c-primary); background: rgba(108,99,255,.05); }
.header-balance svg { width:14px; height:14px; color:var(--c-text3); }
.header-icon-btn {
  position: relative; width: 36px; height: 36px; border-radius: 9px;
  background: transparent; border: 1px solid var(--c-border2);
  display: flex; align-items: center; justify-content: center;
  color: var(--c-text2); transition: all var(--transition); cursor: pointer;
}
.header-icon-btn:hover { border-color: var(--c-primary); color: var(--c-primary); background: rgba(108,99,255,.05); }
.header-icon-btn svg { width:15px; height:15px; }
.notif-badge {
  position: absolute; top: -4px; right: -4px;
  background: var(--c-primary); color: #fff; border-radius: 50%;
  width: 16px; height: 16px; font-size: 9px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--c-bg);
}
.header-avatar {
  position: relative; width: 36px; height: 36px; border-radius: 9px;
  background: var(--c-primary);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 700; font-size: 14px;
  overflow: hidden; transition: all var(--transition);
  border: 1px solid var(--c-border2);
}
.header-avatar:hover { box-shadow: 0 0 0 3px rgba(108,99,255,.2); border-color: var(--c-primary); }
.header-avatar img { width:100%; height:100%; object-fit:cover; }
.vip-badge {
  position: absolute; bottom:-2px; right:-5px;
  font-size: 7px; font-weight: 800; padding: 1px 4px; border-radius: 4px;
  border: 1.5px solid #fff; text-transform: uppercase; letter-spacing:.04em;
}
.vip-1 { background:#CD7F32; color:#fff; }
.vip-2 { background:#A8A9AD; color:#fff; }
.vip-3 { background:#F59E0B; color:#fff; }
.vip-4 { background:#6C63FF; color:#fff; }
.vip-5 { background:linear-gradient(135deg,var(--c-primary),var(--c-accent)); color:#fff; }

/* Кнопки для неавторизованных */
.btn-ghost {
  background: transparent; border: 1px solid var(--c-border2); color: var(--c-text2);
}
.btn-ghost:hover { border-color: var(--c-primary); color: var(--c-primary); background: rgba(108,99,255,.05); }

/* Burger */
.burger {
  display: none; flex-direction: column; justify-content: center; gap: 5px;
  width: 36px; height: 36px; padding: 8px; cursor: pointer;
  border-radius: 9px; border: 1px solid var(--c-border2);
  background: transparent; transition: all var(--transition);
}
.burger:hover { border-color: var(--c-primary); background: rgba(108,99,255,.05); }
.burger span { display:block; width:100%; height:2px; background:var(--c-text2); border-radius:2px; transition:all .28s; }
.burger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.burger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile-only — скрыто на десктопе */
.mobile-only { display: none !important; }

/* Mobile overlay */
.mobile-overlay {
  position: fixed; inset: 0; z-index: 850;
  background: rgba(20,22,40,.55);
  opacity: 0; pointer-events: none;
  transition: opacity .3s ease;
}
.mobile-overlay.show { opacity: 1; pointer-events: auto; }

/* ── Hero section ──────────────────────────────────────────── */
.hero {
  padding: 100px 0 80px;
  position: relative; overflow: hidden;
}
.hero::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(ellipse 70% 80% at 60% 50%, rgba(108,99,255,.06) 0%, transparent 70%);
}
.hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.hero-tag {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px; border-radius: 50px;
  background: rgba(108,99,255,.09); border: 1px solid rgba(108,99,255,.2);
  font-size: 12px; font-weight: 700; color: var(--c-primary);
  letter-spacing: .06em; text-transform: uppercase; margin-bottom: 20px;
}
.hero-tag::before { content:''; width:6px;height:6px;border-radius:50%;background:var(--c-primary);animation:pulse-dot 1.5s infinite; }
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.4)} }
.hero h1 {
  font-family: var(--font-head);
  font-size: clamp(36px, 5vw, 60px);
  font-weight: 800; line-height: 1.1;
  letter-spacing: -.02em; margin-bottom: 20px;
}
.hero-desc { font-size: 17px; color: var(--c-text2); line-height: 1.7; margin-bottom: 36px; max-width: 480px; }
.hero-btns { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 48px; }
.hero-stats { display: flex; gap: 32px; flex-wrap: wrap; }
.hero-stat-item { }
.hero-stat-num {
  font-family: var(--font-head); font-size: 26px; font-weight: 800;
  color: var(--c-primary); letter-spacing: -.02em;
}
.hero-stat-label { font-size: 12px; color: var(--c-text3); font-weight: 500; }

/* Hero visual */
.hero-visual { position: relative; display: flex; justify-content: center; align-items: center; }
.hero-card-main {
  width: 300px; background: var(--c-surface);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--c-border2); border-radius: var(--radius-xl);
  padding: 28px; box-shadow: var(--shadow-lg); position: relative; z-index: 2;
}
.hero-card-float {
  position: absolute; padding: 12px 18px;
  background: rgba(255,255,255,.9); backdrop-filter: blur(12px);
  border: 1px solid var(--c-border2); border-radius: var(--radius);
  box-shadow: var(--shadow); font-size: 13px; font-weight: 600;
  display: flex; align-items: center; gap: 8px; white-space: nowrap;
  animation: float 3s ease-in-out infinite;
}
.hero-card-float--1 { top: 20px; right: -20px; animation-delay: 0s; }
.hero-card-float--2 { bottom: 40px; left: -30px; animation-delay: 1s; }
.hero-card-float--3 { top: 50%; right: -40px; animation-delay:.5s; }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

/* ── Stats bar ─────────────────────────────────────────────── */
.stats-bar {
  padding: 32px 0;
  background: var(--c-surface);
  backdrop-filter: blur(16px);
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
}
.stats-bar-inner { display: flex; gap: 0; justify-content: space-around; flex-wrap: wrap; }
.stats-bar-item {
  text-align: center; padding: 12px 24px;
  border-right: 1px solid var(--c-border);
  flex: 1;
}
.stats-bar-item:last-child { border-right: none; }
.stats-bar-num {
  font-family: var(--font-head); font-size: 32px; font-weight: 800;
  color: var(--c-primary); letter-spacing: -.02em;
}
.stats-bar-label { font-size: 13px; color: var(--c-text2); font-weight: 500; }

/* ── Network cards ─────────────────────────────────────────── */
.networks-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
.network-card {
  padding: 28px 24px; border-radius: var(--radius-lg);
  background: var(--c-surface); backdrop-filter: blur(16px);
  border: 1px solid var(--c-border2);
  box-shadow: var(--shadow-xs);
  transition: all var(--transition);
  cursor: pointer; display: flex; flex-direction: column; gap: 14px;
}
.network-card:hover {
  transform: translateY(-4px); box-shadow: var(--shadow);
  border-color: var(--network-color, var(--c-primary));
}
.network-icon {
  width: 52px; height: 52px; border-radius: var(--radius);
  background: var(--network-bg, rgba(108,99,255,.1));
  display: flex; align-items: center; justify-content: center;
  color: var(--network-color, var(--c-primary));
}
.network-icon svg { width: 24px; height: 24px; }
.network-name { font-weight: 700; font-size: 16px; }
.network-services { font-size: 13px; color: var(--c-text2); }
.network-price { font-size: 12px; font-weight: 600; color: var(--c-text3); }
.network-price span { color: var(--c-primary); font-size: 15px; }

/* ── Feature cards ─────────────────────────────────────────── */
.features-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.feature-card {
  padding: 32px 28px; border-radius: var(--radius-lg);
  background: var(--c-surface); backdrop-filter: blur(16px);
  border: 1px solid var(--c-border);
  transition: all var(--transition);
}
.feature-card:hover { box-shadow: var(--shadow); border-color: var(--c-border2); transform: translateY(-3px); }
.feature-icon {
  width: 48px; height: 48px; border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(108,99,255,.12), rgba(62,198,224,.12));
  display: flex; align-items: center; justify-content: center;
  color: var(--c-primary); margin-bottom: 18px;
}
.feature-icon svg { width:22px;height:22px; }
.feature-title { font-family:var(--font-head); font-size:18px; font-weight:700; margin-bottom:10px; }
.feature-desc { font-size: 14px; color: var(--c-text2); line-height:1.7; }

/* ── Section titles ────────────────────────────────────────── */
.section-title {
  font-family: var(--font-head);
  font-size: clamp(26px, 4vw, 42px);
  font-weight: 800; letter-spacing: -.02em;
  line-height: 1.15; margin-bottom: 14px;
}
.section-sub {
  font-size: 16px; color: var(--c-text2); max-width: 560px; margin: 0 auto 50px;
  line-height: 1.7;
}

/* ── How it works ──────────────────────────────────────────── */
.steps-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:24px; }
.step-card {
  padding:28px 24px; border-radius:var(--radius-lg);
  background:var(--c-surface); border:1px solid var(--c-border);
  position:relative; text-align:center;
}
.step-num {
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--c-primary),var(--c-accent));
  color:#fff; font-weight:800; font-size:16px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;
}
.step-title { font-weight:700;font-size:15px;margin-bottom:8px; }
.step-desc  { font-size:13px;color:var(--c-text2);line-height:1.6; }
.step-arrow {
  position:absolute;top:50%;right:-16px;transform:translateY(-50%);
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  color:var(--c-text3); z-index:1;
}
.step-card:last-child .step-arrow { display:none; }

/* ── Reviews ───────────────────────────────────────────────── */
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.review-card {
  padding:28px; border-radius:var(--radius-lg);
  background:var(--c-surface); backdrop-filter:blur(16px);
  border:1px solid var(--c-border);
}
.review-stars { color:#F59E0B; font-size:16px; letter-spacing:2px; margin-bottom:14px; }
.review-text { font-size:14px;color:var(--c-text2);line-height:1.7;margin-bottom:18px; font-style:italic; }
.review-author { display:flex;align-items:center;gap:10px; }
.review-avatar {
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--c-primary),var(--c-accent));
  color:#fff;font-weight:700;font-size:14px;
  display:flex;align-items:center;justify-content:center;
}
.review-name { font-weight:700;font-size:14px; }
.review-meta { font-size:12px;color:var(--c-text3); }

/* ── FAQ ───────────────────────────────────────────────────── */
.faq-list { display:flex;flex-direction:column;gap:8px; max-width:760px;margin:0 auto; }
.faq-item {
  border-radius:var(--radius); background:var(--c-surface);
  border:1px solid var(--c-border); overflow:hidden;
}
.faq-question {
  width:100%;padding:18px 22px;text-align:left;
  background:none;border:none; font-size:15px;font-weight:600;
  color:var(--c-text); display:flex;justify-content:space-between;align-items:center;gap:12px;
  cursor:pointer; transition:all var(--transition);
}
.faq-question:hover { color:var(--c-primary); }
.faq-icon { flex-shrink:0; width:20px;height:20px; color:var(--c-text3); transition:transform .3s; }
.faq-item.open .faq-icon { transform:rotate(180deg); color:var(--c-primary); }
.faq-answer { max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1); }
.faq-answer-inner { padding:0 22px 18px; font-size:14px;color:var(--c-text2);line-height:1.7; }

/* ── CTA section ───────────────────────────────────────────── */
.cta-section {
  background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-d) 50%, #3730A3 100%);
  border-radius: var(--radius-xl); padding: 72px 60px; text-align:center;
  position:relative; overflow:hidden; margin:80px 0;
  box-shadow: 0 24px 64px rgba(108,99,255,.35);
}
.cta-section::before {
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse at 30% 20%, rgba(255,255,255,.12) 0%, transparent 50%),
              radial-gradient(ellipse at 70% 80%, rgba(255,255,255,.07) 0%, transparent 50%);
}
.cta-section * { position:relative;z-index:1; }
.cta-section h2 { color:#fff; font-family:var(--font-head);font-size:clamp(24px,4vw,42px);font-weight:800;margin-bottom:14px; }
.cta-section p { color:rgba(255,255,255,.8);font-size:17px;margin-bottom:36px; }
.cta-section .btn-outline { border-color:rgba(255,255,255,.6);color:#fff;background:rgba(255,255,255,.12); }
.cta-section .btn-outline:hover { background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.9); }

/* ── Page hero (inner pages) ───────────────────────────────── */
.page-hero {
  padding: 56px 0 40px;
  border-bottom: 1px solid var(--c-border);
  margin-bottom: 48px;
}
.page-hero h1 { font-family:var(--font-head);font-size:clamp(28px,4vw,44px);font-weight:800;margin-bottom:8px; }
.page-hero p { color:var(--c-text2);font-size:16px; }
.breadcrumb { display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:13px;color:var(--c-text3); }
.breadcrumb a { color:var(--c-primary); }
.breadcrumb svg { width:12px;height:12px; }

/* ── Auth pages ────────────────────────────────────────────── */
.auth-wrap {
  min-height: calc(100vh - 68px);
  display:flex;align-items:center;justify-content:center;
  padding:40px 24px;
}
.auth-card {
  width: 100%; max-width: 440px;
  padding: 44px 40px;
}
.auth-logo { text-align:center;margin-bottom:32px; }
.auth-logo .logo { justify-content:center; }
.auth-title { font-family:var(--font-head);font-size:26px;font-weight:800;margin-bottom:6px; }
.auth-sub { font-size:14px;color:var(--c-text2);margin-bottom:28px; }
.auth-divider { display:flex;align-items:center;gap:12px;margin:20px 0; }
.auth-divider::before,.auth-divider::after { content:'';flex:1;height:1px;background:var(--c-border2); }
.auth-divider span { font-size:12px;color:var(--c-text3); }
.auth-footer { text-align:center;margin-top:20px;font-size:14px;color:var(--c-text2); }
.auth-footer a { color:var(--c-primary);font-weight:600; }

/* Password toggle */
.input-wrap { position:relative; }
.input-toggle-btn {
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  background:none;border:none;padding:4px;color:var(--c-text3);
  cursor:pointer;transition:color var(--transition);
}
.input-toggle-btn:hover { color:var(--c-primary); }
.input-toggle-btn svg { width:16px;height:16px; }

/* ── Profile page ──────────────────────────────────────────── */
.profile-layout { display:grid;grid-template-columns:280px 1fr;gap:28px;align-items:start; }
.profile-sidebar { position:sticky;top:88px; }
.profile-card {
  padding:28px 24px; margin-bottom:16px;
}
.profile-avatar-wrap { text-align:center;margin-bottom:20px; }
.profile-avatar-big {
  width:88px;height:88px;border-radius:50%;
  background:linear-gradient(135deg,var(--c-primary),var(--c-accent));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:32px;font-weight:800;margin:0 auto 12px;
  position:relative;border:3px solid var(--c-surface);
  box-shadow:0 0 0 3px var(--c-primary);
}
.profile-username { font-weight:700;font-size:18px;margin-bottom:4px; }
.profile-email { font-size:13px;color:var(--c-text3); }
.profile-balance-box {
  background:linear-gradient(135deg,var(--c-primary),var(--c-accent));
  border-radius:var(--radius);padding:16px;text-align:center;margin:16px 0;
  color:#fff;
}
.profile-balance-box .amount { font-size:28px;font-weight:800; }
.profile-balance-box .label  { font-size:12px;opacity:.8; }
.profile-nav { display:flex;flex-direction:column;gap:4px;margin-top:8px; }
.profile-nav-link {
  display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);
  font-size:14px;font-weight:500;color:var(--c-text2);transition:all var(--transition);
}
.profile-nav-link svg { width:15px;height:15px; }
.profile-nav-link:hover,.profile-nav-link.active { background:rgba(108,99,255,.1);color:var(--c-primary); }
.profile-main-title { font-family:var(--font-head);font-size:22px;font-weight:800;margin-bottom:20px; }

/* Stats grid */
.profile-stats { display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:24px; }
.profile-stat-card {
  padding:18px 20px;border-radius:var(--radius);
  background:var(--c-surface);border:1px solid var(--c-border);
}
.profile-stat-card .val { font-size:24px;font-weight:800;color:var(--c-primary);font-family:var(--font-head); }
.profile-stat-card .lbl { font-size:12px;color:var(--c-text3);font-weight:500;margin-top:2px; }

/* Tabs */
.tabs { display:flex;gap:4px;background:var(--c-bg2);padding:4px;border-radius:var(--radius);margin-bottom:24px; }
.tab-btn {
  flex:1;padding:9px 14px;border-radius:var(--radius-sm);
  font-size:13px;font-weight:600;border:none;background:none;
  color:var(--c-text2);cursor:pointer;transition:all var(--transition);
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.tab-btn.active { background:#fff;color:var(--c-primary);box-shadow:var(--shadow-xs); }
.tab-content { display:none; }
.tab-content.active { display:block; }

/* Table */
.data-table { width:100%;border-collapse:collapse; }
.data-table th {
  padding:10px 14px;font-size:11px;font-weight:700;letter-spacing:.05em;
  text-transform:uppercase;color:var(--c-text3);border-bottom:1.5px solid var(--c-border2);
  text-align:left;
}
.data-table td { padding:14px;font-size:14px;border-bottom:1px solid var(--c-border); }
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover td { background:rgba(108,99,255,.03); }
.table-wrap { overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--c-border2); }

/* ── New order form ────────────────────────────────────────── */
.new-order-layout { display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start; }
.order-form-card { padding:36px 32px; }
.network-selector { display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px; }
.network-btn {
  padding:14px 10px; border-radius:var(--radius);
  background:var(--c-surface);border:1.5px solid var(--c-border2);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  font-size:12px;font-weight:600;color:var(--c-text2);
  cursor:pointer;transition:all var(--transition);
}
.network-btn:hover,.network-btn.active {
  border-color:var(--c-primary);color:var(--c-primary);
  background:rgba(108,99,255,.07);
}
.network-btn svg { width:22px;height:22px; }
.order-summary-card { padding:28px;position:sticky;top:88px; }
.order-summary-row { display:flex;justify-content:space-between;align-items:center;
  padding:10px 0;border-bottom:1px solid var(--c-border);font-size:14px; }
.order-summary-row:last-child { border-bottom:none; }
.order-summary-total { font-size:22px;font-weight:800;color:var(--c-primary);font-family:var(--font-head); }
.qty-slider { width:100%; margin:8px 0; accent-color:var(--c-primary); }

/* ── Support page ──────────────────────────────────────────── */
.support-grid { display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;margin-bottom:48px; }
.support-channel {
  padding:28px;text-align:center;border-radius:var(--radius-lg);
  background:var(--c-surface);border:1px solid var(--c-border);
  transition:all var(--transition);
}
.support-channel:hover { transform:translateY(-3px);box-shadow:var(--shadow); }
.support-channel-icon {
  width:56px;height:56px;border-radius:50%;margin:0 auto 16px;
  background:linear-gradient(135deg,rgba(108,99,255,.1),rgba(62,198,224,.1));
  display:flex;align-items:center;justify-content:center;color:var(--c-primary);
}
.support-channel-icon svg { width:24px;height:24px; }

/* ── Orders stub ───────────────────────────────────────────── */
.empty-state {
  text-align:center;padding:80px 24px;
}
.empty-state-icon {
  width:80px;height:80px;border-radius:50%;margin:0 auto 24px;
  background:rgba(108,99,255,.08);
  display:flex;align-items:center;justify-content:center;color:var(--c-text3);
}
.empty-state-icon svg { width:36px;height:36px; }
.empty-state h3 { font-size:20px;font-weight:700;margin-bottom:8px; }
.empty-state p { color:var(--c-text2);margin-bottom:24px;max-width:340px;margin-left:auto;margin-right:auto; }

/* ── Footer ────────────────────────────────────────────────── */
.site-footer {
  background: var(--c-surface);
  backdrop-filter: blur(12px);
  border-top: 1px solid var(--c-border2);
  padding: 64px 0 0;
  margin-top: 80px;
}
.footer-grid { display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:48px; }
.footer-brand p { font-size:14px;color:var(--c-text2);margin-top:14px;line-height:1.7;max-width:280px; }
.footer-socials { display:flex;gap:10px;margin-top:18px; }
.footer-social-link {
  width:36px;height:36px;border-radius:50%;background:var(--c-bg2);
  display:flex;align-items:center;justify-content:center;color:var(--c-text2);
  transition:all var(--transition);border:1px solid var(--c-border);
}
.footer-social-link:hover { background:var(--c-primary);color:#fff;border-color:var(--c-primary); }
.footer-social-link svg { width:16px;height:16px; }
.footer-col h4 { font-weight:700;font-size:14px;margin-bottom:16px;color:var(--c-text); }
.footer-col ul { display:flex;flex-direction:column;gap:10px; }
.footer-col ul li a { font-size:14px;color:var(--c-text2);transition:color var(--transition); }
.footer-col ul li a:hover { color:var(--c-primary); }
.footer-payments { display:flex;gap:6px;flex-wrap:wrap;margin-top:18px; }
.payment-badge {
  padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;
  background:var(--c-bg2);border:1px solid var(--c-border2);color:var(--c-text2);
}
.footer-bottom {
  border-top:1px solid var(--c-border);padding:20px 0;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;
}
.footer-bottom p { font-size:13px;color:var(--c-text3); }
.footer-version { font-size:11px;color:var(--c-text3);opacity:.6; }

/* ── Spinner ───────────────────────────────────────────────── */
.spinner {
  width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);
  border-top-color:#fff;border-radius:50%;
  animation:spin .7s linear infinite;
}
@keyframes spin { to{transform:rotate(360deg)} }

/* ── Animations ────────────────────────────────────────────── */
.fade-up {
  opacity:0;transform:translateY(28px);
  transition:opacity .6s cubic-bezier(.4,0,.2,1),transform .6s cubic-bezier(.4,0,.2,1);
}
.fade-up.visible { opacity:1;transform:translateY(0); }

/* ── Toast ─────────────────────────────────────────────────── */
.toast-wrap { position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px; }
.toast {
  padding:14px 18px;border-radius:var(--radius);background:#fff;
  border:1px solid var(--c-border2);box-shadow:var(--shadow);
  font-size:14px;font-weight:500;display:flex;align-items:center;gap:10px;
  animation:slideIn .3s cubic-bezier(.4,0,.2,1);
  min-width:260px;max-width:360px;
}
@keyframes slideIn { from{transform:translateX(120%);opacity:0} to{transform:translateX(0);opacity:1} }
.toast-success { border-left:3px solid var(--c-success); }
.toast-error   { border-left:3px solid var(--c-error); }
.toast-info    { border-left:3px solid var(--c-primary); }

/* ============================================================
   MOBILE
   ============================================================ */
/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — Mobile-first overrides
   ══════════════════════════════════════════════════════════════ */

/* ── 1024px tablet ─────────────────────────────────────────── */
@media (max-width: 1024px) {
  .hero-inner            { grid-template-columns: 1fr; gap: 40px; }
  .hero-visual           { display: none; }
  .networks-grid         { grid-template-columns: repeat(2, 1fr); }
  .features-grid         { grid-template-columns: repeat(2, 1fr); }
  .reviews-grid          { grid-template-columns: 1fr 1fr; }
  .steps-grid            { grid-template-columns: repeat(2, 1fr); }
  .footer-grid           { grid-template-columns: 1fr 1fr; gap: 32px; }
  .profile-layout        { grid-template-columns: 1fr; }
  .profile-sidebar       { position: static; }
  .new-order-layout      { grid-template-columns: 1fr; }
  .order-summary-card    { position: static; }
  .support-grid          { grid-template-columns: 1fr; }
}

/* ── 768px mobile ───────────────────────────────────────────── */
@media (max-width: 768px) {

  /* Шапка */
  .header-inner { gap: 8px; padding: 0 4px; }
  .online-badge { display: none !important; }
  .logo { margin-right: auto; }

  /* На мобильном скрываем баланс и уведомления из header-right */
  .header-balance { display: none !important; }
  .header-icon-btn { display: none !important; }

  /* Бургер */
  .burger { display: flex !important; }

  /* Overlay */
  .mobile-overlay { display: block; }

  /* Drawer — выезжает справа, полная высота */
  .main-nav {
    display: flex !important;
    position: fixed;
    top: 0; right: 0; bottom: 0;
    width: min(300px, 85vw);
    height: 100%;
    height: 100dvh; /* учитывает адресную строку мобильного браузера */
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    background: #ffffff;
    border-left: 1px solid rgba(99,102,241,.15);
    padding: 0;
    z-index: 870;
    margin-left: 0;
    transform: translateX(110%);
    transition: transform .3s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
    box-shadow: -8px 0 32px rgba(20,22,40,.18);
  }
  .main-nav.open { transform: translateX(0) !important; }

  /* Drawer header — лого + закрытие */
  .main-nav::before {
    content: 'LikesDrom';
    display: block;
    padding: 20px 20px 16px;
    font-family: var(--font-head);
    font-size: 17px; font-weight: 800;
    color: var(--c-text);
    border-bottom: 1px solid var(--c-border);
    flex-shrink: 0;
  }

  /* Ссылки в drawer */
  .main-nav .nav-link {
    border-radius: 8px;
    padding: 13px 16px;
    font-size: 15px;
    margin: 0 8px;
  }
  .main-nav .nav-link--cta {
    margin: 8px 8px 4px;
    justify-content: center;
    border-radius: 10px;
  }
  .main-nav .nav-divider { margin: 8px 8px; }
  .main-nav .nav-balance-row { margin: 2px 8px; }
  .main-nav .nav-link--danger { margin: 0 8px; }

  /* Mobile-only элементы — показываем */
  .mobile-only { display: flex !important; }
  .nav-divider.mobile-only { display: block !important; }

  /* Layout */
  .networks-grid { grid-template-columns: 1fr 1fr; }
  .features-grid { grid-template-columns: 1fr; }
  .reviews-grid  { grid-template-columns: 1fr; }
  .steps-grid    { grid-template-columns: 1fr 1fr; }
  .footer-grid   { grid-template-columns: 1fr; gap: 24px; }
  .cta-section   { padding: 48px 28px; }

  /* Order form */
  .network-selector { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .network-btn      { padding: 12px 6px; font-size: 11px; }
  .order-form-card  { padding: 24px 20px; }
  .order-summary-card { padding: 20px; }

  /* Profile */
  .profile-stats  { grid-template-columns: 1fr 1fr; }
  .profile-sidebar { padding: 20px; }
  .tabs           { flex-wrap: wrap; }
  .tab-btn        { font-size: 12px; padding: 8px 10px; }

  /* Hero */
  .hero           { padding: 60px 0 50px; }
  .section        { padding: 56px 0; }
  .hero-title     { font-size: clamp(28px,7vw,44px); }
  .hero-btns      { flex-wrap: wrap; }

  /* Table */
  .data-table th,
  .data-table td  { padding: 10px 10px; font-size: 13px; }

  /* Stats bar */
  .stats-bar-inner { gap: 0; flex-wrap: wrap; }
  .stats-bar-item  { flex: 1 1 33%; min-width: 100px; }

  /* Support */
  .support-grid   { grid-template-columns: 1fr 1fr; }

  /* Footer */
  .footer-socials { justify-content: flex-start; }
  .footer-payments { flex-wrap: wrap; }
}

/* ── 480px small phones ─────────────────────────────────────── */
@media (max-width: 480px) {
  /* Core layout */
  .container             { padding: 0 16px; }
  .section               { padding: 44px 0; }

  /* Header */
  .site-header           { padding: 0 16px; }
  .logo-text             { font-size: 17px; }
  .header-notify         { display: none; }  /* hide bell on tiny screens */

  /* Typography */
  .hero-title            { font-size: clamp(24px, 8vw, 36px); line-height: 1.2; }
  .hero-desc             { font-size: 15px; }
  .section-title         { font-size: clamp(22px, 6vw, 30px); }

  /* Buttons */
  .hero-btns             { flex-direction: column; width: 100%; }
  .btn-lg                { width: 100%; justify-content: center; }

  /* Stats */
  .stats-bar-inner       { flex-direction: column; align-items: stretch; }
  .stats-bar-item        { border-right: none; border-bottom: 1px solid var(--c-border); flex: 1; }
  .stats-bar-item:last-child { border-bottom: none; }

  /* Grids */
  .networks-grid         { grid-template-columns: 1fr; }
  .features-grid         { grid-template-columns: 1fr; }
  .steps-grid            { grid-template-columns: 1fr; }
  .reviews-grid          { grid-template-columns: 1fr; }
  .step-arrow            { display: none; }

  /* Order */
  .network-selector      { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .network-btn           { padding: 14px 8px; font-size: 12px; }
  .network-btn svg       { width: 20px; height: 20px; }
  .order-form-card       { padding: 20px 16px; }
  .order-summary-card    { padding: 16px; }
  .order-summary-total   { font-size: 20px; }
  .new-order-layout      { gap: 16px; }

  /* Profile */
  .profile-stats         { grid-template-columns: 1fr; }
  .profile-stat-card     { padding: 16px; }
  .profile-stat-card .val{ font-size: 20px; }
  .profile-layout        { gap: 16px; }
  .tabs                  { gap: 2px; }
  .tab-btn               { font-size: 11px; padding: 8px 8px; flex: 1 1 auto; }

  /* Auth */
  .auth-card             { padding: 28px 20px; margin: 0 0; }
  .auth-page             { padding: 40px 0; }

  /* Tables — make scrollable on mobile */
  .table-wrap            { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .data-table            { min-width: 540px; }

  /* Support */
  .support-grid          { grid-template-columns: 1fr; gap: 14px; }
  .support-channel       { padding: 20px; }

  /* Footer */
  .footer-grid           { grid-template-columns: 1fr; gap: 20px; }
  .footer-col h4         { margin-top: 8px; }
  .footer-payments       { margin-top: 12px; }
  .footer-bottom         { flex-direction: column; gap: 6px; text-align: center; }

  /* FAQ */
  .faq-item summary      { font-size: 14px; padding: 16px; }

  /* Glass cards padding */
  .glass                 { border-radius: var(--radius); }

  /* CTA */
  .cta-section           { padding: 40px 20px; border-radius: 20px; margin: 0 16px; }

  /* Legal pages */
  .legal-body            { padding: 0; }
  .legal-body h2         { font-size: 17px; }

  /* About page team grid */
  [style*="grid-template-columns:repeat(4,1fr)"] { grid-template-columns: 1fr 1fr !important; }
  [style*="grid-template-columns:repeat(3,1fr)"] { grid-template-columns: 1fr 1fr !important; }

  /* Guarantees table */
  .data-table th,
  .data-table td         { padding: 8px; font-size: 12px; white-space: nowrap; }
}

/* ── 360px very small phones ────────────────────────────────── */
@media (max-width: 360px) {
  .container             { padding: 0 12px; }
  .network-selector      { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .network-btn           { padding: 12px 6px; font-size: 11px; }
  .hero-title            { font-size: 22px; }
  .auth-card             { padding: 22px 14px; }
  .tab-btn               { font-size: 10px; padding: 7px 5px; }
}

/* Online badge — десктоп: margin-right:auto создаёт пространство перед nav */
#online-badge { flex-shrink: 0; margin-right: auto; }

/* Orders sidebar — на планшетах уходит под список */
@media (max-width: 960px) {
  [style*="grid-template-columns:1fr 300px"] {
    grid-template-columns: 1fr !important;
  }
}
