/* ============================================================
   FONTS (self-hosted)
   ============================================================ */
@font-face{font-family:"General Sans";font-style:normal;font-weight:400;font-display:swap;src:url("../assets/fonts/GeneralSans-Regular.woff2") format("woff2");}
@font-face{font-family:"General Sans";font-style:normal;font-weight:500;font-display:swap;src:url("../assets/fonts/GeneralSans-Medium.woff2") format("woff2");}
@font-face{font-family:"General Sans";font-style:normal;font-weight:600;font-display:swap;src:url("../assets/fonts/GeneralSans-Semibold.ttf") format("truetype-variations");}
@font-face{font-family:"General Sans";font-style:normal;font-weight:700;font-display:swap;src:url("../assets/fonts/GeneralSans-Bold.woff2") format("woff2");}
@font-face{font-family:"Lato";font-style:normal;font-weight:400;font-display:swap;src:url("../assets/fonts/Lato-Regular.ttf") format("truetype");}
@font-face{font-family:"Lato";font-style:normal;font-weight:700;font-display:swap;src:url("../assets/fonts/Lato-Bold.ttf") format("truetype");}

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root{
  --navy-900:#092F70; --navy-700:#334C84; --navy-600:#115AD6;
  --navy-hero:#0A2A66; --navy-card:#12356F; --navy-step:#3C5485;
  --orange-500:#FC905F; --coral-500:#FF6450;
  --white:#fff; --surface:#E6EAF0; --gray-500:#6F7779; --ink:#111418;
  --font-display:"General Sans",system-ui,sans-serif;
  --font-body:"Lato",system-ui,sans-serif;
  --shadow-card:0 8px 24px rgba(9,47,112,.10);
  --shadow-pop:0 16px 40px rgba(9,47,112,.16);
  --gutter:80px;
  --maxw:1440px;
  /* Padding lateral que mantiene el contenido centrado a --maxw pero deja
     el fondo de cada sección a todo el ancho (evita bordes blancos en desktop). */
  --pad-x:max(var(--gutter), calc((100% - var(--maxw)) / 2 + var(--gutter)));
}

/* ============================================================
   RESET
   ============================================================ */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--white);font-family:var(--font-body);color:var(--navy-900);-webkit-font-smoothing:antialiased;}
img{max-width:100%;display:block;}
a{text-decoration:none;}
.shell{position:relative;overflow:hidden;}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:9px;height:42px;padding:0 24px;border-radius:100px;
  font-family:var(--font-display);font-weight:500;font-size:15px;cursor:pointer;border:none;
  transition:transform .18s ease,background .2s ease,box-shadow .2s ease,color .2s ease;white-space:nowrap;}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-pop);}
.btn:active{transform:translateY(0) scale(.98);}
.btn--dark{background:#111;color:#fff;}
.btn--dark:hover{background:#000;}
.btn--light{background:#fff;color:var(--ink);box-shadow:var(--shadow-card);}
.btn--light:hover{background:#111;color:#fff;}
.btn--ghost{background:transparent;color:#fff;border:1.5px solid #fff;}
.btn--ghost:hover{background:#fff;color:var(--navy-900);}
.btn__dot{width:7px;height:7px;border-radius:50%;background:var(--orange-500);}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;background:var(--surface);padding-bottom:0;}
.hero__inner{position:relative;padding:0 var(--pad-x);}
.hero__notch{position:absolute;bottom:0;right:0;width:6%;height:30px;background:#fff;
  clip-path:polygon(100% 0,100% 100%,0 100%);pointer-events:none;}

.topbar{position:relative;z-index:5;display:flex;align-items:center;justify-content:space-between;
  padding-top:64px;gap:24px;}
.logo{display:inline-flex;align-items:center;font-family:var(--font-display);font-weight:700;
  font-size:46px;letter-spacing:1px;line-height:1;color:var(--navy-900);}

.nav-pill{display:flex;align-items:center;gap:34px;border-radius:20px;padding:18px 34px;
  border:2px solid transparent;
  background:linear-gradient(var(--navy-hero),var(--navy-hero)) padding-box,
             linear-gradient(90deg,var(--navy-600),var(--orange-500)) border-box;
  box-shadow:0 8px 24px rgba(9,47,112,.14);}
.nav-pill a{font-family:var(--font-body);font-size:16px;color:#fff;opacity:.9;transition:opacity .15s ease;}
.nav-pill a:hover{opacity:1;}

.burger{display:none;width:44px;height:44px;border-radius:12px;border:1px solid rgba(9,47,112,.15);
  background:rgba(255,255,255,.6);align-items:center;justify-content:center;cursor:pointer;
  color:var(--navy-900);font-size:24px;flex:0 0 auto;
  transition:background .28s ease,color .28s ease,border-color .28s ease,
             transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .28s ease;}
.burger:hover{box-shadow:0 6px 18px rgba(9,47,112,.18);}
/* Al abrir: la manija toma el degradé azul->coral de la marca y rota */
.burger[aria-expanded="true"]{color:#fff;border-color:transparent;transform:rotate(90deg);
  background:linear-gradient(135deg,var(--navy-600),var(--coral-500));
  box-shadow:0 8px 22px rgba(255,100,80,.35);}
.burger i{transition:transform .4s cubic-bezier(.34,1.56,.64,1);}
.burger[aria-expanded="true"] i{transform:scale(1.06);}

/* Menú mobile: overlay tipo "glass" (iOS) que FLOTA sobre la página, no la empuja */
.mobile-nav{position:absolute;left:var(--gutter);right:var(--gutter);margin-top:12px;z-index:40;
  max-height:0;opacity:0;visibility:hidden;overflow:hidden;
  border-radius:18px;border:1px solid rgba(255,255,255,.6);
  background:rgba(255,255,255,.5);
  -webkit-backdrop-filter:blur(18px) saturate(170%);
  backdrop-filter:blur(18px) saturate(170%);
  box-shadow:0 20px 44px rgba(9,47,112,.26);transform:translateY(-10px);
  transition:max-height .38s cubic-bezier(.4,0,.2,1),opacity .3s ease,
             transform .38s cubic-bezier(.4,0,.2,1),visibility .38s;}
.mobile-nav.open{max-height:420px;opacity:1;visibility:visible;transform:translateY(0);}
.mobile-nav a{display:block;font-family:var(--font-body);font-size:17px;color:var(--navy-900);
  padding:15px 22px;border-bottom:1px solid rgba(9,47,112,.08);
  opacity:0;transform:translateX(-14px);
  transition:opacity .32s ease,transform .32s ease,background .2s ease,color .2s ease;}
.mobile-nav a:last-child{border-bottom:none;}
.mobile-nav a:hover{background:rgba(17,90,214,.06);color:var(--navy-600);}
/* Aparición escalonada de cada link al abrir */
.mobile-nav.open a{opacity:1;transform:translateX(0);}
.mobile-nav.open a:nth-child(1){transition-delay:.10s;}
.mobile-nav.open a:nth-child(2){transition-delay:.16s;}
.mobile-nav.open a:nth-child(3){transition-delay:.22s;}
.mobile-nav.open a:nth-child(4){transition-delay:.28s;}

.hero__grid{position:relative;display:grid;grid-template-columns:0.92fr 1.15fr;gap:44px;
  align-items:stretch;padding-top:56px;}
.hero__art{width:82%;height:auto;align-self:end;margin:0 auto;filter:drop-shadow(0 24px 34px rgba(9,47,112,.16));}
.hero__title{margin:0 0 20px;font-family:var(--font-display);font-weight:400;font-size:46px;
  line-height:56px;letter-spacing:1px;color:var(--ink);max-width:600px;}
.hero__title b{font-weight:600;background:linear-gradient(90deg,var(--navy-600),var(--orange-500));
  -webkit-background-clip:text;background-clip:text;color:transparent;}
.hero__p{margin:0 0 12px;font-family:var(--font-body);font-size:15px;line-height:22px;color:#1A1D21;max-width:540px;}
.hero__p--cta{font-weight:700;color:var(--navy-900);margin-bottom:24px;}

/* ============================================================
   WHY CHOOSE
   ============================================================ */
.why{position:relative;padding:96px var(--pad-x) 0;}
.why__watermark{position:absolute;left:50%;top:40px;transform:translateX(-50%);
  font-family:var(--font-display);font-weight:700;font-size:120px;color:rgba(51,76,132,.12);
  pointer-events:none;letter-spacing:-4px;z-index:0;}
.why__title{text-align:center;font-family:var(--font-display);font-weight:600;font-size:24px;
  letter-spacing:1.5px;color:var(--ink);position:relative;z-index:1;}
.why__title b{font-weight:700;}
.why__row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;position:relative;z-index:1;}
.why__card{border-radius:24px;padding:40px;display:flex;flex-direction:column;gap:24px;min-height:300px;color:#fff;}
.why__card i{font-size:38px;}
.why__card h3{margin:0;font-family:var(--font-display);font-weight:700;font-size:26px;letter-spacing:.3px;}
.why__card p{margin:0;font-family:var(--font-body);font-size:16px;line-height:24px;opacity:.95;}
.why__card--navy{background:var(--navy-hero);}
.why__card--gray{background:#8B96AE;}
.why__card--coral{background:#F4614C;}

/* ============================================================
   SERVICES (navy band)
   ============================================================ */
.services{background:var(--navy-900);color:#fff;padding:88px var(--pad-x);margin-top:64px;}
.services__title{margin:0 0 44px;font-family:var(--font-display);font-weight:400;font-size:32px;letter-spacing:.5px;}
.services__title b{font-weight:700;}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.svc-card{background:var(--navy-card);border-radius:22px;padding:32px;display:flex;flex-direction:column;gap:16px;
  transition:transform .2s ease,box-shadow .2s ease;}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 18px 38px rgba(0,0,0,.28);}
.svc-card__head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;}
.svc-card__head h4{margin:0;font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:.3px;line-height:1.2;}
.svc-chip{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:13px;
  background:var(--orange-500);flex:0 0 auto;}
.svc-chip i{font-size:22px;color:#fff;}
.svc-card p{margin:0;font-family:var(--font-body);font-size:15px;line-height:22px;opacity:.9;}
.svc-card__label{font-family:var(--font-body);font-weight:700;font-size:15px;margin-top:auto;padding-top:6px;}
.svc-pills{display:flex;gap:10px;flex-wrap:wrap;}
.svc-pills span{font-family:var(--font-body);font-size:13px;color:#fff;background:var(--navy-step);padding:8px 16px;border-radius:100px;}

/* steps */
.steps{background:var(--navy-step);border-radius:30px;padding:56px;margin-top:56px;}
.steps__title{margin:0 0 48px;text-align:center;font-family:var(--font-display);font-weight:400;font-size:32px;letter-spacing:.5px;color:#fff;}
.steps__title b{font-weight:700;}
.track{position:relative;display:flex;justify-content:space-between;align-items:flex-start;}
.track__line{position:absolute;left:11%;right:11%;top:28px;height:2px;background:rgba(255,255,255,.35);z-index:0;}
.step{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;padding:0 14px;}
.step__chip{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:15px;background:var(--orange-500);flex:0 0 auto;}
.step__chip i{font-size:26px;color:#fff;}
.step h5{margin:0;font-family:var(--font-display);font-weight:700;font-size:20px;color:#fff;letter-spacing:.3px;}
.step p{margin:0;font-family:var(--font-body);font-size:15px;line-height:21px;color:rgba(255,255,255,.78);}

/* ============================================================
   FAQ
   ============================================================ */
.faq{padding:88px var(--pad-x);background:#fff;}
.faq__panel{max-width:900px;margin:0 auto;}
.faq__title{margin:0 0 8px;text-align:center;font-family:var(--font-display);font-weight:700;font-size:32px;letter-spacing:1px;color:var(--navy-900);}
.faq__sub{margin:0 0 40px;text-align:center;font-family:var(--font-body);font-size:16px;line-height:22px;color:var(--gray-500);}
.faq__list{display:flex;flex-direction:column;gap:16px;}
.faq-item{background:#fff;border-radius:22px;box-shadow:var(--shadow-card);overflow:hidden;
  transition:box-shadow .2s ease;}
.faq-item:hover{box-shadow:0 12px 30px rgba(9,47,112,.13);}
.faq-item.open{box-shadow:0 14px 34px rgba(9,47,112,.15);}
.faq-item__q{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:24px 28px;cursor:pointer;
  list-style:none;font-family:var(--font-display);font-weight:500;font-size:18px;letter-spacing:.2px;color:var(--navy-900);}
.faq-item__q::-webkit-details-marker{display:none;}
.faq-chip{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;
  background:var(--surface);color:var(--navy-900);flex:0 0 auto;transition:background .22s ease,color .22s ease;}
.faq-chip i{transition:transform .24s ease;}
.faq-item.open .faq-chip{background:var(--orange-500);color:#fff;}
.faq-item.open .faq-chip i{transform:rotate(45deg);}
.faq-item__a{max-height:0;opacity:0;overflow:hidden;padding:0 28px;transition:max-height .28s ease,opacity .22s ease,padding .28s ease;}
.faq-item.open .faq-item__a{max-height:320px;opacity:1;padding:0 28px 26px;}
.faq-item__a p{margin:0;font-family:var(--font-body);font-size:15px;line-height:22px;color:var(--gray-500);}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{position:relative;background:var(--surface);padding:64px var(--pad-x) 72px;
  clip-path:polygon(0 30px,94% 30px,100% 0,100% 100%,0 100%);}
.footer__top{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;}
.footer__top h2{margin:0 0 8px;font-family:var(--font-display);font-weight:700;font-size:30px;letter-spacing:1px;color:var(--ink);line-height:1.2;}
.footer__top p{margin:0;font-family:var(--font-body);font-size:18px;line-height:24px;color:#42474D;}
.footer__logo{display:inline-flex;align-items:center;font-family:var(--font-display);font-weight:700;font-size:34px;letter-spacing:1px;line-height:1;color:var(--navy-900);}
.rrss{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:36px;}
.rrss-card{border-radius:30px;background:var(--navy-step);display:flex;flex-direction:column;align-items:center;gap:22px;padding:24px;
  transition:transform .2s ease,box-shadow .2s ease;}
.rrss-card:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgba(9,47,112,.22);}
.rrss-card__head{display:flex;align-items:center;gap:12px;align-self:stretch;}
.rrss-card__head i{font-size:34px;color:#fff;}
.rrss-card__head h4{margin:0;font-family:var(--font-display);font-weight:700;font-size:20px;color:#fff;letter-spacing:.5px;}
.rrss-card .btn{align-self:stretch;justify-content:center;height:46px;font-size:17px;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  :root{--gutter:48px;}
  .nav-pill{display:none;}
  .burger{display:inline-flex;}
  /* En mobile/tablet solo la manija: se oculta el botón Contacto */
  .topbar .btn--light{display:none;}
  .hero__grid{grid-template-columns:1fr;text-align:center;padding-top:36px;}
  .hero__art{max-width:360px;width:78%;order:-1;align-self:center;}
  .hero__title,.hero__p{margin-left:auto;margin-right:auto;}
  .why__row{grid-template-columns:1fr 1fr;}
  .svc-grid{grid-template-columns:1fr;}
}
@media(max-width:680px){
  :root{--gutter:22px;}
  .topbar{padding-top:32px;}
  .logo{font-size:38px;}
  /* En mobile la ilustración de la compu se oculta y el hero respira más */
  .hero__art{display:none;}
  .hero{padding-bottom:38px;}
  .hero__grid{padding-top:30px;}
  .hero__title{font-size:27px;line-height:34px;letter-spacing:.3px;margin-bottom:16px;}
  .hero__p{font-size:14px;line-height:20px;}
  .hero__p--cta{margin-bottom:22px;}
  .services{padding:56px var(--gutter);}
  .steps{padding:32px 22px;}
  .faq{padding:48px var(--gutter);}
  .faq__title{font-size:26px;}
  .footer{padding:56px var(--gutter) 64px;}
  .why{padding:64px var(--gutter) 0;}
  .why__row{grid-template-columns:1fr;}
  .why__watermark{font-size:84px;}
  /* Footer: 2x2 con cards chicas SOLO en mobile */
  .rrss{grid-template-columns:1fr 1fr;gap:14px;}
  .rrss-card{border-radius:18px;gap:14px;padding:18px;}
  .rrss-card__head{gap:10px;}
  .rrss-card__head i{font-size:24px;}
  .rrss-card__head h4{font-size:16px;letter-spacing:.4px;}
  .rrss-card .btn{height:40px;font-size:15px;}
  .track{flex-direction:column;gap:28px;}
  .track__line{display:none;}
  .step{align-items:flex-start;text-align:left;padding:0;}
  /* Footer: encabezado más chico en mobile para que el logo quede a la derecha */
  .footer__top{flex-direction:row;align-items:center;gap:14px;}
  .footer__top h2{font-size:20px;letter-spacing:.5px;margin-bottom:4px;}
  .footer__top p{font-size:13px;line-height:17px;}
}
@media(max-width:430px){
  .rrss{gap:10px;}
  .rrss-card{padding:16px;border-radius:16px;}
}

/* Respeta usuarios que prefieren menos movimiento */
@media(prefers-reduced-motion:reduce){
  .burger,.burger i,.mobile-nav,.mobile-nav a{transition:none;}
}
