/* ============================================
   SWEET PARADISE — Light Pink VR Design System
   ============================================ */

:root{
  /* Surfaces */
  --cream:#FFF6FB;
  --paper:#FFEEF6;
  --paper-2:#FFE0EE;
  --rose-soft:#FFD1E3;

  /* Brand */
  --pink:#FF2DA0;
  --pink-deep:#E91E91;
  --pink-2:#FF6BC1;
  --pink-3:#FFB3DC;
  --violet:#9333EA;
  --violet-2:#C084FC;

  /* Ink */
  --ink:#2A0820;        /* primary text */
  --ink-2:#5A2545;      /* secondary text */
  --ink-3:#8A4A6E;      /* muted text */

  /* Lines */
  --line:rgba(255,45,160,.14);
  --line-strong:rgba(255,45,160,.28);
  --line-dark:rgba(42,8,32,.10);

  /* Fonts */
  --display:'Space Grotesk', system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
section[id]{scroll-margin-top:88px}
html,body{
  color:var(--ink);
  font-family:var(--display);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -webkit-text-size-adjust:100%;
  overflow-x:hidden;
}
body{
  min-height:100vh;
  background:
    radial-gradient(60% 50% at 12% 8%, rgba(255,107,193,.20), transparent 60%),
    radial-gradient(50% 40% at 92% 22%, rgba(192,132,252,.18), transparent 60%),
    linear-gradient(180deg, #FFF6FB 0%, #FFEEF6 50%, #FFE0EE 100%);
}

/* ===== Global shader backdrop (page-wide aurora) ===== */
.page-shader{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  width:100vw;height:100vh;
  opacity:0;transition:opacity 1.2s ease;
  filter:blur(24px) saturate(1.1);
  transform:scale(1.08);   /* hide blur edges */
}
.page-shader.ready{opacity:.55}
/* Soft cream wash over the shader so content is comfortable to read */
.page-shader-scrim{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(80% 60% at 50% 50%, rgba(255,246,251,.78) 0%, rgba(255,246,251,.55) 50%, rgba(255,246,251,.32) 100%),
    linear-gradient(180deg, rgba(255,246,251,.20) 0%, rgba(255,246,251,0) 30%, rgba(255,246,251,0) 70%, rgba(255,246,251,.45) 100%);
}
@media (max-width: 720px){
  .page-shader.ready{opacity:.30}                 /* very subtle on mobile */
  .page-shader-scrim{background:rgba(255,246,251,.82)}
}
/* Everything that's not the shader sits above it */
.nav, .hero, .section, footer, .foot-bar, .mobile-menu, .menu-backdrop, .cursor-fx{position:relative;z-index:2}
.mobile-menu, .menu-backdrop, .cursor-fx{z-index:95}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

/* ---------- NAV ---------- */
.nav{
  position:sticky;top:0;z-index:90;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;
  backdrop-filter:blur(14px);
  background:rgba(255,246,251,.78);
  border-bottom:1px solid var(--line);
  transition:background .3s, box-shadow .3s, border-color .3s, padding .3s;
}
.nav.scrolled{
  background:rgba(255,246,251,.92);
  box-shadow:0 8px 30px rgba(255,45,160,.12);
  border-bottom-color:var(--line-strong);
  padding-top:13px;padding-bottom:13px;
}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.brand-mark{
  width:40px;height:40px;border-radius:12px;
  background:radial-gradient(120% 120% at 30% 20%, #fff 0%, var(--cream) 70%, var(--rose-soft) 100%);
  display:grid;place-items:center;
  box-shadow:0 6px 20px rgba(255,45,160,.22), inset 0 1px 0 rgba(255,255,255,.7);
  border:1px solid var(--line-strong);
  overflow:hidden;
  transition:transform .35s cubic-bezier(.22,.61,.36,1), box-shadow .35s;
}
.brand:hover .brand-mark{transform:translateY(-1px) rotate(-3deg) scale(1.05);box-shadow:0 10px 28px rgba(255,45,160,.32)}
.brand-mark img{width:24px;height:30px;object-fit:contain;filter:drop-shadow(0 1px 1px rgba(131,5,85,.18))}
.brand .name{font-size:18px}
.brand .name b{color:var(--ink)}
.brand .name em{font-style:normal;color:var(--pink-deep);font-weight:500}

.nav-links{display:flex;align-items:center;gap:28px;font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase}
.nav-links a{color:var(--ink-2);transition:color .2s;position:relative}
.nav-links a:hover{color:var(--pink-deep)}
.nav-links a.active{color:var(--pink-deep)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--pink);border-radius:1px}

.nav .cta{
  padding:11px 20px;border-radius:999px;
  background:linear-gradient(135deg, var(--pink), var(--violet));
  color:#fff;
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  box-shadow:0 8px 24px rgba(255,45,160,.35), inset 0 1px 0 rgba(255,255,255,.3);
  transition:transform .2s, box-shadow .2s;
}
.nav .cta:hover{transform:translateY(-1px);box-shadow:0 12px 32px rgba(255,45,160,.5)}

/* ---------- COMMON TYPE ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--pink-deep);
  padding:8px 14px;border:1px solid var(--line-strong);border-radius:999px;
  background:rgba(255,255,255,.6);
  backdrop-filter:blur(8px);
}
.eyebrow .dot{width:6px;height:6px;background:var(--pink);border-radius:50%;box-shadow:0 0 10px var(--pink);animation:blink 1.6s infinite}
@keyframes blink{50%{opacity:.35}}

.h-display{font-size:clamp(48px,7vw,108px);line-height:.94;font-weight:700;letter-spacing:-.035em;text-wrap:balance;color:var(--ink)}
.h-section{font-size:clamp(40px,5vw,72px);line-height:.96;letter-spacing:-.025em;font-weight:700;text-wrap:balance;color:var(--ink)}
.h-card{font-size:24px;line-height:1.1;letter-spacing:-.01em;font-weight:600;color:var(--ink)}
.lead{font-size:clamp(15px,1.2vw,18px);max-width:48ch;line-height:1.55;color:var(--ink-2)}
.muted{color:var(--ink-3)}
.stroke{-webkit-text-stroke:1.8px var(--ink);color:transparent}
.gradient-text{
  background:linear-gradient(135deg, var(--pink) 0%, var(--violet) 80%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 26px;border-radius:999px;
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  transition:transform .2s, box-shadow .2s;
  cursor:pointer;
}
.btn-primary{
  background:linear-gradient(135deg, var(--pink), var(--violet));
  color:#fff;
  box-shadow:0 12px 36px rgba(255,45,160,.4), inset 0 1px 0 rgba(255,255,255,.3);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 44px rgba(255,45,160,.55)}

.btn-ghost{
  background:#fff;color:var(--ink);
  border:1px solid var(--line-strong);
  box-shadow:0 6px 20px rgba(255,45,160,.10);
}
.btn-ghost:hover{transform:translateY(-2px);border-color:var(--pink)}
.btn-ghost svg{width:14px;height:14px}

/* ---------- HUD ELEMENT (subtle, only on landing hero) ---------- */
.hud-corner{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-3);
  display:inline-flex;align-items:center;gap:8px;
}
.hud-corner .tick{width:8px;height:8px;border:1.5px solid var(--pink);transform:rotate(45deg)}
.hud-corner .live{width:7px;height:7px;border-radius:50%;background:var(--pink);box-shadow:0 0 10px var(--pink);animation:blink 1.6s infinite}

/* ---------- CARD PRIMITIVE ---------- */
.card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:28px;
  box-shadow:0 4px 24px rgba(255,45,160,.06), 0 1px 2px rgba(42,8,32,.04);
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(255,45,160,.14);border-color:var(--line-strong)}
.card-glass{
  background:linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.6));
  border:1px solid rgba(255,255,255,.7);
  backdrop-filter:blur(14px);
  box-shadow:0 10px 30px rgba(255,45,160,.10), inset 0 1px 0 rgba(255,255,255,.8);
}
.card-pink{
  background:linear-gradient(135deg, var(--pink), var(--violet));
  color:#fff;
  border:0;
  box-shadow:0 20px 50px rgba(255,45,160,.4);
}
.card-pink h3,.card-pink h2{color:#fff}
.card-pink p{color:rgba(255,255,255,.9)}

/* ---------- SECTION SHELL ---------- */
.section{padding:120px 32px;position:relative}
.section-narrow{padding:80px 32px}
.container{max-width:1320px;margin:0 auto;position:relative}

.section-head{
  display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:end;
  margin-bottom:64px;
}
.section-head .num{
  font-family:var(--mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--pink-deep);
  padding:8px 14px;border:1px solid var(--line-strong);border-radius:999px;
  background:#fff;justify-self:start;
}

/* ---------- PLACEHOLDERS ---------- */
.ph{
  position:relative;
  display:flex;align-items:center;justify-content:center;
  background:
    repeating-linear-gradient(135deg, rgba(255,45,160,.10) 0 14px, transparent 14px 28px),
    linear-gradient(135deg, var(--paper-2), var(--rose-soft));
  border:1px dashed var(--line-strong);
  border-radius:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--pink-deep);
}
.ph::after{
  content:"";position:absolute;inset:14px;
  border:1px solid rgba(255,45,160,.25);border-radius:8px;pointer-events:none;
}
.ph .ph-tag{
  padding:6px 12px;background:#fff;border-radius:6px;
  border:1px solid var(--line-strong);
  position:relative;z-index:1;
}

/* ---------- FOOTER ---------- */
footer{
  padding:80px 32px 32px;
  background:linear-gradient(180deg, transparent, rgba(255,45,160,.06));
  border-top:1px solid var(--line);
}
.foot{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:1.5fr .8fr .8fr .8fr;gap:48px;
}
.foot h4{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--pink-deep);
  margin-bottom:16px;
}
.foot a{display:block;font-size:14px;color:var(--ink-2);padding:5px 0;transition:color .2s}
.foot a:hover{color:var(--pink-deep)}
.foot-tag{font-size:15px;line-height:1.5;color:var(--ink-2);max-width:34ch;margin-top:14px}
.foot-bot{
  max-width:1320px;margin:56px auto 0;padding-top:24px;
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-3);
  flex-wrap:wrap;gap:16px;
}

/* ---------- MOBILE NAV ---------- */
.nav-toggle{
  display:none;
  width:44px;height:44px;border-radius:12px;
  border:1px solid var(--line-strong);background:#fff;
  align-items:center;justify-content:center;flex-direction:column;gap:5px;
  box-shadow:0 6px 18px rgba(255,45,160,.10);
}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s, opacity .2s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{
  position:fixed;inset:0 0 0 auto;z-index:95;
  width:min(82vw,360px);
  background:linear-gradient(180deg, var(--cream), var(--paper));
  border-left:1px solid var(--line-strong);
  box-shadow:-20px 0 60px rgba(255,45,160,.18);
  transform:translateX(100%);
  transition:transform .4s cubic-bezier(.22,.61,.36,1);
  padding:96px 28px 32px;
  display:flex;flex-direction:column;gap:4px;
}
.mobile-menu.open{transform:none}
.mobile-menu a{
  font-family:var(--mono);font-size:14px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);padding:16px 4px;border-bottom:1px solid var(--line);
  transition:color .2s, padding-left .2s;
}
.mobile-menu a:hover,.mobile-menu a.active{color:var(--pink-deep);padding-left:8px}
.mobile-menu .menu-cta{
  margin-top:20px;text-align:center;
  padding:16px;border-radius:999px;
  background:linear-gradient(135deg,var(--pink),var(--violet));color:#fff;border:0;
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  box-shadow:0 12px 30px rgba(255,45,160,.35);
}
.menu-backdrop{
  position:fixed;inset:0;z-index:94;
  background:rgba(42,8,32,.32);backdrop-filter:blur(2px);
  opacity:0;visibility:hidden;transition:opacity .3s, visibility .3s;
}
.menu-backdrop.open{opacity:1;visibility:visible}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 980px){
  .nav-links{display:none}
  .nav .cta{display:none}
  .nav-toggle{display:flex}
  .section{padding:80px 24px}
  .section-head{grid-template-columns:1fr;gap:18px;margin-bottom:40px}
  .foot{grid-template-columns:1fr 1fr;gap:32px}
  .nav{padding:14px 20px}
}
@media (max-width: 560px){
  .section{padding:56px 18px}
  .section-head{margin-bottom:28px;gap:12px}
  .foot{grid-template-columns:1fr;gap:24px}
  .foot-bot{flex-direction:column;align-items:flex-start;gap:10px}
  .h-section{font-size:clamp(32px,9vw,46px)}
  .h-display{font-size:clamp(40px,11vw,64px)}
  .h-card{font-size:20px}
}
