/* ============================================================
   Klip Connect — landing (pure CSS, hand-authored)
   Ported from the approved design "Klip Connect.html" (Claude Design handoff).
   Hand-edit freely; no build step. Cache-busted via ?v=filemtime in the blade.
   ============================================================ */

:root{
  --bg:#0a0b0a;
  --bg-soft:#101210;
  --ink:#0a0b0a;
  --paper:#f4f5f2;
  --white:#ffffff;
  --accent:#9ae022;          /* lime */
  --accent-deep:#6fb800;
  --accent-ink:#0a0b0a;
  --red:#ff3b30;
  --muted:#a7ada4;
  --line:rgba(154,224,34,.14);
  --card-radius:18px;
  --maxw:600px;
  --pad:24px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;}
.landing{
  font-family:'Archivo',system-ui,sans-serif;
  background:var(--bg);
  color:var(--white);
  line-height:1.25;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
.landing img{display:block;max-width:100%;}
.landing a{color:inherit;}

/* ---------- atmosphere: masked lime grid + soft green glows (behind everything) ---------- */
.atmos{position:fixed;inset:0;z-index:-1;pointer-events:none;background:var(--bg);}
.atmos::before{                       /* neon grid — masked to the upper area, fades downward (production-accurate, "smooth") */
  content:"";position:absolute;inset:0;opacity:.18;
  background-image:
    linear-gradient(rgba(198,248,6,.30) 1px,transparent 1px),
    linear-gradient(90deg,rgba(198,248,6,.30) 1px,transparent 1px);
  background-size:34px 34px;
  -webkit-mask-image:radial-gradient(75% 55% at 50% 35%,#000 50%,transparent 100%);
  mask-image:radial-gradient(75% 55% at 50% 35%,#000 50%,transparent 100%);
}
.atmos::after{                        /* soft neon glows: top-center, left, bottom-right (production palette) */
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(44rem 30rem at 50% -6%, rgba(198,248,6,.25), transparent 60%),
    radial-gradient(26rem 26rem at -8% 34%, rgba(198,248,6,.20), transparent 60%),
    radial-gradient(28rem 28rem at 108% 86%, rgba(198,248,6,.20), transparent 60%);
}

/* ---------- shared bits ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);}
/* per-section grid removed — the global .atmos grid now covers the whole page (production-style) */
.grid-bg{}
.pill{
  display:inline-flex;align-items:center;gap:.4em;
  background:var(--accent);color:var(--accent-ink);
  font-weight:800;border-radius:999px;
  padding:.42em .95em;line-height:1;white-space:nowrap;
}
.hl{background:var(--accent);color:var(--accent-ink);padding:.04em .18em;border-radius:6px;box-decoration-break:clone;-webkit-box-decoration-break:clone;}
.grn{color:var(--accent);}
.ital{font-style:italic;}
.tightcaps{letter-spacing:-.01em;}

/* ---------- top nav ---------- */
.topbar{padding-top:28px;}
.nav{
  background:#000;border-radius:999px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:11px 16px 11px 12px;
  border:1px solid #1d1f1c;
}
/* logo chip — green accent + dashboard image logo (production lockup). Production chip is neon #C6F806; using the design accent (lime) for consistency. */
.logo{
  background:var(--accent);border-radius:999px;
  padding:6px 14px;line-height:1;
  display:inline-flex;align-items:center;flex:0 0 auto;
}
.logo img{height:16px;width:auto;display:block;}
/* tagline — production size/placement: small, dim, right-aligned, wraps */
.nav-tag{font-weight:600;font-size:9px;color:#d4d4d4;letter-spacing:.3px;line-height:1.3;text-align:right;}

/* ---------- hero ---------- */
.hero{position:relative;padding:12px 0 24px;}
.hero-inner{position:relative;}
/* full-width light panel = the whole hero block; nav pill + talent live ON it and are
   clipped by it (overflow:hidden) so nothing bleeds past the rounded edges. */
.hero-card{
  position:relative;overflow:hidden;isolation:isolate;
  background:linear-gradient(150deg,#fafbf7 0%,#e9ebe2 100%);
  color:#0a0b0a;
  border-radius:30px;
  padding:14px 16px 28px;
  min-height:420px;
}
/* faint lime corner wash inside the card — adds depth without stealing focus */
.hero-card::before{
  content:"";position:absolute;right:-10%;top:-30%;width:70%;height:120%;z-index:0;
  background:radial-gradient(closest-side,rgba(154,224,34,.22),transparent 70%);
  pointer-events:none;
}
/* nav pill living at the top of the card */
.hero-card .nav{position:relative;z-index:4;}
.hero-copy{position:relative;z-index:2;width:58%;margin-top:20px;padding:0 6px;}
.hero-kicker{font-size:14px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.hero-kicker .stop{background:var(--accent);color:#0a0b0a;font-weight:900;font-style:italic;padding:.2em .55em;border-radius:999px;}
.hero-kicker em{font-style:italic;color:#26281f;font-weight:700;}
.hero h1{
  font-weight:900;letter-spacing:-.025em;line-height:1.0;color:#0a0b0a;
  /* 6vw (was 7vw): keeps line 1 "Ubah Skill Clipping" clear of the talent across the 440–660 band */
  font-size:clamp(26px,6vw,50px);
  text-transform:none;
}
.hero h1 .hl-line{display:block;white-space:nowrap;}
.hero h1 .line3{display:block;margin-top:.16em;}

/* ---------- hero CTA — "Free Member Now" (black pill, lime segment + white Now) ---------- */
.hero-cta{
  margin-top:24px;display:inline-flex;align-items:center;gap:.15em;
  padding:5px;border-radius:999px;
  background:#0a0b0a;border:1px solid #2c2e2a;
  text-decoration:none;white-space:nowrap;
  box-shadow:0 6px 16px -10px rgba(10,11,10,.55);
  transition:transform .18s ease,box-shadow .18s ease;
}
.hero-cta .a{
  background:var(--accent);color:#0a0b0a;
  font-weight:800;letter-spacing:-.01em;
  padding:.55em 1.15em;border-radius:999px;
}
.hero-cta .b{
  color:#fff;font-weight:800;letter-spacing:-.01em;
  padding:.1em .95em .1em .45em;
}
.hero-cta:hover{transform:translateY(-1px);box-shadow:0 11px 24px -10px rgba(10,11,10,.6);}
.hero-cta:active{transform:translateY(0);}

/* ---------- presenter cutout — WRAPPED inside the card, anchored bottom-right ---------- */
.hero-photo{
  position:absolute;right:0;bottom:0;width:50%;height:100%;z-index:1;
  pointer-events:none;display:flex;align-items:flex-end;justify-content:flex-end;
}
.talent-glow{
  position:absolute;right:2%;bottom:0;width:88%;height:78%;z-index:0;
  background:radial-gradient(ellipse 60% 70% at 60% 90%,rgba(154,224,34,.30),transparent 70%);
  pointer-events:none;
}
.talent{
  position:relative;z-index:1;right:0;bottom:0;
  height:100%;width:auto;max-width:none;object-fit:contain;object-position:bottom right;
  filter:drop-shadow(-12px 14px 24px rgba(0,0,0,.28));
}

/* mobile + tablet: hero spans full viewport width, only the bottom is rounded.
   Talent is contained in the card (no bleed): sits bottom-right, clipped by the card. */
@media (max-width:1023px){
  .hero{padding-top:0;}
  .hero .wrap{padding-left:0;padding-right:0;max-width:none;}
  .hero-card{border-radius:0 0 30px 30px;padding:16px 22px 26px;min-height:460px;}
  /* sit the talent in the lower-right, fully in-frame (right:0) so the raised
     hand/finger is never clipped at the card's right edge. */
  .hero-photo{width:47%;height:70%;right:0;bottom:0;}
  .talent{height:100%;width:auto;}
}
/* smallest phones: keep the talent smaller & lower-right, but fully in-frame so the
   raised hand/finger isn't clipped at the right edge. */
@media (max-width:480px){
  .hero-card{min-height:430px;}
  .hero-photo{width:44%;height:56%;right:0;}
}

/* ---------- section heading ---------- */
.landing section{position:relative;}
.sec{padding:30px 0;}
.sec-h{
  font-weight:900;letter-spacing:-.02em;line-height:1.0;
  font-size:clamp(30px,7.4vw,42px);
}
.sec-h.center{text-align:center;}

/* ---------- why card ---------- */
.why{padding-top:24px;}
.why-h{color:#cfd4ca;margin-bottom:20px;}
.why-card{
  position:relative;overflow:hidden;
  background:
    radial-gradient(120% 140% at 100% 0%, #b6f23a 0%, #97e024 42%, #74c10d 100%);
  color:#0a0b0a;border-radius:26px;padding:26px 24px;
}
.why-card ul{list-style:none;display:flex;flex-direction:column;gap:13px;position:relative;z-index:2;}
.why-card li{display:flex;gap:11px;align-items:flex-start;font-weight:700;font-size:16px;letter-spacing:-.01em;}
.why-card .ck{flex:0 0 auto;width:18px;height:18px;margin-top:1px;}
.why-card .ck svg{width:100%;height:100%;}
.why-card .ghost{position:absolute;right:-6%;bottom:-22%;width:46%;opacity:.22;z-index:1;}
.why-card .ghost svg{width:100%;height:auto;}

/* ---------- not for everyone ---------- */
.nfe{padding:46px 0 36px;text-align:center;}
.nfe-h{display:inline-block;text-align:center;}
.nfe-h .l1 .b{color:var(--accent);}
.nfe-h .l1{font-weight:900;letter-spacing:-.02em;line-height:1.0;font-size:clamp(34px,8.4vw,48px);}
.nfe-bang{color:var(--red);display:inline-block;transform:rotate(8deg);}
.nfe-bang svg{width:.9em;height:.83em;display:block;}   /* inline SVG bangs (text ‼ rendered as a tacky emoji on phones) */
.nfe-sub{color:#e9ece6;font-weight:800;font-size:clamp(18px,4.6vw,22px);margin:28px 0 22px;}
.dont{display:grid;grid-template-columns:1fr;gap:16px 34px;text-align:left;max-width:560px;margin:0 auto;}
.dont li{display:flex;gap:10px;align-items:flex-start;list-style:none;font-size:14.5px;font-weight:600;color:#e7eae3;letter-spacing:-.005em;}
.dont .xx{flex:0 0 auto;width:18px;height:18px;margin-top:1px;}
.dont .xx svg{width:100%;height:100%;}

/* ---------- proof ---------- */
.proof{padding:30px 0 14px;text-align:center;}
/* framed rounded grid box (production: Bukti Nyata sits inside its own ring + contained grid + top glow) */
.proof-box{
  --proofpad:clamp(16px,3vw,40px);    /* shared with .feed-row's negative margin */
  position:relative;overflow:hidden;
  border-radius:clamp(24px,3vw,34px);
  background:rgba(18,18,18,.6);
  box-shadow:inset 0 0 0 1px rgba(198,248,6,.15);
  padding:clamp(30px,4vw,52px) var(--proofpad) clamp(36px,4vw,56px);
}
.proof-box::before{                   /* crisp contained grid */
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(198,248,6,.14) 1px,transparent 1px),
    linear-gradient(90deg,rgba(198,248,6,.14) 1px,transparent 1px);
  background-size:28px 28px;
}
.proof-box::after{                    /* soft green glow at the top-center of the box */
  content:"";position:absolute;left:50%;top:-16%;width:62%;height:64%;
  transform:translateX(-50%);z-index:0;pointer-events:none;
  background:radial-gradient(closest-side, rgba(198,248,6,.20), transparent 72%);
}
.proof-box > *{position:relative;z-index:1;}
.proof .sub{color:#c9cec5;font-weight:600;font-size:15px;margin-top:6px;}
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:26px;}
.proof-card{
  background:var(--white);border-radius:14px;aspect-ratio:9/15;
  position:relative;overflow:hidden;display:flex;align-items:flex-end;
  box-shadow:0 0 0 1px rgba(255,255,255,.06);
}
.proof-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.proof-card .views{position:relative;z-index:3;margin:0 0 16px 16px;font-weight:800;color:#0a0b0a;font-size:14px;background:#fff;padding:2px 6px;border-radius:5px;}
.proof-card a.play{position:absolute;inset:0;z-index:4;}
.proof-grid--1{grid-template-columns:minmax(0,220px);justify-content:center;}
.proof-grid--2{grid-template-columns:repeat(2,minmax(0,220px));justify-content:center;}

/* ---------- proof: FYP conveyor (counter + two counter-scrolling marquee rows) ---------- */
.proof-total{margin-top:22px;}
.proof-total strong{
  display:inline-block;font-weight:900;color:var(--accent);line-height:1;
  font-size:clamp(34px,5vw,56px);letter-spacing:-.02em;
  font-variant-numeric:tabular-nums;  /* fixed digit width: no jitter while counting */
}
.proof-total span{display:block;margin-top:8px;color:#c9cec5;font-weight:700;font-size:12px;letter-spacing:.14em;}

/* full bleed to the box's inner edge; fade via mask so the lime grid motif
   shows through (overlay gradients would paint grey bars over it) */
.feed-row{
  margin:26px calc(-1 * var(--proofpad)) 0;
  overflow:hidden;padding-block:6px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.feed-row + .feed-row{margin-top:14px;}
/* --n (cards per copy) comes inline from Blade: duration scales with count so
   drift speed is constant (~one card width per 4.5s) at 3 or 30 items */
.feed-track{display:flex;width:max-content;animation:feed-scroll calc(var(--n) * 4.5s) linear infinite;}
.feed-row--rev .feed-track{animation-direction:reverse;animation-duration:calc(var(--n) * 4.5s * 1.15);}
.feed-row:focus-within .feed-track,
.feed-row.is-paused .feed-track{animation-play-state:paused;}
@keyframes feed-scroll{to{transform:translateX(-50%);}}
/* gap and padding-right must stay equal or the -50% loop point shows a seam */
.feed-copy{display:flex;gap:14px;padding-right:14px;}
.feed-card{
  position:relative;flex:0 0 var(--feed-w,clamp(124px,36vw,160px));
  aspect-ratio:9/15;border-radius:14px;overflow:hidden;
  display:flex;align-items:flex-end;background:var(--white);
  box-shadow:0 0 0 1px rgba(255,255,255,.06);
  user-select:none;-webkit-user-drag:none;
  transition:transform .25s ease, box-shadow .25s ease;
}
.feed-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;-webkit-user-drag:none;}
.feed-card .views{position:relative;z-index:3;margin:0 0 12px 12px;font-weight:800;color:#0a0b0a;font-size:13px;background:#fff;padding:2px 6px;border-radius:5px;}
.feed-card:hover,.feed-card:focus-visible{
  transform:scale(1.04);
  box-shadow:0 0 0 1.5px rgba(198,248,6,.7),0 0 24px rgba(198,248,6,.25);
}
/* hover-pause only for real pointers; iOS sticky :hover would freeze rows */
@media (hover:hover) and (pointer:fine){
  .feed-row:hover .feed-track{animation-play-state:paused;}
}

/* ---------- payment (3D coverflow slider) ---------- */
.pay{padding:30px 0;text-align:center;}
.pay .lbl{font-weight:800;color:#e9ece6;font-size:clamp(18px,4.4vw,22px);margin-bottom:4px;}
.pay h2{font-weight:900;color:var(--accent);font-size:clamp(28px,7vw,40px);letter-spacing:-.02em;}

/* Coverflow: a center card with neighbours tilted in 3D, straight over the dark page bg.
   Per-slider sizing comes from inline --cf-w / --cf-h custom props in the blade. */
.cf{
  --cf-shift:76%;      /* how far the side cards sit from centre (× their own width) */
  --cf-rot:40deg;      /* 3D hinge angle of the side cards */
  --cf-dur:.7s;
  position:relative;margin-top:28px;
  display:flex;align-items:center;justify-content:center;
  isolation:isolate;overflow:hidden;            /* clip the overflowing far slides */
  padding:clamp(18px,3vw,30px) 0;
}
/* per-section card size (kept in CSS so desktop media overrides aren't beaten by inline styles) */
.pay .cf{--cf-w:clamp(185px,56vw,300px);--cf-h:calc(var(--cf-w) * 5 / 4);}  /* payment proof: 4:5 */

.cf-viewport{
  position:relative;z-index:1;
  width:min(100%,calc(var(--cf-w) * 2.7));
  height:calc(var(--cf-h) * 1.18);
  perspective:1300px;
  display:grid;place-items:center;
  touch-action:pan-y;                            /* let the page scroll vertically; we capture horizontal */
}
.cf-track{position:relative;width:var(--cf-w);height:var(--cf-h);transform-style:preserve-3d;}
.cf-slide{
  position:absolute;inset:0;width:var(--cf-w);height:var(--cf-h);
  transform-style:preserve-3d;cursor:pointer;
  transition:transform var(--cf-dur) cubic-bezier(.4,.08,.2,1),
             filter var(--cf-dur) ease,opacity var(--cf-dur) ease;
  will-change:transform;
}
.cf-slide[data-state="current"]{transform:translateX(0) scale(1.12);filter:brightness(1);cursor:default;}
.cf-slide[data-state="next"]{transform:translateX(var(--cf-shift)) rotateY(calc(-1 * var(--cf-rot))) scale(.95);filter:brightness(.5);}
.cf-slide[data-state="prev"]{transform:translateX(calc(-1 * var(--cf-shift))) rotateY(var(--cf-rot)) scale(.95);filter:brightness(.5);}
.cf-slide[data-state="far-next"]{transform:translateX(calc(var(--cf-shift) * 1.7)) rotateY(calc(-1 * var(--cf-rot))) scale(.85);filter:brightness(.35);opacity:0;}
.cf-slide[data-state="far-prev"]{transform:translateX(calc(var(--cf-shift) * -1.7)) rotateY(var(--cf-rot)) scale(.85);filter:brightness(.35);opacity:0;}

.cf-slide-in{
  position:relative;width:100%;height:100%;border-radius:16px;overflow:hidden;
  background:#11130f;box-shadow:0 30px 60px -22px rgba(0,0,0,.75);
  transform:rotateX(var(--tiltX,0deg)) rotateY(var(--tiltY,0deg));
  transition:transform .25s ease;
}
.cf-media{position:absolute;inset:0;}
.cf-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.cf-cap{
  position:absolute;left:0;right:0;bottom:0;z-index:2;padding:42px 18px 16px;text-align:left;
  background:linear-gradient(to top,rgba(0,0,0,.82),rgba(0,0,0,.35) 55%,transparent);
  opacity:0;transition:opacity .4s ease;
}
.cf-slide[data-state="current"] .cf-cap{opacity:1;transition:opacity .5s ease .25s;}
.cf-cap span{display:block;font-weight:800;font-size:clamp(15px,4.4vw,20px);color:#fff;letter-spacing:-.01em;line-height:1.2;}

.cf-nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:46px;height:46px;border-radius:999px;display:grid;place-items:center;cursor:pointer;
  background:rgba(10,11,10,.5);border:1px solid rgba(255,255,255,.18);color:#fff;
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  transition:background .2s ease,color .2s ease,border-color .2s ease,transform .2s ease;
}
.cf-nav:hover{background:var(--accent);color:#0a0b0a;border-color:transparent;}
.cf-nav:active{transform:translateY(-50%) scale(.92);}
.cf-nav svg{width:24px;height:24px;}
.cf-prev{left:max(8px,2vw);}
.cf-next{right:max(8px,2vw);}

@media (prefers-reduced-motion: reduce){
  .cf-slide{transition-duration:.001ms;}
  .cf-slide-in{transition-duration:.001ms;}
}

/* empty-slot placeholders (no CRUD image yet) */
.slot{position:absolute;inset:0;display:grid;place-items:center;gap:8px;
  background:repeating-linear-gradient(135deg,#eef0ea 0 10px,#e7e9e2 10px 20px);
  color:#9aa39a;font-weight:800;font-size:12px;letter-spacing:.02em;text-align:center;padding:8px;}
.slot svg{width:30px;height:30px;opacity:.7;}
.proof-card .slot,.feed-card .slot{background:#e6e7e2;}   /* light grey placeholder, like production */
.proof-card .slot .play-circle,.feed-card .slot .play-circle{width:48px;height:48px;border-radius:999px;background:#2b2e28;display:grid;place-items:center;}
.proof-card .slot .play-circle svg,.feed-card .slot .play-circle svg{width:18px;height:18px;}

/* big decorative arrow behind lower sections */
.arrowfield{position:relative;}
.arrowfield::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background:
    linear-gradient(115deg, transparent 40%, rgba(154,224,34,.05) 41%, rgba(154,224,34,.05) 43%, transparent 44%),
    linear-gradient(115deg, transparent 52%, rgba(154,224,34,.05) 53%, rgba(154,224,34,.05) 55%, transparent 56%);
}
.arrowfield > *{position:relative;z-index:1;}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid rgba(255,255,255,.08);padding:30px 0 26px;text-align:center;color:#8b9285;font-size:12.5px;}
.site-footer .brandline{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;font-weight:600;}
.site-footer img{height:24px;width:auto;}
.foot-logo{font-family:var(--display);font-weight:900;font-size:15px;letter-spacing:-.02em;color:#f4f5f2;}
.foot-logo i{font-style:normal;font-weight:600;color:#8b9285;}
.site-footer .links{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:center;}
.site-footer a,.site-footer button{color:#8b9285;background:none;border:0;cursor:pointer;font:inherit;}
.site-footer a:hover,.site-footer button:hover{color:var(--accent);}


/* ---------- floating CTA (pill, bottom-right, all devices) ---------- */
/* below the cookie-consent banner (z-60): consent wins while open */
.float-cta{
  position:fixed;right:16px;bottom:calc(16px + env(safe-area-inset-bottom));z-index:59;
}
.float-cta a{
  display:flex;align-items:center;justify-content:center;gap:.5em;
  min-height:52px;padding:0 22px;border-radius:999px;background:var(--accent);color:#0a0b0a;
  font-weight:900;font-size:15px;text-decoration:none;
  box-shadow:0 10px 28px rgba(154,224,34,.35);
  transition:transform .15s ease;
}
.float-cta a:hover{transform:scale(1.04);}
.float-cta a .fc-ico{width:1.25em;height:1.25em;}
.float-cta--round a{width:56px;min-height:56px;padding:0;}
.float-cta--round a .fc-ico{width:24px;height:24px;}
/* keep content clear of the floating pill on small screens */
@media (max-width:1023px){ .landing{padding-bottom:88px;} }

/* ====================================================================
   RESPONSIVE — tablet / laptop / desktop
==================================================================== */
@media (min-width:600px){
  :root{--maxw:720px;--pad:34px;}
  .nav-tag{font-size:12px;}
  .why-card li{font-size:18px;}
  .dont{grid-template-columns:1fr 1fr;}
  .proof-grid{gap:20px;}
  .dont li{font-size:16px;}
  /* tablet: spread the coverflow side cards a little wider */
  .cf{--cf-shift:80%;--cf-rot:42deg;}
  /* tablet: more room — talent taller but still fully inside the card */
  .hero-card{min-height:480px;}
  .hero-photo{width:48%;height:82%;}
}

@media (min-width:1024px){
  :root{--maxw:1080px;--pad:48px;}
  .topbar{padding-top:40px;}
  .nav{padding:14px 22px 14px 14px;gap:20px;}
  .logo{padding:7px 18px;}
  .logo img{height:20px;}
  .nav-tag{font-size:12px;}

  .hero{padding:24px 0 52px;}
  .hero-inner{position:relative;}
  .hero-card{width:100%;padding:20px 24px 40px;min-height:560px;border-radius:46px;display:block;}
  .hero-copy{width:58%;margin-top:46px;padding:0 24px;}
  /* talent fully wrapped inside the card: anchored bottom-right, clipped by the rounded card.
     height < 100% keeps her head off the top edge and the overall figure smaller. */
  .hero-photo{position:absolute;right:1%;bottom:0;width:46%;height:82%;}
  .talent{height:100%;width:auto;}
  .hero h1{font-size:clamp(50px,5vw,76px);}
  .hero-kicker{font-size:18px;}

  .sec{padding:48px 0;}
  .why{padding-top:40px;}
  .why-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:40px;align-items:center;}
  .why-h{margin-bottom:0;}
  .why-card{padding:40px 38px;}
  .why-card li{font-size:20px;}

  .nfe{padding:70px 0 56px;}
  .nfe-sub{margin:34px 0 30px;}
  .dont{max-width:840px;gap:22px 60px;}
  .dont li{font-size:18px;}

  .proof{padding:54px 0 20px;}
  .proof-grid{max-width:880px;margin-left:auto;margin-right:auto;gap:26px;}
  .proof .sub{font-size:18px;}
  .feed-row{
    --feed-w:176px;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
            mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
  }
  .feed-copy{gap:18px;padding-right:18px;}  /* keep equal: loop seam */

  .pay{padding:54px 0;}
  /* desktop: larger centre card, side cards fanned wider */
  .cf{--cf-shift:86%;--cf-rot:44deg;}
  .pay .cf{--cf-w:clamp(250px,23vw,330px);--cf-h:calc(var(--cf-w) * 5 / 4);}

}

@media (min-width:1440px){
  :root{--maxw:1240px;--pad:60px;}
  .hero h1{font-size:80px;}
  .hero-card{min-height:600px;}
  .sec-h{font-size:46px;}
  .why-card li{font-size:21px;}
}

/* ============================ FOR CLIENT / BRAND ============================ */
/* Sits between the proof (Bukti Nyata) and payment sections, on the global .atmos.
   The header lives in a compact ringed panel (.fb-herobox) mirroring the .proof-box
   treatment (grain texture instead of the lime grid) so the two read as siblings;
   the process / comparison / CTA flow open below. Note the intentional divergence:
   .fb-herobox uses a film-grain ::before + an opaque dark gradient background, while
   .proof-box uses the lime line-grid + a semi-transparent background — these are
   siblings with deliberate visual differences, not copies of each other. */
.brandblk{padding:clamp(40px,7vw,72px) 0;}

/* (a) header box — sibling of the Bukti Nyata proof-box */
.fb-herobox{position:relative;overflow:hidden;text-align:center;border-radius:clamp(24px,3vw,34px);background:linear-gradient(180deg,#121212,#0d0e0d);box-shadow:inset 0 0 0 1px rgba(198,248,6,.15);padding:clamp(30px,4vw,52px) clamp(16px,3vw,40px) clamp(34px,4vw,50px);}
.fb-herobox::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%27200%27 height=%27200%27%3E%3Cfilter id=%27n%27%3E%3CfeTurbulence type=%27fractalNoise%27 baseFrequency=%270.85%27 numOctaves=%272%27 stitchTiles=%27stitch%27/%3E%3C/filter%3E%3Crect width=%27100%25%27 height=%27100%25%27 filter=%27url(%23n)%27/%3E%3C/svg%3E");background-size:180px 180px;opacity:.05;mix-blend-mode:screen;}
.fb-herobox::after{content:"";position:absolute;left:50%;top:-16%;width:62%;height:64%;transform:translateX(-50%);z-index:0;pointer-events:none;background:radial-gradient(closest-side,rgba(198,248,6,.20),transparent 72%);}
.fb-herobox > *{position:relative;z-index:1;}

/* logo strip (inside the header box) */
.logos{margin:0 0 clamp(24px,3.5vw,34px);padding-bottom:clamp(20px,3vw,28px);border-bottom:1px solid rgba(198,248,6,.12);}
.logos-eyebrow{display:flex;align-items:center;justify-content:center;gap:clamp(12px,2vw,18px);margin:0 0 clamp(18px,2.6vw,24px);text-align:center;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.22em;}
.logos-eyebrow::before,.logos-eyebrow::after{content:"";height:1px;flex:0 1 clamp(20px,5vw,48px);background:rgba(154,224,34,.32);}
.logo-marquee{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);}
.logo-track{display:flex;width:max-content;animation:logo-scroll 38s linear infinite;}
@media (hover:hover) and (pointer:fine){.logo-marquee:hover .logo-track{animation-play-state:paused;}}
.logo-marquee:focus-within .logo-track{animation-play-state:paused;}
@keyframes logo-scroll{to{transform:translateX(-50%);}}
.logo-group{display:flex;align-items:center;gap:clamp(40px,6vw,64px);padding-right:clamp(40px,6vw,64px);list-style:none;margin:0;}
.logo-group--static{flex-wrap:wrap;justify-content:center;padding-right:0;row-gap:clamp(16px,2.6vw,22px);}
.logo-item{display:flex;align-items:center;}
.logo-item img{height:clamp(40px,8vw,52px);width:auto;max-width:min(200px,60vw);object-fit:contain;filter:brightness(0) invert(1);opacity:.65;transition:opacity .25s;}
.logo-item a:hover img,.logo-item:hover img{opacity:1;}

/* header copy (lime headline echoes the Bukti Nyata headline) */
.fb-eyebrow{display:inline-block;color:var(--accent);font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;}
.fb-h2{color:var(--accent);font-weight:900;letter-spacing:-.02em;line-height:1.06;font-size:clamp(28px,5.6vw,42px);max-width:20ch;margin:0 auto;}
.fb-hl{border-bottom:2px solid rgba(154,224,34,.5);}
.fb-intro{margin:16px auto 0;max-width:60ch;color:#c9cec5;font-weight:500;font-size:clamp(14px,1.7vw,16px);line-height:1.65;}

/* (b) open content below the box */
.forbrand{margin:0 auto;}
.fb-kicker{display:flex;align-items:center;gap:10px;margin:clamp(36px,5vw,56px) 0 clamp(18px,2.5vw,24px);color:var(--muted);font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;}
.fb-kicker::before{content:"";width:8px;height:8px;border-radius:2px;background:var(--accent);flex:none;box-shadow:0 0 12px rgba(154,224,34,.5);}
.fb-kicker::after{content:"";height:1px;flex:1;background:var(--line);}

/* steps — 2-col grid of open cards */
.fb-steps{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:0;}
.fb-step{background:rgba(16,18,16,.6);border:1px solid rgba(198,248,6,.1);border-radius:18px;padding:clamp(20px,3vw,28px);transition:transform .2s ease,box-shadow .2s ease;}
.fb-step:hover{transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,0,0,.4),0 0 0 1px rgba(198,248,6,.18);}
.fb-step-num{display:block;color:var(--accent);font-weight:900;font-size:clamp(26px,3.4vw,36px);letter-spacing:-.03em;line-height:1;}
.fb-step h3{margin:10px 0 8px;color:#fff;font-weight:800;font-size:clamp(15px,1.9vw,18px);letter-spacing:-.01em;line-height:1.3;}
.fb-step p{margin:0;color:var(--muted);font-size:13.5px;line-height:1.62;}

/* comparison — 3 open cards, winner highlighted */
.fb-compare{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.fb-card{background:rgba(16,18,16,.6);border:1px solid rgba(198,248,6,.1);border-radius:18px;padding:clamp(20px,2.6vw,26px);transition:transform .2s ease;}
.fb-card:hover{transform:translateY(-2px);}
.fb-card-tag{display:inline-block;background:var(--accent);color:var(--accent-ink);font-size:9px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;padding:3px 9px;border-radius:999px;margin:0 0 10px;}
.fb-card-name{color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin:0 0 10px;}
.fb-card-price{color:#fff;font-weight:900;font-size:clamp(20px,3vw,26px);letter-spacing:-.02em;line-height:1.1;margin:0 0 6px;}
.fb-card-unit{color:var(--muted);font-size:12px;line-height:1.5;margin:0;}
.fb-card--win{border-color:rgba(154,224,34,.5);box-shadow:0 0 28px rgba(154,224,34,.08),inset 0 0 0 1px rgba(154,224,34,.12);}
.fb-card--win .fb-card-price{color:var(--accent);}
.fb-footnote{margin:10px 0 0;color:var(--muted);font-style:italic;font-size:11.5px;}

/* CTA — consultative card */
.fb-cta{margin-top:clamp(36px,5vw,54px);}
.fb-cta-card{text-align:center;border:1px solid rgba(198,248,6,.12);border-radius:22px;background:rgba(14,16,14,.7);padding:clamp(28px,4vw,44px) clamp(20px,4vw,52px);}
.fb-cta-eyebrow{display:inline-block;color:var(--accent);font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;margin-bottom:12px;}
.fb-cta-h2{margin:0 auto 12px;max-width:26ch;color:#fff;font-weight:900;letter-spacing:-.02em;line-height:1.2;font-size:clamp(22px,3.6vw,30px);}
.fb-cta-sub{margin:0 auto 22px;max-width:48ch;color:var(--muted);font-size:clamp(13px,1.6vw,15px);line-height:1.6;}
.fb-cta-chips{list-style:none;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:0 0 24px;padding:0;}
.fb-cta-chip{border:1px solid rgba(154,224,34,.28);border-radius:999px;padding:5px 14px;font-size:12px;font-weight:500;color:#c9cec5;}
.fb-cta-btn{display:inline-block;background:var(--accent);color:var(--accent-ink);font-weight:800;font-size:15px;letter-spacing:-.01em;text-decoration:none;padding:14px 30px;border-radius:999px;box-shadow:0 10px 30px rgba(154,224,34,.2);transition:transform .2s,box-shadow .2s;}
.fb-cta-btn:hover{transform:translateY(-2px);box-shadow:0 14px 38px rgba(154,224,34,.34);}

@media (min-width:1024px){
  .logo-item img{height:56px;}
}
@media (max-width:760px){
  .fb-steps{grid-template-columns:1fr;}
  .fb-compare{grid-template-columns:1fr;}
}

@media (prefers-reduced-motion:reduce){ .landing *{transition:none!important;animation:none!important;} }

/* reduced motion: the global rule above already stops the marquee; turn the
   rows into manually swipeable snap rows and hide the loop duplicates */
@media (prefers-reduced-motion:reduce){
  .feed-track{width:auto;}
  .feed-row{overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;}
  .feed-row::-webkit-scrollbar{display:none;}
  .feed-card{scroll-snap-align:center;}
  [data-dup]{display:none;}
}

/* reduced motion: stop the logo marquee and let it wrap into a static centred row */
@media (prefers-reduced-motion:reduce){
  .logo-track{width:auto;flex-wrap:wrap;justify-content:center;row-gap:18px;}
  .logo-marquee{overflow:visible;-webkit-mask-image:none;mask-image:none;}
  .logo-track [data-dup]{display:none;}
}
