/* ===== Design System — Nicolle Sánchez ===== */
:root{
  --ivory:      #F7F2EB;
  --paper:      #FBF8F3;
  --cream:      #EFE7DC;
  --stone:      #C9BEB1;
  --champagne:  #B89B7A;
  --champagne-2:#9E8362;
  --charcoal:   #1B1714;
  --charcoal-2: #2A2420;
  --ink:        #121010;
  --line:       rgba(27,23,20,.14);
  --line-soft:  rgba(27,23,20,.08);
  --line-light: rgba(255,255,255,.18);
  --muted:      #6B5E53;

  --serif:  'Cormorant Garamond', 'Times New Roman', Times, serif;
  --sans:   'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;

  --max: 1440px;
  --gut: clamp(20px, 4vw, 64px);
  --sec: clamp(72px, 10vw, 140px);

  --t-fast: cubic-bezier(.2,.8,.2,1);
  --t-smooth: cubic-bezier(.65,0,.35,1);
}

*,
*::before,
*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--paper);
  color:var(--charcoal);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  font-weight:300;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img, video{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }

/* Selection */
::selection{ background:var(--champagne); color:var(--paper); }

/* Reveal animations */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity 1s var(--t-smooth), transform 1s var(--t-smooth); }
.reveal.in{ opacity:1; transform:none; }

/* ===== Intro curtain ===== */
.intro{
  position:fixed; inset:0;
  background:var(--charcoal);
  z-index:200;
  display:grid; place-items:center;
  transition:opacity .9s var(--t-smooth), visibility .9s;
}
.intro.hidden{ opacity:0; visibility:hidden; pointer-events:none; }
.intro__mark img{
  width:clamp(200px, 24vw, 340px);
  opacity:0;
  animation:introFade 1.2s var(--t-smooth) .1s forwards;
  filter:drop-shadow(0 2px 20px rgba(0,0,0,.3));
}
@keyframes introFade{
  0%{ opacity:0; transform:translateY(8px) scale(.98); letter-spacing:.3em; }
  50%{ opacity:1; }
  100%{ opacity:1; transform:none; }
}

/* ===== Navigation ===== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gut);
  transition:background .45s var(--t-smooth), color .45s, padding .45s;
}
.nav--light{
  background:rgba(251,248,243,.85);
  backdrop-filter:saturate(140%) blur(16px);
  -webkit-backdrop-filter:saturate(140%) blur(16px);
  border-bottom:1px solid var(--line-soft);
  padding:12px var(--gut);
}
.nav__brand{ display:flex; align-items:center; gap:10px; }
.nav__logo{
  height:clamp(58px, 5.2vw, 76px);
  width:auto;
  transition:opacity .3s, height .45s var(--t-smooth), transform .4s var(--t-smooth);
  transform-origin:left center;
  filter:drop-shadow(0 1px 10px rgba(0,0,0,.08));
}
.nav--light .nav__logo{
  height:clamp(46px, 4.4vw, 60px);
}
.nav__logo--dark{ display:block; }
.nav__logo--light{ display:none; }
.nav--hero .nav__logo--dark{ display:none; }
.nav--hero .nav__logo--light{ display:block; filter:drop-shadow(0 2px 14px rgba(0,0,0,.45)); }
.nav--hero{ color:var(--paper); }
.nav--hero .nav__links a:hover{ color:var(--champagne); }

.nav__links{
  display:flex; gap:34px;
  font-family:var(--sans);
  font-size:12.5px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:400;
}
.nav__links a{ position:relative; padding:6px 0; transition:color .3s; }
.nav__links a::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:1px; background:currentColor; transform:scaleX(0); transform-origin:left;
  transition:transform .5s var(--t-smooth);
}
.nav__links a:hover::after{ transform:scaleX(1); }

.nav__right{ display:flex; align-items:center; gap:18px; }
.langs{ display:flex; align-items:center; gap:8px;
  font-size:12px; letter-spacing:.18em; text-transform:uppercase; }
.lang{ padding:4px 2px; opacity:.55; transition:opacity .3s, color .3s; }
.lang:hover{ opacity:1; }
.lang.active{ opacity:1; color:var(--champagne); }
.langs__sep{ opacity:.35; }

.burger{ display:none; width:30px; height:20px; position:relative; }
.burger span{
  position:absolute; left:0; right:0; height:1px; background:currentColor;
  transition:transform .4s var(--t-smooth), opacity .3s, top .4s var(--t-smooth);
}
.burger span:nth-child(1){ top:3px; }
.burger span:nth-child(2){ top:10px; }
.burger span:nth-child(3){ top:17px; }
.burger.open span:nth-child(1){ top:10px; transform:rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ top:10px; transform:rotate(-45deg); }

/* Drawer */
.drawer{
  position:fixed; inset:0; z-index:40;
  background:var(--charcoal); color:var(--paper);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:40px;
  transform:translateY(-102%); transition:transform .6s var(--t-smooth);
  padding:80px var(--gut);
}
.drawer.open{ transform:translateY(0); }
.drawer__nav{ display:flex; flex-direction:column; gap:26px; text-align:center;
  font-family:var(--serif); font-size:clamp(30px, 7vw, 44px); font-weight:400; }
.drawer__nav a{ transition:color .3s; }
.drawer__nav a:hover{ color:var(--champagne); }
.drawer__langs{ display:flex; gap:10px; font-size:13px; letter-spacing:.2em; text-transform:uppercase; }

/* ===== Shared typography ===== */
.eyebrow{
  font-family:var(--sans);
  font-size:11.5px;
  letter-spacing:.38em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--champagne-2);
  margin:0 0 18px;
}
.h-display{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(38px, 6.4vw, 88px);
  line-height:1.02;
  letter-spacing:-.01em;
  margin:0 0 20px;
}
.h-serif{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(24px, 2.6vw, 34px);
  line-height:1.15;
  letter-spacing:-.005em;
  margin:0 0 14px;
}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:14px;
  padding:16px 30px;
  border:1px solid currentColor;
  font-family:var(--sans);
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-weight:500;
  transition:background .4s var(--t-smooth), color .4s, border-color .4s;
}
.btn--primary{ background:var(--charcoal); color:var(--paper); border-color:var(--charcoal); }
.btn--primary:hover{ background:var(--champagne); border-color:var(--champagne); color:var(--paper); }
.btn--ghost{ background:transparent; }
.btn--ghost:hover{ background:currentColor; color:var(--paper); }
.hero .btn--ghost{ color:var(--paper); }
.hero .btn--ghost:hover{ background:var(--paper); color:var(--charcoal); }

/* ===== HERO ===== */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  display:grid; grid-template-columns:1fr;
  align-items:center;
  color:var(--paper);
  background:var(--charcoal);
  overflow:hidden;
}
.hero__media{
  position:absolute; inset:0;
  z-index:0;
}
.hero__video{
  width:100%; height:100%; object-fit:cover; object-position:center 30%;
  filter:brightness(.78) saturate(1.04);
}
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(10,8,7,.55) 0%, rgba(10,8,7,.15) 30%, rgba(10,8,7,.15) 60%, rgba(10,8,7,.78) 100%),
    radial-gradient(100% 70% at 30% 40%, rgba(0,0,0,.25), rgba(0,0,0,0));
}
.hero__content{
  position:relative; z-index:2;
  padding:140px var(--gut) 180px;
  max-width:var(--max); margin:0 auto; width:100%;
}
.hero .eyebrow{ color:rgba(255,244,230,.78); }
.display{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(58px, 12vw, 180px);
  line-height:.92;
  letter-spacing:-.02em;
  margin:10px 0 28px;
}
.display__line{ display:block; }
.display__line--italic{ font-style:italic; font-weight:300; color:var(--stone); margin-left:clamp(18px, 6vw, 90px); }
.hero__tag{
  font-family:var(--serif); font-style:italic;
  font-size:clamp(18px, 1.8vw, 24px);
  max-width:560px; margin:0 0 10px;
  color:#EAD9C2;
}
.hero__sub{
  font-family:var(--sans);
  font-size:14px; letter-spacing:.04em;
  max-width:520px; color:rgba(255,244,230,.78);
  margin:0 0 36px;
}
.hero__ctas{ display:flex; gap:14px; flex-wrap:wrap; }
.hero__scroll{
  position:absolute; bottom:36px; left:50%;
  transform:translateX(-50%);
  display:flex; align-items:center; gap:12px;
  color:rgba(255,244,230,.65);
  font-size:10.5px; letter-spacing:.36em; text-transform:uppercase;
  z-index:2;
}
.hero__scroll i{
  width:1px; height:32px; background:currentColor; display:inline-block;
  animation:scrollPulse 2.4s infinite;
  transform-origin:top;
}
@keyframes scrollPulse{
  0%,100%{ transform:scaleY(.25); opacity:.4; }
  50%{ transform:scaleY(1); opacity:1; }
}

/* ===== Sections shared ===== */
.section{
  padding:var(--sec) var(--gut);
  max-width:var(--max);
  margin:0 auto;
}
.section__head{ max-width:780px; margin:0 auto 64px; text-align:center; }
.section__lede{
  font-family:var(--serif); font-style:italic;
  font-size:clamp(18px, 1.6vw, 22px);
  color:var(--muted);
  line-height:1.45;
  margin:10px auto 0; max-width:640px;
}

/* ===== About ===== */
.about__grid{
  display:grid; grid-template-columns:minmax(240px, 1fr) 1.2fr;
  gap:clamp(32px, 6vw, 88px); align-items:center;
  margin-bottom:80px;
}
.about__photo{
  margin:0;
  position:relative;
  aspect-ratio: 4/5;
  overflow:hidden;
}
.about__photo::after{
  content:""; position:absolute; inset:14px; border:1px solid var(--stone);
  mix-blend-mode:multiply; pointer-events:none;
}
.about__photo img{ width:100%; height:100%; object-fit:cover; transition:transform 1.4s var(--t-smooth); }
.about__photo:hover img{ transform:scale(1.04); }
.about__text p{ font-size:17px; line-height:1.75; margin:0 0 18px; }
.about__text .about__meta{
  font-family:var(--serif); font-style:italic;
  font-size:17px; color:var(--champagne-2);
  margin-top:28px; padding-top:22px; border-top:1px solid var(--line);
}

/* Credentials strip */
.creds{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:16px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:36px 0;
}
.creds li{ text-align:center; padding:0 10px; border-left:1px solid var(--line-soft); }
.creds li:first-child{ border-left:none; }
.creds__n{
  display:block; font-family:var(--serif);
  font-size:clamp(26px, 2.2vw, 36px); font-weight:400;
  color:var(--charcoal); letter-spacing:-.01em;
}
.creds__l{
  display:block; margin-top:6px;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--muted);
}

/* ===== Services ===== */
.services__grid{
  display:grid; grid-template-columns:repeat(2, 1fr);
  gap:1px; background:var(--line);
  border:1px solid var(--line);
}
.service{
  background:var(--paper);
  padding:clamp(32px, 4vw, 56px);
  transition:background .5s var(--t-smooth);
  position:relative;
}
.service:hover{ background:var(--ivory); }
.service__num{
  font-family:var(--serif); font-style:italic;
  font-size:14px; color:var(--champagne-2); letter-spacing:.2em;
  margin-bottom:18px;
}
.service p{ color:var(--muted); font-size:15.5px; line-height:1.72; margin:0 0 20px; max-width:56ch; }
.service ul{
  list-style:none; padding:0; margin:0 0 20px;
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:8px 22px;
}
.service li{
  position:relative;
  padding-left:16px;
  font-size:14px; color:var(--charcoal-2); line-height:1.5;
}
.service li::before{
  content:""; position:absolute; left:0; top:.75em;
  width:6px; height:1px; background:var(--champagne);
}
.service__opt{
  font-family:var(--serif); font-style:italic;
  color:var(--muted); font-size:14px;
  border-top:1px solid var(--line-soft); padding-top:16px; margin-top:8px;
}
.services__note{
  text-align:center;
  margin:56px auto 0;
  font-family:var(--serif); font-style:italic;
  color:var(--muted); max-width:480px;
}

/* ===== Products strip ===== */
.products{
  background:var(--ivory);
  max-width:none;
}
.products .section__head{ margin-bottom:40px; }
.brand-row{
  overflow:hidden;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:28px 0;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
}
.brand-row__track{
  display:flex; gap:64px; width:max-content;
  animation:brandScroll 52s linear infinite;
  font-family:var(--serif); font-weight:400;
  font-size:clamp(22px, 2.2vw, 30px);
  color:var(--charcoal);
  letter-spacing:.02em;
  white-space:nowrap;
}
.brand-row__track span{ position:relative; padding-right:64px; }
.brand-row__track span::after{
  content:"·"; position:absolute; right:0; top:50%; transform:translateY(-55%);
  color:var(--champagne);
}
.brand-row__track span:last-child::after{ content:""; }
@keyframes brandScroll{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}

/* ===== Signature ===== */
.signature{ text-align:center; padding-top:clamp(40px, 6vw, 90px); padding-bottom:clamp(40px, 6vw, 90px); }
.pullquote{
  max-width:900px; margin:0 auto;
  font-family:var(--serif); font-weight:300;
  font-size:clamp(24px, 3.2vw, 44px);
  line-height:1.28;
  color:var(--charcoal);
  font-style:italic;
}
.pullquote p{ margin:0 0 28px; }
.pullquote footer{
  font-family:var(--sans); font-style:normal;
  font-size:12px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--champagne-2); font-weight:500;
}

/* ===== Portfolio — filters + masonry ===== */
.filters{
  display:flex; justify-content:center; flex-wrap:wrap; gap:6px;
  margin:0 auto 48px;
  padding:6px;
  border:1px solid var(--line);
  width:fit-content;
  border-radius:999px;
  background:var(--paper);
}
.filter{
  padding:10px 22px;
  font-size:11.5px; letter-spacing:.26em; text-transform:uppercase; font-weight:500;
  color:var(--muted);
  border-radius:999px;
  transition:background .35s var(--t-smooth), color .35s;
}
.filter:hover{ color:var(--charcoal); }
.filter.active{ background:var(--charcoal); color:var(--paper); }

.masonry{
  column-count:3;
  column-gap:12px;
}
@media (max-width:980px){ .masonry{ column-count:2; } }
@media (max-width:540px){ .masonry{ column-count:1; } }

.tile{
  position:relative; break-inside:avoid;
  margin:0 0 12px;
  overflow:hidden;
  cursor:zoom-in;
  background:var(--stone);
}
.tile img{
  width:100%; height:auto;
  transition:transform 1.2s var(--t-smooth), filter .6s;
}
.tile::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(0,0,0,.55));
  opacity:0; transition:opacity .5s var(--t-smooth);
  pointer-events:none;
}
.tile__meta{
  position:absolute; left:18px; right:18px; bottom:14px;
  color:#fff;
  opacity:0; transform:translateY(6px);
  transition:opacity .5s var(--t-smooth), transform .5s var(--t-smooth);
  pointer-events:none;
}
.tile__meta small{ display:block; font-size:10px; letter-spacing:.32em; text-transform:uppercase; color:var(--stone); }
.tile__meta b{
  display:block; font-family:var(--serif); font-weight:400;
  font-size:18px; letter-spacing:.01em; margin-top:2px;
}
.tile:hover img{ transform:scale(1.035); }
.tile:hover::after{ opacity:1; }
.tile:hover .tile__meta{ opacity:1; transform:translateY(0); }
.tile.hide{ display:none; }

/* ===== Runway — designer blocks ===== */
.runway{ background:var(--ivory); max-width:none; padding-left:var(--gut); padding-right:var(--gut); }
.runway__designers{
  max-width:var(--max); margin:0 auto;
  display:flex; flex-direction:column; gap:clamp(64px, 8vw, 110px);
}
.designer{
  display:grid; grid-template-columns:380px 1fr; gap:clamp(28px, 4vw, 64px);
  align-items:start;
}
.designer:nth-child(even){ grid-template-columns:1fr 380px; }
.designer:nth-child(even) .designer__info{ order:2; }
.designer__info{ position:sticky; top:100px; }
.designer__info h3{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(30px, 3vw, 44px); letter-spacing:-.005em;
  margin:0 0 12px;
}
.designer__info p{ margin:6px 0; font-size:14.5px; color:var(--charcoal-2); }
.designer__info .muted{ color:var(--muted); font-style:italic; font-family:var(--serif); font-size:16px; }
.designer__info .line{
  display:block; margin-top:20px; height:1px; background:var(--champagne); width:40px;
}
.designer__gallery{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:8px;
}
.designer__gallery .tile img{ aspect-ratio:3/4; object-fit:cover; width:100%; height:100%; }
.designer__gallery .tile--wide{ grid-column:span 2; }
.designer__gallery .tile--tall img{ aspect-ratio:3/4; }

@media (max-width:900px){
  .designer, .designer:nth-child(even){ grid-template-columns:1fr; }
  .designer__info{ position:static; }
  .designer:nth-child(even) .designer__info{ order:0; }
  .designer__gallery{ grid-template-columns:repeat(2,1fr); }
}

/* ===== Contact ===== */
.contact{ background:var(--charcoal); color:var(--paper); max-width:none; padding-left:var(--gut); padding-right:var(--gut); }
.contact .eyebrow{ color:var(--champagne); }
.contact .h-display{ color:var(--paper); }
.contact__grid{
  max-width:var(--max); margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(40px, 6vw, 80px);
}
.contact__text p{ color:rgba(247,242,235,.7); font-size:17px; line-height:1.7; max-width:44ch; }
.contact__details{ list-style:none; padding:0; margin:40px 0 0; display:grid; gap:14px; }
.contact__details li{ display:grid; grid-template-columns:120px 1fr; align-items:baseline; gap:16px; padding:14px 0; border-top:1px solid var(--line-light); }
.contact__details li:last-child{ border-bottom:1px solid var(--line-light); }
.contact__k{ font-size:10.5px; letter-spacing:.28em; text-transform:uppercase; color:var(--stone); }
.contact__details a{ border-bottom:1px solid transparent; transition:border-color .3s; }
.contact__details a:hover{ border-color:var(--champagne); }

/* Form */
.contact__form{ display:grid; gap:18px; }
.f-row{ display:grid; }
.f-row--two{ grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:540px){ .f-row--two{ grid-template-columns:1fr; } }
.f-row label{ display:grid; gap:8px; }
.f-row span{
  font-size:10.5px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--stone); font-weight:500;
}
.f-row input,
.f-row select,
.f-row textarea{
  appearance:none;
  width:100%;
  padding:12px 0;
  background:transparent;
  border:none; border-bottom:1px solid var(--line-light);
  font-family:var(--sans); font-size:15px; color:var(--paper);
  transition:border-color .3s;
  border-radius:0;
}
.f-row textarea{ resize:vertical; min-height:100px; }
.f-row input:focus,
.f-row select:focus,
.f-row textarea:focus{ outline:none; border-bottom-color:var(--champagne); }
.f-row select option{ background:var(--charcoal); color:var(--paper); }
.f-row input[type=date]{ color:rgba(247,242,235,.85); }
.f-row input::placeholder, .f-row textarea::placeholder{ color:rgba(247,242,235,.4); }
.f-actions{ display:flex; align-items:center; gap:20px; margin-top:10px; flex-wrap:wrap; }
.f-actions .btn{ background:var(--paper); color:var(--charcoal); border-color:var(--paper); }
.f-actions .btn:hover{ background:var(--champagne); border-color:var(--champagne); color:var(--paper); }
.f-hint{ margin:0; color:var(--stone); font-size:12.5px; font-style:italic; font-family:var(--serif); }
.f-status{ margin:8px 0 0; font-size:13px; color:var(--champagne); min-height:1.2em; }

/* ===== Footer ===== */
.foot{ background:var(--ink); color:rgba(247,242,235,.72); padding:64px var(--gut) 40px; }
.foot__grid{
  max-width:var(--max); margin:0 auto;
  display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; align-items:start;
}
.foot__brand img{ height:72px; width:auto; margin-bottom:18px; filter:drop-shadow(0 2px 10px rgba(0,0,0,.25)); }
.foot__brand p{ max-width:34ch; font-size:14px; line-height:1.6; }
.foot__nav{ display:grid; gap:10px; font-size:12px; letter-spacing:.22em; text-transform:uppercase; }
.foot__nav a{ transition:color .3s; }
.foot__nav a:hover{ color:var(--champagne); }
.foot__meta{ font-size:13px; line-height:1.6; }
.foot__meta a:hover{ color:var(--champagne); }
@media (max-width:780px){
  .foot__grid{ grid-template-columns:1fr; }
}

/* ===== Lightbox ===== */
.lightbox{
  position:fixed; inset:0; z-index:100;
  background:rgba(10,8,7,.96);
  display:none;
  align-items:center; justify-content:center;
  padding:4vw;
}
.lightbox.open{ display:flex; }
.lightbox__figure{ margin:0; max-width:90vw; max-height:86vh; display:flex; flex-direction:column; align-items:center; gap:14px; }
.lightbox__figure img{ max-width:100%; max-height:80vh; object-fit:contain; box-shadow:0 20px 60px rgba(0,0,0,.5); }
.lightbox__figure figcaption{
  color:rgba(247,242,235,.72); font-family:var(--serif); font-style:italic;
  text-align:center; font-size:15px;
}
.lightbox__close, .lightbox__prev, .lightbox__next{
  position:absolute; color:var(--paper);
  font-size:28px; width:48px; height:48px;
  display:grid; place-items:center;
  border:1px solid rgba(255,255,255,.25);
  border-radius:50%;
  background:rgba(0,0,0,.25);
  transition:background .3s, transform .3s;
}
.lightbox__close{ top:24px; right:24px; }
.lightbox__prev{ left:24px; top:50%; transform:translateY(-50%); }
.lightbox__next{ right:24px; top:50%; transform:translateY(-50%); }
.lightbox__close:hover, .lightbox__prev:hover, .lightbox__next:hover{ background:var(--champagne); border-color:var(--champagne); }

/* ===== Responsive ===== */
@media (max-width:860px){
  .nav__links{ display:none; }
  .burger{ display:inline-block; }
  .nav--hero .burger span{ background:var(--paper); }
  .langs{ display:none; }
  .nav__logo{ height:56px; }
  .nav--light .nav__logo{ height:46px; }
  .hero__content{ padding:120px var(--gut) 120px; }
  .about__grid{ grid-template-columns:1fr; }
  .services__grid{ grid-template-columns:1fr; }
  .contact__grid{ grid-template-columns:1fr; }
  .creds{ grid-template-columns:repeat(2, 1fr); gap:24px; }
  .creds li:nth-child(3){ border-left:none; }
  .foot__brand img{ height:60px; }
}
@media (max-width:540px){
  .nav{ padding:12px var(--gut); }
  .nav--light{ padding:10px var(--gut); }
  .nav__logo{ height:48px; }
  .nav--light .nav__logo{ height:40px; }
  .hero__ctas{ flex-direction:column; align-items:stretch; }
  .btn{ justify-content:center; }
  .service ul{ grid-template-columns:1fr; }
}
@media (max-width:380px){
  .nav__logo{ height:42px; }
  .nav--light .nav__logo{ height:36px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{ animation-duration:.01ms !important; transition-duration:.01ms !important; }
}
