/* ==========================================================
   WAGS MEDIA — one-page cinematic portfolio
   Display: Archivo (expanded caps) · Statement: Newsreader italic
   Chrome: IBM Plex Mono · Accent: crimson
   ========================================================== */

:root{
  --black:#0d0b0a;
  --black-2:#161211;
  --bone:#ece5d8;
  --bone-2:#e0d7c7;
  --crimson:#a01f2d;
  --crimson-hot:#d02e3e;
  --smoke:#93877b;
  --line:rgba(236,229,216,.14);
  --line-d:rgba(13,11,10,.16);
  --pad:clamp(20px,5vw,80px);
  --maxw:1360px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--black);color:var(--bone);
  font-family:"Archivo",system-ui,sans-serif;
  font-variation-settings:"wdth" 100;
  font-size:clamp(15px,1.05vw,17px);line-height:1.65;font-weight:400;
  overflow-x:hidden;
}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:999;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

.display{font-family:"Archivo",sans-serif;font-variation-settings:"wdth" 122;font-weight:800;
  text-transform:uppercase;line-height:.9;letter-spacing:-.01em}
.mono{font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase}
.serif{font-family:"Newsreader",Georgia,serif;font-style:italic;font-weight:420}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}

/* progress bar */
#progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--crimson-hot);z-index:300}

/* ---------- nav ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px var(--pad);mix-blend-mode:difference}
.wordmark{font-family:"Archivo";font-variation-settings:"wdth" 125;font-weight:800;
  text-transform:uppercase;font-size:1rem;letter-spacing:.08em;color:#fff}
nav{display:flex;gap:26px}
nav a{font-family:"IBM Plex Mono",monospace;font-size:.68rem;letter-spacing:.16em;
  text-transform:uppercase;color:#fff;opacity:.7;transition:opacity .2s}
nav a:hover{opacity:1}
.est{font-family:"IBM Plex Mono",monospace;font-size:.68rem;letter-spacing:.16em;color:#fff;opacity:.7}
@media(max-width:960px){
  header{padding:12px 16px;flex-wrap:wrap;gap:8px}
  nav{gap:14px;flex-wrap:wrap;justify-content:flex-end;flex:1}
  nav a{font-size:.6rem;letter-spacing:.1em}
  .est{display:none}
}

/* ---------- hero / viewfinder ---------- */
.hero{position:relative;height:100svh;min-height:560px;overflow:hidden;background:#000}
.hero .media{position:absolute;inset:0;overflow:hidden}
.hero .media img{width:100%;height:100%;object-fit:cover;filter:brightness(.72) saturate(.92)}
.hero .media iframe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:max(105vw,187vh);height:max(105svh,60vw);
  pointer-events:none;opacity:0;transition:opacity 1.2s ease;filter:brightness(.72) saturate(.92);border:0}
.hero.playing .media iframe{opacity:1}
.hero .scrim{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(0,0,0,.42),transparent 32%,transparent 62%,rgba(0,0,0,.68))}
.bar{position:absolute;left:0;right:0;height:clamp(28px,5vh,54px);background:var(--black);z-index:6}
.bar.top{top:0}.bar.bot{bottom:0}

/* HUD */
.hud{position:absolute;inset:clamp(44px,8vh,80px) clamp(18px,3.5vw,52px);z-index:5;pointer-events:none}
.corner{position:absolute;width:26px;height:26px;border:1px solid rgba(236,229,216,.55)}
.corner.tl{top:0;left:0;border-right:0;border-bottom:0}
.corner.tr{top:0;right:0;border-left:0;border-bottom:0}
.corner.bl{bottom:0;left:0;border-right:0;border-top:0}
.corner.br{bottom:0;right:0;border-left:0;border-top:0}
.hud-row{position:absolute;left:0;right:0;display:flex;justify-content:space-between;align-items:center;color:rgba(236,229,216,.85)}
.hud-row.top{top:14px;padding:0 18px}
.hud-row.bot{bottom:14px;padding:0 18px}
.rec{display:flex;align-items:center;gap:8px}
.rec i{width:9px;height:9px;border-radius:50%;background:var(--crimson-hot);animation:blink 1.6s steps(2) infinite}
@keyframes blink{50%{opacity:.15}}
@media(prefers-reduced-motion:reduce){.rec i{animation:none}}

.hero-title{position:absolute;left:0;right:0;bottom:clamp(70px,14vh,130px);z-index:7;text-align:left}
.hero-title .kicker{color:var(--crimson-hot);margin-bottom:14px;display:inline-block;
  background:rgba(13,11,10,.6);padding:7px 12px;backdrop-filter:blur(2px)}
.hero-title h1{font-size:clamp(2.6rem,9.2vw,8.2rem);color:var(--bone)}
.hero-title h1 em{font-style:normal;color:transparent;-webkit-text-stroke:1.5px var(--bone)}
.hero-title p{max-width:56ch;margin-top:18px;color:rgba(236,229,216,.85);font-size:clamp(.95rem,1.2vw,1.1rem)}
.scroll-cue{position:absolute;bottom:calc(clamp(28px,5vh,54px) + 14px);right:var(--pad);z-index:7;
  color:var(--smoke);display:flex;align-items:center;gap:10px}
.scroll-cue span{display:inline-block;width:1px;height:38px;background:var(--smoke);
  animation:drop 1.8s ease-in-out infinite;transform-origin:top}
@keyframes drop{0%{transform:scaleY(0)}55%{transform:scaleY(1)}100%{transform:scaleY(0);transform-origin:bottom}}
@media(prefers-reduced-motion:reduce){.scroll-cue span{animation:none}}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;padding:16px 0;background:var(--black)}
.marquee .track{display:flex;gap:52px;white-space:nowrap;width:max-content;animation:slide 36s linear infinite}
@keyframes slide{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee .track{animation:none}}
.marquee span{font-family:"Archivo";font-variation-settings:"wdth" 122;font-weight:800;
  text-transform:uppercase;font-size:1rem;letter-spacing:.1em;color:var(--smoke)}
.marquee span b{color:var(--crimson-hot);font-weight:800;margin-right:52px}

/* ---------- sections ---------- */
section{padding-block:clamp(64px,10vw,140px)}
.paper{background:var(--bone);color:var(--black)}
.slate{display:flex;align-items:baseline;gap:18px;margin-bottom:clamp(30px,4.5vw,56px);
  border-bottom:1px solid var(--line);padding-bottom:16px}
.paper .slate{border-color:var(--line-d)}
.slate .no{font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.14em;color:var(--crimson-hot)}
.paper .slate .no{color:var(--crimson)}
.slate h2{font-size:clamp(1.9rem,4.6vw,3.6rem)}
.slate .take{margin-left:auto;font-family:"IBM Plex Mono",monospace;font-size:.66rem;
  letter-spacing:.14em;color:var(--smoke);text-transform:uppercase}
@media(max-width:640px){.slate .take{display:none}}

.statement{font-size:clamp(1.5rem,3.4vw,2.7rem);line-height:1.3;max-width:30ch}
.statement em{color:var(--crimson)}
.state-meta{margin-top:34px;display:flex;gap:40px;flex-wrap:wrap;color:#6c6157}
.state-meta div b{display:block;font-family:"IBM Plex Mono",monospace;font-size:.66rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--crimson);margin-bottom:6px;font-weight:400}

/* ---------- video ---------- */
.feature{position:relative;aspect-ratio:16/9;background:#000;overflow:hidden}
.feature iframe{width:100%;height:100%;border:0}
.vgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:8px}
@media(max-width:900px){.vgrid{grid-template-columns:repeat(2,1fr)}}
.vgrid .cell{aspect-ratio:16/9;background:#000}
.vgrid iframe{width:100%;height:100%;border:0}
.vcaps{margin-top:26px;display:flex;flex-wrap:wrap;gap:10px}
.vcaps span{font-family:"IBM Plex Mono",monospace;font-size:.66rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--smoke);border:1px solid var(--line);padding:8px 14px}

/* ---------- photography masonry ---------- */
.masonry{columns:3;column-gap:8px}
@media(max-width:900px){.masonry{columns:2}}
@media(max-width:540px){.masonry{columns:1}}
.masonry figure{break-inside:avoid;margin:0 0 8px;position:relative;overflow:hidden;cursor:zoom-in}
.masonry img{width:100%;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.masonry figure:hover img{transform:scale(1.03)}
.masonry figcaption{position:absolute;left:10px;bottom:8px;font-family:"IBM Plex Mono",monospace;
  font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;
  background:rgba(13,11,10,.62);padding:4px 8px;opacity:0;transition:opacity .25s}
.masonry figure:hover figcaption{opacity:1}
@media(prefers-reduced-motion:reduce){.masonry img{transition:none}}

/* lightbox */
#lb{position:fixed;inset:0;background:rgba(9,8,7,.94);z-index:400;display:none;
  align-items:center;justify-content:center;padding:4vmin;cursor:zoom-out}
#lb.open{display:flex}
#lb img{max-width:92vw;max-height:88vh;object-fit:contain}
#lb .x{position:absolute;top:20px;right:26px;color:var(--bone);font-family:"IBM Plex Mono",monospace;
  font-size:.8rem;letter-spacing:.2em;cursor:pointer;background:none;border:0}

/* ---------- filmstrip (real estate) ---------- */
.re-intro{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,70px);align-items:center;margin-bottom:clamp(28px,4vw,48px)}
@media(max-width:880px){.re-intro{grid-template-columns:1fr}}
.re-intro .media{aspect-ratio:4/3;overflow:hidden}
.re-intro .media img{width:100%;height:100%;object-fit:cover}
.strip{display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:14px;
  scrollbar-width:thin;scrollbar-color:var(--crimson) transparent}
.strip figure{flex:0 0 clamp(240px,30vw,420px);scroll-snap-align:start;position:relative;margin:0}
.strip img{width:100%;aspect-ratio:3/2;object-fit:cover}
.strip .fno{position:absolute;top:10px;left:10px;font-family:"IBM Plex Mono",monospace;
  font-size:.6rem;letter-spacing:.16em;color:#fff;background:rgba(13,11,10,.6);padding:3px 8px}
.strip-hint{font-family:"IBM Plex Mono",monospace;font-size:.64rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--smoke);margin-top:6px}

/* ---------- design grid ---------- */
.dgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
@media(max-width:900px){.dgrid{grid-template-columns:repeat(2,1fr)}}
.dgrid figure{margin:0;overflow:hidden;background:#fff;aspect-ratio:1/1;cursor:zoom-in}
.dgrid img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.dgrid figure:hover img{transform:scale(1.04)}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:start}
@media(max-width:820px){.about-grid{grid-template-columns:1fr}}
.about-grid .lede{font-size:clamp(1.1rem,1.7vw,1.35rem);line-height:1.55}
.facts{border-top:1px solid var(--line)}
.facts div{display:flex;justify-content:space-between;gap:20px;padding:16px 0;border-bottom:1px solid var(--line)}
.facts b{font-family:"IBM Plex Mono",monospace;font-size:.68rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--smoke);font-weight:400}
.facts span{text-align:right}

/* ---------- contact ---------- */
.contact{text-align:center}
.contact h2{font-size:clamp(2.4rem,8vw,6.5rem)}
.contact .mail{display:inline-block;margin-top:26px;font-family:"IBM Plex Mono",monospace;
  font-size:clamp(.9rem,1.6vw,1.15rem);letter-spacing:.12em;color:var(--bone);
  border:1px solid var(--line);padding:18px 34px;transition:.25s}
.contact .mail:hover{background:var(--crimson);border-color:var(--crimson);color:#fff}
.contact .area{margin-top:22px;color:var(--smoke)}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:26px var(--pad);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-family:"IBM Plex Mono",monospace;font-size:.66rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--smoke)}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

:focus-visible{outline:2px solid var(--crimson-hot);outline-offset:3px}

/* larger 2-col video grid */
.vgrid-2{grid-template-columns:repeat(2,1fr);margin-top:0}
@media(max-width:700px){.vgrid-2{grid-template-columns:1fr}}
