/* ============================================================
   NoScroll — Main Stylesheet
   Material 3 · Roboto · Dark-first · v2.0
   Fonts + tokens load via wp_enqueue_style (no @import — faster first paint).
   ============================================================ */

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  font-size:16px;
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  /* Offset anchor targets for sticky header + progress bar */
  scroll-padding-top:clamp(72px,12vh,100px);
}
body{
  font-family:'Roboto',system-ui,sans-serif;
  font-weight:400;
  background:var(--ns-bg);
  color:var(--ns-text);
  line-height:1.6;
  min-height:100vh;
  transition:background .4s ease,color .4s ease;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
::selection{
  background:rgba(236,13,102,.24);
  color:var(--ns-text);
}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button,input,textarea,select{font-family:inherit;font-size:inherit}
button{cursor:pointer;border:none;background:none}

/* ── Typography ── */
h1,h2,h3,h4,h5,h6{font-family:'Roboto',sans-serif;font-weight:700;line-height:1.14;color:var(--ns-text)}
h1{font-size:clamp(2.4rem,6vw,4.8rem);font-weight:900;letter-spacing:-.04em;text-wrap:balance}
h2{font-size:clamp(1.85rem,4vw,3.2rem);font-weight:800;letter-spacing:-.03em;text-wrap:balance}
h3{font-size:clamp(1.3rem,2.8vw,2.2rem);font-weight:700}
h4{font-size:1.2rem;font-weight:700}
p{color:var(--ns-text-secondary);line-height:1.75;font-size:1.0625rem}

/* ── Layout ── */
.container{width:100%;max-width:1280px;margin-inline:auto;padding-inline:clamp(var(--sp-6), 5vw, var(--sp-12))}
.container--narrow{max-width:880px}
.container--wide{max-width:1440px}
.section{padding-block:clamp(var(--sp-12), 10vw, var(--sp-24))}
.section--sm{padding-block:clamp(var(--sp-6), 5vw, var(--sp-12))}
.section--lg{padding-block:clamp(var(--sp-20), 15vw, var(--sp-32))}

/* ── Helpers ── */
.text-center{text-align:center}
.text-primary{color:var(--ns-primary)}
.text-secondary-color{color:var(--ns-text-secondary)}
.text-curious{color:var(--ns-curious)}
.text-block-all{color:var(--ns-block-all)}
.text-one-reel{color:var(--ns-one-reel)}
.text-success{color:var(--ns-success)}
.font-mono{font-family:'Roboto Mono',monospace}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.gradient-text{
  background:linear-gradient(135deg,var(--ns-primary) 0%,#AE5DFF 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ============================================================
   SCROLL ANIMATIONS (M3 Expressive)
   ============================================================ */

@media(prefers-reduced-motion:no-preference){
  [data-animate]{
    will-change:transform,opacity,filter;
    opacity:0;
  }
  [data-animate="fade-up"]    {transform:translateY(40px)}
  [data-animate="fade-down"]  {transform:translateY(-30px)}
  [data-animate="fade-left"]  {transform:translateX(-40px)}
  [data-animate="fade-right"] {transform:translateX(40px)}
  [data-animate="scale-up"]   {transform:scale(.92)}

  [data-animate].is-visible{
    opacity:1;
    transform:none;
    filter:none;
    transition:
      opacity 800ms cubic-bezier(0.3, 0, 0, 1),
      transform 800ms cubic-bezier(0.3, 0, 0, 1),
      filter 600ms ease;
    transition-delay:calc(var(--delay,0) * 120ms);
  }
}
@media(prefers-reduced-motion:reduce){
  [data-animate]{opacity:1;transform:none}
}

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */

.announcement-bar{
  background:linear-gradient(90deg,rgba(236,13,102,.12),rgba(55,66,255,.12));
  border-bottom:1px solid rgba(236,13,102,.2);
  padding:10px var(--sp-4);
  text-align:center;
  font-size:.8125rem;
  color:var(--ns-text-secondary);
  display:flex;align-items:center;justify-content:center;gap:var(--sp-3);
  flex-wrap:wrap;
}
.announcement-bar a{
  color:var(--ns-primary);font-weight:600;
  border-bottom:1px solid rgba(236,13,102,.4);
  transition:border-color .2s;
}
.announcement-bar a:hover{border-color:var(--ns-primary)}
.announcement-badge{
  background:var(--ns-primary);color:#fff;
  font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:2px 8px;border-radius:var(--r-full);
}

/* ============================================================
   SITE HEADER / NAV
   ============================================================ */

.site-header{
  position:sticky;top:0;z-index:200;
  background:rgba(0,18,43,.82);
  backdrop-filter:blur(20px) saturate(1.6);
  -webkit-backdrop-filter:blur(20px) saturate(1.6);
  border-bottom:1px solid var(--ns-outline-var);
  transition:background .4s;
  box-shadow:0 4px 24px -8px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.04);
}
[data-theme="light"] .site-header{
  background:rgba(250,250,250,.88);
  box-shadow:0 4px 24px -10px rgba(0,18,43,.08),inset 0 1px 0 rgba(255,255,255,.85);
}

.site-header__inner{
  display:flex;align-items:center;justify-content:space-between;
  height:64px;gap:var(--sp-6);
}

.site-logo{
  display:flex;align-items:center;gap:var(--sp-3);
  font-size:1.2rem;font-weight:900;color:var(--ns-text);letter-spacing:-.02em;flex-shrink:0;
  text-decoration:none;
}
.site-logo:hover{color:var(--ns-text);opacity:.92}
.site-logo__mark{
  width:34px;height:34px;border-radius:var(--r-md);
  background:linear-gradient(135deg,var(--ns-primary),#7C3AED);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:17px;font-weight:900;
  box-shadow:0 4px 12px rgba(236,13,102,.4);
}

/* Landscape wordmark (SVG asset — tinted via theme text color) */
.site-logo--landscape{
  gap:0;
}
.site-logo--landscape .site-logo__graphic{
  display:block;
  flex-shrink:0;
  height:clamp(32.5px,5.25vw,42.5px);
  width:auto;
  max-width:min(250px,62.5vw);
  aspect-ratio:241/95;
  background-color:var(--ns-text);
  -webkit-mask-image:url('../img/noscroll_landscape_logo.svg');
  mask-image:url('../img/noscroll_landscape_logo.svg');
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat;
  -webkit-mask-position:left center;
  mask-position:left center;
  -webkit-mask-size:contain;
  mask-size:contain;
  transition:opacity .2s ease,background-color .25s ease;
}
.site-footer .site-logo--landscape .site-logo__graphic{
  height:clamp(34.375px,5.46875vw,43.75px);
  max-width:min(281px,85vw);
}

.site-nav{display:flex;align-items:center;gap:2px}
.site-nav .site-nav__menu{
  display:flex;align-items:center;gap:2px;margin:0;padding:0;list-style:none;
}
.site-nav .site-nav__menu li{margin:0}
.site-header__nav-wrap{
  flex:1;display:flex;justify-content:center;align-items:center;min-width:0;
}
.site-header .site-header-nav.wp-block-navigation .wp-block-navigation-item .wp-block-navigation-item__content{
  padding:8px 16px;border-radius:var(--r-full);
  font-size:.875rem;font-weight:500;color:var(--ns-text-secondary);
  transition:background .2s,color .2s;
}
.site-header .site-header-nav.wp-block-navigation .wp-block-navigation-item .wp-block-navigation-item__content:hover{
  background:rgba(255,255,255,.07);color:var(--ns-text);
}
[data-theme="light"] .site-header .site-header-nav.wp-block-navigation .wp-block-navigation-item .wp-block-navigation-item__content:hover{
  background:rgba(0,0,0,.06);color:var(--ns-text);
}

.site-header-nav--static .site-nav__menu{display:flex;align-items:center;gap:2px;margin:0;padding:0;list-style:none;flex-wrap:wrap;justify-content:center}
.site-header-nav--static .site-nav__menu li{margin:0}
.site-header-nav--static .site-nav__link{
  padding:8px 16px;border-radius:var(--r-full);
  font-size:.875rem;font-weight:500;color:var(--ns-text-secondary);
  transition:background .2s,color .2s;
}
.site-header-nav--static .site-nav__link:hover{background:rgba(255,255,255,.07);color:var(--ns-text)}
[data-theme="light"] .site-header-nav--static .site-nav__link:hover{background:rgba(0,0,0,.06);color:var(--ns-text)}
.site-nav__link{
  padding:8px 16px;border-radius:var(--r-full);
  font-size:.875rem;font-weight:500;color:var(--ns-text-secondary);
  transition:background .2s,color .2s;
}
.site-nav__link:hover,.site-nav__link.is-active{
  background:rgba(255,255,255,.07);color:var(--ns-text);
}
[data-theme="light"] .site-nav__link:hover,
[data-theme="light"] .site-nav__link.is-active{background:rgba(0,0,0,.06);color:var(--ns-text)}

.site-header__actions{display:flex;align-items:center;gap:var(--sp-3)}

/* Theme toggle */
.theme-toggle{position:relative;width:50px;height:26px;flex-shrink:0;cursor:pointer}
.theme-toggle input{opacity:0;width:0;height:0;position:absolute}
.theme-toggle__track{
  position:absolute;inset:0;border-radius:var(--r-full);
  background:var(--ns-outline-var);transition:background .2s;
}
.theme-toggle input:checked+.theme-toggle__track{background:var(--ns-primary)}
.theme-toggle__thumb{
  position:absolute;top:3px;left:3px;width:20px;height:20px;
  border-radius:50%;background:#fff;transition:transform .2s;
  display:flex;align-items:center;justify-content:center;font-size:11px;
  pointer-events:none;
}
.theme-toggle input:checked~.theme-toggle__thumb{transform:translateX(24px)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:var(--sp-2);border-radius:var(--r-md)}
.hamburger span{display:block;width:22px;height:2px;background:var(--ns-text);border-radius:2px;transition:transform .2s,opacity .2s}
.hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.is-open span:nth-child(2){opacity:0}
.hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav */
.mobile-nav{
  display:none;position:fixed;top:64px;right:0;bottom:0;left:0;
  background:rgba(0,18,43,0.82);
  backdrop-filter:blur(20px) saturate(1.6);
  -webkit-backdrop-filter:blur(20px) saturate(1.6);
  z-index:199;padding:var(--sp-6);padding-bottom:calc(var(--sp-6) + env(safe-area-inset-bottom, 20px));
  flex-direction:column;
  border-top:1px solid var(--ns-outline-var);overflow-y:auto;
}
[data-theme="light"] .mobile-nav{
  background:rgba(250,250,250,0.88);
}
.mobile-nav .mobile-nav__menu{
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--sp-4);margin:0;padding:var(--sp-8) 0;list-style:none;flex:1;
}
.mobile-nav .mobile-nav__menu li{margin:0}
.mobile-nav.is-open{display:flex}
.mobile-nav__link{
  padding:var(--sp-3) var(--sp-6);border-radius:var(--r-lg);font-size:1.5rem;font-weight:700;text-align:center;
  color:var(--ns-text-secondary);transition:background .2s,color .2s,transform .2s;
}
.mobile-nav__link:hover{background:var(--ns-surface);color:var(--ns-text);transform:scale(1.05)}
.divider{height:1px;background:var(--ns-outline-var);border:none}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 32px;border-radius:var(--r-full);font-size:1.0625rem;font-weight:700;
  letter-spacing:.02em;
  transition:transform .35s var(--ease-premium),box-shadow .35s var(--ease-premium),background .25s ease,border-color .25s ease,color .25s ease;
  white-space:nowrap;
  position:relative;overflow:hidden;will-change:transform,box-shadow;
}
.btn:active{transform:scale(.96) !important}
.btn-primary{
  background:var(--ns-primary);color:var(--ns-on-primary);
  box-shadow:0 8px 32px -4px rgba(236,13,102,0.3),inset 0 1px 0 rgba(255,255,255,.22);
}
.btn-primary:hover{
  background:#d40b5c;box-shadow:0 12px 40px rgba(236,13,102,0.45),inset 0 1px 0 rgba(255,255,255,.28);
}
.btn-secondary{
  background:var(--ns-surface-container);color:var(--ns-text);
  border:1px solid var(--ns-outline-var);
}
.btn-secondary:hover{
  background:var(--ns-surface-high);border-color:var(--ns-primary);
}
.btn-tonal{
  background:var(--ns-surface-container);color:var(--ns-text-secondary);
}
.btn-tonal:hover{
  background:var(--ns-surface-high);color:var(--ns-text);
}
.btn--sm{padding:10px 22px;font-size:.875rem}
.btn--lg{padding:18px 40px;font-size:1.15rem}
.btn--icon{padding:10px}

/* ============================================================
   LANDING PAGE — HERO
   ============================================================ */

.lp-hero{
  position:relative;overflow:hidden;
  padding-block:clamp(60px,8vw,120px);
}

/* Background radial glows */
.lp-hero::before{
  content:'';position:absolute;top:-15%;left:30%;width:800px;height:600px;
  background:radial-gradient(ellipse,rgba(236,13,102,.1) 0%,transparent 65%);
  pointer-events:none;
}
.lp-hero::after{
  content:'';position:absolute;bottom:-10%;right:-5%;width:600px;height:500px;
  background:radial-gradient(ellipse,rgba(55,66,255,.08) 0%,transparent 65%);
  pointer-events:none;
}

.lp-hero__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-12);align-items:center;
  position:relative;z-index:1;
}

/* Left column */
.lp-hero__content{}

.lp-hero__eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:var(--r-full);
  background:var(--ns-surface-var);border:1px solid var(--ns-outline-var);
  font-size:.8125rem;font-weight:500;color:var(--ns-text-secondary);
  margin-bottom:var(--sp-5);
}
.lp-hero__eyebrow .star{color:var(--ns-one-reel);font-size:1rem}

.lp-hero__title{
  margin-bottom:var(--sp-5);line-height:1.12;
}

.lp-hero__sub{
  font-size:clamp(1rem,1.8vw,1.2rem);color:var(--ns-text-secondary);
  max-width:480px;margin-bottom:var(--sp-8);line-height:1.65;
}

/* Store badge */
.store-badge{
  display:inline-flex;align-items:center;gap:12px;
  padding:12px 22px;border-radius:var(--r-lg);
  background:var(--ns-surface);border:1.5px solid var(--ns-outline-var);
  color:var(--ns-text);font-size:.875rem;font-weight:500;
  transition:background .25s var(--ease-premium),border-color .25s ease,transform .3s var(--ease-premium),box-shadow .3s var(--ease-premium);
  box-shadow:0 2px 8px rgba(0,0,0,.06),inset 0 1px 0 rgba(255,255,255,.06);
}
[data-theme="light"] .store-badge{
  box-shadow:0 2px 10px rgba(0,18,43,.06),inset 0 1px 0 rgba(255,255,255,.95);
}
.store-badge:hover{background:var(--ns-surface-var);border-color:var(--ns-outline);transform:translateY(-3px);box-shadow:0 8px 20px rgba(0,0,0,.1)}
.store-badge__icon{font-size:26px;line-height:1}
.store-badge__text{display:flex;flex-direction:column;text-align:left}
.store-badge__label{font-size:.6875rem;color:var(--ns-text-secondary);letter-spacing:.06em;text-transform:uppercase}
.store-badge__name{font-size:1.0625rem;font-weight:700}

.lp-hero__actions{display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap;margin-bottom:var(--sp-8)}

/* Rating pill */
.rating-pill{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.875rem;color:var(--ns-text-secondary);
}
.rating-stars{color:var(--ns-one-reel);letter-spacing:1px}

/* Trust metrics row */
.trust-row{
  display:flex;align-items:center;gap:var(--sp-6);flex-wrap:wrap;
  padding-top:var(--sp-6);border-top:1px solid var(--ns-outline-var);
}
.trust-item{display:flex;flex-direction:column;gap:2px}
.trust-item__val{
  font-size:1.375rem;font-weight:900;color:var(--ns-text);
  font-family:'Roboto',sans-serif;line-height:1;
}
.trust-item__lbl{font-size:.75rem;color:var(--ns-text-secondary);text-transform:uppercase;letter-spacing:.08em}

/* ── Right column: Phone Mockup ── */
.lp-hero__visual{
  display:flex;justify-content:center;align-items:center;
  position:relative;
}

/* Floating stat chips around phone */
.floating-chip{
  position:absolute;
  display:flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:var(--r-lg);
  background:var(--ns-surface);border:1px solid var(--ns-outline-var);
  font-size:.8125rem;font-weight:600;color:var(--ns-text);
  box-shadow:0 8px 32px rgba(0,0,0,.4);
  white-space:nowrap;z-index:10;
}
.fc-1{top:8%;right:-8%;animation:chipFloat 4s ease-in-out infinite}
.fc-2{bottom:18%;left:-10%;animation:chipFloat 4s ease-in-out infinite .8s}
.fc-3{top:45%;right:-12%;animation:chipFloat 4s ease-in-out infinite 1.6s}

@keyframes chipFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}

/* ── CSS Phone Mockup ── */
.phone-frame{
  position:relative;width:256px;flex-shrink:0;
  filter:drop-shadow(0 40px 80px rgba(0,0,0,.6))
         drop-shadow(0 0 60px rgba(236,13,102,.12));
}

.phone-shell{
  background:linear-gradient(160deg,#1c2e50,#0d1929);
  border-radius:46px;
  border:1.5px solid rgba(255,255,255,.13);
  padding:11px;
  position:relative;
}
.phone-shell::before{/* side buttons */
  content:'';position:absolute;
  left:-3px;top:90px;width:3px;height:36px;
  background:linear-gradient(160deg,#1c2e50,#0d1929);
  border-radius:2px 0 0 2px;
  box-shadow:-2px 0 0 rgba(255,255,255,.08);
}

.phone-screen{
  background:#000;border-radius:36px;overflow:hidden;
  display:flex;flex-direction:column;
  aspect-ratio: 9 / 19.5; /* Matches modern phone aspect ratios */
}

.phone-screen-img{
  width:100%;height:100%;object-fit:cover;
  display:block;
}

/* App UI area */
.app-ui{padding:10px 12px;display:flex;flex-direction:column;gap:10px;flex:1;background:var(--ns-bg)}

.app-header{display:flex;justify-content:space-between;align-items:flex-start}

.app-title-row{display:flex;align-items:center;gap:5px;margin-bottom:2px}
.app-title-text{font-size:18px;font-weight:900;color:var(--ns-text);letter-spacing:-.02em}

.app-premium{
  display:inline-flex;align-items:center;gap:2px;
  padding:2px 7px;border-radius:var(--r-full);
  background:linear-gradient(135deg,#7C3AED,var(--ns-primary));
  color:#fff;font-size:7.5px;font-weight:700;letter-spacing:.06em;
}

.app-subtitle-text{font-size:9.5px;color:rgba(225,228,243,.65);display:block}

.app-bell{position:relative;width:26px;height:26px;font-size:14px;display:flex;align-items:center;justify-content:center}
.app-bell-badge{
  position:absolute;top:-2px;right:-2px;
  width:13px;height:13px;border-radius:50%;
  background:var(--ns-primary);color:#fff;font-size:7px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}

/* Active plan card */
.active-plan-card{
  background:linear-gradient(150deg,rgba(90,35,5,.55),rgba(7,34,72,.97));
  border:1px solid rgba(255,152,0,.28);border-radius:18px;padding:12px;
}
.plan-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}

.active-pill{
  display:inline-flex;align-items:center;gap:4px;
  background:rgba(76,175,80,.18);border:1px solid rgba(76,175,80,.3);
  color:var(--ns-success);font-size:8px;font-weight:700;
  padding:2px 8px;border-radius:var(--r-full);letter-spacing:.07em;
}
.active-dot{width:5px;height:5px;border-radius:50%;background:var(--ns-success);box-shadow:0 0 5px var(--ns-success);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.4)}}

.pause-btn{
  width:26px;height:26px;border-radius:50%;
  background:var(--ns-surface);display:flex;align-items:center;justify-content:center;
  font-size:10px;color:var(--ns-text);
}

.plan-icon-ring{
  width:52px;height:52px;border-radius:50%;
  border:2.5px solid var(--ns-one-reel);
  background:rgba(255,152,0,.15);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 8px;font-size:22px;
  box-shadow:0 0 18px rgba(255,152,0,.28);
}
.plan-name-text{font-size:14px;font-weight:700;color:var(--ns-text);text-align:center;margin-bottom:1px}
.plan-tagline-text{font-size:8.5px;color:rgba(225,228,243,.65);text-align:center;margin-bottom:10px}

.plan-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px}
.plan-stat{
  background:var(--ns-surface);border-radius:10px;padding:5px 4px;
  display:flex;flex-direction:column;align-items:center;gap:1px;
}
.plan-stat-val{font-size:11px;font-weight:700;color:var(--ns-text)}
.plan-stat-lbl{font-size:7px;color:rgba(225,228,243,.6);text-align:center}

/* Plan selector */
.select-plan-label{font-size:7.5px;font-weight:700;letter-spacing:.12em;color:rgba(225,228,243,.55);text-transform:uppercase}
.plan-chips-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:5px}
.plan-chip{
  background:var(--ns-surface);border:1px solid var(--ns-outline-var);border-radius:12px;
  padding:7px 4px;display:flex;flex-direction:column;align-items:center;gap:3px;
}
.plan-chip-icon{font-size:16px}
.plan-chip-name{font-size:7.5px;color:var(--ns-text-secondary);font-weight:500}
.plan-chip--selected{background:rgba(255,152,0,.12);border-color:rgba(255,152,0,.4)}
.plan-chip--selected .plan-chip-name{color:var(--ns-one-reel);font-weight:700}
.plan-chip-bar{width:16px;height:2px;background:var(--ns-one-reel);border-radius:var(--r-full);margin-top:2px}

/* Doom section */
.doom-label{font-size:7.5px;font-weight:700;letter-spacing:.12em;color:rgba(225,228,243,.55);text-transform:uppercase}
.featured-row{
  display:flex;justify-content:space-between;align-items:center;
  background:var(--ns-surface);border-radius:12px;padding:7px 10px;
}
.featured-row-title{font-size:10px;font-weight:700;color:var(--ns-text)}
.featured-count{
  background:var(--ns-surface-var);color:var(--ns-text-secondary);
  font-size:8px;font-weight:700;padding:2px 7px;border-radius:var(--r-full);
}

/* App bottom nav */
.app-bottom-nav{
  display:grid;grid-template-columns:1fr 1fr 1fr;
  background:var(--ns-surface);border-top:1px solid var(--ns-outline-var);
  padding:10px 8px 14px;margin-top:auto;
}
.nav-tab{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:8px;color:rgba(225,228,243,.5)}
.nav-tab-active{font-size:8px;font-weight:600;color:var(--ns-text)}
.nav-tab-icon{
  font-size:16px;padding:5px 16px;border-radius:var(--r-full);
  background:transparent;
}
.nav-tab-active .nav-tab-icon{background:var(--ns-one-reel);font-size:14px;color:#fff}

.phone-home-bar{width:60px;height:5px;background:rgba(255,255,255,.2);border-radius:var(--r-full);margin:8px auto 3px}

/* ============================================================
   BLOCKED APPS MARQUEE STRIP
   ============================================================ */

.apps-marquee-section{
  border-block:1px solid var(--ns-outline-var);
  padding-block:var(--sp-5);overflow:hidden;
  background:var(--ns-surface);
}
.apps-marquee-inner{position:relative}
.apps-marquee-inner::before,.apps-marquee-inner::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.apps-marquee-inner::before{left:0;background:linear-gradient(90deg,var(--ns-surface),transparent)}
.apps-marquee-inner::after{right:0;background:linear-gradient(-90deg,var(--ns-surface),transparent)}

.apps-marquee-track{
  display:flex;gap:var(--sp-4);width:max-content;
  animation:marquee 28s linear infinite;
}
.apps-marquee-track:hover{animation-play-state:paused}

@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.app-pill{
  display:flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:var(--r-full);
  background:var(--ns-bg);border:1px solid var(--ns-outline-var);
  font-size:.8125rem;font-weight:500;color:var(--ns-text-secondary);
  white-space:nowrap;flex-shrink:0;
}
.app-pill__icon{font-size:18px}

/* ============================================================
   PROBLEM STATS SECTION
   ============================================================ */

.lp-problem{
  padding-block:var(--sp-16);
  background:linear-gradient(135deg,rgba(236,13,102,.05),rgba(55,66,255,.05));
  border-block:1px solid var(--ns-outline-var);
}
.problem-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4)}

.problem-stat{
  background:var(--ns-surface);border:1px solid var(--ns-outline-var);border-radius:var(--r-xl);
  padding:var(--sp-6) var(--sp-5);text-align:center;
  transition:border-color .2s,transform .2s;
}
.problem-stat:hover{border-color:var(--ns-outline);transform:translateY(-3px)}
.problem-stat__num{
  font-size:clamp(2rem,4vw,3rem);font-weight:900;line-height:1;
  margin-bottom:4px;display:block;
}
.problem-stat__lbl{font-size:.8125rem;color:var(--ns-text-secondary);line-height:1.45}

/* ============================================================
   PLANS SECTION
   ============================================================ */

.lp-plans{padding-block:clamp(60px,7vw,100px);position:relative}

.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6);margin-top:var(--sp-12)}

.plan-card{
  position:relative;overflow:hidden;
  background:var(--ns-surface-low);border:1px solid var(--ns-outline-var);border-radius:var(--r-2xl);
  padding:var(--sp-8);
  transition:var(--transition);
  display:flex;flex-direction:column;
}
.plan-card:hover{
  background:var(--ns-surface-container);
  transform:translateY(-8px);box-shadow:var(--shadow-3);
  border-color:var(--ns-primary);
}

.plan-card--curious{--pc:var(--ns-curious)}
.plan-card--blockall{--pc:var(--ns-block-all)}
.plan-card--onereel{--pc:var(--ns-one-reel)}

/* popular badge */
.plan-popular{
  position:absolute;top:var(--sp-5);right:var(--sp-5);
  background:var(--ns-primary);color:#fff;
  font-size:.65rem;font-weight:900;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 12px;border-radius:var(--r-full);
  box-shadow:0 4px 12px rgba(236,13,102,0.3);
}

.plan-card__icon{
  width:64px;height:64px;border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;font-size:28px;
  background:var(--ns-surface-container);
  margin-bottom:var(--sp-6);transition:var(--transition);
  border:1px solid var(--ns-outline-var);
}
.plan-card:hover .plan-card__icon{
  transform:scale(1.1) rotate(5deg);
  background:var(--ns-surface-high);
  border-color:var(--pc);
}

.plan-card__name{
  font-size:1.75rem;font-weight:900;color:var(--ns-text);
  margin-bottom:6px;
}
.plan-card__tagline{font-size:.9375rem;color:var(--ns-text-secondary);margin-bottom:var(--sp-6);line-height:1.6}

.plan-card__features{display:flex;flex-direction:column;gap:12px;margin-bottom:var(--sp-8);flex:1}
.plan-feature{display:flex;align-items:flex-start;gap:12px;font-size:.9375rem;color:var(--ns-text-secondary);font-weight:500}
.plan-feature-check{
  width:20px;height:20px;border-radius:50%;flex-shrink:0;margin-top:2px;
  background:rgba(177,244,175,0.15);display:flex;align-items:center;justify-content:center;
  font-size:10px;color:var(--ns-success);
}
.plan-card__cta{display:flex;width:100%}

/* ============================================================
   FEATURES BENTO GRID
   ============================================================ */

.lp-features{
  padding-block:clamp(60px,7vw,100px);
  background:var(--ns-surface);border-block:1px solid var(--ns-outline-var);
}
.bento-grid{
  display:grid;grid-template-columns:repeat(12,1fr);
  gap:var(--sp-4);margin-top:var(--sp-10);
}
.bento-card{
  background:var(--ns-surface-low);border:1px solid var(--ns-outline-var);border-radius:var(--r-2xl);
  padding:var(--sp-8);overflow:hidden;
  transition:var(--transition);
  position:relative;
}
.bento-card::after {
  content: ''; position: absolute; inset: 0; background: radial-gradient(circle at top left, rgba(255,255,255,0.03), transparent); pointer-events: none;
}
.bento-card:hover{
  background:var(--ns-surface-container);
  border-color:rgba(236,13,102,0.3);
  transform:translateY(-6px);box-shadow:var(--shadow-3);
}

.b-5 {grid-column:span 5}
.b-7 {grid-column:span 7}
.b-4 {grid-column:span 4}
.b-8 {grid-column:span 8}
.b-6 {grid-column:span 6}
.b-12{grid-column:span 12}
.b-3 {grid-column:span 3}

.bento-card__emoji{font-size:2.5rem;margin-bottom:var(--sp-4)}
.bento-card__title{font-size:1.35rem;font-weight:800;margin-bottom:8px;color:var(--ns-text)}
.bento-card__body{font-size:1rem;color:var(--ns-text-secondary);line-height:1.7}

/* Big stat inside bento */
.bento-stat{font-size:clamp(2.5rem,5vw,4.5rem);font-weight:900;line-height:1;margin-bottom:6px}

/* Website restriction chip mockup inside bento */
.url-chip{
  display:flex;align-items:center;gap:8px;
  padding:7px 12px;background:var(--ns-surface);
  border:1px solid var(--ns-outline-var);border-radius:10px;
  font-size:.75rem;font-family:'Roboto Mono',monospace;
}
.url-chip-icon{font-size:14px}
.url-chip-url{flex:1;color:var(--ns-text)}
.url-chip-badge{
  font-size:.625rem;font-weight:700;padding:2px 8px;border-radius:var(--r-full);
  background:rgba(76,175,80,.18);color:var(--ns-success);
}

/* Privacy badge */
.privacy-badges{display:flex;flex-direction:column;gap:8px;margin-top:var(--sp-4)}
.privacy-badge{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;background:var(--ns-surface-var);border-radius:var(--r-lg);
  font-size:.8125rem;color:var(--ns-text-secondary);
}
.privacy-badge-icon{font-size:18px;flex-shrink:0}

/* ============================================================
   HOW IT WORKS
   ============================================================ */

.lp-how{padding-block:clamp(60px,7vw,100px)}

.steps-wrapper{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-16);align-items:center;
  margin-top:var(--sp-10);
}

.steps-list{display:flex;flex-direction:column;gap:4px}
.step-item{
  display:flex;gap:var(--sp-5);padding:var(--sp-5) var(--sp-4);
  border-radius:var(--r-xl);cursor:default;
  transition:background .25s;
  border-left:3px solid transparent;
}
.step-item:hover{background:var(--ns-surface);border-left-color:var(--ns-primary)}

.step-num{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:var(--ns-surface-var);border:2px solid var(--ns-outline-var);
  display:flex;align-items:center;justify-content:center;
  font-size:.875rem;font-weight:700;color:var(--ns-primary);
  font-family:'Roboto Mono',monospace;
  transition:background .25s,border-color .25s;
}
.step-item:hover .step-num{background:rgba(236,13,102,.12);border-color:var(--ns-primary)}
.step-content h4{margin-bottom:4px}
.step-content p{font-size:.875rem}

/* How-it-works visual */
.how-visual{
  background:var(--ns-surface);border:1px solid var(--ns-outline-var);
  border-radius:var(--r-2xl);padding:var(--sp-6);
  display:flex;flex-direction:column;gap:var(--sp-3);
}
.how-visual-step{
  display:flex;align-items:center;gap:var(--sp-4);
  padding:var(--sp-4) var(--sp-4);background:var(--ns-bg);
  border-radius:var(--r-lg);border:1px solid var(--ns-outline-var);
}
.how-visual-step-num{
  width:32px;height:32px;border-radius:50%;background:var(--ns-surface-var);
  display:flex;align-items:center;justify-content:center;font-size:.75rem;
  font-weight:700;color:var(--ns-primary);flex-shrink:0;
}
.how-visual-step-text{font-size:.8125rem;font-weight:500;color:var(--ns-text)}
.how-visual-step-icon{margin-left:auto;font-size:18px}

/* ============================================================
   WHATS NEW — v2.0
   ============================================================ */

.lp-v2{
  padding-block:clamp(60px,7vw,100px);
  background:var(--ns-surface-var);border-block:1px solid var(--ns-outline-var);
}
.v2-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-12);align-items:center;margin-top:var(--sp-10)}

.v2-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:var(--r-full);
  background:rgba(236,13,102,.15);border:1px solid rgba(236,13,102,.3);
  color:var(--ns-primary);font-size:.8125rem;font-weight:600;
  margin-bottom:var(--sp-5);
}
.v2-features-list{
  display:flex;flex-direction:column;gap:var(--sp-3);margin-top:var(--sp-6);
}
.v2-feature{
  display:flex;align-items:center;gap:var(--sp-3);
  padding:var(--sp-3) var(--sp-4);background:var(--ns-surface);
  border-radius:var(--r-lg);border:1px solid var(--ns-outline-var);
  font-size:.875rem;font-weight:500;color:var(--ns-text);
  transition:border-color .2s,transform .2s;
}
.v2-feature:hover{border-color:var(--ns-outline);transform:translateX(4px)}
.v2-feature-icon{font-size:18px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);background:var(--ns-surface-var);flex-shrink:0}

/* Second phone mockup for v2 section */
.v2-phone{
  display:flex;justify-content:flex-end;position:relative;
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */

.lp-reviews{padding-block:clamp(60px,7vw,100px)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5);margin-top:var(--sp-10)}

.review-card{
  background:var(--ns-surface);border:1px solid var(--ns-outline-var);
  border-radius:var(--r-xl);padding:var(--sp-6);
  transition:border-color .2s,transform .2s;
}
.review-card:hover{border-color:var(--ns-outline);transform:translateY(-3px)}

.review-stars{color:var(--ns-one-reel);font-size:.875rem;letter-spacing:2px;margin-bottom:var(--sp-4)}
.review-quote{
  font-size:.9375rem;color:var(--ns-text);line-height:1.65;
  margin-bottom:var(--sp-5);font-style:italic;
}
.review-author{display:flex;align-items:center;gap:var(--sp-3)}
.review-avatar{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  background:var(--ns-surface-var);display:flex;align-items:center;justify-content:center;font-size:16px;
}
.review-name{font-size:.875rem;font-weight:700;color:var(--ns-text)}
.review-handle{font-size:.75rem;color:var(--ns-text-secondary)}
.review-plan{
  display:inline-block;font-size:.6875rem;font-weight:700;
  padding:2px 8px;border-radius:var(--r-full);margin-top:3px;
}
.review-plan--curious {background:rgba(66,110,255,.18);color:var(--ns-curious)}
.review-plan--blockall{background:rgba(255,87,34,.18);color:var(--ns-block-all)}
.review-plan--onereel {background:rgba(255,152,0,.18);color:var(--ns-one-reel)}

/* ============================================================
   BLOG POSTS
   ============================================================ */

.lp-blog{
  padding-block:clamp(60px,7vw,100px);
  background:var(--ns-surface);border-top:1px solid var(--ns-outline-var);
}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5);margin-top:var(--sp-8)}

.post-card{
  background:var(--ns-bg);border:1px solid var(--ns-outline-var);
  border-radius:var(--r-xl);overflow:hidden;
  transition:border-color .2s,transform .2s,box-shadow .2s;
}
.post-card:hover{border-color:var(--ns-outline);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.35)}

.post-card__thumb{aspect-ratio:16/9;background:var(--ns-surface-var);overflow:hidden}
.post-card__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post-card:hover .post-card__thumb img{transform:scale(1.04)}

.post-card__body{padding:var(--sp-5)}
.post-card__cat{font-size:.6875rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ns-primary);margin-bottom:8px}
.post-card__title{font-size:1rem;font-weight:700;color:var(--ns-text);line-height:1.4;margin-bottom:8px}
.post-card__title a{color:inherit;transition:color .2s}
.post-card__title a:hover{color:var(--ns-primary)}
.post-card__excerpt{font-size:.8125rem;color:var(--ns-text-secondary);margin-bottom:var(--sp-4);line-height:1.6}
.post-card__meta{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--ns-text-secondary)}
.post-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--ns-outline)}

/* ============================================================
   CTA SECTION
   ============================================================ */

.lp-cta{padding-block:clamp(60px,7vw,100px)}
.cta-wrap{
  text-align:center;
  background:var(--ns-surface);border:1px solid var(--ns-outline-var);
  border-radius:28px;padding:clamp(40px,6vw,80px) var(--sp-6);
  position:relative;overflow:hidden;
}
.cta-wrap::before{
  content:'';position:absolute;top:-30%;left:50%;transform:translateX(-50%);
  width:700px;height:500px;
  background:radial-gradient(ellipse,rgba(236,13,102,.1),transparent 65%);
  pointer-events:none;
}
.cta-wrap::after{
  content:'';position:absolute;bottom:-20%;right:10%;
  width:400px;height:300px;
  background:radial-gradient(ellipse,rgba(55,66,255,.08),transparent 65%);
  pointer-events:none;
}
.cta-wrap>*{position:relative;z-index:1}
.cta-wrap h2{margin-bottom:var(--sp-4)}
.cta-wrap>p{max-width:480px;margin:0 auto var(--sp-8)}
.cta-actions{display:flex;align-items:center;justify-content:center;gap:var(--sp-4);flex-wrap:wrap}

/* ============================================================
   BADGES & MISC
   ============================================================ */

.badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:var(--r-full);
  font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
}
.pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 16px;border-radius:var(--r-full);
  font-size:.7rem;font-weight:700;
}
.pill--primary { background:var(--ns-primary-container); color:var(--ns-on-primary-container)}

.badge--active{
  background:rgba(177,244,175,0.12);color:var(--ns-success);border:1px solid rgba(177,244,175,0.2);
}
.badge--active::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--ns-success);box-shadow:0 0 10px var(--ns-success);
  animation:pulse 2s ease-in-out infinite;
}
.badge--premium{background:linear-gradient(135deg,#7C3AED,var(--ns-primary));color:#fff;padding:6px 16px}
.section-eyebrow{
  font-size:.75rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;
  color:var(--ns-primary);display:block;margin-bottom:var(--sp-4);
}

/* ============================================================
   BLOG / SINGLE POST CONTENT
   ============================================================ */

.page-hero{padding-block:var(--sp-16) var(--sp-10);border-bottom:1px solid var(--ns-outline-var)}
.page-hero__eyebrow{font-size:.875rem;font-weight:700;color:var(--ns-primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--sp-3)}
.page-hero__title{margin-bottom:var(--sp-4)}
.page-hero__subtitle{color:var(--ns-text-secondary);font-size:1.125rem;max-width:560px}

.post-hero{padding-block:var(--sp-12);background:var(--ns-surface);border-bottom:1px solid var(--ns-outline-var)}
.post-category{font-size:.875rem;font-weight:700;color:var(--ns-primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--sp-4)}
.post-meta{display:flex;align-items:center;justify-content:center;gap:var(--sp-4);flex-wrap:wrap;color:var(--ns-text-secondary);font-size:.875rem}

.entry-content{max-width:720px;margin-inline:auto;padding-block:var(--sp-10)}
.entry-content p{margin-bottom:var(--sp-5)}
.entry-content h2{margin-top:var(--sp-10);margin-bottom:var(--sp-4)}
.entry-content h3{margin-top:var(--sp-8);margin-bottom:var(--sp-3)}
.entry-content ul,.entry-content ol{padding-left:var(--sp-6);margin-bottom:var(--sp-5)}
.entry-content li{margin-bottom:var(--sp-2);color:var(--ns-text-secondary)}
.entry-content a{color:var(--ns-primary);text-decoration:underline;text-decoration-color:rgba(236,13,102,.3)}
.entry-content a:hover{text-decoration-color:var(--ns-primary)}
.entry-content code{font-family:'Roboto Mono',monospace;font-size:.9em;background:var(--ns-surface-var);padding:2px 6px;border-radius:var(--r-xs);color:var(--ns-one-reel)}
.entry-content pre{background:var(--ns-surface-var);border:1px solid var(--ns-outline-var);border-radius:var(--r-lg);padding:var(--sp-6);overflow-x:auto;margin-bottom:var(--sp-5)}
.entry-content pre code{background:none;padding:0;color:var(--ns-text)}
.entry-content blockquote{border-left:3px solid var(--ns-primary);padding-left:var(--sp-5);margin-block:var(--sp-6);color:var(--ns-text-secondary);font-style:italic}
.entry-content img{border-radius:var(--r-lg);margin-block:var(--sp-5)}

.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--ns-text-secondary);margin-bottom:var(--sp-6)}
.breadcrumb a{color:var(--ns-text-secondary);transition:color .2s}
.breadcrumb a:hover{color:var(--ns-text)}
.breadcrumb__sep{color:var(--ns-outline)}

/* ============================================================
   DOCS
   ============================================================ */

.docs-layout{display:grid;grid-template-columns:240px 1fr;gap:var(--sp-10);align-items:start;padding-block:var(--sp-10)}
.docs-sidebar{position:sticky;top:80px}
.docs-nav__section{margin-bottom:var(--sp-5)}
.docs-nav__section-title{font-size:.6875rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ns-text-secondary);padding:var(--sp-2) var(--sp-3);margin-bottom:2px}
.docs-nav__link{display:block;padding:var(--sp-2) var(--sp-3);border-radius:var(--r-md);font-size:.875rem;color:var(--ns-text-secondary);transition:background .2s,color .2s;border-left:2px solid transparent}
.docs-nav__link:hover{background:var(--ns-surface);color:var(--ns-text)}
.docs-nav__link.is-active{background:var(--ns-surface-var);color:var(--ns-primary);border-left-color:var(--ns-primary)}

/* ============================================================
   SUPPORT
   ============================================================ */

.support-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--sp-4);margin-top:var(--sp-8)}
.support-card{background:var(--ns-surface);border:1px solid var(--ns-outline-var);border-radius:var(--r-xl);padding:var(--sp-6);transition:border-color .2s,transform .2s}
.support-card:hover{border-color:var(--ns-primary);transform:translateY(-2px)}
.support-card__icon{font-size:1.875rem;margin-bottom:var(--sp-4)}
.support-card__title{font-size:1.0625rem;font-weight:700;margin-bottom:6px}
.support-card__body{font-size:.875rem;color:var(--ns-text-secondary)}

.faq-list{display:flex;flex-direction:column;gap:8px;margin-top:var(--sp-8)}
.faq-item{background:var(--ns-surface);border:1px solid var(--ns-outline-var);border-radius:var(--r-lg);overflow:hidden}
.faq-item__question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--sp-5) var(--sp-6);font-size:1rem;font-weight:500;color:var(--ns-text);text-align:left;transition:background .2s}
.faq-item__question:hover{background:var(--ns-surface-var)}
.faq-item__chevron{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--ns-outline);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .25s,border-color .2s;color:var(--ns-text-secondary);font-size:12px}
.faq-item.is-open .faq-item__chevron{transform:rotate(180deg);border-color:var(--ns-primary);color:var(--ns-primary)}
.faq-item__answer{display:none;padding:0 var(--sp-6) var(--sp-5);font-size:.875rem;color:var(--ns-text-secondary);line-height:1.7}
.faq-item.is-open .faq-item__answer{display:block}

/* ============================================================
   FOOTER
   ============================================================ */

.site-footer{
  background:var(--ns-surface);
  border-top:1px solid var(--ns-outline-var);
  padding-top:var(--sp-16);padding-bottom:var(--sp-8);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
[data-theme="light"] .site-footer{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.88);
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--sp-10);margin-bottom:var(--sp-12)}
.footer-brand__tagline{font-size:.875rem;color:var(--ns-text-secondary);margin-top:var(--sp-3);margin-bottom:var(--sp-5);max-width:220px;line-height:1.65}
.footer-social{display:flex;gap:var(--sp-3)}
.social-btn{width:34px;height:34px;border-radius:var(--r-md);background:var(--ns-surface-var);border:1px solid var(--ns-outline-var);display:flex;align-items:center;justify-content:center;color:var(--ns-text-secondary);font-size:15px;transition:background .2s,color .2s,border-color .2s}
.social-btn:hover{background:var(--ns-primary);color:#fff;border-color:transparent}
.footer-col__title{font-size:.6875rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ns-text-secondary);margin-bottom:var(--sp-4)}
.footer-col__links{display:flex;flex-direction:column;gap:8px}
.footer-col__link{font-size:.875rem;color:var(--ns-text-secondary);transition:color .2s}
.footer-col__link:hover{color:var(--ns-text)}
.footer-col ul.footer-col__links{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col ul.footer-col__links a{font-size:.875rem;color:var(--ns-text-secondary);transition:color .2s;text-decoration:none}
.footer-col ul.footer-col__links a:hover{color:var(--ns-text)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-4);padding-top:var(--sp-6);border-top:1px solid var(--ns-outline-var);font-size:.75rem;color:var(--ns-text-secondary)}
.footer-bottom .ns-footer-credit{color:inherit;text-decoration:underline;text-underline-offset:2px}
.footer-bottom .ns-footer-credit:hover{color:var(--ns-text)}

/* ============================================================
   FORMS & INPUTS
   ============================================================ */

input[type=text],input[type=email],input[type=search],input[type=url],textarea,select{
  width:100%;padding:12px 16px;background:var(--ns-surface-var);
  border:1.5px solid var(--ns-outline-var);border-radius:var(--r-lg);
  color:var(--ns-text);font-size:1rem;transition:border-color .2s,box-shadow .2s;outline:none;
}
input:focus,textarea:focus,select:focus{border-color:var(--ns-primary);box-shadow:0 0 0 3px rgba(236,13,102,.15)}
label{display:block;font-size:.875rem;font-weight:500;margin-bottom:8px;color:var(--ns-text-secondary)}

/* ============================================================
   PAGINATION
   ============================================================ */

.pagination,.nav-links{display:flex;align-items:center;justify-content:center;gap:8px;padding-block:var(--sp-8)}
.page-numbers,.nav-links a,.nav-links span{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding-inline:var(--sp-3);border-radius:var(--r-md);font-size:.875rem;font-weight:500;color:var(--ns-text-secondary);background:var(--ns-surface);border:1px solid var(--ns-outline-var);transition:background .2s,border-color .2s,color .2s}
.page-numbers:hover,.nav-links a:hover{background:var(--ns-surface-var);border-color:var(--ns-outline);color:var(--ns-text)}
.page-numbers.current{background:var(--ns-primary);border-color:transparent;color:#fff}

/* ============================================================
   404
   ============================================================ */
.not-found-section{min-height:62vh;display:flex;align-items:center}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media(max-width:1100px){
  .lp-hero__grid{grid-template-columns:1fr 1fr;gap:var(--sp-8)}
  .plans-grid{grid-template-columns:1fr;max-width:520px;margin-inline:auto}
  .problem-grid{grid-template-columns:repeat(2,1fr)}
  .b-5{grid-column:span 6}.b-7{grid-column:span 6}.b-4{grid-column:span 6}.b-8{grid-column:span 6}.b-3{grid-column:span 4}
  .footer-grid{grid-template-columns:1fr 1fr}
  .docs-layout{grid-template-columns:200px 1fr}
  .v2-grid{grid-template-columns:1fr}
  .steps-wrapper{grid-template-columns:1fr}
}

@media(max-width:900px){
  .lp-hero__grid{grid-template-columns:1fr;text-align:center}
  .lp-hero__sub{margin-inline:auto}
  .lp-hero__actions{justify-content:center}
  .trust-row{justify-content:center}
  .lp-hero__visual{order:-1}
  .fc-1,.fc-2,.fc-3{display:none}
  .reviews-grid{grid-template-columns:1fr}
}

@media(max-width:768px){
  /* PHP fallback header: hide desktop menu + primary CTA; block header uses core Navigation overlay on small screens */
  .site-nav,.site-header__actions .btn{display:none}
  .hamburger{display:flex}
  .site-header .site-header-nav.wp-block-navigation,
  .site-header__nav-wrap {display:none}
  .bento-grid{grid-template-columns:1fr}
  .b-5,.b-7,.b-4,.b-8,.b-6,.b-3{grid-column:span 12}
  .blog-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .docs-layout{grid-template-columns:1fr}
  .docs-sidebar{position:static}
  .footer-bottom{flex-direction:column;text-align:center}
  .plans-grid{grid-template-columns:1fr}
}

@media(max-width:400px){
  .container{padding-inline:var(--sp-3)}
}
@media(max-width:540px){
  .container{padding-inline:var(--sp-4)}
  .problem-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .cta-actions{flex-direction:column;align-items:stretch}
  .store-badge{justify-content:center}
  .lp-hero__actions{flex-direction:column;align-items:stretch}
}

/* ── Feature Focus Grid ── */
.v2-grid{display:grid;grid-template-columns:1.2fr 1.1fr;gap:var(--sp-12);align-items:center}
.v2-grid--reverse{grid-template-columns:1.1fr 1.2fr}
.v2-grid--reverse > div:first-child{order:2}
.v2-grid--reverse > div:last-child{order:1}

.how-visual{
  display:flex;justify-content:center;align-items:center;position:relative;
}

@media(max-width:991px){
  .v2-grid, .v2-grid--reverse{
    grid-template-columns:1fr;text-align:center;gap:var(--sp-8);
  }
  .v2-grid--reverse > div:first-child{order:1}
  .v2-grid--reverse > div:last-child{order:2}
  .v2-grid p{max-width:520px;margin-inline:auto}
  .v2-grid .feature-checks{justify-content:center;text-align:left;max-width:max-content;margin-inline:auto}
}
