/* ============================================================
   Gaastro — sistema de diseño compartido (todas las páginas)
   Coloca este archivo en la raíz del sitio (junto a index.html).
   ============================================================ */
@font-face{font-family:'Objektiv';src:url('fonts/ObjektivMk1_Trial_Lt.ttf') format('truetype');font-weight:300;font-display:swap}
@font-face{font-family:'Objektiv';src:url('fonts/ObjektivMk1_Trial_Rg.ttf') format('truetype');font-weight:400;font-display:swap}
@font-face{font-family:'Objektiv';src:url('fonts/ObjektivMk1_Trial_Md.ttf') format('truetype');font-weight:500;font-display:swap}
@font-face{font-family:'Objektiv';src:url('fonts/ObjektivMk1_Trial_Bd.ttf') format('truetype');font-weight:700;font-display:swap}
@font-face{font-family:'Objektiv';src:url('fonts/ObjektivMk1_Trial_XBd.ttf') format('truetype');font-weight:800;font-display:swap}
@font-face{font-family:'Objektiv';src:url('fonts/ObjektivMk1_Trial_Blk.ttf') format('truetype');font-weight:900;font-display:swap}

:root{
  --azul:#132BD6;
  --azul-osc:#0d1f9c;
  --amarillo:#F3CA40;
  --negro:#101114;
  --gris:#5b5e6b;
  --gris-cl:#eef0f5;
  --blanco:#ffffff;
  --radio:18px;
  --max:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Objektiv',system-ui,Arial,sans-serif;color:var(--negro);background:var(--blanco);line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
section{padding:90px 0}
h1,h2,h3{line-height:1.05;letter-spacing:-.02em;font-weight:900;text-transform:lowercase}
h2{font-size:clamp(2rem,4.5vw,3.2rem)}
.eyebrow{font-weight:800;text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;color:var(--azul)}
.lead{font-size:1.13rem;color:var(--gris);font-weight:400}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:inherit;font-weight:800;font-size:1rem;text-transform:lowercase;padding:15px 28px;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}
.btn:hover{transform:translateY(-2px)}
.btn-amarillo{background:var(--amarillo);color:var(--negro);box-shadow:0 8px 22px rgba(243,202,64,.35)}
.btn-azul{background:var(--azul);color:#fff}
.btn-line{background:transparent;border-color:currentColor}
.btn-line-blanco{background:transparent;border-color:rgba(255,255,255,.6);color:#fff}

/* Promo bar */
.promo{background:var(--negro);color:#fff;text-align:center;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:9px 16px}
.promo a{color:var(--amarillo)}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--gris-cl)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.nav .logo img{height:34px}
.nav ul{display:flex;gap:28px;list-style:none}
.nav ul a{font-weight:500;font-size:.97rem;text-transform:lowercase;color:var(--negro);transition:color .15s}
.nav ul a:hover{color:var(--azul)}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.burger span{width:24px;height:2.5px;background:var(--negro);border-radius:2px}

/* Hero */
.hero{background:var(--azul);color:#fff;position:relative;overflow:hidden;padding:96px 0 104px}
.hero.sm{padding:70px 0 78px}
.hero .mark-bg{position:absolute;right:-90px;top:50%;transform:translateY(-50%);width:560px;opacity:.10;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;position:relative;z-index:2}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);color:#fff}
.hero h1 .amar{color:var(--amarillo)}
.hero p{font-size:1.2rem;color:rgba(255,255,255,.9);margin:22px 0 32px;max-width:40ch;font-weight:400}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:var(--radio);padding:26px}
.hero-card h3{font-size:1.15rem;color:#fff;text-transform:none;margin-bottom:6px}
.hero-card p{font-size:.98rem;margin:0 0 14px}
.hero-stats{display:flex;gap:26px;margin-top:26px}
.hero-stats .n{font-size:1.7rem;font-weight:900;color:var(--amarillo)}
.hero-stats small{color:rgba(255,255,255,.75);font-size:.8rem;text-transform:uppercase;letter-spacing:.08em}

/* Routes */
.routes-head{text-align:center;max-width:680px;margin:0 auto 50px}
.routes{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.route{display:block;border:1.5px solid var(--gris-cl);border-radius:var(--radio);padding:26px 22px;transition:border-color .15s,transform .15s,box-shadow .15s;background:#fff}
.route:hover{border-color:var(--azul);transform:translateY(-4px);box-shadow:0 14px 30px rgba(19,43,214,.08)}
.route .tag{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--azul)}
.route h3{font-size:1.25rem;text-transform:lowercase;margin:14px 0 8px}
.route p{font-size:.95rem;color:var(--gris)}
.route .go{display:inline-block;margin-top:16px;font-weight:800;color:var(--azul)}

/* Qué es */
.que{background:var(--gris-cl)}
.que-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.que p{font-size:1.08rem;color:#2c2e38;margin-top:18px}
.que .mark{width:230px;margin:0 auto}

/* Tarjetas de producto */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.card{border:1.5px solid var(--gris-cl);border-radius:var(--radio);padding:30px;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(0,0,0,.07)}
.card .badge{align-self:flex-start;background:var(--amarillo);color:var(--negro);font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;padding:5px 11px;border-radius:999px;margin-bottom:14px}
.card h3{font-size:1.4rem;text-transform:lowercase}
.card .desc{color:var(--gris);font-size:.96rem;margin:10px 0 18px;flex:1}
.card .precio{font-size:1.7rem;font-weight:900;margin-bottom:16px}
.card .precio small{font-size:.85rem;font-weight:500;color:var(--gris)}
.center{text-align:center;margin-top:40px}

/* Academy band */
.academy{background:var(--negro);color:#fff}
.academy-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.academy h2{color:#fff}
.academy p{color:rgba(255,255,255,.82);margin:18px 0 28px;font-size:1.08rem}
.academy ul{list-style:none;display:grid;gap:10px;margin-bottom:28px}
.academy li{padding-left:28px;position:relative;color:rgba(255,255,255,.9)}
.academy li:before{content:"→";position:absolute;left:0;color:var(--amarillo);font-weight:800}
.academy-card{background:var(--azul);border-radius:var(--radio);padding:36px;text-align:center}
.academy-card .big{font-size:2.6rem;font-weight:900;color:var(--amarillo);text-transform:lowercase;line-height:1}

/* Servicios split */
.serv{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:46px}
.serv-box{border-radius:var(--radio);padding:38px;border:1.5px solid var(--gris-cl)}
.serv-box.aze{background:var(--gris-cl)}
.serv-box.con{background:var(--azul);color:#fff}
.serv-box h3{font-size:1.7rem;text-transform:lowercase;margin-bottom:6px}
.serv-box .k{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.14em;opacity:.7}
.serv-box p{margin:14px 0 22px;font-size:1.02rem}
.serv-box.con p{color:rgba(255,255,255,.88)}

/* Prueba social */
.social{background:var(--gris-cl)}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}
.quote{background:#fff;border-radius:var(--radio);padding:28px}
.quote p{font-style:italic;color:#2c2e38}
.quote .who{margin-top:16px;font-weight:800;font-size:.92rem}
.quote .who span{display:block;font-weight:500;color:var(--gris);font-style:normal;font-size:.85rem}
.ph{color:#b9bcca;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.72rem}

/* Alonso */
.alonso-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:46px;align-items:center}
.alonso .mark{width:200px}
.alonso p{color:#2c2e38;margin-top:14px}

/* Captura */
.cap{background:var(--azul);color:#fff;text-align:center}
.cap h2{color:#fff}
.cap p{color:rgba(255,255,255,.88);max-width:46ch;margin:16px auto 28px;font-size:1.08rem}
.form{display:flex;gap:10px;max-width:440px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.form input{flex:1;min-width:220px;padding:15px 18px;border-radius:999px;border:0;font-family:inherit;font-size:1rem}

/* ===== Componentes de páginas internas (asesoría, etc.) ===== */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
.feature{background:#fff;border:1.5px solid var(--gris-cl);border-radius:var(--radio);padding:22px}
.feature b{display:block;margin-bottom:4px;font-size:1.02rem}
.feature p{font-size:.92rem;color:var(--gris);margin:0}

.esquemas{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.esquema{border:1.5px solid var(--gris-cl);border-radius:var(--radio);padding:30px;background:#fff;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}
.esquema:hover{transform:translateY(-3px)}
.esquema.active{border-color:var(--azul);box-shadow:0 14px 30px rgba(19,43,214,.12)}
.esquema .num{font-size:1.6rem;font-weight:900;color:var(--amarillo)}
.esquema h3{font-size:1.25rem;text-transform:lowercase;margin:8px 0}
.esquema p{font-size:.95rem;color:var(--gris)}
.esquema .open-hint{display:inline-block;margin-top:16px;font-weight:800;color:var(--azul);font-size:.9rem}
.esquema.active .open-hint{color:var(--gris)}

/* Paneles de los esquemas (tabs) */
.panels{margin-top:40px}
.panel{display:none}
.panel.active{display:block;animation:panelfade .3s ease}
@keyframes panelfade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.panel h3.panel-title{font-size:1.7rem;text-transform:lowercase;margin-bottom:6px}

.table-wrap{overflow-x:auto;margin-top:26px}
.ptable{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radio);overflow:hidden;border:1.5px solid var(--gris-cl);min-width:480px}
.ptable th,.ptable td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--gris-cl)}
.ptable th{background:var(--gris-cl);font-size:.74rem;text-transform:uppercase;letter-spacing:.1em}
.ptable td.precio{font-weight:900;color:var(--azul);white-space:nowrap}
.ptable tr:last-child td{border-bottom:0}

.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:42px}
.prog{border:1.5px solid var(--gris-cl);border-radius:var(--radio);padding:26px;display:flex;flex-direction:column;background:#fff}
.prog h3{font-size:1.18rem;text-transform:lowercase}
.prog .meta{font-size:.78rem;color:var(--gris);margin:6px 0 12px;text-transform:uppercase;letter-spacing:.06em}
.prog .obj{font-size:.92rem;color:#2c2e38;margin-bottom:12px}
.prog ul{list-style:none;margin:0 0 16px;padding:0;display:grid;gap:5px}
.prog li{font-size:.85rem;color:var(--gris);padding-left:16px;position:relative}
.prog li:before{content:"▪";position:absolute;left:0;color:var(--azul)}
.prog .price{margin-top:auto;font-size:1.35rem;font-weight:900}
.prog .price small{font-size:.78rem;font-weight:500;color:var(--gris)}

.note{font-size:.85rem;color:var(--gris);font-style:italic;margin-top:16px}
.banner{background:var(--amarillo);border-radius:var(--radio);padding:34px;text-align:center;margin-top:10px}
.banner h3{text-transform:lowercase;font-size:1.6rem;margin-bottom:8px}
.banner p{color:#3a3206;margin-bottom:18px}

/* Proceso por fases */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:42px}
.step{border:1.5px solid var(--gris-cl);border-radius:var(--radio);padding:24px;background:#fff}
.step .sn{font-size:1.8rem;font-weight:900;color:var(--amarillo);line-height:1}
.step b{display:block;margin:10px 0 6px;text-transform:lowercase;font-size:1.05rem}
.step p{font-size:.9rem;color:var(--gris);margin:0}

/* FAQ */
.faq{max-width:780px;margin:38px auto 0}
.faq details{border-bottom:1px solid var(--gris-cl);padding:18px 2px}
.faq summary{cursor:pointer;font-weight:800;font-size:1.05rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"+";color:var(--azul);font-weight:900;font-size:1.4rem;line-height:1}
.faq details[open] summary:after{content:"\2013"}
.faq p{color:var(--gris);margin-top:10px}

/* Texto legal (aviso de privacidad) */
.legal{max-width:820px;margin:0 auto}
.legal h2{font-size:1.3rem;margin:30px 0 8px;text-transform:none;letter-spacing:normal;font-weight:800}
.legal h3{font-size:1.05rem;margin:18px 0 6px;text-transform:none;letter-spacing:normal;font-weight:800}
.legal p,.legal li{color:#2c2e38;font-size:.96rem;line-height:1.65}
.legal p{margin:8px 0}
.legal ul{margin:8px 0 8px 20px;display:grid;gap:6px}
.legal a{color:var(--azul);font-weight:700}
.legal .updated{color:var(--gris);font-size:.85rem}

/* Callout / aviso */
.callout{background:#fff8e1;border:1.5px solid var(--amarillo);border-radius:14px;padding:18px 22px;margin:0 auto;max-width:780px}
.callout b{display:block;margin-bottom:8px}
.callout ul{margin:6px 0 0 18px;color:#5b5e6b;font-size:.95rem;display:grid;gap:6px}
.quote-form input[type=file]{padding:9px;background:#fff;cursor:pointer}
.quote-form .check{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;color:var(--gris)}
.quote-form .check input{width:auto;margin-top:3px}

/* Formulario de cotización */
.quote-form{max-width:780px;margin:36px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:16px}
.quote-form .full{grid-column:1/-1}
.quote-form label{display:block;font-weight:700;font-size:.84rem;margin-bottom:6px}
.quote-form input,.quote-form select,.quote-form textarea{width:100%;padding:13px 14px;border:1.5px solid var(--gris-cl);border-radius:12px;font-family:inherit;font-size:1rem;background:#fff;color:var(--negro)}
.quote-form textarea{min-height:120px;resize:vertical}
.quote-form input:focus,.quote-form select:focus,.quote-form textarea:focus{outline:none;border-color:var(--azul)}
.quote-form .btn{width:100%;justify-content:center}
@media(max-width:620px){ .quote-form{grid-template-columns:1fr} }

/* ===== Banner hero tipo carrusel (tienda) ===== */
.hero-banner{position:relative;border-radius:var(--radio);overflow:hidden;height:420px;margin-top:20px}
.bslide{position:absolute;inset:0;opacity:0;transition:opacity .7s ease;display:flex;align-items:center}
.bslide.active{opacity:1;z-index:1}
.bslide .bcontent{position:relative;z-index:3;padding:0 8%;max-width:600px;color:#fff}
.bslide .bcontent .eyebrow{color:var(--amarillo)}
.bslide h2{color:#fff;font-size:clamp(1.9rem,4vw,3.1rem);margin:10px 0 12px}
.bslide p{color:rgba(255,255,255,.92);margin-bottom:22px;font-size:1.08rem;max-width:34ch}
.bslide .bimg{position:absolute;right:0;top:0;bottom:0;width:48%;height:100%;object-fit:cover;z-index:1}
.bslide:after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none}
.bslide.theme-azul{background:var(--azul)}
.bslide.theme-azul:after{background:linear-gradient(90deg,var(--azul) 45%,rgba(19,43,214,0) 80%)}
.bslide.theme-negro{background:var(--negro)}
.bslide.theme-negro:after{background:linear-gradient(90deg,var(--negro) 45%,rgba(16,17,20,0) 80%)}
.bslide.theme-amarillo{background:var(--amarillo)}
.bslide.theme-amarillo:after{background:linear-gradient(90deg,var(--amarillo) 45%,rgba(243,202,64,0) 80%)}
.bslide.theme-amarillo .bcontent{color:var(--negro)}
.bslide.theme-amarillo h2{color:var(--negro)}
.bslide.theme-amarillo p{color:#3a3206}
.bslide.theme-amarillo .eyebrow{color:var(--azul)}
.bdots{position:absolute;bottom:16px;left:8%;display:flex;gap:8px;z-index:6;background:rgba(0,0,0,.18);padding:8px 12px;border-radius:999px;backdrop-filter:blur(4px)}
.bdots button{width:10px;height:10px;border-radius:50%;border:0;background:rgba(255,255,255,.55);cursor:pointer;padding:0;transition:width .2s}
.bdots button.active{background:#fff;width:26px;border-radius:6px}
.barrow{position:absolute;top:50%;transform:translateY(-50%);z-index:6;background:rgba(0,0,0,.28);border:0;color:#fff;width:42px;height:42px;border-radius:50%;cursor:pointer;font-size:1.4rem;line-height:1;display:flex;align-items:center;justify-content:center}
.barrow:hover{background:rgba(0,0,0,.45)}
.barrow.prev{left:14px}
.barrow.next{right:14px}
@media(max-width:760px){
  .hero-banner{height:auto;min-height:330px}
  .bslide{position:absolute}
  .bslide .bimg{display:none}
  .bslide:after{background:none!important}
  .bslide .bcontent{padding:34px 24px;max-width:none}
}

/* ===== Tarjeta de producto con imagen ===== */
.pcard{border:1.5px solid var(--gris-cl);border-radius:var(--radio);overflow:hidden;display:flex;flex-direction:column;background:#fff;transition:transform .15s,box-shadow .15s}
.pcard:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(0,0,0,.10)}
.pcard .thumb{position:relative;aspect-ratio:1/1;background:var(--gris-cl);overflow:hidden}
.pcard .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.pcard:hover .thumb img{transform:scale(1.06)}
.pcard .thumb.ph{display:flex;align-items:center;justify-content:center;background:var(--azul)}
.pcard .thumb.ph img{width:42%;height:auto;object-fit:contain;transition:none}
.pcard .thumb .badge{position:absolute;top:12px;left:12px;background:var(--amarillo);color:var(--negro);font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;padding:5px 11px;border-radius:999px}
.pcard .body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.pcard h3{font-size:1.2rem;text-transform:lowercase}
.pcard .desc{color:var(--gris);font-size:.9rem;margin:8px 0 16px;flex:1}
.pcard .precio{font-size:1.5rem;font-weight:900;margin-bottom:14px}
.pcard .precio small{font-size:.78rem;font-weight:500;color:var(--gris)}
.pcard .precio .tach{font-size:.85rem;color:#b9bcca;text-decoration:line-through;font-weight:600;margin-left:6px}
.pcard .btn{width:100%;justify-content:center}

/* ===== Navegación por categorías (tienda) ===== */
.catnav{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:28px}
.catnav a{padding:9px 16px;border:1.5px solid var(--gris-cl);border-radius:999px;font-weight:700;font-size:.85rem;text-transform:lowercase;color:var(--negro);background:#fff;transition:border-color .15s,color .15s}
.catnav a:hover{border-color:var(--azul);color:var(--azul)}
.cathead{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:4px}
.pcard .badge.nuevo{background:var(--azul);color:#fff}

/* ===== Lista de contacto clicable ===== */
.clist{display:grid;gap:12px;margin-top:4px}
.clink{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:#fff;font-weight:700;transition:background .15s,transform .15s}
.clink:hover{background:rgba(255,255,255,.18);transform:translateX(3px)}
.clink .ico{width:42px;height:42px;border-radius:11px;background:var(--amarillo);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.clink .ico svg{width:22px;height:22px;display:block}
.clink .ct{line-height:1.2}
.clink .ct small{display:block;font-weight:500;color:rgba(255,255,255,.7);font-size:.78rem}

/* ===== Microsite de producto ===== */
.shot{width:100%;border-radius:14px;border:1px solid var(--gris-cl);box-shadow:0 22px 55px rgba(0,0,0,.16)}
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.chip{padding:7px 14px;border-radius:999px;font-size:.8rem;font-weight:700;border:1.5px solid var(--gris-cl);color:var(--negro);background:#fff}
.chip.on-blue{border-color:rgba(255,255,255,.4);color:#fff;background:transparent}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.frow + .frow{margin-top:60px}
.frow.rev .ftext{order:2}
.frow .ftext h3{font-size:1.6rem;text-transform:lowercase;margin-bottom:10px}
.frow .ftext p{color:#2c2e38}
.frow .ftag{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--azul)}
.pricebox{background:var(--azul);color:#fff;border-radius:var(--radio);padding:44px;text-align:center;max-width:560px;margin:0 auto}
.pricebox .big{font-size:3.4rem;font-weight:900;color:var(--amarillo);line-height:1}
.pricebox p{color:rgba(255,255,255,.85);margin:6px 0 0}
.pricebox .btn{margin-top:22px}
.problem{background:var(--negro);color:#fff}
.problem h2{color:#fff}
.problem .bad{list-style:none;display:grid;gap:12px;margin-top:22px;max-width:660px}
.problem .bad li{padding-left:30px;position:relative;color:rgba(255,255,255,.9);font-size:1.05rem}
.problem .bad li:before{content:"\2717";position:absolute;left:0;color:#ED2580;font-weight:900}
.modnum{color:var(--azul);font-weight:900;margin-right:4px}
@media(max-width:900px){ .frow{grid-template-columns:1fr;gap:24px} .frow.rev .ftext{order:0} }

@media(max-width:900px){ .steps{grid-template-columns:1fr 1fr} }
@media(max-width:560px){ .steps{grid-template-columns:1fr} }

/* Footer */
footer{background:var(--negro);color:#cfd2dc;padding:64px 0 30px;font-size:.95rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px}
footer .logo img{height:30px;margin-bottom:16px}
footer h4{color:#fff;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;margin-bottom:14px}
footer a{display:block;color:#cfd2dc;padding:4px 0}
footer a:hover{color:var(--amarillo)}
.foot-bottom{border-top:1px solid #2a2c34;margin-top:40px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem;color:#8a8d99}

/* Responsive */
@media(max-width:1120px) and (min-width:901px){ .routes{grid-template-columns:repeat(3,1fr)} }
@media(max-width:900px){
  .hero-grid,.que-grid,.academy-grid,.alonso-grid{grid-template-columns:1fr}
  .routes,.feature-grid,.esquemas,.prog-grid{grid-template-columns:1fr 1fr}
  .cards,.quotes{grid-template-columns:1fr}
  .serv{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav ul,.nav .nav-cta .btn{display:none}
  .burger{display:flex}
  .nav ul.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;background:#fff;padding:18px 24px;gap:6px;border-bottom:1px solid var(--gris-cl)}
  .nav ul.open a{padding:10px 0}
  section{padding:64px 0}
  .hero{padding:64px 0 72px}
}
@media(max-width:560px){ .routes,.feature-grid,.esquemas,.prog-grid{grid-template-columns:1fr} .foot-grid{grid-template-columns:1fr 1fr} }
