/*
Theme Name: Rent a Car Montijo
Theme URI: https://tuweb.com/
Author: Tu Nombre / Especialista WP
Description: Tema personalizado y optimizado a partir de plantilla estática para Rent a Car Montijo.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: rent-a-car-montijo
*/

/* 1. ANTÍDOTO OBLIGATORIO PARA EL HUECO BLANCO DE WP */
html, html:root {
  margin-top: 0px !important;
  padding-top: 0px !important;
  scroll-behavior: smooth;
}

:root {
  --azul:#0d2f6e; --azul-m:#1a4ab0; --azul-l:#2563eb;
  --naranja:#e85d04; --naranja-v:#f77f00; --dorado:#fca311;
  --blanco:#fff; --gris-f:#f4f6fb; --gris:#8a9bb5;
  --oscuro:#091a3d; --sombra:rgba(13,47,110,.14);
}

/* 2. Resetear márgenes por defecto del navegador */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Outfit', sans-serif;
  overflow-x: hidden;
  background: var(--oscuro); /* Mantenemos tu fondo azul corporativo */
  margin-top: 0px !important;
}

/* TOPBAR (Corregido el color para que se lea "Montijo, Badajoz") */
.topbar {
  background: var(--oscuro);
  color: #94a3b8 !important; /* Gris claro para que los textos planos sean visibles */
  font-size: .8rem;
  padding: 9px 0;
  text-align: center;
  letter-spacing: .04em; 
  margin-top: 0px;
}
/* NAV */
nav{position:sticky;top:0;z-index:1000;background:rgba(9,26,61,.97);backdrop-filter:blur(16px);
  padding:0 5%;display:flex;align-items:center;justify-content:space-between;
  height:76px;box-shadow:0 2px 30px rgba(0,0,0,.3);transition:height .3s}
.nav-logo{height:62px;width:auto;filter:drop-shadow(0 0 14px rgba(252,163,17,.3));transition:transform .3s}
.nav-logo:hover{transform:scale(1.05)}
.nav-center{display:flex;gap:4px;list-style:none;align-items:center}
.nav-center a{color:#b8cce4;text-decoration:none;font-size:.88rem;font-weight:500;
  padding:9px 16px;border-radius:7px;letter-spacing:.04em;transition:all .2s}
.nav-center a:hover{color:#fff;background:rgba(255,255,255,.09)}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-tel{color:#ffffff;font-weight:700;font-size:.88rem;text-decoration:none;transition:color .2s;text-shadow:0 1px 0 rgba(0,0,0,.25)}
.nav-tel:hover{color:var(--naranja-v)}
.btn-presupuesto{background:linear-gradient(135deg,var(--naranja),var(--naranja-v));
  color:#fff;font-weight:700;font-size:.85rem;padding:10px 22px;border-radius:8px;
  text-decoration:none;box-shadow:0 4px 16px rgba(232,93,4,.4);transition:all .3s}
.btn-presupuesto:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,93,4,.55)}

/* HERO */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden;
  background:linear-gradient(135deg,#091a3d 0%,#0d2f6e 50%,#1a4ab0 100%)}
.hero-bg{position:absolute;inset:0;
  background:radial-gradient(ellipse 65% 65% at 68% 50%,rgba(232,93,4,.16) 0%,transparent 70%),
             radial-gradient(ellipse 40% 80% at 8% 80%,rgba(26,74,176,.35) 0%,transparent 60%)}
.hero-grid{position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:55px 55px}
.speed-lines{position:absolute;right:0;top:0;width:55%;height:100%;overflow:hidden;pointer-events:none}
.sl{position:absolute;height:2px;background:linear-gradient(90deg,transparent,rgba(232,93,4,.55),rgba(252,163,17,.75),transparent);
  border-radius:2px;animation:sl 3s ease-in-out infinite}
@keyframes sl{0%{width:0;right:100%;opacity:0}20%{opacity:1}80%{opacity:1}100%{width:60%;right:-10%;opacity:0}}

.hero-inner{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:70px 5%;
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;width:100%}

.hero-badge{display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,var(--naranja),var(--dorado));
  color:#ffffff;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:8px 18px;border-radius:100px;margin-bottom:22px;box-shadow:0 6px 18px rgba(0,0,0,.18);animation:fiu .6s ease both}
.hero-badge::before{content:'';width:7px;height:7px;background:rgba(255,255,255,.85);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}

.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(3.2rem,5.5vw,5.5rem);
  line-height:1;color:#fff;letter-spacing:.02em;animation:fiu .7s ease .1s both}
.hero-title span{background:linear-gradient(90deg,var(--naranja),var(--dorado));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:1.05rem;color:#a0b8d0;line-height:1.75;margin:18px 0 32px;
  max-width:480px;animation:fiu .7s ease .2s both}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;animation:fiu .7s ease .3s both}
.btn-p{background:linear-gradient(135deg,var(--naranja),var(--naranja-v));color:#fff;
  font-weight:700;font-size:.95rem;padding:15px 34px;border-radius:10px;text-decoration:none;
  display:inline-flex;align-items:center;gap:9px;box-shadow:0 8px 28px rgba(232,93,4,.4);
  transition:all .3s;border:none;cursor:pointer}
.btn-p:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(232,93,4,.58)}
.btn-o{background:transparent;color:#fff;font-weight:600;font-size:.95rem;
  padding:15px 34px;border-radius:10px;text-decoration:none;display:inline-flex;
  align-items:center;gap:9px;border:2px solid rgba(255,255,255,.28);transition:all .3s}
.btn-o:hover{border-color:var(--dorado);color:var(--dorado);background:rgba(252,163,17,.07)}

.hero-stats{display:flex;gap:32px;margin-top:44px;animation:fiu .7s ease .4s both}
.stat-n{font-family:'Bebas Neue',sans-serif;font-size:2.3rem;color:var(--dorado);line-height:1}
.stat-l{font-size:.75rem;color:#6a82a0;text-transform:uppercase;letter-spacing:.08em;margin-top:3px}

.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;
  animation:fir .8s ease .2s both}
.hero-car-svg{width:100%;max-width:580px;filter:drop-shadow(0 24px 56px rgba(0,0,0,.5)) drop-shadow(0 0 40px rgba(232,93,4,.22));animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.hero-glow{position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:320px;height:28px;background:rgba(232,93,4,.22);filter:blur(28px);border-radius:50%}

/* BOOKING */
.booking-wrap{background:linear-gradient(180deg,#0d2f6e,#091a3d);padding:0 5% 56px}
.booking-card{max-width:1280px;margin:0 auto;background:rgba(255,255,255,.065);
  backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;
  padding:36px 40px;transform:translateY(-36px);box-shadow:0 36px 72px rgba(0,0,0,.28)}
.bk-title{color:#fff;font-size:1.35rem;font-weight:700;margin-bottom:26px;
  display:flex;align-items:center;gap:10px}
.bk-title::before{content:'';display:inline-block;width:4px;height:24px;
  background:linear-gradient(180deg,var(--naranja),var(--dorado));border-radius:2px}
.bk-grid{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:14px;align-items:end}
.fg{display:flex;flex-direction:column;gap:7px}
.fg label{color:#7a92b8;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em}
.fg input,.fg select{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
  color:#fff;padding:13px 16px;border-radius:9px;font-size:.92rem;font-family:'Outfit',sans-serif;
  outline:none;transition:border-color .25s,background .25s}
.fg input:focus,.fg select:focus{border-color:var(--naranja);background:rgba(255,255,255,.12)}
.fg select option{background:#0d2f6e;color:#fff}
.fg input::placeholder{color:#4a5e78}
input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(1) opacity(.4)}
.btn-buscar{background:linear-gradient(135deg,var(--naranja),var(--dorado));color:#fff;
  font-weight:700;font-size:.95rem;padding:13px 28px;border-radius:9px;border:none;
  cursor:pointer;display:flex;align-items:center;gap:8px;height:50px;
  box-shadow:0 6px 20px rgba(232,93,4,.4);transition:all .3s;white-space:nowrap}
.btn-buscar:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(232,93,4,.55)}

/* SECCIONES */
.sec{padding:88px 5%;max-width:1280px;margin:0 auto}
.sec-bg{background:var(--gris-f)}
.sec-bg .sec{padding:88px 5%}
.sl-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  color:var(--naranja);margin-bottom:10px}
.sl-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.2rem,3.8vw,3.4rem);
  color:var(--oscuro);line-height:1.05;margin-bottom:14px}
.sl-title span{background:linear-gradient(90deg,var(--naranja),var(--naranja-v));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sl-desc{font-size:1rem;color:#5a6e88;line-height:1.75;max-width:520px}

/* FLEET CATEGORIES */
.fleet-cats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.fcat{background:#fff;border:1px solid rgba(13,47,110,.07);border-radius:16px;
  padding:28px 26px;text-decoration:none;color:inherit;transition:all .3s;
  display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden}
.fcat::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--naranja),var(--dorado));
  transform:scaleX(0);transition:transform .3s;transform-origin:left}
.fcat:hover{transform:translateY(-5px);box-shadow:0 16px 44px var(--sombra);border-color:rgba(232,93,4,.18)}
.fcat:hover::after{transform:scaleX(1)}
.fcat-icon{font-size:2.2rem}
.fcat-name{font-weight:800;font-size:1rem;color:var(--oscuro)}
.fcat-desc{font-size:.84rem;color:#5a6e88;line-height:1.6;flex:1}
.fcat-price{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:var(--azul);margin-top:4px}
.fcat-price span{font-family:'Outfit',sans-serif;font-size:.78rem;color:var(--gris);font-weight:500}

/* CAROUSEL */
.carousel-section{background:var(--gris-f);padding:88px 0;overflow:hidden}
.carousel-head{max-width:1280px;margin:0 auto 52px;padding:0 5%;
  display:flex;justify-content:space-between;align-items:flex-end}
.carousel-wrap{position:relative;overflow:hidden}
.c-track{display:flex;gap:24px;padding:16px 5% 24px;
  transition:transform .6s cubic-bezier(.25,.46,.45,.94);cursor:grab;will-change:transform}
.c-track:active{cursor:grabbing}

.vcard{background:#fff;border-radius:18px;overflow:hidden;min-width:320px;flex-shrink:0;
  box-shadow:0 4px 20px rgba(13,47,110,.08);transition:all .35s;
  border:1px solid rgba(13,47,110,.06);position:relative}
.vcard:hover{transform:translateY(-7px);box-shadow:0 20px 48px rgba(13,47,110,.16);
  border-color:rgba(232,93,4,.18)}

.vcard-img{width:100%;height:195px;overflow:hidden;position:relative;
  background:linear-gradient(135deg,#e2e8f5,#d1daf0)}
.vcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.vcard:hover .vcard-img img{transform:scale(1.06)}
.vcard-img-svg{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.vbadge {
  position: absolute;
  top: 14px;
  left: 14px;
  background: linear-gradient(135deg, var(--naranja), var(--naranja-v));
  color: #fff;
  font-size: .7rem;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 100px;
  text-transform: uppercase;
  letter-spacing: .05em;
}

/* MODIFICADO: Ahora con fondo sólido y sombra para que resalte sobre la foto */
.vbadge-disp {
  position: absolute;
  top: 14px;
  right: 14px;
  background: #ffffff;                 /* Fondo blanco puro totalmente opaco */
  color: #16a34a;                      /* Tu color verde para el texto */
  border: 1px solid #16a34a;           /* Borde verde sólido bien definido */
  font-size: .68rem;
  font-weight: 700;                     /* Letra un poco más gruesa (negrita) */
  padding: 4px 10px;
  border-radius: 100px;
  display: flex;
  align-items: center;
  gap: 5px;
  box-shadow: 0 3px 8px rgba(0,0,0,0.15); /* Sombra para despegar el botón de la imagen */
}

.vbadge-disp::before {
  content: '';
  width: 6px;
  height: 6px;
  background: #22c55e;
  border-radius: 50%;
  animation: pulse 2s infinite;
}

.vcard-body{padding:22px}
.vcat{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--gris);margin-bottom:5px}
.vname{font-size:1.2rem;font-weight:800;color:var(--oscuro);margin-bottom:14px}
.vspecs{display:flex;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.vspec{display:flex;align-items:center;gap:4px;font-size:.8rem;color:#5a6e88;font-weight:500}
.vprow{display:flex;align-items:flex-end;justify-content:space-between}
.vp-from{font-size:.72rem;color:var(--gris);text-transform:uppercase;letter-spacing:.04em}
.vp-num{font-family:'Bebas Neue',sans-serif;font-size:2.1rem;color:var(--oscuro);line-height:1}
.vp-unit{font-size:.78rem;color:var(--gris);font-weight:500;margin-left:3px}
.btn-rsv{background:linear-gradient(135deg,var(--azul),var(--azul-m));color:#fff;
  font-weight:700;font-size:.82rem;padding:11px 20px;border-radius:8px;text-decoration:none;
  display:inline-flex;align-items:center;gap:6px;transition:all .3s;
  border:none;cursor:pointer;box-shadow:0 4px 14px rgba(13,47,110,.22)}
.btn-rsv:hover{background:linear-gradient(135deg,var(--naranja),var(--naranja-v));
  transform:translateY(-2px);box-shadow:0 7px 20px rgba(232,93,4,.38)}

/* CAROUSEL CONTROLS */
.c-controls{display:flex;justify-content:center;gap:16px;margin-top:28px;padding:0 5%;align-items:center;position:relative;z-index:2}
.c-controls::before{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:220px;height:1px;background:rgba(13,47,110,.1);border-radius:999px;z-index:-1}
.c-btn{width:60px;height:60px;border-radius:50%;border:none;
  background:linear-gradient(135deg,rgba(232,93,4,.12),rgba(13,47,110,.18));
  color:var(--azul);font-size:1.25rem;cursor:pointer;transition:all .25s;
  display:flex;align-items:center;justify-content:center;box-shadow:0 20px 40px rgba(13,47,110,.12);
  outline:none;position:relative}
.c-btn svg{width:24px;height:24px;display:block;}
.c-btn::after{content:'';position:absolute;inset:8px;border-radius:50%;background:rgba(255,255,255,.24);opacity:0;transition:opacity .25s}
.c-btn:hover{transform:translateY(-2px) scale(1.04);background:linear-gradient(135deg,var(--naranja),var(--dorado));color:#fff;box-shadow:0 24px 50px rgba(232,93,4,.25)}
.c-btn:hover::after{opacity:1}
.c-dots{display:flex;gap:10px;align-items:center;margin:0 16px}
.c-dot{width:10px;height:10px;border-radius:50%;background:rgba(13,47,110,.18);cursor:pointer;
  border:none;transition:all .25s;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.c-dot.on{width:18px;border-radius:999px;background:var(--naranja);box-shadow:0 0 0 8px rgba(232,93,4,.08)}

/* WHY */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px}
.wcard{background:#fff;border-radius:16px;padding:32px 28px;
  border:1px solid rgba(13,47,110,.06);box-shadow:0 3px 16px rgba(13,47,110,.05);
  transition:all .32s;position:relative;overflow:hidden}
.wcard::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--naranja),var(--dorado));transform:scaleX(0);
  transition:transform .32s;transform-origin:left}
.wcard:hover{transform:translateY(-5px);box-shadow:0 14px 44px rgba(13,47,110,.12)}
.wcard:hover::before{transform:scaleX(1)}
.wicon{width:58px;height:58px;background:rgba(13,47,110,.07);border-radius:14px;
  display:flex;align-items:center;justify-content:center;font-size:1.6rem;
  margin-bottom:20px;transition:background .3s}
.wcard:hover .wicon{background:linear-gradient(135deg,var(--naranja),var(--naranja-v))}
.wtitle{font-size:1rem;font-weight:800;color:var(--oscuro);margin-bottom:8px}
.wdesc{font-size:.88rem;color:#5a6e88;line-height:1.7}

/* COVERAGE */
.cov-wrap{background:var(--oscuro);padding:88px 5%;position:relative;overflow:hidden}
.cov-wrap::before{content:'';position:absolute;top:-80px;right:-80px;width:440px;height:440px;
  background:radial-gradient(circle,rgba(232,93,4,.1),transparent 70%);border-radius:50%;pointer-events:none}
.cov-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.cov-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:32px}
.cov-item{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:11px;padding:16px 18px;display:flex;align-items:center;gap:12px;transition:all .25s}
.cov-item:hover{background:rgba(232,93,4,.09);border-color:rgba(232,93,4,.28)}
.cov-name{font-weight:700;color:#fff;font-size:.9rem}
.cov-km{font-size:.75rem;color:var(--dorado);font-weight:600}
.map-box{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:22px;height:400px;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;}
.map-ring{position:absolute;border-radius:50%;border:1px solid rgba(232,93,4,.14);animation:ring 3s ease-in-out infinite}
.map-ring:nth-child(1){width:130px;height:130px;animation-delay:0s}
.map-ring:nth-child(2){width:220px;height:220px;animation-delay:.5s}
.map-ring:nth-child(3){width:310px;height:310px;animation-delay:1s}
@keyframes ring{0%{opacity:.6;transform:scale(.85)}100%{opacity:0;transform:scale(1.1)}}
.map-pin{position:absolute;font-size:2.2rem;animation:pinbounce 2.5s ease-in-out infinite}
@keyframes pinbounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.map-lbl{position:absolute;bottom:24px;text-align:center}
.map-lbl strong{color:#fff;font-size:.95rem;display:block}
.map-lbl span{color:#6a82a0;font-size:.78rem}

/* AIRPORT */
.airport-wrap{padding:88px 5%;background:#fff}
.airport-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.airport-img{border-radius:20px;overflow:hidden;height:360px;
  background:none!important;
  display:flex;align-items:center;justify-content:center;
  box-shadow:none!important;position:relative}
.airport-img::after{display:none}
.airport-logo{max-width:100%;max-height:100%;object-fit:contain;display:block;background:none!important}
.airport-list{list-style:none;margin:24px 0 32px;display:flex;flex-direction:column;gap:12px}
.airport-list li{display:flex;align-items:center;gap:12px;font-size:.95rem;color:#4a5568;font-weight:500}
.airport-list li::before{content:'•';width:24px;height:24px;background:linear-gradient(135deg,var(--naranja),var(--dorado));
  color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:800;flex-shrink:0}

/* FERIA */
.feria-wrap{background:linear-gradient(135deg,#0d2f6e,#1a4ab0);padding:72px 5%;
  position:relative;overflow:hidden;text-align:center}
.feria-wrap::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(232,93,4,.12),transparent)}
.feria-inner{position:relative;max-width:700px;margin:0 auto}
.feria-season{display:inline-block;background:rgba(252,163,17,.15);border:1px solid rgba(252,163,17,.3);
  color:var(--dorado);font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 16px;border-radius:100px;margin-bottom:20px}
.feria-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(2rem,4vw,3.2rem);color:#fff;line-height:1.05;margin-bottom:14px}
.feria-desc{color:#a0b8d0;font-size:1rem;line-height:1.7;margin-bottom:32px}

/* TESTIMONIAL */
.testi-wrap{background:var(--gris-f);padding:88px 0;overflow:hidden}
.testi-head{max-width:1280px;margin:0 auto 52px;padding:0 5%;text-align:center}
.testi-head .sl-desc{margin:0 auto}
.testi-scroll{display:flex;gap:24px;padding:8px 5%;animation:scrollt 32s linear infinite;width:max-content}
.testi-scroll:hover{animation-play-state:paused}
@keyframes scrollt{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.tcard{background:#fff;border-radius:14px;padding:26px;min-width:300px;max-width:300px;
  box-shadow:0 3px 16px rgba(13,47,110,.06);border:1px solid rgba(13,47,110,.05);flex-shrink:0}
.tcard-stars{color:var(--dorado);font-size:.95rem;letter-spacing:.06em;margin-bottom:12px}
.tcard-text{font-size:.88rem;color:#4a5568;line-height:1.75;font-style:italic;margin-bottom:18px}
.tcard-author{display:flex;align-items:center;gap:10px}
.tavatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;font-weight:800;color:#fff;flex-shrink:0}
.tname{font-weight:700;font-size:.88rem;color:var(--oscuro)}
.tloc{font-size:.75rem;color:var(--gris)}

/* RATING */
.rating-band{background:var(--oscuro);padding:48px 5%;text-align:center}
.rating-band .rating-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:60px;flex-wrap:wrap}
.r-num{font-family:'Bebas Neue',sans-serif;font-size:4.5rem;color:var(--dorado);line-height:1}
.r-label{color:#7a92b8;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em}
.r-quote{max-width:420px;text-align:left}
.r-quote p{color:#a0b8d0;font-style:italic;font-size:1rem;line-height:1.7;margin-bottom:8px}
.r-quote cite{color:#6a82a0;font-size:.82rem}

/* FAQ */
.faq-box{max-width:780px;margin:52px auto 0;color:#fff}
.faq-item{border-bottom:1px solid rgba(13,47,110,.08)}
.faq-q{display:flex;justify-content:space-between;align-items:center;
  padding:20px 0;cursor:pointer;font-weight:700;font-size:.96rem;color:var(--#fff);
  transition:color .25s;gap:14px}
.faq-q:hover{color:var(--naranja)}
.faq-ico{width:28px;height:28px;border-radius:50%;background:rgba(13,47,110,.07);
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;
  transition:all .3s;color:var(--azul)}
.faq-item.open .faq-ico{background:var(--naranja);color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease;
  font-size:.92rem;color:#5a6e88;line-height:1.75}
.faq-item.open .faq-a{max-height:180px;padding-bottom:20px}

/* CTA */
.cta-sec{background:linear-gradient(135deg,var(--azul),var(--azul-m),var(--azul-l));
  padding:80px 5%;text-align:center;position:relative;overflow:hidden}
.cta-sec::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 50% 80% at 20% 50%,rgba(232,93,4,.13),transparent),
             radial-gradient(ellipse 50% 80% at 80% 50%,rgba(252,163,17,.09),transparent)}
.cta-inner{position:relative;max-width:660px;margin:0 auto}
.cta-inner h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.3rem,4.5vw,3.8rem);
  color:#fff;margin-bottom:14px;line-height:1.05}
.cta-inner p{color:#a0b8d0;font-size:1.02rem;margin-bottom:32px}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* FOOTER */
footer{background:var(--oscuro);padding:60px 5% 0;color:#7a92b8}
.footer-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.8fr 1fr 1fr 1.5fr;
  gap:52px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-logo{height:60px;width:auto;margin-bottom:18px;filter:brightness(1.1)}
.footer-desc{font-size:.85rem;line-height:1.75;max-width:270px}
.f-social{display:flex;gap:9px;margin-top:22px}
.fsoc{width:38px;height:38px;border-radius:9px;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;
  font-size:1rem;cursor:pointer;transition:all .25s;text-decoration:none}
.fsoc:hover{background:var(--naranja);border-color:var(--naranja);transform:translateY(-3px)}
.fcol h4{color:#fff;font-weight:700;font-size:.95rem;margin-bottom:18px;letter-spacing:.03em}
.fcol ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.fcol ul a{color:#7a92b8;text-decoration:none;font-size:.85rem;transition:color .2s;
  display:flex;align-items:center;gap:7px}
.fcol ul a:hover{color:var(--dorado)}
.fcol ul a::before{content:'•';font-size:.72rem}
.fcontact-item{display:flex;gap:10px;align-items:flex-start;margin-bottom:13px;font-size:.85rem}
.fcontact-item a{color:var(--dorado);text-decoration:none}
.footer-bot{max-width:1280px;margin:0 auto;padding:18px 0;
  display:flex;justify-content:space-between;align-items:center;font-size:.78rem}
.footer-bot a{color:var(--dorado);text-decoration:none}

/* WA FLOAT */
.wa{position:fixed;bottom:28px;right:28px;z-index:999;width:56px;height:56px;
  background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;text-decoration:none;box-shadow:0 6px 22px rgba(37,211,102,.42);
  animation:wobble 5s ease-in-out infinite;transition:transform .25s}
.wa:hover{transform:scale(1.13)!important}
@keyframes wobble{0%,100%{transform:rotate(0)}10%{transform:rotate(-8deg)}20%{transform:rotate(8deg)}30%{transform:rotate(-4deg)}40%{transform:rotate(4deg)}50%{transform:rotate(0)}}

/* ANIMATIONS */
@keyframes fiu{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fir{from{opacity:0;transform:translateX(36px)}to{opacity:1;transform:translateX(0)}}
.rev{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.rev.vis{opacity:1;transform:translateY(0)}

/* SCROLLBAR */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--oscuro)}
::-webkit-scrollbar-thumb{background:var(--naranja);border-radius:3px}
/* Fila exclusiva para bajar los botones y ponerlos en paralelo */
.vcard-footer-btns {
  display: flex;
  gap: 8px;
  margin-top: 14px; /* Esto empuja los botones más abajo separándolos del precio */
  width: 100%;
}

/* Botón Más detalle adaptado */
.btn-detail {
  flex: 1;                             /* Hace que ambos botones midan lo mismo */
  background: #f4f6fb;                 /* Fondo grisáceo muy limpio */
  color: var(--azul);                  /* Tu color azul */
  border: 1px solid rgba(13,47,110,.2);
  font-weight: 700;
  font-size: .82rem;
  padding: 10px 0;                     /* Altura idéntica a presupuesto */
  border-radius: 8px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all .3s;
  cursor: pointer;
}

.btn-detail:hover {
  background: var(--azul);
  color: #fff;
  border-color: var(--azul);
  transform: translateY(-2px);
}

/* Forzamos al botón Presupuesto a estirarse igual que el de detalles */
.vcard-footer-btns .btn-rsv {
  flex: 1;
  font-size: .82rem;
  padding: 10px 0;
  justify-content: center;
  margin: 0;
}

/* Ajuste para el logo dentro del radar */
.map-pin {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff; /* Fondo blanco sutil detrás del logo si lo necesita, o cámbialo a 'transparent' */
  border-radius: 50%;
  padding: 6px; /* Espaciado interno */
  box-shadow: 0 0 15px rgba(255, 255, 255, 0.2);
  width: 50px;  /* Ajusta el tamaño del círculo central a tu gusto */
  height: 50px;
}

.map-custom-logo {
  width: 100%;
  height: 100%;
  object-fit: contain; /* Evita que el logo se deforme o se estire */
}

/* RESPONSIVE: Tablet y Móvil */
@media (max-width: 1024px) {
  .hero-inner { grid-template-columns: 1fr; padding: 48px 5%; gap: 32px }
  .hero-visual { max-width: 520px; margin: 0 auto }
  .hero-stats { justify-content: space-between; flex-wrap: wrap; gap: 18px }
  .hero-sub { max-width: 100% }
  .bk-grid { grid-template-columns: 1fr 1fr; gap: 16px }
  .booking-card { padding: 32px 28px }
  .fleet-cats { grid-template-columns: repeat(2, 1fr); gap: 18px }
  .carousel-head { flex-direction: column; align-items: flex-start; gap: 18px }
  .airport-inner, .cov-inner, .why-grid, .footer-grid { grid-template-columns: 1fr; gap: 28px }
  .testi-scroll { padding: 8px 5%; }
  .footer-bot { flex-direction: column; gap: 16px }
}

@media (max-width: 767px) {
  .topbar { font-size: .75rem; padding: 8px 0 }
  nav { height: 64px; padding: 0 4% }
  .nav-center { display: none }
  .nav-right { gap: 12px }
  .hero-inner { padding: 34px 4%; gap: 24px }
  .hero-title { font-size: clamp(2.3rem, 6vw, 3.4rem) }
  .hero-sub { font-size: .96rem; line-height: 1.7 }
  .hero-btns { flex-direction: column; width: 100% }
  .hero-btns a { width: 100%; justify-content: center }
  .hero-stats { gap: 14px }
  .booking-card { padding: 26px 22px }
  .bk-grid { grid-template-columns: 1fr; gap: 12px }
  .fleet-cats { grid-template-columns: 1fr; gap: 14px }
  .vcard { min-width: auto; width: 100% }
  .vcard-img { height: 180px }
  .vcard-body { padding: 20px }
  .vcard-footer-btns { flex-direction: column; gap: 10px }
  .btn-detail, .btn-rsv { width: 100%; padding: 12px 16px }
  .carousel-wrap { overflow: visible }
  .c-controls { padding: 0 4% }
  .airport-wrap, .cov-wrap, .why-grid, .testi-wrap, .cta-sec, .rating-band { padding: 64px 4% }
  .airport-img { height: 280px }
  .map-box { height: 260px }
  .airport-list li { font-size: .92rem }
  .cov-grid { gap: 12px }
  .testi-scroll { animation: none; overflow-x: auto; gap: 18px; padding: 12px 4% }
  .tcard { min-width: 260px }
  .footer-grid { grid-template-columns: 1fr; gap: 22px }
  .footer-bot { flex-direction: column; align-items: flex-start; gap: 12px }
  .wa { bottom: 16px; right: 16px; width: 50px; height: 50px }
}

@media (max-width: 480px) {
  nav { padding: 0 3% }
  .hero-inner { padding: 26px 3%; gap: 20px }
  .hero-title { font-size: clamp(2rem, 8vw, 2.8rem) }
  .hero-sub { font-size: .92rem }
  .hero-badge { padding: 7px 16px; font-size: .72rem }
  .hero-btns { gap: 12px }
  .btn-p, .btn-o, .btn-buscar { width: 100%; padding: 14px 18px }
  .booking-card { padding: 18px 16px }
  .airport-img { height: 240px }
  .map-box { height: 220px }
  .cov-wrap, .why-grid, .testi-wrap, .cta-sec, .rating-band { padding: 50px 3% }
  .sl-title { font-size: clamp(1.8rem, 6vw, 2.3rem) }
  .tcard { min-width: 240px }
  .c-controls { gap: 12px }
  .c-btn { width: 52px; height: 52px }
  .footer-bot { padding-bottom: 12px }
  .wa { bottom: 14px; right: 14px; width: 46px; height: 46px }
}

/* Ajustes extra para pantallas muy pequeñas */
@media (max-width: 420px) {
  .hero-title { font-size: 1.85rem }
  .bk-title { font-size: 1.05rem }
  .vcard-img { height: 150px }
  .airport-img { height: 220px }
}

