/* ============================================================
   DANISH STUDIO — Cinematic Editorial Theme
   ============================================================ */

:root{
  /* Ink / surfaces */
  --ink:        #07080A;
  --ink-2:      #0C0E12;
  --ink-3:      #14171D;
  --ink-soft:   #1B1F26;
  --line:       rgba(255,255,255,.10);
  --line-soft:  rgba(255,255,255,.06);

  /* Type */
  --paper:      #F4F6F8;
  --paper-dim:  #C7CCD3;
  --muted:      #8B939E;
  --muted-2:    #5E656F;

  /* Brand — electric blue from the DS logo */
  --brand:      #2BA6FF;
  --brand-2:    #0C74E0;
  --brand-3:    #0A5CC0;
  --glow:       rgba(43,166,255,.45);

  /* Warmth accent (newborn / family) */
  --warm:       #E7C9A0;

  /* Fonts */
  --serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono:  "JetBrains Mono", ui-monospace, "SF Mono", monospace;

  /* Layout */
  --pad: clamp(20px, 5vw, 80px);
  --maxw: 1480px;

  --ease: cubic-bezier(.22,1,.36,1);
  --ease-soft: cubic-bezier(.4,0,.2,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);
  color:var(--paper);
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body.is-locked{ overflow:hidden; }

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
ul,ol{ list-style:none; }
::selection{ background:var(--brand); color:#fff; }

.wrap{ width:min(100% - calc(var(--pad)*2), var(--maxw)); margin-inline:auto; }

/* ---------- Type helpers ---------- */
.eyebrow{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted); display:flex; align-items:center; gap:.7em;
  margin-bottom:1.6rem;
}
.eyebrow span{ width:34px; height:1px; background:var(--brand); display:inline-block; }

.sec-head{ padding-block: clamp(70px,9vw,140px) clamp(34px,4vw,60px); }
.sec-head--split{ display:flex; justify-content:space-between; align-items:flex-end; gap:40px; flex-wrap:wrap; }
.sec-title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2.3rem, 6vw, 5rem); line-height:1.02; letter-spacing:-.02em;
}

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{
  position:fixed; inset:0; z-index:9999; background:var(--ink);
  display:grid; place-items:center; color:var(--paper);
  transition:opacity .8s var(--ease), visibility .8s;
}
.preloader.done{ opacity:0; visibility:hidden; }
.preloader__inner{ text-align:center; width:min(80vw,420px); }
.preloader__logo{ display:flex; flex-direction:column; align-items:center; gap:18px; color:var(--brand); }
.aperture{ animation:spin 8s linear infinite; }
.aperture__blades path{ transform-origin:60px 60px; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.preloader__word{
  font-family:var(--mono); letter-spacing:.42em; font-size:.74rem; color:var(--paper);
  padding-left:.42em; opacity:.85;
}
.preloader__count{
  font-family:var(--serif); font-size:3.6rem; font-weight:500; margin-top:26px; color:var(--paper);
}
.preloader__count i{ font-size:1.1rem; font-style:normal; color:var(--muted); vertical-align:super; }
.preloader__bar{ height:2px; background:var(--line); margin-top:18px; overflow:hidden; border-radius:2px; }
.preloader__bar span{ display:block; height:100%; width:0%; background:var(--brand); box-shadow:0 0 18px var(--glow); }

/* ============================================================
   CURSOR
   ============================================================ */
.cursor{
  position:fixed; top:0; left:0; width:10px; height:10px; border-radius:50%;
  background:var(--brand); pointer-events:none; z-index:9000;
  transform:translate(-50%,-50%); mix-blend-mode:difference;
  transition:width .3s var(--ease), height .3s var(--ease), background .3s;
  display:grid; place-items:center;
}
.cursor.is-hover{ width:74px; height:74px; background:rgba(43,166,255,.18); mix-blend-mode:normal; border:1px solid var(--brand); }
.cursor.is-down{ transform:translate(-50%,-50%) scale(.8); }
.cursor__label{
  font-family:var(--mono); font-size:.6rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--paper); opacity:0; transition:opacity .2s; white-space:nowrap;
}
.cursor.is-hover .cursor__label{ opacity:1; }
@media (hover:none), (pointer:coarse){ .cursor{ display:none; } }

/* ---------- Scroll progress ---------- */
.scroll-progress{
  position:fixed; top:0; left:0; height:2px; width:0%; z-index:8000;
  background:linear-gradient(90deg,var(--brand),var(--warm)); box-shadow:0 0 12px var(--glow);
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  transition:transform .5s var(--ease), background .4s, backdrop-filter .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{ background:rgba(7,8,10,.72); backdrop-filter:blur(18px) saturate(140%); border-color:var(--line-soft); }
.nav.hidden{ transform:translateY(-110%); }
.nav__inner{
  width:min(100% - 48px, var(--maxw)); margin-inline:auto;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:20px 0;
}
.nav.scrolled .nav__inner{ padding:14px 0; }

.brand{ display:flex; align-items:center; gap:12px; color:var(--paper); }
.brand__mark{ color:var(--brand); transition:transform .6s var(--ease); }
.brand:hover .brand__mark{ transform:rotate(90deg); }
.brand__type{ font-family:var(--serif); font-size:1.3rem; font-weight:600; letter-spacing:.01em; }
.brand__type em{ font-style:normal; color:var(--brand); font-weight:500; margin-left:.18em; }

.nav__links{ display:flex; gap:34px; }
.nav__links a{
  font-size:.9rem; color:var(--paper-dim); position:relative; padding:4px 0; letter-spacing:.01em;
  transition:color .3s;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--brand); transition:width .35s var(--ease);
}
.nav__links a:hover{ color:var(--paper); }
.nav__links a:hover::after{ width:100%; }

.nav__burger{ display:none; width:42px; height:42px; flex-direction:column; gap:6px; align-items:center; justify-content:center; }
.nav__burger span{ width:22px; height:1.5px; background:var(--paper); transition:transform .4s var(--ease), opacity .3s; }
.nav__burger.open span:first-child{ transform:translateY(3.75px) rotate(45deg); }
.nav__burger.open span:last-child{ transform:translateY(-3.75px) rotate(-45deg); }

@media (max-width:900px){
  .nav .nav__links, .nav .nav__cta{ display:none !important; }
  .nav .nav__burger{ display:flex !important; }
}

/* ---------- Buttons ---------- */
.btn{
  position:relative; display:inline-flex; align-items:center; justify-content:center;
  font-size:.86rem; font-weight:500; letter-spacing:.02em; border-radius:100px;
  padding:15px 30px; overflow:hidden; transition:color .4s var(--ease), border-color .4s, transform .2s;
  will-change:transform;
}
.btn span{ position:relative; z-index:2; }
.btn--solid{ background:var(--brand); color:#04121f; font-weight:600; }
.btn--solid::before{ content:""; position:absolute; inset:0; background:var(--paper); transform:translateY(101%); transition:transform .5s var(--ease); z-index:1; }
.btn--solid:hover{ color:#000; }
.btn--solid:hover::before{ transform:translateY(0); }
.btn--ghost{ border:1px solid var(--line); color:var(--paper); }
.btn--ghost::before{ content:""; position:absolute; inset:0; background:var(--paper); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); z-index:1; }
.btn--ghost:hover{ color:#000; border-color:var(--paper); }
.btn--ghost:hover::before{ transform:scaleX(1); }
.btn--pill{ border:1px solid var(--line); padding:11px 22px; font-size:.82rem; }
.btn--pill::before{ content:""; position:absolute; inset:0; background:var(--brand); transform:translateY(101%); transition:transform .45s var(--ease); z-index:1; }
.btn--pill:hover{ color:#04121f; border-color:var(--brand); }
.btn--pill:hover::before{ transform:translateY(0); }
.btn--lg{ padding:19px 44px; font-size:1rem; }
.btn--wide{ width:100%; }

/* ============================================================
   MOBILE MENU
   ============================================================ */
.menu{ position:fixed; inset:0; z-index:999; visibility:hidden; }
.menu.open{ visibility:visible; }
.menu__bg{ position:absolute; inset:0; background:var(--ink-2); clip-path:circle(0% at 100% 0); transition:clip-path .7s var(--ease); }
.menu.open .menu__bg{ clip-path:circle(150% at 100% 0); }
.menu__nav{ position:relative; height:100%; display:flex; flex-direction:column; justify-content:center; gap:6px; padding:0 var(--pad); }
.menu__nav a{
  font-family:var(--serif); font-size:clamp(2.2rem,11vw,4rem); font-weight:500; color:var(--paper);
  display:flex; align-items:baseline; gap:18px; opacity:0; transform:translateY(30px);
  transition:opacity .5s var(--ease), transform .5s var(--ease), color .3s;
}
.menu.open .menu__nav a{ opacity:1; transform:none; }
.menu.open .menu__nav a:nth-child(1){ transition-delay:.15s; }
.menu.open .menu__nav a:nth-child(2){ transition-delay:.22s; }
.menu.open .menu__nav a:nth-child(3){ transition-delay:.29s; }
.menu.open .menu__nav a:nth-child(4){ transition-delay:.36s; }
.menu.open .menu__nav a:nth-child(5){ transition-delay:.43s; }
.menu__nav a:hover{ color:var(--brand); }
.menu__idx{ font-family:var(--mono); font-size:.8rem; color:var(--brand); }
.menu__foot{ position:absolute; bottom:40px; left:var(--pad); display:flex; gap:28px; font-family:var(--mono); font-size:.8rem; color:var(--muted); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; }
.hero__media{ position:absolute; inset:-8% 0 0 0; height:116%; z-index:0; }
.hero__img{ width:100%; height:100%; object-fit:cover; object-position:center 30%; filter:grayscale(.15) contrast(1.05); }
.hero__veil{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(7,8,10,.55) 0%, rgba(7,8,10,.15) 35%, rgba(7,8,10,.65) 78%, var(--ink) 100%),
    radial-gradient(120% 80% at 80% 10%, transparent, rgba(7,8,10,.55));
}
.hero__grain{ position:absolute; inset:0; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

.hero__content{ position:relative; z-index:2; width:min(100% - calc(var(--pad)*2), var(--maxw)); margin-inline:auto; padding-bottom:clamp(80px,12vh,160px); }
.hero__kick{
  font-family:var(--mono); font-size:.76rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--paper-dim); display:flex; align-items:center; gap:.7em; margin-bottom:22px;
}
.hero__kick .dot{ width:7px; height:7px; border-radius:50%; background:var(--brand); box-shadow:0 0 12px var(--glow); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%,100%{ opacity:1; } 50%{ opacity:.3; } }

.hero__title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2.9rem, 9.5vw, 9rem); line-height:.96; letter-spacing:-.025em;
}
.hero__title em{ font-style:italic; color:var(--brand); }
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .line span{ display:block; transform:translateY(105%); transition:transform 1s var(--ease); }
.loaded .hero__title .line span{ transform:translateY(0); }
.loaded .hero__title .line:nth-child(2) span{ transition-delay:.12s; }

.hero__sub{ max-width:46ch; margin-top:28px; color:var(--paper-dim); font-size:clamp(1rem,1.5vw,1.18rem); font-weight:300; }
.hero__actions{ display:flex; gap:16px; margin-top:38px; flex-wrap:wrap; }

.hero__scroll{ position:absolute; right:var(--pad); bottom:48px; z-index:2; display:flex; flex-direction:column; align-items:center; gap:12px; font-family:var(--mono); font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.hero__scroll i{ width:1px; height:54px; background:linear-gradient(var(--brand),transparent); position:relative; overflow:hidden; }
.hero__scroll i::after{ content:""; position:absolute; top:-54px; left:0; width:100%; height:54px; background:var(--paper); animation:scrolldash 2s var(--ease) infinite; }
@keyframes scrolldash{ to{ top:54px; } }
.hero__meta{ position:absolute; left:var(--pad); bottom:48px; z-index:2; display:flex; flex-direction:column; gap:6px; font-family:var(--mono); font-size:.66rem; letter-spacing:.12em; color:var(--muted); }
@media (max-width:860px){ .hero__meta, .hero__scroll{ display:none; } }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{ border-block:1px solid var(--line-soft); padding:26px 0; overflow:hidden; background:var(--ink); }
.marquee__track{ display:flex; align-items:center; gap:40px; width:max-content; animation:marquee 38s linear infinite; }
.marquee__track span{ font-family:var(--serif); font-style:italic; font-size:clamp(1.6rem,3vw,2.6rem); color:var(--paper); white-space:nowrap; }
.marquee__track i{ color:var(--brand); font-style:normal; font-size:1.1rem; }
@keyframes marquee{ to{ transform:translateX(-50%); } }
.marquee:hover .marquee__track{ animation-play-state:paused; }

/* ============================================================
   INTRO
   ============================================================ */
.intro{ padding-block:clamp(90px,13vw,200px); }
.intro__statement{
  font-family:var(--serif); font-weight:500; letter-spacing:-.02em;
  font-size:clamp(1.8rem, 4.4vw, 3.9rem); line-height:1.12; max-width:18ch;
}
.intro__statement em{ font-style:italic; color:var(--brand); }
.reveal-line{ display:block; overflow:hidden; }
.reveal-line > *{ display:inline-block; }
.intro__statement .reveal-line{ position:relative; }
.intro__statement .reveal-line{ clip-path:inset(0 0 110% 0); transition:clip-path .9s var(--ease); }
.intro__statement.in .reveal-line{ clip-path:inset(0 0 -10% 0); }
.intro__statement.in .reveal-line:nth-child(2){ transition-delay:.12s; }
.intro__statement.in .reveal-line:nth-child(3){ transition-delay:.24s; }

.intro__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:40px; margin-top:60px; max-width:880px; margin-left:auto; }
.intro__col p{ color:var(--paper-dim); font-size:1.05rem; font-weight:300; }

.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:30px; margin-top:clamp(60px,8vw,110px); border-top:1px solid var(--line); padding-top:50px; }
.stats li{ display:flex; flex-direction:column; gap:8px; }
.stats b{ font-family:var(--serif); font-size:clamp(2.4rem,5vw,4rem); font-weight:500; line-height:1; color:var(--paper); }
.stats span{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }

/* ============================================================
   SERVICES
   ============================================================ */
.svc{ width:min(100% - calc(var(--pad)*2), var(--maxw)); margin-inline:auto; border-top:1px solid var(--line); }
.svc__row{
  position:relative; display:grid; grid-template-columns:80px 1.1fr 1.4fr 40px; align-items:center; gap:20px;
  padding:34px 8px; border-bottom:1px solid var(--line); transition:padding .4s var(--ease), background .4s; isolation:isolate;
}
.svc__row::before{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(43,166,255,.08),transparent); opacity:0; transition:opacity .4s; z-index:-1; }
.svc__row:hover{ padding-left:28px; }
.svc__row:hover::before{ opacity:1; }
.svc__no{ font-family:var(--mono); font-size:.8rem; color:var(--brand); }
.svc__name{ font-family:var(--serif); font-size:clamp(1.5rem,3vw,2.5rem); font-weight:500; letter-spacing:-.01em; transition:color .3s; }
.svc__row:hover .svc__name{ color:var(--brand); }
.svc__desc{ color:var(--muted); font-size:.96rem; }
.svc__go{ font-size:1.4rem; color:var(--muted); justify-self:end; transition:transform .4s var(--ease), color .3s; }
.svc__row:hover .svc__go{ transform:translate(4px,-4px); color:var(--paper); }
.svc__peek{
  position:absolute; right:18%; top:50%; width:230px; aspect-ratio:4/5; border-radius:8px; overflow:hidden;
  transform:translateY(-50%) scale(.9); opacity:0; pointer-events:none; transition:opacity .4s var(--ease), transform .4s var(--ease);
  box-shadow:0 30px 70px rgba(0,0,0,.6); z-index:5;
}
.svc__peek img{ width:100%; height:100%; object-fit:cover; }
@media (hover:hover){ .svc__row:hover .svc__peek{ opacity:1; transform:translateY(-50%) scale(1); } }

@media (max-width:760px){
  .svc__row{ grid-template-columns:44px 1fr 28px; gap:12px; padding:24px 4px; }
  .svc__desc{ display:none; }
  .svc__peek{ display:none; }
}

/* ============================================================
   FEATURE (sticky)
   ============================================================ */
.feature{ position:relative; display:grid; grid-template-columns:1fr 1fr; gap:0; }
.feature__sticky{ position:relative; }
.feature__media{ position:sticky; top:0; height:100svh; overflow:hidden; }
.feature__media img{ width:100%; height:120%; object-fit:cover; }
.feature__text{ padding:clamp(80px,10vw,160px) var(--pad); display:flex; flex-direction:column; justify-content:center; gap:70px; }
.feature__block h3{ font-family:var(--serif); font-weight:500; font-size:clamp(2.4rem,5vw,4.4rem); line-height:1; letter-spacing:-.02em; margin-bottom:18px; }
.feature__block h3 em{ font-style:italic; color:var(--brand); }
.feature__block h4{ font-family:var(--serif); font-weight:500; font-size:1.5rem; margin-bottom:12px; }
.feature__block p{ color:var(--paper-dim); font-weight:300; max-width:42ch; }
@media (max-width:900px){
  .feature{ grid-template-columns:1fr; }
  .feature__media{ position:relative; height:70svh; }
  .feature__text{ gap:48px; }
}

/* ============================================================
   WORK / GALLERY
   ============================================================ */
.filters{ display:flex; gap:8px; flex-wrap:wrap; }
.filter{
  font-family:var(--mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase;
  padding:9px 16px; border:1px solid var(--line); border-radius:100px; color:var(--muted); transition:all .3s var(--ease);
}
.filter:hover{ color:var(--paper); border-color:var(--paper-dim); }
.filter.is-active{ background:var(--brand); border-color:var(--brand); color:#04121f; font-weight:500; }

.gallery{
  width:min(100% - calc(var(--pad)*2), var(--maxw)); margin-inline:auto;
  columns:3; column-gap:18px; padding-top:10px;
}
.card{ position:relative; break-inside:avoid; margin-bottom:18px; border-radius:10px; overflow:hidden; cursor:pointer; background:var(--ink-3); }
.card img{ width:100%; transition:transform .9s var(--ease), filter .6s; filter:grayscale(.2); }
.card:hover img{ transform:scale(1.05); filter:grayscale(0); }
.card figcaption{
  position:absolute; inset:auto 0 0 0; padding:24px 20px 18px;
  background:linear-gradient(0deg, rgba(7,8,10,.9), transparent);
  display:flex; flex-direction:column; gap:2px; transform:translateY(8px); opacity:0; transition:all .45s var(--ease);
}
.card:hover figcaption{ transform:none; opacity:1; }
.card figcaption span{ font-family:var(--serif); font-size:1.3rem; }
.card figcaption i{ font-family:var(--mono); font-style:normal; font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--brand); }
.card.hide{ display:none; }

.work__cta{ padding-block:clamp(50px,7vw,90px); display:flex; justify-content:center; }
.work__cta .btn{ max-width:480px; }

@media (max-width:980px){ .gallery{ columns:2; } }
@media (max-width:560px){ .gallery{ columns:1; } }

/* ============================================================
   PROCESS
   ============================================================ */
.process{ background:var(--ink-2); border-block:1px solid var(--line-soft); }
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); margin-bottom:clamp(80px,10vw,140px); border-radius:12px; overflow:hidden; }
.step{ background:var(--ink-2); padding:40px 30px 50px; transition:background .4s; min-height:300px; display:flex; flex-direction:column; }
.step:hover{ background:var(--ink-3); }
.step__no{ font-family:var(--mono); font-size:.8rem; color:var(--brand); margin-bottom:auto; }
.step h3{ font-family:var(--serif); font-weight:500; font-size:1.9rem; margin:60px 0 14px; }
.step p{ color:var(--muted); font-size:.94rem; }
@media (max-width:900px){ .steps{ grid-template-columns:repeat(2,1fr); } .step{ min-height:240px; } }
@media (max-width:520px){ .steps{ grid-template-columns:1fr; } .step{ min-height:auto; } }

/* ============================================================
   STUDIO
   ============================================================ */
.studio{ padding-block:clamp(90px,12vw,180px); }
.studio__grid{ width:min(100% - calc(var(--pad)*2), var(--maxw)); margin-inline:auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,100px); align-items:center; }
.studio__media{ position:relative; border-radius:12px; overflow:hidden; aspect-ratio:4/5; }
.studio__media img{ width:100%; height:110%; object-fit:cover; }
.studio__tag{ position:absolute; left:18px; bottom:18px; font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; padding:8px 14px; background:rgba(7,8,10,.6); backdrop-filter:blur(8px); border:1px solid var(--line); border-radius:100px; }
.studio__title{ font-family:var(--serif); font-weight:500; font-size:clamp(2rem,4.6vw,3.6rem); line-height:1.05; letter-spacing:-.02em; margin-bottom:26px; }
.studio__title em{ font-style:italic; color:var(--brand); }
.studio__text p{ color:var(--paper-dim); font-weight:300; margin-bottom:18px; max-width:50ch; }
.studio__sign{ margin-top:34px; display:flex; flex-direction:column; gap:4px; }
.studio__signature{ font-family:var(--serif); font-style:italic; font-size:1.7rem; color:var(--paper); }
.studio__role{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }

.studio__team{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:clamp(60px,8vw,110px); }
.member{ position:relative; border-radius:10px; overflow:hidden; aspect-ratio:3/4; }
.member img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.5); transition:filter .5s, transform .8s var(--ease); }
.member:hover img{ filter:grayscale(0); transform:scale(1.04); }
.member figcaption{ position:absolute; inset:auto 0 0 0; padding:18px 16px; background:linear-gradient(0deg,rgba(7,8,10,.92),transparent); }
.member figcaption b{ display:block; font-family:var(--serif); font-weight:500; font-size:1.05rem; }
.member figcaption span{ font-family:var(--mono); font-size:.64rem; letter-spacing:.08em; text-transform:uppercase; color:var(--brand); }
@media (max-width:900px){ .studio__grid{ grid-template-columns:1fr; } .studio__team{ grid-template-columns:repeat(2,1fr); } }

/* ============================================================
   QUOTES
   ============================================================ */
.quotes{ padding-block:clamp(90px,12vw,170px); background:var(--ink-2); border-block:1px solid var(--line-soft); overflow:hidden; }
.quotes__viewport{ overflow:hidden; margin-top:20px; }
.quotes__track{ display:flex; transition:transform .8s var(--ease); }
.quote{ min-width:100%; padding-right:60px; }
.quote p{ font-family:var(--serif); font-style:italic; font-weight:400; font-size:clamp(1.6rem,3.6vw,3rem); line-height:1.28; letter-spacing:-.01em; max-width:24ch; }
.quote footer{ margin-top:34px; display:flex; flex-direction:column; gap:3px; }
.quote footer b{ font-family:var(--sans); font-weight:600; font-size:1rem; }
.quote footer span{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--brand); }
.quotes__nav{ display:flex; align-items:center; gap:20px; margin-top:50px; }
.quotes__nav button{ width:54px; height:54px; border:1px solid var(--line); border-radius:50%; font-size:1.1rem; color:var(--paper); transition:all .3s var(--ease); }
.quotes__nav button:hover{ background:var(--brand); border-color:var(--brand); color:#04121f; }
.quotes__dots{ display:flex; gap:8px; }
.quotes__dots i{ width:8px; height:8px; border-radius:50%; background:var(--line); transition:all .3s; cursor:pointer; }
.quotes__dots i.on{ background:var(--brand); width:24px; border-radius:8px; }

/* ============================================================
   LOGOS / RECOGNITION
   ============================================================ */
.logos{ overflow:hidden; padding:30px 0; border-bottom:1px solid var(--line-soft); }
.logos__track{ display:flex; gap:34px; align-items:center; width:max-content; animation:marquee 40s linear infinite; }
.logos__track span{ font-family:var(--mono); font-size:.82rem; letter-spacing:.06em; color:var(--paper-dim); white-space:nowrap; }
.logos__track i{ color:var(--brand); }

/* ============================================================
   CTA
   ============================================================ */
.cta{ position:relative; min-height:90svh; display:grid; place-items:center; text-align:center; overflow:hidden; }
.cta__media{ position:absolute; inset:-8% 0; height:116%; z-index:0; }
.cta__media img{ width:100%; height:100%; object-fit:cover; }
.cta__veil{ position:absolute; inset:0; background:radial-gradient(80% 80% at 50% 50%, rgba(7,8,10,.55), var(--ink) 92%); }
.cta__content{ position:relative; z-index:2; padding:var(--pad); }
.cta__title{ font-family:var(--serif); font-weight:500; font-size:clamp(2.6rem,8vw,7rem); line-height:.98; letter-spacing:-.025em; }
.cta__title em{ font-style:italic; color:var(--brand); }
.cta__sub{ color:var(--paper-dim); margin:24px auto 40px; max-width:46ch; font-weight:300; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ padding-block:clamp(90px,12vw,180px); }
.contact__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,100px); }
.contact__title{ font-family:var(--serif); font-weight:500; font-size:clamp(2.4rem,6vw,5rem); line-height:1; letter-spacing:-.02em; margin-bottom:24px; }
.contact__lead{ color:var(--paper-dim); font-weight:300; max-width:42ch; margin-bottom:44px; }
.contact__info{ display:flex; flex-direction:column; gap:2px; border-top:1px solid var(--line); }
.contact__info li{ display:flex; gap:24px; align-items:baseline; padding:18px 0; border-bottom:1px solid var(--line); }
.contact__info span{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); min-width:90px; }
.contact__info a{ font-size:1.05rem; color:var(--paper); transition:color .3s; }
.contact__info a[href]:hover{ color:var(--brand); }

/* form */
.contact__form{ display:flex; flex-direction:column; gap:6px; }
.field{ position:relative; margin-bottom:22px; }
.field input, .field textarea, .field select{
  width:100%; background:transparent; border:none; border-bottom:1px solid var(--line);
  padding:16px 0 12px; color:var(--paper); font-family:var(--sans); font-size:1rem; transition:border-color .3s;
  border-radius:0;
}
.field textarea{ resize:vertical; min-height:60px; }
.field select{ appearance:none; cursor:pointer; padding-top:24px; }
.field select option{ background:var(--ink-2); color:var(--paper); }
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--brand); }
.field label{
  position:absolute; left:0; top:16px; color:var(--muted); pointer-events:none;
  transition:transform .3s var(--ease), font-size .3s, color .3s; font-size:1rem; transform-origin:left;
}
.field label.label--static,
.field input:focus + label, .field input:not(:placeholder-shown) + label,
.field textarea:focus + label, .field textarea:not(:placeholder-shown) + label{
  transform:translateY(-18px) scale(.72); color:var(--brand); font-family:var(--mono); letter-spacing:.08em; text-transform:uppercase;
}
.form__note{ font-family:var(--mono); font-size:.78rem; color:var(--brand); margin-top:8px; min-height:1.2em; }
.field.invalid input, .field.invalid textarea, .field.invalid select{ border-color:#ff6b6b; }

@media (max-width:820px){ .contact__grid{ grid-template-columns:1fr; } }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink-2); border-top:1px solid var(--line); padding-top:clamp(60px,8vw,110px); }
.footer__top{ display:flex; justify-content:space-between; align-items:flex-end; gap:40px; flex-wrap:wrap; padding-bottom:60px; border-bottom:1px solid var(--line); }
.footer__brand{ font-family:var(--serif); font-size:clamp(2.4rem,7vw,5.5rem); font-weight:600; line-height:.9; }
.footer__brand em{ font-style:normal; color:var(--brand); font-weight:500; }
.footer__mantra{ color:var(--muted); max-width:34ch; font-weight:300; }
.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr) 1.4fr; gap:30px; padding-block:60px; }
.footer__cols h5{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:18px; font-weight:500; }
.footer__cols a{ display:block; color:var(--paper-dim); padding:6px 0; transition:color .3s, padding-left .3s; }
.footer__cols a:hover{ color:var(--brand); padding-left:6px; }
.footer__big{ text-align:right; display:flex; flex-direction:column; gap:8px; align-items:flex-end; }
.footer__set{ font-family:var(--mono); font-size:.8rem; color:var(--muted); }
.footer__clock{ font-family:var(--serif); font-size:2.4rem; color:var(--paper); }
.footer__base{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; padding-block:30px; font-family:var(--mono); font-size:.74rem; color:var(--muted); border-top:1px solid var(--line); }
.footer__base a:hover{ color:var(--brand); }
@media (max-width:760px){ .footer__cols{ grid-template-columns:1fr 1fr; } .footer__big{ grid-column:1/-1; text-align:left; align-items:flex-start; } }

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{ position:fixed; inset:0; z-index:5000; background:rgba(5,6,8,.96); backdrop-filter:blur(10px); display:grid; place-items:center; opacity:0; visibility:hidden; transition:opacity .4s var(--ease), visibility .4s; }
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox__stage{ max-width:min(92vw,1100px); max-height:84vh; display:flex; flex-direction:column; gap:14px; align-items:center; }
.lightbox__stage img{ max-height:78vh; width:auto; border-radius:8px; box-shadow:0 40px 120px rgba(0,0,0,.7); transform:scale(.96); transition:transform .5s var(--ease); }
.lightbox.open .lightbox__stage img{ transform:scale(1); }
.lightbox__stage figcaption{ font-family:var(--mono); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--paper-dim); }
.lightbox__close{ position:absolute; top:26px; right:30px; font-size:1.4rem; color:var(--paper); width:50px; height:50px; border:1px solid var(--line); border-radius:50%; transition:all .3s; }
.lightbox__close:hover{ background:var(--brand); border-color:var(--brand); color:#04121f; }
.lightbox__arrow{ position:absolute; top:50%; transform:translateY(-50%); font-size:1.4rem; color:var(--paper); width:56px; height:56px; border:1px solid var(--line); border-radius:50%; transition:all .3s; }
.lightbox__arrow:hover{ background:var(--brand); border-color:var(--brand); color:#04121f; }
.lightbox__arrow--prev{ left:30px; } .lightbox__arrow--next{ right:30px; }
@media (max-width:600px){ .lightbox__arrow{ width:46px; height:46px; } .lightbox__arrow--prev{ left:12px; } .lightbox__arrow--next{ right:12px; } }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
  .aperture, .marquee__track, .logos__track, .hero__scroll i::after, .hero__kick .dot{ animation:none !important; }
  .hero__title .line span{ transform:none !important; }
  .intro__statement .reveal-line{ clip-path:none !important; }
  *{ scroll-behavior:auto !important; }
}
