  :root{
    --paper:#F4F1EA;
    --paper-2:#ECE6D9;
    --card:#FBFAF6;
    --ink:#15130F;
    --ink-soft:#5A554B;
    --blue:#2840FF;
    --blue-deep:#1422B0;
    --lime:#CCFF47;
    --line:rgba(21,19,15,0.12);
    --line-soft:rgba(21,19,15,0.07);
    --shadow:14px 18px 0 rgba(21,19,15,1);
    --r:22px;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  /* Paper grain is baked into the body background via background-blend-mode
     instead of a fixed mix-blend-mode overlay. A fixed blend layer forces the
     whole viewport to re-composite every animation frame and was dropping a
     frame (the page blanked) while the card wall scrolled. Here the blend is
     resolved during body's own paint — no extra layer, no blank. */
  body{
    background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.25'/%3E%3C/svg%3E"),var(--paper);
    background-blend-mode:multiply;
    color:var(--ink);
    font-family:"Hanken Grotesk",sans-serif;
    font-size:18px;line-height:1.5;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  .display{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;line-height:.94;letter-spacing:-.03em}
  .wrap{max-width:1240px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
  a{color:inherit;text-decoration:none}

  /* ---------- buttons ---------- */
  .btn{
    display:inline-flex;align-items:center;gap:10px;
    font-family:"Hanken Grotesk";font-weight:700;font-size:17px;
    padding:16px 26px;border-radius:100px;border:2px solid var(--ink);
    cursor:pointer;transition:transform .18s cubic-bezier(.3,1.4,.5,1),box-shadow .18s,background .18s;
    white-space:nowrap;
  }
  .btn-primary{background:var(--blue);color:#fff;box-shadow:5px 6px 0 var(--ink)}
  .btn-primary:hover{transform:translate(-2px,-2px);box-shadow:8px 10px 0 var(--ink)}
  .btn-ghost{background:transparent;color:var(--ink);box-shadow:5px 6px 0 transparent}
  .btn-ghost:hover{background:var(--lime);transform:translate(-2px,-2px);box-shadow:5px 6px 0 var(--ink)}
  .btn .arr{transition:transform .2s}
  .btn:hover .arr{transform:translateX(4px)}

  /* ---------- nav ---------- */
  header{position:sticky;top:0;z-index:50;backdrop-filter:blur(8px);
    background:rgba(244,241,234,.78);border-bottom:1px solid var(--line-soft)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:92px}
  /* === LOGO === */
  .logo{display:flex;align-items:center}
  .logo img{height:64px;width:auto;display:block}
  .foot-brand .logo img{filter:brightness(0) invert(1)} /* turns the same logo white for the dark footer */
  .nav-links{display:flex;align-items:center;gap:34px;font-weight:600;font-size:16px}
  .nav-links a{position:relative;color:var(--ink-soft);transition:color .2s}
  .nav-links a:hover{color:var(--ink)}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:3px;background:var(--blue);transition:width .25s}
  .nav-links a:hover::after{width:100%}
  .nav-cta{display:flex;align-items:center;gap:14px}
  .menu-btn{display:none}

  /* ---------- hero ---------- */
  .hero{padding:70px 0 40px;position:relative}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
  h1.hero-h{font-size:clamp(46px,7vw,92px)}
  .hero-sub{font-size:clamp(18px,1.4vw,21px);color:var(--ink-soft);max-width:520px;margin:30px 0 38px;font-weight:500}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
  .hero-note{margin-top:24px;font-size:15px;color:var(--ink-soft);font-weight:600;display:flex;align-items:center;gap:10px}
  .hero-note .tick{color:var(--blue)}

  /* hero visual — tilted browser card */
  .hero-visual{position:relative}
  .browser{background:var(--card);border:2px solid var(--ink);border-radius:18px;
    box-shadow:var(--shadow);overflow:hidden;transform:rotate(2.2deg);position:relative;z-index:2}
  .browser-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:2px solid var(--ink);background:var(--paper-2)}
  .browser-bar i{width:12px;height:12px;border-radius:50%;border:1.5px solid var(--ink);display:block}
  .browser-bar i:nth-child(1){background:#FF6B5E}.browser-bar i:nth-child(2){background:var(--lime)}.browser-bar i:nth-child(3){background:var(--blue)}
  .browser-url{margin-left:12px;background:var(--paper);border:1.5px solid var(--ink);border-radius:100px;
    padding:5px 14px;font-size:12px;font-weight:600;color:var(--ink-soft);flex:1}
  .site{padding:22px}
  .site-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
  .site-logo{width:74px;height:14px;background:var(--ink);border-radius:5px}
  .site-nav span{display:flex;gap:9px}
  .site-nav span b{width:34px;height:8px;background:var(--line);border-radius:5px;display:block}
  .site-hero{height:118px;border-radius:12px;border:2px solid var(--ink);
    background:linear-gradient(120deg,var(--blue),var(--blue-deep));position:relative;overflow:hidden;margin-bottom:16px}
  .site-hero::after{content:"";position:absolute;right:-30px;top:-30px;width:130px;height:130px;border-radius:50%;background:var(--lime);opacity:.9}
  .site-hero b{position:absolute;left:18px;top:26px;width:130px;height:13px;background:#fff;border-radius:6px;display:block;opacity:.95}
  .site-hero b+b{top:48px;width:90px;opacity:.7}
  .site-hero em{position:absolute;left:18px;bottom:18px;width:78px;height:24px;background:var(--lime);border:1.5px solid var(--ink);border-radius:100px;display:block}
  .site-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:11px}
  .site-cards div{height:54px;border-radius:9px;border:1.5px solid var(--ink);background:var(--paper-2)}
  .site-cards div:nth-child(2){background:var(--lime)}
  /* floating chips */
  .chip{position:absolute;z-index:3;background:var(--card);border:2px solid var(--ink);
    border-radius:100px;padding:10px 16px;font-weight:700;font-size:14px;box-shadow:5px 6px 0 var(--ink);
    display:flex;align-items:center;gap:8px}
  .chip .x{color:#FF6B5E;font-weight:800}
  .chip-1{top:-18px;left:-26px;transform:rotate(-6deg);animation:float 5s ease-in-out infinite}
  .chip-2{bottom:38px;left:-40px;transform:rotate(4deg);background:var(--lime);animation:float 6s ease-in-out infinite .6s}
  .chip-3{bottom:-16px;right:-10px;transform:rotate(-3deg);animation:float 5.5s ease-in-out infinite .3s}
  @keyframes float{0%,100%{translate:0 0}50%{translate:0 -10px}}

  /* ---------- scrolling website wall ---------- */
  .wall{position:relative;height:560px;display:grid;grid-template-columns:1fr 1fr;gap:16px;overflow:hidden}
  /* top/bottom fade as overlays instead of mask-image: a CSS mask forces an
     offscreen buffer that the browser periodically re-rasterises, which blanked
     the content for a frame. Overlays paint on top — no buffer, no blank.
     (position:absolute keeps these out of the 2-column grid.) */
  .wall::before,.wall::after{content:"";position:absolute;left:0;right:0;height:11%;z-index:3;pointer-events:none}
  .wall::before{top:0;background:linear-gradient(var(--paper),transparent)}
  .wall::after{bottom:0;background:linear-gradient(transparent,var(--paper))}
  /* will-change keeps each column on its own persistent compositor layer, so
     the browser doesn't tear it down and recreate it at the loop boundary
     (that recreation was the one-frame flick each cycle). This is safe now the
     fixed mix-blend-mode grain layer is gone; before, the two together blanked
     the page. */
  .wall-col{display:flex;flex-direction:column;will-change:transform;backface-visibility:hidden}
  .wall-col.up{animation:scrollUp 40s linear infinite}
  .wall-col.down{animation:scrollDown 40s linear infinite}
  .wall:hover .wall-col,
  .wall.is-paused .wall-col{animation-play-state:paused}
  /* two identical groups stacked; loop distance = the exact pixel gap between
     them, measured in JS into --shift. A percentage (-50%) can land on a
     sub-pixel and jump one frame each cycle (the flick where the columns meet).
     --shift holds the negative px distance; -50% is just a pre-JS fallback. */
  @keyframes scrollUp{from{transform:translate3d(0,0,0)}to{transform:translate3d(0,var(--shift,-50%),0)}}
  @keyframes scrollDown{from{transform:translate3d(0,var(--shift,-50%),0)}to{transform:translate3d(0,0,0)}}
  @media(prefers-reduced-motion:reduce){.wall-col{animation:none !important;transform:none !important}}
  .wall-group{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}
  .mini{flex:none;border:2px solid var(--ink);border-radius:14px;overflow:hidden;background:var(--card)}
  .mini .bar{display:flex;gap:5px;padding:8px 11px;border-bottom:2px solid var(--ink)}
  .mini .bar i{width:7px;height:7px;border-radius:50%;background:var(--ink);opacity:.45}
  .mini .frame{height:230px;overflow:hidden}
  .mini img{display:block;width:100%;height:230px;object-fit:cover;object-position:top}
  /* ---------- sections ---------- */
  section{position:relative;z-index:2}
  .sec{padding:96px 0}
  .sec-head{max-width:680px;margin-bottom:54px}
  .kicker{font-weight:800;font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:16px}
  .sec-head h2{font-size:clamp(34px,4.6vw,60px)}
  .sec-head p{color:var(--ink-soft);font-size:19px;margin-top:18px;font-weight:500}

  /* features */
  .features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .feat{background:var(--card);border:2px solid var(--ink);border-radius:var(--r);padding:30px 26px;
    transition:transform .2s,box-shadow .2s}
  .feat:hover{transform:translate(-3px,-3px);box-shadow:8px 10px 0 var(--ink)}
  .feat .ic{width:52px;height:52px;border-radius:13px;border:2px solid var(--ink);display:grid;place-items:center;margin-bottom:20px;background:var(--paper-2)}
  .feat:nth-child(3n+1) .ic{background:var(--lime)}
  .feat:nth-child(3n+2) .ic{background:var(--blue);color:#fff}
  .feat .ic svg{width:26px;height:26px}
  .feat h3{font-family:"Bricolage Grotesque";font-weight:700;font-size:22px;letter-spacing:-.02em;margin-bottom:10px}
  .feat p{color:var(--ink-soft);font-size:16px;font-weight:500}

  /* shop / categories */
  .shop{background:var(--paper-2);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
  .shop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
  .tile{background:var(--card);border:2px solid var(--ink);border-radius:var(--r);overflow:hidden;
    transition:transform .2s,box-shadow .2s;cursor:pointer}
  .tile:hover{transform:translate(-3px,-3px);box-shadow:8px 10px 0 var(--ink)}
  .thumb{height:140px;border-bottom:2px solid var(--ink);position:relative;overflow:hidden;padding:16px}
  .thumb .bar{height:9px;border-radius:5px;background:rgba(21,19,15,.18);margin-bottom:7px}
  .thumb .bar.s{width:55%}.thumb .bar.t{width:38%}
  .thumb .block{position:absolute;bottom:14px;left:16px;right:16px;height:46px;border-radius:8px;border:1.5px solid var(--ink)}
  .tile:nth-child(4n+1) .thumb{background:linear-gradient(135deg,#FFE9D6,#FFD0B0)}
  .tile:nth-child(4n+1) .block{background:#FF8C5E}
  .tile:nth-child(4n+2) .thumb{background:linear-gradient(135deg,#DCE4FF,#B9C6FF)}
  .tile:nth-child(4n+2) .block{background:var(--blue)}
  .tile:nth-child(4n+3) .thumb{background:linear-gradient(135deg,#EBFFC2,var(--lime))}
  .tile:nth-child(4n+3) .block{background:#7FB300}
  .tile:nth-child(4n+4) .thumb{background:linear-gradient(135deg,#FFE0F0,#FFC2E0)}
  .tile:nth-child(4n+4) .block{background:#E85DA8}
  .tile-foot{padding:18px 20px;display:flex;align-items:center;justify-content:space-between}
  .tile-foot h4{font-family:"Bricolage Grotesque";font-weight:700;font-size:18px;letter-spacing:-.02em}
  .tile-foot small{display:block;color:var(--ink-soft);font-weight:600;font-size:13px;margin-top:3px}
  .tile-foot .go{width:34px;height:34px;border-radius:50%;border:2px solid var(--ink);display:grid;place-items:center;flex-shrink:0;transition:background .2s}
  .tile:hover .go{background:var(--lime)}

  /* steps */
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .step{position:relative;padding-top:14px}
  .step .num{font-family:"Bricolage Grotesque";font-weight:800;font-size:80px;color:transparent;
    -webkit-text-stroke:2px var(--ink);line-height:.8;letter-spacing:-.04em}
  .step h3{font-family:"Bricolage Grotesque";font-weight:700;font-size:24px;letter-spacing:-.02em;margin:14px 0 10px}
  .step p{color:var(--ink-soft);font-weight:500}

  /* comparison */
  .compare{background:var(--ink);color:var(--paper);border-radius:32px;padding:54px 48px;overflow:hidden;position:relative}
  .compare h2{font-size:clamp(30px,4vw,50px);color:#fff;max-width:560px;margin-bottom:38px}
  .compare h2 em{color:var(--lime);font-style:normal}
  .compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:2px solid rgba(255,255,255,.2);border-radius:18px;overflow:hidden}
  .col-head{padding:18px 26px;font-family:"Bricolage Grotesque";font-weight:700;font-size:20px;letter-spacing:-.02em;border-bottom:2px solid rgba(255,255,255,.2)}
  .col-head.them{color:rgba(255,255,255,.55)}
  .col-head.us{background:var(--blue);color:#fff}
  .crow{padding:16px 26px;border-bottom:1px solid rgba(255,255,255,.13);display:flex;align-items:center;gap:11px;font-weight:600;font-size:16px}
  .crow.them{color:rgba(255,255,255,.6)}
  .crow.us{background:rgba(40,64,255,.14)}
  .crow .m{color:#FF6B5E}.crow .c{color:var(--lime)}
  .compare-grid>div:last-child .crow:last-child,.compare-grid>div:nth-last-child(2) .crow:last-child{border-bottom:none}

  /* cta band */
  .cta-band{text-align:center;padding:110px 0}
  .cta-band h2{font-size:clamp(40px,6vw,82px);max-width:880px;margin:0 auto 20px}
  .cta-band h2 mark{background:var(--lime);color:var(--ink);padding:0 .1em;border-radius:8px}
  .cta-band p{color:var(--ink-soft);font-size:20px;font-weight:500;margin-bottom:36px}

  /* footer */
  footer{background:var(--ink);color:var(--paper);padding:70px 0 36px;position:relative;z-index:2}
  .foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.16)}
  .foot-brand p{color:rgba(255,255,255,.6);font-weight:500;margin-top:18px;max-width:300px}
  .foot-col h5{font-family:"Bricolage Grotesque";font-weight:700;font-size:15px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:18px}
  .foot-col a{display:block;color:rgba(255,255,255,.62);font-weight:500;margin-bottom:12px;transition:color .2s}
  .foot-col a:hover{color:var(--lime)}
  .foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:28px;color:rgba(255,255,255,.45);font-size:14px;font-weight:500;flex-wrap:wrap;gap:14px}

  /* reveal
   Content is visible by default. JavaScript may add .in, but visibility must
   never depend on it; otherwise the page can flash blank or stay hidden. */
.reveal,
.reveal.in{
  opacity:1 !important;
  transform:none !important;
  visibility:visible !important;
}

  /* responsive */
  @media(max-width:980px){
    .hero-grid{grid-template-columns:1fr;gap:60px}
    .features,.shop-grid,.steps{grid-template-columns:repeat(2,1fr)}
    .nav-links{display:none}
    .menu-btn{display:grid;place-items:center;width:46px;height:46px;border:2px solid var(--ink);border-radius:12px;background:var(--card);cursor:pointer}
    .compare-grid{grid-template-columns:1fr}
    .compare-grid .them{display:none}
    .foot-top{grid-template-columns:1fr 1fr}
  }
  @media(max-width:560px){
    .wrap{padding:0 20px}
    .features,.shop-grid,.steps{grid-template-columns:1fr}
    .nav-cta .btn-ghost{display:none}
    .compare{padding:36px 22px}
    .foot-top{grid-template-columns:1fr 1fr}
    .chip-2{display:none}
  }

/* =========================================================
   Mobile refinement pass — locked spacing, persistent header,
   smaller hero CTA, and cleaner phone layout.
   ========================================================= */
:root{
  --page-pad:clamp(20px,4vw,32px);
  --mobile-header-h:78px;
}

.wrap{padding-inline:var(--page-pad)}

.btn,
.btn-primary,
.btn-ghost,
.btn-primary:hover,
.btn-ghost:hover{
  box-shadow:none;
  transform:none;
}

.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-deep)}
.btn-ghost:hover{background:rgba(21,19,15,.04)}

@media(max-width:980px){
  header{position:sticky;top:0;z-index:80;background:rgba(244,241,234,.94);backdrop-filter:blur(12px)}
  .nav{height:var(--mobile-header-h);gap:12px}
  .logo{flex:0 0 auto}
  .logo img{height:50px}
  .nav-cta{margin-left:auto;gap:10px;flex:0 0 auto}
  .nav-cta .btn-ghost{display:none}
  .nav-cta .btn-primary{height:48px;padding:0 20px;font-size:15px;border-width:2px}

  .menu-btn{
    position:relative;display:grid;place-items:center;flex:0 0 52px;width:52px;height:52px;
    border:2px solid var(--ink);border-radius:16px;background:var(--card);cursor:pointer;
    font-size:0;color:transparent;line-height:0;overflow:hidden;
  }
  .menu-btn::before,.menu-btn::after{
    content:"";position:absolute;left:15px;right:15px;height:3px;border-radius:10px;background:var(--ink);
    transition:transform .22s ease,box-shadow .22s ease,top .22s ease;
  }
  .menu-btn::before{top:17px;box-shadow:0 8px 0 var(--ink)}
  .menu-btn::after{top:33px}
  .menu-btn.is-open::before{top:25px;transform:rotate(45deg);box-shadow:0 0 0 transparent}
  .menu-btn.is-open::after{top:25px;transform:rotate(-45deg)}

  .nav-links{
    display:flex;position:fixed;left:0;right:0;top:var(--mobile-header-h);bottom:0;z-index:70;
    flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;
    padding:42px var(--page-pad) 32px;background:var(--paper);
    border-top:1px solid var(--line-soft);
    opacity:0;visibility:hidden;pointer-events:none;transform:translateY(10px);
    transition:opacity .22s ease,transform .22s ease,visibility 0s linear .22s;
  }
  body.menu-open .nav-links{opacity:1;visibility:visible;pointer-events:auto;transform:none;transition-delay:0s}
  .nav-links a{font-family:"Bricolage Grotesque",sans-serif;font-size:clamp(36px,9vw,58px);line-height:.98;font-weight:800;letter-spacing:-.045em;color:var(--ink);padding:24px 0;border-bottom:1px solid var(--line)}
  .nav-links a::after{display:none}
}

@media(max-width:760px){
  .hero{padding:64px 0 46px}
  .hero-grid{gap:42px}
  h1.hero-h{font-size:clamp(56px,14.5vw,76px);line-height:.92;letter-spacing:-.055em;max-width:9ch}
  .hero-sub{font-size:clamp(19px,5.1vw,24px);line-height:1.45;max-width:31ch;margin:34px 0 34px;color:var(--ink-soft)}
  .hero-cta{width:100%;display:block}
  .hero-cta .btn-primary{width:100%;max-width:420px;height:64px;justify-content:center;padding:0 24px;font-size:18px;border-width:2px;border-radius:999px}
  .hero-note{margin-top:24px;font-size:16px;line-height:1.55;gap:8px 10px;flex-wrap:wrap;max-width:34ch}

  .wall{height:520px;gap:12px;margin-top:10px}
  .wall-group{gap:12px;margin-bottom:12px}
  .mini{border-width:2px;border-radius:14px}
  .mini .bar{padding:7px 9px}
  .mini .frame,.mini img{height:170px}
}

@media(max-width:560px){
  :root{--page-pad:24px;--mobile-header-h:78px}
  .wrap{padding-inline:var(--page-pad)}
  .nav{height:var(--mobile-header-h)}
  .logo img{height:48px}
  .nav-cta .btn-primary{height:46px;padding:0 18px;font-size:14px}
  .menu-btn{flex-basis:50px;width:50px;height:50px;border-radius:15px}

  .hero{padding:58px 0 40px}
  h1.hero-h{font-size:clamp(48px,13.4vw,64px);max-width:9.5ch}
  .hero-sub{font-size:20px;max-width:30ch;margin:30px 0 32px}
  .hero-cta .btn-primary{height:60px;font-size:17px;max-width:100%}
  .hero-note{font-size:15.5px;max-width:30ch;margin-top:22px}
  .wall{height:500px}
  .mini .frame,.mini img{height:150px}
}

@media(max-width:390px){
  :root{--page-pad:20px}
  .logo img{height:44px}
  .nav-cta .btn-primary{height:44px;padding:0 15px;font-size:13.5px}
  .menu-btn{flex-basis:46px;width:46px;height:46px;border-radius:14px}
  h1.hero-h{font-size:clamp(44px,13vw,56px)}
  .hero-sub{font-size:18px}
  .hero-cta .btn-primary{height:58px;font-size:16px}
}
