/* ===================================================
   NxT Api Shop — Mobile-First Premium UI
   Base = phone. Desktop added via min-width queries.
   =================================================== */

/* ── Tokens ── */
:root {
  --bg:      #07080f;
  --bg-2:    #0d0f1c;
  --panel:   rgba(255,255,255,.045);
  --panel-s: rgba(255,255,255,.08);
  --border:  rgba(255,255,255,.09);
  --text:    #e8eaf4;
  --muted:   #8b92aa;
  --primary: #7c5cff;
  --accent:  #22d3ee;
  --pink:    #f472b6;
  --green:   #34d399;
  --red:     #fb7185;
  --yellow:  #fde68a;
  --shadow:  0 8px 24px rgba(0,0,0,.4);
  --radius:  14px;
  --glass-blur: 16px;
}
[data-theme="light"] {
  --bg:      #f3f4f9;
  --bg-2:    #ffffff;
  --panel:   rgba(15,20,36,.035);
  --panel-s: rgba(15,20,36,.065);
  --border:  rgba(15,20,36,.10);
  --text:    #0d0f1c;
  --muted:   #5a6478;
  --shadow:  0 8px 20px rgba(15,20,36,.09);
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
  overflow-x: hidden;
}
body {
  font-family: 'Plus Jakarta Sans', 'Inter', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.55;
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  max-width: 100vw;
}
*, *::before, *::after { max-width: 100%; }
img, svg, video, canvas, iframe { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
pre, code { white-space: pre-wrap; word-break: break-word; }

/* ── Dark bg gradient ── */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: -2;
  background:
    radial-gradient(800px 450px at 10% -10%, rgba(124,92,255,.14), transparent 60%),
    radial-gradient(600px 350px at 90%  5%, rgba(34,211,238,.10), transparent 60%),
    radial-gradient(550px 450px at 50% 100%,rgba(244,114,182,.07),transparent 60%);
  pointer-events: none;
}
[data-theme="light"] body::before { display: none; }

/* Aurora orbs */
.aurora { position:fixed; inset:0; overflow:hidden; pointer-events:none; z-index:0; }
.aurora .orb {
  position:absolute; border-radius:50%; filter:blur(65px);
  opacity:.4; animation: floaty 18s ease-in-out infinite;
}
.aurora .o1 { width:360px;height:360px;background:radial-gradient(circle,#7c5cff,transparent 70%);top:-100px;left:-80px; }
.aurora .o2 { width:300px;height:300px;background:radial-gradient(circle,#22d3ee,transparent 70%);top:35%;right:-90px;animation-delay:-7s; }
.aurora .o3 { width:280px;height:280px;background:radial-gradient(circle,#f472b6,transparent 70%);bottom:-100px;left:25%;animation-delay:-13s; }
.aurora .grid-overlay {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:44px 44px;
  mask-image:radial-gradient(ellipse at center,black 25%,transparent 72%);
}
[data-theme="light"] .aurora .orb { opacity:.18; }
[data-theme="light"] .aurora .grid-overlay {
  background-image:
    linear-gradient(rgba(0,0,0,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,0,0,.04) 1px,transparent 1px);
}
@keyframes floaty { 0%,100%{transform:translateY(0) scale(1)} 50%{transform:translateY(-25px) scale(1.06)} }
main, header, footer { position:relative; z-index:1; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--panel-s); border-radius:5px; }
::-webkit-scrollbar-thumb:hover { background:var(--primary); }
::selection { background:rgba(124,92,255,.38); color:#fff; }

/* ═══════════════════════════════════
   CONTAINER
   ═══════════════════════════════════ */
.container {
  width:100%; max-width:1200px;
  margin:0 auto; padding:0 16px;
}
@media(min-width:640px){ .container{ padding:0 22px; } }

/* ═══════════════════════════════════
   NAV
   ═══════════════════════════════════ */
.nav {
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(18px) saturate(150%);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  background:color-mix(in oklab,var(--bg) 72%,transparent);
  border-bottom:1px solid var(--border);
}
.nav-inner {
  display:flex; align-items:center; gap:10px; height:56px;
}
.brand {
  display:inline-flex; align-items:center; gap:8px;
  font-weight:800; font-size:.98rem; letter-spacing:-.01em; flex-shrink:0;
}
.brand-mark { width:28px; height:28px; transition:transform .4s; }
.brand:hover .brand-mark { transform:rotate(-12deg) scale(1.08); }

.nav-links { display:none; gap:4px; margin-left:auto; align-items:center; }
@media(min-width:860px){ .nav-links { display:flex !important; } }

.nav-links a {
  padding:7px 11px; border-radius:9px; font-size:.88rem; color:var(--muted);
  transition:color .2s,background .2s; position:relative;
}
.nav-links a:hover { color:var(--text); background:var(--panel); }
.nav-links a.active { color:var(--text); background:var(--panel-s); }
.nav-links a.active::after {
  content:''; position:absolute; bottom:-3px; left:50%; transform:translateX(-50%);
  width:18px; height:3px; border-radius:3px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  box-shadow:0 0 8px var(--primary);
}

.nav-actions { display:flex; align-items:center; gap:7px; margin-left:auto; }
@media(min-width:860px){ .nav-actions{ margin-left:0; } }

.menu-btn {
  display:inline-grid; place-items:center;
  width:36px; height:36px; border-radius:9px;
  border:1px solid var(--border); background:var(--panel); color:var(--text);
}
@media(min-width:860px){ .menu-btn{ display:none; } }

.nav-links.open {
  display:flex; flex-direction:column;
  position:fixed; top:56px; left:0; right:0;
  background:var(--bg-2); border-bottom:1px solid var(--border);
  padding:12px 16px 18px; gap:5px; z-index:49;
  animation:slideDown .22s ease;
}
.nav-links.open a { padding:11px 14px; border-radius:10px; font-size:.93rem; color:var(--text); }
.nav-links.open a:hover,.nav-links.open a.active { background:var(--panel-s); }
@keyframes slideDown { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }

/* Announce */
.announce {
  background:linear-gradient(90deg,rgba(124,92,255,.18),rgba(34,211,238,.16),rgba(244,114,182,.16));
  background-size:200% 100%; animation:shiftBg 14s linear infinite;
  border-bottom:1px solid var(--border); padding:7px 0; font-size:.8rem;
  text-align:center; color:var(--text);
}
@keyframes shiftBg { from{background-position:0% 50%} to{background-position:200% 50%} }

/* ═══════════════════════════════════
   BUTTONS
   ═══════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:11px 18px; border-radius:12px;
  font-weight:600; font-size:.95rem; border:1px solid transparent;
  transition:all .2s ease; min-height:44px; cursor:pointer;
  position:relative; overflow:hidden;
}
.btn-primary {
  background:linear-gradient(135deg,var(--primary),#5b8cff);
  color:#fff; box-shadow:0 6px 18px -5px rgba(124,92,255,.55);
}
@media(hover:hover){
  .btn-primary:hover { transform:translateY(-2px); box-shadow:0 10px 22px -5px rgba(124,92,255,.68); }
}
.btn-primary:active { transform:none; }
.btn-ghost  { background:var(--panel); border-color:var(--border); color:var(--text); }
.btn-glass  { background:var(--panel); border-color:var(--border); color:var(--text); backdrop-filter:blur(12px); }
@media(hover:hover){
  .btn-ghost:hover,.btn-glass:hover { background:var(--panel-s); }
  .btn-glass:hover { border-color:rgba(124,92,255,.42); }
}
.btn-danger  { background:rgba(251,113,133,.13); color:var(--red);   border-color:rgba(251,113,133,.28); }
.btn-success { background:rgba(52,211,153,.13);  color:var(--green); border-color:rgba(52,211,153,.28); }
.btn-sm  { padding:7px 13px; font-size:.82rem; border-radius:9px; min-height:36px; }
.btn-lg  { padding:13px 24px; font-size:1rem; border-radius:13px; min-height:50px; }
.btn-block { width:100%; justify-content:center; }
.btn:disabled { opacity:.42; cursor:not-allowed; pointer-events:none; }

.btn-shine::before {
  content:''; position:absolute; top:0; left:-100%; width:55%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transform:skewX(-20deg); transition:left .7s;
}
.btn-shine:hover::before { left:130%; }

.icon-btn {
  width:36px; height:36px; display:inline-grid; place-items:center;
  border-radius:9px; border:1px solid var(--border);
  background:var(--panel); color:var(--text);
  transition:background .2s,transform .2s; flex-shrink:0;
}
@media(hover:hover){ .icon-btn:hover { background:var(--panel-s); transform:translateY(-1px); } }

/* ═══════════════════════════════════
   CARDS
   ═══════════════════════════════════ */
.card, .glass-card {
  background:var(--panel); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px;
  backdrop-filter:blur(var(--glass-blur)) saturate(138%);
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(138%);
  transition:transform .25s,border-color .25s,box-shadow .25s;
  position:relative; overflow:hidden;
}
@media(min-width:600px){ .card,.glass-card{ padding:20px; } }
@media(hover:hover){
  .card:hover,.glass-card:hover {
    transform:translateY(-3px);
    border-color:rgba(124,92,255,.38);
    box-shadow:0 12px 32px -13px rgba(124,92,255,.22);
  }
}
.card-title { font-weight:700; font-size:.98rem; margin:0 0 5px; }
.card-sub   { color:var(--muted); font-size:.86rem; margin:0; line-height:1.45; }
.card-row   { display:flex; gap:11px; align-items:center; }

/* ═══════════════════════════════════
   GRID
   ═══════════════════════════════════ */
.grid { display:grid; gap:12px; }
.grid-2,.grid-3,.grid-4 { grid-template-columns:1fr; gap:11px; }
@media(min-width:500px){ .grid-2{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:580px){ .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:900px){ .grid-3{ grid-template-columns:repeat(3,1fr); gap:16px; } }
@media(min-width:960px){ .grid-4{ grid-template-columns:repeat(4,1fr); gap:16px; } }

/* ═══════════════════════════════════
   SECTIONS
   ═══════════════════════════════════ */
.section { padding:28px 0; }
@media(min-width:860px){ .section{ padding:52px 0; } }
.section-head { text-align:center; margin-bottom:20px; }
.section-title { font-size:1.4rem; font-weight:800; letter-spacing:-.01em; }
.section-sub   { color:var(--muted); margin-top:5px; font-size:.92rem; }
@media(min-width:860px){ .section-title{ font-size:1.9rem; } }

/* ═══════════════════════════════════
   HERO
   ═══════════════════════════════════ */
.hero, .hero-premium { padding:48px 0 28px; text-align:center; position:relative; }
@media(min-width:860px){ .hero,.hero-premium{ padding:78px 0 44px; } }

.pill-badge {
  display:inline-flex; gap:6px; align-items:center;
  padding:6px 13px; border-radius:999px;
  background:var(--panel); border:1px solid var(--border);
  font-size:.78rem; color:var(--muted); backdrop-filter:blur(10px); margin-bottom:14px;
}
.hero-title, .hero h1 {
  font-size:clamp(1.8rem, 7.5vw, 3.7rem);
  line-height:1.1; letter-spacing:-.02em; margin:0 0 13px; font-weight:800;
  background:linear-gradient(120deg,var(--text) 20%,#c5b8ff 50%,#7cf6ff 80%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:shine 8s linear infinite; background-size:200% auto;
}
[data-theme="light"] .hero-title,[data-theme="light"] .hero h1 {
  background:linear-gradient(120deg,#0d0f1c 20%,#4f3bff 50%,#0891b2 80%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
@keyframes shine { to{background-position:-200% center} }
.hero-sub, .hero p {
  color:var(--muted); max-width:58ch; margin:0 auto 22px;
  font-size:clamp(.92rem,2.2vw,1.1rem);
}
.hero-actions { display:flex; gap:9px; justify-content:center; flex-wrap:wrap; }
@media(max-width:360px){ .hero-actions .btn{ width:100%; } }
.trust-row {
  display:flex; gap:8px; justify-content:center; flex-wrap:wrap;
  margin-top:16px; color:var(--muted); font-size:.8rem;
}
.trust-row b { color:var(--text); }

/* ═══════════════════════════════════
   STATS
   ═══════════════════════════════════ */
.stat {
  background:var(--panel); border:1px solid var(--border);
  border-radius:var(--radius); padding:15px 16px;
  transition:transform .2s,border-color .2s; position:relative; overflow:hidden;
}
.stat::after {
  content:''; position:absolute; inset:0;
  background:radial-gradient(160px 80px at var(--mx,80%) var(--my,20%),
    color-mix(in oklab,var(--primary) 20%,transparent),transparent 60%);
  opacity:0; transition:opacity .3s; pointer-events:none;
}
@media(hover:hover){
  .stat:hover { transform:translateY(-2px); border-color:rgba(124,92,255,.35); box-shadow:0 10px 26px -13px var(--primary); }
  .stat:hover::after { opacity:1; }
}
.stat .label { color:var(--muted); font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; font-weight:600; }
.stat .value { font-size:1.55rem; font-weight:800; margin-top:5px; letter-spacing:-.01em; }
.stat .delta { font-size:.75rem; color:var(--green); margin-top:4px; }

.stat-card { text-align:center; padding:18px 14px; }
.stat-num {
  font-size:clamp(1.55rem,4vw,2.3rem); font-weight:800;
  background:linear-gradient(120deg,var(--primary),var(--accent));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.stat-lbl { margin-top:4px; color:var(--muted); font-size:.78rem; letter-spacing:.04em; text-transform:uppercase; }

/* ═══════════════════════════════════
   API CARDS
   ═══════════════════════════════════ */
.api-card-pro { display:flex; flex-direction:column; gap:10px; text-decoration:none; color:inherit; }
.api-card-top  { display:flex; justify-content:space-between; align-items:flex-start; }
.api-card-bottom { display:flex; flex-wrap:wrap; gap:5px; margin-top:auto; padding-top:8px; }
.api-icon {
  width:40px; height:40px; border-radius:11px; display:grid; place-items:center;
  background:linear-gradient(135deg,rgba(124,92,255,.2),rgba(34,211,238,.15));
  border:1px solid var(--border); color:#fff; flex-shrink:0; transition:transform .3s;
}
@media(hover:hover){ .card:hover .api-icon { transform:rotate(-6deg) scale(1.04); } }
.api-icon-lg { width:52px; height:52px; border-radius:14px; }
.api-hero { display:flex; gap:14px; align-items:center; margin:10px 0 20px; }
@media(max-width:560px){ .api-hero{ flex-direction:column; text-align:center; align-items:center; } }
.badges { display:flex; gap:5px; flex-wrap:wrap; }

/* ═══════════════════════════════════
   CHIPS / TAGS
   ═══════════════════════════════════ */
.chip {
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 9px; border-radius:999px; font-size:.7rem; font-weight:600;
  border:1px solid var(--border); background:var(--panel); color:var(--text);
}
.chip-soft { color:var(--muted); }
.chip-method { font-family:'JetBrains Mono',monospace; letter-spacing:.04em; }
.chip-free    { background:rgba(52,211,153,.12);  border-color:rgba(52,211,153,.35);  color:#4ade80; }
.chip-paid    { background:rgba(124,92,255,.14);  border-color:rgba(124,92,255,.4);   color:#c5b8ff; }
.chip-verified{ background:rgba(59,130,246,.15);  border-color:rgba(59,130,246,.4);   color:#7dd3fc; }
.chip-featured{ background:rgba(244,114,182,.15); border-color:rgba(244,114,182,.4);  color:#fbcfe8; }
.chip-new     { background:rgba(52,211,153,.14);  border-color:rgba(52,211,153,.4);   color:#86efac; }
.chip-popular { background:rgba(251,146,60,.14);  border-color:rgba(251,146,60,.4);   color:#fdba74; }
.chip-pro     { background:rgba(250,204,21,.16);  border-color:rgba(250,204,21,.4);   color:#fde68a; }

.tag {
  font-size:.68rem; padding:3px 8px; border-radius:999px;
  background:var(--panel-s); color:var(--muted); border:1px solid var(--border);
  text-transform:uppercase; letter-spacing:.04em; font-weight:600;
}
.tag.free { color:var(--green); border-color:rgba(52,211,153,.3); background:rgba(52,211,153,.08); }
.tag.paid { color:var(--accent); border-color:rgba(34,211,238,.3); background:rgba(34,211,238,.08); }

.badge {
  display:inline-flex; align-items:center; gap:4px;
  padding:2px 8px; border-radius:999px; font-size:.68rem; font-weight:600;
  border:1px solid var(--border); background:var(--panel-s); color:var(--muted);
}
.badge.green  { color:var(--green); border-color:rgba(52,211,153,.3);  background:rgba(52,211,153,.1); }
.badge.red    { color:var(--red);   border-color:rgba(251,113,133,.3); background:rgba(251,113,133,.1); }
.badge.yellow { color:var(--yellow);border-color:rgba(253,230,138,.3); background:rgba(253,230,138,.1); }
.badge.blue   { color:var(--accent);border-color:rgba(34,211,238,.3);  background:rgba(34,211,238,.1); }
.badge.dot::before { content:''; width:5px; height:5px; border-radius:50%; background:currentColor; }

.rating { color:#fbbf24; font-size:.88rem; letter-spacing:.03em; }
.rt-num { color:var(--text); font-weight:700; margin-left:4px; }

/* ═══════════════════════════════════
   FORMS
   ═══════════════════════════════════ */
.field { display:flex; flex-direction:column; gap:5px; margin-bottom:13px; }
.field label { font-size:.82rem; color:var(--muted); font-weight:600; }
.input, .select, .textarea,
input[type="text"], input[type="email"], input[type="password"],
input[type="number"], textarea, select {
  width:100%; background:var(--panel); color:var(--text);
  border:1px solid var(--border); border-radius:11px;
  padding:12px 14px; font-size:16px; /* no iOS zoom */
  font-family:inherit; line-height:1.4;
  transition:border-color .2s,box-shadow .2s;
  -webkit-appearance:none; appearance:none;
}
.input:focus,.select:focus,.textarea:focus,input:focus,textarea:focus,select:focus {
  outline:none; border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(124,92,255,.16);
}
.textarea { resize:vertical; min-height:85px; }
.pw-wrap  { position:relative; }
.pw-toggle {
  position:absolute; right:8px; top:50%; transform:translateY(-50%);
  background:transparent; border:0; color:var(--muted); cursor:pointer;
  padding:6px 9px; border-radius:7px; font-size:16px;
}
.pw-toggle:hover { color:var(--text); }
.pw-meter { height:4px; background:var(--panel-s); border-radius:4px; overflow:hidden; margin-top:5px; }
.pw-meter span { display:block; height:100%; width:0; background:var(--red); transition:width .3s,background .3s; border-radius:4px; }

.otp-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(42px,1fr)); gap:8px; }
.otp-cell {
  text-align:center; font-size:1.45rem; font-weight:700;
  padding:11px 0; background:var(--panel); border:1px solid var(--border);
  color:var(--text); border-radius:10px;
  font-family:'JetBrains Mono',monospace; transition:border-color .2s,transform .15s;
}
.otp-cell:focus { outline:none; border-color:var(--primary); transform:translateY(-2px); }

/* ═══════════════════════════════════
   AUTH
   ═══════════════════════════════════ */
.auth-wrap {
  min-height:calc(100vh - 56px);
  display:grid; place-items:center; padding:20px 16px;
}
.auth-card { width:100%; max-width:440px; padding:22px 18px; }
@media(min-width:480px){ .auth-card{ padding:30px 26px; } }
.auth-card h1 { font-size:1.45rem; margin-bottom:4px; }
.auth-card p  { color:var(--muted); margin-bottom:16px; font-size:.9rem; }
.auth-glow {
  position:absolute; top:-65px; right:-65px; width:190px; height:190px;
  border-radius:50%; pointer-events:none;
  background:radial-gradient(circle,rgba(124,92,255,.28),transparent 70%);
  filter:blur(20px); animation:glowFloat 6s ease-in-out infinite alternate;
}
@keyframes glowFloat { 0%{transform:translate(0,0)} 100%{transform:translate(-22px,22px)} }
.auth-icon {
  width:46px; height:46px; border-radius:12px; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff; margin-bottom:12px; box-shadow:0 6px 18px -5px var(--primary);
  animation:bobbing 4s ease-in-out infinite;
}
@keyframes bobbing { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-4px)} }

/* ═══════════════════════════════════
   TABLE
   ═══════════════════════════════════ */
.table-wrap {
  overflow-x:auto; border-radius:var(--radius);
  border:1px solid var(--border); background:var(--panel);
  -webkit-overflow-scrolling:touch;
}
table.tbl { width:100%; border-collapse:collapse; }
table.tbl th,table.tbl td { padding:10px 12px; text-align:left; font-size:.86rem; border-bottom:1px solid var(--border); }
table.tbl th { color:var(--muted); font-weight:600; background:var(--panel-s); white-space:nowrap; }
table.tbl tr:last-child td { border-bottom:none; }
@media(hover:hover){ table.tbl tr:hover td{ background:var(--panel-s); } }

/* Mobile card-rows */
@media(max-width:640px){
  .table-wrap { overflow:visible; border:none; background:transparent; }
  table.tbl { display:block; min-width:0; border:none; background:transparent; }
  table.tbl thead { display:none; }
  table.tbl tbody { display:block; width:100%; }
  table.tbl tr {
    display:block; background:var(--panel); border:1px solid var(--border);
    border-radius:12px; padding:12px 14px; margin-bottom:9px; backdrop-filter:blur(10px);
  }
  table.tbl td {
    display:flex; justify-content:space-between; align-items:center;
    padding:5px 0; border:none; font-size:.84rem; word-break:break-word;
  }
  table.tbl td:first-child {
    font-size:.95rem; font-weight:600;
    border-bottom:1px dashed var(--border); padding-bottom:7px; margin-bottom:3px;
    justify-content:flex-start;
  }
  table.tbl td:last-child {
    border-top:1px dashed var(--border); padding-top:8px; margin-top:5px;
    justify-content:flex-end; flex-wrap:wrap; gap:6px;
  }
  table.tbl td[data-label]::before {
    content:attr(data-label); color:var(--muted);
    font-size:.66rem; text-transform:uppercase; letter-spacing:.4px; font-weight:500;
  }
  table.tbl td .btn-sm { font-size:.72rem; padding:6px 9px; }
  table.tbl td form { display:inline-flex; }
}

/* ═══════════════════════════════════
   SIDEBAR
   ═══════════════════════════════════ */
.layout { display:grid; grid-template-columns:1fr; gap:12px; padding:18px 0; }
@media(min-width:860px){ .layout{ grid-template-columns:218px 1fr; gap:24px; padding:26px 0; } }

.sidebar {
  display:flex; flex-direction:row;
  overflow-x:auto; overflow-y:hidden;
  gap:5px; padding:8px;
  background:var(--panel); border:1px solid var(--border);
  border-radius:12px; scrollbar-width:none; backdrop-filter:blur(10px);
  max-width:calc(100vw - 32px);
}
.sidebar::-webkit-scrollbar { display:none; }

@media(min-width:860px){
  .sidebar {
    flex-direction:column; overflow-x:hidden; overflow-y:auto;
    max-height:calc(100vh - 96px); max-width:none;
    padding:10px; gap:2px;
    position:sticky; top:74px; align-self:start;
    border-radius:var(--radius);
  }
}
.sidebar a {
  display:inline-flex; align-items:center; gap:7px;
  white-space:nowrap; flex-shrink:0;
  padding:8px 11px; border-radius:8px;
  color:var(--muted); font-size:.82rem; font-weight:500; transition:background .2s,color .2s;
}
.sidebar a svg { width:13px; height:13px; }
.sidebar a.active { background:var(--panel-s); color:var(--text); font-weight:600; }
@media(min-width:860px){
  .sidebar a { white-space:normal; flex-shrink:1; width:100%; padding:9px 12px; font-size:.88rem; border-radius:10px; }
  .sidebar a svg { width:15px; height:15px; }
  .sidebar a:hover { background:var(--panel-s); color:var(--text); transform:translateX(2px); }
  .sidebar a.active {
    background:linear-gradient(135deg,rgba(124,92,255,.2),rgba(34,211,238,.18));
    color:var(--text); font-weight:600; box-shadow:inset 3px 0 0 var(--primary);
  }
}
.sidebar-section {
  font-size:.63rem; text-transform:uppercase; letter-spacing:.07em; color:var(--muted);
  flex-shrink:0; padding:8px 5px; align-self:center;
  border-right:1px solid var(--border); margin-right:3px;
}
@media(min-width:860px){
  .sidebar-section { padding:12px 12px 4px; border-right:none; margin-right:0; align-self:flex-start; font-size:.68rem; }
}

/* ═══════════════════════════════════
   CATEGORIES
   ═══════════════════════════════════ */
.cat-cloud { display:flex; flex-wrap:wrap; gap:7px; justify-content:center; }
.cat-pill {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 13px; border-radius:999px;
  background:var(--panel); border:1px solid var(--border);
  font-weight:600; font-size:.86rem; color:var(--text);
  backdrop-filter:blur(10px); transition:all .2s;
}
@media(hover:hover){ .cat-pill:hover{ border-color:var(--primary); transform:translateY(-2px); } }
.cat-pill span { background:rgba(124,92,255,.2); color:#c5b8ff; padding:1px 7px; border-radius:999px; font-size:.72rem; }

/* ═══════════════════════════════════
   PRICING
   ═══════════════════════════════════ */
.plan-card,.price-card { display:flex; flex-direction:column; gap:12px; position:relative; }
.plan-popular,.price-card.popular {
  border-color:rgba(124,92,255,.5); box-shadow:0 0 26px rgba(124,92,255,.15);
}
.plan-tag,.price-card.popular::before {
  content:'Most Popular'; position:absolute; top:-11px; right:14px;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff; font-size:.65rem; padding:3px 10px;
  border-radius:999px; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
}
.plan-name  { margin:0; font-size:1rem; }
.plan-price,.price-amount {
  font-size:1.85rem; font-weight:800;
  background:linear-gradient(120deg,var(--primary),var(--accent));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.plan-price span,.price-amount span { font-size:.78rem; color:var(--muted); font-weight:500; -webkit-text-fill-color:var(--muted); }
.plan-feats,.price-features {
  list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:7px; flex:1;
}
.plan-feats li,.price-features li {
  position:relative; padding-left:19px; color:var(--muted); font-size:.88rem;
}
.plan-feats li::before,.price-features li::before { content:"✓"; position:absolute; left:0; color:var(--green); font-weight:800; }

/* ═══════════════════════════════════
   CODE
   ═══════════════════════════════════ */
.code,pre.code {
  background:#080b14; color:#d6deeb; border-radius:10px;
  padding:12px 13px;
  font-family:'JetBrains Mono',ui-monospace,Menlo,monospace;
  font-size:.78rem; line-height:1.55; overflow-x:auto;
  border:1px solid var(--border);
}
[data-theme="light"] .code { background:#f1f4f9; color:#0d0f1c; }
.copy-btn {
  float:right; background:var(--panel-s); border:1px solid var(--border);
  color:var(--text); padding:3px 8px; border-radius:7px; cursor:pointer; font-size:.72rem;
}
.copy-btn:hover { background:var(--primary); color:#fff; }

/* ═══════════════════════════════════
   FLASH
   ═══════════════════════════════════ */
.flash { margin-bottom:13px; }
.flash > div {
  padding:10px 13px; border-radius:10px; margin-bottom:6px; font-size:.86rem;
  border:1px solid var(--border); background:var(--panel);
  display:flex; align-items:center; gap:8px;
  animation:slideIn .3s cubic-bezier(.4,0,.2,1);
}
.flash .success { color:var(--green);  border-color:rgba(52,211,153,.28);  background:rgba(52,211,153,.08); }
.flash .error   { color:var(--red);    border-color:rgba(251,113,133,.28); background:rgba(251,113,133,.08); }
.flash .info    { color:var(--accent); border-color:rgba(34,211,238,.28);  background:rgba(34,211,238,.08); }
@keyframes slideIn { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }

/* ═══════════════════════════════════
   FOOTER
   ═══════════════════════════════════ */
.footer {
  border-top:1px solid var(--border); margin-top:44px;
  padding:26px 0 52px; color:var(--muted); font-size:.84rem;
}
.footer-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media(min-width:700px){ .footer-grid{ grid-template-columns:2fr 1fr 1fr 1fr; gap:26px; } }
.footer h4 { color:var(--text); font-size:.88rem; margin:0 0 8px; }
.footer a  { display:block; padding:3px 0; color:var(--muted); transition:color .2s; }
.footer a:hover { color:var(--text); }

/* ═══════════════════════════════════
   REVIEWS
   ═══════════════════════════════════ */
.review-card { display:flex; flex-direction:column; gap:8px; }
.review-body { color:var(--muted); font-style:italic; margin:0; font-size:.88rem; line-height:1.5; }
.review-meta { font-size:.8rem; color:var(--muted); }
.review-meta a { color:var(--primary); }

/* ═══════════════════════════════════
   MODAL (bottom sheet on mobile)
   ═══════════════════════════════════ */
.modal-backdrop {
  position:fixed; inset:0; background:rgba(5,8,16,.74);
  z-index:100; display:none; align-items:flex-end; justify-content:center;
  padding:0; backdrop-filter:blur(5px); animation:fadeIn .2s;
}
@media(min-width:600px){ .modal-backdrop{ align-items:center; padding:20px; } }
.modal-backdrop.open { display:flex; }
.modal {
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:18px 18px 0 0; width:100%; padding:20px 16px 30px;
  box-shadow:0 -8px 36px rgba(0,0,0,.4);
  animation:sheetUp .27s cubic-bezier(.4,0,.2,1);
}
@media(min-width:600px){
  .modal{ max-width:500px; border-radius:var(--radius); padding:22px; animation:modalIn .24s cubic-bezier(.4,0,.2,1); }
}
@keyframes fadeIn  { from{opacity:0} to{opacity:1} }
@keyframes sheetUp { from{transform:translateY(55px);opacity:0} to{transform:translateY(0);opacity:1} }
@keyframes modalIn { from{transform:scale(.95) translateY(9px);opacity:0} to{transform:scale(1) translateY(0);opacity:1} }

/* ═══════════════════════════════════
   MISC
   ═══════════════════════════════════ */
.switch { position:relative; display:inline-block; width:41px; height:22px; }
.switch input { opacity:0; width:0; height:0; }
.slider { position:absolute; cursor:pointer; inset:0; background:var(--panel-s); border:1px solid var(--border); border-radius:999px; transition:background .25s; }
.slider::before { content:''; position:absolute; height:16px; width:16px; left:2px; top:2px; background:var(--text); border-radius:50%; transition:transform .25s; }
.switch input:checked + .slider { background:var(--primary); border-color:var(--primary); }
.switch input:checked + .slider::before { transform:translateX(18px); background:#fff; }

.spinner { width:17px; height:17px; border-radius:50%; border:2px solid var(--border); border-top-color:var(--primary); animation:spin .8s linear infinite; display:inline-block; }
@keyframes spin { to{transform:rotate(360deg)} }

.skel { background:linear-gradient(90deg,var(--panel) 0%,var(--panel-s) 50%,var(--panel) 100%); background-size:200% 100%; animation:skel 1.5s linear infinite; border-radius:8px; }
@keyframes skel { from{background-position:200% 0} to{background-position:-200% 0} }

.fab {
  position:fixed; bottom:18px; right:14px; z-index:40;
  width:50px; height:50px; border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff; display:grid; place-items:center;
  box-shadow:0 8px 22px -6px var(--primary); border:0;
  transition:transform .25s; animation:bobbing 3s ease-in-out infinite;
}
.fab:hover { transform:translateY(-4px) scale(1.04); }

[data-tooltip] { position:relative; }
[data-tooltip]::after {
  content:attr(data-tooltip); position:absolute; bottom:calc(100% + 7px); left:50%;
  transform:translateX(-50%) translateY(4px); white-space:nowrap;
  background:var(--bg-2); color:var(--text); border:1px solid var(--border);
  padding:4px 9px; border-radius:7px; font-size:.7rem; pointer-events:none;
  opacity:0; transition:opacity .2s,transform .2s; z-index:60;
  box-shadow:0 5px 16px rgba(0,0,0,.28);
}
[data-tooltip]:hover::after { opacity:1; transform:translateX(-50%) translateY(0); }

.marquee { overflow:hidden; padding:11px 0; border-block:1px solid var(--border); background:var(--panel); }
.marquee-track { display:flex; gap:42px; width:max-content; animation:marquee 20s linear infinite; }
.marquee-track span { color:var(--muted); font-weight:600; letter-spacing:.04em; font-size:.84rem; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

.star-input { display:inline-flex; flex-direction:row-reverse; gap:4px; }
.star-input input { display:none; }
.star-input label { font-size:1.45rem; color:#444; cursor:pointer; transition:color .15s; }
.star-input input:checked ~ label,
.star-input label:hover,
.star-input label:hover ~ label { color:#fbbf24; }

.cta-band { padding:28px 0; }
.cta-card {
  text-align:center; padding:34px 20px;
  background:linear-gradient(135deg,rgba(124,92,255,.13),rgba(34,211,238,.09));
  border-color:rgba(124,92,255,.36);
}
.cta-card h2 { font-size:clamp(1.35rem,3vw,1.9rem); margin:0 0 8px; }
.cta-card p  { color:var(--muted); margin:0 0 16px; font-size:.92rem; }

.reveal { opacity:0; transform:translateY(11px); transition:opacity .52s ease,transform .52s ease; }
.reveal.in { opacity:1; transform:translateY(0); }

.chart-box { position:relative; width:100%; height:160px; }
.chart-box canvas { max-height:160px !important; }
@media(min-width:640px){ .chart-box{ height:210px; } .chart-box canvas{ max-height:210px !important; } }

#theme-toggle:hover svg { animation:spin 1.2s linear infinite; }
@keyframes pop { 0%{transform:scale(0)} 60%{transform:scale(1.14)} 100%{transform:scale(1)} }
.pop { animation:pop .32s cubic-bezier(.4,0,.2,1); }
.value-pulse { animation:valuePulse 1s ease; }
@keyframes valuePulse { 0%{color:var(--accent)} 100%{color:var(--text)} }

/* Light overrides */
[data-theme="light"] .nav   { background:rgba(255,255,255,.8); }
[data-theme="light"] .modal { background:#fff; }
[data-theme="light"] .otp-cell { background:#fff; }
