/* =========================================================================
   ReelSong — landing styles
   Token block (custom properties + keyframes + --grain) lifted VERBATIM from
   the design prototype's <helmet><style> (ReelSong.dc.html). Do not re-derive.
   ========================================================================= */

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:'Space Grotesk',system-ui,sans-serif;-webkit-font-smoothing:antialiased;}
::selection{background:#B6FF2E;color:#0B0B0F;}
[data-rs]::-webkit-scrollbar{width:0;height:0;}
.rs-scroll::-webkit-scrollbar{height:6px;}
.rs-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px;}

/* ---- NEON DARK (default) — sticker/poster ---- */
[data-rs]{
  --bg:#0B0B0F; --bg2:#101019; --surface:#16161F; --surface-2:#1E1E2B;
  --border:rgba(255,255,255,0.16); --text:#F5F5F7; --text-dim:rgba(245,245,247,0.72); --text-mute:rgba(245,245,247,0.5);
  --ink:#0B0B0F;
  --grad-warm:linear-gradient(100deg,#FF8A1E,#FFD23F); --grad-cool:linear-gradient(100deg,#B6FF2E,#22D3D3,#4C6FFF);
  --grad-accent:linear-gradient(100deg,#B6FF2E,#22D3D3);
  --card-out:2px solid rgba(255,255,255,0.22); --hard:6px 6px 0 #9B5DE5; --hard2:6px 6px 0 #22D3D3; --shadow:6px 6px 0 #9B5DE5; --glow:none;
  --hl-bg:#B6FF2E; --hl-fg:#0B0B0F; --hl-r:10px; --hl-pad:0 0.16em; --hl-shadow:4px 4px 0 rgba(0,0,0,0.28); --hl-tilt:rotate(-2.5deg);
  --accent-2:#22D3D3; --num:#B6FF2E;
  --btn-bg:#B6FF2E; --btn-text:#0B0B0F; --btn-out:2px solid #0B0B0F; --btn-shadow:4px 4px 0 #0B0B0F;
  --cta-bg:#B6FF2E; --cta-fg:#0B0B0F; --cta-out:2px solid #0B0B0F; --cta-btn-bg:#0B0B0F; --cta-btn-fg:#B6FF2E;
  --marquee-bg:#B6FF2E; --marquee-fg:#0B0B0F;
  --play-bg:#B6FF2E; --play-fg:#0B0B0F; --play-out:2px solid #0B0B0F; --play-shadow:3px 3px 0 #0B0B0F;
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  --radius:20px; --radius-sm:14px; --pill:999px; --blur:none;
  --font-display:'Unbounded'; --font-body:'Space Grotesk'; --font-mono:'JetBrains Mono';
  --doodle:visible; --bar-bg:rgba(11,11,15,0.82); --hair:1px;
}
[data-rs][data-variant="neon"][data-theme="light"]{
  --bg:#F3F2E9; --bg2:#FFFFFF; --surface:#FFFFFF; --surface-2:#FFFFFF;
  --border:rgba(11,11,15,0.16); --text:#0B0B0F; --text-dim:rgba(11,11,15,0.66); --text-mute:rgba(11,11,15,0.46);
  --card-out:2px solid #0B0B0F; --hard:6px 6px 0 #9B5DE5; --hard2:6px 6px 0 #22D3D3; --shadow:6px 6px 0 #9B5DE5;
  --accent-2:#0E8F90; --num:#0B0B0F;
  --cta-bg:#0B0B0F; --cta-fg:#FFFFFF; --cta-out:2px solid #0B0B0F; --cta-btn-bg:#B6FF2E; --cta-btn-fg:#0B0B0F;
  --marquee-bg:#0B0B0F; --marquee-fg:#B6FF2E;
  --bar-bg:rgba(243,242,233,0.85);
}
@keyframes rs-eq{0%,100%{transform:scaleY(0.28)}50%{transform:scaleY(1)}}
@keyframes rs-floatA{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-16px) rotate(-6deg)}}
@keyframes rs-floatB{0%,100%{transform:translateY(0) rotate(8deg)}50%{transform:translateY(14px) rotate(8deg)}}
@keyframes rs-floatC{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes rs-spin{to{transform:rotate(360deg)}}
@keyframes rs-grad{to{background-position:200% center}}
@keyframes rs-pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,0.0)}50%{box-shadow:0 0 0 8px rgba(255,255,255,0.06)}}
@keyframes rs-scan{0%{transform:translateY(-100%)}100%{transform:translateY(400%)}}
@keyframes rs-shine{0%{background-position:-120% 0}60%,100%{background-position:220% 0}}
@keyframes rs-marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes rs-pop{0%{transform:scale(0.6);opacity:0}60%{transform:scale(1.1)}100%{transform:scale(1);opacity:1}}
@keyframes rs-flow{0%{transform:translateX(0) scale(0.5);opacity:0}15%{opacity:1}80%{opacity:1}100%{transform:translateX(72px) scale(1);opacity:0}}
@keyframes rs-flame{0%,100%{transform:scale(1) rotate(-5deg);filter:drop-shadow(0 0 0 rgba(255,138,30,0))}45%{transform:scale(1.28) rotate(6deg);filter:drop-shadow(0 0 6px rgba(255,138,30,0.85))}}
/* rs-rise: card/row staggered entrance (referenced by the gallery cards) */
@keyframes rs-rise{0%{opacity:0;transform:translateY(18px)}100%{opacity:1;transform:none}}

/* =========================================================================
   LAYOUT — resolved from the prototype renderVals() into static CSS.
   Mobile-first. Landing breakpoint = 860px (mobile = viewport < 860).
   ========================================================================= */

.rs-root{
  background-color:var(--bg);
  color:var(--text);
  font-family:var(--font-body),sans-serif;
  min-height:100vh;
  width:100%;
  overflow-x:hidden;
  position:relative;
  padding-bottom:88px; /* mobile, no player */
}
.rs-grain{
  position:fixed;inset:0;pointer-events:none;z-index:1;
  opacity:0.055;mix-blend-mode:overlay;background-image:var(--grain);
}
.rs-progress{
  position:fixed;top:0;left:0;height:3px;z-index:80;
  background:var(--btn-bg);width:0%;transition:width .12s linear;
}

.rs-container{width:100%;max-width:1180px;margin:0 auto;padding:0 20px;}

/* ---------- TOP BAR ---------- */
.rs-header{
  position:sticky;top:0;z-index:60;background:var(--bar-bg);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:var(--hair) solid var(--border);
}
.rs-bar-inner{
  width:100%;max-width:1180px;margin:0 auto;padding:0 16px;height:62px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.rs-logo{display:flex;align-items:center;gap:10px;cursor:pointer;flex:none;background:none;border:none;}
.rs-logo-mark{
  width:30px;height:30px;border-radius:9px;background:var(--grad-cool);
  display:flex;align-items:center;justify-content:center;box-shadow:var(--glow);
}
.rs-logo-tri{
  width:0;height:0;border-left:9px solid #0B0B0F;border-top:6px solid transparent;
  border-bottom:6px solid transparent;margin-left:2px;
}
.rs-wordmark{font-family:var(--font-display);font-weight:800;font-size:19px;letter-spacing:-0.02em;color:var(--text);}
.rs-wordmark .grad{background:var(--grad-cool);-webkit-background-clip:text;background-clip:text;color:transparent;}

.rs-nav{display:none;}
.rs-nav span{cursor:pointer;color:var(--text-dim);font-size:14px;font-weight:500;}
.rs-bar-right{display:flex;align-items:center;gap:10px;flex:none;}
.rs-theme-toggle{
  width:38px;height:38px;border-radius:var(--pill);border:var(--hair) solid var(--border);
  background:var(--surface-2);color:var(--text);cursor:pointer;display:flex;
  align-items:center;justify-content:center;flex:none;font-size:16px;
}
.rs-nav-cta{display:none;}
.rs-menu-btn{
  width:38px;height:38px;border-radius:999px;border:var(--hair) solid var(--border);
  background:var(--surface-2);cursor:pointer;display:flex;align-items:center;justify-content:center;flex:none;
}
.rs-menu-btn .bars{
  width:16px;height:2px;background:var(--text);border-radius:2px;
  box-shadow:0 5px 0 var(--text),0 -5px 0 var(--text);
}
.rs-mobile-menu{
  padding:8px 20px 18px;display:flex;flex-direction:column;gap:4px;
  border-top:var(--hair) solid var(--border);background:var(--bar-bg);
}
.rs-mobile-menu[hidden]{display:none;}
.rs-mobile-menu span{padding:13px 0;font-size:17px;font-weight:600;cursor:pointer;border-bottom:var(--hair) solid var(--border);}
.rs-mobile-menu span:last-child{border-bottom:none;}

/* ---------- buttons / shared ---------- */
.rs-btn-primary{
  background:var(--btn-bg);color:var(--btn-text);border:var(--btn-out);
  border-radius:999px;font-family:var(--font-display);font-weight:700;
  cursor:pointer;box-shadow:var(--btn-shadow);
}
.rs-btn-ghost{
  background:transparent;color:var(--text);border:var(--hair) solid var(--border);
  border-radius:var(--pill);padding:15px 22px;font-family:var(--font-body);
  font-weight:600;font-size:15px;cursor:pointer;
}
.rs-press:active{transform:scale(0.97);}

/* ---------- HERO ---------- */
.rs-hero{padding:30px 0 36px;position:relative;}
.rs-doodles{visibility:var(--doodle);position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.rs-hero-grid{display:flex;flex-direction:column;gap:34px;}
.rs-hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;background:var(--surface);
  border:var(--card-out);border-radius:var(--pill);padding:7px 14px;
  box-shadow:var(--hard);margin-bottom:22px;
}
.rs-hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:#B6FF2E;box-shadow:0 0 10px #B6FF2E;}
.rs-hero-eyebrow .label{font-family:var(--font-mono);font-size:11px;letter-spacing:0.04em;color:var(--text-dim);text-transform:uppercase;}
.rs-hero-title{
  font-family:var(--font-display);font-weight:800;letter-spacing:-0.02em;
  line-height:1.08;font-size:36px;
}
.rs-hl{
  display:inline-block;background:var(--hl-bg);color:var(--hl-fg);
  border-radius:var(--hl-r);padding:var(--hl-pad);box-shadow:var(--hl-shadow);transform:var(--hl-tilt);
}
.rs-accent{color:var(--accent-2);}
.rs-hero-btns{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:30px;}
.rs-hero-cta{padding:16px 24px;font-size:16px;}
.rs-hero-drops{margin-top:30px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.rs-hero-drops .lbl{font-family:var(--font-mono);font-size:11px;color:var(--text-mute);text-transform:uppercase;letter-spacing:0.06em;}
.rs-hero-drops .pills{display:flex;gap:8px;}
.rs-hero-drops .pills span{font-family:var(--font-display);font-weight:700;font-size:12px;padding:6px 13px;border-radius:999px;border:var(--card-out);}

.rs-hero-visual{position:relative;display:flex;justify-content:center;}
.rs-hero-stage{position:relative;width:100%;max-width:360px;display:flex;gap:16px;align-items:center;}
.rs-photo-card{
  position:relative;width:150px;aspect-ratio:9/16;border-radius:var(--radius);
  overflow:hidden;flex:none;box-shadow:var(--hard);border:var(--card-out);
  animation:rs-floatC 6s ease-in-out infinite;
}
.rs-photo-card{cursor:pointer;}
.rs-photo-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.rs-photo-shade{position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,0.5));pointer-events:none;}
.rs-scan-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(182,255,46,0.16) 1px,transparent 1px),linear-gradient(90deg,rgba(182,255,46,0.16) 1px,transparent 1px);
  background-size:20px 20px;
}
.rs-scan-line{
  position:absolute;left:0;right:0;height:36%;
  background:linear-gradient(180deg,transparent,rgba(182,255,46,0.55),transparent);
  animation:rs-scan 1.2s linear infinite;pointer-events:none;
}
.rs-photo-label{
  position:absolute;left:12px;bottom:12px;font-family:var(--font-mono);font-size:10px;
  color:rgba(255,255,255,0.85);background:rgba(0,0,0,0.3);padding:4px 8px;border-radius:6px;
}
.rs-photo-eq{position:absolute;top:12px;right:12px;display:flex;gap:3px;align-items:flex-end;height:22px;}
.rs-photo-eq span{display:block;width:3px;height:100%;background:#fff;border-radius:3px;transform-origin:bottom;animation:rs-eq 0.9s ease-in-out infinite;}
.rs-photo-eq span:nth-child(2){animation-delay:.15s;}
.rs-photo-eq span:nth-child(3){animation-delay:.3s;}
.rs-photo-eq span:nth-child(4){animation-delay:.45s;}

.rs-flow{visibility:var(--doodle);position:absolute;left:42%;top:0;bottom:0;width:80px;display:flex;align-items:center;pointer-events:none;z-index:1;}
.rs-flow .track{position:relative;width:100%;height:12px;}
.rs-flow .track span{position:absolute;left:0;border-radius:50%;animation:rs-flow 1.8s linear infinite;}

.rs-song-col{flex:1;display:flex;flex-direction:column;gap:14px;min-width:0;position:relative;}
.rs-feat-card{
  background:var(--surface);border:var(--card-out);border-radius:var(--radius);
  box-shadow:var(--hard);padding:14px;display:flex;flex-direction:column;gap:12px;position:relative;
}
.rs-feat-cover{position:relative;border-radius:var(--radius-sm);overflow:hidden;height:152px;}
.rs-feat-cover .grain{position:absolute;inset:0;opacity:0.12;mix-blend-mode:overlay;background-image:var(--grain);}
.rs-feat-cover .shade{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,0.6));}
.rs-feat-badge{
  position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:5px;
  background:rgba(0,0,0,0.34);backdrop-filter:blur(4px);color:#fff;font-family:var(--font-display);
  font-weight:800;font-size:11px;padding:5px 10px;border-radius:999px;
}
.rs-feat-eq{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);display:flex;gap:4px;align-items:flex-end;height:42px;}
.rs-feat-meta{position:absolute;left:12px;right:12px;bottom:11px;}
.rs-feat-meta .title{color:#fff;font-family:var(--font-display);font-weight:800;font-size:19px;line-height:1.1;letter-spacing:-0.01em;}
.rs-feat-meta .sub{display:flex;align-items:center;gap:7px;margin-top:4px;}
.rs-feat-meta .sub span{color:rgba(255,255,255,0.92);font-family:var(--font-mono);font-size:10px;}
.rs-feat-prog{display:flex;align-items:center;gap:8px;}
.rs-feat-prog .t{font-family:var(--font-mono);font-size:10px;color:var(--text-mute);min-width:30px;}
.rs-feat-prog .t.r{text-align:right;}
.rs-feat-prog .bar{flex:1;height:6px;border-radius:99px;background:var(--surface-2);overflow:hidden;}
.rs-feat-prog .bar .fill{height:100%;background:var(--grad-cool);border-radius:99px;}
.rs-feat-ctrls{display:flex;align-items:center;justify-content:center;gap:20px;}
.rs-skip{position:relative;width:42px;height:42px;border-radius:50%;background:var(--surface-2);border:var(--card-out);color:var(--text);cursor:pointer;flex:none;}
.rs-skip .glyph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:28px;line-height:1;opacity:0.85;}
.rs-skip .num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:700;font-size:8px;margin-top:1px;}
.rs-play-btn{
  width:52px;height:52px;border-radius:50%;background:var(--play-bg);color:var(--play-fg);
  border:var(--play-out);box-shadow:var(--play-shadow);cursor:pointer;display:flex;
  align-items:center;justify-content:center;flex:none;
}
.rs-feat-overlay{
  position:absolute;inset:-6px;border-radius:18px;background:rgba(11,11,15,0.62);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;z-index:3;
}
.rs-feat-overlay .bars{display:flex;gap:3px;align-items:flex-end;height:26px;}
.rs-feat-overlay .txt{font-family:var(--font-mono);font-size:11px;color:#B6FF2E;}
.rs-demo-done{
  position:absolute;top:-16px;right:-4px;z-index:6;background:var(--btn-bg);color:var(--btn-text);
  border:var(--btn-out);box-shadow:var(--btn-shadow);border-radius:999px;padding:8px 14px;
  font-family:var(--font-display);font-weight:800;font-size:13px;animation:rs-pop .45s ease;white-space:nowrap;
}
.rs-glow-blob{
  visibility:var(--doodle);position:absolute;width:60%;height:60%;left:20%;top:24%;
  background:radial-gradient(circle,rgba(76,111,255,0.5),transparent 70%);filter:blur(50px);z-index:-1;
}

/* equalizer span common */
.eqbar{display:block;width:3px;height:100%;border-radius:3px;transform-origin:bottom;}

/* ---------- MARQUEE ---------- */
.rs-marquee{
  overflow:hidden;background:var(--marquee-bg);color:var(--marquee-fg);
  border-top:2px solid var(--marquee-fg);border-bottom:2px solid var(--marquee-fg);padding:13px 0;
}
.rs-marquee-track{
  display:flex;width:max-content;animation:rs-marquee 28s linear infinite;
  font-family:var(--font-display);font-weight:800;font-size:clamp(18px,2.6vw,28px);
  letter-spacing:-0.01em;text-transform:uppercase;white-space:nowrap;
}
.rs-marquee-set{display:flex;align-items:center;}
.rs-marquee-set .word{padding:0 22px;}
.rs-marquee-set .star{opacity:0.55;}

/* ---------- SECTIONS ---------- */
.rs-sec{padding:64px 0;}
.rs-sec-alt{padding:64px 0;background:var(--bg2);border-top:var(--hair) solid var(--border);border-bottom:var(--hair) solid var(--border);}
.rs-sec-gallery{padding:64px 0;background:var(--bg2);border-top:var(--hair) solid var(--border);}
.rs-eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-mute);margin-bottom:10px;}
.rs-sec-head{margin-bottom:28px;}
.rs-sec-title{font-family:var(--font-display);font-weight:800;letter-spacing:-0.02em;line-height:1.06;font-size:26px;}

/* steps */
.rs-steps{display:flex;flex-direction:column;gap:16px;}
.rs-step-card{background:var(--surface);border:var(--card-out);border-radius:var(--radius);padding:22px;box-shadow:var(--hard);transition:transform .22s ease;}
.rs-step-card:hover{transform:translateY(-5px);}
.rs-step-top{display:flex;align-items:center;gap:14px;margin-bottom:14px;}
.rs-num-badge{
  display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:16px;
  background:var(--nb);color:#0B0B0F;border:2px solid #0B0B0F;box-shadow:4px 4px 0 #0B0B0F;
  font-family:var(--font-display);font-weight:800;font-size:23px;transform:rotate(-4deg);flex:none;
}
.rs-step-top .line{flex:1;height:var(--hair);background:var(--border);}
.rs-step-card h3{font-family:var(--font-display);font-weight:700;font-size:21px;letter-spacing:-0.01em;margin-bottom:8px;}
.rs-step-card p{color:var(--text-dim);font-size:15px;line-height:1.55;}

/* gallery */
.rs-gallery-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap;}
.rs-swipe-hint{font-family:var(--font-mono);font-size:12px;color:var(--text-mute);}
.rs-gallery{
  display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:4px 20px 16px;margin:0 -20px;-webkit-overflow-scrolling:touch;
}
.rs-gallery-card{
  flex:none;width:250px;scroll-snap-align:start;background:var(--surface);border:var(--card-out);
  border-radius:var(--radius);display:flex;flex-direction:column;transition:transform .22s ease;
  animation:rs-rise .5s cubic-bezier(.2,.7,.2,1) backwards;
}
.rs-gallery-card:hover{transform:translateY(-6px);}
.rs-gallery-card.v1{box-shadow:var(--hard);}
.rs-gallery-card.v2{box-shadow:var(--hard2);}
.rs-cover{position:relative;aspect-ratio:1;border-radius:calc(var(--radius) - 6px);margin:10px 10px 0;overflow:hidden;}
.rs-cover .grain{position:absolute;inset:0;opacity:0.07;mix-blend-mode:overlay;background-image:var(--grain);}
.rs-cover .emoji{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:52px;filter:drop-shadow(0 6px 14px rgba(0,0,0,0.35));}
.rs-ver-badge{position:absolute;top:10px;right:10px;background:#0B0B0F;color:#fff;font-family:var(--font-display);font-weight:800;font-size:11px;padding:5px 9px;border-radius:8px;border:2px solid #fff;z-index:6;}
.rs-trend-badge{
  position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:5px;
  background:rgba(0,0,0,0.34);backdrop-filter:blur(4px);color:#fff;font-family:var(--font-display);
  font-weight:700;font-size:11px;padding:5px 10px;border-radius:999px;z-index:6;
}
.rs-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3;background:transparent;border:none;}
.rs-play-overlay .circle{
  width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,0.16);
  backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border:1.5px solid rgba(255,255,255,0.6);
  display:flex;align-items:center;justify-content:center;
}
.rs-cover-prog{position:absolute;left:10px;right:10px;bottom:10px;height:4px;border-radius:99px;background:rgba(255,255,255,0.3);overflow:hidden;z-index:4;}
.rs-cover-prog .fill{height:100%;background:#fff;border-radius:99px;}
.rs-card-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:10px;}
.rs-card-title{font-family:var(--font-display);font-weight:800;font-size:18px;letter-spacing:-0.01em;line-height:1.15;}
.rs-card-style{display:flex;align-items:center;gap:6px;margin-top:5px;color:var(--text-dim);font-size:13px;}
.rs-card-row{display:flex;align-items:center;gap:8px;}
.rs-card-row .handle{font-family:var(--font-mono);font-size:10px;color:var(--text-mute);}
.rs-vote{margin-left:auto;display:flex;align-items:center;gap:6px;background:var(--surface-2);color:var(--text);border:none;border-radius:999px;padding:6px 12px;font-weight:600;font-size:13px;cursor:pointer;}
.rs-card-desc{color:var(--text-dim);font-size:13px;line-height:1.5;}
.rs-card-stats{display:flex;align-items:center;gap:12px;color:var(--text-mute);font-family:var(--font-mono);font-size:11px;position:relative;}
.rs-card-menu-btn{margin-left:auto;background:transparent;border:none;color:var(--text);cursor:pointer;font-size:20px;line-height:1;padding:0 6px;}
.rs-menu{position:absolute;right:0;bottom:32px;z-index:20;min-width:182px;background:var(--surface);border:var(--card-out);border-radius:var(--radius-sm);box-shadow:var(--hard);overflow:hidden;text-align:left;}
.rs-menu[hidden]{display:none;}
.rs-menu div{padding:11px 14px;font-size:13px;cursor:pointer;border-bottom:var(--hair) solid var(--border);}
.rs-menu div:last-child{border-bottom:none;}

/* features */
.rs-feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.rs-feature{background:var(--surface);border:var(--card-out);border-radius:var(--radius);padding:18px;box-shadow:var(--hard);transition:transform .22s ease;}
.rs-feature:hover{transform:translateY(-6px);}
.rs-feature-icon{
  width:50px;height:50px;border-radius:14px;background:var(--fi);border:2px solid #0B0B0F;
  box-shadow:4px 4px 0 #0B0B0F;color:#0B0B0F;display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;transform:rotate(-4deg);
}
.rs-feature h3{font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:-0.01em;margin-bottom:7px;}
.rs-feature p{color:var(--text-dim);font-size:13px;line-height:1.5;}

/* faq */
.rs-faq-container{width:100%;max-width:780px;margin:0 auto;padding:0 20px;}
.rs-faq-list{display:flex;flex-direction:column;gap:12px;}
.rs-faq-card{background:var(--surface);border:var(--card-out);border-radius:var(--radius-sm);box-shadow:var(--hard);padding:18px;}
.rs-faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;cursor:pointer;}
.rs-faq-q .q{font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:-0.01em;}
.rs-faq-q .ic{font-family:var(--font-display);font-weight:700;font-size:24px;line-height:1;color:var(--accent-2);transform:rotate(0deg);transition:transform .3s ease;flex:none;}
.rs-faq-card.open .rs-faq-q .ic{transform:rotate(45deg);}
.rs-faq-a{overflow:hidden;max-height:0;transition:max-height .35s ease;}
.rs-faq-card.open .rs-faq-a{max-height:320px;}
.rs-faq-a p{color:var(--text-dim);font-size:15px;line-height:1.6;padding-top:14px;}

/* closing CTA */
.rs-cta-panel{
  position:relative;overflow:hidden;text-align:center;border-radius:24px;padding:48px 24px;
  background:var(--cta-bg);color:var(--cta-fg);border:var(--cta-out);box-shadow:var(--hard);
}
.rs-cta-glow{visibility:var(--doodle);position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(182,255,46,0.25),transparent 45%),radial-gradient(circle at 85% 80%,rgba(255,61,166,0.3),transparent 45%);}
.rs-cta-inner{position:relative;z-index:2;}
.rs-cta-title{color:var(--cta-fg);font-family:var(--font-display);font-weight:800;letter-spacing:-0.02em;line-height:1.05;font-size:30px;}
.rs-cta-title .u{border-bottom:0.1em solid currentColor;padding-bottom:0.03em;}
.rs-cta-sub{color:var(--cta-fg);opacity:0.78;font-size:16px;max-width:30ch;margin:16px auto 30px;line-height:1.5;}
.rs-cta-btn{background:var(--cta-btn-bg);color:var(--cta-btn-fg);border:var(--btn-out);border-radius:999px;padding:17px 30px;font-family:var(--font-display);font-weight:700;font-size:17px;cursor:pointer;box-shadow:var(--btn-shadow);}

/* footer */
.rs-footer{padding:40px 0 60px;border-top:var(--hair) solid var(--border);}
.rs-foot-cta{display:flex;flex-direction:column;gap:18px;}
.rs-foot-cta h3{font-family:var(--font-display);font-weight:800;font-size:22px;letter-spacing:-0.01em;}
.rs-foot-cta p{color:var(--text-dim);font-size:14px;margin-top:6px;max-width:34ch;}
.rs-foot-form{display:flex;gap:8px;flex:none;width:100%;}
.rs-foot-form input{flex:1;min-width:0;background:var(--surface);border:var(--card-out);border-radius:var(--pill);padding:13px 16px;font-family:var(--font-body);font-size:14px;color:var(--text);outline:none;}
.rs-foot-form button{background:var(--btn-bg);color:var(--btn-text);border:var(--btn-out);box-shadow:var(--btn-shadow);border-radius:var(--pill);padding:13px 18px;font-family:var(--font-display);font-weight:700;font-size:14px;cursor:pointer;white-space:nowrap;}
.rs-foot-div{height:var(--hair);background:var(--border);margin:30px 0;}
.rs-foot-row{display:flex;flex-direction:column;gap:18px;}
.rs-foot-brand{display:flex;align-items:center;gap:10px;}
.rs-foot-brand .mark{width:28px;height:28px;border-radius:8px;background:var(--grad-cool);display:flex;align-items:center;justify-content:center;}
.rs-foot-brand .tri{width:0;height:0;border-left:8px solid #0B0B0F;border-top:5px solid transparent;border-bottom:5px solid transparent;margin-left:2px;}
.rs-foot-brand .name{font-family:var(--font-display);font-weight:800;font-size:17px;}
.rs-foot-brand .url{font-family:var(--font-mono);font-size:12px;color:var(--text-mute);}
.rs-foot-links{display:flex;gap:22px;flex-wrap:wrap;color:var(--text-dim);font-size:14px;}
.rs-foot-links span{cursor:pointer;}
.rs-foot-copy{font-family:var(--font-mono);font-size:11px;color:var(--text-mute);margin-top:24px;}

/* ---------- MOBILE STICKY BOTTOM CTA ---------- */
.rs-bottom-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:70;
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:var(--bar-bg);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-top:var(--hair) solid var(--border);
}
.rs-bottom-bar button{
  width:100%;background:var(--btn-bg);color:var(--btn-text);border:var(--btn-out);border-radius:var(--pill);
  padding:17px;font-family:var(--font-display);font-weight:700;font-size:16px;cursor:pointer;
  box-shadow:var(--btn-shadow);display:flex;align-items:center;justify-content:center;gap:8px;
}

/* ---------- STICKY MINI-PLAYER ---------- */
.rs-np{
  position:fixed;left:0;right:0;bottom:76px;z-index:75;background:var(--bar-bg);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-top:2px solid var(--border);
  box-shadow:0 -10px 34px rgba(0,0,0,0.28);
}
.rs-np[hidden]{display:none;}
.rs-np-prog{position:absolute;top:0;left:0;right:0;height:3px;background:var(--surface-2);overflow:hidden;}
.rs-np-prog .fill{height:100%;background:var(--grad-cool);}
.rs-np-inner{width:100%;max-width:1180px;margin:0 auto;padding:9px 14px;display:flex;align-items:center;gap:14px;}
.rs-np-track{display:flex;align-items:center;gap:11px;min-width:0;flex:1;}
.rs-np-cover{position:relative;width:42px;height:42px;border-radius:11px;overflow:hidden;flex:none;}
.rs-np-cover .grain{position:absolute;inset:0;opacity:0.14;mix-blend-mode:overlay;background-image:var(--grain);}
.rs-np-cover .eq{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;gap:2px;padding:9px;}
.rs-np-info{min-width:0;}
.rs-np-info .t{font-family:var(--font-display);font-weight:700;font-size:14px;letter-spacing:-0.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rs-np-info .h{font-family:var(--font-mono);font-size:10px;color:var(--text-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rs-np-badge{display:none;}
.rs-np-heart{display:flex;align-items:center;gap:6px;flex:none;background:var(--surface-2);border:none;border-radius:999px;padding:7px 12px;font-family:var(--font-body);font-weight:600;font-size:13px;color:var(--text);cursor:pointer;}
.rs-np-ctrls{display:flex;align-items:center;gap:10px;flex:none;}
.rs-np-skip{display:none;}
.rs-np-toggle{width:44px;height:44px;border-radius:50%;background:var(--play-bg);color:var(--play-fg);border:var(--play-out);box-shadow:var(--play-shadow);cursor:pointer;display:flex;align-items:center;justify-content:center;flex:none;}
.rs-np-round{width:40px;height:40px;border-radius:50%;background:var(--surface-2);border:var(--card-out);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;flex:none;}
.rs-np-time{display:none;}
.rs-np-menu-wrap{position:relative;flex:none;}
.rs-np-menu{position:absolute;right:0;bottom:50px;z-index:30;min-width:184px;background:var(--surface);border:var(--card-out);border-radius:var(--radius-sm);box-shadow:var(--hard);overflow:hidden;text-align:left;}
.rs-np-menu[hidden]{display:none;}
.rs-np-menu div{padding:11px 14px;font-size:13px;cursor:pointer;border-bottom:var(--hair) solid var(--border);}
.rs-np-menu div:last-child{border-bottom:none;}
.rs-np-close{width:34px;height:34px;border-radius:50%;background:transparent;border:none;color:var(--text-mute);cursor:pointer;font-size:23px;line-height:1;flex:none;}

/* toast */
.rs-toast{
  position:fixed;left:50%;transform:translateX(-50%);bottom:152px;z-index:90;
  background:var(--marquee-bg);color:var(--marquee-fg);font-family:var(--font-display);font-weight:700;
  font-size:14px;padding:11px 20px;border-radius:999px;box-shadow:var(--hard);border:2px solid var(--marquee-fg);white-space:nowrap;
}
.rs-toast[hidden]{display:none;}

/* root padding states (set by JS) */
.rs-root.player-open{padding-bottom:150px;}

/* =========================================================================
   DESKTOP — breakpoint 860px
   ========================================================================= */
@media (min-width:860px){
  .rs-root{padding-bottom:0;}
  .rs-root.player-open{padding-bottom:78px;}
  .rs-container{padding:0 40px;}
  .rs-bar-inner{padding:0 40px;}
  .rs-nav{display:flex;align-items:center;gap:26px;flex:1;justify-content:center;}
  .rs-nav-cta{
    display:inline-block;background:var(--btn-bg);color:var(--btn-text);border:var(--btn-out);
    border-radius:999px;padding:10px 18px;font-family:var(--font-body);font-weight:700;font-size:13px;
    cursor:pointer;box-shadow:var(--btn-shadow);
  }
  .rs-menu-btn{display:none;}
  .rs-mobile-menu{display:none !important;}

  .rs-hero{padding:24px 0;min-height:calc(100svh - 110px);display:flex;align-items:center;}
  .rs-hero .rs-container{width:100%;}
  .rs-hero-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:64px;align-items:center;}
  .rs-hero-title{font-size:clamp(52px,4.6vw,68px);line-height:1.05;}
  .rs-hero-btns{margin-top:36px;}
  .rs-hero-drops{margin-top:34px;}
  .rs-hero-cta{padding:17px 30px;font-size:16px;}
  .rs-hero-stage{max-width:500px;}
  .rs-photo-card{width:248px;}

  .rs-sec,.rs-sec-alt,.rs-sec-gallery{padding:110px 0;}
  .rs-sec-head,.rs-gallery-head{margin-bottom:52px;}
  .rs-sec-title{font-size:40px;}
  .rs-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
  .rs-step-card{padding:28px;}
  .rs-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:0;margin:0;overflow:visible;}
  .rs-gallery-card{width:auto;}
  .rs-feat-grid{grid-template-columns:repeat(3,1fr);gap:18px;}
  .rs-feature{padding:26px;}
  .rs-feature h3{font-size:18px;}
  .rs-feature p{font-size:14px;}
  .rs-faq-container{padding:0 40px;}
  .rs-faq-card{padding:20px 24px;}
  .rs-faq-q .q{font-size:18px;}
  .rs-cta-panel{border-radius:32px;padding:80px 40px;}
  .rs-cta-title{font-size:46px;}
  .rs-cta-sub{font-size:18px;}
  .rs-cta-btn{padding:18px 36px;font-size:18px;}
  .rs-footer{padding:56px 0;}
  .rs-foot-cta{flex-direction:row;align-items:center;justify-content:space-between;gap:32px;}
  .rs-foot-cta h3{font-size:26px;}
  .rs-foot-form{width:380px;}
  .rs-foot-row{flex-direction:row;align-items:center;justify-content:space-between;gap:20px;}

  .rs-bottom-bar{display:none;}

  .rs-np{bottom:0;}
  .rs-np-inner{padding:12px 24px;}
  .rs-np-badge{display:inline-flex;align-items:center;gap:5px;flex:none;font-family:var(--font-display);font-weight:700;font-size:12px;padding:5px 11px;border-radius:999px;background:var(--surface-2);}
  .rs-np-ctrls{gap:16px;}
  .rs-np-skip{position:relative;display:block;width:38px;height:38px;border-radius:50%;background:var(--surface-2);border:var(--card-out);color:var(--text);cursor:pointer;flex:none;}
  .rs-np-skip .glyph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:25px;line-height:1;opacity:0.85;}
  .rs-np-skip .num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:700;font-size:7px;margin-top:1px;}
  .rs-np-toggle{width:46px;height:46px;}
  .rs-np-time{display:block;font-family:var(--font-mono);font-size:11px;color:var(--text-mute);flex:none;min-width:74px;text-align:right;}
  .rs-toast{bottom:92px;}
}

/* =========================================================================
   REDUCED MOTION — gate the big continuous loops
   ========================================================================= */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
    scroll-behavior:auto !important;
  }
  .rs-marquee-track{animation:none !important;transform:none !important;}
  .rs-photo-card{animation:none !important;}
  .rs-doodles,.rs-flow,.rs-glow-blob,.rs-cta-glow{display:none !important;}
  .rs-scan-line{animation:none !important;}
  .eqbar,.rs-photo-eq span,.rs-feat-eq span{animation:none !important;transform:scaleY(0.6) !important;}
}
