/* ============================================================
   WDB v2 — Award-tier shared design + motion system
   Locked palette: white #ffffff / greige #f0ede7 / ink #11100e
   ============================================================ */
:root{
  --bg:#ffffff; --greige:#f0ede7; --greige-deep:#e7e1d4; --paper:#faf8f4;
  --ink:#11100e; --ink-soft:#37332d; --muted:#6c665b; --line:#ddd6c8; --line-strong:#bfb6a4;
  --maxw:1360px; --gutter:clamp(20px,4.5vw,80px);
  --serif:"Fraunces","Playfair Display",Georgia,serif;
  --sans:"Inter","Helvetica Neue",Arial,sans-serif;
  --mono:"IBM Plex Mono","SF Mono",ui-monospace,monospace;
  --expo:cubic-bezier(.16,1,.3,1);
  --power:cubic-bezier(.6,.01,.05,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.6;font-weight:400;overflow-x:hidden}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.serif{font-family:var(--serif)} .mono{font-family:var(--mono)}
h1,h2,h3{font-family:var(--serif);font-weight:430;line-height:1.0;letter-spacing:-.018em}
.eyebrow{font-family:var(--mono);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.lead{font-size:clamp(1.05rem,1.4vw,1.3rem);line-height:1.5;color:var(--ink-soft)}

/* ---------- buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.7em;font-family:var(--mono);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;padding:1.1em 1.7em;border:1px solid var(--ink);overflow:hidden;cursor:pointer;background:transparent;color:var(--ink);transition:color .5s var(--expo)}
.btn span{position:relative;z-index:2}
.btn::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s var(--expo);z-index:1}
.btn:hover{color:#fff}.btn:hover::before{transform:translateY(0)}
.btn--solid{background:var(--ink);color:#fff}
.btn--solid::before{background:var(--paper)}.btn--solid:hover{color:var(--ink)}
.btn .arr{transition:transform .5s var(--expo)} .btn:hover .arr{transform:translate(4px,-4px)}

/* ---------- mask reveal (line) ---------- */
.reveal-line{display:block;overflow:hidden}
.reveal-line>*{display:block;transform:translateY(100%);transition:transform 1s var(--expo)}
.is-in .reveal-line>*{transform:translateY(0)}
/* generic fade-rise */
.rise{opacity:1;transform:none}
.js .rise{opacity:0;transform:translateY(26px);transition:opacity .9s var(--expo),transform .9s var(--expo)}
.js .is-in .rise,.js .rise.is-in{opacity:1;transform:none}
/* char split */
.char{display:inline-block;transform:translateY(110%);transition:transform .8s var(--expo)}
.is-in .char{transform:translateY(0)}

/* ---------- image mask reveal ---------- */
.imgmask{position:relative;overflow:hidden}
.imgmask>img,.imgmask>video{transition:transform 1.4s var(--expo);transform:scale(1.12)}
.imgmask::after{content:"";position:absolute;inset:0;background:var(--greige);transform:scaleY(1);transform-origin:bottom;transition:transform 1.1s var(--power)}
.is-in .imgmask>img,.is-in .imgmask>video,.imgmask.is-in>img,.imgmask.is-in>video{transform:scale(1)}
.is-in .imgmask::after,.imgmask.is-in::after{transform:scaleY(0)}

/* ---------- before/after hover wipe (still pairs) ---------- */
.ba-hover{position:relative;overflow:hidden;cursor:ew-resize}
.ba-hover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba-hover .after{clip-path:inset(0 0 0 0)}
.ba-hover .before{clip-path:inset(0 0 0 100%);transition:clip-path .15s linear}
.ba-hover:hover .before{clip-path:inset(0 0 0 50%)}
/* drag-functional before/after (with [data-ba]) */
[data-ba]{cursor:ew-resize}
[data-ba] .before{transition:none}
[data-ba] .ba-handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;z-index:4;box-shadow:0 0 0 1px rgba(0,0,0,.15),0 0 18px rgba(0,0,0,.25);transform:translateX(-1px)}
[data-ba] .ba-handle::after{content:"⇆";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:#fff;color:var(--ink);display:grid;place-items:center;font-size:.9rem;box-shadow:0 6px 20px rgba(0,0,0,.25)}
.ba-hover .ba-tag{position:absolute;top:12px;z-index:3;font-family:var(--mono);font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.7)}
.ba-hover .ba-tag.b{left:12px}.ba-hover .ba-tag.a{right:12px}

/* ---------- film grain ---------- */
.grain::before{content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.04;mix-blend-mode:multiply;
 background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* Custom cursor intentionally removed: keep native pointer/drag cursors for WDB restraint. */

/* ---------- video hero ---------- */
.vhero{position:relative;height:100svh;min-height:600px;overflow:hidden;background:var(--ink)}
.vhero video,.vhero .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vhero .poster{z-index:1;transition:opacity 1.2s var(--expo)}
.vhero.video-ready .poster{opacity:0}
.vhero video{z-index:0}
.vhero .scrim{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(17,16,14,.34),rgba(17,16,14,.12) 38%,rgba(17,16,14,.06) 60%,rgba(17,16,14,.55))}

/* ---------- reduced motion / no-js safety ---------- */
.no-js .reveal-line>*,.no-js .char{transform:none}
.no-js .imgmask>img,.no-js .imgmask>video{transform:none}
.no-js .imgmask::after{display:none}
.no-js .rise{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  *{transition-duration:.001ms!important;animation-duration:.001ms!important}
  .reveal-line>*,.char{transform:none!important}
  .imgmask>img,.imgmask>video{transform:none!important}.imgmask::after{display:none!important}
  .rise{opacity:1!important;transform:none!important}
}

/* mock chrome */
.mockbar{position:fixed;top:0;left:0;right:0;z-index:10000;background:var(--ink);color:#fff;font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;display:flex;justify-content:space-between;gap:10px}
.mockbar a{color:#fff;opacity:.6}.mockbar a:hover{opacity:1}
