/* =============================================================
   Pasquinelli & Asoc. â€” Estudio JurÃ­dico
   styles.css â€” diseÃ±o visual original (no modificar)
   Variables, layout, animaciones, componentes y responsive.
   ============================================================= */
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic-ext.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("fonts/montserrat-vietnamese.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("fonts/montserrat-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("fonts/montserrat-latin.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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic-ext.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("fonts/montserrat-vietnamese.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("fonts/montserrat-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("fonts/montserrat-latin.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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic-ext.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/montserrat-vietnamese.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/montserrat-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/montserrat-latin.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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic-ext.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/montserrat-vietnamese.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/montserrat-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/montserrat-latin.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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic-ext.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/montserrat-vietnamese.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/montserrat-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/montserrat-latin.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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic-ext.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/montserrat-vietnamese.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/montserrat-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/montserrat-latin.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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic-ext.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/montserrat-vietnamese.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/montserrat-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("fonts/montserrat-latin.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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic-ext.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/montserrat-cyrillic.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/montserrat-vietnamese.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/montserrat-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("fonts/montserrat-latin.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;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#1C1B35;
  --navy-light:#252444;
  --navy-dark:#131224;
  --navy-mid:#1E1D38;
  --navy-line:#3A3955;
  --white:#FFFFFF;
  --off-white:#F5F5F5;
  --paper:#FAFAFA;
  --gray:#9B9AB0;
  --gray-light:#E8E7F0;
  --gray-line:#D8D8DC;
  --text:#3D3C58;
  --border:rgba(255,255,255,0.1);
}

/* Isometric grid — signature brand pattern */
.iso-grid-navy{
  background-color:var(--navy);
  background-image:
    linear-gradient(60deg, var(--navy-line) 1px, transparent 1px),
    linear-gradient(-60deg, var(--navy-line) 1px, transparent 1px),
    linear-gradient(0deg,  var(--navy-line) 1px, transparent 1px);
  background-size:32px 56px,32px 56px,32px 56px;
  opacity:1;
}
.iso-grid-paper{
  background-color:var(--paper);
  background-image:
    linear-gradient(60deg, var(--gray-line) 1px, transparent 1px),
    linear-gradient(-60deg, var(--gray-line) 1px, transparent 1px),
    linear-gradient(0deg,  var(--gray-line) 1px, transparent 1px);
  background-size:32px 56px,32px 56px,32px 56px;
}
html{scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;color:var(--navy);background:var(--white);overflow-x:hidden}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--navy-dark)}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.3)}
img{max-width:100%;display:block}
a{text-decoration:none}

/* ── TOPBAR ── */
.topbar{
  background:var(--navy-dark);
  padding:0.55rem 5rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom:1px solid var(--border);
}
.topbar-left{display:flex;gap:2rem;align-items:center}
.topbar-item{
  display:flex;align-items:center;gap:0.45rem;
  font-size:0.65rem;font-weight:500;letter-spacing:0.05em;
  color:rgba(255,255,255,0.55);
}
.topbar-item a{color:inherit;transition:color .2s}
.topbar-item a:hover{color:var(--white)}
.topbar-right{display:flex;gap:1rem;align-items:center}
.topbar-social{
  width:26px;height:26px;border:1px solid rgba(255,255,255,0.15);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.4);font-size:0.6rem;font-weight:700;
  transition:all .2s;
}
.topbar-social:hover{border-color:rgba(255,255,255,0.6);color:var(--white)}
.topbar-matricula{
  font-size:0.58rem;font-weight:600;letter-spacing:0.08em;
  color:rgba(255,255,255,0.25);padding-left:1rem;
  border-left:1px solid rgba(255,255,255,0.1);
}

/* ── NAV ── */
nav{
  position:sticky;top:0;z-index:1000;
  background:var(--navy);
  padding:0 5rem;
  display:flex;align-items:center;justify-content:space-between;
  height:68px;
  border-bottom:1px solid rgba(255,255,255,0.06);
  transition:box-shadow .3s;
}
nav.shadow{box-shadow:0 4px 40px rgba(0,0,0,0.4)}
.nav-logo{display:flex;align-items:center;gap:0.85rem;}
.nav-logo-img{width:42px;height:42px;object-fit:cover}
.nav-logo-text{line-height:1.25}
.nav-logo-title{
  font-size:0.82rem;font-weight:700;letter-spacing:0.02em;
  color:var(--white);
}
.nav-logo-sub{
  font-size:0.58rem;font-weight:400;letter-spacing:0.12em;
  text-transform:uppercase;color:rgba(255,255,255,0.45);
}
.nav-links{display:flex;align-items:center;gap:0.25rem;list-style:none}
.nav-links a{
  font-size:0.7rem;font-weight:600;letter-spacing:0.08em;
  text-transform:uppercase;color:rgba(255,255,255,0.6);
  padding:0.5rem 0.85rem;transition:color .2s;
  position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-2px;left:0.85rem;right:0.85rem;
  height:1px;background:var(--white);transform:scaleX(0);
  transition:transform .25s;transform-origin:left;
}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{
  background:var(--white);color:var(--navy)!important;
  padding:0.6rem 1.4rem!important;font-weight:700!important;
  transition:all .25s!important;
}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:rgba(255,255,255,0.88)!important;transform:translateY(-1px)}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.nav-burger span{display:block;width:22px;height:2px;background:var(--white);transition:.3s}

/* ── HERO ── */
.hero{
  min-height:92vh;
  background:var(--navy-dark);
  display:grid;grid-template-columns:1fr 1fr;
  position:relative;overflow:hidden;
}
.hero-left{
  padding:6rem 3rem 5rem 5rem;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;z-index:2;
}
.hero-bg-lines{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);
  background-size:50px 50px;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:0.6rem;
  margin-bottom:2rem;
  opacity:0;animation:fadeUp .7s ease .1s forwards;
}
.hero-tag-line{width:28px;height:1px;background:rgba(255,255,255,0.4)}
.hero-tag-text{
  font-size:0.62rem;font-weight:700;letter-spacing:0.2em;
  text-transform:uppercase;color:rgba(255,255,255,0.5);
}
.hero-title{
  font-size:clamp(2.4rem,4.5vw,3.8rem);
  font-weight:800;line-height:1.06;
  color:var(--white);
  margin-bottom:1.5rem;
  opacity:0;animation:fadeUp .7s ease .25s forwards;
}
.hero-title span{
  display:block;font-weight:300;font-size:0.75em;
  color:rgba(255,255,255,0.6);letter-spacing:0.01em;
}
.hero-desc{
  font-size:0.88rem;font-weight:400;line-height:1.85;
  color:rgba(255,255,255,0.5);max-width:440px;
  margin-bottom:2.5rem;
  opacity:0;animation:fadeUp .7s ease .4s forwards;
}
.hero-actions{
  display:flex;gap:1rem;flex-wrap:wrap;align-items:center;
  opacity:0;animation:fadeUp .7s ease .55s forwards;
}
.hero-free{
  display:inline-flex;align-items:center;gap:0.6rem;
  margin-top:1.5rem;
  padding:0.55rem 0.9rem;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);
  font-size:0.7rem;color:rgba(255,255,255,0.7);letter-spacing:0.02em;
  opacity:0;animation:fadeUp .7s ease .65s forwards;
}
.hero-free strong{color:var(--white);font-weight:700}
.hero-free-dot{
  width:6px;height:6px;background:#fff;border-radius:50%;flex-shrink:0;
  box-shadow:0 0 0 3px rgba(255,255,255,0.15);
  animation:pulseDot 2.4s ease-in-out infinite;
}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:0.4}}
.btn-white{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:var(--white);color:var(--navy-dark);
  padding:0.9rem 1.75rem;
  font-size:0.72rem;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;transition:all .25s;
}
.btn-white:hover{background:rgba(255,255,255,0.88);transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,0.3)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:0.5rem;
  border:1px solid rgba(255,255,255,0.3);color:rgba(255,255,255,0.7);
  padding:0.9rem 1.75rem;
  font-size:0.72rem;font-weight:600;letter-spacing:0.08em;
  text-transform:uppercase;transition:all .25s;
}
.btn-ghost:hover{border-color:var(--white);color:var(--white)}
.hero-stats{
  display:flex;gap:0;
  margin-top:3rem;padding-top:2rem;
  border-top:1px solid rgba(255,255,255,0.08);
  opacity:0;animation:fadeUp .7s ease .7s forwards;
}
.hero-stat{
  flex:1;padding:0 1.6rem;
  border-left:1px solid rgba(255,255,255,0.09);
}
.hero-stat:first-child{border-left:none;padding-left:0}
.hero-stat-n{
  font-size:2.4rem;font-weight:800;color:var(--white);line-height:1;
  letter-spacing:-0.02em;
}
.hero-stat-l{
  font-size:0.62rem;font-weight:500;letter-spacing:0.12em;
  text-transform:uppercase;color:rgba(255,255,255,0.4);
  margin-top:0.7rem;line-height:1.4;
  white-space:nowrap;
}
.hero-right{
  position:relative;
  background:var(--navy-mid);
  overflow:hidden;
}
.hero-right::before{
  content:'';position:absolute;inset:1.25rem;
  border:1px solid rgba(255,255,255,0.12);
  pointer-events:none;z-index:3;
}
.hero-photo{
  width:100%;height:100%;object-fit:cover;object-position:center;
  filter:grayscale(15%) brightness(0.92) contrast(1.03);
  display:block;
}
.hero-photo-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(19,18,36,0.55) 0%,rgba(19,18,36,0.15) 35%,rgba(19,18,36,0) 70%),
    linear-gradient(0deg,rgba(19,18,36,0.85) 0%,rgba(19,18,36,0.1) 45%);
}
.hero-photo-grid{
  position:absolute;inset:0;opacity:0.06;mix-blend-mode:screen;
  background-image:
    linear-gradient(60deg, #fff 1px, transparent 1px),
    linear-gradient(-60deg, #fff 1px, transparent 1px);
  background-size:40px 70px;
}
.hero-badge{
  position:absolute;bottom:2.25rem;left:2.25rem;right:2.25rem;
  background:rgba(19,18,36,0.92);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.12);
  padding:1.15rem 1.35rem;max-width:340px;
  opacity:0;animation:fadeIn 1s ease 0.8s forwards;
  display:flex;align-items:center;gap:1rem;z-index:4;
}
.hero-badge-mark{
  width:36px;height:36px;border:1px solid rgba(255,255,255,0.25);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-family:'Montserrat',sans-serif;font-size:1rem;color:var(--white);font-weight:700;letter-spacing:-0.02em;
}
.hero-badge-title{
  font-size:0.72rem;font-weight:700;color:var(--white);margin-bottom:0.18rem;letter-spacing:0.02em;
}
.hero-badge-sub{
  font-size:0.6rem;font-weight:400;color:rgba(255,255,255,0.5);line-height:1.5;letter-spacing:0.04em;
}

/* ── SERVICIOS STRIP ── */
.services-strip{
  background:var(--white);
  border-bottom:1px solid var(--gray-light);
  padding:0 5rem;
  display:flex;overflow-x:auto;
  scrollbar-width:none;
}
.services-strip::-webkit-scrollbar{display:none}
.strip-item{
  flex-shrink:0;padding:1.4rem 2rem;
  border-right:1px solid var(--gray-light);
  display:flex;align-items:center;gap:0.6rem;
  font-size:0.72rem;font-weight:700;letter-spacing:0.04em;
  color:var(--navy);text-transform:uppercase;
  transition:background .2s;cursor:pointer;
  white-space:nowrap;
}
.strip-item:first-child{border-left:1px solid var(--gray-light)}
.strip-item:hover{background:var(--off-white)}
.strip-item svg{flex-shrink:0;opacity:0.5}

/* ── SECTION BASE ── */
.section{max-width:1200px;margin:0 auto;padding:6rem 2rem}
.section-full{padding:6rem 0}
.section-full .section{padding-top:0;padding-bottom:0}
.tag{
  display:inline-flex;align-items:center;gap:0.5rem;margin-bottom:1rem;
}
.tag-line{width:24px;height:1px;background:var(--navy)}
.tag-text{
  font-size:0.6rem;font-weight:700;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--navy);opacity:0.5;
}
.tag.light .tag-line{background:rgba(255,255,255,0.4)}
.tag.light .tag-text{color:rgba(255,255,255,0.4)}
h2.section-title{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(1.9rem, 3.5vw, 2.8rem);
  font-weight:800;line-height:1.1;color:var(--navy);
  margin-bottom:1.25rem;
  letter-spacing:-0.015em;
}
h2.section-title em{font-style:normal;font-weight:200;color:var(--gray);display:block;font-size:0.65em;letter-spacing:0;margin-top:0.25rem}
h2.section-title.light{color:var(--white)}
h2.section-title.light em{color:rgba(255,255,255,0.4)}
.section-lead{
  font-size:0.88rem;line-height:1.85;color:var(--gray);max-width:500px;
}
.section-lead.light{color:rgba(255,255,255,0.45)}

/* ── SERVICIOS GRID ── */
.bg-off{background:var(--off-white)}
.services-header{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;
  align-items:end;margin-bottom:4rem;
}
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--gray-light);
}
.srv-card{
  background:var(--white);padding:2.25rem 2rem;
  position:relative;overflow:hidden;transition:all .3s;
}
.srv-card::before{
  content:'';position:absolute;top:0;left:0;
  width:3px;height:0;background:var(--navy);
  transition:height .35s ease;
}
.srv-card:hover{background:var(--navy);}
.srv-card:hover::before{height:100%}
.srv-icon{
  width:40px;height:40px;
  background:var(--off-white);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.25rem;transition:.3s;
}
.srv-card:hover .srv-icon{background:rgba(255,255,255,0.1)}
.srv-icon svg{transition:.3s}
.srv-card:hover .srv-icon svg{stroke:var(--white)}
.srv-name{
  font-size:0.82rem;font-weight:700;letter-spacing:0.03em;
  text-transform:uppercase;color:var(--navy);
  margin-bottom:0.65rem;transition:.3s;
}
.srv-card:hover .srv-name{color:var(--white)}
.srv-text{
  font-size:0.77rem;line-height:1.75;color:var(--gray);
  transition:.3s;
}
.srv-card:hover .srv-text{color:rgba(255,255,255,0.55)}
.srv-link{
  display:inline-flex;align-items:center;gap:0.35rem;
  margin-top:1.25rem;
  font-size:0.62rem;font-weight:700;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--navy);
  transition:.3s;
}
.srv-card:hover .srv-link{color:rgba(255,255,255,0.7)}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.about-photo-col{
  position:relative;overflow:hidden;
  background:var(--off-white);
  display:flex;align-items:center;justify-content:center;
  padding:5rem 3rem;
  border-right:1px solid var(--gray-light);
}
.about-portrait-wrap{display:flex;flex-direction:column;align-items:center;max-width:280px;width:100%}
.about-portrait{
  width:200px;height:240px;
  background:var(--navy);
  border:1px solid var(--gray-light);
  margin-bottom:1.25rem;
  position:relative;overflow:hidden;
}
.about-portrait svg{width:100%;height:100%;display:block}
.about-portrait::after{
  content:'';position:absolute;inset:0;
  border:1px solid rgba(255,255,255,0.08);margin:6px;
  pointer-events:none;
}
.about-portrait-caption{text-align:center;padding-top:0.75rem;border-top:1px solid var(--gray-light);width:100%}
.about-portrait-name{font-size:0.78rem;font-weight:700;color:var(--navy);letter-spacing:0.02em}
.about-portrait-role{font-size:0.62rem;font-weight:400;color:var(--gray);letter-spacing:0.1em;text-transform:uppercase;margin-top:0.3rem}
.about-portrait-mat{font-size:0.55rem;font-weight:500;color:var(--gray);letter-spacing:0.05em;margin-top:0.45rem;line-height:1.6}
.about-content{
  background:var(--white);
  padding:5rem;display:flex;flex-direction:column;justify-content:center;
}
.credentials-list{display:flex;flex-direction:column;gap:0;margin-top:2rem}
.cred-item{
  display:flex;gap:1rem;padding:1.1rem 0;
  border-bottom:1px solid var(--gray-light);align-items:flex-start;
  transition:.25s;
}
.cred-item:first-child{border-top:1px solid var(--gray-light)}
.cred-num{
  font-size:0.65rem;font-weight:700;color:var(--gray);
  min-width:24px;margin-top:2px;
}
.cred-text{font-size:0.8rem;font-weight:600;color:var(--navy);line-height:1.4}
.cred-sub{
  font-size:0.7rem;font-weight:400;color:var(--gray);
  margin-top:0.15rem;
}

/* ── DIFERENCIAL ── */
.diferencial-bg{
  background:var(--navy-dark);
  position:relative;overflow:hidden;
}
.diferencial-bg::before{
  content:'PASQUINELLI';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-size:14vw;font-weight:900;
  color:rgba(255,255,255,0.018);
  white-space:nowrap;letter-spacing:0.05em;
  pointer-events:none;
}
.diferencial-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.dif-left{padding:6rem 5rem;}
.dif-quote{
  font-size:1.15rem;font-style:italic;font-weight:300;
  color:rgba(255,255,255,0.45);line-height:1.8;
  border-left:2px solid rgba(255,255,255,0.2);
  padding-left:1.5rem;margin-top:2rem;max-width:380px;
}
.dif-right{padding:6rem 5rem 6rem 3rem}
.dif-items{display:flex;flex-direction:column;gap:0}
.dif-item{
  display:flex;gap:1.25rem;padding:1.4rem 1.5rem;
  border-bottom:1px solid rgba(255,255,255,0.05);
  cursor:default;transition:.25s;
}
.dif-item:first-child{border-top:1px solid rgba(255,255,255,0.05)}
.dif-item:hover{background:rgba(255,255,255,0.03)}
.dif-n{
  font-size:0.72rem;font-weight:700;
  color:rgba(255,255,255,0.2);min-width:28px;margin-top:2px;
}
.dif-body{}
.dif-title{font-size:0.8rem;font-weight:700;color:rgba(255,255,255,0.8);}
.dif-desc{font-size:0.72rem;font-weight:400;color:rgba(255,255,255,0.35);margin-top:0.2rem;line-height:1.6}

/* ── PROCESO ── */
.proceso-wrap{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:4rem;background:var(--gray-light);align-items:stretch}
.proceso-image-col{position:relative;overflow:hidden;background:var(--navy);min-height:420px}
.proceso-image-col img{width:100%;height:100%;object-fit:cover;filter:grayscale(25%) brightness(0.92);display:block}
.proceso-image-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(28,27,53,0.15) 0%,rgba(28,27,53,0.55) 100%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:2rem;
}
.proceso-image-eyebrow{font-size:0.6rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.6);margin-bottom:0.5rem}
.proceso-image-quote{font-size:0.92rem;font-weight:300;font-style:italic;color:var(--white);line-height:1.5;max-width:280px}
.proceso-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--gray-light)}
.proceso-step{
  background:var(--white);padding:2.5rem 2rem;
  border-right:1px solid var(--gray-light);
  border-bottom:1px solid var(--gray-light);
  position:relative;
}
.proceso-step:last-child{border-right:none}
.paso-n{
  font-size:3rem;font-weight:900;color:var(--off-white);
  line-height:1;margin-bottom:1rem;
}
.paso-title{
  font-size:0.8rem;font-weight:700;text-transform:uppercase;
  letter-spacing:0.05em;color:var(--navy);margin-bottom:0.5rem;
}
.paso-text{font-size:0.75rem;line-height:1.7;color:var(--gray)}

/* ── SEO TEXTO ── */
.seo-section{background:var(--off-white)}
.seo-grid{display:grid;grid-template-columns:2fr 1fr;gap:4rem;align-items:start}
.seo-text h3{
  font-size:1rem;font-weight:700;color:var(--navy);
  margin:1.5rem 0 0.5rem;
}
.seo-text p{
  font-size:0.82rem;line-height:1.85;color:var(--text);margin-bottom:0.5rem;
}
.seo-text ul{
  list-style:none;display:flex;flex-direction:column;gap:0.4rem;
  margin:0.5rem 0;
}
.seo-text ul li{
  font-size:0.8rem;color:var(--text);padding-left:1.2rem;position:relative;
}
.seo-text ul li::before{
  content:'—';position:absolute;left:0;color:var(--gray);font-size:0.7rem;
}
.seo-aside{
  background:var(--navy);padding:2rem;
  position:sticky;top:100px;
}
.aside-title{
  font-size:0.72rem;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;color:rgba(255,255,255,0.5);
  margin-bottom:1.25rem;
}
.aside-item{
  padding:0.85rem 0;border-bottom:1px solid rgba(255,255,255,0.07);
  display:flex;gap:0.75rem;align-items:center;
}
.aside-item:last-child{border-bottom:none}
.aside-item-icon{
  width:32px;height:32px;background:rgba(255,255,255,0.06);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.aside-item-text{font-size:0.72rem;font-weight:600;color:rgba(255,255,255,0.7);line-height:1.4}
.aside-item-sub{font-size:0.65rem;color:rgba(255,255,255,0.3);margin-top:0.1rem}

/* ── BLOG ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--gray-light)}
.blog-card{
  background:var(--white);padding:2.25rem;
  transition:all .3s;cursor:pointer;
  position:relative;overflow:hidden;
}
.blog-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:2px;background:var(--navy);
  transform:scaleX(0);transition:.3s;transform-origin:left;
}
.blog-card:hover::after{transform:scaleX(1)}
.blog-card:hover{background:var(--off-white)}
.blog-num{
  font-size:2.5rem;font-weight:900;color:var(--off-white);
  line-height:1;margin-bottom:1rem;
}
.blog-tag{
  font-size:0.58rem;font-weight:700;letter-spacing:0.15em;
  text-transform:uppercase;color:var(--gray);margin-bottom:0.6rem;
}
.blog-title{
  font-size:0.88rem;font-weight:700;color:var(--navy);
  line-height:1.4;margin-bottom:0.65rem;
}
.blog-excerpt{font-size:0.75rem;line-height:1.75;color:var(--gray)}
.blog-link{
  display:inline-flex;align-items:center;gap:0.35rem;
  margin-top:1.25rem;
  font-size:0.62rem;font-weight:700;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--navy);
  border-bottom:1px solid var(--gray-light);padding-bottom:2px;
  transition:.25s;
}
.blog-card:hover .blog-link{border-color:var(--navy)}

/* ── CTA BAND ── */
.cta-band{
  background:var(--navy-dark);
  padding:5rem;
  display:grid;grid-template-columns:1fr auto;gap:4rem;
  align-items:center;
  border-top:1px solid rgba(255,255,255,0.06);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.cta-title{
  font-size:clamp(1.6rem,3vw,2.4rem);
  font-weight:800;color:var(--white);line-height:1.15;
  margin-bottom:0.75rem;
}
.cta-sub{font-size:0.85rem;color:rgba(255,255,255,0.4);line-height:1.7}
.cta-actions{display:flex;flex-direction:column;gap:0.85rem;align-items:flex-start;white-space:nowrap}

/* ── CONTACTO ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.contact-info-col{
  background:var(--navy);padding:5rem;
}
.contact-form-col{
  background:var(--white);padding:5rem;
}
.contact-item{display:flex;gap:1rem;margin-top:1.5rem;align-items:flex-start}
.contact-item-icon{
  width:38px;height:38px;border:1px solid rgba(255,255,255,0.12);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-item-label{
  font-size:0.58rem;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:0.2rem;
}
.contact-item-val{
  font-size:0.82rem;font-weight:600;color:rgba(255,255,255,0.8);
}
.contact-item-val a{color:inherit;transition:.2s}
.contact-item-val a:hover{color:var(--white)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-field{margin-bottom:1.1rem}
.form-field label{
  display:block;font-size:0.62rem;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--navy);margin-bottom:0.4rem;
}
.form-field input,
.form-field textarea,
.form-field select{
  width:100%;padding:0.8rem 0.9rem;
  border:1px solid var(--gray-light);background:var(--off-white);
  font-family:'Montserrat',sans-serif;font-size:0.8rem;color:var(--navy);
  outline:none;transition:border-color .2s;appearance:none;
}
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus{border-color:var(--navy);background:var(--white)}
.form-field textarea{min-height:100px;resize:vertical}
.btn-navy{
  width:100%;background:var(--navy);color:var(--white);
  padding:0.95rem;border:none;cursor:pointer;
  font-family:'Montserrat',sans-serif;font-size:0.72rem;
  font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  display:flex;align-items:center;justify-content:center;gap:0.5rem;
  transition:background .25s;
}
.btn-navy:hover{background:var(--navy-light)}
.form-note{
  font-size:0.62rem;color:var(--gray);text-align:center;
  margin-top:0.85rem;line-height:1.6;
}

/* ── FOOTER ── */
footer{background:var(--navy-dark);border-top:1px solid rgba(255,255,255,0.05)}
.footer-main{
  max-width:1200px;margin:0 auto;padding:4rem 2rem;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;
}
.footer-brand-text{
  font-size:0.75rem;line-height:1.85;
  color:rgba(255,255,255,0.3);margin-top:1.1rem;max-width:240px;
}
.footer-matricula{
  font-size:0.6rem;color:rgba(255,255,255,0.18);
  margin-top:0.5rem;letter-spacing:0.05em;
}
.footer-col-title{
  font-size:0.6rem;font-weight:700;letter-spacing:0.16em;
  text-transform:uppercase;color:rgba(255,255,255,0.35);
  margin-bottom:1rem;
}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:0.5rem}
.footer-links a{
  font-size:0.75rem;color:rgba(255,255,255,0.35);
  transition:color .2s;
}
.footer-links a:hover{color:rgba(255,255,255,0.75)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.05);
  max-width:1200px;margin:0 auto;
  padding:1.5rem 2rem;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;
}
.footer-copy{
  font-size:0.62rem;color:rgba(255,255,255,0.18);
}
.footer-social-row{display:flex;gap:0.5rem}
.footer-soc{
  width:30px;height:30px;border:1px solid rgba(255,255,255,0.1);
  display:flex;align-items:center;justify-content:center;
  font-size:0.62rem;font-weight:700;
  color:rgba(255,255,255,0.3);transition:all .2s;
}
.footer-soc:hover{border-color:rgba(255,255,255,0.4);color:rgba(255,255,255,0.7)}

/* ── WA FLOAT ── */
.wa-float{
  position:fixed;bottom:2rem;right:2rem;z-index:999;
  display:flex;align-items:center;gap:0.7rem;
  background:#25D366;color:var(--white);
  padding:0.8rem 1.2rem;
  box-shadow:0 6px 28px rgba(37,211,102,0.45);
  transition:all .3s;animation:pulse 3s ease infinite;
}
.wa-float:hover{background:#1EBE57;transform:translateY(-3px);animation:none}
.wa-float-text{font-size:0.68rem;font-weight:700}
.wa-float-sub{font-size:0.58rem;opacity:.75;font-weight:400}

/* ── FAQ ── */
.faq-grid{display:flex;flex-direction:column;gap:0;max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--gray-light);overflow:hidden}
.faq-item:first-child{border-top:1px solid var(--gray-light)}
.faq-q{
  width:100%;background:none;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  padding:1.35rem 0;text-align:left;
  font-family:'Montserrat',sans-serif;font-size:1rem;font-weight:700;
  color:var(--navy);line-height:1.4;transition:color .2s;
}
.faq-q:hover{color:var(--navy-light)}
.faq-q svg{flex-shrink:0;transition:transform .3s;opacity:.4}
.faq-item.open .faq-q svg{transform:rotate(45deg);opacity:.7}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;
  font-size:0.95rem;line-height:1.8;color:var(--text);padding:0 0 0 0;
}
.faq-item.open .faq-a{max-height:300px;padding:0 0 1.5rem 0}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}
.revealed{opacity:1;transform:translateY(0)}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{box-shadow:0 6px 28px rgba(37,211,102,.45)}50%{box-shadow:0 6px 45px rgba(37,211,102,.7)}}

/* ── MOBILE MENU ── */
.mob-menu{
  display:none;position:fixed;inset:0;z-index:2000;
  background:var(--navy-dark);
  flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;
}
.mob-menu.open{display:flex}
.mob-menu a{
  font-size:1.3rem;font-weight:700;color:rgba(255,255,255,0.6);
  letter-spacing:0.04em;transition:color .2s;
}
.mob-menu a:hover{color:var(--white)}
.mob-close{
  position:absolute;top:1.5rem;right:2rem;
  background:none;border:none;color:var(--white);
  font-size:1.5rem;cursor:pointer;
}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .topbar{padding:.5rem 2rem}
  nav{padding:0 2rem}
  .hero{grid-template-columns:1fr;min-height:auto}
  /* foto arriba, texto abajo */
  .hero-right{order:-1;height:340px;min-height:340px}
  .hero-right::before{inset:0.85rem}
  .hero-photo{height:340px}
  .hero-badge{bottom:1.25rem;left:1.25rem;right:1.25rem;max-width:none;padding:.85rem 1rem}
  .hero-badge-title{font-size:.7rem}
  .hero-badge-sub{font-size:.56rem}
  .hero-left{padding:3rem 2rem 4rem}
  .services-strip{padding:0 2rem}
  .section{padding:4rem 2rem}
  .services-header{grid-template-columns:1fr}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr}
  .about-photo-col{padding:3rem 2rem}
  .about-content{padding:3rem 2rem}
  .diferencial-grid{grid-template-columns:1fr}
  .dif-left{padding:4rem 2rem 2rem}
  .dif-right{padding:2rem 2rem 4rem}
  .proceso-grid{grid-template-columns:1fr 1fr}
  .proceso-wrap{grid-template-columns:1fr}
  .proceso-image-col{min-height:0;height:320px;aspect-ratio:auto}
  .proceso-image-col img{height:100%;width:100%;object-fit:cover}
  .seo-grid{grid-template-columns:1fr}
  .seo-aside{position:static}
  .blog-grid{grid-template-columns:1fr}
  .cta-band{grid-template-columns:1fr;padding:3rem 2rem;gap:2rem}
  .contact-grid{grid-template-columns:1fr}
  .contact-info-col{padding:3rem 2rem}
  .contact-form-col{padding:3rem 2rem}
  .footer-main{grid-template-columns:1fr 1fr;gap:2rem;padding:3rem 2rem}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:640px){
  /* topbar — ocultamos info densa, dejamos solo tel + redes */
  .topbar{padding:.5rem 1.25rem}
  .topbar-left{gap:.85rem}
  .topbar-item:nth-child(2),
  .topbar-item:nth-child(3){display:none}
  .topbar-matricula{display:none}
  .topbar-right{gap:.5rem}
  /* nav */
  nav{padding:0 1.25rem;height:60px}
  .nav-logo-img{width:36px;height:36px}
  .nav-logo-title{font-size:.78rem}
  .nav-logo-sub{font-size:.54rem}
  /* hero — más compacto en mobile chico */
  .hero-left{padding:2.5rem 1.25rem 3rem}
  .hero-right{height:300px;min-height:300px}
  .hero-photo{height:300px}
  .hero-title{font-size:2rem;line-height:1.08}
  .hero-desc{font-size:.85rem;line-height:1.7;margin-bottom:1.75rem}
  .hero-actions{flex-direction:column;align-items:stretch;width:100%;gap:.75rem}
  .hero-actions .btn-white,
  .hero-actions .btn-ghost{justify-content:center;width:100%}
  .hero-free{font-size:.65rem}
  .hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem;padding-top:1.5rem}
  .hero-stat{padding:0 .6rem;border-left:1px solid rgba(255,255,255,0.09)}
  .hero-stat:first-child{padding-left:.6rem}
  .hero-stat-n{font-size:1.4rem}
  .hero-stat-l{font-size:.55rem;line-height:1.3;white-space:normal}
  /* secciones — menos aire vertical */
  .section{padding:3.5rem 1.25rem}
  /* services strip — chips más finos */
  .services-strip{padding:0 1.25rem}
  .strip-item{padding:1rem 1.25rem;font-size:.65rem}
  /* services grid 1 col */
  .services-grid{grid-template-columns:1fr}
  .srv-card{padding:1.75rem 1.5rem}
  /* proceso 1 col */
  .proceso-grid{grid-template-columns:1fr}
  .proceso-step{padding:2rem 1.5rem}
  .paso-n{font-size:2.4rem;margin-bottom:.75rem}
  /* about */
  .about-photo-col{padding:2.5rem 1.25rem}
  .about-content{padding:2.5rem 1.25rem}
  /* SEO */
  .seo-text h3{font-size:.95rem}
  .seo-text p{font-size:.8rem}
  /* blog */
  .blog-card{padding:1.75rem 1.5rem}
  .blog-num{font-size:2rem}
  /* FAQ */
  .faq-q{font-size:.93rem;padding:1.1rem 0}
  .faq-a{font-size:.9rem}
  /* CTA band — botones full width centrados */
  .cta-band{padding:2.5rem 1.25rem;gap:1.5rem}
  .cta-actions{width:100%;align-items:stretch}
  .cta-actions .btn-white,
  .cta-actions .btn-ghost{justify-content:center;width:100%;white-space:normal}
  .cta-title{font-size:1.5rem}
  .cta-sub{font-size:.8rem}
  /* footer */
  .footer-main{grid-template-columns:1fr;padding:2.5rem 1.25rem;gap:2rem}
  .footer-bottom{padding:1.25rem;flex-direction:column;align-items:flex-start;gap:.75rem}
  /* WA float — más compacto */
  .wa-float{bottom:1rem;right:1rem;padding:.7rem .9rem;gap:.5rem}
  .wa-float-sub{display:none}
  .wa-float-text{font-size:.65rem}
  /* page header (sub-páginas) */
  .page-header{padding:3rem 1.25rem 2.5rem}
  /* calculadora */
  .calc-card{padding:1.75rem 1.25rem}
  .calc-total{padding:1rem 1.25rem;flex-direction:column;align-items:flex-start;gap:.5rem}
  .calc-total-amount{font-size:1.4rem}
  /* contact */
  .contact-info-col{padding:2.5rem 1.25rem}
  .contact-form-col{padding:2.5rem 1.25rem}
}

/* =============================================================
   Extensiones multi-page (no modifican el diseño del original;
   añaden estados, foto real de Sobre mí, headers de páginas internas
   y bloques específicos para servicios.html / como-reclamar.html).
   ============================================================= */

/* Estado activo de navegación (página actual) */
.nav-links a.is-active{color:var(--white)}
.nav-links a.is-active::after{transform:scaleX(1)}

/* Logo: el .png trae fondo navy, sin padding extra para que recorte limpio en 42px */
.nav-logo-img{background:var(--navy)}

/* Foto real (Sobre mí) reemplaza al placeholder SVG */
.about-portrait img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(15%) brightness(0.95) contrast(1.05);
}

/* Page header — eyebrow + H1 + lede en sub-páginas */
.page-header{
  background:var(--navy-dark);color:var(--white);
  padding:5rem 5rem 4rem;position:relative;overflow:hidden;
}
.page-header::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);
  background-size:50px 50px;
  pointer-events:none;
}
.page-header > *{position:relative;z-index:1}
.page-header .tag .tag-line{background:rgba(255,255,255,0.4)}
.page-header .tag .tag-text{color:rgba(255,255,255,0.55)}
.page-header h1{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(2.2rem,4vw,3.4rem);
  font-weight:800;color:var(--white);line-height:1.08;
  letter-spacing:-0.015em;margin-top:0.5rem;
}
.page-header .lede{
  font-size:0.95rem;line-height:1.85;color:rgba(255,255,255,0.55);
  max-width:680px;margin-top:1.5rem;
}
@media(max-width:1024px){.page-header{padding:4rem 2rem 3rem}}

/* Bloque de servicio detallado (servicios.html) */
.service-detail{
  display:grid;grid-template-columns:80px 1fr;gap:2rem;
  padding:3rem 0;border-top:1px solid var(--gray-light);
}
.service-detail:first-of-type{border-top:none;padding-top:1rem}
.service-detail-num{
  font-size:0.65rem;font-weight:700;letter-spacing:0.18em;
  color:var(--gray);
}
.service-detail h2{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(1.5rem,2.4vw,1.95rem);
  font-weight:800;color:var(--navy);
  margin-bottom:1.25rem;letter-spacing:-0.01em;line-height:1.2;
}
.service-detail p{
  font-size:0.85rem;line-height:1.85;color:var(--text);
  margin-bottom:0.85rem;
}
.service-detail .srv-cta{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:var(--navy);color:var(--white);
  padding:0.85rem 1.4rem;margin-top:0.75rem;
  font-size:0.7rem;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;transition:background .25s;
}
.service-detail .srv-cta:hover{background:var(--navy-light)}
@media(max-width:1024px){
  .service-detail{grid-template-columns:1fr;gap:0.5rem}
}

/* Lista de pasos extendida (como-reclamar.html) */
.steps-list{display:flex;flex-direction:column;gap:0;margin:3rem 0}
.step-block{
  display:grid;grid-template-columns:90px 1fr;gap:2rem;
  padding:2.25rem 0;border-top:1px solid var(--gray-light);
  align-items:start;
}
.step-block:last-of-type{border-bottom:1px solid var(--gray-light)}
.step-block .step-n{
  font-size:2.6rem;font-weight:900;color:var(--navy);line-height:1;
}
.step-block h2{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(1.3rem,2.1vw,1.7rem);
  font-weight:800;color:var(--navy);
  margin-bottom:0.85rem;letter-spacing:-0.01em;line-height:1.25;
}
.step-block p{font-size:0.85rem;line-height:1.85;color:var(--text)}
@media(max-width:1024px){
  .step-block{grid-template-columns:1fr;gap:0.6rem;padding:2rem 0}
  .step-block .step-n{font-size:2rem}
}

/* Lista con check (servicios / como-reclamar) */
.check-list{list-style:none;display:flex;flex-direction:column;gap:0.5rem;margin:1rem 0}
.check-list li{
  font-size:0.8rem;color:var(--text);padding-left:1.4rem;position:relative;line-height:1.65;
}
.check-list li::before{
  content:'';position:absolute;left:0;top:0.55rem;
  width:8px;height:8px;background:var(--navy);
}

/* Tarjetas Blog: extender el grid del original a múltiples filas */
.blog-grid.blog-grid-multi{grid-template-columns:repeat(3,1fr);gap:1px}
@media(max-width:1024px){.blog-grid.blog-grid-multi{grid-template-columns:1fr}}

/* Banner "consulta gratuita" en columna de contacto */
.contact-free-banner{
  display:flex;align-items:center;gap:0.85rem;
  padding:1rem 1.25rem;margin-top:1.75rem;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.1);
}
.contact-free-banner-dot{
  width:8px;height:8px;background:var(--white);border-radius:50%;flex-shrink:0;
  box-shadow:0 0 0 4px rgba(255,255,255,0.12);
  animation:pulseDot 2.4s ease-in-out infinite;
}
.contact-free-banner-text{font-size:0.78rem;font-weight:700;color:var(--white);letter-spacing:0.02em}
.contact-free-banner-sub{font-size:0.62rem;font-weight:500;color:rgba(255,255,255,0.5);letter-spacing:0.05em;margin-top:0.15rem}

/* =============================================================
   Iteración 2 — extensiones adicionales
   ============================================================= */

/* Badge / about-portrait con LOGO img (reemplaza la letra P) */
.hero-badge-mark{padding:0;overflow:hidden;background:var(--navy)}
.hero-badge-mark img{width:100%;height:100%;display:block;object-fit:contain;padding:4px}
.about-portrait .badge-logo{
  position:absolute;top:1rem;left:1rem;z-index:2;
  width:48px;height:48px;background:var(--navy);
  border:1px solid rgba(255,255,255,0.18);
  display:flex;align-items:center;justify-content:center;
}
.about-portrait .badge-logo img{width:100%;height:100%;object-fit:contain;padding:6px}

/* Wordmark en footer (oculto en mobile) */
.footer-wordmark{
  display:block;margin-top:1rem;
  height:34px;width:auto;max-width:240px;
  opacity:0.78;transition:opacity .2s;
}
.footer-wordmark:hover{opacity:1}
@media(max-width:1024px){.footer-wordmark{display:none}}

/* Footer ahora con 5 columnas (brand + 4 listas, una de zonas) */
@media(min-width:1025px){
  .footer-main{grid-template-columns:2fr 1fr 1fr 1fr 1fr}
}

/* Hero interno (páginas geo / página header full) — se queda con page-header existente */

/* CALCULADORA */
.calc-wrap{max-width:880px;margin:0 auto;padding:3rem 0}
.calc-card{
  background:var(--white);border:1px solid var(--gray-light);
  padding:2.5rem;
}
.calc-card h2{
  font-family:'Montserrat',sans-serif;font-size:1.1rem;
  font-weight:800;color:var(--navy);margin-bottom:1.25rem;
  letter-spacing:-0.01em;text-transform:uppercase;letter-spacing:0.05em;
  font-size:0.78rem;
}
.calc-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;
  margin-bottom:1.5rem;
}
@media(max-width:768px){.calc-grid{grid-template-columns:1fr}}
.calc-error{
  display:none;background:#fdecec;color:#931515;border:1px solid #f5c2c2;
  padding:0.75rem 1rem;font-size:0.78rem;margin-bottom:1rem;line-height:1.55;
}
.calc-error.show{display:block}
.calc-warn{
  display:none;background:#fff7e6;color:#7a5b13;border:1px solid #f0d28a;
  padding:0.75rem 1rem;font-size:0.78rem;margin-bottom:1rem;line-height:1.55;
}
.calc-warn.show{display:block}
.calc-results{
  margin-top:2rem;padding-top:2rem;border-top:1px solid var(--gray-light);
  display:none;
}
.calc-results.show{display:block}
.calc-line{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:1rem;padding:0.85rem 0;border-bottom:1px solid var(--gray-light);
}
.calc-line:last-of-type{border-bottom:none}
.calc-line-label{font-size:0.82rem;font-weight:600;color:var(--navy);max-width:60%}
.calc-line-sub{font-size:0.7rem;font-weight:400;color:var(--gray);margin-top:0.2rem;line-height:1.5}
.calc-line-amount{font-size:0.95rem;font-weight:700;color:var(--navy);text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
.calc-total{
  margin-top:1rem;padding:1.25rem 1.5rem;
  background:var(--navy);color:var(--white);
  display:flex;justify-content:space-between;align-items:center;
}
.calc-total-label{font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em}
.calc-total-amount{font-size:1.6rem;font-weight:800;font-variant-numeric:tabular-nums}
.calc-disclaimer{
  font-size:0.72rem;color:var(--gray);line-height:1.7;
  margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--gray-light);
}
.calc-disclaimer strong{color:var(--navy)}

/* ARTÍCULOS DE BLOG (/blog/*.html) */
.article{
  display:grid;grid-template-columns:1fr 280px;gap:3rem;
  max-width:1100px;margin:0 auto;padding:3rem 2rem 5rem;
}
@media(max-width:1024px){
  .article{grid-template-columns:1fr;padding:2rem 1.5rem 3rem}
}
.article-body{font-size:0.92rem;line-height:1.85;color:var(--text)}
.article-body p{margin-bottom:1rem}
.article-body h2{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(1.35rem,2.2vw,1.7rem);
  font-weight:800;color:var(--navy);
  margin:2.25rem 0 0.85rem;letter-spacing:-0.01em;line-height:1.2;
}
.article-body h2:first-child{margin-top:0}
.article-body h3{
  font-family:'Montserrat',sans-serif;
  font-size:1rem;font-weight:700;color:var(--navy);
  margin:1.5rem 0 0.5rem;
}
.article-body ul, .article-body ol{
  margin:0.5rem 0 1rem 1.5rem;display:flex;flex-direction:column;gap:0.4rem;
}
.article-body ul li{font-size:0.88rem;line-height:1.7;color:var(--text)}
.article-body strong{color:var(--navy);font-weight:700}
.article-body a{color:var(--navy);text-decoration:underline;text-underline-offset:3px}
.article-body a:hover{color:var(--navy-light)}
.article-meta{
  display:flex;flex-wrap:wrap;gap:1rem;align-items:center;
  font-size:0.7rem;color:var(--gray);
  padding-bottom:1.25rem;margin-bottom:2rem;
  border-bottom:1px solid var(--gray-light);
  letter-spacing:0.05em;text-transform:uppercase;font-weight:600;
}
.article-meta .article-tag{
  background:var(--off-white);padding:0.3rem 0.6rem;color:var(--navy);
}
.article-h1{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(1.7rem,3.2vw,2.4rem);
  font-weight:800;color:var(--navy);
  line-height:1.15;letter-spacing:-0.015em;
  margin-bottom:1.25rem;
}
.article-lede{
  font-size:1rem;font-weight:300;color:var(--gray);
  line-height:1.7;margin-bottom:1.5rem;
}
.article-cta-block{
  margin-top:2.5rem;padding:1.75rem;background:var(--off-white);
  border-left:4px solid var(--navy);
}
.article-cta-block h3{margin-top:0;font-size:1rem;font-weight:700}
.article-cta-block p{font-size:0.85rem;line-height:1.7;color:var(--text);margin-bottom:1rem}
.article-cta-block .btn-row{display:flex;flex-wrap:wrap;gap:0.6rem}

/* Sidebar de artículo */
.article-aside{position:sticky;top:100px;height:max-content}
.article-aside-block{
  background:var(--navy);padding:1.75rem;color:var(--white);
}
.article-aside-block h4{
  font-size:0.65rem;font-weight:700;letter-spacing:0.15em;
  text-transform:uppercase;color:rgba(255,255,255,0.55);
  margin-bottom:1rem;
}
.article-aside-block .btn-white{
  width:100%;justify-content:center;font-size:0.7rem;
  padding:0.85rem 1rem;
}
.article-related{
  margin-top:2rem;padding:1.5rem;border:1px solid var(--gray-line);
}
.article-related h4{
  font-size:0.6rem;font-weight:700;letter-spacing:0.15em;
  text-transform:uppercase;color:var(--gray);margin-bottom:1rem;
}
.article-related ul{list-style:none;display:flex;flex-direction:column;gap:0.65rem}
.article-related a{
  font-size:0.78rem;color:var(--navy);font-weight:600;line-height:1.45;
  display:block;padding-bottom:0.65rem;border-bottom:1px solid var(--gray-light);
}
.article-related li:last-child a{border-bottom:none;padding-bottom:0}
.article-related a:hover{color:var(--navy-light)}

/* Página geo (zona específica) */
.geo-features{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--gray-light);margin-top:2rem;
}
@media(max-width:768px){.geo-features{grid-template-columns:1fr}}
.geo-feature{background:var(--white);padding:1.75rem 1.5rem}
.geo-feature h3{
  font-size:0.85rem;font-weight:700;color:var(--navy);
  margin-bottom:0.6rem;letter-spacing:0.01em;
}
.geo-feature p{font-size:0.8rem;line-height:1.7;color:var(--text)}

/* Imagen heroica en como-reclamar */
.hero-image-banner{
  position:relative;width:100%;height:380px;overflow:hidden;
  background:var(--navy);
}
.hero-image-banner img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(20%) brightness(0.85) contrast(1.05);
}
.hero-image-banner-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(28,27,53,0.45) 0%,rgba(28,27,53,0.7) 100%);
  display:flex;align-items:flex-end;padding:3rem;
}
.hero-image-banner-quote{
  font-size:1.05rem;font-weight:300;font-style:italic;color:var(--white);
  max-width:560px;line-height:1.55;
}
@media(max-width:768px){
  .hero-image-banner{height:260px}
  .hero-image-banner-overlay{padding:1.5rem}
  .hero-image-banner-quote{font-size:0.9rem}
}

/* Variante "loose" — menos zoom, deja ver mas del documento (servicios) */
.hero-image-banner-loose{height:320px}
.hero-image-banner-loose img{
  object-fit:cover;object-position:center 70%;
  filter:grayscale(10%) brightness(0.9) contrast(1.0);
}
@media(max-width:768px){
  .hero-image-banner-loose{height:240px}
  .hero-image-banner-loose img{object-position:center 60%}
}

/* Page header split — texto + imagen vertical al costado (FAQ) */
.page-header-split{
  display:grid;grid-template-columns:1fr 420px;gap:3rem;
  align-items:center;
  padding:4rem 5rem;
}
.page-header-split > *{position:relative;z-index:1}
.page-header-split .page-header-text{max-width:580px}
.page-header-figure{
  margin:0;overflow:hidden;position:relative;
  background:var(--navy);
  aspect-ratio:3/4;
}
.page-header-figure img{
  width:100%;height:100%;display:block;object-fit:cover;
  /* Filtro estilo hero: blanqueado, oscurecido, sin saturar */
  filter:grayscale(40%) brightness(0.68) contrast(1.0) saturate(0.85);
}
.page-header-figure::after{
  /* Doble gradient para fundirse con el fondo navy: izquierda + bottom */
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(90deg,rgba(28,27,53,0.55) 0%,rgba(28,27,53,0) 35%),
    linear-gradient(0deg,rgba(28,27,53,0.5) 0%,rgba(28,27,53,0) 55%);
}
@media(max-width:1024px){
  .page-header-split{grid-template-columns:1fr;gap:2rem;padding:3rem 2rem}
  .page-header-figure{aspect-ratio:16/9;max-width:560px;margin:0 auto}
  .page-header-figure::after{
    background:linear-gradient(0deg,rgba(28,27,53,0.55) 0%,rgba(28,27,53,0) 55%);
  }
}
@media(max-width:640px){
  .page-header-split{padding:2.5rem 1.25rem}
  .page-header-figure{aspect-ratio:4/3}
}

/* =============================================================
   Iteración 4 — estados del formulario de contacto (envío email)
   ============================================================= */
.form-status{
  display:none;font-size:0.78rem;line-height:1.55;
  padding:0.75rem 1rem;margin:1rem 0;
}
.form-status.form-status-error{
  display:block;background:#fdecec;color:#931515;
  border:1px solid #f5c2c2;
}
.form-success{
  text-align:center;padding:2.5rem 1.5rem;
  background:var(--off-white);border:1px solid var(--gray-light);
}
.form-success-icon{
  width:54px;height:54px;border-radius:50%;
  background:#25D366;color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:1.7rem;font-weight:700;margin:0 auto 1rem;
  animation:fadeIn .4s ease;
}
.form-success h3{
  font-family:'Montserrat',sans-serif;font-size:1.2rem;font-weight:800;
  color:var(--navy);margin-bottom:0.6rem;letter-spacing:-0.01em;
}
.form-success p{
  font-size:0.85rem;line-height:1.7;color:var(--text);margin-bottom:0.5rem;
}
.form-success .btn-navy{display:inline-flex;width:auto}

/* Calculadora con imagen al costado (iter 4) — 50/50, imagen estirada vertical */
.calc-wrap{max-width:1240px}
.calc-grid-2col{
  display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;
  align-items:stretch;
}

/* Alinear inputs de la fila — labels que envuelven (2 lineas) no deben empujar el input */
.calc-grid .form-field{display:flex;flex-direction:column;margin-bottom:0}
.calc-grid .form-field label{flex:0 0 auto}
.calc-grid .form-field input,
.calc-grid .form-field select{margin-top:auto}
.calc-aside{display:flex;flex-direction:column}
.calc-aside-figure{
  margin:0;overflow:hidden;
  background:var(--navy);
  height:100%;min-height:480px;
}
.calc-aside-figure img{
  width:100%;height:100%;display:block;object-fit:cover;
  filter:grayscale(15%) brightness(0.95) contrast(1.05);
}
@media(max-width:1024px){
  .calc-grid-2col{grid-template-columns:1fr;gap:2rem}
  .calc-aside-figure{height:auto;min-height:0;aspect-ratio:16/9;max-width:680px;margin:0 auto}
}
@media(max-width:640px){
  .calc-aside-figure{aspect-ratio:4/3}
}

/* =============================================================
   Iteración 4 — agregados visuales y estructurales
   ============================================================= */

/* srv-card como link (toda la card clickeable) */
a.srv-card{text-decoration:none;color:inherit;display:block}

/* SVGs de services-grid más prominentes */
.srv-icon svg{transition:.3s;opacity:1}

/* Blog num más prominente en home */
.blog-grid .blog-num--strong{color:var(--gray)}

/* ============= STICKY CTA BAR MOBILE ============= */
.mobile-cta-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  height:56px;
  background:var(--navy);
  border-top:1px solid rgba(255,255,255,0.08);
  z-index:999;
  box-shadow:0 -4px 20px rgba(0,0,0,0.25);
}
.mobile-cta-item{
  flex:1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:0.2rem;
  color:rgba(255,255,255,0.85);
  font-size:0.62rem;font-weight:600;letter-spacing:0.05em;
  text-transform:uppercase;
  border-right:1px solid rgba(255,255,255,0.06);
  transition:background .2s;
  text-decoration:none;
}
.mobile-cta-item:last-child{border-right:none}
.mobile-cta-item:hover, .mobile-cta-item:active{
  background:rgba(255,255,255,0.05);color:var(--white);
}
.mobile-cta-wa{background:#25D366;color:#fff}
.mobile-cta-wa:hover, .mobile-cta-wa:active{background:#20bf5b;color:#fff}
@media(max-width:640px){
  .mobile-cta-bar{display:flex}
  body{padding-bottom:56px}
  .wa-float{display:none}
}

/* ============= PÁGINAS GEO ============= */
.geo-content{max-width:880px}
.geo-content > p,
.geo-content article > p{
  font-size:0.92rem;line-height:1.85;color:var(--text);
  margin-bottom:1rem;
}
.geo-content h2{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(1.4rem,2.4vw,1.9rem);
  font-weight:800;color:var(--navy);
  margin:2.5rem 0 1rem;
  letter-spacing:-0.01em;line-height:1.2;
}
.geo-content h2:first-of-type{margin-top:1.5rem}
.geo-content a{
  color:var(--navy);font-weight:700;
  border-bottom:1px solid var(--navy);
}
.geo-content a:hover{opacity:0.7}
/* Pin SVG dentro de h3 de geo-feature */
.geo-feature h3{
  display:flex;align-items:center;gap:0.5rem;
}
.geo-feature h3 svg{
  width:14px;height:14px;flex-shrink:0;
  color:var(--navy);opacity:0.75;
}
/* geo-image */
.geo-image{
  width:100%;
  margin:2rem 0;
  position:relative;overflow:hidden;
  background:var(--navy-dark);
  border:1px solid var(--gray-light);
  aspect-ratio:16/9;
}
.geo-image img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(15%) brightness(0.92) contrast(1.03);
}
.geo-image-placeholder{
  width:100%;height:100%;
  background-color:var(--navy);
  background-image:
    linear-gradient(60deg, var(--navy-line) 1px, transparent 1px),
    linear-gradient(-60deg, var(--navy-line) 1px, transparent 1px),
    linear-gradient(0deg, var(--navy-line) 1px, transparent 1px);
  background-size:32px 56px,32px 56px,32px 56px;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.35);
  font-size:0.7rem;font-weight:600;letter-spacing:0.15em;
  text-transform:uppercase;text-align:center;padding:1rem;
}
.geo-image-caption{
  font-size:0.7rem!important;color:var(--gray);
  margin-top:-1rem!important;margin-bottom:1.5rem!important;
  font-style:italic;
}
@media(max-width:700px){
  .geo-features{grid-template-columns:1fr}
}

/* ============= STAGGER ANIMACIONES ============= */
.services-grid.reveal .srv-card,
.blog-grid.reveal .blog-card{
  opacity:0;transform:translateY(20px);
  transition:opacity .6s ease,transform .6s ease;
}
.services-grid.reveal.revealed .srv-card,
.blog-grid.reveal.revealed .blog-card{
  opacity:1;transform:translateY(0);
}
.services-grid.reveal.revealed .srv-card:nth-child(1){transition-delay:0.05s}
.services-grid.reveal.revealed .srv-card:nth-child(2){transition-delay:0.15s}
.services-grid.reveal.revealed .srv-card:nth-child(3){transition-delay:0.25s}
.services-grid.reveal.revealed .srv-card:nth-child(4){transition-delay:0.35s}
.services-grid.reveal.revealed .srv-card:nth-child(5){transition-delay:0.45s}
.services-grid.reveal.revealed .srv-card:nth-child(6){transition-delay:0.55s}
.blog-grid.reveal.revealed .blog-card:nth-child(1){transition-delay:0.1s}
.blog-grid.reveal.revealed .blog-card:nth-child(2){transition-delay:0.25s}
.blog-grid.reveal.revealed .blog-card:nth-child(3){transition-delay:0.4s}

/* Parallax: que el transform del JS no rompa otros estilos */
.hero-photo{will-change:transform}

/* ============= CALC HELPER (calculadora) ============= */
.calc-helper{
  display:flex;align-items:flex-start;gap:0.5rem;
  margin-top:0.5rem;margin-bottom:1.25rem;
  padding:0.7rem 0.85rem;
  background:rgba(28,27,53,0.04);
  border-left:2px solid var(--navy);
  font-size:0.72rem;line-height:1.55;color:var(--text);
}
.calc-helper svg{
  flex-shrink:0;color:var(--navy);margin-top:2px;
}
.calc-helper strong{color:var(--navy);font-weight:700}
