/* ============================================================
   RideCheetah — styles.css (build v3)
   Gold-on-near-black. No purple. No frameworks.
   All named keyframes run with NO JS so the page is animated
   even before/without JS or WebGL.
   ============================================================ */

/* ---------- :root variables (contract verbatim) ---------- */
:root{
  /* palette */
  --gold-1:#FFE07A; --gold:#F7A823; --gold-2:#E2780C;
  --grad-gold:linear-gradient(120deg,var(--gold-1),var(--gold),var(--gold-2));
  --ink:#0B0805; --ink-2:#15100A; --cream:#FFF6E2; --muted:#B9A077;
  --good:#16A34A; --bad:#DC2626;
  --line:rgba(255,224,122,.14);            /* hairline borders */
  /* type scale (clamp) */
  --fs-display:clamp(2.75rem,7vw,6rem);
  --fs-h1:clamp(2.4rem,5.5vw,4.75rem);
  --fs-h2:clamp(1.9rem,3.6vw,3rem);
  --fs-h3:clamp(1.2rem,1.8vw,1.55rem);
  --fs-lead:clamp(1.05rem,1.5vw,1.3rem);
  --fs-body:clamp(1rem,1.1vw,1.075rem);
  --fs-small:.875rem;
  /* spacing scale */
  --sp-1:.5rem; --sp-2:.75rem; --sp-3:1rem; --sp-4:1.5rem; --sp-5:2rem;
  --sp-6:3rem; --sp-7:4.5rem; --sp-8:7rem; --sp-section:clamp(5rem,10vw,9rem);
  --maxw:1200px; --gutter:clamp(1.25rem,4vw,2.5rem);
  /* radii */
  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-xl:32px; --r-pill:999px;
  /* gold-tinted shadows */
  --sh-card:0 20px 60px -20px rgba(0,0,0,.7), 0 0 0 1px var(--line);
  --sh-gold:0 10px 40px -8px rgba(247,168,35,.45);
  --sh-gold-strong:0 0 60px -6px rgba(247,168,35,.6);
  /* motion */
  --ease:cubic-bezier(.22,.61,.36,1); --ease-out:cubic-bezier(.16,1,.3,1);
  --dur:.7s; --z-bg:0; --z-content:2; --z-nav:50; --z-cursor:60;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:'Inter',system-ui,sans-serif;
  font-size:var(--fs-body);
  line-height:1.65;
  background:var(--ink);
  color:var(--cream);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
h1,h2,h3{margin:0;font-weight:800;letter-spacing:-.02em;line-height:1.05;}
h1{font-weight:900;}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px;}

/* ---------- Background canvas (WebGL target) ---------- */
canvas#bg{
  position:fixed;inset:0;width:100vw;height:100vh;
  z-index:var(--z-bg);pointer-events:none;
}

/* ---------- Cursor glow (desktop, JS-driven position) ---------- */
.cursor-glow{
  position:fixed;top:0;left:0;width:380px;height:380px;
  margin:-190px 0 0 -190px;border-radius:50%;
  background:radial-gradient(circle,rgba(247,168,35,.16),rgba(247,168,35,0) 65%);
  pointer-events:none;z-index:var(--z-cursor);
  opacity:0;transition:opacity .4s ease;mix-blend-mode:screen;
  will-change:transform;
}

/* ---------- Flowing gold gradient text ---------- */
.grad-text{
  background:var(--grad-gold);background-size:200% 200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:gradFlow 6s linear infinite;
}

/* ============================================================
   KEYFRAMES (all defined by exact contract names)
   ============================================================ */

/* hero aurora drift — bg-position 0%→200% + slow drift/rotate */
@keyframes auroraFlow{
  0%  {background-position:0% 50%;   transform:translate3d(-2%,-1%,0) rotate(-2deg) scale(1.05);}
  100%{background-position:200% 50%; transform:translate3d(2%,2%,0)  rotate(3deg)  scale(1.15);}
}

/* flowing gold text + button gradient */
@keyframes gradFlow{
  0%  {background-position:0% 50%;}
  100%{background-position:200% 50%;}
}

/* infinite marquee strip */
@keyframes marquee{
  0%  {transform:translateX(0);}
  100%{transform:translateX(-50%);}
}

/* CTA sheen sweep (::before light band) */
@keyframes ctaShimmer{
  0%  {transform:translateX(-120%) skewX(-18deg);}
  60% {transform:translateX(120%)  skewX(-18deg);}
  100%{transform:translateX(120%)  skewX(-18deg);}
}

/* CTA glow breathing */
@keyframes ctaPulse{
  0%,100%{box-shadow:var(--sh-gold);}
  50%    {box-shadow:var(--sh-gold-strong);}
}

/* no-3d phone sway: translateY ±12px + rotate ±5deg */
@keyframes fallbackFloat{
  0%  {transform:translateY(-12px) rotate(-5deg);}
  100%{transform:translateY(12px)  rotate(5deg);}
}

/* hero scroll cue */
@keyframes scrollCue{
  0%  {transform:translateY(0);   opacity:1;}
  100%{transform:translateY(10px);opacity:.2;}
}

/* ambient gold bloom (aurora accent, logo) */
@keyframes glowPulse{
  0%,100%{opacity:.55;transform:scale(1);}
  50%    {opacity:1;  transform:scale(1.06);}
}

/* ============================================================
   REVEAL mechanics (CSS side; JS toggles .is-in)
   ============================================================ */
.reveal{
  opacity:0;transform:translateY(28px);filter:blur(6px);
  transition:opacity .7s var(--ease-out),transform .7s var(--ease-out),filter .7s var(--ease-out);
  transition-delay:var(--_d,0ms);
}
.reveal.is-in{opacity:1;transform:none;filter:blur(0);}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  background:linear-gradient(180deg,rgba(11,8,5,.85),rgba(11,8,5,.35));
  border-bottom:1px solid var(--line);
}
.nav__inner{
  max-width:var(--maxw);margin-inline:auto;padding:.7rem var(--gutter);
  display:flex;align-items:center;gap:var(--sp-4);
}
.nav__brand{display:flex;align-items:center;gap:.6rem;font-weight:900;letter-spacing:-.02em;}
.nav__logo{width:34px;height:34px;border-radius:9px;animation:glowPulse 4s ease-in-out infinite;}
.nav__name{font-size:1.15rem;}
.nav__links{
  display:flex;align-items:center;gap:var(--sp-5);
  margin-left:auto;position:relative;
}
.nav__link{
  color:var(--muted);font-weight:600;font-size:var(--fs-small);
  padding:.35rem .1rem;transition:color .25s var(--ease);position:relative;
}
.nav__link:hover{color:var(--cream);}
.nav__link.is-active{color:var(--cream);}
.nav__indicator{
  position:absolute;bottom:-4px;left:0;height:2px;width:0;
  background:var(--grad-gold);border-radius:2px;
  transition:left .35s var(--ease),width .35s var(--ease);
  pointer-events:none;
}
.nav__cta{margin-left:var(--sp-2);}
.nav__burger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:0;cursor:pointer;padding:.4rem;margin-left:auto;
}
.nav__burger span{
  width:24px;height:2px;background:var(--cream);border-radius:2px;
  transition:transform .3s var(--ease),opacity .3s var(--ease);
}
.nav.is-open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav.is-open .nav__burger span:nth-child(2){opacity:0;}
.nav.is-open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.9rem 1.5rem;font-weight:800;font-size:var(--fs-body);
  border-radius:var(--r-pill);cursor:pointer;border:0;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
  will-change:transform;text-align:center;line-height:1;
}
.btn--gold{
  background:var(--grad-gold);background-size:200% 200%;color:#1a1206;
  animation:gradFlow 6s linear infinite;box-shadow:var(--sh-gold);
}
.btn--gold:hover{transform:translateY(-2px);box-shadow:var(--sh-gold-strong);}
.btn--ghost{
  background:transparent;border:1px solid var(--line);color:var(--cream);
}
.btn--ghost:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--sh-gold);}
.btn--shimmer{position:relative;overflow:hidden;animation:gradFlow 6s linear infinite,ctaPulse 2.6s ease-in-out infinite;}
.btn--shimmer::before{
  content:"";position:absolute;top:0;left:0;width:45%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);
  transform:translateX(-120%) skewX(-18deg);
  animation:ctaShimmer 3.2s ease-in-out infinite;pointer-events:none;
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  max-width:var(--maxw);margin-inline:auto;
  padding:8rem var(--gutter) 4rem;
  z-index:var(--z-content);overflow:hidden;
}

/* always-on CSS aurora (also no-WebGL backdrop) */
.hero__aurora{
  position:absolute;inset:-20% -10%;z-index:-1;pointer-events:none;
  background:
    radial-gradient(40% 55% at 70% 30%,rgba(247,168,35,.30),transparent 70%),
    radial-gradient(45% 45% at 25% 65%,rgba(226,120,12,.22),transparent 70%),
    radial-gradient(35% 40% at 50% 20%,rgba(255,224,122,.18),transparent 70%),
    conic-gradient(from 0deg at 60% 40%,rgba(247,168,35,.10),rgba(226,120,12,.05),rgba(255,224,122,.12),rgba(247,168,35,.10));
  background-size:200% 200%;
  filter:blur(30px);opacity:.9;
  animation:auroraFlow 18s ease-in-out infinite alternate;
}

/* 3D stage / fallback anchor */
.hero__stage{position:absolute;inset:0;pointer-events:none;z-index:-1;}

/* CSS-animated fallback phone (only under html.no-3d) */
.hero-fallback{display:none;position:absolute;inset:0;}
html.no-3d .hero-fallback{display:block;}
html.is-3d  .hero-fallback{display:none;}
.hero-fallback__phone{
  position:absolute;top:50%;right:8%;transform-origin:center;
  width:clamp(220px,24vw,300px);aspect-ratio:9/19;
  margin-top:-32vh;
  background:linear-gradient(160deg,#1c150c,#0e0a06);
  border:1px solid var(--line);border-radius:34px;
  box-shadow:var(--sh-gold),var(--sh-card);
  padding:16px;
  animation:fallbackFloat 6s ease-in-out infinite alternate;
}
.hero-fallback__card{
  height:100%;border-radius:22px;
  background:linear-gradient(165deg,rgba(247,168,35,.16),rgba(11,8,5,.6));
  border:1px solid var(--line);
  padding:18px 16px;display:flex;flex-direction:column;gap:10px;
}
.hero-fallback__verdict{
  font-weight:900;font-size:2rem;letter-spacing:-.02em;
  color:var(--good);
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 12px rgba(247,168,35,.5));
  margin-bottom:6px;
}
.hero-fallback__row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.9rem;color:var(--muted);
  padding:.5rem 0;border-top:1px solid var(--line);
}
.hero-fallback__row span:last-child{color:var(--cream);font-weight:800;font-size:1.05rem;}

/* hero content */
.hero__content{position:relative;max-width:760px;z-index:1;}
.hero__title{font-size:var(--fs-display);margin-bottom:var(--sp-4);}
.hero__title .line{
  display:block;
  /* base reveal state for staggered JS load reveal */
  opacity:0;transform:translateY(34px);filter:blur(8px);
  transition:opacity .8s var(--ease-out),transform .8s var(--ease-out),filter .8s var(--ease-out);
}
.hero__title .line.is-in{opacity:1;transform:none;filter:blur(0);}
.hero__sub{
  font-size:var(--fs-lead);color:var(--muted);max-width:620px;
  margin-bottom:var(--sp-5);
}
.hero__actions{display:flex;flex-wrap:wrap;gap:var(--sp-3);margin-bottom:var(--sp-6);}

.hero__stats{display:flex;flex-wrap:wrap;gap:var(--sp-6);}
.stat{display:flex;flex-direction:column;}
.stat .count{
  font-size:clamp(1.9rem,3vw,2.6rem);font-weight:900;letter-spacing:-.02em;
  background:var(--grad-gold);background-size:200% 200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:gradFlow 6s linear infinite;
}
.stat__label{font-size:var(--fs-small);color:var(--muted);max-width:160px;}

/* scroll cue */
.hero__cue{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  width:22px;height:34px;border:2px solid var(--line);border-radius:var(--r-pill);
}
.hero__cue::after{
  content:"";position:absolute;top:7px;left:50%;margin-left:-3px;
  width:6px;height:6px;border-radius:50%;background:var(--gold);
  animation:scrollCue 1.8s ease-in-out infinite;
}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  position:relative;z-index:var(--z-content);
  border-block:1px solid var(--line);
  background:linear-gradient(180deg,rgba(21,16,10,.6),rgba(11,8,5,.3));
  padding-block:var(--sp-4);overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.marquee__track{display:flex;width:max-content;animation:marquee 32s linear infinite;}
.marquee__group{display:flex;align-items:center;flex-shrink:0;}
.marquee__item{
  font-weight:800;font-size:clamp(1rem,1.6vw,1.35rem);letter-spacing:-.01em;
  color:var(--cream);padding-inline:var(--sp-4);white-space:nowrap;
}
.marquee__dot{
  width:8px;height:8px;border-radius:50%;background:var(--gold);
  box-shadow:0 0 12px rgba(247,168,35,.6);flex-shrink:0;
}

/* ============================================================
   SECTIONS (shared)
   ============================================================ */
.section{
  max-width:var(--maxw);margin-inline:auto;
  padding-inline:var(--gutter);padding-block:var(--sp-section);
  position:relative;z-index:var(--z-content);background:transparent;
}
.section__head{margin-bottom:var(--sp-6);max-width:720px;}
.eyebrow{
  font-size:var(--fs-small);font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);margin:0 0 var(--sp-2);
}
.section__title{font-size:var(--fs-h2);}

/* glassy panel base used by cards */
.why__col,.step,.feature,.price__card{
  background:linear-gradient(165deg,rgba(21,16,10,.72),rgba(11,8,5,.5));
  border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--sh-card);
}

/* ---------- De ce ---------- */
.why__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);}
.why__col{padding:var(--sp-5);}
.why__problem{border-color:rgba(220,38,38,.22);}
.why__solution{border-color:rgba(22,163,74,.22);}
.why__head{font-size:var(--fs-h3);margin-bottom:var(--sp-3);}
.why__problem .why__head{color:var(--bad);}
.why__solution .why__head{color:var(--good);}
.why__list{display:flex;flex-direction:column;gap:var(--sp-2);}
.why__point{
  position:relative;padding-left:1.6rem;color:var(--muted);font-size:var(--fs-body);
}
.why__point::before{
  content:"";position:absolute;left:0;top:.6em;width:8px;height:8px;border-radius:50%;
  background:var(--grad-gold);box-shadow:0 0 8px rgba(247,168,35,.6);
}

/* ---------- Cum funcționează ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4);}
.step{padding:var(--sp-5);}
.step__num{
  font-size:2.5rem;font-weight:900;letter-spacing:-.04em;line-height:1;
  background:var(--grad-gold);background-size:200% 200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:gradFlow 6s linear infinite;margin-bottom:var(--sp-3);
}
.step__title{font-size:var(--fs-h3);margin-bottom:var(--sp-2);}
.step__text{color:var(--muted);}

/* ---------- Funcții ---------- */
.features__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4);}
.feature{
  padding:var(--sp-5);transition:box-shadow .3s var(--ease),border-color .3s var(--ease);
}
.feature:hover{border-color:rgba(247,168,35,.35);box-shadow:var(--sh-gold),var(--sh-card);}
.feature__icon{
  width:54px;height:54px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,rgba(247,168,35,.18),rgba(247,168,35,.03));
  border:1px solid var(--line);color:var(--gold);margin-bottom:var(--sp-3);
}
.feature__icon svg{width:26px;height:26px;}
.feature__title{font-size:var(--fs-h3);margin-bottom:var(--sp-2);}
.feature__text{color:var(--muted);}

/* ---------- Preț ---------- */
.section--price{display:flex;flex-direction:column;align-items:center;text-align:center;}
.section--price .section__head{text-align:center;margin-inline:auto;}
.price__card{
  padding:var(--sp-6) var(--sp-5);max-width:460px;width:100%;
  display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);
  border-color:rgba(247,168,35,.3);box-shadow:var(--sh-gold),var(--sh-card);
}
.price__plan{
  font-size:var(--fs-small);font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);
}
.price__amount{display:flex;align-items:baseline;gap:.3rem;}
.price__amount .count{
  font-size:clamp(3rem,7vw,4.5rem);font-weight:900;letter-spacing:-.03em;line-height:1;
  background:var(--grad-gold);background-size:200% 200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:gradFlow 6s linear infinite;
}
.price__per{font-size:var(--fs-lead);color:var(--muted);font-weight:600;}
.price__list{display:flex;flex-direction:column;gap:var(--sp-2);margin-block:var(--sp-2);width:100%;}
.price__feat{
  position:relative;padding-left:1.7rem;color:var(--cream);text-align:left;
}
.price__feat::before{
  content:"✓";position:absolute;left:0;top:0;color:var(--good);font-weight:900;
}
.price__card .btn{width:100%;}
.price__note{font-size:var(--fs-small);color:var(--muted);margin:0;}
.price__note a{color:var(--gold);text-decoration:underline;text-underline-offset:3px;}

/* ---------- FAQ ---------- */
.faq__list{display:flex;flex-direction:column;gap:var(--sp-2);max-width:780px;}
.faq__item{
  background:linear-gradient(165deg,rgba(21,16,10,.6),rgba(11,8,5,.4));
  border:1px solid var(--line);border-radius:var(--r-md);
  padding:0 var(--sp-4);overflow:hidden;
  transition:border-color .25s var(--ease);
}
.faq__item[open]{border-color:rgba(247,168,35,.3);}
.faq__q{
  cursor:pointer;font-weight:800;font-size:var(--fs-h3);
  padding:var(--sp-4) 0;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:var(--sp-3);
}
.faq__q::-webkit-details-marker{display:none;}
.faq__q::after{
  content:"+";color:var(--gold);font-weight:900;font-size:1.5rem;line-height:1;
  transition:transform .3s var(--ease);
}
.faq__item[open] .faq__q::after{transform:rotate(45deg);}
.faq__a{color:var(--muted);margin:0;padding:0 0 var(--sp-4);}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  position:relative;z-index:var(--z-content);
  border-top:1px solid var(--line);
  background:linear-gradient(180deg,rgba(11,8,5,.3),rgba(21,16,10,.7));
}
.footer__inner{
  max-width:var(--maxw);margin-inline:auto;padding:var(--sp-6) var(--gutter);
  display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-4);justify-content:space-between;
}
.footer__brand{display:flex;align-items:center;gap:.6rem;font-weight:900;}
.footer__logo{width:30px;height:30px;border-radius:8px;}
.footer__links{display:flex;flex-wrap:wrap;gap:var(--sp-4);}
.footer__links a{color:var(--muted);font-size:var(--fs-small);font-weight:600;transition:color .25s var(--ease);}
.footer__links a:hover{color:var(--cream);}
.footer__legal{color:var(--muted);font-size:var(--fs-small);margin:0;}

/* ============================================================
   RESPONSIVE (mobile-first adjustments at breakpoints)
   ============================================================ */
@media (max-width:900px){
  .nav__links{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:flex-start;gap:var(--sp-3);
    background:rgba(11,8,5,.97);backdrop-filter:blur(14px);
    padding:var(--sp-4) var(--gutter);
    border-bottom:1px solid var(--line);
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:opacity .3s var(--ease),transform .3s var(--ease);
  }
  .nav.is-open .nav__links{transform:none;opacity:1;pointer-events:auto;display:flex;}
  .nav__indicator{display:none;}
  .nav__cta{display:none;}
  .nav__burger{display:flex;}

  .why__grid{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .features__grid{grid-template-columns:1fr;}

  .hero-fallback__phone{right:50%;transform:translateX(50%);margin-top:-30vh;opacity:.85;}
}

@media (max-width:600px){
  :root{--fs-display:clamp(2.25rem,9vw,3.25rem);}
  .hero{padding-top:7rem;}
  .hero__actions{flex-direction:column;align-items:stretch;}
  .hero__actions .btn{width:100%;}
  .hero__stats{flex-direction:column;gap:var(--sp-4);}
  .footer__inner{flex-direction:column;align-items:flex-start;}
}

/* ============================================================
   REDUCED MOTION (mandatory)
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;}
  .reveal{opacity:1!important;transform:none!important;filter:none!important;}
  .hero__title .line{opacity:1!important;transform:none!important;filter:none!important;}
  .marquee__track{transform:none!important;}
  .hero__aurora{animation:none!important;}
  .hero__cue{display:none;}
  .cursor-glow{display:none!important;}
}
