/* ============================================================
   AL LAISA — Corporate
   "Ateliers Quiet Grotesque"
   Instrument Sans (everything) + Instrument Serif (rare accent).
   Sentence case, hairline structure, one easing curve.
   Motion budget: one gentle rise per block, nothing loops.
   ============================================================ */

:root{
  --ink:#181713;
  --ink-55:rgba(24,23,19,.55);
  --ink-70:rgba(24,23,19,.7);
  --body:#5b5852;
  --faint:#93908a;
  --line:rgba(24,23,19,.12);
  --line-solid:#e8e6e1;
  --paper:#ffffff;
  --cream:#f7f5f1;
  --taupe:#8a7a66;
  --serif:"Instrument Serif", Georgia, serif;
  --sans:"Instrument Sans", "Segoe UI", sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --pad:clamp(20px, 5vw, 72px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  font-weight:400;
  font-synthesis:none;
  color:var(--body);
  background:var(--paper);
  font-size:1rem;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
::selection{background:var(--ink);color:#fff}

.container{max-width:1380px;margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

/* ---------- typography ---------- */
h1,h2,h3{
  font-family:var(--sans);
  font-weight:450;
  color:var(--ink);
  letter-spacing:-.03em;
}
h1 em,h2 em,h3 em,.serif-accent{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  font-size:.98em;
  letter-spacing:0;
  color:var(--ink);
}

.display-xl{font-size:clamp(2.75rem, 7vw, 6.25rem);line-height:1.02;font-weight:425}
.display-lg{font-size:clamp(2.1rem, 4.6vw, 3.9rem);line-height:1.05;font-weight:435}
.display-md{font-size:clamp(1.7rem, 3vw, 2.7rem);line-height:1.1;letter-spacing:-.025em}
.display-sm{font-size:clamp(1.35rem, 2vw, 1.8rem);line-height:1.25;letter-spacing:-.02em}
p.display-lg{color:var(--ink)}
@media(max-width:480px){
  .display-xl,.display-lg{letter-spacing:-.02em}
}

.eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:.6875rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--taupe);margin-bottom:28px;
}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--taupe);flex:none}

.lead{font-size:clamp(1.05rem, 1.4vw, 1.1875rem);line-height:1.8;font-weight:400;color:var(--ink-70)}
.small-note{font-size:.8125rem;letter-spacing:0;color:var(--faint)}

/* ---------- buttons & links ---------- */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--sans);
  font-size:.875rem;font-weight:500;letter-spacing:.01em;
  color:var(--ink);cursor:pointer;
  border:1px solid var(--ink);border-radius:999px;
  padding:.85em 2em;
  background:transparent;
  transition:background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease);
}
.btn:hover{background:var(--ink);color:#fff}
.btn.solid{background:var(--ink);color:#fff}
.btn.solid:hover{background:transparent;color:var(--ink)}
.btn.on-dark{border-color:rgba(255,255,255,.75);color:#fff}
.btn.on-dark:hover{background:#fff;color:var(--ink);border-color:#fff}

.link-line{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.9375rem;font-weight:450;letter-spacing:0;color:var(--ink);
  padding-bottom:6px;position:relative;
}
.link-line::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:var(--ink);
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.link-line:hover::after{transform:scaleX(1)}
.link-line .arr{transition:transform .35s var(--ease)}
.link-line:hover .arr{transform:translateX(6px)}
.arr{width:22px;height:10px;flex:none}
.arr line,.arr path{stroke:currentColor;stroke-width:1.1;fill:none}

/* ---------- header : the hairline atelier bar ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:transparent;
  border-bottom:1px solid transparent;
  transition:background .45s var(--ease), border-color .45s var(--ease), transform .45s var(--ease);
}
.site-header.scrolled{
  background:var(--paper);
  border-bottom-color:var(--line);
}
.site-header.hidden{transform:translateY(-101%)}
/* no-JS / failed-JS: transparent header is a scripted enhancement only */
html:not(.anim) .site-header{background:var(--paper);border-bottom-color:var(--line)}
/* keep the bar (and its Close button) above the fullscreen overlay */
body.menu-open .site-header{transform:none;background:var(--paper);border-bottom-color:transparent;z-index:300}

.site-header .bar{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  height:64px;
  padding:0 clamp(20px,4vw,48px);
  max-width:1560px;margin:0 auto;
}
.nav-side{display:flex;align-items:center;gap:clamp(22px,3vw,40px)}
.nav-side.nav-left{justify-self:start}
.nav-side.nav-right{justify-self:end}
.nav-side a{
  font-size:.9375rem;font-weight:450;letter-spacing:0;color:var(--ink);
  position:relative;padding:4px 0;
}
.nav-side a::after{
  content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;
  background:var(--ink);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav-side a:hover::after{transform:scaleX(1)}
.nav-side a.active::after{transform:scaleX(1);background:var(--taupe)}

.wordmark{
  justify-self:center;
  font-family:var(--sans);font-weight:500;
  font-size:1.0625rem;line-height:1;
  text-transform:uppercase;
  letter-spacing:.22em;margin-right:-.22em; /* optical centering of tracked caps */
  color:var(--ink);
  white-space:nowrap;
}

.menu-toggle{
  display:none;
  grid-column:3;justify-self:end;
  align-items:center;gap:10px;
  background:none;border:0;cursor:pointer;
  font-family:var(--sans);font-size:.9375rem;font-weight:500;letter-spacing:0;
  color:var(--ink);
  padding:10px 0 10px 16px;min-height:44px;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;
}
.menu-toggle .mt-ico{
  width:22px;height:12px;position:relative;flex:none;display:inline-block;
}
.menu-toggle .mt-ico span{
  position:absolute;left:0;width:100%;height:1.5px;background:currentColor;
  transition:transform .4s var(--ease), top .4s var(--ease);
}
.menu-toggle .mt-ico span:nth-child(1){top:2px}
.menu-toggle .mt-ico span:nth-child(2){top:9px}
.menu-open .menu-toggle .mt-ico span:nth-child(1){top:5.5px;transform:rotate(45deg)}
.menu-open .menu-toggle .mt-ico span:nth-child(2){top:5.5px;transform:rotate(-45deg)}
.menu-toggle .mt-close{display:none}
.menu-open .menu-toggle .mt-open{display:none}
.menu-open .menu-toggle .mt-close{display:inline}

/* mobile overlay menu */
.mobile-menu{
  position:fixed;top:0;right:0;bottom:0;left:0;background:var(--paper);z-index:200;
  display:flex;flex-direction:column;justify-content:center;
  padding:76px var(--pad) 0;
  min-height:100vh;min-height:100dvh;overflow-y:auto;
  opacity:0;visibility:hidden;
  transition:opacity .45s var(--ease), visibility .45s;
}
.menu-open .mobile-menu{opacity:1;visibility:visible}
.mobile-menu a{
  font-family:var(--sans);font-weight:400;letter-spacing:-.02em;
  font-size:clamp(2.4rem,9.5vw,3.5rem);line-height:1.15;
  color:var(--ink);
  padding:14px 0;border-bottom:1px solid var(--line);
  display:flex;align-items:baseline;gap:20px;
  opacity:0;transform:translateY(18px);
  transition:opacity .5s var(--ease), transform .5s var(--ease);
}
.mobile-menu a .idx{
  order:-1;
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1rem;letter-spacing:0;color:var(--taupe);
  min-width:2ch;
}
.menu-open .mobile-menu a{opacity:1;transform:none}
.mobile-menu .mm-foot{
  margin-top:auto;padding:34px 0 max(28px, env(safe-area-inset-bottom));
  font-size:.8125rem;letter-spacing:0;color:var(--faint);
  display:flex;flex-wrap:wrap;gap:6px 24px;
  opacity:0;transition:opacity .5s var(--ease) .25s;
}
.menu-open .mobile-menu .mm-foot{opacity:1}
.mobile-menu .mm-foot a{
  font-size:.8125rem;padding:0;border:0;opacity:1;transform:none;
  display:inline;color:var(--ink-70);letter-spacing:0;
}
body.menu-open{overflow:hidden}

/* ---------- hero (home) ---------- */
.hero{
  min-height:100vh;min-height:100svh;
  display:grid;grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr);
  position:relative;
}
.hero-copy{
  display:flex;flex-direction:column;justify-content:center;
  padding:calc(64px + 4vh) var(--pad) 10vh clamp(20px,6vw,110px);
  position:relative;z-index:2;
}
.hero-copy .eyebrow{margin-bottom:34px}
.hero-copy h1{margin-bottom:32px}
.hero-copy .lead{max-width:52ch;margin-bottom:48px}
.hero-ctas{display:flex;gap:28px;flex-wrap:wrap;align-items:center}

.hero-media{position:relative;overflow:hidden;min-height:60vh}
.hero-media img{
  position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center top;
}
/* JS-independent settle-in: the hero image never depends on script or observers */
@media (prefers-reduced-motion: no-preference){
  .hero-media img{animation:heroSettle 2.2s var(--ease) both}
  @keyframes heroSettle{from{transform:scale(1.06)}to{transform:scale(1)}}
}
.hero-media::after{
  content:"";position:absolute;top:0;right:0;bottom:0;left:0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.5) 0%, rgba(255,255,255,0) 16%),
    linear-gradient(90deg, rgba(255,255,255,.5) 0%, rgba(255,255,255,0) 24%);
}

.hero-scroll{
  position:absolute;bottom:34px;left:clamp(20px,6vw,110px);
  display:flex;align-items:center;gap:14px;
  font-size:.75rem;font-weight:450;letter-spacing:.02em;color:var(--faint);
}
.hero-scroll .line{
  width:1px;height:52px;
  background:linear-gradient(180deg, var(--taupe) 0 30%, var(--line-solid) 30%);
}

.hero-side{
  position:absolute;right:26px;bottom:34px;z-index:3;
  writing-mode:vertical-rl;
  font-size:.6875rem;font-weight:450;letter-spacing:.08em;color:var(--faint);
}

/* ---------- brand marquee ---------- */
.logo-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:44px 0;overflow:hidden;background:var(--paper)}
.marquee{display:flex;width:max-content;animation:marquee 36s linear infinite}
.logo-strip:hover .marquee{animation-play-state:paused}
.marquee .set{display:flex;align-items:center;flex:none}
.marquee .logo-cell{
  padding:0 clamp(34px,5vw,84px);display:flex;align-items:center;flex:none;
  border-right:1px solid var(--line);
}
.marquee img{height:24px;width:auto;opacity:.55;filter:grayscale(1)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- generic section ---------- */
.section{padding:clamp(90px,11vw,170px) 0}
.section.cream{background:var(--cream)}
.section-head{max-width:900px;margin-bottom:clamp(48px,6vw,90px)}

/* ---------- split layouts ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(44px,7vw,120px);align-items:center}
.split.flip{grid-template-columns:.95fr 1.05fr}
.split-copy h2{margin-bottom:30px}
.split-copy p{margin-bottom:22px;max-width:56ch}
.split-copy .link-line{margin-top:22px}

.figure{position:relative;overflow:hidden}
.figure img{width:100%;height:auto}
.figure .cap{
  position:absolute;left:0;bottom:0;background:var(--paper);
  padding:12px 24px 0 0;
  font-size:.75rem;font-weight:450;letter-spacing:.02em;color:var(--faint);
}
.figure-offset{position:relative}

.mini-stats{display:flex;gap:clamp(28px,4vw,64px);margin-top:44px;padding-top:34px;border-top:1px solid var(--line)}
.mini-stats .ms .n{
  font-weight:300;font-size:2.1rem;color:var(--ink);line-height:1;
  letter-spacing:-.02em;font-feature-settings:"tnum";
}
.mini-stats .ms .l{
  font-size:.6875rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--faint);margin-top:10px;
}

/* ---------- stats ledger ---------- */
.stats-band{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0 clamp(20px,3vw,48px);
  border-top:1px solid var(--ink);
}
.stat{
  text-align:left;
  padding:clamp(28px,3.5vw,48px) 0 0;
}
.stat .num{
  font-weight:300;font-size:clamp(2.6rem,5vw,4.25rem);color:var(--ink);line-height:1;
  letter-spacing:-.02em;font-feature-settings:"tnum";
  display:inline-flex;align-items:flex-start;
}
.stat .num .suffix{
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:var(--taupe);font-size:.5em;margin-left:4px;margin-top:.1em;
}
.stat .lbl{
  margin-top:14px;
  font-size:.6875rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--faint);
}

/* ---------- brands index (home) ---------- */
.brand-index{border-top:1px solid var(--line)}
.brand-row{
  display:grid;grid-template-columns:64px 1fr auto;align-items:center;gap:clamp(20px,4vw,60px);
  padding:clamp(24px,3.2vw,40px) 0;border-bottom:1px solid var(--line);
  position:relative;color:var(--ink);
}
.brand-row::after{
  content:"";position:absolute;left:0;bottom:-1px;width:100%;height:1px;
  background:var(--ink);transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--ease);
}
.brand-row:hover::after{transform:scaleX(1)}
.brand-row .no{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1rem;letter-spacing:0;color:var(--taupe);
}
.brand-row .name{
  font-weight:425;letter-spacing:-.02em;
  font-size:clamp(1.8rem,3.8vw,3.1rem);line-height:1.05;
  transition:transform .45s var(--ease);
}
.brand-row:hover .name{transform:translateX(14px)}
.brand-row .meta{
  display:flex;align-items:center;gap:22px;
}
.brand-row .meta .cat{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1.05rem;letter-spacing:0;color:var(--taupe);
  opacity:0;transform:translateX(-8px);
  transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.brand-row:hover .meta .cat{opacity:1;transform:none}
@media (hover:none){.brand-row .meta .cat{display:none}}
.brand-row .meta .arr{color:var(--ink);transition:transform .45s var(--ease)}
.brand-row:hover .meta .arr{transform:translateX(8px)}

.hover-preview{
  position:fixed;z-index:90;width:250px;height:330px;pointer-events:none;
  overflow:hidden;opacity:0;transform:scale(.96);
  border:1px solid var(--line-solid);
  transition:opacity .35s var(--ease), transform .5s var(--ease);
}
.hover-preview.on{opacity:1;transform:scale(1)}
.hover-preview img{
  position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity .3s;
}
.hover-preview img.show{opacity:1}

/* ---------- horizontal editorial scroller ---------- */
.hscroll-wrap{position:relative}
.hscroll{
  display:flex;gap:clamp(18px,2.4vw,34px);
  overflow-x:auto;scroll-snap-type:x mandatory;
  padding:6px var(--pad) 30px;
  scrollbar-width:none;
  cursor:grab;
}
.hscroll::-webkit-scrollbar{display:none}
.hscroll.dragging{cursor:grabbing;scroll-snap-type:none}
.hscroll .card{
  flex:0 0 clamp(240px,26vw,340px);scroll-snap-align:start;
}
.hscroll .card .ph{overflow:hidden;aspect-ratio:3/4;position:relative}
.hscroll .card .ph img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s var(--ease);
}
.hscroll .card:hover .ph img{transform:scale(1.03)}
.hscroll .card .t{
  margin-top:16px;display:flex;justify-content:space-between;align-items:baseline;
}
.hscroll .card .t .n{
  font-weight:450;font-size:1.05rem;letter-spacing:-.01em;color:var(--ink);
}
.hscroll .card .t .i{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:.9375rem;letter-spacing:0;color:var(--taupe);
}
.hscroll-progress{
  height:1px;background:var(--line-solid);margin:8px var(--pad) 0;position:relative;
}
.hscroll-progress .fill{
  position:absolute;left:0;top:-0.5px;height:2px;background:var(--taupe);width:12%;
  transition:width .2s linear;
}

/* ---------- values ---------- */
.values-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);border-left:1px solid var(--line);
}
.value-cell{
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:clamp(30px,3.6vw,56px);
}
.value-cell .vn{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1rem;letter-spacing:0;color:var(--taupe);
  display:block;margin-bottom:24px;
}
.value-cell h3{font-size:1.3rem;font-weight:475;letter-spacing:-.015em;margin-bottom:12px}
.value-cell p{font-size:.9375rem;line-height:1.75}

/* ---------- editorial interlude (type on paper + still image) ---------- */
.interlude{padding-top:clamp(90px,11vw,170px)}
.interlude .interlude-head{margin-bottom:clamp(44px,6vw,80px)}
.interlude .interlude-head h2{max-width:20ch;margin-bottom:32px}
.interlude-media{height:clamp(340px,55vh,580px);overflow:hidden}
.interlude-media img{width:100%;height:100%;object-fit:cover}

/* ---------- statement closer (type only) ---------- */
.statement .eyebrow{margin-bottom:34px}
.statement h2,.statement p.display-lg{max-width:24ch;margin-bottom:36px}

/* ---------- CTA split (career) ---------- */
.cta-split{display:grid;grid-template-columns:1fr 1fr;min-height:560px}
.cta-split .media{position:relative;overflow:hidden}
.cta-split .media img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}
.cta-split .content{
  background:var(--ink);color:#c9c5bc;
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(50px,6vw,100px);
}
.cta-split .content .eyebrow{color:#b3a08a}
.cta-split .content .eyebrow::before{background:#b3a08a}
.cta-split .content h2{color:#fff;margin-bottom:24px}
.cta-split .content p{margin-bottom:40px;max-width:46ch}

/* ---------- footer ---------- */
.site-footer{
  border-top:1px solid var(--line);
  padding-top:clamp(60px,8vw,110px);
  background:var(--paper);
  overflow:hidden;
}
.foot-top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:clamp(30px,5vw,70px);
  padding-bottom:clamp(50px,6vw,90px);
}
.foot-brand .wordmark{
  justify-self:start;display:inline-block;
  font-size:1.0625rem;margin-bottom:24px;
}
.foot-brand p{max-width:34ch;font-size:.9375rem}
.foot-col .fc-title{
  font-size:.6875rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--taupe);margin-bottom:24px;
}
.foot-col li{margin-bottom:12px}
.foot-col a{font-size:.9375rem;font-weight:450;color:var(--body);transition:color .3s}
.foot-col a:hover{color:var(--ink)}
.foot-col .addr{font-size:.9375rem;line-height:2}
.socials{display:flex;flex-wrap:wrap;gap:6px 22px;margin-top:26px}
.socials a{
  font-size:.875rem;font-weight:450;color:var(--body);
  position:relative;padding-bottom:4px;
  transition:color .3s;
}
.socials a::after{
  content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;
  background:var(--ink);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.socials a:hover{color:var(--ink)}
.socials a:hover::after{transform:scaleX(1)}
.foot-bottom{
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;
  padding:26px 0;font-size:.8125rem;letter-spacing:0;color:var(--faint);
}
.foot-bottom .fig{color:var(--taupe)}
.foot-mark{
  font-weight:450;letter-spacing:-.04em;line-height:.72;
  font-size:clamp(4rem,14vw,13rem);
  color:rgba(24,23,19,.055);
  text-align:center;white-space:nowrap;
  user-select:none;pointer-events:none;
  margin-bottom:-.06em;
}

/* ---------- subpage header ---------- */
.page-head{
  padding:calc(64px + clamp(70px,10vw,140px)) 0 clamp(56px,7vw,100px);
  border-bottom:1px solid var(--line);
}
.page-head h1{max-width:18ch}
.page-head .lead{max-width:62ch;margin-top:30px}

/* ---------- about page ---------- */
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.vm-card{padding:0}
.vm-card:first-child{padding-right:clamp(36px,4.5vw,70px)}
.vm-card + .vm-card{border-left:1px solid var(--line);padding-left:clamp(36px,4.5vw,70px)}
.vm-card .vm-i{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1.05rem;color:var(--taupe);
  display:block;margin-bottom:20px;
}
.vm-card h3{font-size:clamp(1.5rem,2.2vw,2rem);font-weight:450;letter-spacing:-.02em;margin-bottom:18px}

/* timeline — hairline ledger */
.timeline{max-width:1000px;margin:0 auto;border-top:1px solid var(--line)}
.tl-item{
  display:grid;grid-template-columns:clamp(90px,12vw,150px) 1fr;
  gap:clamp(20px,4vw,60px);align-items:start;
  padding:clamp(28px,3.5vw,44px) 0;
  border-bottom:1px solid var(--line);
}
.tl-item .yr{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(1.8rem,2.6vw,2.4rem);color:var(--taupe);line-height:1;letter-spacing:0;
}
.tl-item h3{font-size:1.25rem;font-weight:475;letter-spacing:-.015em;margin-bottom:8px}
.tl-item p{max-width:58ch;font-size:.9375rem}

/* ---------- brands page ---------- */
.brand-feature{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,110px);
  align-items:center;padding:clamp(60px,8vw,120px) 0;border-bottom:1px solid var(--line);
}
.brand-feature:last-of-type{border-bottom:0}
.brand-feature.flip .bf-media{order:2}
.brand-feature .bf-media{overflow:hidden;position:relative}
.brand-feature .bf-media .ratio{aspect-ratio:4/5;overflow:hidden}
.brand-feature .bf-media img{width:100%;height:100%;object-fit:cover}
.brand-feature .bf-logo{height:28px;width:auto;margin-bottom:34px;opacity:.9}
.brand-feature h2{margin-bottom:20px}
.brand-feature .bf-meta{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1.05rem;letter-spacing:0;color:var(--taupe);
  margin-top:26px;
}

/* ---------- career page ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,40px)}
.pillar{border-top:1px solid var(--ink);padding-top:30px}
.pillar .pn{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1rem;color:var(--taupe);display:block;margin-bottom:20px;
}
.pillar h3{font-size:1.3rem;font-weight:475;letter-spacing:-.015em;margin-bottom:12px}
.benefit-list{border-top:1px solid var(--line)}
.benefit-list li{
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:22px 0;border-bottom:1px solid var(--line);
  font-size:1.15rem;font-weight:450;letter-spacing:-.01em;color:var(--ink);
}
.benefit-list li .bi{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:.9375rem;letter-spacing:0;color:var(--taupe);text-transform:none;
}

/* ---------- contact page ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(50px,7vw,120px)}
.c-cards{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.c-card{
  display:grid;grid-template-columns:clamp(90px,22%,150px) 1fr auto;
  align-items:center;gap:18px;
  padding:26px 0;border-bottom:1px solid var(--line);
  color:var(--ink);
}
.c-card .cl{
  font-size:.6875rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--faint);
}
.c-card .cv{
  font-size:clamp(1.05rem,1.6vw,1.25rem);font-weight:450;letter-spacing:-.01em;
  transition:color .3s;
}
.c-card .arr{color:var(--ink);opacity:0;transform:translateX(-8px);
  transition:opacity .35s var(--ease), transform .35s var(--ease)}
a.c-card:hover .arr{opacity:1;transform:none}
a.c-card:hover .cv{color:var(--taupe)}

.form{display:grid;grid-template-columns:1fr 1fr;gap:34px 30px}
.form .full{grid-column:1/-1}
.field label{
  display:block;
  font-size:.8125rem;font-weight:450;letter-spacing:0;
  color:var(--faint);margin-bottom:10px;
}
.field input,.field textarea,.field select{
  width:100%;border:0;border-bottom:1px solid var(--line-solid);background:transparent;
  font-family:var(--sans);font-weight:400;font-size:1.05rem;color:var(--ink);
  padding:10px 2px 14px;outline:none;border-radius:0;
  transition:border-color .4s;resize:vertical;
}
.field input:focus,.field textarea:focus{border-color:var(--taupe)}
.form .btn{justify-self:start;margin-top:6px}
.form-note{font-size:.8125rem;color:var(--faint);letter-spacing:0}

/* ---------- reveal animations ----------
   Gated behind html.anim (set by JS on load): if scripts are blocked
   or fail, no content is ever hidden — the page renders statically. */
@media (prefers-reduced-motion: no-preference){
  html.anim .rv{opacity:0;transform:translateY(14px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
  html.anim .rv.in{opacity:1;transform:none}
  html.anim .rv-img{clip-path:inset(0 0 100% 0);transition:clip-path 1.1s var(--ease)}
  html.anim .rv-img.in{clip-path:inset(0 0 0% 0)}
}

/* ---------- legacy browser fallbacks ---------- */
@supports not (aspect-ratio: 1 / 1){
  .hscroll .card .ph{height:0;padding-top:133.33%}
  .hscroll .card .ph img{position:absolute;top:0;right:0;bottom:0;left:0}
  .brand-feature .bf-media .ratio{position:relative;height:0;padding-top:125%}
  .brand-feature .bf-media .ratio img{position:absolute;top:0;left:0;right:0;bottom:0}
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .marquee{animation:none;flex-wrap:wrap;width:auto}
  .hero-media img{transition:none;transform:none}
  .mobile-menu a,.mobile-menu .mm-foot{transition:none;transform:none}
  .site-header{transition:background .2s,border-color .2s}
  .site-header.hidden{transform:none}
}

/* ---------- responsive ---------- */
@media(max-width:1080px){
  .nav-side{display:none}
  .menu-toggle{display:inline-flex}
  .site-header .bar{grid-template-columns:auto 1fr auto;height:56px}
  .wordmark{justify-self:start;grid-column:1;letter-spacing:.18em;margin-right:0;font-size:.9375rem}
  .hero{grid-template-columns:1fr}
  .hero-media{min-height:52vh;order:-1;margin-top:56px}
  .hero-copy{padding:7vh var(--pad) 12vh}
  .hero-scroll{left:var(--pad)}
  .hero-side{display:none}
  .split,.split.flip{grid-template-columns:1fr;gap:54px}
  .values-grid{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .cta-split{grid-template-columns:1fr}
  .cta-split .media{min-height:380px}
  .brand-feature{grid-template-columns:1fr;gap:44px}
  .brand-feature.flip .bf-media{order:0}
  .contact-grid{grid-template-columns:1fr}
  .vm-grid{grid-template-columns:1fr}
  .vm-card:first-child{padding-right:0}
  .vm-card + .vm-card{border-left:0;border-top:1px solid var(--line);padding-left:0;padding-top:clamp(36px,5vw,54px);margin-top:clamp(36px,5vw,54px)}
  .pillars{grid-template-columns:1fr}
  .hover-preview{display:none}
  .page-head{padding-top:calc(56px + clamp(60px,9vw,110px))}
}
@media(max-width:900px){
  .stats-band{grid-template-columns:1fr 1fr;gap:6px 28px}
  .stat{padding-top:22px}
}
@media(max-width:640px){
  .values-grid{grid-template-columns:1fr}
  .form{grid-template-columns:1fr}
  .brand-row{grid-template-columns:40px 1fr auto}
  .brand-row .meta .cat{display:none}
  .foot-top{grid-template-columns:1fr}
  .mini-stats{flex-wrap:wrap}
  .tl-item{grid-template-columns:1fr;gap:10px}
  .c-card{grid-template-columns:1fr auto;grid-template-rows:auto auto}
  .c-card .cl{grid-column:1/-1}
}

/* ---------- clamp() fallback (Safari 13.0-13.3 era) ----------
   Placed last so it wins the cascade on browsers without clamp();
   modern browsers never enter this block. */
@supports not (width: clamp(1px, 2vw, 3px)){
  .container{padding-left:5vw;padding-right:5vw}
  .section{padding:100px 0}
  .page-head{padding:140px 0 70px}
  .hero-copy{padding:110px 5vw 10vh 6vw}
  .display-xl{font-size:60px}
  .display-lg{font-size:42px}
  .display-md{font-size:30px}
  .display-sm{font-size:22px}
  .hscroll .card{flex:0 0 300px}
  .interlude{padding-top:100px}
  .interlude-media{height:480px}
  .stats-band{gap:0 32px}
  .site-header .bar{padding:0 5vw}
}
