/* ============================================================
   L SQUARE — v2  "Modern" (Cover-inspired, original)
   Warm monochrome · Hanken Grotesk (Samara-style) · motion-forward
   ============================================================ */
/* Hanken Grotesk is loaded via a parallel <link> + preconnect in functions.php
   (faster than a render-blocking @import). */

:root{
  --paper:#FFFFFF;
  --paper-2:#F4F4F3;
  --paper-3:#EAEAE8;
  --ink:#1A1A1A;
  --ink-soft:#3B3B3A;
  --muted:#6F6F6D;
  --faint:#A6A6A3;
  --line:rgba(20,20,20,.12);
  --line-2:rgba(20,20,20,.06);
  --black:#141414;
  --on-black:#F4F4F2;
  --on-black-mut:#9A9A97;

  --maxw:1400px;
  --gutter:clamp(20px,4.5vw,64px);
  --sans:'Hanken Grotesk',-apple-system,system-ui,sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-io:cubic-bezier(.16,1,.3,1);
  --radius:18px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--paper);color:var(--ink);
  font-size:17px;line-height:1.55;font-weight:400;overflow-x:clip;
}
::selection{background:var(--ink);color:var(--paper)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.section{position:relative;padding-block:clamp(80px,11vw,160px)}

/* ---- type ---- */
h1,h2,h3,h4{font-weight:500;letter-spacing:-.025em;line-height:1.0}
.kicker{font-size:12.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.statement{
  font-size:clamp(30px,5.2vw,68px);line-height:1.04;letter-spacing:-.035em;font-weight:400;
  max-width:18ch;
}
.statement b{font-weight:600}
.statement .dim{color:var(--faint)}
.h-xl{font-size:clamp(42px,8vw,118px);line-height:.98;letter-spacing:-.045em;font-weight:500}
.h-lg{font-size:clamp(30px,4.4vw,58px);line-height:1.02;letter-spacing:-.035em;font-weight:500}
.h-md{font-size:clamp(22px,2.3vw,30px);line-height:1.1;letter-spacing:-.02em;font-weight:500}
.lead{font-size:clamp(18px,1.5vw,21px);line-height:1.5;color:var(--ink-soft);max-width:46ch}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--ink)}
.muted{color:var(--muted)}

/* ---- buttons (liquid glass) ---- */
.btn{
  position:relative;isolation:isolate;overflow:hidden;
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-weight:600;font-size:14.5px;letter-spacing:-.01em;
  padding:14px 26px;border-radius:980px;color:#1c1c1c;
  background:radial-gradient(80px circle at var(--mx,50%) var(--my,150%),rgba(255,255,255,.6),transparent 60%),linear-gradient(177deg, rgba(255,255,255,.92) 0%, rgba(247,247,247,.8) 50%, rgba(236,236,236,.72) 100%);
  -webkit-backdrop-filter:blur(12px) saturate(160%);backdrop-filter:blur(12px) saturate(160%);
  border:1px solid rgba(255,255,255,.85);
  box-shadow:
    0 22px 45px -14px rgba(0,0,0,.3),
    0 4px 10px -4px rgba(0,0,0,.16),
    inset 0 2px 3px rgba(255,255,255,.95),
    inset 0 -9px 15px -6px rgba(0,0,0,.09),
    inset 0 0 0 1px rgba(255,255,255,.4);
  transition:transform .3s var(--ease),box-shadow .4s var(--ease);
  white-space:nowrap;
}
.btn>span{position:relative;z-index:2}
.btn::after{
  content:attr(data-label);
  position:absolute;left:0;right:0;top:56%;z-index:1;pointer-events:none;
  text-align:center;font-weight:600;font-size:inherit;letter-spacing:-.01em;line-height:1;
  color:rgba(18,18,18,.1);filter:blur(1.5px);
}
.btn::before{
  content:"";position:absolute;top:0;bottom:0;left:-75%;width:55%;z-index:3;pointer-events:none;
  background:linear-gradient(100deg,transparent 0%,rgba(255,255,255,.2) 38%,rgba(255,255,255,.95) 50%,rgba(255,255,255,.2) 62%,transparent 100%);
  transform:skewX(-16deg);opacity:0;
}
@media (prefers-reduced-motion:no-preference){
  .btn:hover::before{animation:btnSheen .85s var(--ease)}
}
@keyframes btnSheen{0%{left:-75%;opacity:0}12%{opacity:1}100%{left:135%;opacity:0}}
.btn .ar{transition:transform .45s var(--ease)}
.btn:hover{transform:translateY(-2px);
  box-shadow:0 30px 58px -16px rgba(0,0,0,.34),0 6px 14px -4px rgba(0,0,0,.18),
    inset 0 2px 3px rgba(255,255,255,.95),inset 0 -9px 15px -6px rgba(0,0,0,.09),inset 0 0 0 1px rgba(255,255,255,.4)}
.btn:hover .ar{transform:translateX(4px)}
.btn:active{transform:translateY(0) scale(.985)}
.btn.lg{padding:18px 34px;font-size:16px}
/* secondary — clearer, more transparent glass */
.btn.ghost{color:var(--ink);
  background:radial-gradient(80px circle at var(--mx,50%) var(--my,150%),rgba(255,255,255,.5),transparent 60%),linear-gradient(177deg, rgba(255,255,255,.55) 0%, rgba(255,255,255,.3) 100%);
  border:1px solid rgba(255,255,255,.65);
  box-shadow:0 16px 34px -16px rgba(0,0,0,.22),inset 0 2px 2px rgba(255,255,255,.7),inset 0 0 0 1px rgba(255,255,255,.3)}
.btn.ghost::after{color:rgba(18,18,18,.07)}
.btn.ghost:hover{background:linear-gradient(177deg, rgba(255,255,255,.7), rgba(255,255,255,.45))}
/* on dark surfaces */
.btn.on-black{color:#fff;
  background:radial-gradient(80px circle at var(--mx,50%) var(--my,150%),rgba(255,255,255,.32),transparent 60%),linear-gradient(177deg, rgba(255,255,255,.24) 0%, rgba(255,255,255,.08) 100%);
  border:1px solid rgba(255,255,255,.38);
  box-shadow:0 20px 44px -16px rgba(0,0,0,.6),inset 0 2px 2px rgba(255,255,255,.4),inset 0 -8px 14px -6px rgba(0,0,0,.22),inset 0 0 0 1px rgba(255,255,255,.16)}
.btn.on-black::after{color:rgba(255,255,255,.12)}
.btn.on-black:hover{background:linear-gradient(177deg, rgba(255,255,255,.34), rgba(255,255,255,.14))}
.tlink{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:14.5px;position:relative;padding-bottom:3px}
.tlink::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:100%;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)}
.tlink:hover::after{transform:scaleX(1);transform-origin:left}
.tlink .ar{transition:transform .45s var(--ease)}
.tlink:hover .ar{transform:translateX(4px)}

/* ---- reveals ---- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s var(--ease-io),transform 1s var(--ease-io)}
.reveal.in{opacity:1;transform:none}
[data-stagger]>*{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease-io),transform .9s var(--ease-io)}
[data-stagger].in>*{opacity:1;transform:none}
.img-reveal{overflow:hidden}
.img-reveal>*{clip-path:inset(0 0 100% 0);transition:clip-path 1.2s var(--ease-io)}
.img-reveal.in>*{clip-path:inset(0 0 0 0)}
@media (prefers-reduced-motion:reduce){
  .reveal,[data-stagger]>*{opacity:1;transform:none}
  .img-reveal>*{clip-path:none}
}

image-slot{background:var(--paper-2);border-radius:var(--radius)}

/* ---- section dividers (draw-in on scroll) ---- */
.sdiv{position:absolute;top:0;left:50%;height:1px;z-index:5;
  width:min(var(--maxw,1400px),calc(100% - 2*var(--gutter)));
  background:var(--line);transform:translateX(-50%) scaleX(0);transform-origin:center;
  transition:transform 1.2s var(--ease)}
.sdiv.in{transform:translateX(-50%) scaleX(1)}
@media (prefers-reduced-motion:reduce){.sdiv{transition:none}}
