/* ============================================================
   RICHARD PERMIN — "Quiet Altitude Gallery"
   Light · editorial · Swiss-minimalist · one cold accent.
   Built on the tokens demonstrated in styleguide.css (SPEC §1–§10).
   ============================================================ */

:root{
  /* --- Color system (exact, SPEC §1) --- */
  --snow:#F7F6F4;        /* primary background — warm off-white */
  --stone:#E8E4E0;       /* secondary surface / cards / dividers */
  --mist:#D8DBDE;        /* tertiary surface / cool tint / chart grid */
  --graphite:#222427;    /* primary text & ink */
  --alpine:#213A78;      /* the single accent — deep navy. Use sparingly. */

  /* --- Derived (allowed) --- */
  --ink-muted:rgba(34,36,39,.56);   /* labels / meta */
  --ink-soft:rgba(34,36,39,.85);    /* body text */
  --hairline:rgba(34,36,39,.14);    /* hairline rules / borders */
  --hairline-soft:rgba(34,36,39,.08);
  --alpine-soft:rgba(33,58,120,.10);

  /* --- Type --- */
  --display:'Cormorant Garamond',Georgia,serif;        /* elegant editorial serif — headlines */
  --body:'Inter',ui-sans-serif,system-ui,-apple-system,sans-serif;
  --ui:'Space Grotesk',ui-sans-serif,system-ui,sans-serif; /* crisp grotesk — micro-labels & numerals */

  /* --- Geometry --- */
  --maxw:1320px;
  --pad:clamp(20px,5vw,72px);
  --section-y:clamp(80px,12vh,180px);
  --shadow-soft:0 1px 2px rgba(34,36,39,.04);
  --nav-h:64px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:var(--nav-h)}
body{
  background:var(--snow);
  color:var(--graphite);
  font-family:var(--body);
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{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(--alpine);color:var(--snow)}
:focus-visible{outline:2px solid var(--alpine);outline-offset:3px}

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

/* ---------- Reusable type helpers ---------- */
.label{
  font-family:var(--body);
  font-size:11px;font-weight:500;
  text-transform:uppercase;letter-spacing:.18em;
  color:var(--ink-muted);line-height:1.4;
}
.label--ink{color:var(--graphite)}
.label--accent{color:var(--alpine)}
.data{
  font-family:var(--display);font-weight:500;
  text-transform:uppercase;letter-spacing:.14em;
  font-size:11px;color:var(--ink-muted);
  font-feature-settings:"tnum" 1;
}
.data--ink{color:var(--graphite)}

/* ---------- Layout primitives ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.section{padding-block:var(--section-y);position:relative}
.section + .section{border-top:1px solid var(--hairline)}

.section-head{
  display:flex;align-items:baseline;gap:18px;
  margin-bottom:clamp(32px,5vw,64px);flex-wrap:wrap;
}
.section-no{
  font-family:var(--display);font-weight:500;font-size:13px;
  letter-spacing:.04em;color:var(--alpine);font-feature-settings:"tnum" 1;
}
.section-title{
  font-family:var(--display);font-weight:500;
  font-size:clamp(24px,3.6vw,38px);
  letter-spacing:-.02em;line-height:1.05;
}
.section-head .rule{flex:1 1 120px;height:1px;background:var(--hairline);align-self:center;margin-bottom:6px;min-width:40px}
.section-head .label{align-self:center;margin-bottom:4px}

.lead{
  max-width:62ch;
  font-size:clamp(15px,1.6vw,17px);font-weight:300;
  line-height:1.65;color:var(--ink-soft);
}

/* topo background helper */
.topo-bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;pointer-events:none;z-index:0;opacity:.5;
}
.section > .wrap{position:relative;z-index:1}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:120;
  background:rgba(247,246,244,.82);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--hairline);
  transition:transform .4s ease;
}
.nav-row{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{
  width:18px;height:18px;flex:none;
  background:
    linear-gradient(135deg,transparent 46%,var(--alpine) 46% 54%,transparent 54%),
    linear-gradient(45deg,transparent 46%,var(--graphite) 46% 54%,transparent 54%);
}
.brand-name{
  font-family:var(--display);font-weight:500;font-size:15px;letter-spacing:-.01em;
}
.brand-name b{color:var(--alpine);font-weight:500}
.nav-menu{display:flex;gap:clamp(14px,2vw,30px);list-style:none}
.nav-menu a{
  font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.16em;
  color:var(--ink-muted);transition:color .25s ease;position:relative;padding:4px 0;
}
.nav-menu a:hover{color:var(--graphite)}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-meta{font-family:var(--display);font-size:11px;letter-spacing:.14em;color:var(--ink-muted)}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;
  color:var(--graphite);border:1px solid var(--hairline);
  padding:9px 14px;transition:border-color .25s,background .25s;
}
.nav-cta:hover{border-color:var(--alpine);background:var(--alpine-soft)}
.nav-cta .dot{width:6px;height:6px;background:var(--alpine)}
.burger{display:none;width:34px;height:34px;flex-direction:column;justify-content:center;gap:5px;align-items:center}
.burger span{display:block;width:20px;height:1.5px;background:var(--graphite);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-menu{
  position:fixed;inset:0;z-index:110;
  background:var(--snow);
  padding:calc(var(--nav-h) + 32px) var(--pad) 40px;
  display:flex;flex-direction:column;gap:4px;
  transform:translateY(-100%);transition:transform .45s cubic-bezier(.16,1,.3,1);
  visibility:hidden;
}
.mobile-menu.open{transform:none;visibility:visible}
.mobile-menu a{
  font-family:var(--display);font-weight:500;font-size:clamp(26px,8vw,40px);
  letter-spacing:-.02em;padding:10px 0;border-bottom:1px solid var(--hairline);
}
.mobile-menu .mm-foot{
  margin-top:auto;padding-top:24px;display:flex;gap:20px;flex-wrap:wrap;
}
.mobile-menu .mm-foot a{
  font-family:var(--body);font-size:12px;font-weight:500;text-transform:uppercase;
  letter-spacing:.14em;color:var(--ink-muted);border:0;padding:0;
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  padding-top:var(--nav-h);
  background:var(--snow);
  overflow:hidden;
}
.hero-topo{
  position:absolute;top:0;right:-10%;width:60%;height:90%;
  object-fit:cover;opacity:.4;pointer-events:none;z-index:0;
  -webkit-mask-image:linear-gradient(200deg,#000,transparent 70%);
          mask-image:linear-gradient(200deg,#000,transparent 70%);
}
.hero-top{
  position:relative;z-index:1;
  max-width:var(--maxw);margin:0 auto;padding:clamp(22px,4vw,40px) var(--pad) clamp(18px,3vw,28px);
  display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:10px 24px;
  border-bottom:1px solid var(--hairline);
}
.hero-top-l,.hero-top-r{display:flex;flex-direction:column;gap:6px}
.hero-top-r{text-align:right}
.hero-grid{
  position:relative;z-index:1;
  max-width:var(--maxw);margin:0 auto;padding:clamp(36px,6vw,72px) var(--pad) 0;
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:start;
}
.hero-copy{display:flex;flex-direction:column}
.hero-eyebrow{margin-bottom:clamp(20px,4vw,36px)}
.hero-title{
  font-family:var(--display);font-weight:500;
  font-size:clamp(52px,9vw,116px);letter-spacing:-.03em;line-height:.94;
  margin-bottom:clamp(20px,3vw,32px);
}
.hero-tagline{
  font-family:var(--display);font-weight:500;
  font-size:clamp(15px,2.2vw,22px);letter-spacing:.02em;color:var(--alpine);
  margin-bottom:clamp(22px,3vw,32px);
}
.hero-lede{
  max-width:50ch;font-size:clamp(15px,1.7vw,18px);font-weight:300;
  line-height:1.65;color:var(--ink-soft);
}
.hero-lede em{font-style:normal;color:var(--graphite);font-weight:400}
.hero-figure{position:relative}
.hero-media{
  position:relative;overflow:hidden;
  aspect-ratio:3/4;border:1px solid var(--hairline);background:var(--stone);
  will-change:transform;
}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:50% 42%}
.hero-fig-corner{position:absolute;z-index:2;display:flex;flex-direction:column;gap:3px}
.hero-fig-corner.tl{top:14px;left:14px}
.hero-fig-corner.br{bottom:14px;right:14px;text-align:right;align-items:flex-end}
.hero-fig-corner .data{
  background:rgba(247,246,244,.78);padding:4px 8px;color:var(--graphite);
  backdrop-filter:blur(4px);
}
.hero-stats{
  position:relative;z-index:1;
  max-width:var(--maxw);margin:clamp(36px,5vw,64px) auto 0;padding:0 var(--pad);
}
.hero-stats-inner{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--hairline)}
.hero-stat{
  padding:clamp(20px,3vw,30px);border-left:1px solid var(--hairline);
  display:flex;flex-direction:column;gap:8px;
}
.hero-stat:first-child{border-left:0}
.hero-stat .k{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted)}
.hero-stat .v{
  font-family:var(--display);font-weight:500;font-size:clamp(30px,5vw,52px);
  letter-spacing:-.02em;line-height:1;font-feature-settings:"tnum" 1;
}
.hero-stat .v sup{font-size:.5em;vertical-align:top}
.hero-stat .u{font-size:12px;font-weight:300;color:var(--ink-soft)}

/* ============================================================
   TICKER — partners marquee (light)
   ============================================================ */
.ticker{
  border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);
  overflow:hidden;padding-block:22px;background:var(--snow);
  margin-top:clamp(48px,7vw,90px);
}
.ticker-track{display:flex;width:max-content;gap:0;animation:ticker 36s linear infinite}
.ticker-item{
  font-family:var(--display);font-weight:500;font-size:clamp(15px,2.2vw,20px);
  letter-spacing:.02em;color:var(--graphite);
  display:inline-flex;align-items:center;gap:clamp(24px,4vw,52px);white-space:nowrap;
  padding-left:clamp(24px,4vw,52px);
}
.ticker-item::after{content:"·";color:var(--alpine)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.ticker-track{animation:none;flex-wrap:wrap}}

/* ============================================================
   PARTNERS
   ============================================================ */
.partners-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid var(--hairline);
  margin-top:clamp(20px,3vw,32px);
}
.partner-cell{
  background:var(--snow);padding:clamp(24px,3vw,40px);
  border-left:1px solid var(--hairline);border-top:1px solid var(--hairline);
  display:flex;flex-direction:column;gap:14px;min-height:150px;
  transition:background .3s;
}
.partner-cell:nth-child(-n+4){border-top:0}
.partner-cell:nth-child(4n+1){border-left:0}
.partner-cell:hover{background:var(--stone)}
.partner-name{font-family:var(--display);font-weight:500;font-size:clamp(22px,2.8vw,30px);letter-spacing:-.01em;line-height:1;white-space:nowrap;transition:color .3s}
.partner-cell .meta{margin-top:auto;display:flex;flex-direction:column;gap:3px}
.partner-cell .meta span{font-size:12px;color:var(--ink-muted);font-weight:300}
.partner-cell .meta span:first-child{color:var(--graphite);font-weight:500;text-transform:uppercase;letter-spacing:.1em;font-size:11px}
/* Former sponsors — reduced "track record" strip, present but secondary */
.partners-prev{
  margin-top:clamp(22px,3vw,32px);padding-top:clamp(20px,2.5vw,26px);
  border-top:1px solid var(--hairline);
  display:flex;flex-wrap:wrap;align-items:baseline;gap:14px clamp(18px,3vw,34px);
}
.partners-prev__lbl{
  font-family:var(--ui);font-size:10px;font-weight:500;
  text-transform:uppercase;letter-spacing:.18em;color:var(--ink-muted);
  flex:0 0 auto;
}
.partners-prev__list{
  list-style:none;display:flex;flex-wrap:wrap;align-items:baseline;
  gap:6px clamp(14px,2vw,24px);
}
.partners-prev__list li{
  font-family:var(--display);font-size:clamp(15px,1.7vw,19px);font-weight:500;
  letter-spacing:-.01em;color:var(--ink-soft);font-variant-numeric:lining-nums;
  position:relative;transition:color .3s;
}
.partners-prev__list li + li::before{
  content:"";position:absolute;left:calc(-1 * clamp(7px,1vw,12px));top:50%;
  width:3px;height:3px;border-radius:50%;background:var(--mist);transform:translateY(-50%);
}
.partners-prev__list li:hover{color:var(--graphite)}

.partners-note{
  margin-top:clamp(20px,3vw,28px);font-size:13px;font-weight:300;color:var(--ink-soft);
}
.partners-note a{color:var(--alpine);border-bottom:1px solid var(--hairline)}
.partners-note em{font-style:normal;color:var(--graphite)}

/* ============================================================
   BRAND WORK / CASES
   ============================================================ */
.case{margin-top:clamp(40px,6vw,80px)}
.case-hero{position:relative;overflow:hidden;border:1px solid var(--hairline);background:var(--stone)}
.case-hero > img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.case-play{
  position:absolute;top:18px;right:18px;z-index:3;
  width:56px;height:56px;border-radius:50%;
  background:rgba(247,246,244,.85);border:1px solid var(--hairline);
  display:grid;place-items:center;color:var(--alpine);
  transition:transform .3s,background .3s;backdrop-filter:blur(4px);
}
.case-play:hover{transform:scale(1.06);background:var(--snow)}
.case-play svg{width:22px;height:22px;fill:currentColor;margin-left:2px}
.case-hero-inner{padding:clamp(24px,4vw,48px);display:flex;flex-direction:column;gap:18px}
.case-hero-top{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px 20px;
  font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-muted);
  padding-bottom:16px;border-bottom:1px solid var(--hairline);
}
.case-hero-top .num{color:var(--alpine)}
.case-hero-top em{font-style:normal;color:var(--graphite)}
.case-brand{
  font-family:var(--display);font-weight:500;font-size:clamp(40px,7vw,88px);
  letter-spacing:-.03em;line-height:.95;
}
.case-brand em{font-style:normal;color:var(--alpine)}
.case-hero-foot{
  display:grid;grid-template-columns:1.6fr repeat(3,minmax(0,.7fr));
  gap:clamp(16px,2.5vw,32px);align-items:start;
  padding-top:18px;border-top:1px solid var(--hairline);
}
.case-deck{font-size:14px;font-weight:300;line-height:1.6;color:var(--ink-soft);max-width:52ch}
.case-deck em{font-style:normal;color:var(--graphite);font-weight:400}
.case-hero-foot .k{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted);margin-bottom:5px}
.case-hero-foot .v{font-size:13px;font-weight:400;color:var(--graphite)}

.case-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--hairline);border:1px solid var(--hairline);border-top:0;
}
.case--zenith .case-grid{grid-template-columns:repeat(3,1fr)}
.case-tile{position:relative;background:var(--snow);overflow:hidden;aspect-ratio:4/5}
.case-tile img{width:100%;height:100%;object-fit:cover}
.case-tile .lab{
  position:absolute;left:12px;bottom:12px;z-index:1;
  background:rgba(247,246,244,.82);padding:4px 8px;backdrop-filter:blur(4px);
  font-family:var(--display);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite);
}
.case-tile.swatch{background:var(--alpine);color:var(--snow);display:flex;align-items:flex-end;padding:20px}
.case-tile.swatch .sh{font-family:var(--display);font-weight:500;font-size:clamp(18px,2.4vw,26px);letter-spacing:-.01em;line-height:1.05}
.case-tile.swatch .sh em{font-style:normal;opacity:.7}
.case-tile.swatch .ss{font-size:11px;letter-spacing:.04em;opacity:.78;margin-top:8px;font-weight:300}

.case-body{
  display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(28px,4vw,64px);
  border:1px solid var(--hairline);border-top:0;
  padding:clamp(28px,4vw,56px);
}
.case-meta .tag{
  font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.16em;color:var(--alpine);
  display:block;margin-bottom:20px;
}
.case-meta h4{font-family:var(--display);font-weight:500;font-size:clamp(22px,3vw,32px);letter-spacing:-.02em;line-height:1.1;margin-bottom:18px}
.case-meta h4 em,.case-pull em{font-style:normal;color:var(--alpine)}
.case-meta p{font-size:14px;font-weight:300;line-height:1.65;color:var(--ink-soft);max-width:54ch}
.case-deliv{list-style:none;margin-top:26px;display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--hairline)}
.case-deliv li{
  padding:13px 0;border-bottom:1px solid var(--hairline);font-size:13px;color:var(--graphite);
  display:flex;flex-direction:column;gap:3px;padding-right:14px;
}
.case-deliv li span{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-muted)}
.case-pull{
  background:var(--stone);border:1px solid var(--hairline);padding:clamp(24px,3vw,36px);
  display:flex;flex-direction:column;gap:20px;align-self:start;
}
.case-pull q{font-family:var(--display);font-weight:500;font-size:clamp(17px,2.2vw,23px);letter-spacing:-.01em;line-height:1.3}
.case-pull .attr{display:flex;flex-direction:column;gap:12px;padding-top:18px;border-top:1px solid var(--hairline)}
.case-pull .attr span{font-size:12px;color:var(--ink-muted)}
.case-pull .attr em{font-style:normal;color:var(--graphite)}
.case-pull .cta{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--alpine)}

/* ============================================================
   FEATURE FILM
   ============================================================ */
.feature{position:relative;border-top:1px solid var(--hairline)}
.feature-inner{
  max-width:var(--maxw);margin:0 auto;padding:var(--section-y) var(--pad);
  display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,4vw,56px);align-items:center;
}
.feature-text{display:flex;flex-direction:column}
.feature-top{
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-muted);
  padding-bottom:16px;border-bottom:1px solid var(--hairline);margin-bottom:clamp(20px,3vw,30px);
}
.feature-top em{font-style:normal;color:var(--alpine)}
.feature-title{
  font-family:var(--display);font-weight:500;font-size:clamp(44px,7vw,86px);
  letter-spacing:-.03em;line-height:.95;margin-bottom:clamp(20px,3vw,30px);
}
.feature-title em{font-style:normal;color:var(--alpine)}
.feature-cap{font-size:14px;font-weight:300;line-height:1.65;color:var(--ink-soft);max-width:52ch;margin-bottom:clamp(22px,3vw,32px)}
.feature-metas{display:flex;gap:clamp(20px,4vw,44px);flex-wrap:wrap;margin-bottom:clamp(24px,3vw,34px)}
.feature-meta .k{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted);margin-bottom:5px}
.feature-meta .v{font-family:var(--display);font-size:16px;font-weight:500;letter-spacing:-.01em}
.feature-play{display:inline-flex;align-items:center;gap:16px;align-self:flex-start}
.feature-play .play-btn{
  width:60px;height:60px;border-radius:50%;border:1px solid var(--alpine);
  display:grid;place-items:center;color:var(--alpine);flex:none;
  transition:background .3s,color .3s,transform .3s;
}
.feature-play:hover .play-btn{background:var(--alpine);color:var(--snow);transform:scale(1.05)}
.feature-play .play-btn svg{width:22px;height:22px;fill:currentColor;margin-left:3px}
.feature-play .pl-label{display:flex;flex-direction:column;gap:3px;text-align:left;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted)}
.feature-play .pl-label em{font-style:normal;font-family:var(--display);font-size:15px;letter-spacing:-.01em;text-transform:none;color:var(--graphite)}
.feature-media{position:relative;overflow:hidden;border:1px solid var(--hairline);background:var(--stone);aspect-ratio:4/3}
.feature-media img{width:100%;height:100%;object-fit:cover}
.feature-media .data{position:absolute;left:14px;bottom:14px;background:rgba(247,246,244,.8);padding:4px 8px;color:var(--graphite);backdrop-filter:blur(4px)}

/* ============================================================
   FILMS
   ============================================================ */
.films-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px)}
.film{
  display:flex;flex-direction:column;text-align:left;
  border:1px solid var(--hairline);background:var(--snow);box-shadow:var(--shadow-soft);
  transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .3s;
}
.film:hover{transform:translateY(-4px);border-color:var(--alpine)}
.film-media{position:relative;overflow:hidden;aspect-ratio:16/10;border-bottom:1px solid var(--hairline);background:var(--stone)}
.film-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.film:hover .film-media img{transform:scale(1.04)}
.film-runtime{
  position:absolute;top:12px;left:12px;
  font-family:var(--display);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  background:rgba(247,246,244,.85);padding:4px 8px;color:var(--alpine);backdrop-filter:blur(4px);
}
.film-play{
  position:absolute;bottom:12px;right:12px;
  width:42px;height:42px;border-radius:50%;
  background:rgba(247,246,244,.88);border:1px solid var(--hairline);
  display:grid;place-items:center;color:var(--alpine);transition:background .3s,transform .3s;
}
.film:hover .film-play{background:var(--alpine);color:var(--snow);transform:scale(1.05)}
.film-play svg{width:16px;height:16px;fill:currentColor;margin-left:2px}
.film-body{padding:clamp(18px,2vw,24px);display:flex;flex-direction:column;gap:10px;flex:1}
.film-head{display:flex;gap:14px;font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-muted)}
.film-head .yr{color:var(--alpine);font-family:var(--display)}
.film-ttl{font-family:var(--display);font-weight:500;font-size:clamp(20px,2.4vw,26px);letter-spacing:-.02em;line-height:1.05}
.film-ttl em{font-style:normal;color:var(--alpine)}
.film-desc{font-size:13px;font-weight:300;line-height:1.55;color:var(--ink-soft)}
.film-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--hairline);display:flex;justify-content:space-between;align-items:center}
.film-foot .src{font-size:11px;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.1em}
.film-foot .arr{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--alpine)}

/* ============================================================
   ABOUT / BIO
   ============================================================ */
.bio-grid-wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(28px,4vw,64px);align-items:start}
.bio-quote{
  font-family:var(--display);font-weight:500;font-size:clamp(24px,3.4vw,40px);
  letter-spacing:-.02em;line-height:1.18;margin:clamp(20px,3vw,28px) 0 14px;
}
.bio-quote span{color:var(--alpine)}
.bio-quote-attr{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-muted);margin-bottom:clamp(28px,4vw,40px)}
.bio-body{display:flex;flex-direction:column;gap:16px;max-width:58ch}
.bio-body p{font-size:15px;font-weight:300;line-height:1.7;color:var(--ink-soft)}
.bio-body strong,.bio-body em{color:var(--graphite);font-weight:500;font-style:normal}
.bio-meta{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--hairline);margin-top:clamp(28px,4vw,40px)}
.bio-meta > div{padding:18px 20px;border-left:1px solid var(--hairline);border-top:1px solid var(--hairline)}
.bio-meta > div:nth-child(-n+2){border-top:0}
.bio-meta > div:nth-child(odd){border-left:0}
.bio-meta .k{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted);margin-bottom:6px}
.bio-meta .v{font-family:var(--display);font-size:15px;font-weight:500;letter-spacing:-.01em}
.bio-portrait{position:relative;overflow:hidden;border:1px solid var(--hairline);aspect-ratio:4/5;background:var(--stone)}
.bio-portrait img{width:100%;height:100%;object-fit:cover;object-position:50% 35%}
.bio-portrait .cap{position:absolute;left:14px;bottom:14px;right:14px;z-index:1;display:flex;justify-content:space-between;gap:10px}
.bio-portrait .cap span{
  background:rgba(247,246,244,.82);padding:4px 8px;backdrop-filter:blur(4px);
  font-family:var(--display);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite);
}
.bio-portrait .cap em{font-style:normal;color:var(--alpine)}

/* ============================================================
   CAREER — data section (altitude ring + line chart)
   ============================================================ */
.career-data{
  display:grid;grid-template-columns:minmax(220px,.7fr) 1.3fr;gap:1px;
  background:var(--hairline);border:1px solid var(--hairline);
  margin-bottom:clamp(28px,4vw,44px);
}
.data-cell{background:var(--snow);padding:clamp(24px,3vw,40px);display:flex;flex-direction:column;gap:18px}
.data-cell .cap{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.donut-wrap{display:flex;align-items:center;justify-content:center;flex:1;min-height:180px}
.donut-wrap svg{width:min(200px,100%);height:auto;overflow:visible}
.chart-wrap{flex:1;min-height:180px}
.chart-wrap svg{width:100%;height:auto}
.chart-foot{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;padding-top:6px}

.facts{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--hairline)}
.fact{
  padding:clamp(20px,2.5vw,30px);border-left:1px solid var(--hairline);border-top:1px solid var(--hairline);
  display:flex;flex-direction:column;gap:8px;
}
.fact:nth-child(-n+4){border-top:0}
.fact:nth-child(4n+1){border-left:0}
.fact .k{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted)}
.fact .n{font-family:var(--display);font-weight:500;font-size:clamp(28px,4vw,44px);letter-spacing:-.02em;line-height:1;font-feature-settings:"tnum" 1}
.fact .n sup{font-size:.5em;color:var(--alpine)}
.fact .u{font-size:12px;font-weight:300;color:var(--ink-soft)}

/* ============================================================
   CONTENT WORLDS
   ============================================================ */
.worlds{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.8vw,24px)}
.world{display:flex;flex-direction:column;border:1px solid var(--hairline);background:var(--snow);box-shadow:var(--shadow-soft);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.world:hover{transform:translateY(-4px)}
.world .tile{position:relative;overflow:hidden;aspect-ratio:3/4;border-bottom:1px solid var(--hairline);background:var(--stone)}
.world .tile img{width:100%;height:100%;object-fit:cover}
.world .wcorner{position:absolute;top:12px;left:12px;z-index:1;background:rgba(247,246,244,.82);padding:3px 7px;backdrop-filter:blur(4px)}
.world .wlabel{position:absolute;bottom:12px;left:12px;z-index:1;background:rgba(247,246,244,.82);padding:4px 8px;backdrop-filter:blur(4px);font-family:var(--display);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--graphite)}
.world .meta{padding:18px 18px 22px;display:flex;flex-direction:column;gap:12px;flex:1}
.world .wtitle{font-family:var(--display);font-weight:500;font-size:18px;letter-spacing:-.01em;line-height:1.15}
.world .virtues{display:flex;flex-wrap:wrap;gap:6px}
.world .virtues span{font-size:10.5px;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--graphite);border:1px solid var(--hairline);padding:4px 8px}
.world .wdata{margin-top:auto;padding-top:12px;border-top:1px solid var(--hairline)}

/* ============================================================
   DISPATCHES / LATEST
   ============================================================ */
.dispatch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px)}
.dispatch{
  display:flex;flex-direction:column;border:1px solid var(--hairline);background:var(--snow);
  box-shadow:var(--shadow-soft);transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .3s;
}
.dispatch:hover{transform:translateY(-4px);border-color:var(--alpine)}
.dispatch-img{overflow:hidden;aspect-ratio:16/10;border-bottom:1px solid var(--hairline);background:var(--stone)}
.dispatch-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.dispatch:hover .dispatch-img img{transform:scale(1.04)}
.dispatch-body{padding:clamp(18px,2vw,24px);display:flex;flex-direction:column;gap:10px;flex:1}
.dispatch-meta{display:flex;justify-content:space-between;gap:12px;font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-muted)}
.dispatch-meta em{font-style:normal;color:var(--alpine)}
.dispatch-ttl{font-family:var(--display);font-weight:500;font-size:clamp(17px,2vw,21px);letter-spacing:-.01em;line-height:1.15}
.dispatch-body p{font-size:13px;font-weight:300;line-height:1.55;color:var(--ink-soft)}
.dispatch-foot{padding:0 clamp(18px,2vw,24px) clamp(18px,2vw,24px);display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--ink-muted)}
.dispatch-foot .arr{font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--alpine)}

/* ============================================================
   PRESS
   ============================================================ */
.press-grid{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--hairline)}
.press-cell{
  padding:clamp(24px,3vw,36px);border-left:1px solid var(--hairline);border-top:1px solid var(--hairline);
  display:flex;flex-direction:column;gap:16px;min-height:200px;transition:background .3s;
}
.press-cell:nth-child(-n+3){border-top:0}
.press-cell:nth-child(3n+1){border-left:0}
.press-cell:hover{background:var(--stone)}
.press-cell .src{font-family:var(--display);font-weight:500;font-size:clamp(18px,2.2vw,24px);letter-spacing:-.01em}
.press-cell .ex{font-size:13px;font-weight:300;line-height:1.55;color:var(--ink-soft)}
.press-cell .foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--hairline);display:flex;justify-content:space-between;align-items:center}
.press-cell .foot span:first-child{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-muted)}
.press-cell .arr{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--alpine)}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline)}
.gallery-cell{position:relative;overflow:hidden;aspect-ratio:1;background:var(--stone)}
.gallery-cell img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}

/* Unify the non-pre-treated photography toward the airy Quiet Altitude palette
   (hero / content-worlds / portrait images are already treated, so excluded). */
.case-hero > img,.case-tile img,.feature-media img,.film-media img,.dispatch-img img,.gallery-cell img{
  filter:saturate(.82) brightness(1.045) contrast(.95);
}
.gallery-cell:hover img{transform:scale(1.05)}
.gallery-cell .l{
  position:absolute;left:10px;bottom:10px;z-index:1;
  background:rgba(247,246,244,.82);padding:3px 7px;backdrop-filter:blur(4px);
  font-family:var(--display);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--graphite);
  opacity:0;transform:translateY(4px);transition:opacity .3s,transform .3s;
}
.gallery-cell:hover .l{opacity:1;transform:none}
.gallery-foot{margin-top:clamp(20px,3vw,28px);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--ink-muted)}
.gallery-foot a{color:var(--alpine);border-bottom:1px solid var(--hairline)}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,64px)}
.contact-eyebrow{display:block;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.18em;color:var(--alpine);margin-bottom:clamp(22px,3vw,30px)}
.contact-h{font-family:var(--display);font-weight:500;font-size:clamp(38px,6vw,72px);letter-spacing:-.03em;line-height:1;margin-bottom:clamp(28px,4vw,40px)}
.contact-h em{font-style:normal;color:var(--alpine)}
.contact-actions{display:flex;gap:14px;flex-wrap:wrap}
.contact-cta{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;
  border:1px solid var(--hairline);padding:14px 20px;color:var(--graphite);transition:border-color .3s,background .3s;
}
.contact-cta:hover{border-color:var(--alpine);background:var(--alpine-soft)}
.contact-cta.primary{background:var(--alpine);color:var(--snow);border-color:var(--alpine)}
.contact-cta.primary:hover{background:var(--graphite);border-color:var(--graphite)}
.contact-r{border:1px solid var(--hairline)}
.contact-block{padding:clamp(18px,2.5vw,26px);border-top:1px solid var(--hairline)}
.contact-block:first-child{border-top:0}
.contact-block .k{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-muted);margin-bottom:8px}
.contact-block .v{font-family:var(--display);font-size:clamp(15px,1.8vw,18px);font-weight:500;letter-spacing:-.01em}
.contact-block .v a{border-bottom:1px solid var(--hairline)}
.contact-block .v a:hover{color:var(--alpine)}
.contact-socials{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:4px}
.contact-socials a{font-family:var(--body);font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-muted)}
.contact-socials a:hover{color:var(--alpine)}

/* ============================================================
   FOOTER VALUES SPINE
   ============================================================ */
.values-foot{border-top:1px solid var(--graphite);padding-block:clamp(40px,6vw,72px)}
.values-spine{display:grid;grid-template-columns:repeat(5,1fr)}
.values-spine .val{
  text-align:center;padding:10px 12px;border-left:1px solid var(--hairline);
  font-family:var(--display);font-weight:500;font-size:clamp(12px,1.6vw,15px);
  letter-spacing:.22em;text-transform:uppercase;color:var(--graphite);
}
.values-spine .val:first-child{border-left:0}
.foot-row{
  display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:12px 24px;
  margin-top:clamp(36px,5vw,60px);padding-top:22px;border-top:1px solid var(--hairline);
  font-size:12px;color:var(--ink-muted);
}
.foot-row em{font-style:normal;color:var(--graphite)}
.foot-row a{color:var(--alpine)}

/* ============================================================
   VIDEO LIGHTBOX
   ============================================================ */
.lightbox{
  position:fixed;inset:0;z-index:300;
  background:rgba(34,36,39,.88);
  display:grid;place-items:center;padding:clamp(16px,4vw,48px);
  opacity:0;transition:opacity .3s ease;
}
.lightbox.open{opacity:1}
.lightbox[hidden]{display:none}
.lightbox-inner{position:relative;width:min(1100px,100%)}
.lightbox-close{
  position:absolute;top:-44px;right:0;
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--snow);
}
.lightbox-close span{font-size:15px}
#lightboxFrame{position:relative;aspect-ratio:16/9;background:#000;border:1px solid rgba(255,255,255,.15)}
#lightboxFrame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ============================================================
   MOTION (restrained)
   ============================================================ */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(16px);transition:opacity 1.1s cubic-bezier(.16,1,.3,1),transform 1.1s cubic-bezier(.16,1,.3,1)}
  .reveal.in{opacity:1;transform:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .hero-grid{grid-template-columns:1fr;gap:clamp(28px,5vw,40px)}
  .hero-figure{max-width:520px}
  .hero-topo{display:none}
  .case-hero-foot{grid-template-columns:1fr 1fr}
  .case-hero-foot .case-deck{grid-column:1/-1}
  .case-body{grid-template-columns:1fr}
  .feature-inner{grid-template-columns:1fr}
  .films-grid,.dispatch-grid{grid-template-columns:repeat(2,1fr)}
  .worlds{grid-template-columns:repeat(2,1fr)}
  .press-grid{grid-template-columns:repeat(2,1fr)}
  .press-cell:nth-child(-n+3){border-top:1px solid var(--hairline)}
  .press-cell:nth-child(-n+2){border-top:0}
  .press-cell:nth-child(3n+1){border-left:1px solid var(--hairline)}
  .press-cell:nth-child(odd){border-left:0}
  .bio-grid-wrap{grid-template-columns:1fr;gap:32px}
  .bio-portrait{max-width:560px}
  .contact-inner{grid-template-columns:1fr}
  .career-data{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav-menu,.nav-meta{display:none}
  .burger{display:flex}
  .nav-cta{display:none}
  .partners-grid{grid-template-columns:repeat(2,1fr)}
  .partner-cell:nth-child(-n+3){border-top:1px solid var(--hairline)}
  .partner-cell:nth-child(-n+2){border-top:0}
  .partner-cell:nth-child(3n+1){border-left:1px solid var(--hairline)}
  .partner-cell:nth-child(odd){border-left:0}
  .facts{grid-template-columns:repeat(2,1fr)}
  .fact:nth-child(-n+4){border-top:1px solid var(--hairline)}
  .fact:nth-child(-n+2){border-top:0}
  .fact:nth-child(4n+1){border-left:1px solid var(--hairline)}
  .fact:nth-child(odd){border-left:0}
  .case-grid,.case--zenith .case-grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:560px){
  .hero-top-r{text-align:left}
  .hero-stats-inner{grid-template-columns:1fr}
  .hero-stat{border-left:0;border-top:1px solid var(--hairline)}
  .hero-stat:first-child{border-top:0}
  .films-grid,.dispatch-grid{grid-template-columns:1fr}
  .worlds{grid-template-columns:1fr}
  .press-grid{grid-template-columns:1fr}
  .press-cell{border-left:0!important;border-top:1px solid var(--hairline)!important}
  .press-cell:first-child{border-top:0!important}
  .partners-grid{grid-template-columns:1fr}
  .partner-cell{border-left:0!important;border-top:1px solid var(--hairline)!important}
  .partner-cell:first-child{border-top:0!important}
  .facts{grid-template-columns:1fr}
  .fact{border-left:0!important;border-top:1px solid var(--hairline)!important}
  .fact:first-child{border-top:0!important}
  .case-grid,.case--zenith .case-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .case-hero-foot{grid-template-columns:1fr}
  .bio-meta{grid-template-columns:1fr}
  .bio-meta > div{border-left:0!important;border-top:1px solid var(--hairline)!important}
  .bio-meta > div:first-child{border-top:0!important}
  .case-deliv{grid-template-columns:1fr}
  .values-spine{grid-template-columns:1fr}
  .values-spine .val{border-left:0;border-top:1px solid var(--hairline);padding:14px}
  .values-spine .val:first-child{border-top:0}
  .feature-metas{gap:18px}
}
@media print{
  .nav,.mobile-menu,.lightbox,.ticker{display:none}
  .section{padding-block:32px;break-inside:avoid}
  body{background:#fff}
}

/* ============================================================
   TYPE REFINEMENT
   Display is now Cormorant Garamond (elegant editorial serif).
   Keep the crisp grotesk (--ui) for micro-labels & numerals so
   tracked uppercase tags stay legible and figures stay lining.
   Placed last so it overrides the per-component --display rules.
   ============================================================ */
.data,.section-no,.brand-name,.nav-meta,.hero-stat .v,.case-tile .lab,
.feature-meta .v,.film-runtime,.film-head .yr,.fact .n,.bio-meta .v,
.bio-portrait .cap span,.world .wlabel,.gallery-cell .l,.contact-block .v,
.values-spine .val{
  font-family:var(--ui);
}

/* Sponsor wordmarks — homogeneous serif lockups. Lining figures keep
   names like "Glacier 3000" clean; gentle accent on hover. */
.ticker-item,.partner-name,.case-brand,.press-cell .src{
  font-variant-numeric:lining-nums;
}
.partner-cell:hover .partner-name{color:var(--alpine)}
