/* ===== Fuentes autoalojadas (subset latin, font-display:swap) ===== */
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:500;font-display:swap;src:url('/fonts/cormorant-garamond-500i.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/cormorant-garamond-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/cormorant-garamond-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/cormorant-garamond-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Mulish';font-style:italic;font-weight:400;font-display:swap;src:url('/fonts/mulish-400i.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Mulish';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/mulish-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Mulish';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/mulish-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Mulish';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/mulish-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Mulish';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/mulish-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Mulish';font-style:normal;font-weight:800;font-display:swap;src:url('/fonts/mulish-800.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* ============================================================
   Náutica Ibiza — Taller Náutico (redesign)
   Mediterráneo luminoso · azul marino · latón
   ============================================================ */

:root{
  /* color */
  --ink:#0c2033;
  --ink-soft:#3a4d5e;
  --navy:#0e2d47;
  --navy-900:#081a2b;
  --navy-800:#0c2640;
  --sea:#1f567a;
  --paper:#ffffff;
  --mist:#eef4f7;
  --mist-2:#e3edf2;
  --sand:#f6f1e8;
  --brass:#b0894e;
  --brass-deep:#977237;
  --brass-soft:#c9aa72;
  --brass-ui:#8a6528;   /* AA sobre blanco con texto blanco */
  --brass-text:#7a5a23; /* AA como texto sobre blanco */
  --line:rgba(12,32,51,.13);
  --line-light:rgba(255,255,255,.16);

  /* type */
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Mulish",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  /* layout */
  --container:1240px;
  --gutter:clamp(20px,5vw,64px);
  --radius:7px;
  --shadow-sm:0 1px 2px rgba(8,26,43,.06),0 6px 18px rgba(8,26,43,.06);
  --shadow-md:0 18px 50px rgba(8,26,43,.14);
  --ease:cubic-bezier(.21,.61,.35,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
/* Foco visible para navegación por teclado (accesibilidad) */
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,[tabindex]:focus-visible{
  outline:3px solid var(--brass-ui);
  outline-offset:2px;
  border-radius:3px;
}
.hero a:focus-visible,.hero button:focus-visible,
.section--navy a:focus-visible,.section--navy button:focus-visible,
.band a:focus-visible,.cta-band a:focus-visible,
.footer a:focus-visible{outline-color:#fff}

/* ---------- type primitives ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.06;margin:0;letter-spacing:-.01em}
h1{font-size:clamp(2.6rem,6.2vw,5rem);font-weight:500}
h2{font-size:clamp(2rem,4.4vw,3.4rem)}
h3{font-size:clamp(1.4rem,2.4vw,2rem)}
p{margin:0 0 1.1em;text-wrap:pretty}
p:last-child{margin-bottom:0}
strong{font-weight:700;color:var(--ink)}

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.26em;
  color:var(--brass-text);
  display:inline-flex;align-items:center;gap:.7em;
  margin:0 0 1.1rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brass);display:inline-block}
.eyebrow.center{justify-content:center}
.eyebrow.light{color:#e9d6ab}

.lede{font-size:clamp(1.05rem,1.4vw,1.2rem);color:var(--ink-soft);line-height:1.75}
.prose-narrow{max-width:760px}
.prose-narrow p{margin-top:1.2rem}
.faq-head{text-align:center;margin-bottom:clamp(34px,4vw,56px)}

/* ---------- layout ---------- */
.container{max-width:var(--container);margin:0 auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(64px,9vw,128px)}
.section--mist{background:var(--mist)}
.section--sand{background:var(--sand)}
.section--navy{background:var(--navy);color:#eaf1f6}
.section--tight{padding-block:clamp(48px,6vw,80px)}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--brass-ui);--fg:#fff;
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans);font-weight:700;font-size:.92rem;
  letter-spacing:.02em;
  padding:.92em 1.6em;border-radius:50px;
  background:var(--bg);color:var(--fg);
  border:1px solid transparent;cursor:pointer;
  transition:transform .3s var(--ease),background .3s var(--ease),box-shadow .3s var(--ease),color .3s var(--ease);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);background:#6e4f1d;box-shadow:0 10px 26px rgba(110,79,29,.34)}
.btn--ghost{--bg:transparent;--fg:#fff;border-color:rgba(255,255,255,.4)}
.btn--ghost:hover{background:rgba(255,255,255,.1);border-color:#fff;box-shadow:none}
.btn--dark{--bg:var(--navy);--fg:#fff}
.btn--dark:hover{background:var(--navy-900);box-shadow:0 10px 26px rgba(8,26,43,.28)}
.btn--outline{--bg:transparent;--fg:var(--navy);border-color:var(--line)}
.btn--outline:hover{background:var(--navy);color:#fff;border-color:var(--navy);box-shadow:none}
.btn .ar{transition:transform .3s var(--ease)}
.btn:hover .ar{transform:translateX(4px)}

.txtlink{
  display:inline-flex;align-items:center;gap:.5em;
  font-weight:700;font-size:.9rem;color:var(--sea);
  letter-spacing:.02em;
}
.txtlink .ar{transition:transform .3s var(--ease)}
.txtlink:hover{color:var(--brass-deep)}
.txtlink:hover .ar{transform:translateX(5px)}
/* enlaces sobre fondo oscuro — debe ir DESPUÉS de .txtlink para ganar en cascada */
.txtlink.txtlink--light{color:#e9d6ab}
.txtlink.txtlink--light:hover{color:#fff}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:fixed;inset:0 0 auto 0;z-index:80;
  background:rgba(8,22,36,.97);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  box-shadow:0 1px 0 rgba(255,255,255,.08);
  transition:box-shadow .4s var(--ease),padding .4s var(--ease);
  padding-block:14px;
}
.header__inner{
  max-width:var(--container);margin:0 auto;padding-inline:var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.header__logo img{height:60px;width:auto;transition:height .4s var(--ease)}
.nav{display:flex;align-items:center;gap:34px}
.nav__list{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}
.nav__list a{
  font-size:.95rem;font-weight:600;color:#f2f7fb;letter-spacing:.02em;
  position:relative;padding:6px 0;transition:color .3s;
}
.nav__list a::after{
  content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--brass-soft);
  transition:width .3s var(--ease);
}
.nav__list a:hover{color:#fff}
.nav__list a:hover::after{width:100%}
.nav__list>.nav__item>a[aria-current="page"]{color:#fff}
.nav__list>.nav__item>a[aria-current="page"]::after{width:100%}

.nav__item{position:relative;display:flex;align-items:center;gap:2px}
.nav__item.has-sub>a::after{display:none}
.subtoggle{
  background:none;border:0;cursor:pointer;color:#f2f7fb;
  width:28px;height:28px;display:grid;place-items:center;border-radius:50%;
  transition:background .25s;
}
.subtoggle:hover,.subtoggle:focus-visible{background:rgba(255,255,255,.14)}
.subtoggle .caret{font-size:.62rem;line-height:1;display:block;transition:transform .3s}
.nav__item.open .subtoggle .caret,
.nav__item:hover .subtoggle .caret,
.nav__item:focus-within .subtoggle .caret{transform:rotate(180deg)}
.submenu{
  position:absolute;top:calc(100% + 15px);left:0;
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);
  padding:10px;min-width:284px;list-style:none;margin:0;
  opacity:0;visibility:hidden;pointer-events:none;transform:translateY(8px);
  transition:opacity .24s var(--ease),transform .24s var(--ease),visibility 0s linear .24s;
}
/* puente invisible: cubre el hueco entre el enlace y el panel para que el hover no se corte */
.submenu::before{content:"";position:absolute;left:0;right:0;top:-15px;height:15px}
.nav__item:hover .submenu,
.nav__item:focus-within .submenu,
.nav__item.open .submenu{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);
  transition:opacity .24s var(--ease),transform .24s var(--ease),visibility 0s;
}
.submenu a{display:block;color:var(--ink);font-size:.92rem;font-weight:600;padding:11px 14px;border-radius:5px;transition:background .2s,color .2s}
.submenu a::after{display:none}
.submenu a:hover,.submenu a:focus-visible{background:var(--mist);color:var(--brass-text)}
.submenu a[aria-current="page"]{background:var(--mist);color:var(--brass-text)}

.header__cta{display:flex;align-items:center;gap:18px}
.header__phone{
  display:inline-flex;align-items:center;gap:.55em;color:#fff;font-weight:700;font-size:.92rem;
}
.header__phone .ph-ic{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.35);font-size:.8rem}

/* scrolled state */
.header.scrolled{box-shadow:0 1px 0 rgba(255,255,255,.06),0 14px 40px rgba(8,26,43,.35);padding-block:9px}
.header.scrolled .header__logo img{height:48px}

/* hamburger */
.burger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;border:0;background:none;cursor:pointer;align-items:center;justify-content:center}
.burger span{width:24px;height:2px;background:#fff;border-radius:2px;transition:transform .3s var(--ease),opacity .3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:79;background:var(--navy-900);
  padding:96px var(--gutter) 40px;
  transform:translateX(100%);transition:transform .42s var(--ease);
  display:flex;flex-direction:column;gap:6px;overflow-y:auto;
}
.drawer.open{transform:translateX(0)}
.drawer a{color:#eaf1f6;font-family:var(--serif);font-size:1.7rem;font-weight:500;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.drawer .sub a{font-family:var(--sans);font-size:1rem;font-weight:600;color:var(--brass-soft);padding:9px 0 9px 18px;border:0}
.drawer__foot{margin-top:auto;padding-top:28px;color:#9fb4c4;font-size:.9rem}
.drawer__foot a{font-family:var(--sans);font-size:1rem;border:0;padding:4px 0;color:#fff}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:clamp(560px,78vh,760px);display:flex;align-items:center;color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:-6% 0 -6% 0;z-index:0;will-change:transform}
.hero__bg img{width:100%;height:112%;object-fit:cover;object-position:center center}
.hero__veil{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg,rgba(8,20,33,.82) 0%,rgba(8,20,33,.58) 46%,rgba(8,20,33,.10) 80%),
    linear-gradient(180deg,rgba(8,20,33,.55) 0%,rgba(8,20,33,.32) 50%,rgba(8,20,33,.60) 100%);}
.hero__veil::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 15% 90%,rgba(8,20,33,.5),transparent 60%)}
.hero__inner{position:relative;z-index:2;width:100%;max-width:var(--container);margin:0 auto;padding:clamp(96px,14vh,140px) var(--gutter) clamp(80px,11vh,110px)}
.hero__content{max-width:920px}
.hero h1{margin-bottom:.4em;text-shadow:0 2px 18px rgba(8,20,33,.45)}
.hero h1 .accent{font-style:italic;color:#e9d6ab;font-weight:500}
.hero .eyebrow{text-shadow:0 1px 10px rgba(8,20,33,.55)}
.hero__sub{font-size:clamp(1.05rem,1.5vw,1.28rem);color:#dbe6ee;max-width:640px;line-height:1.7;margin-bottom:2rem;text-shadow:0 1px 12px rgba(8,20,33,.5)}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.7);
  display:flex;flex-direction:column;align-items:center;gap:8px}
.hero__scroll .line{width:1px;height:34px;background:linear-gradient(180deg,var(--brass-soft),transparent);animation:scrollpulse 2.2s var(--ease) infinite}
@keyframes scrollpulse{0%{transform:scaleY(.3);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.01%{transform-origin:bottom}100%{transform:scaleY(.3);transform-origin:bottom}}

/* ============================================================
   PAGE HERO (páginas interiores)
   ============================================================ */
.page-hero{background:linear-gradient(180deg,#081a2b 0%,#0e2d47 100%);color:#fff;padding:calc(92px + clamp(36px,6vw,72px)) 0 clamp(40px,6vw,64px)}
.breadcrumb{list-style:none;display:flex;flex-wrap:wrap;gap:.6em;margin:0 0 1.2rem;padding:0;font-size:.85rem;color:#b9c9d6}
.breadcrumb a{display:inline-block;padding:4px 0;color:#dbe6ee;font-weight:600}
.breadcrumb a:hover{color:var(--brass-soft)}
.breadcrumb li+li::before{content:"\203A";margin-right:.6em;color:#8da2b3}
.page-hero h1{font-size:clamp(2.2rem,4.6vw,3.6rem);max-width:900px}
.page-hero .lede{color:#cfdde8;max-width:760px;margin-top:1.1rem}

/* CTA band (páginas interiores) */
.cta-band{background:var(--navy);color:#fff;text-align:center}
.cta-band .container{padding-block:clamp(56px,7vw,88px);display:flex;flex-direction:column;align-items:center;gap:22px}
.cta-band h2{color:#fff;max-width:720px}
.cta-band p{color:#c4d3df;max-width:620px;margin:0}
.cta-band .actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* checklist */
.check-list{list-style:none;margin:1.2rem 0 0;padding:0;display:grid;gap:14px}
.check-list li{list-style:none;position:relative;padding-left:28px;color:var(--ink-soft);font-size:1rem}
.check-list li::before{content:"";position:absolute;left:0;top:.5em;width:9px;height:9px;background:var(--brass-ui);transform:rotate(45deg)}
.check-list li strong{color:var(--ink)}

/* ============================================================
   OPINIONES / reseñas
   ============================================================ */
.reviews-rating{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px 16px;margin:0 0 clamp(28px,4vw,44px);text-align:center}
.reviews-rating .stars{color:var(--brass-text);letter-spacing:2px;font-size:1.25rem;line-height:1}
.reviews-rating strong{font-size:1.25rem;color:var(--navy)}
.reviews-rating span{color:var(--ink-soft);font-size:.98rem}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
.review-card{margin:0;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,2.4vw,30px);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:14px}
.review-card__stars{color:var(--brass-text);letter-spacing:2px;font-size:1.05rem;line-height:1}
.review-card blockquote{margin:0;color:var(--ink-soft);font-size:1.02rem;line-height:1.65;font-style:italic}
.review-card__author{font-weight:700;color:var(--ink);font-size:.95rem;margin-top:auto}
@media(max-width:860px){.review-grid{grid-template-columns:1fr}}

/* ============================================================
   INTRO / split
   ============================================================ */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,90px);align-items:center}
.split--rev .split__media{order:-1}
.prose>*+*{margin-top:1.1em}
.prose h2{margin-bottom:.2em}
.contactline{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:1.8rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.contactline .ci{display:inline-flex;align-items:center;gap:.6em;font-weight:600;color:var(--ink)}
.contactline .ci .dot{width:34px;height:34px;border-radius:50%;background:var(--mist);display:grid;place-items:center;color:var(--brass-text);font-size:.95rem}
.contactline .ci strong{color:var(--sea)}
.contactline--bare{border-top:0;padding-top:0;margin-top:0;margin-bottom:1.4rem}
.prose-after{margin-top:1.6rem}
.head-gap{margin-bottom:clamp(34px,4vw,56px)}
.btn--center{justify-content:center}
.h2like{font-size:clamp(1.7rem,3vw,2.5rem);margin-bottom:.2em}
.h3like{font-size:1.35rem;color:var(--navy)}
.prose blockquote.pull{margin:1.4rem 0 0;padding:1.2rem 1.5rem;border-left:3px solid var(--brass-ui);background:var(--mist);color:var(--ink-soft);font-size:1rem;border-radius:0 var(--radius) var(--radius) 0}
.num-list{margin:1.2rem 0 1.4rem;padding-left:1.3em;display:grid;gap:12px;color:var(--ink-soft)}
.num-list li::marker{color:var(--brass-text);font-weight:700}
.num-list li strong{color:var(--ink)}

/* brand pages */
.brand-claim{font-family:var(--serif);font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:600;color:var(--brass-text);letter-spacing:.04em;margin-top:.4rem}
.video-wrap{margin-top:clamp(28px,4vw,44px);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:16/9;background:#000}
.video-wrap iframe{display:block;width:100%;height:100%;border:0}
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:22px;margin-top:clamp(28px,4vw,44px)}
.prod{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-sm)}
.prod img{width:100%;aspect-ratio:1/1;object-fit:contain;background:#fff}
.prod h3{font-family:var(--sans);font-size:1rem;font-weight:700;color:var(--navy);margin:0;line-height:1.4}
.prod .freq{font-size:.85rem;color:var(--ink-soft);margin:0}
.prod .freq strong{color:var(--ink)}
.fullimg{margin-top:clamp(28px,4vw,44px);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md)}
.fullimg img{display:block;width:100%;height:auto}

/* ============================================================
   LIGHTBOX (galerías)
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:clamp(16px,4vw,48px);
  background:rgba(6,14,23,.88);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility 0s linear .3s}
.lightbox.show{opacity:1;visibility:visible;transition:opacity .3s var(--ease)}
.lightbox figure{margin:0;max-width:min(1100px,92vw);display:flex;flex-direction:column;gap:16px;
  transform:scale(.96);transition:transform .3s var(--ease)}
.lightbox.show figure{transform:scale(1)}
.lightbox figure img{max-width:100%;max-height:76vh;object-fit:contain;border-radius:var(--radius);
  box-shadow:0 30px 80px rgba(0,0,0,.55);display:block;margin:0 auto}
.lightbox figcaption{color:#eaf1f6;text-align:center;font-size:.95rem;font-weight:600;letter-spacing:.02em}
.lightbox .lb-close{position:absolute;top:18px;right:18px;width:46px;height:46px;border-radius:50%;
  border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.1);color:#fff;font-size:1.1rem;
  cursor:pointer;display:grid;place-items:center;transition:background .25s}
.lightbox .lb-close:hover,.lightbox .lb-close:focus-visible{background:rgba(255,255,255,.24)}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;
  border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.1);color:#fff;font-size:1.25rem;
  cursor:pointer;display:grid;place-items:center;transition:background .25s}
.lightbox .lb-nav:hover,.lightbox .lb-nav:focus-visible{background:rgba(255,255,255,.24)}
.lightbox .lb-prev{left:18px}
.lightbox .lb-next{right:18px}
.lightbox.single .lb-nav{display:none}
@media (max-width:600px){
  .lightbox .lb-nav{width:44px;height:44px}
  .lightbox .lb-prev{left:8px}
  .lightbox .lb-next{right:8px}
}

.split__media{position:relative}
.framed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);position:relative;aspect-ratio:4/5}
.framed img{width:100%;height:100%;object-fit:cover}
.framed--wide{aspect-ratio:4/3}
.framed--wide img{object-fit:contain;background:#fff}
.media-badge{position:absolute;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);padding:20px 24px;display:flex;flex-direction:column;gap:2px}
.media-badge.br{right:-18px;bottom:-22px}
.media-badge .n{font-family:var(--serif);font-size:2.4rem;font-weight:600;color:var(--navy);line-height:1}
.media-badge .l{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}

/* feature list (4 bullets) */
.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2vw,26px);margin-top:2.6rem}
.feature{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
.feature .fnum{font-family:var(--serif);font-size:1.1rem;color:var(--brass-text);font-weight:700;letter-spacing:.05em}
.feature h3{font-size:1.32rem;margin:.5rem 0 .55rem}
.feature p{font-size:.97rem;color:var(--ink-soft);margin:0}

/* Rejillas y tarjetas de servicio (grid-2 / grid-3) */
.grid-2,.grid-3{display:grid;gap:clamp(16px,2vw,26px);margin-top:2.4rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.service-card,.feature-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(24px,2.6vw,32px);transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s}
.service-card:hover,.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
.service-card h3,.feature-card h3{font-size:1.22rem;color:var(--navy);margin:0 0 .7rem}
.service-card p,.feature-card p{font-size:.97rem;color:var(--ink-soft);margin:0 0 1rem}
.service-card p:last-child,.feature-card p:last-child{margin-bottom:0}
.service-card .check-list,.feature-card .check-list{margin:.6rem 0 1rem}

/* ============================================================
   SERVICES grid (numbered editorial cards)
   ============================================================ */
.svc-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:clamp(34px,4vw,58px)}
.svc-head .lede{max-width:520px;margin-bottom:6px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.svc{background:var(--paper);padding:clamp(30px,3vw,44px);display:flex;flex-direction:column;min-height:280px;position:relative;transition:background .4s var(--ease)}
.svc::after{content:"";position:absolute;left:0;top:0;width:100%;height:2px;background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.svc:hover{background:var(--mist)}
.svc:hover::after{transform:scaleX(1)}
.svc__num{font-family:var(--serif);font-size:1.7rem;font-weight:600;color:var(--brass-deep);line-height:1;margin-bottom:auto}
.svc h3{font-size:1.42rem;margin:30px 0 .55rem;color:var(--navy)}
.svc p{font-size:.96rem;color:var(--ink-soft);margin:0 0 1.4rem}
.svc .txtlink{margin-top:auto}

/* ============================================================
   PARALLAX QUOTE BAND
   ============================================================ */
.band{position:relative;color:#fff;overflow:hidden;isolation:isolate}
.band__bg{position:absolute;inset:-12% 0;z-index:-2;will-change:transform}
.band__bg img{width:100%;height:124%;object-fit:cover}
.band::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,rgba(8,20,33,.9) 0%,rgba(8,20,33,.66) 55%,rgba(14,45,71,.5) 100%)}
.band .container{padding-block:clamp(80px,12vw,160px)}
.band__inner{max-width:760px}
.band h2{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:.5em}
.band h2 em{color:var(--brass-soft);font-weight:500}
.band p{color:#d7e2ea;font-size:clamp(1rem,1.4vw,1.18rem);margin-bottom:2rem}

/* ============================================================
   OFFICIAL / NAVY section
   ============================================================ */
.section--navy .eyebrow{color:var(--brass-soft)}
.section--navy h2,.section--navy h3{color:#fff}
.section--navy p{color:#c4d3df}
/* strong sobre fondos oscuros: contraste AA */
.section--navy strong,.ocard strong,.band strong,.cta-band strong,.hero strong,.page-hero strong{color:#fff}
.brand-row{display:flex;flex-wrap:wrap;gap:14px;margin:2.4rem 0 0}
.brand-chip{border:1px solid var(--line-light);border-radius:50px;padding:12px 26px;display:flex;flex-direction:column;gap:3px;line-height:1.05}
.brand-chip .bn{font-family:var(--serif);font-size:1.25rem;font-weight:600;color:#fff;letter-spacing:.03em;white-space:nowrap}
.brand-chip .bt{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-soft)}

.official-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,2.4vw,32px);margin-top:clamp(40px,5vw,64px)}
.ocard{background:var(--navy-800);border:1px solid var(--line-light);border-radius:var(--radius);padding:clamp(30px,3vw,42px);transition:transform .4s var(--ease),border-color .4s}
.ocard:hover{transform:translateY(-4px);border-color:var(--brass)}
.ocard h3{font-size:1.5rem;margin-bottom:.7rem}
.ocard p{font-size:.98rem;margin:0}
.ocard.span2{grid-column:1/-1}
.model-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.4rem}
.model-chips span{font-size:.8rem;font-weight:700;letter-spacing:.04em;padding:7px 16px;border-radius:50px;background:rgba(176,137,78,.16);color:var(--brass-soft);border:1px solid rgba(176,137,78,.35)}
/* chips sobre fondo claro (páginas interiores) */
.model-chips--page{margin-top:1.6rem}
.model-chips--page span{background:var(--mist);color:var(--brass-text);border-color:rgba(122,90,35,.3);font-size:.88rem}
.adv-list{list-style:none;margin:1.2rem 0 0;padding:0;display:grid;gap:14px}
.adv-list li{list-style:none;position:relative;padding-left:28px;color:#c4d3df;font-size:.98rem}
.adv-list li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;background:var(--brass);transform:rotate(45deg)}
.adv-list li strong{color:#fff}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gphoto{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--mist-2)}
.gphoto img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.gphoto::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(8,20,33,.8))}
.gphoto:hover img{transform:scale(1.07)}
.gphoto.tall{grid-row:span 2}
.gphoto.wide{grid-column:span 2}
.gcap{position:absolute;left:18px;bottom:14px;right:18px;z-index:2;color:#fff;font-weight:700;font-size:.9rem;letter-spacing:.02em}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:860px;margin:0 auto}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item h3{margin:0}
.faq__q{width:100%;background:none;border:0;cursor:pointer;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:28px 0;font-family:var(--serif);font-size:clamp(1.25rem,2vw,1.6rem);font-weight:600;color:var(--navy)}
.faq__q .pm{flex:none;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;position:relative;transition:background .3s,border-color .3s}
.faq__q .pm::before,.faq__q .pm::after{content:"";position:absolute;background:var(--brass-text);transition:transform .35s var(--ease),background .3s}
.faq__q .pm::before{width:14px;height:2px}
.faq__q .pm::after{width:2px;height:14px}
.faq__item.open .faq__q .pm{background:var(--navy);border-color:var(--navy)}
.faq__item.open .faq__q .pm::before,.faq__item.open .faq__q .pm::after{background:#fff}
.faq__item.open .faq__q .pm::after{transform:scaleY(0)}
.faq__a{overflow:hidden;max-height:0;transition:max-height .45s var(--ease)}
.faq__a-inner{padding:0 0 28px;color:var(--ink-soft);font-size:1.02rem;max-width:680px}
/* FAQ nativa (details/summary) */
.faq__question{cursor:pointer;list-style:none;padding:22px 0;font-family:var(--serif);font-size:1.18rem;
  color:var(--navy);font-weight:600;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq__question::-webkit-details-marker{display:none}
.faq__question::after{content:"+";color:var(--brass-text);font-size:1.5rem;line-height:1;flex:none}
details[open] .faq__question::after{content:"\2013"}
.faq__answer{padding:0 0 26px;color:var(--ink-soft);font-size:1.02rem;line-height:1.7;max-width:720px}
.faq__answer p{margin:0}

/* ============================================================
   CONTACT + MAP
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:start}
.info-block+.info-block{margin-top:26px}
.info-block .il{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-text);font-weight:700;margin-bottom:.5rem}
.info-block .iv{font-family:var(--serif);font-size:1.5rem;color:var(--navy);font-weight:600;line-height:1.25}
.info-block .iv a:hover{color:var(--brass-deep)}
.info-block .sub{color:var(--ink-soft);font-size:.96rem;margin-top:.2rem}

.form{display:grid;gap:18px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(28px,3vw,40px);box-shadow:var(--shadow-sm)}
.form__title{font-size:clamp(1.5rem,2.4vw,2rem);margin-bottom:.4rem}
.contact-grid .form__title{margin-bottom:0}
.contact-grid>div>.form__title{margin-bottom:1.4rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.field input,.field textarea{
  font-family:var(--sans);font-size:1rem;color:var(--ink);
  padding:13px 15px;border:1px solid var(--line);border-radius:6px;background:#fcfdfe;
  transition:border-color .25s,box-shadow .25s;width:100%;
}
.field textarea{resize:vertical;min-height:118px}
.field input::placeholder,.field textarea::placeholder{color:#64768a;opacity:1}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--sea);box-shadow:0 0 0 3px rgba(31,86,122,.12)}
.field.err input,.field.err textarea{border-color:#c0492f;box-shadow:0 0 0 3px rgba(192,73,47,.1)}
.form__note{font-size:.82rem;color:var(--ink-soft)}
.form__ok{display:none;align-items:center;gap:.6em;background:rgba(31,86,122,.08);color:var(--sea);font-weight:700;padding:13px 16px;border-radius:6px}
.form__ok.show{display:flex}
.form__err{display:none;align-items:center;gap:.6em;background:rgba(192,73,47,.08);color:#a23c25;font-weight:700;padding:13px 16px;border-radius:6px}
.form__err.show{display:flex}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.g-recaptcha{min-height:78px}

.map-wrap{margin-top:26px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.map-wrap iframe{display:block;width:100%;height:300px;border:0;filter:grayscale(.3) contrast(1.05)}
.map-facade{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  width:100%;height:300px;border:0;cursor:pointer;color:#fff;text-align:center;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-900) 100%)}
.map-facade__pin{font-size:2rem;line-height:1}
.map-facade__txt{font-family:var(--serif);font-size:1.3rem;font-weight:600}
.map-facade__sub{font-size:.86rem;color:#bcd0df}
.map-facade:hover{filter:brightness(1.1)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--navy-900);color:#9fb4c4;padding-block:clamp(56px,7vw,84px) 32px}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer__logo img{height:54px;margin-bottom:20px}
.footer__brand p{font-size:.95rem;color:#8ea4b5;max-width:300px}
.footer h3{font-family:var(--sans);font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin-bottom:18px;font-weight:700}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:4px}
.footer ul a{display:inline-block;padding:6px 0;font-size:.94rem;color:#9fb4c4;transition:color .25s}
.footer ul a:hover{color:var(--brass-soft)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding-top:28px;font-size:.85rem;color:#8da2b3}

/* ============================================================
   FLOATING CTAs
   ============================================================ */
.floaters{position:fixed;right:18px;bottom:18px;z-index:70;display:flex;flex-direction:column;gap:12px}
.float-btn{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow-md);color:#fff;transition:transform .3s var(--ease);position:relative}
.float-btn:hover{transform:scale(1.08)}
.float-btn svg{width:28px;height:28px}
.float-btn.wa{background:#25d366}
.float-btn.call{background:var(--brass-ui)}
.float-btn .tip{position:absolute;right:70px;top:50%;transform:translateY(-50%) translateX(8px);
  background:var(--navy-900);color:#fff;font-size:.78rem;font-weight:600;padding:7px 13px;border-radius:6px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .3s,transform .3s}
.float-btn:hover .tip{opacity:1;transform:translateY(-50%) translateX(0)}

/* ============================================================
   REVEAL animation
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .hero__scroll .line{animation:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .footer__top{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:860px){
  .nav,.header__phone{display:none}
  .burger{display:flex}
  .split{grid-template-columns:1fr;gap:40px}
  .split--rev .split__media{order:0}
  .feature-grid{grid-template-columns:1fr}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .official-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .hero__strip .container{grid-template-columns:1fr}
  .media-badge.br{right:14px;bottom:-18px;padding:16px 18px}
}
@media (max-width:600px){
  body{font-size:16px}
  .header__logo img{height:48px}
  .header.scrolled .header__logo img{height:42px}
  .svc-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr;grid-auto-rows:220px}
  .gphoto.wide,.gphoto.tall{grid-column:auto;grid-row:auto}
  .form .row{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr;gap:30px}
  .hero__actions .btn{width:100%;justify-content:center}
  .svc-head{flex-direction:column;align-items:flex-start}
}
