/* ============================================================
   Hi Design Studio — Sistema visual
   Paleta oficial: crema · carbón · negro tipográfico · mostaza (5%)
   Regla 80 / 15 / 5  ·  Tipografía: Helvetica (sans rotunda)
   ============================================================ */

@font-face{
  font-family:'Satoshi';
  src:url('fonts/Satoshi-Variable.woff2') format('woff2'),
      url('fonts/Satoshi-Variable.woff') format('woff');
  font-weight:300 900; font-style:normal; font-display:swap;
}

:root{
  /* --- Paleta de marca --- */
  --cream:      #F5F4F1;   /* fondo general */
  --white:      #FFFFFF;   /* frente de tarjetas / secciones alternas */
  --ink:        #1A1A1A;   /* negro tipográfico */
  --ink-2:      #555555;   /* texto secundario */
  --carbon:     #2A2A2A;   /* bloques oscuros */
  --carbon-soft:#3A3A3A;   /* tags / separadores en zonas oscuras */
  --line:       rgba(0,0,0,.10);
  --line-2:     rgba(0,0,0,.16);
  --line-dark:  rgba(255,255,255,.14);

  --gold:       #E5B100;   /* mostaza — acento (ajustable por Tweaks) */
  --gold-deep:  #9c7a00;   /* mostaza legible sobre claro (texto/links) */
  --gold-tint:  color-mix(in srgb, var(--gold), #ffffff 86%);

  /* alias de fondo */
  --bg:      var(--cream);
  --surface: var(--white);

  /* Tipografía */
  --sans: "Satoshi", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --display: var(--sans);

  /* Métrica */
  --maxw: 1200px;
  --gut: clamp(20px, 5vw, 64px);
  --sec: clamp(72px, 10vw, 124px);
  --radius: 14px;
  --radius-lg: 20px;

  --shadow-sm: 0 1px 2px rgba(26,26,26,.05), 0 2px 10px rgba(26,26,26,.05);
  --shadow-md: 0 10px 34px rgba(26,26,26,.10);
  --shadow-lg: 0 32px 70px -26px rgba(26,26,26,.34);

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; font-family:var(--sans); color:var(--ink); background:var(--bg);
  font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
::selection{ background:var(--gold); color:var(--ink); }

/* ---------- Layout ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
.section{ padding-block:var(--sec); }
.section--surface{ background:var(--surface); }
.section--greige{ background:#ECE9E2; }
.section--dark{ background:var(--carbon); color:#f2efe9; }

/* ---------- Tipografía ---------- */
.eyebrow{
  font-size:12px; font-weight:700; letter-spacing:.26em; text-transform:uppercase;
  color:var(--gold-deep); margin:0 0 18px; display:flex; align-items:center; gap:12px;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--gold); display:inline-block; }
.section--dark .eyebrow{ color:var(--gold); }

h1,h2,h3{ font-family:var(--display); font-weight:800; line-height:1.03; letter-spacing:-.025em; margin:0; }
.h1{ font-size:clamp(38px, 6.6vw, 78px); }
.h2{ font-size:clamp(30px, 4.4vw, 54px); }
.h3{ font-size:clamp(21px, 2.3vw, 27px); letter-spacing:-.02em; }
.lead{ font-size:clamp(17px,1.9vw,21px); color:var(--ink-2); line-height:1.55; max-width:56ch; }
.section--dark .lead{ color:#c4beb2; }
.muted{ color:var(--ink-2); }
.accent{ color:var(--gold-deep); }

/* ---------- Botones ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px; padding:15px 26px; border-radius:999px;
  font-weight:700; font-size:16px; letter-spacing:-.01em; border:1.5px solid transparent;
  transition:all .25s var(--ease); white-space:nowrap;
}
.btn--gold{ background:var(--gold); color:var(--ink); }
.btn--gold:hover{ background:#cf9f00; transform:translateY(-2px); box-shadow:0 12px 26px -10px rgba(229,177,0,.8); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn--ghost:hover{ border-color:var(--ink); transform:translateY(-2px); }
.section--dark .btn--ghost{ color:#f2efe9; border-color:var(--line-dark); }
.section--dark .btn--ghost:hover{ border-color:#f2efe9; }
.btn--lg{ padding:18px 34px; font-size:18px; }
.btn .arrow{ transition:transform .25s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }

/* ---------- Imágenes (frames) ---------- */
.frame{ position:relative; overflow:hidden; border-radius:var(--radius-lg); background:#e9e6df; }
.frame img{ width:100%; height:100%; object-fit:cover; display:block; }
.frame--portrait{ aspect-ratio:4/5; }
.frame--landscape{ aspect-ratio:4/3; }
.frame--wide{ aspect-ratio:16/10; }
.frame--square{ aspect-ratio:1/1; }

/* ---------- Nav ---------- */
.nav{
  position:sticky; top:0; z-index:60;
  background:color-mix(in srgb, var(--cream) 88%, transparent);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent; transition:border-color .3s, box-shadow .3s;
}
.nav.scrolled{ border-color:var(--line); box-shadow:var(--shadow-sm); }
.nav__row{ display:flex; align-items:center; justify-content:space-between; height:76px; gap:22px; }
/* Logo (redibujado en Satoshi, proporción fija) — solo HDS. */
.logo{ display:inline-flex; align-items:baseline; line-height:1; }
.logo__word{ font-weight:900; font-size:30px; letter-spacing:-.03em; color:var(--ink); }
.logo__sq{ width:.19em; height:.19em; background:var(--gold); display:inline-block; margin-left:.06em; vertical-align:baseline; }
.logo--light .logo__word{ color:#fff; }
.nav__links{ display:flex; align-items:center; gap:28px; }
.nav__links a{ font-size:15px; font-weight:500; color:var(--ink); opacity:.82; transition:opacity .2s; white-space:nowrap; }
.nav__links a:hover{ opacity:1; }
.nav__cta{ display:flex; align-items:center; gap:16px; }

/* Selector de idioma (desplegable) */
.lang{ position:relative; }
.lang__btn{
  display:flex; align-items:center; gap:7px; border:1px solid var(--line-2); border-radius:999px;
  padding:8px 12px; background:transparent; font-size:14px; font-weight:700; letter-spacing:.02em; color:var(--ink);
  transition:border-color .2s, background .2s;
}
.lang__btn:hover{ border-color:var(--ink); }
.lang__btn svg{ color:var(--ink-2); }
.lang__caret{ transition:transform .25s var(--ease); }
.lang.open .lang__caret{ transform:rotate(180deg); }
.lang__menu{
  position:absolute; top:calc(100% + 8px); right:0; min-width:148px; list-style:none; margin:0; padding:6px;
  background:#fff; border:1px solid var(--line); border-radius:12px; box-shadow:var(--shadow-md);
  display:none; z-index:80;
}
.lang.open .lang__menu{ display:block; }
.lang__menu li{ padding:10px 12px; border-radius:8px; font-size:15px; font-weight:600; color:var(--ink); cursor:pointer; transition:background .15s; }
.lang__menu li:hover{ background:var(--cream); }
.lang__menu li.active{ color:var(--gold-deep); }
.lang__menu li.active::after{ content:"✓"; float:right; font-weight:800; }
.nav__phone{ font-weight:700; font-size:15px; display:flex; align-items:center; gap:7px; white-space:nowrap; }
.nav__phone svg{ color:var(--gold-deep); }
.nav__burger{ display:none; width:44px; height:44px; border:1px solid var(--line-2); border-radius:10px; background:transparent; align-items:center; justify-content:center; }
.nav__burger span{ display:block; width:18px; height:2px; background:var(--ink); position:relative; }
.nav__burger span::before,.nav__burger span::after{ content:""; position:absolute; left:0; width:18px; height:2px; background:var(--ink); }
.nav__burger span::before{ top:-6px; } .nav__burger span::after{ top:6px; }

/* ---------- Hero ---------- */
.hero{ padding-top:clamp(36px,5vw,64px); padding-bottom:var(--sec); overflow:hidden; }
.hero__grid{ display:grid; grid-template-columns:1.04fr .96fr; gap:clamp(32px,5vw,68px); align-items:center; }
.hero h1 .mark{ position:relative; white-space:nowrap; color:var(--ink); }
.hero h1 .mark::after{
  content:""; position:absolute; left:-2px; right:-2px; bottom:.04em; height:.16em;
  background:var(--gold); z-index:-1; border-radius:3px;
}
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.hero__trust{ display:flex; flex-wrap:wrap; gap:8px 22px; margin-top:30px; color:var(--ink-2); font-size:14.5px; font-weight:600; }
.hero__trust span{ display:inline-flex; align-items:center; gap:8px; }
.dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); display:inline-block; }
.hero__media .frame{ box-shadow:var(--shadow-lg); }

/* ---------- Strip de confianza ---------- */
.strip{ border-block:1px solid var(--line); }
.strip__row{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:18px 30px; padding-block:22px; }
.strip__item{ display:flex; align-items:center; gap:11px; font-weight:600; font-size:15px; }
.strip__item svg{ color:var(--gold-deep); flex:none; }

/* ---------- Encabezados de sección ---------- */
.sec-head{ max-width:64ch; }
.sec-head .lead{ margin-top:16px; }
.center{ text-align:center; } .center .eyebrow{ justify-content:center; } .sec-head.center{ margin-inline:auto; }

/* ---------- Públicos ---------- */
.aud{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.aud__card{
  position:relative; border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:38px 36px; background:var(--surface); overflow:hidden;
  transition:transform .3s var(--ease), box-shadow .3s, border-color .3s;
}
.aud__card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.aud__card .tag{ font-size:12px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); }
.aud__card h3{ margin:14px 0 12px; }
.aud__card p{ color:var(--ink-2); margin:0 0 22px; }
.aud__link{ font-weight:700; display:inline-flex; align-items:center; gap:9px; color:var(--ink); }
.aud__link .arrow{ transition:transform .25s var(--ease); }
.aud__card:hover .aud__link .arrow{ transform:translateX(5px); }
.aud__card .ghost-num{ position:absolute; right:24px; top:8px; font-size:90px; font-weight:800; color:var(--gold-tint); letter-spacing:-.04em; line-height:1; z-index:0; }
.aud__card > *{ position:relative; z-index:1; }

/* ---------- Servicios ---------- */
.svcs{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.svc{
  border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; background:var(--bg);
  display:flex; flex-direction:column; transition:transform .3s var(--ease), box-shadow .3s;
}
.svc:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.svc .frame{ border-radius:0; }
.svc__body{ padding:26px 26px 30px; }
.svc__num{ font-size:13px; font-weight:800; letter-spacing:.08em; color:var(--gold-deep); }
.svc h3{ margin:8px 0 12px; }
.svc p{ color:var(--ink-2); margin:0; font-size:15.5px; }

/* ---------- Antes / Después ---------- */
.works{ display:grid; grid-template-columns:repeat(2,1fr); gap:26px; }
.work{ border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; background:var(--surface); }
.work__pair{ display:grid; grid-template-columns:1fr 1fr; }
.work__half{ position:relative; }
.work__half .frame{ border-radius:0; }
.work__half .ba{
  position:absolute; top:12px; left:12px; z-index:3; font-size:11px; font-weight:800; letter-spacing:.12em;
  text-transform:uppercase; padding:6px 11px; border-radius:999px; background:rgba(26,26,26,.8); color:#fff; backdrop-filter:blur(4px);
}
.work__half--after .ba{ background:var(--gold); color:var(--ink); }
.work__cap{ padding:18px 22px; display:flex; align-items:center; justify-content:space-between; gap:12px; }
.work__cap b{ font-weight:700; } .work__cap span{ font-size:13.5px; color:var(--ink-2); }

/* ---------- Galería de resultados ---------- */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.gallery figure{ margin:0; position:relative; }
.gallery .frame{ aspect-ratio:3/4; }
.gallery figcaption{
  position:absolute; left:14px; bottom:14px; z-index:2; color:#fff; font-weight:700; font-size:15px;
  text-shadow:0 1px 10px rgba(0,0,0,.5); letter-spacing:-.01em;
}
.gallery .frame::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.46), transparent 46%); }

/* ---------- Resultados (toggle) ---------- */
.toggle{ display:inline-flex; padding:5px; background:var(--surface); border:1px solid var(--line); border-radius:999px; gap:4px; margin-bottom:38px; }
.section--surface .toggle{ background:var(--cream); }
.toggle button{ border:none; background:transparent; padding:11px 22px; border-radius:999px; font-weight:700; font-size:15px; color:var(--ink-2); transition:all .25s var(--ease); }
.toggle button.active{ background:var(--ink); color:#fff; }
.results{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px 40px; }
.result{ display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-bottom:1px solid var(--line); }
.result__ic{ flex:none; width:30px; height:30px; border-radius:8px; background:var(--gold-tint); display:grid; place-items:center; color:var(--gold-deep); }
.result p{ margin:0; font-size:17px; font-weight:600; }

/* ---------- Proceso (tarjetas) ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.step{ position:relative; background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg); padding:36px 28px 30px; overflow:hidden; box-shadow:var(--shadow-sm); }
.step::before{ content:""; position:absolute; top:0; left:0; right:0; height:4px; background:var(--gold); }
.step__n{ display:block; font-size:46px; font-weight:900; color:var(--gold); letter-spacing:-.03em; line-height:1; margin-bottom:18px; }
.step h3{ margin:0 0 10px; font-size:21px; }
.step p{ margin:0; color:var(--ink-2); font-size:15px; line-height:1.55; }

/* ---------- Ideal para ---------- */
.chips{ display:flex; flex-wrap:wrap; gap:12px; }
.chip{ padding:12px 20px; border:1px solid var(--line-2); border-radius:999px; font-weight:600; font-size:15.5px; background:var(--surface); transition:all .25s var(--ease); }
.chip:hover{ border-color:var(--gold); background:var(--gold-tint); }

/* ---------- Contacto (fondo claro) ---------- */
.contact{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,64px); align-items:start; }
.form-card{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(22px,3vw,34px); box-shadow:var(--shadow-md); margin-top:28px; }
.form{ display:grid; gap:16px; }
.field{ display:grid; gap:7px; }
.field label{ font-size:13px; font-weight:700; letter-spacing:.03em; color:var(--ink); }
.field input,.field select,.field textarea{
  font:inherit; padding:14px 16px; border:1.5px solid var(--line-2); border-radius:12px;
  background:#fff; color:var(--ink); transition:border-color .2s, box-shadow .2s; width:100%;
}
.field input::placeholder,.field textarea::placeholder{ color:#9a958c; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 4px rgba(229,177,0,.20); }
.field textarea{ resize:vertical; min-height:96px; }
.field--row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form__note{ font-size:13.5px; color:var(--ink-2); }
.form__ok{ display:none; padding:18px 20px; border-radius:12px; background:var(--gold-tint); border:1px solid var(--gold); font-weight:600; color:var(--ink); }
.form.sent .form__ok{ display:block; } .form.sent .form__hide{ display:none; }
.hp{ position:absolute !important; left:-9999px !important; width:1px; height:1px; opacity:0; pointer-events:none; }
.form__err{ display:none; color:#c43b30; font-size:14px; font-weight:600; margin:0; }
.form.error .form__err{ display:block; }
.btn.is-loading{ opacity:.7; pointer-events:none; }
.contact__side .h3{ margin-bottom:8px; }
.contact__list{ list-style:none; margin:24px 0 0; padding:0; display:grid; gap:2px; }
.contact__list li{ border-top:1px solid var(--line); }
.contact__list a,.contact__list span{ display:flex; align-items:center; gap:14px; padding:16px 2px; font-weight:600; color:var(--ink); }
.contact__list .k{ font-size:11.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-2); width:92px; flex:none; }
.socials{ display:flex; gap:12px; margin-top:26px; }
.socials a{ width:46px; height:46px; border:1px solid var(--line-2); border-radius:12px; display:grid; place-items:center; color:var(--ink); transition:all .25s var(--ease); }
.socials a:hover{ background:var(--ink); color:#fff; border-color:var(--ink); transform:translateY(-2px); }

/* ---------- Adaptación (área especializada) ---------- */
.adapt{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,64px); align-items:center; }
.adapt__media .frame{ aspect-ratio:4/3; box-shadow:var(--shadow-md); }
.adapt h2{ margin:14px 0 0; max-width:16ch; }
.adapt p{ margin:18px 0 0; max-width:54ch; color:var(--ink-2); font-size:clamp(16px,1.7vw,18px); line-height:1.6; }
.adapt__list{ list-style:none; margin:28px 0 0; padding:0; }
.adapt__list li{ display:flex; align-items:flex-start; gap:14px; padding:17px 0; border-top:1px solid var(--line-2); font-weight:600; font-size:16px; }
.adapt__list li:last-child{ border-bottom:1px solid var(--line-2); }
.adapt__list .ar{ color:var(--gold-deep); font-weight:800; flex:none; }
.adapt .btn{ margin-top:30px; }

/* ---------- Para profesionales (brief) ---------- */
.brief{ background:#ECE9E2; border-left:5px solid var(--gold); }
.brief h2{ margin:14px 0 0; max-width:20ch; }
.brief p{ margin:18px 0 0; max-width:62ch; color:var(--ink-2); font-size:clamp(16px,1.7vw,18px); line-height:1.6; }
.brief .btn{ margin-top:28px; }

/* ---------- Modal solicitar brief ---------- */
.modal{ position:fixed; inset:0; z-index:90; display:none; align-items:center; justify-content:center; padding:24px; }
.modal.open{ display:flex; }
.modal__backdrop{ position:absolute; inset:0; background:rgba(26,26,26,.55); }
.modal__card{ position:relative; z-index:1; background:#fff; border-radius:var(--radius-lg); width:min(460px,100%); padding:clamp(26px,4vw,38px); box-shadow:var(--shadow-lg); }
.modal__close{ position:absolute; top:14px; right:14px; width:36px; height:36px; border:none; background:transparent; border-radius:9px; font-size:22px; line-height:1; color:var(--ink-2); }
.modal__close:hover{ background:var(--cream); }
.modal h3{ margin:0 6px 6px 0; }
.modal__sub{ margin:0 0 22px; color:var(--ink-2); font-size:15px; }
.modal__ok{ display:none; padding:18px 20px; border-radius:12px; background:var(--gold-tint); border:1px solid var(--gold); font-weight:600; color:var(--ink); }
.modal.sent .modal__ok{ display:block; } .modal.sent .modal__form{ display:none; }

/* ---------- Footer ---------- */
.footer{ background:#1f1e1c; color:#cdc7ba; }
.footer__row{ display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; gap:30px; padding-block:50px 28px; }
.footer__logo img{ height:40px; width:auto; }
.footer__nav{ display:flex; flex-wrap:wrap; gap:22px; font-size:15px; }
.footer__nav a{ opacity:.82; } .footer__nav a:hover{ opacity:1; color:var(--gold); }
.footer__legal{ border-top:1px solid rgba(255,255,255,.1); padding-block:22px 30px; font-size:13px; color:#8b8579; display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; gap:12px 24px; }
.footer__legal-nav{ display:flex; flex-wrap:wrap; gap:18px; }
.footer__legal-nav a{ color:#a39d92; } .footer__legal-nav a:hover{ color:var(--gold); }

/* ---------- Banner de cookies ---------- */
.cookies{
  position:fixed; left:16px; right:16px; bottom:16px; z-index:85; max-width:560px; margin:0 auto;
  background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow-lg);
  padding:22px 24px; display:none;
}
.cookies.show{ display:block; }
.cookies h4{ margin:0 0 6px; font-size:17px; font-weight:800; letter-spacing:-.01em; }
.cookies p{ margin:0 0 16px; font-size:14px; color:var(--ink-2); line-height:1.5; }
.cookies p a{ color:var(--gold-deep); font-weight:700; text-decoration:underline; }
.cookies__actions{ display:flex; flex-wrap:wrap; gap:10px; }
.cookies__actions .btn{ padding:11px 20px; font-size:14px; }

/* ---------- Páginas legales ---------- */
.legal-main{ max-width:760px; margin:0 auto; padding:clamp(40px,7vw,80px) var(--gut) clamp(60px,9vw,110px); }
.legal-main h1{ font-size:clamp(32px,5vw,48px); margin-bottom:8px; }
.legal-main .legal-updated{ color:var(--ink-2); font-size:14px; margin:0 0 40px; }
.legal-main h2{ font-size:clamp(20px,2.4vw,26px); margin:42px 0 14px; }
.legal-main h3{ font-size:18px; margin:28px 0 10px; }
.legal-main p, .legal-main li{ color:#333; font-size:16px; line-height:1.7; }
.legal-main ul{ padding-left:22px; margin:12px 0; display:grid; gap:6px; }
.legal-main a{ color:var(--gold-deep); text-decoration:underline; }
.legal-main table{ width:100%; border-collapse:collapse; margin:16px 0; font-size:14.5px; }
.legal-main th, .legal-main td{ border:1px solid var(--line-2); padding:10px 12px; text-align:left; vertical-align:top; }
.legal-main th{ background:var(--cream); font-weight:700; }
.legal-back{ display:inline-flex; align-items:center; gap:8px; font-weight:700; margin-bottom:30px; color:var(--ink); }
.legal-back:hover{ color:var(--gold-deep); }

/* ---------- WhatsApp flotante ---------- */
.wa{
  position:fixed; right:22px; bottom:22px; z-index:70; display:flex; align-items:center; gap:11px;
  padding:14px 20px 14px 16px; background:#1faa54; color:#fff; border-radius:999px; font-weight:700; font-size:15px;
  box-shadow:0 14px 34px -10px rgba(31,170,84,.7); transition:transform .25s var(--ease);
}
.wa:hover{ transform:translateY(-3px) scale(1.02); }
.wa svg{ flex:none; }

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

/* ============================================================ Responsive */
@media (max-width: 1100px){ .nav__phone{ display:none; } .nav__links{ gap:22px; } }
@media (max-width: 960px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero__media{ order:-1; }
  .svcs{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr 1fr; }
  .steps{ grid-template-columns:1fr 1fr; }
  .contact{ grid-template-columns:1fr; }
  .works{ grid-template-columns:1fr; }
  .adapt{ grid-template-columns:1fr; }
  .adapt__media{ order:-1; }
}
@media (max-width: 720px){
  body{ font-size:16px; }
  .nav__links, .nav__phone{ display:none; }
  .nav__burger{ display:flex; }
  .nav.open .nav__links{
    display:flex; position:absolute; top:76px; left:0; right:0; flex-direction:column; align-items:flex-start;
    background:var(--cream); border-bottom:1px solid var(--line); padding:18px var(--gut) 26px; gap:6px; box-shadow:var(--shadow-md);
  }
  .nav.open .nav__links a{ padding:12px 0; font-size:18px; width:100%; border-bottom:1px solid var(--line); }
  .aud{ grid-template-columns:1fr; }
  .results{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr; }
  .field--row{ grid-template-columns:1fr; }
}
