@import url('../fonts/fonts.css');

/* ===================================================================
   PRO·RIGGING — sistema de diseño (TEMA CLARO · colores corporativos)
   Marca real: naranja #ff6600 + carbón #1a1817 sobre fondo claro.
   Serif editorial de alto contraste (Fraunces) + grotesca (Hanken Grotesk).
   Todo auto-hospedado: sin recursos externos (CSP 'self').
=================================================================== */

:root{
  /* Paleta clara corporativa */
  --bg:        #ffffff;   /* página */
  --bg-soft:   #f4f6f8;   /* secciones alternas / paneles */
  --bg-tint:   #fbf7f3;   /* tinte cálido muy sutil */
  --ink:       #1a1817;   /* carbón corporativo: texto/títulos y zonas oscuras */
  --ink-2:     #262321;   /* carbón claro (degradados) */
  --muted:     #5b626c;   /* texto secundario */
  --steel:     #8b93a0;   /* etiquetas/gris frío */
  --orange:    #ff6600;   /* acento corporativo (fondos, iconos, bordes, botón) */
  --orange-ink:#c2470b;   /* naranja para TEXTO sobre claro (contraste AA) */
  --orange-dk: #e65500;   /* hover de botón */
  --danger:    #c0392b;
  --on-dark:   #eef1f4;   /* texto sobre zonas oscuras */
  --on-dark-soft:#b8bfc8;
  --line:      rgba(20,22,26,.13);
  --line-soft: rgba(20,22,26,.07);
  --glass:     rgba(255,255,255,.82);

  /* Tipografía */
  --serif: 'Fraunces', Georgia, 'Times New Roman', serif;
  --sans:  'Hanken Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  /* Métrica */
  --maxw: 1280px;
  --gut: clamp(1.2rem, 4vw, 3.5rem);
  --radius: 4px;
  --ease: cubic-bezier(.16,.84,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  line-height:1.65;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* Atmósfera de fondo: degradados radiales cálidos muy sutiles */
body::before{
  content:"";
  position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(1100px 600px at 82% -10%, rgba(255,102,0,.06), transparent 60%),
    radial-gradient(900px 600px at 0% 8%, rgba(20,22,26,.04), transparent 55%),
    var(--bg);
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* ---------- Tipografía base ---------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; line-height:1.05; margin:0; letter-spacing:-.015em; color:var(--ink); }
p{ margin:0 0 1rem; }
.lead{ font-size:clamp(1.05rem,1.6vw,1.3rem); color:var(--muted); line-height:1.7; }

.kicker{
  font-family:var(--sans);
  font-size:.72rem; font-weight:700;
  letter-spacing:.3em; text-transform:uppercase;
  color:var(--orange-ink);
  display:inline-flex; align-items:center; gap:.7rem;
}
.kicker::before{ content:""; width:34px; height:2px; background:var(--orange); }

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(4rem,9vw,8rem); position:relative; }
.section--tight{ padding-block:clamp(3rem,6vw,5rem); }
.section--soft{ background:var(--bg-soft); }
.eyebrow-row{ display:flex; align-items:baseline; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-bottom:2.4rem; }
.sec-index{ font-family:var(--serif); font-size:.95rem; color:var(--steel); font-weight:600; }
.divider{ height:1px; background:var(--line); border:0; margin:0; }

/* ---------- Botones ---------- */
.btn{
  --bg:var(--orange); --fg:#1a1817;
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--sans); font-weight:700; font-size:.86rem;
  letter-spacing:.06em; text-transform:uppercase;
  padding:.95rem 1.7rem; border-radius:var(--radius);
  background:var(--bg); color:var(--fg);
  border:1px solid transparent; cursor:pointer;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s, color .3s, border-color .3s;
  position:relative;
}
.btn:hover{ transform:translateY(-2px); background:var(--orange-dk); box-shadow:0 14px 30px -12px rgba(255,102,0,.55); }
.btn svg{ width:1em; height:1em; transition:transform .35s var(--ease); }
.btn:hover svg{ transform:translateX(4px); }
.btn--ghost{ --bg:transparent; --fg:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ background:transparent; border-color:var(--orange); color:var(--orange-ink); box-shadow:none; }
.btn--block{ width:100%; justify-content:center; }
/* Botón sobre fondos oscuros (footer/CTA) */
.on-dark .btn--ghost{ --fg:var(--on-dark); border-color:rgba(255,255,255,.22); }
.on-dark .btn--ghost:hover{ color:#fff; border-color:var(--orange); }

/* ---------- Header / nav ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:80;
  transition:background .4s, border-color .4s, box-shadow .4s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{ background:var(--glass); backdrop-filter:blur(14px); border-bottom-color:var(--line); box-shadow:0 6px 24px -18px rgba(0,0,0,.35); }
.nav{ display:flex; align-items:center; justify-content:space-between; padding-block:1rem; }
.brand{ display:flex; align-items:center; }
.brand .logo{ height:30px; width:auto; }
.nav-links{ display:flex; align-items:center; gap:2rem; list-style:none; margin:0; padding:0; }
.nav-links a{
  font-family:var(--sans); font-size:.82rem; font-weight:600;
  letter-spacing:.05em; text-transform:uppercase; color:var(--ink);
  position:relative; padding-block:.3rem; transition:color .25s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:var(--orange); transition:width .35s var(--ease);
}
.nav-links a:hover,.nav-links a[aria-current="page"]{ color:var(--orange-ink); }
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{ width:100%; }

.nav-tools{ display:flex; align-items:center; gap:1rem; }
.lang-toggle{
  display:flex; border:1px solid var(--line); border-radius:999px; overflow:hidden;
  font-family:var(--sans); font-size:.72rem; font-weight:700; letter-spacing:.05em;
}
.lang-toggle button{
  background:none; border:0; color:var(--muted); cursor:pointer;
  padding:.35rem .7rem; transition:background .25s,color .25s;
}
.lang-toggle button[aria-pressed="true"]{ background:var(--orange); color:#1a1817; }

.nav-toggle{ display:none; background:none; border:0; cursor:pointer; padding:.4rem; }
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--ink); margin:5px 0; transition:.3s var(--ease); }

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  padding-top:6rem; overflow:hidden;
}
.hero__media{ position:absolute; inset:0; z-index:-1; }
.hero__media img{ width:100%; height:100%; object-fit:cover; }
/* Velo claro a la izquierda → texto carbón legible; imagen visible a la derecha */
.hero__media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(100deg, var(--bg) 0%, rgba(255,255,255,.94) 30%, rgba(255,255,255,.55) 52%, rgba(255,255,255,0) 74%),
    linear-gradient(0deg, rgba(255,255,255,.55), transparent 30%);
}
.hero__canvas{ position:absolute; inset:0; z-index:-1; opacity:.6; }
.hero__inner{ max-width:60rem; }
.hero h1{
  font-size:clamp(2.7rem, 7.2vw, 6.2rem);
  font-weight:600; letter-spacing:-.03em; margin:1.4rem 0 1.4rem; color:var(--ink);
}
.hero h1 em{ font-style:italic; color:var(--orange-ink); font-weight:600; }
.hero .lead{ max-width:40rem; color:var(--ink); opacity:.82; }
.hero__cta{ display:flex; gap:1rem; flex-wrap:wrap; margin-top:2.2rem; }
.scroll-cue{
  position:absolute; left:var(--gut); bottom:1.6rem; display:flex; align-items:center; gap:.6rem;
  font-size:.7rem; letter-spacing:.25em; text-transform:uppercase; color:var(--muted);
}
.scroll-cue .line{ width:2px; height:42px; background:linear-gradient(var(--orange),transparent); animation:cue 2.4s var(--ease) infinite; transform-origin:top; }
@keyframes cue{ 0%,100%{ transform:scaleY(.4); opacity:.4; } 50%{ transform:scaleY(1); opacity:1; } }

/* Tira de stats */
.statstrip{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--bg-soft); }
.statstrip .wrap{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:2.2rem 1rem; text-align:center; border-left:1px solid var(--line-soft); }
.stat:first-child{ border-left:0; }
.stat .num{ font-family:var(--serif); font-size:clamp(2rem,4vw,3.2rem); font-weight:600; color:var(--ink); line-height:1; }
.stat .num b{ color:var(--orange); font-weight:600; }
.stat .lbl{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-top:.6rem; }

/* ---------- Servicios ---------- */
.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(--bg); padding:2.2rem 1.9rem; position:relative; transition:background .4s var(--ease); }
.svc:hover{ background:var(--bg-tint); }
.svc__ic{ width:42px; height:42px; color:var(--orange); margin-bottom:1.4rem; }
.svc h3{ font-size:1.3rem; margin-bottom:.55rem; }
.svc p{ color:var(--muted); font-size:.95rem; margin:0; }
.svc__n{ position:absolute; top:1.3rem; right:1.5rem; font-family:var(--serif); color:var(--steel); font-size:.85rem; }

/* ---------- Split / about ---------- */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.split--rev{ direction:rtl; }
.split--rev>*{ direction:ltr; }
.frame{ position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:0 30px 60px -30px rgba(20,22,26,.4); }
.frame img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/5; transition:transform .9s var(--ease); }
.frame:hover img{ transform:scale(1.04); }
.frame__tag{
  position:absolute; left:0; bottom:0; background:var(--orange); color:#fff;
  font-family:var(--serif); font-size:1.1rem; font-weight:700; padding:.7rem 1.2rem;
}
.feature-list{ list-style:none; margin:1.6rem 0 0; padding:0; display:grid; gap:1px; }
.feature-list li{ display:flex; gap:1rem; padding:1rem 0; border-top:1px solid var(--line); align-items:flex-start; }
.feature-list li::before{ content:""; width:8px; height:8px; margin-top:.55rem; flex:none; background:var(--orange); transform:rotate(45deg); }
.feature-list b{ color:var(--ink); }
.feature-list .desc{ font-size:.95rem; color:var(--muted); line-height:1.6; }

/* ---------- Proyectos por eslora ---------- */
.fleet{ display:grid; gap:1px; background:var(--line); border-block:1px solid var(--line); }
.fleet__row{
  background:var(--bg); display:grid; grid-template-columns:minmax(0,.85fr) minmax(0,2fr) auto;
  gap:2rem; align-items:center; padding:2rem var(--gut);
  transition:background .4s var(--ease);
}
.fleet__row:hover{ background:var(--bg-tint); }
.fleet__size{ font-family:var(--serif); font-size:clamp(1.8rem,3.4vw,2.9rem); font-weight:600; color:var(--ink); white-space:nowrap; }
.fleet__size b{ color:var(--orange); }
.fleet__row:hover .fleet__size{ color:var(--orange-ink); }
.fleet__desc h3{ font-size:1.15rem; margin-bottom:.3rem; }
.fleet__desc p{ color:var(--muted); margin:0; font-size:.95rem; }
.fleet__meta{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--steel); text-align:right; }

/* ---------- Equipo ---------- */
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.member{ background:var(--bg); border:1px solid var(--line); border-radius:var(--radius); padding:2rem 1.8rem; transition:border-color .4s, transform .4s var(--ease), box-shadow .4s; }
.member:hover{ border-color:var(--orange); transform:translateY(-4px); box-shadow:0 24px 40px -28px rgba(20,22,26,.45); }
.member__avatar{
  width:64px; height:64px; border-radius:50%; display:grid; place-items:center;
  background:linear-gradient(135deg,#fff,var(--bg-soft)); border:1px solid var(--line);
  font-family:var(--serif); font-size:1.4rem; font-weight:700; color:var(--orange); margin-bottom:1.2rem;
}
.member h3{ font-size:1.25rem; margin-bottom:.2rem; }
.member .role{ font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--orange-ink); margin-bottom:.8rem; font-weight:600; }
.member p{ color:var(--muted); font-size:.92rem; margin:0; }

/* ---------- Proveedores ---------- */
.brand-cloud{ display:flex; flex-wrap:wrap; gap:.7rem; }
.brand-cloud span{
  font-family:var(--serif); font-size:clamp(.95rem,1.6vw,1.3rem); color:var(--muted);
  padding:.35rem .85rem; border:1px solid var(--line); border-radius:999px;
  transition:color .3s, border-color .3s, background .3s;
}
.brand-cloud span:hover{ color:var(--ink); border-color:var(--orange); background:rgba(255,102,0,.07); }
.marquee{ overflow:hidden; border-block:1px solid var(--line); padding-block:1.4rem; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee__track{ display:flex; gap:3rem; width:max-content; animation:scrollx 38s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee span{ font-family:var(--serif); font-size:1.3rem; color:var(--steel); white-space:nowrap; letter-spacing:.02em; }
@keyframes scrollx{ to{ transform:translateX(-50%); } }

/* ---------- CTA band (oscuro, foco visual) ---------- */
.cta-band{ position:relative; overflow:hidden; border-radius:var(--radius); padding:clamp(2.6rem,5vw,4.4rem); background:linear-gradient(120deg,var(--ink),var(--ink-2)); color:var(--on-dark); }
.cta-band h2{ font-size:clamp(1.8rem,4vw,3rem); max-width:18ch; margin-bottom:1rem; color:#fff; }
.cta-band .lead{ color:var(--on-dark-soft); }
.cta-band .kicker{ color:var(--orange); }
.cta-band .rope{ position:absolute; right:-40px; top:-40px; width:280px; height:280px; color:var(--orange); opacity:.16; }

/* ---------- Contacto ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.loc-card{ border:1px solid var(--line); border-radius:var(--radius); padding:1.8rem; background:var(--bg); margin-bottom:1.2rem; transition:border-color .3s, box-shadow .3s; }
.loc-card:hover{ border-color:var(--orange); box-shadow:0 20px 40px -30px rgba(20,22,26,.4); }
.loc-card h3{ font-size:1.3rem; display:flex; align-items:center; gap:.6rem; margin-bottom:.8rem; }
.loc-card .row{ display:flex; gap:.7rem; align-items:center; color:var(--muted); font-size:.95rem; padding:.3rem 0; }
.loc-card .row svg{ width:18px; height:18px; color:var(--orange); flex:none; }
.loc-card a:hover{ color:var(--orange-ink); }

form .field{ margin-bottom:1.2rem; }
form label{ display:block; font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:.5rem; font-weight:600; }
form input,form textarea{
  width:100%; background:var(--bg-soft); border:1px solid var(--line); border-radius:var(--radius);
  color:var(--ink); font-family:var(--sans); font-size:1rem; padding:.85rem 1rem; transition:border-color .25s, box-shadow .25s, background .25s;
}
form input:focus,form textarea:focus{ outline:none; background:#fff; border-color:var(--orange); box-shadow:0 0 0 3px rgba(255,102,0,.16); }
form textarea{ resize:vertical; min-height:140px; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.consent{ display:flex; gap:.7rem; align-items:flex-start; font-size:.85rem; color:var(--muted); }
.consent input{ width:auto; margin-top:.25rem; accent-color:var(--orange); }
.consent a{ color:var(--orange-ink); text-decoration:underline; }
.form-note{ font-size:.85rem; margin-top:1rem; min-height:1.2em; }
.form-note.ok{ color:#1f8a4c; }
.form-note.err{ color:var(--danger); }

/* ---------- Footer (oscuro corporativo) ---------- */
.site-footer{ background:var(--ink); color:var(--on-dark-soft); padding-block:clamp(3rem,6vw,4.5rem) 2rem; margin-top:3rem; }
.site-footer .logo{ height:30px; width:auto; margin-bottom:1rem; }
.site-footer h4{ font-family:var(--sans); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--steel); margin-bottom:1.1rem; }
.site-footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:.6rem; }
.site-footer a{ color:var(--on-dark-soft); font-size:.92rem; transition:color .25s; }
.site-footer a:hover{ color:var(--orange); }
.site-footer .lead{ color:var(--on-dark-soft); }
.socials{ display:flex; gap:.7rem; margin-top:1rem; }
.socials a{ width:38px; height:38px; border:1px solid rgba(255,255,255,.18); border-radius:50%; display:grid; place-items:center; transition:border-color .3s, color .3s, transform .3s; }
.socials a:hover{ border-color:var(--orange); color:var(--orange); transform:translateY(-2px); }
.socials svg{ width:17px; height:17px; }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2rem; }
.foot-bottom{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-top:3rem; padding-top:1.6rem; border-top:1px solid rgba(255,255,255,.12); font-size:.8rem; color:var(--steel); }
.foot-bottom .seal{ display:inline-flex; align-items:center; gap:.5rem; color:var(--on-dark-soft); }
.foot-bottom .seal svg{ width:15px; height:15px; color:var(--orange); }

/* ---------- Page hero (subpáginas) ---------- */
.page-hero{ padding-top:clamp(8rem,14vw,11rem); padding-bottom:clamp(2.5rem,5vw,4rem); position:relative; background:var(--bg-soft); border-bottom:1px solid var(--line); }
.page-hero h1{ font-size:clamp(2.4rem,6vw,4.4rem); margin:1rem 0 1rem; }
.page-hero .lead{ max-width:46rem; }
.crumbs{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--steel); }
.crumbs a:hover{ color:var(--orange-ink); }

/* ---------- Legal ---------- */
.legal{ max-width:48rem; }
.legal h2{ font-size:1.5rem; margin:2.2rem 0 .8rem; color:var(--ink); }
.legal h3{ font-size:1.1rem; margin:1.4rem 0 .5rem; }
.legal p,.legal li{ color:var(--muted); }
.legal ul{ padding-left:1.2rem; }
.legal a{ color:var(--orange-ink); text-decoration:underline; }
.legal code{ background:var(--bg-soft); border:1px solid var(--line); border-radius:3px; padding:.1em .4em; font-size:.9em; }

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s 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; transform:none; transition:none; }
  .marquee__track,.scroll-cue .line{ animation:none; }
}

/* ---------- Cookie banner + modal ---------- */
.cookie-banner{
  position:fixed; left:1rem; right:1rem; bottom:1rem; z-index:120; max-width:760px; margin-inline:auto;
  background:var(--glass); backdrop-filter:blur(16px); border:1px solid var(--line);
  border-radius:8px; padding:1.4rem 1.5rem; box-shadow:0 24px 60px -22px rgba(20,22,26,.4);
  display:flex; gap:1.2rem; align-items:center; flex-wrap:wrap;
  transform:translateY(140%); transition:transform .6s var(--ease);
}
.cookie-banner.show{ transform:none; }
.cookie-banner p{ margin:0; flex:1 1 280px; font-size:.86rem; color:var(--muted); }
.cookie-banner p b{ color:var(--ink); }
.cookie-banner .actions{ display:flex; gap:.6rem; flex-wrap:wrap; }
.cookie-banner .btn{ padding:.6rem 1.05rem; font-size:.72rem; }
.modal{ position:fixed; inset:0; z-index:130; display:none; place-items:center; padding:1.2rem; }
.modal.show{ display:grid; }
.modal__bg{ position:absolute; inset:0; background:rgba(20,22,26,.5); backdrop-filter:blur(4px); }
.modal__card{ position:relative; width:min(560px,100%); max-height:88vh; overflow:auto; background:#fff; border:1px solid var(--line); border-radius:10px; padding:2rem; box-shadow:0 40px 80px -30px rgba(20,22,26,.5); }
.modal__card h3{ font-size:1.5rem; margin-bottom:.4rem; }
.modal__close{ position:absolute; top:1rem; right:1rem; background:none; border:1px solid var(--line); color:var(--ink); width:34px; height:34px; border-radius:50%; cursor:pointer; }
.ck-cat{ border:1px solid var(--line); border-radius:var(--radius); padding:1.1rem 1.2rem; margin-top:1rem; }
.ck-cat__head{ display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.ck-cat__head h4{ font-family:var(--serif); font-size:1.05rem; }
.ck-cat p{ font-size:.85rem; color:var(--muted); margin:.5rem 0 0; }
.ck-badge{ font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--orange-ink); border:1px solid var(--line); border-radius:999px; padding:.25rem .7rem; }
.switch{ position:relative; width:46px; height:24px; flex:none; }
.switch input{ opacity:0; width:0; height:0; }
.switch .track{ position:absolute; inset:0; background:#d4d8dd; border-radius:999px; transition:.3s; }
.switch .track::before{ content:""; position:absolute; top:3px; left:3px; width:18px; height:18px; background:#fff; border-radius:50%; transition:.3s; box-shadow:0 1px 3px rgba(0,0,0,.3); }
.switch input:checked + .track{ background:var(--orange); }
.switch input:checked + .track::before{ transform:translateX(22px); }
.modal__actions{ display:flex; gap:.7rem; margin-top:1.6rem; flex-wrap:wrap; }

/* ---------- Utilidades (evitan style="" inline → CSP estricta) ---------- */
.sec-title{ font-size:clamp(2rem,4.4vw,3.4rem); margin-top:1rem; }
.sec-title--sm{ font-size:clamp(1.9rem,4vw,3rem); margin:1rem 0 1.2rem; }
.measure{ max-width:42rem; } .measure-40{ max-width:40rem; } .measure-36{ max-width:36rem; }
.measure-30{ max-width:30rem; } .measure-46{ max-width:46rem; }
.fs-sm{ font-size:.95rem; }
.mb-sm{ margin-bottom:.5rem; } .mb-md{ margin-bottom:1.8rem; } .mb-lg{ margin-bottom:2.6rem; }
.mt-md{ margin-top:1.8rem; } .mt-lg{ margin-top:2.4rem; }
.t-center{ text-align:center; }

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .team-grid{ grid-template-columns:repeat(2,1fr); }
  .foot-top{ grid-template-columns:1fr 1fr; }
  .split{ grid-template-columns:1fr; }
  .split--rev{ direction:ltr; }
  .frame img{ aspect-ratio:16/10; }
}
@media (max-width:760px){
  .nav-links{
    position:fixed; inset:0 0 0 auto; width:min(78vw,320px); flex-direction:column; align-items:flex-start;
    background:var(--bg); border-left:1px solid var(--line); padding:6rem 2rem 2rem; gap:1.4rem;
    transform:translateX(100%); transition:transform .45s var(--ease); z-index:90; box-shadow:-20px 0 60px -30px rgba(0,0,0,.3);
  }
  .nav-links.open{ transform:none; }
  .nav-toggle{ display:block; z-index:95; }
  .nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2){ opacity:0; }
  .nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .statstrip .wrap{ grid-template-columns:1fr 1fr; }
  .stat:nth-child(odd){ border-left:0; }
  .stat:nth-child(n+3){ border-top:1px solid var(--line-soft); }
  .svc-grid{ grid-template-columns:1fr; }
  .team-grid{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .foot-top{ grid-template-columns:1fr 1fr; }
  .fleet__row{ grid-template-columns:1fr; gap:.8rem; }
  .fleet__meta{ text-align:left; }
}
