/* ============================================================================
   Grupo SVQ — gruposvq.com
   Monochrome-navy brand system. Tokens mirror the Grupo SVQ design system.
   No third-party requests; fonts self-hosted via fonts.css.
   ============================================================================ */
:root{
  --navy-50:#EEF4FA;--navy-100:#D6E4F1;--navy-200:#B0C9E3;--navy-300:#7FA6CF;--navy-400:#4F7FB4;
  --navy-500:#2B619B;--navy-600:#1A4E85;--navy-700:#0F4173;--navy-800:#0A3A66;--navy-900:#073763;--navy-950:#04223D;
  --gray-50:#F8FAFC;--gray-100:#F1F5F9;--gray-200:#E2E8F0;--gray-300:#CBD5E1;--gray-400:#94A3B8;
  --gray-500:#64748B;--gray-600:#475569;--gray-700:#334155;--gray-800:#1E293B;--gray-900:#0F172A;
  --success:#15803D;--danger:#B91C1C;--danger-tint:#FEE2E2;--success-tint:#DCFCE7;
  --font-head:"Inter Tight","Inter",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --font-mono:"IBM Plex Mono","Cascadia Code",Consolas,monospace;
  --maxw:1140px;--radius:6px;--radius-lg:12px;
  --shadow:0 2px 8px rgba(7,55,99,.08);--shadow-lg:0 14px 40px rgba(7,55,99,.14);
  --space:clamp(64px,9vw,112px);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{font-family:var(--font-body);color:var(--gray-700);background:#fff;line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg{display:block;max-width:100%}
a{color:var(--navy-700);text-underline-offset:3px}
a:hover{color:var(--navy-900)}
:focus-visible{outline:3px solid var(--navy-500);outline-offset:2px;border-radius:3px}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--navy-900);line-height:1.12;letter-spacing:-.015em;font-weight:700}
h2{font-size:clamp(28px,4vw,40px)}
h3{font-size:22px;font-weight:600;line-height:1.25}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.kicker{font-family:var(--font-head);font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--navy-500)}
.section{padding:var(--space) 0}
.section--tint{background:var(--gray-50)}
.lead{font-size:clamp(18px,2.2vw,21px);color:var(--gray-600);max-width:62ch}
.eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.eyebrow::before{content:"";width:28px;height:2px;background:var(--navy-900)}
.skip{position:absolute;left:-999px;top:0;background:var(--navy-900);color:#fff;padding:10px 16px;z-index:1000;border-radius:0 0 6px 0}
.skip:focus{left:0}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:600;font-size:16px;
  padding:13px 24px;border-radius:var(--radius);border:1.5px solid transparent;cursor:pointer;text-decoration:none;transition:background .15s,border-color .15s,color .15s,transform .05s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--navy-900);color:#fff;border-color:var(--navy-900)}
.btn--primary:hover{background:var(--navy-800);color:#fff}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn--ghost:hover{background:rgba(255,255,255,.1);color:#fff}
.btn--outline{background:#fff;color:var(--navy-700);border-color:var(--navy-300)}
.btn--outline:hover{border-color:var(--navy-700);color:var(--navy-900)}
.btn[disabled]{opacity:.55;cursor:not-allowed}
.btn svg{width:18px;height:18px}

/* ---- Header / nav ---- */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--gray-200)}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.nav__logo img{height:46px;width:auto}
.nav__links{display:flex;align-items:center;gap:28px;list-style:none}
.nav__links a:not(.btn){font-family:var(--font-body);font-weight:500;color:var(--gray-700);text-decoration:none;font-size:15.5px}
.nav__links a:not(.btn):hover{color:var(--navy-900)}
.nav__links .btn--primary{color:#fff}
.nav__cta{margin-left:8px}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--navy-900)}
.nav__toggle svg{width:26px;height:26px}
@media (max-width:880px){
  .nav__toggle{display:block}
  .nav__links{position:absolute;top:72px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:#fff;border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow);max-height:0;overflow:hidden;transition:max-height .25s ease}
  .nav__links li{border-top:1px solid var(--gray-100)}
  .nav__links a{display:block;padding:16px 24px}
  .nav__cta{margin:14px 24px 20px}
  .nav[data-open="true"] .nav__links{max-height:420px}
}

/* ---- Hero ---- */
.hero{position:relative;color:#fff;overflow:hidden;background:linear-gradient(155deg,#0A3A66 0%,#073763 52%,#04223D 100%)}
/* faint noise dither — kills gradient banding on dark / OLED panels (invisible ~3%) */
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.03;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero__mark{position:absolute;right:-2%;top:50%;transform:translateY(-50%);width:min(46%,560px);height:auto;opacity:.06;z-index:1;pointer-events:none;user-select:none}
@media (max-width:880px){.hero__mark{right:-14%;top:46%;width:74%;opacity:.045}}
.hero__in{position:relative;max-width:var(--maxw);margin:0 auto;padding:clamp(72px,12vw,128px) 24px;z-index:2}
.hero .kicker{color:var(--navy-200)}
.hero h1{color:#fff;font-size:clamp(38px,6vw,68px);line-height:1.04;max-width:16ch;margin:14px 0 0}
.hero p{color:var(--navy-100);font-size:clamp(18px,2.4vw,22px);max-width:54ch;margin:24px 0 0}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px}
.hero__meta{margin-top:44px;display:flex;flex-wrap:wrap;gap:8px 28px;color:var(--navy-200);font-size:14px;font-family:var(--font-mono)}
.hero__meta span{display:inline-flex;align-items:center;gap:8px}
.hero__meta span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--navy-300)}

/* ---- Services ---- */
.grid{display:grid;gap:22px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(2,1fr)}
@media (max-width:880px){.grid--3{grid-template-columns:1fr 1fr}}
@media (max-width:620px){.grid--3,.grid--4{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:28px;transition:border-color .15s,box-shadow .15s,transform .15s}
.card:hover{border-color:var(--navy-200);box-shadow:var(--shadow);transform:translateY(-2px)}
.card__icon{width:46px;height:46px;border-radius:10px;background:var(--navy-50);color:var(--navy-900);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.card__icon svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.card h3{margin-bottom:8px}
.card p{font-size:15.5px;color:var(--gray-600)}
.card ul{margin:12px 0 0;padding-left:0;list-style:none;font-size:14px;color:var(--gray-500)}
.card li{padding-left:18px;position:relative;margin-top:5px}
.card li::before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:var(--navy-400)}

/* ---- Enfoque (value band) ---- */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:40px}
@media (max-width:880px){.values{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.values{grid-template-columns:1fr}}
.value__n{font-family:var(--font-head);font-weight:700;color:var(--navy-200);font-size:15px;letter-spacing:.1em}
.value h3{font-size:18px;margin:8px 0 6px}
.value p{font-size:15px;color:var(--gray-600)}
.value{border-top:2px solid var(--navy-900);padding-top:16px}

/* ---- Proceso ---- */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:40px}
@media (max-width:880px){.steps{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding:24px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg)}
.step__num{font-family:var(--font-mono);font-size:13px;font-weight:500;color:#fff;background:var(--navy-900);width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.step h3{font-size:18px;margin-bottom:6px}
.step p{font-size:15px;color:var(--gray-600)}

/* ---- Contact ---- */
.contact{background:var(--navy-900);color:#fff}
.contact .kicker{color:var(--navy-200)}
.contact h2{color:#fff}
.contact__grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(32px,5vw,72px);align-items:start;margin-top:36px}
@media (max-width:860px){.contact__grid{grid-template-columns:1fr}}
.contact__aside p{color:var(--navy-100);max-width:42ch}
.contact__list{list-style:none;margin:28px 0 0;display:grid;gap:14px}
.contact__list a,.contact__list span{color:#fff;text-decoration:none;font-weight:500;display:inline-flex;gap:10px;align-items:center}
.contact__list svg{width:18px;height:18px;fill:none;stroke:var(--navy-300);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.form{background:#fff;border-radius:var(--radius-lg);padding:clamp(24px,3vw,36px);color:var(--gray-700)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--font-head);font-weight:600;font-size:14px;color:var(--navy-900);margin-bottom:7px}
.field .req{color:var(--danger)}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:16px;color:var(--gray-800);background:#fff;
  border:1px solid var(--gray-300);border-radius:var(--radius);padding:12px 14px}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--navy-700);box-shadow:0 0 0 3px var(--navy-100)}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:520px){.field--row{grid-template-columns:1fr}}
.consent{display:flex;gap:11px;align-items:flex-start;font-size:14px;color:var(--gray-600)}
.consent input{width:18px;height:18px;margin-top:3px;flex:none;accent-color:var(--navy-900)}
.consent a{color:var(--navy-700)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.cf-turnstile{margin:6px 0 18px}
.form__msg{display:none;border-radius:var(--radius);padding:13px 16px;font-size:14.5px;margin-bottom:18px}
.form__msg--ok{display:block;background:var(--success-tint);color:var(--success);border:1px solid #A7F3C0}
.form__msg--err{display:block;background:var(--danger-tint);color:var(--danger);border:1px solid #FBBEBE}
.form .btn{width:100%;justify-content:center}
.form__note{font-size:12.5px;color:var(--gray-500);margin-top:14px;text-align:center}

/* ---- Footer ---- */
.footer{background:var(--navy-950);color:var(--navy-200);font-size:14.5px}
.footer__in{max-width:var(--maxw);margin:0 auto;padding:60px 24px 28px;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
@media (max-width:760px){.footer__in{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer__in{grid-template-columns:1fr}}
.footer img{height:56px;width:auto;margin-bottom:16px}
.footer__desc{max-width:30ch;color:var(--navy-200)}
.footer h4{font-family:var(--font-head);color:#fff;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;font-weight:600}
.footer ul{list-style:none;display:grid;gap:9px}
.footer a{color:var(--navy-200);text-decoration:none}
.footer a:hover{color:#fff}
.footer__bar{border-top:1px solid var(--navy-800);margin-top:8px}
.footer__bar div{max-width:var(--maxw);margin:0 auto;padding:20px 24px;display:flex;flex-wrap:wrap;gap:6px 18px;justify-content:space-between;font-size:13px;color:var(--navy-300)}

/* ---- Legal pages ---- */
.legal{max-width:820px;margin:0 auto;padding:clamp(48px,7vw,88px) 24px}
.legal h1{font-size:clamp(30px,5vw,44px);margin-bottom:10px}
.legal .updated{font-family:var(--font-mono);font-size:13px;color:var(--gray-500);margin-bottom:36px}
.legal h2{font-size:22px;margin:36px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--navy-900)}
.legal h3{font-size:17px;margin:22px 0 8px}
.legal p,.legal li{font-size:16px;color:var(--gray-700);margin-bottom:12px}
.legal ul,.legal ol{padding-left:22px;margin-bottom:12px}
.legal li{margin-bottom:7px}
.legal .datatable{width:100%;border-collapse:collapse;margin:16px 0}
.legal .datatable th,.legal .datatable td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--gray-200);font-size:15px;vertical-align:top}
.legal .datatable th{width:34%;font-family:var(--font-head);color:var(--navy-900);font-weight:600}
.legal .fill{background:#FEF3C7;color:#92400E;padding:1px 7px;border-radius:4px;font-size:13px;font-family:var(--font-mono)}
.legal .back{display:inline-block;margin-top:40px;font-weight:500}
.page-head{background:var(--navy-900);color:#fff;padding:18px 0}
.page-head .nav__in{height:auto;padding:6px 24px}

/* ---- Thank-you / 404 ---- */
.center-screen{min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:64px 24px}
.center-screen img{height:54px;margin-bottom:28px}
.center-screen h1{font-size:clamp(30px,5vw,46px)}
.center-screen p{margin:14px 0 28px;color:var(--gray-600);max-width:48ch}
