/* ===== HOME page styles ===== */

/* HERO */
.hero{position:relative;overflow:hidden;padding-top:clamp(120px,16vh,180px);padding-bottom:60px}
.hero__inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center}
.hero__badge{display:inline-flex;align-items:center;gap:.6em;padding:.55em 1.1em;border-radius:100px;
  border:1px solid var(--line-dark);background:rgba(255,255,255,.04);
  font-weight:600;font-size:.84rem;color:#fff;margin-bottom:30px}
.hero__pulse{width:8px;height:8px;border-radius:50%;background:#4ade80;box-shadow:0 0 0 0 rgba(74,222,128,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(74,222,128,.55)}70%{box-shadow:0 0 0 9px rgba(74,222,128,0)}100%{box-shadow:0 0 0 0 rgba(74,222,128,0)}}
.hero__title{max-width:16ch;margin-bottom:26px}
.hero__title .clip-up{display:block}
.hero__lede{max-width:54ch;color:var(--tx-light-muted);margin-bottom:36px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-bottom:60px}
.hero__shot{position:relative;width:100%;max-width:920px;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line-dark);box-shadow:0 50px 120px -40px rgba(139,92,214,.5)}
.hero__shot img{width:100%;aspect-ratio:16/9;object-fit:cover}
image-slot.hero__shot-img{display:block;width:100%;height:auto;aspect-ratio:16/9}
.hero__shot-glow{position:absolute;inset:0;background:var(--grad-soft);mix-blend-mode:overlay;z-index:2;pointer-events:none}
.hero__scroll{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:2;
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--tx-light-muted);
  display:flex;align-items:center;gap:.6em}
.hero__scroll span{animation:bob 1.6s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* MARQUEE section */
.marquee-sec{padding-block:34px;border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark)}

/* SECTION HEADS */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:60px;flex-wrap:wrap}
.sec-head > div{max-width:18ch}
.sec-head p.lede{max-width:34ch}
.sec-head--center{flex-direction:column;align-items:center;text-align:center}
.sec-head--center > *{max-width:none}
.inline-link{font-weight:700;color:var(--g-purple);white-space:nowrap}
.inline-link:hover{text-decoration:underline}

/* STATS */
.stats__head{display:flex;flex-direction:column;gap:18px;margin-bottom:56px}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{padding:34px;border-radius:var(--r);background:var(--paper-2);border:1px solid var(--line-light);
  transition:transform .5s var(--ease),box-shadow .5s}
.stat:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(139,92,214,.35)}
.stat__num{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:10px}
.stat__label{font-weight:600;font-size:1rem}
@media(max-width:860px){.stats__grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.stats__grid{grid-template-columns:1fr}}

/* SERVICES grid */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.svc{position:relative;display:flex;flex-direction:column;gap:8px;padding:30px 28px 64px;
  border-radius:var(--r);background:var(--paper-2);border:1px solid var(--line-light);
  transition:transform .5s var(--ease),box-shadow .5s,background .4s;overflow:hidden}
.svc::before{content:"";position:absolute;inset:0;background:var(--grad);opacity:0;transition:opacity .4s;z-index:0}
.svc > *{position:relative;z-index:1;transition:color .35s}
.svc:hover{box-shadow:0 34px 70px -30px rgba(139,92,214,.5)}
.svc:hover::before{opacity:1}
.svc:hover h3,.svc:hover .svc__no,.svc:hover p,.svc:hover .svc__arr{color:#fff!important}
.svc__no{font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--g-purple);letter-spacing:.05em}
.svc h3{margin-top:6px}
.svc__arr{position:absolute;left:28px;bottom:24px;font-size:1.3rem;color:var(--tx-dark-muted);transition:transform .4s var(--ease),color .35s}
.svc:hover .svc__arr{transform:translateX(6px)}
@media(max-width:1024px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.svc-grid{grid-template-columns:1fr}}

/* WORK cards */
.work-grid{display:grid;grid-template-columns:1.6fr 1fr;grid-template-rows:auto auto;gap:18px}
.wcard{position:relative;display:flex;flex-direction:column;border-radius:var(--r-lg);overflow:hidden;
  background:var(--ink-2);border:1px solid var(--line-dark);
  transition:transform .5s var(--ease),box-shadow .5s;padding-bottom:18px}
.wcard:hover{box-shadow:0 40px 90px -36px rgba(139,92,214,.6)}
.wcard--big{grid-row:span 2}
.wcard__media{aspect-ratio:16/9;background:linear-gradient(135deg,var(--c1),var(--c2));position:relative;overflow:hidden}
.wcard--big .wcard__media{aspect-ratio:16/12}
.wcard__media::after{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 30% 30%,rgba(255,255,255,.25),transparent 50%),
  repeating-linear-gradient(115deg,transparent 0 22px,rgba(0,0,0,.06) 22px 44px)}
.wcard__body{padding:26px 28px 8px;display:flex;flex-direction:column;gap:10px}
.wcard__tags{display:flex;gap:8px;flex-wrap:wrap}
.wcard__tags span{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;
  padding:.4em .85em;border-radius:100px;border:1px solid var(--line-dark);color:var(--tx-light-muted)}
.wcard__cta{padding:0 28px;font-weight:700;color:#fff;font-size:.95rem;transition:transform .4s var(--ease);align-self:flex-start}
.wcard:hover .wcard__cta{transform:translateX(6px);color:var(--g-pink)}
/* image-slot inside work cards */
image-slot.wcard__media{display:block;width:100%;height:auto;background:linear-gradient(135deg,var(--c1),var(--c2))}
image-slot.wcard__media::after{display:none}
@media(max-width:760px){.work-grid{grid-template-columns:1fr}.wcard--big{grid-row:auto}}

/* ABOUT strip */
.about-strip__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,6vw,80px);align-items:center}
.about-strip__media{position:relative;border-radius:var(--r-lg);overflow:hidden;transition:transform .5s var(--ease)}
.about-strip__media img{width:100%;aspect-ratio:4/3.4;object-fit:cover}
image-slot.about-strip__slot{display:block;width:100%;height:auto;aspect-ratio:4/3.4}
/* finished founder graphic: show full composition, no gradient tint */
.about-strip__media--clean{background:#fff}
.about-strip__media--clean .about-strip__glow{display:none}
.about-strip__glow{position:absolute;inset:0;background:var(--grad-soft);mix-blend-mode:multiply;z-index:2;pointer-events:none}
.about-strip__body{display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.about-strip__body .btn{margin-top:8px}
@media(max-width:820px){.about-strip__grid{grid-template-columns:1fr}}

/* PROCESS */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:p}
.proc{padding:34px 26px;border-radius:var(--r);border:1px solid var(--line-dark);background:var(--ink-2);
  display:flex;flex-direction:column;gap:12px;transition:transform .5s var(--ease),border-color .4s}
.proc:hover{transform:translateY(-6px);border-color:rgba(139,92,214,.5)}
.proc__no{font-family:var(--font-display);font-weight:600;font-size:2.4rem;line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.proc h3{color:#fff}
@media(max-width:920px){.proc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.proc-grid{grid-template-columns:1fr}}

/* TESTIMONIALS */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.quote{position:relative;padding:36px 30px 30px;border-radius:var(--r);background:var(--paper-2);
  border:1px solid var(--line-light);display:flex;flex-direction:column;gap:20px;
  transition:transform .5s var(--ease),box-shadow .5s}
.quote:hover{transform:translateY(-6px);box-shadow:0 30px 60px -32px rgba(139,92,214,.35)}
.quote__mark{font-family:var(--font-display);font-size:4rem;line-height:.6;height:30px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.quote blockquote{font-size:1.08rem;line-height:1.5;font-weight:500;flex:1}
.quote figcaption{display:flex;align-items:center;gap:14px}
.quote figcaption img{width:48px;height:48px;border-radius:50%;object-fit:cover}
image-slot.avatar-slot{display:block;width:48px;height:48px;flex:0 0 48px}
.quote figcaption span{display:flex;flex-direction:column;font-size:.88rem;color:var(--tx-dark-muted)}
.quote figcaption strong{color:var(--tx-dark);font-size:.98rem}
@media(max-width:820px){.testi-grid{grid-template-columns:1fr}}

/* CTA */
.cta{position:relative;overflow:hidden;padding-block:clamp(90px,13vw,170px)}.cta__inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px}

/* hero rotating word */
.hero__rotate{display:inline-block;position:relative}
.hero__rotate .rw{display:inline-block;background:var(--grad);-webkit-background-clip:text;background-clip:text;
  color:transparent;padding-right:.08em;margin-right:-.04em}
.hero__rotate.swap .rw{animation:rwswap .5s var(--ease)}
@keyframes rwswap{0%{opacity:0;transform:translateY(.32em) rotateX(-40deg)}100%{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.hero__rotate.swap .rw{animation:none}}
.cta__inner h2{max-width:18ch}
.cta__inner .lede{max-width:48ch;color:var(--tx-light-muted)}
.cta__btn{margin-top:10px;font-size:1.05rem;padding:1.1em 1.9em}

/* SHOWREEL */.reel{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line-dark);
  aspect-ratio:16/9;max-width:1000px;margin:0 auto;cursor:pointer;
  box-shadow:0 50px 120px -40px rgba(139,92,214,.55)}
/* SHOWREEL SLIDER */
.reelslider{position:relative;max-width:1000px;margin:0 auto;padding-bottom:38px}
.reelslider__viewport{overflow:hidden;border-radius:var(--r-lg)}
.reelslider__track{display:flex;transition:transform .6s var(--ease)}
.reelslider .reel{flex:0 0 100%;max-width:none;margin:0;border-radius:var(--r-lg)}
.reelslider__arrow{position:absolute;top:calc(50% - 19px);transform:translateY(-50%);z-index:5;
  width:54px;height:54px;border-radius:50%;background:rgba(11,10,18,.55);border:1px solid var(--line-dark);
  color:#fff;font-size:1.8rem;line-height:1;display:grid;place-items:center;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .3s,transform .3s,opacity .3s}
.reelslider__arrow:hover{background:var(--grad);border-color:transparent;transform:translateY(-50%) scale(1.08)}
.reelslider__arrow--prev{left:-12px}
.reelslider__arrow--next{right:-12px}
.reelslider__dots{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:center;gap:10px}
.reelslider__dots button{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.28);transition:.35s var(--ease)}
.reelslider__dots button.active{width:30px;border-radius:6px;background:var(--grad)}
@media(max-width:560px){.reelslider__arrow--prev{left:6px}.reelslider__arrow--next{right:6px}}
.reel__poster{width:100%;height:100%;object-fit:cover}
image-slot.reel__poster{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:1}
.reel__shade,.reel__play,.reel__label{z-index:3}
.reel__shade{position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(11,10,18,.15),rgba(11,10,18,.62))}
.reel__label{pointer-events:none}
.reel__play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:92px;height:92px;
  border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;
  box-shadow:0 16px 50px -10px rgba(139,92,214,.85);transition:transform .4s var(--ease)}
.reel__play svg{margin-left:5px}
.reel__play::after{content:"";position:absolute;inset:-14px;border-radius:50%;
  border:1px solid rgba(255,255,255,.45);animation:reelpulse 2.4s ease-out infinite}
@keyframes reelpulse{0%{transform:scale(.85);opacity:.7}100%{transform:scale(1.35);opacity:0}}
.reel:hover .reel__play{transform:translate(-50%,-50%) scale(1.08)}
.reel__label{position:absolute;left:0;right:0;bottom:24px;text-align:center;color:#fff;font-weight:600;
  letter-spacing:.02em;text-shadow:0 2px 14px rgba(0,0,0,.55)}
.reel iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
@media(prefers-reduced-motion:reduce){.reel__play::after{animation:none}}
