/* ============================================================
   NoCodeZilla — Design System
   Vivid green · near-black · cool light blue-gray · bold geometric type
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Manrope:wght@400;500;600;700;800&family=Unbounded:wght@500;600;700;800&family=IBM+Plex+Sans:wght@400;500;600;700&display=swap');

/* ============================================================
   Tokens
   ============================================================ */
:root{
  /* brand */
  --accent:        #1db90a;
  --accent-600:    #169a08;
  --accent-700:    #117a06;
  --accent-soft:   #e9fae4;
  --accent-glow:   rgba(29,185,10,.30);

  --ink:           #0a0a0c;   /* dark sections */
  --ink-2:         #161618;   /* dark alt */
  --ink-grid:      rgba(255,255,255,.04);

  --surface:       #ffffff;
  --surface-alt:   #f5f5f7;   /* apple light gray */
  --surface-2:     #fbfbfd;

  --text:          #1d1d1f;   /* apple near-black */
  --text-2:        #6e6e73;
  --muted:         #86868b;
  --muted-d:       #a1a1a6;   /* muted on dark */
  --line:          rgba(0,0,0,.08);
  --line-d:        rgba(255,255,255,.12);

  /* tweakable */
  --radius:        18px;
  --fs:            17px;       /* base font size */
  --density:       1;          /* section padding multiplier */
  --font-head:     'Manrope', system-ui, sans-serif;
  --font-body:     'Manrope', system-ui, sans-serif;

  /* derived */
  --r-sm: calc(var(--radius) * .5);
  --r-lg: calc(var(--radius) * 1.5);
  --r-pill: 999px;
  --maxw: 1200px;
  --gut: 24px;
  --sec: calc(104px * var(--density));
  --shadow-sm: 0 1px 2px rgba(0,0,0,.05), 0 2px 10px rgba(0,0,0,.04);
  --shadow:    0 6px 20px rgba(0,0,0,.06), 0 24px 60px rgba(0,0,0,.08);
  --shadow-lg: 0 16px 40px rgba(0,0,0,.08), 0 50px 110px rgba(0,0,0,.12);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ============================================================
   Reset
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:var(--fs);
  line-height:1.6;
  color:var(--text);
  background:var(--surface);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:800;line-height:1.05;margin:0;letter-spacing:-.025em}
p{margin:0}
::selection{background:var(--accent);color:#fff}

/* ============================================================
   Layout helpers
   ============================================================ */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.wrap-wide{max-width:1340px;margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:var(--sec)}
.section-sm{padding-block:calc(var(--sec) * .62)}
.bg-alt{background:var(--surface-alt)}
.bg-2{background:var(--surface-2)}
.bg-ink{background:var(--ink);color:#fff}
.bg-ink h1,.bg-ink h2,.bg-ink h3{color:#fff}

.grid{display:grid;gap:28px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}

/* dark section grid texture */
.ink-grid{position:relative;isolation:isolate}
.ink-grid::before{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background-image:linear-gradient(var(--ink-grid) 1px,transparent 1px),
                   linear-gradient(90deg,var(--ink-grid) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(120% 90% at 30% 10%,#000 35%,transparent 85%);
          mask-image:radial-gradient(120% 90% at 30% 10%,#000 35%,transparent 85%);
}

/* ============================================================
   Typography utilities
   ============================================================ */
.eyebrow{
  font-family:var(--font-body);
  font-weight:600;font-size:.92rem;letter-spacing:.01em;
  color:var(--accent-600);display:inline-flex;align-items:center;gap:0;
}
.bg-ink .eyebrow{color:var(--accent)}
.display{font-size:clamp(3rem,8vw,6.4rem);letter-spacing:-.045em;line-height:.95;font-weight:800}
.h-xl{font-size:clamp(2.3rem,5.2vw,4rem);letter-spacing:-.035em}
.h-lg{font-size:clamp(1.8rem,3.6vw,2.8rem);letter-spacing:-.03em}
.h-md{font-size:clamp(1.3rem,2vw,1.7rem);letter-spacing:-.02em}
.lead{font-size:clamp(1.15rem,1.7vw,1.45rem);color:var(--text-2);line-height:1.5;max-width:46ch;font-weight:500}
.bg-ink .lead{color:var(--muted-d)}
.muted{color:var(--muted)}
.accent{color:var(--accent-600)}
.bg-ink .accent{color:var(--accent)}
.text-balance{text-wrap:balance}
.mono{font-family:'IBM Plex Mono',monospace;font-feature-settings:"tnum"}

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-body);font-weight:600;font-size:1rem;
  padding:13px 26px;border-radius:var(--r-pill);border:0;
  transition:transform .18s var(--ease),box-shadow .25s var(--ease),background .2s,opacity .2s;
  white-space:nowrap;
}
.btn-lg{padding:16px 34px;font-size:1.08rem}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 20px var(--accent-glow)}
.btn-primary:hover{background:var(--accent-600);transform:translateY(-2px);box-shadow:0 10px 28px var(--accent-glow)}
.btn-primary:active{transform:translateY(0)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--ink-2);transform:translateY(-2px)}
.btn-ghost{background:rgba(0,0,0,.05);border:0;color:var(--text)}
.btn-ghost:hover{background:rgba(0,0,0,.09);transform:translateY(-2px)}
.bg-ink .btn-ghost{background:rgba(255,255,255,.1);color:#fff}
.bg-ink .btn-ghost:hover{background:rgba(255,255,255,.16)}
.btn-arrow{transition:transform .2s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(4px)}
.link-arrow{display:inline-flex;align-items:center;gap:6px;font-weight:600;color:var(--accent-600)}
.link-arrow svg{transition:transform .2s var(--ease)}
.link-arrow:hover svg{transform:translateX(4px)}

/* apple-style chevron text link */
.chev{display:inline-flex;align-items:center;gap:5px;font-weight:600;font-size:1.12rem;color:var(--accent-600);transition:color .2s}
.chev svg{transition:transform .2s var(--ease)}
.chev:hover{color:var(--accent-700)}
.chev:hover svg{transform:translateX(3px)}
.bg-ink .chev{color:var(--accent)}

/* ============================================================
   Header / Nav (injected)
   ============================================================ */
.nav{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.72);
  -webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.nav.scrolled{border-color:var(--line)}
.nav-inner{max-width:1180px;margin-inline:auto;padding:11px var(--gut);
  display:flex;align-items:center;gap:24px}
.logo{font-family:var(--font-head);font-weight:800;font-size:1.4rem;letter-spacing:-.04em;
  display:inline-flex;align-items:center;color:var(--text);flex:none}
.logo .g{color:var(--accent)}
.logo .dino{color:var(--accent);font-size:.78em;margin-left:1px;transform:translateY(-1px)}
.nav-links{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}
.nav-links a{padding:8px 15px;border-radius:var(--r-pill);font-weight:500;font-size:.95rem;
  color:var(--text-2);transition:color .18s,background .18s;position:relative}
.nav-links a:hover{color:var(--text);background:rgba(0,0,0,.04)}
.nav-links a.active{color:var(--text);font-weight:600}
.nav-right{display:flex;align-items:center;gap:12px;flex:none}
.lang{display:inline-flex;border:1px solid var(--line);border-radius:var(--r-pill);overflow:hidden;font-weight:600;font-size:.78rem}
.lang button{background:transparent;border:0;padding:6px 11px;color:var(--muted);transition:.18s}
.lang button.on{background:var(--text);color:#fff}
.nav-right .btn{padding:9px 18px;font-size:.92rem}
.nav-burger{display:none;background:transparent;border:0;width:42px;height:42px;border-radius:var(--r-sm)}
.nav-burger span{display:block;width:20px;height:2px;background:var(--text);margin:5px auto;border-radius:2px;transition:.25s}
.nav.open .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .nav-burger span:nth-child(2){opacity:0}
.nav.open .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer — hidden on desktop */
.nav-mobile{display:none}

@media (max-width:980px){
  .nav-links,.nav-right .btn{display:none}
  .nav-burger{display:block}
  .nav-right{margin-left:auto}
  .nav-mobile{position:fixed;inset:60px 0 auto 0;background:rgba(255,255,255,.96);
    -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);
    padding:14px var(--gut) 26px;flex-direction:column;gap:4px;box-shadow:var(--shadow);z-index:199;
    max-height:calc(100vh - 60px);overflow:auto}
  .nav.open .nav-mobile{display:flex;animation:slideDown .28s var(--ease)}
  .nav-mobile a{padding:13px 12px;font-weight:600;font-size:1.12rem;border-radius:var(--r-sm);color:var(--text)}
  .nav-mobile a:hover{background:var(--surface-alt)}
  .nav-mobile .btn{display:inline-flex;margin-top:10px;align-self:flex-start}
}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ============================================================
   Side CTA tab (brand signature)
   ============================================================ */
.side-cta{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:150;
  background:var(--accent);color:#fff;font-weight:700;font-size:.92rem;letter-spacing:.02em;
  writing-mode:vertical-rl;padding:18px 11px;border-radius:14px 0 0 14px;
  box-shadow:-6px 8px 24px var(--accent-glow);transition:transform .2s var(--ease),background .2s}
.side-cta:hover{background:var(--accent-600);transform:translateY(-50%) translateX(-3px)}
@media (max-width:980px){.side-cta{display:none}}

/* ============================================================
   Cards
   ============================================================ */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card-pad{padding:26px}
.card-media{aspect-ratio:16/10;overflow:hidden;background:var(--surface-2);position:relative}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.card:hover .card-media img{transform:scale(1.05)}

.tag{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:.74rem;
  letter-spacing:.04em;text-transform:uppercase;padding:6px 11px;border-radius:var(--r-pill);
  background:var(--accent-soft);color:var(--accent-700)}
.tag.neutral{background:rgba(15,23,42,.05);color:var(--text-2)}
.bg-ink .tag.neutral{background:rgba(255,255,255,.08);color:var(--muted-d)}

/* placeholder media */
.ph{position:relative;background:
   repeating-linear-gradient(135deg,var(--surface-2) 0 11px,#eef2f8 11px 22px);
   display:grid;place-items:center;color:var(--muted);overflow:hidden}
.ph span{font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.04em;
  background:rgba(255,255,255,.78);padding:5px 11px;border-radius:var(--r-pill)}
.bg-ink .ph{background:repeating-linear-gradient(135deg,#23262f 0 11px,#1d2029 11px 22px);color:var(--muted-d)}
.bg-ink .ph span{background:rgba(0,0,0,.4)}

/* ============================================================
   Reveal on scroll
   ============================================================ */
html.js [data-reveal]{opacity:0;transform:translateY(26px);
  transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js [data-reveal].in{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.08s}
[data-reveal-delay="2"]{transition-delay:.16s}
[data-reveal-delay="3"]{transition-delay:.24s}
[data-reveal-delay="4"]{transition-delay:.32s}
[data-reveal-delay="5"]{transition-delay:.40s}
@media (prefers-reduced-motion:reduce){
  html.js [data-reveal]{opacity:1;transform:none;transition:none}
}

/* page enter / exit transition */
.page-main{animation:pageIn .5s var(--ease) both}
@keyframes pageIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
body.leaving .page-main{opacity:0;transform:translateY(-8px);transition:opacity .2s,transform .2s}

/* ============================================================
   Footer (injected)
   ============================================================ */
.footer{background:var(--ink);color:#fff}
.footer-top{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:40px;
  padding-block:64px;border-bottom:1px solid var(--line-d)}
.footer .logo{color:#fff}
.footer-col h4{font-family:var(--font-body);font-weight:700;font-size:.8rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted-d);margin-bottom:16px}
.footer-col a{display:block;padding:6px 0;color:rgba(255,255,255,.82);font-weight:500;transition:color .18s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:center;
  padding-block:26px;color:var(--muted-d);font-size:.9rem}
.footer-cta{max-width:34ch;color:var(--muted-d);margin:18px 0 22px}
.soc{display:flex;gap:10px}
.soc a{width:40px;height:40px;border-radius:var(--r-sm);border:1px solid var(--line-d);
  display:grid;place-items:center;color:#fff;transition:.2s}
.soc a:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-2px)}
@media (max-width:820px){.footer-top{grid-template-columns:1fr 1fr;gap:30px}}
@media (max-width:520px){.footer-top{grid-template-columns:1fr}}

/* ============================================================
   Process / numbered list
   ============================================================ */
.steps{display:grid;gap:2px}
.step{display:grid;grid-template-columns:minmax(190px,260px) 1fr;gap:40px;
  padding:30px 0;border-top:1px solid var(--line-d);align-items:start}
.step:last-child{border-bottom:1px solid var(--line-d)}
.step-h{display:flex;align-items:baseline;gap:14px;font-family:var(--font-head);font-weight:700;font-size:1.6rem}
.step-n{color:var(--accent);font-variant-numeric:tabular-nums}
.step p{color:var(--muted-d);max-width:52ch}
@media (max-width:680px){.step{grid-template-columns:1fr;gap:10px}}

/* stat */
.stat{display:flex;flex-direction:column;gap:4px}
.stat .num{font-family:var(--font-head);font-weight:700;font-size:clamp(2rem,4vw,2.9rem);letter-spacing:-.03em}
.stat .lbl{color:var(--muted);font-size:.95rem;font-weight:600;white-space:nowrap}
.bg-ink .stat .lbl{color:var(--muted-d)}

/* horizontal stat row (page heroes) */
.trust{display:flex;flex-wrap:wrap;align-items:flex-start;gap:24px 48px}
@media (max-width:560px){.trust{gap:20px 32px}}

/* FAQ */
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:transparent;border:0;text-align:left;display:flex;gap:20px;
  align-items:center;justify-content:space-between;padding:24px 0;font-family:var(--font-head);
  font-weight:600;font-size:clamp(1.05rem,1.7vw,1.3rem);color:var(--ink)}
.faq-ic{flex:none;width:36px;height:36px;border-radius:var(--r-pill);background:rgba(15,23,42,.05);
  display:grid;place-items:center;transition:.25s;position:relative}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;background:var(--ink);border-radius:2px;transition:.25s}
.faq-ic::before{width:14px;height:2px}
.faq-ic::after{width:2px;height:14px}
.faq-item.open .faq-ic{background:var(--accent)}
.faq-item.open .faq-ic::before,.faq-item.open .faq-ic::after{background:#fff}
.faq-item.open .faq-ic::after{transform:rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-a-in{padding:0 56px 26px 0;color:var(--text-2);max-width:62ch}

/* form */
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.field label{font-weight:600;font-size:.9rem;color:var(--muted-d)}
.bg-ink .field input,.bg-ink .field textarea{
  background:transparent;border:0;border-bottom:1.5px solid rgba(255,255,255,.25);
  color:#fff;padding:11px 2px;font-family:inherit;font-size:1.05rem;outline:none;transition:border-color .2s}
.bg-ink .field input:focus,.bg-ink .field textarea:focus{border-color:var(--accent)}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.35)}

/* chips / filters */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{padding:9px 18px;border-radius:var(--r-pill);border:1.5px solid var(--line);
  background:#fff;font-weight:600;font-size:.92rem;color:var(--text-2);transition:.18s}
.chip:hover{border-color:var(--ink)}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}

/* breadcrumb */
.crumb{display:flex;gap:9px;align-items:center;font-size:.9rem;color:var(--muted);font-weight:600}
.crumb a:hover{color:var(--accent-600)}
.crumb .sep{opacity:.5}

/* avatar */
.avatar{border-radius:var(--radius);overflow:hidden;background:var(--surface-2);aspect-ratio:1/1}
.avatar img{width:100%;height:100%;object-fit:cover}

/* prose (articles) */
.prose{max-width:72ch}
.prose p{margin:0 0 22px;color:var(--text-2);font-size:1.12rem;line-height:1.72}
.prose h2{font-size:clamp(1.5rem,2.6vw,2rem);margin:46px 0 18px}
.prose h3{font-size:1.35rem;margin:34px 0 14px}
.prose ul{margin:0 0 22px;padding-left:0;list-style:none;display:grid;gap:12px}
.prose ul li{position:relative;padding-left:30px;color:var(--text-2);font-size:1.08rem}
.prose ul li::before{content:"";position:absolute;left:6px;top:11px;width:8px;height:8px;
  border-radius:2px;background:var(--accent);transform:rotate(45deg)}
.prose blockquote{margin:32px 0;padding:6px 0 6px 28px;border-left:3px solid var(--accent);
  font-family:var(--font-head);font-weight:500;font-size:1.4rem;line-height:1.4;color:var(--ink)}
.prose img,.prose .ph{border-radius:var(--r-lg);margin:32px 0}
.prose figcaption{color:var(--muted);font-size:.9rem;margin-top:-18px;margin-bottom:32px}

/* utility spacing */
.mt-0{margin-top:0}.mt-1{margin-top:12px}.mt-2{margin-top:20px}.mt-3{margin-top:32px}.mt-4{margin-top:48px}.mt-5{margin-top:72px}
.mb-1{margin-bottom:12px}.mb-2{margin-bottom:20px}.mb-3{margin-bottom:32px}.mb-4{margin-bottom:48px}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-1{gap:12px}.gap-2{gap:20px}.gap-3{gap:32px}.wrap-gap{flex-wrap:wrap}
.center{text-align:center}.mx-auto{margin-inline:auto}
.section-head{max-width:62ch}
.section-head.center{margin-inline:auto;text-align:center}

@media (max-width:860px){
  .cols-3,.cols-4{grid-template-columns:repeat(2,1fr)}
  :root{--sec:calc(72px * var(--density))}
}
@media (max-width:560px){
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr}
  :root{--gut:18px}
}

/* ============================================================
   Apple-style hero
   ============================================================ */
.hero-apple{padding-top:clamp(44px,7vw,92px);padding-bottom:clamp(36px,5vw,64px);text-align:center;overflow:hidden}
.hero-apple .eyebrow{justify-content:center}
.hero-tagline{font-family:var(--font-head);font-weight:600;letter-spacing:-.03em;line-height:1.12;
  font-size:clamp(1.5rem,3.4vw,2.7rem);color:var(--text-2);max-width:22ch;margin:16px auto 0;text-wrap:balance}
.hero-tagline b{color:var(--text);font-weight:700}
.hero-actions-c{display:flex;justify-content:center;align-items:center;gap:14px 28px;flex-wrap:wrap;margin-top:30px}
.trust-c{display:flex;justify-content:center;flex-wrap:wrap;gap:20px 56px;margin-top:50px}
.trust-c .stat{align-items:center;text-align:center}

/* ---- product stage + no-code builder mockup (replaces hero image) ---- */
.stage{position:relative;margin:clamp(38px,5vw,64px) auto 0;width:min(1000px,100%);display:flex;justify-content:center}
.stage::before{content:"";position:absolute;inset:-14% -4% -34% -4%;z-index:-1;border-radius:50%;
  background:radial-gradient(58% 56% at 50% 38%,var(--accent-soft),transparent 70%);opacity:.75}
.builder{width:100%;background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;
  box-shadow:0 40px 90px rgba(0,0,0,.16);animation:floaty 7s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media (prefers-reduced-motion:reduce){.builder{animation:none}}
.b-bar{display:flex;align-items:center;gap:12px;padding:13px 18px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.b-dots{display:flex;gap:7px;flex:none}
.b-dot{width:12px;height:12px;border-radius:50%}
.b-dot:nth-child(1){background:#ff5f57}.b-dot:nth-child(2){background:#febc2e}.b-dot:nth-child(3){background:#28c840}
.b-url{flex:1;max-width:300px;height:30px;border-radius:9px;background:#fff;border:1px solid var(--line);
  margin-inline:auto;display:flex;align-items:center;justify-content:center;gap:7px;font-size:.82rem;color:var(--muted);font-weight:500}
.b-tag{flex:none;font-size:.76rem;font-weight:600;color:var(--accent-700);background:var(--accent-soft);padding:6px 13px;border-radius:999px}
.b-body{display:grid;grid-template-columns:184px 1fr 196px;min-height:392px}
.b-rail,.b-props{padding:18px 16px;background:#fff;display:flex;flex-direction:column;gap:11px}
.b-rail{border-right:1px solid var(--line)}
.b-props{border-left:1px solid var(--line)}
.b-cap{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.b-item{display:flex;align-items:center;gap:11px}
.b-ico{width:30px;height:30px;border-radius:9px;background:var(--surface-alt);flex:none;display:grid;place-items:center;color:var(--text-2)}
.b-item .ln{height:9px;border-radius:5px;background:var(--surface-alt);flex:1}
.b-item.live .b-ico{background:var(--accent);color:#fff}
.b-canvas{background:var(--surface-2);padding:26px;display:flex;flex-direction:column;gap:15px;align-items:stretch}
.b-blk{background:#fff;border:1px solid var(--line);border-radius:12px}
.b-blk.h{height:30px;width:60%;background:var(--text);border:0}
.b-blk.t{height:52px;position:relative;overflow:hidden}
.b-blk.t::after{content:"";position:absolute;left:16px;right:32%;top:13px;height:8px;border-radius:5px;background:var(--surface-alt);box-shadow:0 16px 0 var(--surface-alt)}
.b-blk.img{height:118px;background:repeating-linear-gradient(135deg,#eef0f4 0 10px,#f6f7f9 10px 20px)}
.b-sel{position:relative;outline:2px solid var(--accent);outline-offset:3px}
.b-cta-blk{align-self:flex-start;background:var(--accent);color:#fff;font-weight:600;font-size:.9rem;padding:11px 22px;border-radius:10px}
.b-prop{display:flex;flex-direction:column;gap:7px}
.b-prop .ln{height:9px;border-radius:5px;background:var(--surface-alt)}
.b-prop .box{height:28px;border-radius:8px;border:1px solid var(--line);background:#fff}
.b-sw{display:flex;gap:8px}
.b-sw i{width:22px;height:22px;border-radius:6px;display:block}
.b-sw i:nth-child(1){background:var(--accent)}.b-sw i:nth-child(2){background:var(--text)}
.b-sw i:nth-child(3){background:#febc2e}.b-sw i:nth-child(4){background:#0a84ff}
@media (max-width:760px){.b-rail,.b-props{display:none}.b-body{grid-template-columns:1fr}.b-canvas{min-height:300px}}

/* floating chips around stage */
.stage-chip{position:absolute;z-index:2;background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow);padding:11px 16px;display:flex;align-items:center;gap:10px;font-weight:600;font-size:.92rem;
  animation:chipFloat 6s ease-in-out infinite}
.stage-chip .d{width:9px;height:9px;border-radius:50%;background:var(--accent)}
.stage-chip.c1{top:14%;left:-3%;animation-delay:.4s}
.stage-chip.c2{top:62%;right:-4%;animation-delay:1.4s}
.stage-chip.c3{bottom:-4%;left:18%;animation-delay:2.2s}
@keyframes chipFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@media (max-width:760px){.stage-chip{display:none}}
@media (prefers-reduced-motion:reduce){.stage-chip{animation:none}}

/* ============================================================
   Bento grid (Apple-style feature tiles)
   ============================================================ */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.bento .tile{grid-column:span 2;background:var(--surface-alt);border-radius:24px;padding:34px;overflow:hidden;
  position:relative;min-height:300px;display:flex;flex-direction:column;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.bento .tile:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.bento .tile.wide{grid-column:span 3}
.bento .tile.full{grid-column:span 6;min-height:240px}
.bento .tile.dark{background:var(--ink);color:#fff}
.bento .tile.accent{background:linear-gradient(150deg,var(--accent),var(--accent-700));color:#fff}
.tile .t-ico{width:52px;height:52px;border-radius:14px;background:#fff;color:var(--accent-700);display:grid;place-items:center;margin-bottom:auto;box-shadow:var(--shadow-sm)}
.tile.dark .t-ico,.tile.accent .t-ico{background:rgba(255,255,255,.14);color:#fff;box-shadow:none}
.tile h3{font-size:1.5rem;margin-top:20px;letter-spacing:-.02em}
.tile p{margin-top:8px;color:var(--text-2);font-size:1.02rem}
.tile.dark p,.tile.accent p{color:rgba(255,255,255,.82)}
.tile .t-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.tile .t-tags span{font-family:'IBM Plex Mono',monospace;font-size:.74rem;color:var(--text-2);background:rgba(0,0,0,.05);padding:4px 9px;border-radius:7px}
.tile.dark .t-tags span,.tile.accent .t-tags span{background:rgba(255,255,255,.14);color:#fff}
.tile .big-num{font-family:var(--font-head);font-weight:800;font-size:clamp(3rem,6vw,5rem);letter-spacing:-.04em;line-height:1}
@media (max-width:860px){.bento{grid-template-columns:repeat(2,1fr)}
  .bento .tile,.bento .tile.wide,.bento .tile.full{grid-column:span 1;min-height:260px}
  .bento .tile.full{grid-column:span 2}}
@media (max-width:560px){.bento{grid-template-columns:1fr}.bento .tile.full{grid-column:span 1}}

/* ============================================================
   Scroll & entrance animation utilities
   ============================================================ */
html.js [data-anim]{opacity:0;will-change:transform,opacity}
html.js [data-anim].in{opacity:1}
[data-anim="up"]{transform:translateY(40px)}
[data-anim="up"].in{transform:none;transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-anim="scale"]{transform:scale(.92)}
[data-anim="scale"].in{transform:none;transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-anim="blur"]{filter:blur(14px);transform:translateY(30px)}
[data-anim="blur"].in{filter:blur(0);transform:none;transition:opacity 1s var(--ease),transform 1s var(--ease),filter 1s var(--ease)}
[data-d="1"]{transition-delay:.08s}[data-d="2"]{transition-delay:.16s}[data-d="3"]{transition-delay:.24s}
[data-d="4"]{transition-delay:.32s}[data-d="5"]{transition-delay:.4s}[data-d="6"]{transition-delay:.48s}
@media (prefers-reduced-motion:reduce){
  html.js [data-anim]{opacity:1!important;transform:none!important;filter:none!important;transition:none!important}
}

/* word-by-word headline reveal */
.reveal-words .w{display:inline-block;opacity:0;transform:translateY(30px) rotate(2deg);
  transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-words.in .w{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal-words .w{opacity:1;transform:none}}

/* scroll-driven progress accent (used on dark sections) */
.scrub-line{height:3px;background:var(--line-d);border-radius:3px;overflow:hidden;position:relative}
.scrub-line i{position:absolute;inset:0;background:var(--accent);transform-origin:left;transform:scaleX(var(--p,0))}

/* sticky scroll-telling section */
.sticky-wrap{position:relative}
.sticky-media{position:sticky;top:90px}

/* marquee logos refinement */
.kpi-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 22px}
.kpi-strip .k{background:var(--surface-alt);border-radius:var(--r-pill);padding:10px 20px;font-weight:600;color:var(--text-2);font-size:.96rem}
.kpi-strip .k b{color:var(--text)}

/* magnetic CTA band */
.cta-band{background:var(--ink);border-radius:32px;padding:clamp(40px,6vw,80px);text-align:center;position:relative;overflow:hidden;color:#fff}
.cta-band::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 120% at 50% 120%,var(--accent-glow),transparent 60%);opacity:.6;pointer-events:none}
.cta-band h2,.cta-band .lead{position:relative;z-index:1}
