/* ============================================================
   Tq+A Studio — tqa-studio.com | Final v5
   All issues fixed. Mobile-first. Clean.
   ============================================================ */

/* ─── VARIABLES ─────────────────────────────────────────── */
:root {
  --dark:    #0e0d0b;
  --dark2:   #161410;
  --dark3:   #232019;
  --light:   #f5f2ee;
  --light2:  #ede9e3;
  --light3:  #d4cec6;
  --gold:    #c9a843;
  --goldd:   #a8893a;
  --tl:      #f0ece6;   /* text-light */
  --td:      #9a9189;   /* text-dim */
  --tk:      #1a1714;   /* text-dark */
  --tm:      #6b6459;   /* text-mid */
  --serif:   'Cormorant Garamond','Times New Roman',serif;
  --sans:    'Jost',system-ui,sans-serif;
  --ease:    cubic-bezier(0.16,1,0.3,1);
  --fast:    200ms var(--ease);
  --mid:     450ms var(--ease);
  --px:      clamp(1.5rem,5vw,5rem);
  --gap:     clamp(5rem,10vh,9rem);
  --navh:    120px;
}

/* ─── RESET ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--dark);color:var(--tl);font-family:var(--sans);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;cursor:pointer;color:inherit}

/* ─── TYPOGRAPHY ─────────────────────────────────────────── */
h1,h2,h3{font-family:var(--serif);font-weight:300;line-height:1.06;letter-spacing:-0.02em}
h1{font-size:clamp(2.6rem,6vw,6.5rem)}
h2{font-size:clamp(2.2rem,4.5vw,5rem)}
h3{font-size:clamp(1.2rem,1.6vw,1.6rem);font-weight:400}
em{font-style:italic;color:var(--gold)}
.attrib{font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);display:block;margin-top:1rem}

/* ─── SECTION LABEL ──────────────────────────────────────── */
/* Label = flex row: gold number + separator + uppercase tag */
.sec__label{
  display:flex;
  align-items:center;
  gap:0.6rem;
  margin-bottom:2rem;
}
.sec__num{
  font-family:var(--sans);
  font-size:0.6rem;
  letter-spacing:0.14em;
  color:var(--gold);
  opacity:0.9;
}
.sec__tag{
  font-family:var(--sans);
  font-size:0.68rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--td);
}

/* ─── BUTTONS ────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;
  font-family:var(--sans);font-size:0.78rem;font-weight:500;
  letter-spacing:0.1em;text-transform:uppercase;
  padding:0.9rem 1.75rem;border-radius:2px;
  border:1px solid transparent;cursor:pointer;
  transition:background var(--fast),color var(--fast),border-color var(--fast),transform 150ms ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn--gold{background:var(--gold);color:var(--dark);border-color:var(--gold)}
.btn--gold:hover{background:var(--goldd);border-color:var(--goldd)}
.btn--light{background:var(--light);color:var(--tk);border-color:var(--light)}
.btn--light:hover{background:var(--light2)}
.btn--outline{background:transparent;color:var(--tl);border-color:rgba(240,236,230,0.35)}
.btn--outline:hover{border-color:var(--tl)}

/* ─── NAV ────────────────────────────────────────────────── */
.nav{
  position:relative;z-index:200;
  height:var(--navh);
  background:var(--light);
  border-bottom:1px solid var(--light3);
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center;
  gap:1.5rem;
  padding:0 var(--px);
}
.nav.scrolled{box-shadow:none}

/* Logo: 100px desktop (+55% vs prior 64px), 72px mobile */
.nav__logo{display:flex;align-items:center;height:100px}
.nav__logo img{height:100%;width:auto;object-fit:contain;display:block}

.nav__links{
  display:flex;justify-content:center;gap:1.75rem;
  font-size:0.78rem;font-weight:400;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--tk);
}
.nav__links a{position:relative;padding:0.25rem 0;opacity:0.6;transition:opacity var(--fast)}
.nav__links a::after{content:'';position:absolute;inset:auto 0 -2px;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform 300ms var(--ease)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{transform:scaleX(1);transform-origin:left}

.nav__cta{
  font-size:0.72rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;
  padding:0.55rem 1.2rem;border:1px solid var(--gold);color:var(--tk);
  border-radius:2px;white-space:nowrap;
  transition:background var(--fast),color var(--fast);
}
.nav__cta:hover{background:var(--gold);color:var(--dark)}

.nav__burger{display:none;flex-direction:column;gap:5px;align-items:flex-end;justify-content:center;width:40px;height:40px;padding:4px}
.nav__burger span{display:block;height:1.5px;background:var(--tk);border-radius:2px;transition:transform var(--mid),width var(--mid)}
.nav__burger span:nth-child(1){width:22px}
.nav__burger span:nth-child(2){width:14px}
.nav__burger[aria-expanded="true"] span:nth-child(1){width:18px;transform:translateY(3.25px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){width:18px;transform:translateY(-3.25px) rotate(-45deg)}

/* Mobile nav */
@media(max-width:860px){
  .nav{grid-template-columns:1fr auto 1fr;gap:0}
  .nav__logo{grid-column:2;justify-self:center;height:72px}
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex;grid-column:3;justify-self:end}
}

/* ─── DRAWER ─────────────────────────────────────────────── */
.drawer{
  position:fixed;inset:0;z-index:190;
  background:var(--light);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:clamp(5rem,10vh,8rem) var(--px) 3rem;
  opacity:0;pointer-events:none;
  transition:opacity 380ms var(--ease);
}
.drawer[aria-hidden="false"]{opacity:1;pointer-events:auto}

.drawer__links{display:flex;flex-direction:column;align-items:center;width:100%;border-top:1px solid var(--light3)}
.drawer__links a{
  font-family:var(--serif);font-size:clamp(2rem,8vw,3.5rem);font-weight:300;
  color:var(--tk);text-align:center;width:100%;
  padding:0.85rem 0;border-bottom:1px solid var(--light3);
  transition:color var(--fast);
}
.drawer__links a:hover{color:var(--gold)}

.drawer__cta{
  margin-top:2rem;font-family:var(--sans);font-size:0.78rem;
  letter-spacing:0.1em;text-transform:uppercase;
  border:1px solid var(--gold);color:var(--tk);
  padding:0.9rem 2.5rem;border-radius:2px;background:transparent;
  transition:background var(--fast),color var(--fast);
  display:inline-block;
}
.drawer__cta:hover{background:var(--gold);color:var(--dark)}

.drawer__bg{position:fixed;inset:0;z-index:185;pointer-events:none}
.drawer__bg.on{pointer-events:auto}

/* ─── HERO ───────────────────────────────────────────────── */
.hero{
  position:relative;
  min-height:calc(100vh - var(--navh));
  min-height:calc(100svh - var(--navh));
  overflow:hidden;
  display:flex;
  align-items:flex-end;
}
/* Image fills entire hero absolutely */
.hero__img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 25%;
  filter:saturate(0.78) contrast(1.04) brightness(0.78);
  z-index:0;
}
/* Gradient overlay — stronger for text legibility */
.hero__shade{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    to bottom,
    rgba(14,13,11,0.55) 0%,
    rgba(14,13,11,0.45) 35%,
    rgba(14,13,11,0.88) 68%,
    rgba(14,13,11,0.98) 100%
  );
}
/* Content over image */
.hero__body{
  position:relative;z-index:2;
  width:100%;
  padding:clamp(3rem,6vh,5rem) var(--px) clamp(4rem,9vh,7rem);
  max-width:min(980px,100%);
}
.hero__eyebrow{
  display:flex;align-items:center;gap:0.75rem;
  font-size:0.68rem;letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(240,236,230,0.5);margin-bottom:1.5rem;
}
.hero__dot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0;box-shadow:0 0 0 3px rgba(201,168,67,0.25)}
.hero__body h1{color:var(--tl);margin-bottom:1.5rem}
.hero__sub{color:rgba(240,236,230,0.65);font-size:clamp(0.95rem,1.3vw,1.1rem);line-height:1.7;max-width:54ch;margin-bottom:2.25rem}
.hero__btns{display:flex;gap:1rem;flex-wrap:wrap}

.hero__coords{
  position:absolute;z-index:2;
  bottom:clamp(2rem,4vh,3.5rem);right:var(--px);
  display:flex;flex-direction:column;align-items:flex-end;gap:0.2rem;
  font-size:0.62rem;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(240,236,230,0.3);
}

/* Hero mobile */
@media(max-width:760px){
  .hero__body{text-align:center;max-width:100%}
  .hero__eyebrow{justify-content:center;flex-wrap:wrap;gap:0.5rem}
  .hero__sub{margin-left:auto;margin-right:auto}
  .hero__btns{flex-direction:column;align-items:center}
  .hero__btns .btn{width:100%;max-width:320px}
  .hero__coords{display:none}
}

/* ─── MARQUEE ────────────────────────────────────────────── */
.marquee{overflow:hidden;background:var(--dark2);border-top:1px solid var(--dark3);border-bottom:1px solid var(--dark3);padding:1.1rem 0}
.marquee__track{
  display:flex;gap:1.25rem;align-items:baseline;white-space:nowrap;
  font-family:var(--serif);font-size:clamp(1.4rem,3vw,2.8rem);
  font-weight:300;letter-spacing:-0.01em;color:rgba(240,236,230,0.2);
  animation:marquee 60s linear infinite;width:max-content;will-change:transform;
}
.marquee__track em{color:rgba(201,168,67,0.4);font-style:italic}
.marquee__track b{color:var(--gold);opacity:0.25;font-weight:300;font-size:0.5em;vertical-align:middle}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ─── SECTIONS — shared ──────────────────────────────────── */
.sec{padding:var(--gap) 0;border-top:1px solid var(--dark3)}

/* Two-column inner: label | content */
.sec__inner{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:clamp(1.5rem,4vw,4rem);
  padding:0 var(--px);
  max-width:1280px;
  margin:0 auto;
  align-items:start;
}
@media(max-width:760px){
  .sec__inner{grid-template-columns:1fr;gap:1.25rem}
}

.sec__cta{text-align:center;padding:3rem var(--px) 0}

/* ─── PHILOSOPHY ─────────────────────────────────────────── */
.phil__quote{
  font-family:var(--serif);font-size:clamp(1.3rem,2.2vw,2rem);
  font-weight:300;line-height:1.42;color:var(--tl);
  letter-spacing:-0.01em;margin-bottom:2rem;
}
.phil__body{font-size:0.92rem;color:var(--td);line-height:1.78;max-width:52ch;margin-bottom:0.25rem}

/* ─── WORKS HEAD ─────────────────────────────────────────── */
.works__head{margin-bottom:clamp(2.5rem,5vh,4rem);align-items:end}
.works__head h2{
  margin:0;
  font-size:clamp(2.2rem,3.6vw,3.6rem);
  line-height:1.05;
  letter-spacing:-0.02em;
}

/* ─── SLIDER — contained, max-width + padding ───────────── */
.slider{
  position:relative;
  max-width:1280px;
  margin:0 auto;
  padding:0 var(--px);
}
.slider__stage{
  position:relative;width:100%;aspect-ratio:16/9;
  overflow:hidden;background:var(--dark2);
  border:1px solid var(--dark3);
}
@media(max-width:640px){.slider__stage{aspect-ratio:4/3}}

.slide{position:absolute;inset:0;opacity:0;transition:opacity 600ms var(--ease);pointer-events:none}
.slide.is-active{opacity:1;pointer-events:auto}
.slide img{width:100%;height:100%;object-fit:cover;filter:saturate(0.88) contrast(1.04)}

.slide__cap{
  position:absolute;bottom:0;left:0;right:0;
  padding:clamp(1.25rem,4vw,2.5rem);
  background:linear-gradient(to top,rgba(14,13,11,0.92) 0%,transparent 100%);
  display:flex;flex-direction:column;gap:0.3rem;
}
.slide__n{font-size:0.65rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);opacity:0.85}
.slide__cap h3{font-size:clamp(1.3rem,2.5vw,2rem);color:var(--tl)}
.slide__cap p{font-size:0.78rem;letter-spacing:0.06em;text-transform:uppercase;color:rgba(240,236,230,0.5)}

.slider__ui{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:1.5rem var(--px) 0}
.slider__btn{width:44px;height:44px;border:1px solid rgba(240,236,230,0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--tl);transition:border-color var(--fast),background var(--fast);flex-shrink:0}
.slider__btn svg{width:18px;height:18px}
.slider__btn:hover{border-color:var(--gold);background:rgba(201,168,67,0.1)}
.slider__dots{display:flex;gap:0.5rem;align-items:center}
.sdot{width:6px;height:6px;border-radius:50%;background:rgba(240,236,230,0.25);border:0;padding:0;cursor:pointer;transition:background var(--fast),transform var(--fast)}
.sdot.on{background:var(--gold);transform:scale(1.35)}

/* Works footnote */
.works__note{
  text-align:center;
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.05rem,1.3vw,1.25rem);
  color:var(--tl);
  opacity:0.7;
  max-width:56ch;
  margin:clamp(2rem,3.5vh,3rem) auto 0;
  padding:0 var(--px);
  line-height:1.6;
  letter-spacing:0.005em;
}

/* ─── NUMBERS ────────────────────────────────────────────── */
.numbers{
  background:var(--dark2);border-top:1px solid var(--dark3);border-bottom:1px solid var(--dark3);
  padding:clamp(3rem,6vh,5rem) var(--px);
}
.numbers__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;max-width:1280px;margin:0 auto}
@media(max-width:720px){.numbers__grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}}
.stat{padding-top:1.25rem;border-top:1px solid var(--dark3)}
.stat__n{display:block;font-family:var(--serif);font-size:clamp(3rem,5.5vw,5.5rem);font-weight:300;line-height:1;letter-spacing:-0.03em;color:var(--tl);margin-bottom:0.4rem}
.stat__l{font-size:0.68rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--td)}

/* ─── STUDIO ─────────────────────────────────────────────── */
/* Editorial full-width header */
.studio__header{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:clamp(1.5rem,4vw,4rem);
  padding:0 var(--px);
  max-width:1280px;
  margin:0 auto clamp(3rem,6vh,5rem);
  align-items:end;
}
@media(max-width:760px){
  .studio__header{grid-template-columns:1fr;gap:1.25rem}
}
.studio__heading h2{font-size:clamp(2.2rem,3.6vw,3.6rem);line-height:1.05;letter-spacing:-0.02em;margin-bottom:1.5rem}
.studio__sub{font-size:clamp(1rem,1.3vw,1.15rem);color:var(--td);line-height:1.75;max-width:52ch}

/* Team */
.team{border-top:1px solid var(--dark3);padding:0 var(--px);max-width:1280px;margin:0 auto}
.team__row{
  display:grid;grid-template-columns:52px 1fr auto;
  align-items:baseline;gap:1.25rem;
  padding:1.1rem 0;border-bottom:1px solid var(--dark3);
  transition:padding-left var(--fast),color var(--fast);
}
.team__row:hover{padding-left:0.75rem;color:var(--gold)}
.team__n{font-size:0.62rem;letter-spacing:0.12em;color:var(--gold);opacity:0.7}
.team__name{font-family:var(--serif);font-size:clamp(1rem,1.8vw,1.5rem);font-weight:300;color:var(--tl);transition:color var(--fast)}
.team__role{font-size:0.68rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--td);text-align:right}
@media(max-width:640px){
  .team__row{grid-template-columns:40px 1fr;gap:0.75rem}
  .team__row:hover{padding-left:0}
  .team__role{grid-column:2;text-align:left;margin-top:0.1rem}
  .team__name{font-size:1.05rem}
}

/* Pull quote */
.pq{max-width:1280px;margin:0 auto;padding:clamp(2.5rem,5vh,4rem) var(--px);border-top:1px solid var(--dark3)}
.pq__mark{display:block;font-family:var(--serif);font-size:clamp(4rem,8vw,8rem);line-height:0.7;color:var(--gold);opacity:0.2;margin-bottom:0.75rem}
.pq__text{font-family:var(--serif);font-size:clamp(1.3rem,2.2vw,2rem);font-weight:300;line-height:1.45;color:var(--tl);max-width:36ch;margin-bottom:1.25rem}
.pq__cite{display:block;font-style:normal;font-size:0.68rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);opacity:0.8}
.pq__foot{margin-top:1.75rem}
@media(max-width:640px){.pq__text{max-width:100%;font-size:1.2rem}}

/* ─── APPROACH ───────────────────────────────────────────── */
.approach__header{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:clamp(1.5rem,4vw,4rem);
  padding:0 var(--px);
  max-width:1280px;
  margin:0 auto clamp(3rem,6vh,5rem);
  align-items:end;
}
@media(max-width:760px){
  .approach__header{grid-template-columns:1fr;gap:1.25rem}
}
.approach__heading h2{font-size:clamp(2.2rem,3.6vw,3.6rem);line-height:1.05;letter-spacing:-0.02em;margin-bottom:1.25rem}
.approach__sub{font-size:0.9rem;color:var(--td);line-height:1.75;max-width:44ch}

/* Steps 2×2 */
.steps{
  display:grid;grid-template-columns:1fr 1fr;
  border-top:1px solid var(--dark3);
  padding:0 var(--px);max-width:1280px;margin:0 auto;
}
@media(max-width:640px){.steps{grid-template-columns:1fr}}

.step{
  padding:clamp(2rem,4vh,3rem) clamp(1.5rem,3vw,3rem) clamp(2rem,4vh,3rem) 0;
  border-right:1px solid var(--dark3);
  border-bottom:1px solid var(--dark3);
}
.step:nth-child(even){border-right:0;padding-right:0;padding-left:clamp(1.5rem,3vw,3rem)}
.step:nth-last-child(-n+2){border-bottom:0}
@media(max-width:640px){
  .step{border-right:0;border-bottom:1px solid var(--dark3);padding:1.75rem 0}
  .step:nth-child(even){padding-left:0}
  .step:last-child{border-bottom:0}
  .step:nth-last-child(-n+2){border-bottom:1px solid var(--dark3)}
  .step:last-child{border-bottom:0}
}
.step__n{display:block;font-family:var(--serif);font-size:clamp(3rem,5vw,5rem);font-weight:300;letter-spacing:-0.04em;color:rgba(201,168,67,0.15);line-height:1;margin-bottom:1rem}
.step__h{font-family:var(--serif);font-size:clamp(1.4rem,2vw,1.8rem);font-weight:300;color:var(--tl);margin-bottom:0.75rem;letter-spacing:-0.01em}
.step__p{font-size:0.9rem;color:var(--td);line-height:1.75;max-width:36ch}

/* ─── PRESS ──────────────────────────────────────────────── */
.press__wrap{margin-bottom:clamp(2.5rem,5vh,4rem);align-items:end;grid-template-columns:200px 1fr}
.press__h{
  font-size:clamp(2.2rem,3.6vw,3.6rem);
  line-height:1.05;
  letter-spacing:-0.02em;
  margin:0;
}
.press{border-top:1px solid var(--dark3);padding:0 var(--px);max-width:1280px;margin:0 auto}
.press__row{
  display:grid;grid-template-columns:56px 160px 1fr;gap:1.5rem;
  align-items:baseline;padding:1.1rem 0;border-bottom:1px solid var(--dark3);
  transition:padding-left var(--fast);cursor:default;
}
.press__row:hover{padding-left:0.5rem}
.press__yr{font-size:0.68rem;letter-spacing:0.12em;color:var(--td)}
.press__pub{font-family:var(--serif);font-size:clamp(1rem,1.3vw,1.2rem);font-weight:400;color:var(--tl);transition:color var(--fast)}
.press__row:hover .press__pub{color:var(--gold)}
.press__ttl{font-family:var(--serif);font-size:0.92rem;color:var(--td);font-style:italic}
@media(max-width:640px){
  .press__row{grid-template-columns:46px 1fr;gap:0.75rem}
  .press__row:hover{padding-left:0}
  .press__ttl{grid-column:2}
  .press__pub{font-size:1rem}
}

/* ─── CONTACT ────────────────────────────────────────────── */
.contact{padding:var(--gap) var(--px);background:var(--dark2);border-top:1px solid var(--dark3)}
.contact__box{max-width:900px;margin:0 auto}

.contact__box h2{margin-bottom:1.25rem;font-size:clamp(2rem,3.6vw,3.6rem);line-height:1.05;letter-spacing:-0.02em}
.contact__lead{font-size:clamp(0.9rem,1.2vw,1.05rem);color:var(--td);line-height:1.75;max-width:52ch;margin-bottom:1.75rem}
.contact__email{
  display:inline-block;font-family:var(--serif);
  font-size:clamp(1.1rem,2.2vw,1.9rem);font-style:italic;font-weight:300;
  color:var(--tl);border-bottom:1px solid rgba(240,236,230,0.3);
  padding-bottom:0.25rem;margin-bottom:2.5rem;
  transition:color var(--fast),border-color var(--fast);word-break:break-all;
}
.contact__email:hover{color:var(--gold);border-color:var(--gold)}

/* Form — explicit dark inputs, no browser defaults */
.form{display:grid;gap:1.25rem;margin-bottom:2.5rem}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
@media(max-width:560px){.form__row{grid-template-columns:1fr}}

.form__field{display:flex;flex-direction:column;gap:0.5rem}
.form__field label{font-size:0.65rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--td)}

/* Force dark styling — override ALL browser defaults */
.form__field input[type="text"],
.form__field input[type="email"],
.form__field textarea{
  display:block;
  width:100%;
  background-color:#252118 !important;
  background:#252118;
  border:1px solid rgba(240,236,230,0.15);
  color:#f0ece6 !important;
  color:var(--tl);
  font-family:var(--sans);
  font-size:0.9rem;
  line-height:1.6;
  padding:0.9rem 1rem;
  border-radius:2px;
  outline:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  transition:border-color var(--fast);
  /* override iOS/Safari autofill */
  -webkit-text-fill-color:#f0ece6;
}
.form__field input[type="text"]::placeholder,
.form__field input[type="email"]::placeholder,
.form__field textarea::placeholder{color:var(--td);opacity:0.6;-webkit-text-fill-color:var(--td)}
.form__field input[type="text"]:focus,
.form__field input[type="email"]:focus,
.form__field textarea:focus{border-color:var(--gold)}
.form__field textarea{resize:vertical;min-height:130px}

/* Autofill override */
.form__field input:-webkit-autofill,
.form__field input:-webkit-autofill:hover,
.form__field input:-webkit-autofill:focus{
  -webkit-box-shadow:0 0 0 1000px #252118 inset;
  -webkit-text-fill-color:#f0ece6;
  border-color:rgba(240,236,230,0.15);
}

.form__submit{align-self:start;min-width:200px}
@media(max-width:560px){.form__submit{width:100%}}
.form__msg{font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold);min-height:1.5em;margin-top:0.5rem}

.contact__meta{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;padding-top:2rem;border-top:1px solid var(--dark3)}
@media(max-width:480px){.contact__meta{grid-template-columns:1fr}}
.contact__lbl{display:block;font-size:0.65rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--td);margin-bottom:0.5rem}
.contact__meta p{color:var(--tl);font-size:0.95rem;line-height:1.65}

/* ─── FOOTER ─────────────────────────────────────────────── */
.footer{background:var(--light);border-top:1px solid var(--light3)}
.footer__inner{max-width:1280px;margin:0 auto;padding:clamp(3rem,6vh,5rem) var(--px) 1.5rem}
.footer__top{
  display:grid;grid-template-columns:auto 1fr 1fr;
  gap:3rem 4rem;padding-bottom:3rem;
  border-bottom:1px solid var(--light3);margin-bottom:1.5rem;align-items:start;
}
@media(max-width:860px){.footer__top{grid-template-columns:1fr 1fr;gap:2rem}.footer__logo{grid-column:1/-1}}
@media(max-width:760px){.footer__top{grid-template-columns:1fr;gap:2.5rem}.footer__logo{grid-column:auto}}

/* Footer logo: 92px (+65% vs prior), transparent PNG */
.footer__logo{display:flex;align-items:center}
.footer__logo img{height:92px;width:auto;object-fit:contain}

.footer__col{display:flex;flex-direction:column;gap:0.6rem}
.footer__cap{display:block;font-size:0.62rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--tm);margin-bottom:0.5rem}
.footer__col a:not(.btn){font-size:0.88rem;color:var(--tk);opacity:0.7;transition:opacity var(--fast),color var(--fast)}
.footer__col a:not(.btn):hover{opacity:1;color:var(--goldd)}
.footer__col p{font-size:0.82rem;color:var(--tm);line-height:1.65}
/* Commission CTA in footer — keep dark text on gold at all times */
.footer__commission{margin-top:1rem;align-self:start;color:var(--dark) !important;opacity:1 !important;font-size:0.78rem}
.footer__commission:hover{color:var(--dark) !important;opacity:1 !important}

.footer__bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:0.72rem;letter-spacing:0.06em;text-transform:uppercase;color:var(--tm)}
.footer__bar a{color:var(--tk);opacity:0.6;transition:opacity var(--fast)}
.footer__bar a:hover{opacity:1}
@media(max-width:600px){.footer__bar{flex-direction:column;text-align:center;gap:0.4rem}}

.sga{background:var(--light);text-align:center;padding:0.6rem var(--px) 1.25rem;font-size:0.68rem;letter-spacing:0.08em;color:var(--tm);border-top:1px solid var(--light3)}
.sga a{color:var(--goldd);font-weight:500}
.sga a:hover{color:var(--gold)}

/* ─── ACCESSIBILITY ──────────────────────────────────────── */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.001ms!important;transition-duration:0.001ms!important}.marquee__track{animation:none}}
::selection{background:var(--gold);color:var(--dark)}

/* ============================================================
   MOBILE — EVERYTHING CENTERED (≤760px)
   ============================================================ */
@media(max-width:760px){

  /* Section labels centered with number above tag */
  .sec__label{
    justify-content:center;
    align-items:center;
  }

  /* Philosophy + Works + Studio + Approach + Press + Contact — all centered */
  .sec__inner,
  .studio__header,
  .approach__header{
    text-align:center;
    justify-items:center;
  }
  .sec__content,
  .studio__heading,
  .approach__heading{
    text-align:center;
  }

  /* Centered inline CTAs + max-width caps */
  .phil__quote,
  .phil__body,
  .studio__sub,
  .approach__sub,
  .hero__sub{
    margin-left:auto;
    margin-right:auto;
  }
  .attrib{text-align:center}

  /* Works heading + footnote centered */
  .works__head h2{text-align:center}

  /* Team rows: stacked + centered (flex beats the grid rules above) */
  .team .team__row{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    text-align:center !important;
    gap:0.35rem !important;
    padding:1.25rem 0 !important;
  }
  .team .team__row:hover{padding-left:0 !important}
  .team__n{text-align:center !important;grid-column:auto !important}
  .team__name{text-align:center !important;grid-column:auto !important}
  .team__role{text-align:center !important;grid-column:auto !important;margin-top:0 !important}

  /* Pull quote centered */
  .pq{text-align:center}
  .pq__text{margin-left:auto;margin-right:auto;max-width:46ch}
  .pq__foot{display:flex;justify-content:center}

  /* Press rows: stacked + centered (flex beats grid) */
  .press .press__row{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    text-align:center !important;
    gap:0.4rem !important;
    padding:1.25rem 0 !important;
  }
  .press .press__row:hover{padding-left:0 !important}
  .press__yr{text-align:center !important;grid-column:auto !important}
  .press__pub{text-align:center !important;grid-column:auto !important}
  .press__ttl{text-align:center !important;grid-column:auto !important}

  /* Press wrap: label + heading stacked + centered */
  .press__wrap{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    text-align:center !important;
    grid-template-columns:none !important;
  }
  .press__h{text-align:center !important;width:100%}

  /* Steps centered */
  .step{text-align:center;padding:1.75rem 0 !important;border-right:0 !important;padding-left:0 !important}
  .step__p{margin-left:auto;margin-right:auto}

  /* Numbers centered */
  .stat{text-align:center}

  /* Contact centered */
  .contact__box{text-align:center}
  .contact__lead{margin-left:auto;margin-right:auto}
  .contact__email{display:block;text-align:center}
  .form{max-width:480px;margin-left:auto;margin-right:auto}
  .form__field label{text-align:center}
  .form__submit{justify-self:center;align-self:center !important;width:100%}
  .contact__meta{text-align:center}

  /* Sec CTA already centered */
  .sec__cta{padding:2.5rem var(--px) 0}

  /* FOOTER — fully centered */
  .footer__top{
    text-align:center;
    justify-items:center;
  }
  .footer__logo{justify-content:center}
  .footer__col{align-items:center;text-align:center}
  .footer__commission{align-self:center !important;margin-top:1.25rem}
  .footer__bar{
    flex-direction:column !important;
    text-align:center;
    gap:0.6rem !important;
    padding-top:0.5rem;
  }
}
