/* ============================================================
   BELIOR — Real Estate · Editorial luxury
   Palette & type derived from the Belior brand guidelines.
   ============================================================ */

/* ---- Brand fidelity hook ----------------------------------
   The brand fonts (The Seasons / Sirenik / Cy Grotesk Key) are
   licensed and not bundled. Drop the files into assets/fonts/ and
   uncomment to get 1:1 fidelity; they will override the web fallbacks.

@font-face{ font-family:"The Seasons"; src:url("../assets/fonts/TheSeasons.woff2") format("woff2"); font-weight:400; font-display:swap; }
@font-face{ font-family:"Cy Grotesk Key"; src:url("../assets/fonts/CyGroteskKey.woff2") format("woff2"); font-weight:400; font-display:swap; }
------------------------------------------------------------- */

:root{
  /* Brand colours */
  --ink:#201E1E;            /* primary ink (brand #201E1E) */
  --ink-deep:#141313;       /* richer near-black for cinematic sections */
  --bone:#E1E5E6;           /* brand off-white */
  --paper:#F2F4F4;          /* lifted paper for airy light sections */
  --cyan:#59D8DD;           /* brand signature cyan */
  --teal:#2E6E7A;           /* deep teal (secondary) */
  --gold:#F2B200;           /* exclusive accent — used once */

  --on-dark:#EDEFEF;
  --on-dark-soft:rgba(237,239,239,.62);
  --on-light:#201E1E;
  --on-light-soft:rgba(32,30,30,.60);
  --line-dark:rgba(237,239,239,.16);
  --line-light:rgba(32,30,30,.14);

  /* Type */
  --serif:"Cormorant Garamond","The Seasons",Georgia,"Times New Roman",serif;
  --sans:"Jost","Cy Grotesk Key","Helvetica Neue",Arial,sans-serif;

  /* Rhythm */
  --pad:clamp(1.25rem,5vw,6rem);
  --section:clamp(5.5rem,12vw,11rem);
  --maxw:1480px;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-in:cubic-bezier(.6,0,.4,1);
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--sans);
  background:var(--ink-deep);
  color:var(--on-dark);
  line-height:1.6;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* Desktop-only proportional scaling. main.js sets --zoom and a fixed canvas
   width on #scaler when the window is narrower than the design width, so the
   whole page shrinks as one piece (no reflow). Mobile keeps its real layout. */
.scaler{transform-origin:top left}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
em{font-style:italic}
::selection{background:var(--cyan);color:var(--ink)}

/* Hide native cursor only when custom cursor is active */
body.has-cursor,body.has-cursor a,body.has-cursor button{cursor:none}

/* ---- Shared type helpers ---- */
.h-display{
  font-family:var(--serif);
  font-weight:400;
  line-height:1.04;
  letter-spacing:-.01em;
}
.eyebrow{
  display:inline-block;
  font-size:.72rem;
  letter-spacing:.36em;
  text-transform:uppercase;
  font-weight:400;
  color:var(--on-light-soft);
}
.eyebrow--cyan{color:var(--teal)}
.manifesto .eyebrow{color:var(--cyan);font-weight:600}   /* Statement of Purpose label, brand blue + bolder for legibility on light */
section .eyebrow{margin-bottom:1.6rem}

/* =========================================================
   PRELOADER
   ========================================================= */
.preloader{
  position:fixed;inset:0;z-index:200;
  background:var(--ink-deep);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.4rem;
  transition:opacity .8s var(--ease),visibility .8s;
}
.preloader.done{opacity:0;visibility:hidden}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:1.1rem;
  animation:floatIn 1s var(--ease) both}
.preloader__mark{width:46px;opacity:.95}
.preloader__word{font-family:var(--serif);letter-spacing:.5em;padding-left:.5em;font-size:1.15rem;color:var(--on-dark)}
.preloader__bar{width:140px;height:1px;background:var(--line-dark);overflow:hidden}
.preloader__bar span{display:block;height:100%;width:0;background:var(--cyan);animation:load 1.4s var(--ease) forwards}
@keyframes load{to{width:100%}}
@keyframes floatIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* =========================================================
   CUSTOM CURSOR
   ========================================================= */
.cursor{position:fixed;top:0;left:0;z-index:150;pointer-events:none;display:none;mix-blend-mode:difference}
.cursor__dot{position:absolute;width:5px;height:5px;border-radius:50%;background:#fff;transform:translate(-50%,-50%)}
.cursor__ring{position:absolute;width:38px;height:38px;border:1px solid rgba(255,255,255,.7);border-radius:50%;
  transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),opacity .3s}
.cursor.is-hover .cursor__ring{width:64px;height:64px;opacity:.5}
@media (hover:hover) and (pointer:fine){.cursor{display:block}}

/* =========================================================
   NAVIGATION
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.5rem var(--pad);
  transition:padding .4s var(--ease),background .4s var(--ease),box-shadow .4s var(--ease);
}
.nav.scrolled{
  padding:.85rem var(--pad);
  background:rgba(20,19,19,.72);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line-dark);
}
.nav__brand{display:flex;align-items:center}
.nav__mark{width:27px}
.nav__links{display:flex;gap:2.4rem}
.nav__links a{
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--on-dark-soft);
  padding:.2rem 0;transition:color .3s var(--ease);
}
.nav__links a:hover{color:var(--cyan)}
.nav__burger{display:none;background:none;border:0;width:34px;height:34px;flex-direction:column;justify-content:center;gap:6px;padding:0}
.nav__burger span{display:block;height:1.4px;width:24px;background:var(--on-dark);transition:transform .4s var(--ease),opacity .3s}

/* =========================================================
   MOBILE MENU
   ========================================================= */
.menu{
  position:fixed;inset:0;z-index:90;background:var(--ink-deep);
  display:flex;flex-direction:column;justify-content:center;
  padding:var(--pad);
  clip-path:inset(0 0 100% 0);
  transition:clip-path .7s var(--ease);
  pointer-events:none;
}
.menu.open{clip-path:inset(0 0 0 0);pointer-events:auto}
.menu__links{display:flex;flex-direction:column;gap:.4rem}
.menu__links a{
  font-family:var(--serif);font-size:clamp(2.4rem,11vw,4rem);color:var(--on-dark);
  display:flex;align-items:baseline;gap:1rem;padding:.4rem 0;
  opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease),transform .5s var(--ease),color .3s;
}
.menu.open .menu__links a{opacity:1;transform:none}
.menu.open .menu__links a:nth-child(1){transition-delay:.18s}
.menu.open .menu__links a:nth-child(2){transition-delay:.26s}
.menu.open .menu__links a:nth-child(3){transition-delay:.34s}
.menu.open .menu__links a:nth-child(4){transition-delay:.42s}
.menu.open .menu__links a:nth-child(5){transition-delay:.50s}
.menu__links a:hover{color:var(--cyan)}
.menu__idx{font-family:var(--sans);font-size:.8rem;letter-spacing:.2em;color:var(--teal)}
.menu__foot{margin-top:auto;padding-top:2rem;display:flex;justify-content:space-between;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--on-dark-soft)}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;min-height:calc(100svh / var(--zoom,1));
  display:grid;grid-template-rows:1fr auto;align-items:center;
  padding:7rem var(--pad) 3rem;
  background:var(--ink-deep);
  overflow:hidden;
}
.hero__video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;z-index:0;
}
.hero__scrim{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(15,17,18,.55) 0%, rgba(15,17,18,.26) 34%,
    rgba(15,17,18,.30) 64%, rgba(15,17,18,.62) 100%);
}
.hero__meta{
  position:absolute;top:6.5rem;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--on-dark-soft);z-index:3;text-shadow:0 1px 14px rgba(0,0,0,.5);
}
.hero__meta--tl{left:var(--pad)}
.hero__meta--tr{right:var(--pad)}
.hero__meta::before{content:"";display:inline-block;width:26px;height:1px;background:var(--cyan);vertical-align:middle;margin-right:.8rem;opacity:.7}

/* The colliding wordmark — "BE | image | OR" */
.hero__title{
  position:absolute;left:0;right:0;top:var(--horizon,46.2%);transform:translateY(-100%);
  display:flex;align-items:flex-end;justify-content:center;gap:clamp(.21rem,21vw,14.7rem);
  font-family:var(--serif);font-weight:500;
  font-size:clamp(5.5rem,26vw,22rem);
  line-height:.8;letter-spacing:-.02em;
  color:var(--cyan);opacity:.4;
  padding:0 var(--pad);z-index:3;
  pointer-events:none;text-shadow:0 4px 40px rgba(0,0,0,.3);
}
/* BE / OR — standing on the skyline; 30% smaller than the previous step */
.hero__title-pre,.hero__title-post{transform:scale(.42);transform-origin:center bottom}
.hero__media{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:2;width:clamp(220px,30vw,400px);aspect-ratio:3/4.4;
  overflow:hidden;border-radius:2px;
  box-shadow:0 40px 120px rgba(0,0,0,.5);
}
.hero__media .motif{width:100%;height:100%}
.hero__tag{
  grid-row:2;text-align:center;z-index:3;position:relative;
  font-family:var(--serif);font-style:italic;font-size:clamp(1.15rem,2.4vw,1.7rem);
  color:var(--on-dark);letter-spacing:.01em;text-shadow:0 2px 24px rgba(0,0,0,.55);
}
.hero__scroll{
  position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--on-dark-soft);z-index:3;
}
.hero__scroll i{display:block;width:1px;height:46px;background:linear-gradient(var(--cyan),transparent);
  animation:scrollPulse 2s var(--ease) infinite}
@keyframes scrollPulse{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* Photo placeholder caption (brand convention) */
[data-photo]{position:relative;background:var(--ink);isolation:isolate}
[data-photo] figcaption{
  position:absolute;left:0;right:0;bottom:1rem;text-align:center;
  font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.4);z-index:2;
}
[data-photo] figcaption.figcaption--dark{color:rgba(32,30,30,.45)}

/* =========================================================
   DEVELOPER MARQUEE — thin credibility strip under the hero
   ========================================================= */
.marquee{
  background:var(--ink-deep);
  border-block:1px solid var(--line-dark);
  overflow:hidden;padding-block:.9rem;
  -webkit-mask-image:linear-gradient(to right,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(to right,transparent,#000 7%,#000 93%,transparent);
}
.marquee__track{display:flex;width:max-content;align-items:center;
  animation:marqueeScroll 46s linear infinite;will-change:transform}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__item{flex:0 0 auto;margin-inline:clamp(1.4rem,2.8vw,2.6rem);
  font-family:var(--sans);font-weight:600;font-size:.82rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--on-dark-soft);white-space:nowrap;opacity:.85;
  transition:color .35s var(--ease),opacity .35s var(--ease)}
.marquee__item:hover{color:var(--cyan);opacity:1}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){
  .marquee{-webkit-mask-image:none;mask-image:none}
  .marquee__track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;row-gap:.6rem}
}

/* =========================================================
   PHILOSOPHY / MANIFESTO
   ========================================================= */
.manifesto{
  background:var(--bone);color:var(--ink);
  padding:clamp(5rem,10.8vw,9.9rem) var(--pad);   /* ~10% less vertical height than var(--section) */
  display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,6vw,5.5rem);align-items:center;
  max-width:var(--maxw);margin-inline:auto;
}
.manifesto__media{order:-1;display:grid;grid-template-columns:1fr 1fr;gap:clamp(.8rem,2vw,1.4rem);align-items:start}
.manifesto__lead{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(1.24rem,2.1vw,1.8rem);line-height:1.28;letter-spacing:-.008em;
  margin-bottom:1.5rem;
}
.manifesto__p{color:var(--on-light-soft);font-size:.97rem;line-height:1.7;max-width:52ch;margin-top:1.05rem}
.manifesto__close{
  font-family:var(--serif);font-style:italic;color:var(--ink);
  font-size:clamp(1.05rem,1.52vw,1.27rem);line-height:1.45;margin-top:1.6rem;
}
.manifesto__img{position:relative;aspect-ratio:3/4.7;overflow:hidden;border-radius:2px;   /* ~11% shorter than 3/5.28 */
  box-shadow:0 24px 70px rgba(32,30,30,.16)}
.manifesto__img .motif{width:100%;height:100%}
.manifesto__img--b{margin-top:clamp(2.25rem,6.3vw,4.95rem)}  /* sits lower than image A */

/* =========================================================
   ETHOS
   ========================================================= */
.ethos{
  /* light Belior blue (cyan tint over light paper, so text stays readable) */
  background:linear-gradient(rgba(89,216,221,.35),rgba(89,216,221,.35)),var(--paper);color:var(--ink);
  padding:var(--section) var(--pad);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,6rem);align-items:start;
  max-width:var(--maxw);margin-inline:auto;
}
.ethos__head{position:sticky;top:18vh}
.ethos__head .eyebrow{color:var(--teal)}
.ethos__head .h-display{font-size:clamp(2rem,3.6vw,3.4rem);margin-top:1.2rem;max-width:16ch}
.ethos__head em{color:var(--teal)}
.ethos__list{list-style:none;display:flex;flex-direction:column}
.ethos__list li{display:flex;gap:1.6rem;padding:2rem 0;border-top:1px solid var(--line-light);align-items:baseline}
.ethos__list li:last-child{border-bottom:1px solid var(--line-light)}
.ethos__idx{font-family:var(--serif);font-size:1rem;color:var(--teal);min-width:2.5rem}
.ethos__list p{font-family:var(--serif);font-size:clamp(1.3rem,2.4vw,1.9rem);line-height:1.3;color:var(--ink)}
.ethos__list strong{font-weight:500;font-style:italic}

/* =========================================================
   APPROACH — one principle at a time (cinematic rotator)
   ========================================================= */
.approach{
  /* left half black (text), right half a full-bleed image (fallback blue behind) */
  background:linear-gradient(to right,var(--ink) 0 50%,var(--cyan) 50% 100%);
  color:var(--on-dark);
  padding:0;
  display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr;gap:0;align-items:stretch;
  max-width:var(--maxw);margin-inline:auto;
  min-height:clamp(34rem,84vh,50rem);
}
/* index (text) on the left, viewer (full-bleed image) on the right */
.approach__index{order:-1;display:flex;flex-direction:column;justify-content:center;
  padding:clamp(3rem,7vw,6rem) clamp(2rem,5vw,4rem) clamp(3rem,7vw,6rem) var(--pad)}
.approach__viewer{order:0}
/* ---- Viewer: stacked slides; the image fills the entire right half ---- */
.approach__viewer{position:relative;width:100%;height:100%;overflow:hidden;background:transparent}
.approach__slide{position:absolute;inset:0;opacity:0;visibility:hidden;background:transparent;
  transition:opacity 1s var(--ease),visibility 1s var(--ease)}
.approach__slide.is-active{opacity:1;visibility:visible}
.approach__slide .media__img{transition:opacity 1.2s var(--ease),transform 7s var(--ease)}
/* slow ken-burns drift on the active image (only visible once a photo loads) */
.approach__slide.is-active .media__img{transform:scale(1.07)}
/* the image fills the right half at full opacity (numeral sits on top) */
.approach .approach__slide.is-loaded .media__img{opacity:1}
/* numeral stays on top of the image (no longer hidden when a photo loads) */
.approach__ghost{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2;
  font-family:var(--serif);font-size:clamp(4.2rem,11vw,8.4rem);color:var(--cyan);
  text-shadow:0 2px 30px rgba(20,19,19,.4);pointer-events:none}
.approach__caption{position:absolute;left:0;right:0;bottom:1rem;text-align:center;z-index:3;
  font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;color:rgba(20,19,19,.45)}
.approach__viewer.is-loaded .approach__caption{opacity:0;transition:opacity .8s var(--ease)}

/* ---- Index: the three names, only the active one lit ---- */
.approach__list{list-style:none;display:flex;flex-direction:column;gap:.1rem;margin-bottom:2.2rem}
.approach__name{display:flex;align-items:baseline;gap:1.1rem;width:100%;text-align:left;
  background:none;border:0;cursor:pointer;padding:.45rem 0;color:var(--on-dark);
  opacity:.3;transition:opacity .5s var(--ease),color .5s var(--ease),transform .5s var(--ease)}
.approach__no{font-family:var(--serif);font-size:.85rem;letter-spacing:.22em;min-width:2.4rem;color:inherit}
.approach__word{font-family:var(--serif);font-weight:400;line-height:1.04;
  font-size:clamp(1.7rem,3.9vw,3.05rem)}
.approach__name.is-active{opacity:1;color:var(--cyan);transform:translateX(.3rem)}
@media (hover:hover) and (pointer:fine){
  .approach__name:hover{opacity:.65}
  .approach__name.is-active:hover{opacity:1}
}

/* ---- Copy: descriptions crossfade in place ---- */
.approach__copy{position:relative;min-height:clamp(8.5rem,17vh,10.5rem)}
.approach__desc{position:absolute;inset:0;margin:0;max-width:44ch;
  color:var(--on-dark-soft);font-size:1.02rem;line-height:1.75;
  opacity:0;transform:translateY(10px);pointer-events:none;
  transition:opacity .6s var(--ease),transform .6s var(--ease)}
.approach__desc.is-active{opacity:1;transform:none}

/* ---- Progress: a slow cyan line for the auto-advance ---- */
.approach__progress{position:relative;height:1px;max-width:22rem;background:var(--line-dark)}
.approach__bar{position:absolute;left:0;top:0;height:100%;width:0;background:var(--cyan)}
.approach__bar.run{animation:approachFill var(--dur,5500ms) linear forwards}
@keyframes approachFill{from{width:0}to{width:100%}}

/* =========================================================
   FEATURED OPPORTUNITY — briefing
   ========================================================= */
.brief{
  background:var(--ink-deep);color:var(--on-dark);
  padding:var(--section) var(--pad);
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,6vw,5.5rem);align-items:center;
  max-width:var(--maxw);margin-inline:auto;
}
.brief__media{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:2px;box-shadow:0 24px 70px rgba(89,216,221,.10)}
.brief__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.brief__media .motif{width:100%;height:100%}
.brief__sig{position:absolute;right:1.1rem;bottom:1.1rem;z-index:2;opacity:.35}
.brief__sig img{width:28px}
.brief__title{font-size:clamp(1.8rem,3.75vw,3.3rem);margin:.6rem 0 2rem;text-transform:uppercase;letter-spacing:.012em}
.brief__facts{display:flex;gap:2.5rem;margin-bottom:2rem;flex-wrap:wrap}
.brief__facts dt{font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--on-dark-soft);margin-bottom:.4rem}
.brief__facts dd{font-family:var(--serif);font-size:1.35rem;font-variant-numeric:tabular-nums;color:var(--cyan)}
.brief__body p{color:var(--on-dark-soft);font-size:.9rem;max-width:42ch;margin-bottom:2.2rem}
/* dark-section overrides: bright cyan eyebrow + light ghost button */
.brief .eyebrow{color:var(--cyan);font-size:.65rem}
.brief .btn--ghost{border-color:var(--line-dark);color:var(--on-dark)}
.brief .btn--ghost:hover{background:var(--on-dark);color:var(--ink);border-color:var(--on-dark)}

/* =========================================================
   VISION
   ========================================================= */
.vision{
  background:var(--paper);color:var(--ink);
  padding:var(--section) var(--pad);
  display:grid;grid-template-columns:1fr .8fr;gap:clamp(2rem,6vw,6rem);align-items:center;
  max-width:var(--maxw);margin-inline:auto;
}
.vision__text .h-display{font-size:clamp(2.2rem,4.6vw,4rem);margin:1.2rem 0 2rem;max-width:14ch}
.vision__text p{color:var(--on-light-soft);max-width:50ch;margin-bottom:1.4rem}
.vision__media{aspect-ratio:3/4;overflow:hidden;border-radius:2px}
.vision__media .motif{width:100%;height:100%}

/* =========================================================
   CONTACT
   ========================================================= */
.contact{
  background:var(--cyan);color:var(--ink);           /* vibrant Belior blue, black text */
  padding:var(--section) var(--pad);
  display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start;
  max-width:var(--maxw);margin-inline:auto;
}
.gold-badge{                                          /* plain bold header, black */
  display:inline-block;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--ink);font-weight:600;
}
.contact__title{font-size:clamp(2.4rem,5vw,4.2rem);margin:1.2rem 0 1.6rem}
.contact__head p{color:rgba(32,30,30,.82);max-width:38ch}

.form{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem 1.4rem}
.field{position:relative}
.field--full{grid-column:1/-1}
.field input,.field select,.field textarea{
  width:100%;background:transparent;border:0;border-bottom:1px solid rgba(32,30,30,.35);
  color:var(--ink);font-family:var(--sans);font-size:1rem;font-weight:300;
  padding:1.4rem 0 .7rem;transition:border-color .3s;resize:none;
}
.field textarea{min-height:3rem}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink)}
.field label{
  position:absolute;left:0;top:1.4rem;color:rgba(32,30,30,.7);pointer-events:none;
  font-size:1rem;transition:top .25s var(--ease),font-size .25s var(--ease),color .25s var(--ease),letter-spacing .25s;
}
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{
  top:-.2rem;font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);
}
/* Luxury select: its label sits above, custom chevron, muted placeholder */
.field--select .label--above{display:block;position:static;
  font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(32,30,30,.72);margin-bottom:.55rem}
.field select{
  appearance:none;-webkit-appearance:none;cursor:pointer;color:var(--ink);
  padding:.45rem 1.6rem .7rem 0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' fill='none' stroke='%23201E1E' stroke-width='1.4'%3E%3Cpath d='M1 2l6 5 6-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .1rem center;background-size:.85rem;
}
.field select:invalid{color:rgba(32,30,30,.5)}
.field select option{background:var(--ink);color:var(--on-dark)}
.field select option[disabled]{color:rgba(237,239,239,.45)}
.form__actions{display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap;margin-top:.6rem}
.form__alt{font-size:.82rem;color:rgba(32,30,30,.75);border-bottom:1px solid transparent;transition:border-color .3s,color .3s}
.form__alt:hover{color:var(--ink-deep);border-color:var(--ink-deep)}
.form__note{grid-column:1/-1;font-size:.85rem;color:var(--ink-deep);min-height:1.2em}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{display:inline-flex;align-items:center;gap:.6em;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.95rem 1.6rem;border-radius:100px;transition:transform .35s var(--ease),background .35s,color .35s;border:1px solid transparent}
.btn span{transition:transform .35s var(--ease)}
.btn:hover span{transform:translateX(5px)}
.btn--solid{background:var(--cyan);color:var(--ink);border:0}
.btn--solid:hover{transform:translateY(-2px);background:#7ee6ea}
/* Contact CTA: black button with gold Belior text (inverts on hover) */
.contact .btn--solid{background:var(--ink-deep);color:var(--gold)}
.contact .btn--solid:hover{background:var(--gold);color:var(--ink-deep)}
.btn--ghost{border-color:var(--line-light);color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--on-dark);border-color:var(--ink)}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--ink-deep);color:var(--on-dark);padding:clamp(2.5rem,5vw,4rem) var(--pad) 2.5rem}
/* Outro: the full lockup sits centred in the vertical middle of the band, raised
   from the bottom, as the closing centrepiece. */
.footer__top{display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:44vh;text-align:center;border-bottom:1px solid var(--line-dark);padding-bottom:3rem;margin-bottom:3rem}
.footer__lockup{width:clamp(120px,16vw,180px);margin:0 auto 1.4rem;opacity:.95}
.footer__tag{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--on-dark-soft)}
.footer__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;max-width:var(--maxw);margin:0 auto 3.5rem}
.footer__grid h4{font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);margin-bottom:1rem;font-weight:400}
.footer__grid p{color:var(--on-dark-soft);font-size:.95rem;line-height:2}
.footer__grid a{transition:color .3s}
.footer__grid a:hover{color:var(--cyan)}
.footer__social{display:flex;gap:1.1rem;align-items:center}
.footer__social a{color:var(--on-dark);display:inline-flex;transition:color .3s var(--ease),transform .3s var(--ease)}
.footer__social a:hover{color:var(--cyan);transform:translateY(-2px)}
.footer__social svg{width:22px;height:22px;display:block}
.footer__license{color:rgba(237,239,239,.4)}
.footer__base{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  padding-top:2rem;border-top:1px solid var(--line-dark);
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--on-dark-soft)}
.muted{color:rgba(237,239,239,.38)}

/* =========================================================
   SCROLL REVEAL ANIMATIONS
   ========================================================= */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease);
  transition-delay:calc(var(--i,0)*90ms)}
[data-reveal].in{opacity:1;transform:none}

[data-split] .word{display:inline-block;overflow:hidden;vertical-align:top}
[data-split] .word > span{display:inline-block;transform:translateY(110%);transition:transform .8s var(--ease);
  transition-delay:calc(var(--wi,0)*40ms)}
[data-split].in .word > span{transform:none}

/* =========================================================
   PHOTOGRAPHY — real images auto-styled to monochrome brand
   ========================================================= */
.media__img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;
  filter:grayscale(1) contrast(1.06) brightness(.96);
  opacity:0;transition:opacity 1.2s var(--ease),transform 1.6s var(--ease);
}
[data-photo].is-loaded .media__img{opacity:1}
[data-photo].is-loaded .motif{opacity:0;transition:opacity .8s var(--ease)}
[data-photo].is-loaded figcaption{opacity:0}
.brief__media:hover .media__img,
.vision__media:hover .media__img{transform:scale(1.04)}

/* =========================================================
   FORM STATES
   ========================================================= */
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.btn[aria-busy="true"]{opacity:.7;pointer-events:none}
.btn[aria-busy="true"] span{animation:pulse 1s var(--ease) infinite}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}
.form.is-done .field,.form.is-done .form__actions{opacity:.45;pointer-events:none;transition:opacity .5s}
.form__note.is-error{color:var(--ink)}

/* =========================================================
   RESPONSIVE
   ========================================================= */
/* Above 800px the layout never reflows: on a narrowed desktop window the whole
   page is scaled down as one piece by #scaler (see main.js), so every section
   keeps its full-size, side-by-side structure. The single-column / stacked
   layout below is reserved for genuine phones and small tablets. */
@media (max-width:800px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .manifesto{grid-template-columns:1fr;gap:2.5rem}
  .ethos{grid-template-columns:1fr;gap:3rem}
  .ethos__head{position:static}
  .vision{grid-template-columns:1fr}
  .vision__media{aspect-ratio:16/10;order:-1}
  .contact{grid-template-columns:1fr}
  /* stacked: no left/right split — blue numeral panel on top, text on black below */
  .approach{grid-template-columns:1fr;grid-template-rows:auto;gap:0;background:var(--ink);min-height:0}
  .approach__viewer{aspect-ratio:4/5;height:auto;order:-1}
  .approach__index{order:0;padding:clamp(2.5rem,8vw,4rem) var(--pad)}
  .approach__copy{min-height:7rem}
  .brief{grid-template-columns:1fr;gap:2.5rem}
  .brief__media{aspect-ratio:4/3}
  .hero__title{gap:clamp(.2rem,16vw,5rem);font-size:clamp(4.5rem,22vw,9rem)}
  .hero__media{width:clamp(180px,42vw,260px)}
}
@media (max-width:560px){
  .form{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr;gap:2.4rem;text-align:center}
  .footer__social{justify-content:center}   /* centre the social icons like the rest of the footer */
  .footer__base{justify-content:center;text-align:center}
  .hero__title{font-size:clamp(4rem,24vw,7rem)}   /* keep BE / OR side-by-side on the horizon, like desktop */
  .hero__media{position:relative;top:auto;left:auto;transform:none;margin:1.2rem auto 0;
    width:min(70vw,260px);box-shadow:0 24px 60px rgba(0,0,0,.5)}
  .hero{grid-template-rows:auto;gap:1.5rem;padding-top:8rem}
  .hero__meta{display:none}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hero__scroll i{animation:none}
  [data-reveal],[data-split] .word > span{opacity:1;transform:none}
  .cursor{display:none!important}
}
