/* ============================================================
   RICHARD PERMIN — Freeskier · Image-maker
   Direction I · "Raw Cinematic" — production stylesheet
   Palette: warm off-white on near-black, signal-orange accent.
   ============================================================ */

:root{
  --bg:#0a0a0a;
  --bg2:#111111;
  --bg3:#0f0e0c;
  --ink:#f3efe6;        /* warm off-white */
  --ink-dim:#8a857a;
  --ink-soft:#cfcabe;
  --line:#252320;
  --line2:#1a1916;
  --accent:#ff4a17;     /* signal orange — search & rescue */
  --snow:#dde5e8;
  --mono:'JetBrains Mono','Geist Mono',ui-monospace,monospace;
  --display:'Funnel Display','Funnel Sans',system-ui,sans-serif;
  --body:'Funnel Sans',system-ui,sans-serif;
  --maxw:1680px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{
  background:var(--bg);color:var(--ink);
  font-family:var(--body);font-weight:300;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
body{overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--accent);color:#0a0a0a}

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

.skip-link{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--accent);color:#0a0a0a;padding:10px 16px;
  font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;
}
.skip-link:focus{left:8px;top:8px}

.mono{font-family:var(--mono);font-weight:500;letter-spacing:.04em;text-transform:uppercase;font-size:11px}
.display{font-family:var(--display);font-weight:800;line-height:.85;letter-spacing:-.04em}
hr{border:0;border-top:1px solid var(--line)}

/* ----- NAV ----- */
.nav{
  position:sticky;top:0;z-index:90;
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  background:rgba(10,10,10,.55);
  border-bottom:1px solid var(--line);
}
.nav-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px;padding:14px 28px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:22px;height:22px;border:1.5px solid var(--ink);position:relative;display:inline-block;flex:none}
.brand-mark::before{content:"";position:absolute;inset:3px;background:var(--accent)}
.brand-name{font-family:var(--display);font-weight:700;letter-spacing:.02em;font-size:14px;text-transform:uppercase}
.brand-name b{color:var(--accent)}
.nav-menu{display:flex;gap:28px;justify-content:center;list-style:none}
.nav-menu a{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);opacity:.78;display:inline-flex;align-items:center;gap:6px;transition:opacity .25s,color .25s}
.nav-menu a::before{content:"";width:4px;height:4px;background:var(--ink-dim);border-radius:50%;transition:background .25s,transform .25s}
.nav-menu a:hover{opacity:1;color:var(--accent)}
.nav-menu a:hover::before{background:var(--accent);transform:scale(1.6)}
.nav-right{display:flex;align-items:center;gap:18px}
.nav-meta{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim)}
.nav-cta{
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  border:1px solid var(--ink);padding:9px 14px;display:inline-flex;align-items:center;gap:8px;
  transition:background .2s,color .2s,border-color .2s;
}
.nav-cta:hover{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}
.nav-cta .dot{width:6px;height:6px;background:var(--accent);border-radius:50%;animation:pulse 1.6s infinite ease-in-out}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

.burger{display:none;flex-direction:column;gap:5px;padding:8px;z-index:120}
.burger span{width:22px;height:1.5px;background:var(--ink);transition:transform .3s,opacity .3s}
.nav.open .burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav.open .burger span:nth-child(2){opacity:0}
.nav.open .burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* mobile drawer */
.mobile-menu{
  position:fixed;inset:0;z-index:80;background:var(--bg);
  display:flex;flex-direction:column;justify-content:center;gap:6px;padding:28px;
  transform:translateY(-100%);transition:transform .45s cubic-bezier(.16,1,.3,1);
  visibility:hidden;
}
.mobile-menu.open{transform:translateY(0);visibility:visible}
.mobile-menu a{font-family:var(--display);font-weight:800;font-size:clamp(34px,9vw,56px);line-height:1.04;letter-spacing:-.03em;text-transform:uppercase;padding:6px 0;border-bottom:1px solid var(--line2)}
.mobile-menu a:hover,.mobile-menu a:focus-visible{color:var(--accent)}
.mobile-menu .mm-foot{margin-top:24px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim);display:flex;gap:18px;flex-wrap:wrap}
.mobile-menu .mm-foot a{font-family:var(--mono);font-size:11px;font-weight:500;border:0;padding:0}

/* ----- HERO ----- */
.hero{position:relative;height:min(92vh,920px);min-height:600px;overflow:hidden;border-bottom:1px solid var(--line)}
.hero-media{position:absolute;inset:0;will-change:transform}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:50% 34%;filter:contrast(1.05) saturate(.86) brightness(.74)}
.hero-media::after{content:"";position:absolute;inset:0;background:
  radial-gradient(120% 80% at 50% 100%,rgba(10,10,10,.85),rgba(10,10,10,0) 60%),
  linear-gradient(180deg,rgba(10,10,10,.55) 0%,rgba(10,10,10,0) 25%,rgba(10,10,10,0) 55%,rgba(10,10,10,.94) 100%);}
.hero-grain{position:absolute;inset:0;pointer-events:none;opacity:.16;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/></svg>");}
.hero-inner{position:relative;z-index:2;padding:clamp(28px,4vw,48px) 28px 36px;display:grid;grid-template-rows:1fr auto;height:100%;max-width:var(--maxw);margin:0 auto}
.hero-top{display:grid;grid-template-columns:1fr auto 1fr;align-items:start;gap:24px}
.hero-top-l,.hero-top-r{display:flex;flex-direction:column;gap:10px}
.hero-top-r{align-items:flex-end;text-align:right}
.hero-tag{display:flex;align-items:center;gap:8px;color:var(--ink-dim)}
.hero-tag::before{content:"";width:6px;height:6px;background:var(--accent);border-radius:50%;flex:none}
.hero-issue{font-family:var(--display);font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--ink);font-size:14px}

.hero-title{font-family:var(--display);font-weight:800;font-size:clamp(64px,15vw,260px);line-height:.8;letter-spacing:-.05em;text-transform:uppercase;color:var(--ink);margin-top:auto}
.hero-title .row{display:block;white-space:nowrap}
.hero-title .row2{display:flex;align-items:flex-end;gap:.18em}
.hero-title .swatch{display:inline-block;width:.42em;height:.6em;background:var(--accent);transform:translateY(-.06em)}

.hero-bottom{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding-top:28px;border-top:1px solid rgba(243,239,230,.18);margin-top:28px}
.hero-lede{font-family:var(--display);font-weight:500;font-size:clamp(15px,1.3vw,18px);line-height:1.34;color:var(--ink);max-width:42ch}
.hero-lede em{color:var(--accent);font-style:normal}
.hero-stat .k{color:var(--ink-dim);margin-bottom:8px}
.hero-stat .v{font-family:var(--display);font-weight:700;font-size:30px;line-height:1;letter-spacing:-.02em}
.hero-stat .u{color:var(--ink-dim);margin-top:6px}

.hero-corner{position:absolute;z-index:2;color:var(--ink-dim);font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase}
.hero-corner em{color:var(--ink);font-style:normal}
.hero-corner.tl{top:14px;left:28px;display:flex;gap:18px}
.hero-corner.tr{top:14px;right:28px;display:flex;gap:18px}
.hero-corner.bl{bottom:14px;left:28px;display:flex;gap:18px}

/* ----- TICKER ----- */
.ticker{display:flex;overflow:hidden;border-bottom:1px solid var(--line);padding:14px 0;background:var(--bg)}
.ticker-track{display:flex;gap:48px;animation:tick 38s linear infinite;white-space:nowrap;padding-left:48px}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-item{font-family:var(--display);font-weight:700;font-size:22px;letter-spacing:.01em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:48px}
.ticker-item::after{content:"";width:8px;height:8px;background:var(--accent);border-radius:50%;flex:none}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ----- SECTION SCAFFOLD ----- */
section{border-bottom:1px solid var(--line)}
/* keep in-page anchor jumps clear of the sticky nav */
section[id],.case[id]{scroll-margin-top:64px}
.wrap{padding:clamp(56px,7vw,96px) 28px;max-width:var(--maxw);margin:0 auto}
.sect-head{display:grid;grid-template-columns:auto 1fr auto;align-items:end;gap:24px;padding-bottom:48px}
.sect-num{font-family:var(--mono);font-size:11px;color:var(--ink-dim);letter-spacing:.08em;text-transform:uppercase}
.sect-title{font-family:var(--display);font-weight:800;font-size:clamp(38px,6vw,92px);line-height:.9;letter-spacing:-.04em;text-transform:uppercase}
.sect-sub{font-family:var(--mono);font-size:11px;color:var(--ink-dim);letter-spacing:.08em;text-transform:uppercase;text-align:right;max-width:26ch;justify-self:end;line-height:1.5}

/* ----- PARTNERS ----- */
.partners{max-width:var(--maxw);margin:0 auto}
.partners-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line)}
.partner-cell{background:var(--bg);padding:42px 18px;display:grid;grid-template-rows:1fr auto;gap:24px;min-height:182px;transition:background .3s;position:relative}
.partner-cell:hover{background:#161513}
.partner-cell:hover .partner-name{color:var(--accent)}
.partner-name{font-family:var(--display);font-weight:800;font-size:clamp(26px,2.4vw,36px);line-height:1;letter-spacing:-.03em;text-transform:uppercase;transition:color .25s}
.partner-cell .meta{display:flex;justify-content:space-between;gap:10px;color:var(--ink-dim);font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase}
.partner-cell .meta em{color:var(--ink);font-style:normal}
.partners-note{padding:22px 28px;font-family:var(--mono);font-size:10px;color:var(--ink-dim);letter-spacing:.06em;text-transform:uppercase;border-top:1px solid var(--line);max-width:var(--maxw);margin:0 auto}

/* ----- FEATURE FILM ----- */
.feature{position:relative;min-height:min(86vh,760px);overflow:hidden}
.feature-media{position:absolute;inset:0;overflow:hidden}
.feature-media img{width:100%;height:100%;object-fit:cover;object-position:center 42%;filter:contrast(1.05) saturate(.85) brightness(.66)}
.feature-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.5),rgba(10,10,10,.05) 30%,rgba(10,10,10,.1) 55%,rgba(10,10,10,.96));pointer-events:none}
.feature-overlay{position:relative;z-index:2;display:grid;grid-template-rows:auto 1fr auto;padding:clamp(20px,3vw,36px) 28px;min-height:inherit;color:var(--ink);max-width:var(--maxw);margin:0 auto}
.feature-top{display:flex;justify-content:space-between;gap:18px;color:var(--ink-dim);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.feature-top em{color:var(--ink);font-style:normal}
.feature-mid{align-self:center;justify-self:start;margin:auto 0}
.feature-play{display:inline-flex;align-items:center;gap:16px;margin-bottom:20px}
.play-btn{width:64px;height:64px;border-radius:50%;border:1.5px solid var(--ink);display:grid;place-items:center;transition:background .25s,border-color .25s,transform .25s;flex:none}
.play-btn svg{width:20px;height:20px;margin-left:3px;fill:var(--ink);transition:fill .25s}
.feature-play:hover .play-btn{background:var(--accent);border-color:var(--accent);transform:scale(1.06)}
.feature-play:hover .play-btn svg{fill:#0a0a0a}
.feature-play .pl-label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.feature-play .pl-label em{display:block;color:var(--ink-dim);font-style:normal;margin-top:3px}
.feature-title{font-family:var(--display);font-weight:800;font-size:clamp(60px,12vw,200px);line-height:.8;letter-spacing:-.045em;text-transform:uppercase}
.feature-title em{font-style:normal;color:var(--accent)}
.feature-foot{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:32px;align-items:end;padding-top:24px;border-top:1px solid rgba(243,239,230,.25);margin-top:24px}
.feature-cap{font-family:var(--display);font-weight:500;font-size:clamp(14px,1.1vw,16px);max-width:46ch;line-height:1.4}
.feature-meta .k{color:var(--ink-dim);font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.feature-meta .v{font-family:var(--display);font-weight:700;font-size:17px;letter-spacing:-.01em;text-transform:uppercase}

/* ----- FILMS GRID ----- */
.films{max-width:var(--maxw);margin:0 auto}
.films-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
.film{background:var(--bg);display:flex;flex-direction:column;position:relative;text-align:left;overflow:hidden}
.film-media{position:relative;aspect-ratio:16/9;overflow:hidden;background:#000}
.film-media img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.92) brightness(.92);transition:transform .8s cubic-bezier(.16,1,.3,1),filter .4s}
.film:hover .film-media img{transform:scale(1.045);filter:contrast(1.04) saturate(1) brightness(1)}
.film-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.1),rgba(10,10,10,0) 40%,rgba(10,10,10,.55));transition:background .4s}
.film-play{position:absolute;inset:0;z-index:2;display:grid;place-items:center;pointer-events:none}
.film-play span{width:54px;height:54px;border-radius:50%;border:1.5px solid rgba(243,239,230,.85);display:grid;place-items:center;background:rgba(10,10,10,.28);backdrop-filter:blur(2px);transition:background .25s,border-color .25s,transform .3s}
.film-play svg{width:16px;height:16px;margin-left:2px;fill:var(--ink)}
.film:hover .film-play span{background:var(--accent);border-color:var(--accent);transform:scale(1.1)}
.film:hover .film-play svg{fill:#0a0a0a}
.film-runtime{position:absolute;right:12px;bottom:12px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink);background:rgba(10,10,10,.6);padding:4px 8px;border:1px solid rgba(243,239,230,.18)}
.film-body{padding:22px 22px 26px;display:flex;flex-direction:column;gap:12px;flex:1}
.film-head{display:flex;justify-content:space-between;gap:12px;font-family:var(--mono);font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-dim)}
.film-head .yr{color:var(--accent)}
.film-ttl{font-family:var(--display);font-weight:800;font-size:clamp(24px,2.1vw,30px);line-height:1;letter-spacing:-.03em;text-transform:uppercase}
.film-ttl em{font-style:normal;color:var(--accent)}
.film-desc{font-size:13.5px;line-height:1.5;color:var(--ink-soft);font-weight:300}
.film-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-dim)}
.film-foot .src{color:var(--ink)}
.film-foot .arr{transition:transform .3s,color .25s}
.film:hover .film-foot .arr{transform:translateX(5px);color:var(--accent)}

/* ----- ABOUT / BIO ----- */
.bio{display:grid;grid-template-columns:1fr 1.05fr;gap:0;max-width:var(--maxw);margin:0 auto}
.bio-l{padding:clamp(56px,7vw,96px) 28px;display:flex;flex-direction:column;gap:30px;border-right:1px solid var(--line)}
.bio-quote{font-family:var(--display);font-weight:700;font-size:clamp(26px,3.1vw,44px);line-height:1.04;letter-spacing:-.02em;color:var(--ink)}
.bio-quote span{color:var(--accent)}
.bio-quote-attr{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim);margin-top:-12px}
.bio-body{font-family:var(--body);font-size:15px;line-height:1.62;color:var(--ink-soft);max-width:56ch;font-weight:300}
.bio-body p+p{margin-top:14px}
.bio-body strong{color:var(--ink);font-weight:500}
.bio-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding-top:26px;border-top:1px solid var(--line)}
.bio-grid .k{color:var(--ink-dim);font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.bio-grid .v{font-family:var(--display);font-weight:700;font-size:17px;letter-spacing:-.01em}
.bio-portrait{position:relative;min-height:560px;background-size:cover;background-position:center 28%;filter:contrast(1.04) saturate(.9)}
.bio-portrait::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,0) 55%,rgba(10,10,10,.9))}
.bio-portrait .cap{position:absolute;bottom:20px;left:24px;right:24px;display:flex;justify-content:space-between;gap:10px;color:var(--ink-dim);font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;z-index:2}
.bio-portrait .cap em{color:var(--ink);font-style:normal}

/* ----- CAREER FACTS ----- */
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);max-width:var(--maxw);margin:0 auto}
.fact{background:var(--bg);padding:clamp(36px,4vw,60px) 28px;display:grid;grid-template-rows:auto 1fr auto;gap:16px;min-height:240px}
.fact .k{color:var(--ink-dim);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.fact .n{font-family:var(--display);font-weight:800;font-size:clamp(52px,6vw,104px);line-height:.85;letter-spacing:-.05em}
.fact .n sup{font-size:.36em;vertical-align:top;color:var(--accent);font-weight:500;margin-left:.06em}
.fact .u{color:var(--ink-dim);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;line-height:1.5}

/* ----- PRESS ----- */
.press{max-width:var(--maxw);margin:0 auto}
.press-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
.press-cell{background:var(--bg);padding:34px 26px 28px;display:flex;flex-direction:column;gap:16px;min-height:230px;transition:background .3s}
.press-cell:hover{background:#161513}
.press-cell .src{font-family:var(--display);font-weight:800;font-size:22px;text-transform:uppercase;letter-spacing:-.02em}
.press-cell:hover .src{color:var(--accent)}
.press-cell .ex{font-size:14px;line-height:1.5;color:var(--ink-soft);font-weight:300;flex:1}
.press-cell .foot{display:flex;justify-content:space-between;align-items:center;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-dim);padding-top:14px;border-top:1px solid var(--line)}
.press-cell .arr{transition:transform .3s,color .25s}
.press-cell:hover .arr{transform:translateX(5px);color:var(--accent)}

/* ----- CONTACT ----- */
.contact{padding:clamp(72px,9vw,128px) 28px clamp(48px,5vw,72px);position:relative;max-width:var(--maxw);margin:0 auto}
.contact::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(180deg,transparent 0 14px,rgba(243,239,230,.025) 14px 15px);pointer-events:none}
.contact-inner{position:relative;display:grid;grid-template-columns:1.4fr 1fr;gap:48px}
.contact-l{display:flex;flex-direction:column;gap:36px}
.contact-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:10px}
.contact-eyebrow::before{content:"";width:24px;height:1px;background:var(--accent)}
.contact-h{font-family:var(--display);font-weight:800;font-size:clamp(48px,9vw,160px);line-height:.84;letter-spacing:-.05em;text-transform:uppercase}
.contact-h em{color:var(--accent);font-style:normal}
.contact-actions{display:flex;flex-wrap:wrap;gap:14px}
.contact-cta{display:inline-flex;align-items:center;gap:16px;border:1px solid var(--ink);padding:18px 26px;font-family:var(--display);font-weight:700;font-size:clamp(16px,1.6vw,21px);text-transform:uppercase;letter-spacing:-.01em;transition:background .2s,color .2s,border-color .2s}
.contact-cta.primary{background:var(--accent);border-color:var(--accent);color:#0a0a0a}
.contact-cta.primary:hover{background:#ff6038;border-color:#ff6038}
.contact-cta:hover{background:var(--ink);border-color:var(--ink);color:#0a0a0a}
.contact-cta .arr{font-family:var(--mono);font-size:17px}
.contact-r{display:flex;flex-direction:column;gap:26px}
.contact-block .k{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:8px}
.contact-block .v{font-family:var(--display);font-weight:700;font-size:19px;letter-spacing:-.01em}
.contact-block .v a{transition:color .2s}
.contact-block .v a:hover{color:var(--accent)}
.contact-socials{display:flex;gap:20px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:.07em;text-transform:uppercase}
.contact-socials a{color:var(--ink-dim);transition:color .2s;display:inline-flex;align-items:center;gap:7px}
.contact-socials a:hover{color:var(--accent)}

/* ----- FOOTER ----- */
footer{padding:34px 28px 30px;border-top:1px solid var(--line);background:var(--bg)}
.foot-row{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim);max-width:var(--maxw);margin:0 auto}
.foot-row em{color:var(--ink);font-style:normal}
.foot-row a:hover{color:var(--accent)}

/* ----- VIDEO LIGHTBOX ----- */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(6,6,6,.94);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:opacity .3s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox-inner{position:relative;width:min(1200px,100%);aspect-ratio:16/9}
.lightbox-inner iframe{position:absolute;inset:0;width:100%;height:100%;border:0;background:#000}
.lightbox-close{position:absolute;top:-46px;right:0;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:8px}
.lightbox-close:hover{color:var(--accent)}
.lightbox-close span{font-size:18px;line-height:1}

/* ----- CASE STUDIES (Moncler / Zenith) ----- */
.cases{max-width:var(--maxw);margin:0 auto}
.case{position:relative;border-top:1px solid var(--line)}
.case:first-child{border-top:0}
.case-hero{position:relative;height:min(78vh,620px);min-height:440px;overflow:hidden;border-bottom:1px solid var(--line)}
.case-hero img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.9) brightness(.74)}
.case-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.55) 0%,rgba(10,10,10,0) 32%,rgba(10,10,10,0) 55%,rgba(10,10,10,.95) 100%)}
.case-hero-inner{position:absolute;inset:0;z-index:2;padding:clamp(20px,3vw,36px) 28px;display:grid;grid-template-rows:auto 1fr auto;color:var(--ink);max-width:var(--maxw);margin:0 auto}
.case-hero-top{display:flex;justify-content:space-between;gap:18px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim)}
.case-hero-top em{color:var(--ink);font-style:normal}
.case-hero-top .num{color:var(--accent)}
.case-brand{align-self:end;font-family:var(--display);font-weight:800;font-size:clamp(64px,13vw,220px);line-height:.78;letter-spacing:-.05em;text-transform:uppercase}
.case-brand em{font-style:normal;color:var(--accent)}
.case-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;width:74px;height:74px;border-radius:50%;border:1.5px solid var(--ink);display:grid;place-items:center;background:rgba(10,10,10,.25);transition:background .25s,border-color .25s,transform .25s}
.case-play svg{width:22px;height:22px;margin-left:3px;fill:var(--ink)}
.case-play:hover{background:var(--accent);border-color:var(--accent);transform:translate(-50%,-50%) scale(1.08)}
.case-play:hover svg{fill:#0a0a0a}
.case-hero-foot{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:32px;align-items:end;padding-top:24px;margin-top:24px;border-top:1px solid rgba(243,239,230,.25)}
.case-deck{font-family:var(--display);font-weight:500;font-size:clamp(14px,1.2vw,17px);line-height:1.34;color:var(--ink);max-width:46ch}
.case-deck em{color:var(--accent);font-style:normal}
.case-hero-foot .k{font-family:var(--mono);font-size:10px;color:var(--ink-dim);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.case-hero-foot .v{font-family:var(--display);font-weight:700;font-size:16px;letter-spacing:-.01em;text-transform:uppercase}
.case-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:130px;gap:1px;background:var(--line)}
.case-tile{background:var(--bg);position:relative;overflow:hidden}
.case-tile img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.9);transition:transform .8s cubic-bezier(.16,1,.3,1)}
.case-tile:hover img{transform:scale(1.05)}
.case-tile .lab{position:absolute;left:12px;bottom:10px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink);text-shadow:0 1px 6px rgba(0,0,0,.8)}
.case-tile.swatch{display:grid;place-items:center;padding:28px;background:#0f0e0c;text-align:center}
.case-tile.swatch .sh{font-family:var(--display);font-weight:800;font-size:clamp(28px,3vw,46px);line-height:.86;letter-spacing:-.03em;text-transform:uppercase}
.case-tile.swatch .sh em{color:var(--accent);font-style:normal}
.case-tile.swatch .ss{font-family:var(--mono);font-size:10px;color:var(--ink-dim);letter-spacing:.08em;text-transform:uppercase;margin-top:12px}
/* moncler tile pattern */
.case--a .t1{grid-column:1/8;grid-row:1/4}
.case--a .t2{grid-column:8/13;grid-row:1/3}
.case--a .t3{grid-column:8/11;grid-row:3/4}
.case--a .t4{grid-column:11/13;grid-row:3/4}
/* Zenith: two clean images + a bold full-width "Defy the Cold" band */
.case--zenith .case-grid{grid-template-columns:1fr 1fr;grid-template-rows:min(34vw,380px) auto}
.case--zenith .t1{grid-area:1/1/2/2}
.case--zenith .t2{grid-area:1/2/2/3}
.case--zenith .t3{grid-area:2/1/3/3}
.case--zenith .case-tile.swatch{min-height:210px}
.case--zenith .case-tile.swatch .sh{font-size:clamp(40px,5vw,76px)}
.case--zenith .case-tile.swatch .ss{font-size:11px;margin-top:16px}
.case-body{display:grid;grid-template-columns:1fr 1.35fr;border-top:1px solid var(--line)}
.case-meta{padding:clamp(36px,4vw,52px) 28px;display:flex;flex-direction:column;gap:22px;border-right:1px solid var(--line)}
.case-meta .tag{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.case-meta h4{font-family:var(--display);font-weight:800;font-size:clamp(26px,2.4vw,34px);line-height:.96;letter-spacing:-.03em;text-transform:uppercase}
.case-meta h4 em{color:var(--accent);font-style:normal}
.case-meta p{font-size:14.5px;line-height:1.6;color:var(--ink-soft);font-weight:300}
.case-deliv{display:grid;grid-template-columns:1fr 1fr;gap:14px 24px;margin-top:auto}
.case-deliv li{list-style:none;padding:13px 0 0;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink)}
.case-deliv li span{display:block;color:var(--ink-dim);font-size:10px;margin-bottom:4px}
.case-pull{padding:clamp(36px,4vw,52px) 28px;display:flex;flex-direction:column;gap:20px;justify-content:center}
.case-pull q{quotes:"\201C" "\201D";font-family:var(--display);font-weight:700;font-size:clamp(22px,2.4vw,34px);line-height:1.1;letter-spacing:-.02em;color:var(--ink)}
.case-pull q::before{content:open-quote;color:var(--accent)}
.case-pull q::after{content:close-quote;color:var(--accent)}
.case-pull q em{color:var(--accent);font-style:normal}
.case-pull .attr{font-family:var(--mono);font-size:11px;color:var(--ink-dim);letter-spacing:.07em;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center;gap:12px;padding-top:16px;border-top:1px solid var(--line);flex-wrap:wrap}
.case-pull .attr em{color:var(--ink);font-style:normal}
.case-pull .cta{font-family:var(--mono);font-size:11px;letter-spacing:.07em;text-transform:uppercase;border:1px solid var(--ink);padding:10px 16px;transition:background .2s,color .2s,border-color .2s}
.case-pull .cta:hover{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}

/* ----- DISPATCHES (latest / news) ----- */
.dispatch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);max-width:var(--maxw);margin:0 auto}
.dispatch{background:var(--bg);display:flex;flex-direction:column;overflow:hidden;text-align:left}
.dispatch-img{aspect-ratio:16/10;overflow:hidden}
.dispatch-img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.9);transition:transform .8s cubic-bezier(.16,1,.3,1)}
.dispatch:hover .dispatch-img img{transform:scale(1.05)}
.dispatch-body{padding:24px 22px 18px;display:flex;flex-direction:column;gap:12px;flex:1}
.dispatch-meta{display:flex;justify-content:space-between;gap:10px;color:var(--ink-dim);font-family:var(--mono);font-size:10px;letter-spacing:.07em;text-transform:uppercase}
.dispatch-meta em{color:var(--accent);font-style:normal}
.dispatch-ttl{font-family:var(--display);font-weight:800;font-size:clamp(22px,2vw,26px);line-height:1.02;letter-spacing:-.03em;text-transform:uppercase}
.dispatch-body p{font-size:13.5px;line-height:1.5;color:var(--ink-soft);font-weight:300}
.dispatch-foot{margin-top:auto;padding:14px 22px;border-top:1px solid var(--line);font-family:var(--mono);font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-dim);display:flex;justify-content:space-between;align-items:center}
.dispatch-foot .arr{transition:transform .3s,color .25s}
.dispatch:hover .dispatch-foot .arr{transform:translateX(5px);color:var(--accent)}

/* ----- GALLERY ----- */
.gallery{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line);max-width:var(--maxw);margin:0 auto}
.gallery-cell{aspect-ratio:1;position:relative;overflow:hidden;background:#000}
.gallery-cell img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.85);transition:transform .8s cubic-bezier(.16,1,.3,1),filter .3s}
.gallery-cell:hover img{transform:scale(1.06);filter:contrast(1.05) saturate(1)}
.gallery-cell::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 62%,rgba(0,0,0,.6))}
.gallery-cell .l{position:absolute;left:10px;bottom:8px;z-index:2;font-family:var(--mono);font-size:9px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink)}
.gallery-foot{padding:22px 28px;border-top:1px solid var(--line);max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-family:var(--mono);font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-dim)}
.gallery-foot a{color:var(--ink)}
.gallery-foot a:hover{color:var(--accent)}

/* ----- SCROLL REVEAL ----- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ====== RESPONSIVE ====== */
@media (max-width:1100px){
  .partners-grid{grid-template-columns:repeat(3,1fr)}
  .films-grid{grid-template-columns:repeat(2,1fr)}
  .press-grid{grid-template-columns:repeat(2,1fr)}
  .facts{grid-template-columns:repeat(2,1fr)}
  .feature-foot{grid-template-columns:1.4fr 1fr 1fr}
  .dispatch-grid{grid-template-columns:repeat(3,1fr)}
  .gallery{grid-template-columns:repeat(4,1fr)}
}

@media (max-width:760px){
  /* flex on mobile so brand sits left, booking + burger sit right
     (the 3-col grid mis-placed them since the menu column is hidden) */
  .nav-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;gap:12px}
  .nav-menu,.nav-meta{display:none}
  .nav-right{gap:14px}
  .nav-cta{padding:9px 13px;font-size:10px;letter-spacing:.05em}
  .burger{display:flex;padding:6px 2px}
  .brand-name{font-size:13px}

  .hero{height:auto;min-height:88vh}
  .hero-inner{padding:24px 16px 18px;text-shadow:0 1px 14px rgba(10,10,10,.6)}
  .hero-top{grid-template-columns:1fr;gap:14px}
  .hero-top-r{align-items:flex-start;text-align:left}
  .hero-bottom{grid-template-columns:1fr 1fr;gap:18px;padding-top:18px;margin-top:18px}
  .hero-bottom .hero-lede{grid-column:1/-1}
  /* hide the corner telemetry on mobile (override the higher-specificity .tl/.tr/.bl) */
  .hero-corner,.hero-corner.tl,.hero-corner.tr,.hero-corner.bl{display:none}
  /* stronger scrim so text stays legible over the bright snow */
  .hero-media img{filter:contrast(1.05) saturate(.86) brightness(.6);object-position:68% 30%}
  .hero-media::after{background:linear-gradient(180deg,rgba(10,10,10,.72) 0%,rgba(10,10,10,.34) 26%,rgba(10,10,10,.42) 54%,rgba(10,10,10,.97) 100%)}
  /* lift the dim meta/labels for contrast (beats inline color:var(--ink-dim)) */
  .hero-tag,.hero-issue,.hero-stat .k,.hero-stat .u,.hero-top-r .mono{color:#d6d0c4 !important}

  .ticker-item{font-size:17px;gap:28px}
  .ticker-track{gap:28px}

  .wrap{padding-left:16px;padding-right:16px}
  .sect-head{grid-template-columns:1fr;gap:14px;padding-bottom:30px}
  .sect-sub{text-align:left;justify-self:start;max-width:none}

  .partners-grid{grid-template-columns:repeat(2,1fr)}
  .partner-cell{min-height:134px;padding:24px 14px}

  .feature{min-height:auto}
  .feature-overlay{padding:18px 16px}
  .feature-mid{margin:40px 0}
  .feature-foot{grid-template-columns:1fr 1fr;gap:18px}
  .feature-cap{grid-column:1/-1}

  .films-grid{grid-template-columns:1fr}

  /* case hero: grow with content; image (absolute) always covers behind the text */
  .case-hero{height:auto;min-height:0;overflow:hidden}
  .case-hero img{position:absolute;inset:0;width:100%;height:100%;filter:contrast(1.05) saturate(.9) brightness(.6)}
  .case-hero::after{background:linear-gradient(180deg,rgba(10,10,10,.6) 0%,rgba(10,10,10,.3) 38%,rgba(10,10,10,.52) 68%,rgba(10,10,10,.96) 100%)}
  .case-hero-inner{position:relative;inset:auto;min-height:62vh;padding:20px 16px 24px;display:flex;flex-direction:column;text-shadow:0 1px 14px rgba(10,10,10,.6)}
  .case-hero-top{flex-wrap:wrap;gap:6px 14px}
  .case-brand{margin-top:auto;font-size:clamp(58px,17vw,112px)}
  .case-hero-foot{grid-template-columns:1fr 1fr;gap:14px;margin-top:18px;padding-top:18px}
  .case-deck{grid-column:1/-1}
  /* image tiles: clean single-column stack — no gaps, no overlaps */
  .case-grid{grid-template-columns:1fr;grid-auto-rows:auto}
  .case--a .t1,.case--a .t2,.case--a .t3,.case--a .t4{grid-column:1/-1;grid-row:auto}
  .case--zenith .case-grid{grid-template-columns:1fr;grid-template-rows:none}
  .case--zenith .t1,.case--zenith .t2,.case--zenith .t3{grid-area:auto}
  .case-tile{aspect-ratio:16/10}
  .case-tile img{position:static}
  .case-tile.swatch{aspect-ratio:auto;min-height:150px;padding:28px 22px}
  .case-tile.swatch .sh{font-size:clamp(30px,8vw,44px)}
  .case-body{grid-template-columns:1fr}
  .case-meta{border-right:none;border-bottom:1px solid var(--line);padding:32px 16px}
  .case-deliv{grid-template-columns:1fr 1fr}
  .case-pull{padding:32px 16px}

  .dispatch-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(3,1fr)}

  .bio{grid-template-columns:1fr}
  .bio-l{border-right:none;border-bottom:1px solid var(--line);padding:48px 16px}
  .bio-portrait{min-height:420px}
  .bio-grid{grid-template-columns:1fr 1fr}

  .facts{grid-template-columns:1fr 1fr}
  .fact{min-height:180px;padding:34px 18px}

  .press-grid{grid-template-columns:1fr}

  .contact{padding:64px 16px 40px}
  .contact-inner{grid-template-columns:1fr;gap:34px}
  .contact-cta{width:100%;justify-content:space-between}

  footer{padding:24px 16px}
  .foot-row{flex-direction:column;align-items:flex-start;gap:10px}
  .lightbox-close{top:-40px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .hero-media{transform:none!important}
}
