/* ============================================================
   OnlyPetz — visual system
   A real website: persistent sidebar + discovery grid of video
   cards, click-to-watch immersive player. Dark, refined, one
   electric accent. Collapses to a bottom-nav app shell on mobile.
   ============================================================ */

:root {
  --bg:        #07070a;
  --bg-2:      #0d0d12;
  --surface:   #14141b;
  --surface-2: #1c1c25;
  --surface-3: #25252f;
  --line:      rgba(255,255,255,0.09);
  --line-2:    rgba(255,255,255,0.14);
  --text:      #f5f5f7;
  --muted:     #9a9aa8;
  --muted-2:   #66667a;

  --accent:    #c8ff4d;          /* acid lime — alive / wild */
  --accent-deep:#9fe016;
  --accent-2:  #5be2c0;          /* teal */
  --hot:       #ff4d6d;          /* like / age-gate */

  --radius:    18px;
  --radius-sm: 12px;
  --sidebar-w: 264px;

  --font-display: "Space Grotesk", -apple-system, system-ui, sans-serif;
  --font-body:    "Inter", -apple-system, system-ui, sans-serif;
}

* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html, body { height:100%; }
body {
  font-family:var(--font-body); background:var(--bg); color:var(--text);
  overflow:hidden; -webkit-font-smoothing:antialiased;
}
img, svg, video { display:block; }
/* uniform animal/glyph icons default to text size; context rules below resize */
img.tw { width:1.15em; height:1.15em; object-fit:contain; vertical-align:-0.18em; display:inline-block; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; color:inherit; cursor:pointer; border:none; background:none; }
::selection { background:var(--accent); color:#0a0a0a; }
::-webkit-scrollbar { width:10px; height:10px; }
::-webkit-scrollbar-thumb { background:var(--surface-3); border-radius:10px; border:2px solid var(--bg); }
::-webkit-scrollbar-track { background:transparent; }

/* ── Ambient backdrop ── */
.ambient { position:fixed; inset:0; z-index:0; overflow:hidden;
  background:
    radial-gradient(50% 40% at 12% -5%, rgba(200,255,77,0.10), transparent 70%),
    radial-gradient(45% 40% at 100% 100%, rgba(91,226,192,0.08), transparent 70%),
    var(--bg);
}

/* ============================================================
   Shell: sidebar + main
   ============================================================ */
.shell { position:relative; z-index:1; display:grid; grid-template-columns:var(--sidebar-w) 1fr; height:100dvh; }

/* ── Sidebar ── */
.sidebar {
  height:100dvh; overflow-y:auto; padding:20px 14px 28px;
  border-right:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,0.015), transparent);
  display:flex; flex-direction:column; gap:6px;
}
.brand { display:flex; align-items:center; gap:9px; padding:6px 8px 14px; font-family:var(--font-display); font-weight:700; font-size:22px; letter-spacing:-0.02em; }
.brand .mark { width:30px; height:30px; border-radius:10px; display:grid; place-items:center;
  background:linear-gradient(135deg, var(--accent), var(--accent-2)); box-shadow:0 0 20px -2px rgba(200,255,77,0.55); }
.brand .mark img { width:18px; height:18px; }
.brand .dot { color:var(--accent); }

.nav-group { display:flex; flex-direction:column; gap:2px; }
.nav-label { font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); padding:14px 10px 6px; }
.nav-item {
  display:flex; align-items:center; gap:11px; padding:10px 11px; border-radius:11px;
  font-size:14.5px; font-weight:600; color:var(--text); transition:background .15s ease;
}
.nav-item:hover { background:rgba(255,255,255,0.05); }
.nav-item[data-active="true"] { background:rgba(255,255,255,0.08); }
.nav-item[data-active="true"] .ic { color:var(--accent); }
.nav-item .ic { width:22px; height:22px; display:grid; place-items:center; font-size:18px; flex:0 0 auto; }
.nav-item .ic img { width:20px; height:20px; }
.nav-item .count { margin-left:auto; font-size:11px; color:var(--muted-2); }

.side-pro {
  margin-top:auto; border:1px solid var(--line); border-radius:var(--radius); padding:15px;
  background:linear-gradient(180deg, rgba(200,255,77,0.07), var(--surface));
}
.side-pro h4 { font-family:var(--font-display); font-size:15px; }
.side-pro p { font-size:12px; color:var(--muted); margin:5px 0 11px; line-height:1.4; }
.side-pro a { display:block; text-align:center; padding:9px; border-radius:11px; font-weight:700; font-size:13px; background:var(--accent); color:#0a0a0a; }
.side-foot { font-size:11px; color:var(--muted-2); padding:12px 8px 0; line-height:1.5; }

/* ── Main column ── */
.main { display:flex; flex-direction:column; min-width:0; height:100dvh; }

.topbar {
  display:flex; align-items:center; gap:14px; padding:14px 26px;
  border-bottom:1px solid var(--line);
  background:rgba(7,7,10,0.7); backdrop-filter:blur(14px); z-index:20;
}
.topbar .m-brand { display:none; }
.search {
  flex:1; max-width:460px; display:flex; align-items:center; gap:9px;
  background:var(--surface); border:1px solid var(--line); border-radius:999px; padding:10px 16px;
}
.search input { flex:1; background:none; border:none; outline:none; color:var(--text); font-size:14px; }
.search input::placeholder { color:var(--muted-2); }
.top-actions { margin-left:auto; display:flex; align-items:center; gap:10px; }
.btn-ghost { padding:9px 16px; border-radius:999px; font-size:13.5px; font-weight:600; border:1px solid var(--line); }
.btn-ghost:hover { border-color:var(--line-2); }
.btn-solid { padding:9px 17px; border-radius:999px; font-size:13.5px; font-weight:700; background:var(--accent); color:#0a0a0a; box-shadow:0 0 22px -7px rgba(200,255,77,0.6); }

/* view scroll area */
.view { flex:1; overflow-y:auto; padding:26px 26px 60px; scroll-behavior:smooth; }

/* ── Category chip rail (home) ── */
.chips { display:flex; gap:9px; overflow-x:auto; padding-bottom:4px; margin-bottom:22px; scrollbar-width:none; }
.chips::-webkit-scrollbar { display:none; }
.chip { flex:0 0 auto; display:flex; align-items:center; gap:7px; padding:8px 15px; border-radius:999px;
  font-size:13.5px; font-weight:600; white-space:nowrap; background:var(--surface); border:1px solid var(--line); }
.chip img { width:17px; height:17px; }
.chip[data-active="true"] { background:var(--accent); color:#0a0a0a; border-color:transparent; }

/* ── Hero / featured ── */
.hero { position:relative; border-radius:24px; overflow:hidden; margin-bottom:34px;
  min-height:300px; display:flex; align-items:flex-end; border:1px solid var(--line); }
.hero .hero-bg { position:absolute; inset:0; z-index:0; }
.hero video, .hero .poster { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.hero .scrim { position:absolute; inset:0; z-index:1; background:linear-gradient(90deg, rgba(7,7,10,0.92) 0%, rgba(7,7,10,0.5) 45%, transparent 80%), linear-gradient(0deg, rgba(7,7,10,0.85), transparent 55%); }
.hero .hero-body { position:relative; z-index:2; padding:30px 34px; max-width:560px; }
.hero .eyebrow { display:inline-flex; align-items:center; gap:7px; font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--accent); }
.hero h1 { font-family:var(--font-display); font-size:clamp(26px,3.4vw,42px); line-height:1.05; letter-spacing:-0.02em; margin:10px 0 8px; }
.hero p { color:#d8d8e0; font-size:15px; line-height:1.5; max-width:440px; }
.hero .hero-cta { display:inline-flex; align-items:center; gap:9px; margin-top:18px; padding:12px 22px; border-radius:999px; background:var(--accent); color:#0a0a0a; font-weight:700; font-size:14.5px; box-shadow:0 12px 40px -12px rgba(200,255,77,0.6); }

/* ── Section ── */
.section { margin-bottom:36px; }
.section-head { display:flex; align-items:baseline; gap:11px; margin-bottom:15px; }
.section-head h2 { font-family:var(--font-display); font-size:21px; letter-spacing:-0.01em; }
.section-head .em { font-size:12px; color:var(--muted-2); }
.section-head a { margin-left:auto; font-size:13px; color:var(--accent); font-weight:600; }

/* ── Video grid + cards ── */
.vgrid { display:grid; grid-template-columns:repeat(auto-fill, minmax(196px,1fr)); gap:18px; }
.vcard { position:relative; aspect-ratio:9/16; border-radius:var(--radius); overflow:hidden;
  background:var(--surface); border:1px solid var(--line); cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.vcard:hover { transform:translateY(-4px); border-color:var(--line-2);
  box-shadow:0 22px 50px -22px rgba(0,0,0,0.85), 0 0 0 1px rgba(255,255,255,0.05); }
.vcard .poster, .vcard video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
/* icon-poster (no real clip): dark tinted panel + big uniform icon */
.vcard .iconposter { position:absolute; inset:0; z-index:0; display:grid; place-items:center;
  background:radial-gradient(70% 60% at 50% 38%, color-mix(in srgb, var(--tint) 26%, var(--surface)), var(--surface)); }
.vcard .iconposter img { width:46%; height:46%; opacity:.92; filter:drop-shadow(0 12px 26px rgba(0,0,0,0.5)); }
.vcard .iconposter .soon { position:absolute; bottom:54px; left:0; right:0; text-align:center; font-size:11px; color:var(--muted); font-weight:600; }
.vcard video { opacity:0; transition:opacity .25s ease; }
.vcard[data-playing="true"] video { opacity:1; }
.vcard .grad { position:absolute; inset:0; z-index:1; background:linear-gradient(0deg, rgba(7,7,10,0.92) 4%, rgba(7,7,10,0.15) 42%, transparent 70%); }
.vcard .top { position:absolute; top:10px; left:10px; right:10px; z-index:2; display:flex; justify-content:space-between; pointer-events:none; }
.vcard .pill { display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:700; padding:4px 9px; border-radius:999px; background:rgba(0,0,0,0.45); backdrop-filter:blur(6px); }
.vcard .pill img { width:13px; height:13px; }
.vcard .pill.gate { background:var(--hot); }
.vcard .dur { font-size:11px; font-weight:600; padding:4px 7px; border-radius:7px; background:rgba(0,0,0,0.5); backdrop-filter:blur(6px); }
.vcard .meta { position:absolute; left:12px; right:12px; bottom:12px; z-index:2; }
.vcard .meta .who { display:flex; align-items:center; gap:7px; font-size:12.5px; font-weight:700; }
.vcard .meta .who .av { width:22px; height:22px; border-radius:50%; background:var(--surface-3); display:grid; place-items:center; overflow:hidden; flex:0 0 auto; }
.vcard .meta .who .av img { width:16px; height:16px; }
.vcard .meta .cap { font-size:12.5px; color:#e2e2e8; line-height:1.35; margin-top:5px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.vcard .meta .stat { display:flex; align-items:center; gap:5px; font-size:11.5px; color:var(--muted); margin-top:6px; }
.vcard .play { position:absolute; inset:0; z-index:2; display:grid; place-items:center; opacity:0; transition:opacity .18s ease; }
.vcard:hover .play { opacity:1; }
.vcard .play span { width:52px; height:52px; border-radius:50%; display:grid; place-items:center; font-size:20px;
  background:rgba(10,10,12,0.55); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,0.25); }
.vcard[data-locked="true"] .iconposter img,
.vcard[data-locked="true"] .poster { filter:blur(16px) brightness(.7); }

/* ── Explore: category collection tiles (mosaic of thumbnails) ── */
.cat-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(248px,1fr)); gap:16px; margin-top:8px; }
.cat-tile { position:relative; border-radius:var(--radius); overflow:hidden; min-height:212px; aspect-ratio:1/0.92;
  display:flex; flex-direction:column; justify-content:flex-end; border:1px solid var(--line);
  background:var(--surface); transition:transform .16s ease, border-color .16s ease; }
.cat-tile:hover { transform:translateY(-3px); border-color:var(--line-2); box-shadow:0 22px 50px -22px rgba(0,0,0,0.8); }
/* the 2x2 thumbnail grid filling the tile */
.cat-mosaic { position:absolute; inset:0; z-index:0; display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; gap:2px; }
.cat-mosaic .cell { position:relative; overflow:hidden; background:radial-gradient(75% 70% at 50% 40%, color-mix(in srgb, var(--tint) 22%, var(--surface)), var(--surface)); }
.cat-mosaic .cell img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.cat-mosaic .cell .mini { position:absolute; inset:0; display:grid; place-items:center; }
.cat-mosaic .cell .mini img { position:static; width:42%; height:42%; opacity:.92; filter:drop-shadow(0 6px 14px rgba(0,0,0,0.4)); }
.cat-mosaic .cell .play-dot { position:absolute; bottom:7px; left:8px; font-size:9px; opacity:.85; text-shadow:0 1px 2px rgba(0,0,0,.6); }
.cat-scrim { position:absolute; inset:0; z-index:1; background:linear-gradient(0deg, rgba(7,7,10,0.96) 8%, rgba(7,7,10,0.35) 40%, transparent 64%); }
.cat-tile[data-locked="true"] .cat-mosaic { filter:blur(11px) brightness(.7); }
.cat-tile .lock { position:absolute; top:12px; right:12px; z-index:3; font-size:10.5px; font-weight:700; background:var(--hot); padding:3px 8px; border-radius:7px; }
.cat-foot { position:relative; z-index:2; display:flex; align-items:flex-end; gap:11px; padding:15px 16px; }
.cat-foot .cat-ic { width:34px; height:34px; flex:0 0 auto; }
.cat-foot .cat-ic img { width:100%; height:100%; filter:drop-shadow(0 4px 10px rgba(0,0,0,0.5)); }
.cat-foot .cat-txt { flex:1; min-width:0; }
.cat-foot .name { font-family:var(--font-display); font-weight:700; font-size:17px; }
.cat-foot .bl { font-size:11.5px; color:var(--muted); margin-top:2px; line-height:1.3;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.cat-foot .cat-count { font-size:11px; font-weight:700; color:#0a0a0a; background:var(--accent); padding:3px 9px; border-radius:999px; flex:0 0 auto; }

/* ── Page heads (explore / pro) ── */
.view h1.title { font-family:var(--font-display); font-size:34px; letter-spacing:-0.02em; }
.view p.sub { color:var(--muted); font-size:15px; margin-top:6px; max-width:600px; line-height:1.5; }
.view .section-label { font-size:12px; font-weight:700; letter-spacing:.09em; text-transform:uppercase; color:var(--muted-2); margin:26px 0 4px; }

/* ── Membership ── */
.pro-wrap { max-width:920px; }
.seg { display:inline-flex; gap:4px; background:var(--surface); border:1px solid var(--line); padding:4px; border-radius:999px; margin:22px 0 6px; }
.seg button { padding:9px 22px; border-radius:999px; font-size:13px; font-weight:700; color:var(--muted); }
.seg button[data-active="true"] { background:var(--accent); color:#0a0a0a; }
.seg-note { font-size:12.5px; color:var(--accent); font-weight:600; height:18px; }
.plans { display:grid; grid-template-columns:1fr 1fr; gap:18px; align-items:start; margin-top:8px; }
.plan { border:1px solid var(--line); border-radius:var(--radius); padding:24px; background:var(--surface); position:relative; overflow:hidden; }
.plan.pro { border-color:rgba(200,255,77,0.5); background:linear-gradient(180deg, rgba(200,255,77,0.06), var(--surface)); }
.plan .ribbon { position:absolute; top:16px; right:-32px; transform:rotate(45deg); background:var(--accent); color:#0a0a0a; font-size:10.5px; font-weight:800; padding:4px 38px; }
.plan .tier { font-family:var(--font-display); font-size:19px; font-weight:700; }
.plan .price { font-family:var(--font-display); font-size:42px; font-weight:700; margin-top:6px; letter-spacing:-0.02em; }
.plan .price small { font-size:15px; color:var(--muted); font-weight:500; }
.plan ul { list-style:none; margin:18px 0 0; display:flex; flex-direction:column; gap:11px; }
.plan li { font-size:14px; display:flex; gap:9px; align-items:flex-start; color:#e6e6ea; }
.plan li .ck { color:var(--accent); font-weight:800; flex:0 0 auto; }
.plan li.off, .plan li.off .ck { color:var(--muted-2); }
.btn { display:block; width:100%; text-align:center; margin-top:20px; padding:13px; border-radius:12px; font-weight:700; font-size:14.5px; background:var(--surface-2); border:1px solid var(--line); }
.btn.primary { background:var(--accent); color:#0a0a0a; border-color:transparent; box-shadow:0 0 26px -6px rgba(200,255,77,0.55); }
.vibe-check { color:var(--hot); font-size:13.5px; font-weight:700; text-align:center; margin-top:13px; line-height:1.4; }
.faq { max-width:720px; margin-top:30px; }
.faq details { border-bottom:1px solid var(--line); padding:15px 2px; }
.faq summary { font-weight:600; font-size:14.5px; list-style:none; display:flex; justify-content:space-between; align-items:center; cursor:pointer; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:"+"; color:var(--accent); font-size:20px; }
.faq details[open] summary::after { content:"–"; }
.faq p { font-size:13.5px; color:var(--muted); margin-top:9px; line-height:1.5; }

/* ============================================================
   Immersive player overlay (click-to-watch)
   ============================================================ */
.player { position:fixed; inset:0; z-index:60; display:none; align-items:center; justify-content:center;
  background:rgba(4,4,6,0.86); backdrop-filter:blur(20px); }
.player[data-open="true"] { display:flex; }
.player .close { position:absolute; top:20px; right:24px; z-index:5; width:42px; height:42px; border-radius:50%;
  background:rgba(255,255,255,0.1); backdrop-filter:blur(8px); font-size:18px; display:grid; place-items:center; }
.player .nav-btn { position:absolute; right:34px; z-index:5; width:46px; height:46px; border-radius:50%;
  background:rgba(255,255,255,0.1); backdrop-filter:blur(8px); font-size:20px; display:grid; place-items:center; }
.player .nav-btn.up { top:calc(50% - 60px); }
.player .nav-btn.down { top:calc(50% + 14px); }

.stage { position:relative; height:min(90dvh, 880px); aspect-ratio:9/16; border-radius:26px; overflow:hidden;
  background:#000; box-shadow:0 40px 120px -24px rgba(0,0,0,0.9), 0 0 0 1px rgba(255,255,255,0.06); display:flex; flex-direction:column; justify-content:flex-end; }
.stage video, .stage .iconposter { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.stage .iconposter { display:grid; place-items:center; background:radial-gradient(70% 60% at 50% 40%, color-mix(in srgb, var(--tint,#333) 26%, #14141b), #0c0c12); }
.stage .iconposter img { width:42%; height:42%; opacity:.92; }
.stage .iconposter .soon { position:absolute; bottom:70px; font-size:12px; color:var(--muted); font-weight:600; }
.stage .vig { position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(0,0,0,0.35), transparent 22%, transparent 55%, rgba(0,0,0,0.82)); }
.stage .progress { position:absolute; top:0; left:0; right:0; height:3px; z-index:5; background:rgba(255,255,255,0.18); }
.stage .progress i { display:block; height:100%; width:0; background:var(--accent); box-shadow:0 0 10px var(--accent); transition:width .15s linear; }

.rail { position:absolute; right:12px; bottom:118px; z-index:4; display:flex; flex-direction:column; align-items:center; gap:18px; }
.rail .act { display:flex; flex-direction:column; align-items:center; gap:5px; }
.rail .act .glyph { width:46px; height:46px; border-radius:50%; display:grid; place-items:center; font-size:22px; background:rgba(0,0,0,0.3); backdrop-filter:blur(4px); transition:transform .15s ease; }
.rail .act:active .glyph { transform:scale(.85); }
.rail .act span { font-size:12px; font-weight:600; text-shadow:0 1px 3px rgba(0,0,0,.6); }
.rail .act[data-on="true"] .glyph.heart { color:var(--hot); transform:scale(1.06); }
.rail .act[data-on="true"] .glyph.save { color:var(--accent); }
.rail .avatar-wrap { position:relative; margin-bottom:4px; }
.rail .avatar { width:48px; height:48px; border-radius:50%; display:grid; place-items:center; overflow:hidden; background:linear-gradient(135deg,#2a2a36,#15151c); border:2px solid #fff; }
.rail .avatar img { width:28px; height:28px; }
.rail .follow { position:absolute; bottom:-9px; left:50%; transform:translateX(-50%); width:22px; height:22px; border-radius:50%; background:var(--accent); color:#0a0a0a; font-size:15px; font-weight:800; display:grid; place-items:center; line-height:0; }
.rail .follow[data-on="true"] { background:#fff; }

.caption { position:relative; z-index:3; padding:0 78px 26px 18px; }
.caption .who { display:flex; align-items:center; gap:8px; font-weight:700; font-size:15px; }
.caption .who .pill { font-size:11px; font-weight:700; padding:3px 9px; border-radius:999px; background:var(--accent); color:#0a0a0a; }
.caption .txt { margin-top:7px; font-size:14px; line-height:1.4; color:#ececf0; }
.caption .music { margin-top:11px; display:flex; align-items:center; gap:7px; font-size:12.5px; color:#dcdce2; overflow:hidden; white-space:nowrap; }
.caption .music .scroller { overflow:hidden; }
.caption .music .scroller b { display:inline-block; font-weight:500; animation:marq 14s linear infinite; }
@keyframes marq { from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

.gate { position:absolute; inset:0; z-index:6; display:none; flex-direction:column; align-items:center; justify-content:center; gap:14px; text-align:center; padding:34px; background:rgba(7,7,10,0.78); backdrop-filter:blur(16px); }
.stage[data-locked="true"] .gate { display:flex; }
.gate .lg { font-size:46px; }
.gate h3 { font-family:var(--font-display); font-size:19px; }
.gate p { font-size:13px; color:var(--muted); max-width:250px; line-height:1.45; }
.gate .btn { max-width:210px; }

/* ── Mobile bottom nav (hidden on desktop) ── */
.tabbar { display:none; }

/* toast */
.toast { position:fixed; left:50%; bottom:30px; transform:translateX(-50%) translateY(20px); z-index:90;
  background:var(--surface-2); border:1px solid var(--line); padding:11px 18px; border-radius:999px; font-size:13.5px; font-weight:600;
  opacity:0; transition:all .25s ease; pointer-events:none; white-space:nowrap; }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

.demo-badge { position:fixed; left:14px; bottom:14px; z-index:50; font-size:11px; color:var(--muted-2);
  background:rgba(0,0,0,0.4); border:1px solid var(--line); padding:5px 10px; border-radius:999px; }

/* ============================================================
   RESPONSIVE — collapse to a mobile app shell w/ bottom nav
   ============================================================ */
@media (max-width:880px){
  .shell { grid-template-columns:1fr; }
  .sidebar { display:none; }
  .main { height:100dvh; }
  .topbar { padding:12px 16px; }
  .topbar .m-brand { display:flex; align-items:center; gap:8px; font-family:var(--font-display); font-weight:700; font-size:19px; }
  .topbar .m-brand .mark { width:26px; height:26px; border-radius:8px; display:grid; place-items:center; background:linear-gradient(135deg,var(--accent),var(--accent-2)); }
  .topbar .m-brand .mark img { width:15px; height:15px; }
  .search { display:none; }
  .top-actions .btn-ghost { display:none; }
  .view { padding:18px 14px 96px; }
  .vgrid { grid-template-columns:1fr 1fr; gap:12px; }
  .cat-grid { grid-template-columns:1fr 1fr; gap:12px; }
  .plans { grid-template-columns:1fr; }
  .hero { min-height:230px; }
  .hero .hero-body { padding:22px; }
  .view h1.title { font-size:27px; }
  .demo-badge { display:none; }

  .stage { height:100dvh; width:100vw; aspect-ratio:auto; border-radius:0; }
  .player .nav-btn { display:none; }
  .player .close { top:14px; right:16px; }

  /* bottom nav returns on mobile only */
  .tabbar { display:flex; position:fixed; bottom:0; left:0; right:0; z-index:40;
    align-items:center; justify-content:space-around;
    padding:8px 8px calc(8px + env(safe-area-inset-bottom));
    background:linear-gradient(0deg, var(--bg) 62%, transparent); border-top:1px solid var(--line); }
  .tab { display:flex; flex-direction:column; align-items:center; gap:3px; font-size:10.5px; color:var(--muted-2); font-weight:600; }
  .tab .ic { font-size:20px; width:24px; height:24px; display:grid; place-items:center; }
  .tab .ic img { width:21px; height:21px; }
  .tab[data-active="true"] { color:var(--text); }
  .tab.create .ic { width:46px; height:31px; border-radius:11px; background:linear-gradient(135deg,var(--accent),var(--accent-2)); color:#0a0a0a; font-weight:800; box-shadow:0 0 20px -4px rgba(200,255,77,0.6); }
}
