:root{
  --bg:#0d0d10;--bg2:#171719;--bg3:#242426;--panel:#202022;--panel2:#2f2f33;
  --line:#3b3b40;--line2:#56565d;--fg:#ffffff;--fg2:#e5e2de;--muted:#b9b3ad;
  --accent:#ff6946;--accent2:#ffcc08;--accent3:#f23b3b;--ok:#25d366;--warn:#ffcc08;
  --radius:24px;--shadow:0 24px 70px rgba(0,0,0,.38);--glow:0 0 42px rgba(255,105,70,.18)
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:radial-gradient(circle at 12% 5%,rgba(255,105,70,.13),transparent 34%),radial-gradient(circle at 90% 8%,rgba(255,204,8,.12),transparent 32%),var(--bg);color:var(--fg);font-family:Inter,system-ui,sans-serif}a{text-decoration:none;color:inherit}p{color:var(--fg2);line-height:1.72}img{max-width:100%}.top-strip{min-height:34px;background:#111112;color:var(--fg2);display:flex;align-items:center;justify-content:center;gap:18px;font-size:12px;font-weight:800;border-bottom:1px solid var(--line)}.top-strip a{color:var(--accent)}.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 5vw;background:rgba(7,13,26,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}.brand{display:flex;align-items:center;gap:12px}.brand b{font-size:18px;letter-spacing:-.04em}.brand small{display:block;color:var(--muted);font-size:11px;font-weight:800}.brand-logo{width:46px;height:46px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#111112;font-weight:950;box-shadow:0 14px 36px rgba(255,105,70,.22)}.desktop-nav{display:flex;gap:22px;align-items:center}.desktop-nav a{color:var(--fg2);font-weight:850;font-size:14px;padding:10px 0;border-bottom:2px solid transparent}.desktop-nav a:hover,.desktop-nav a.active{color:var(--fg);border-color:var(--accent)}.header-actions{display:flex;gap:10px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 18px;border-radius:999px;border:1px solid var(--line2);background:rgba(255,255,255,.04);color:var(--fg);font-weight:900;cursor:pointer;transition:.2s ease}.btn:hover{transform:translateY(-2px);box-shadow:0 16px 35px rgba(0,0,0,.22);border-color:rgba(255,105,70,.45)}.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#111112;border:0;box-shadow:0 14px 34px rgba(255,105,70,.2)}.btn.ghost{background:transparent}.btn.light{background:rgba(255,105,70,.08);border-color:rgba(255,105,70,.28);color:var(--accent)}.btn.large{min-height:56px;padding:0 25px}.page-shell{padding:54px 5vw 76px}.hero{position:relative;min-height:650px;display:grid;grid-template-columns:1.03fr .97fr;gap:34px;align-items:center;padding:64px 5vw 54px;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0 58%,rgba(255,105,70,.05) 58% 100%);pointer-events:none}.hero-content,.hero-visual{position:relative;z-index:2}.eyebrow,.section-head span,.page-kicker{display:inline-flex;padding:9px 15px;border-radius:999px;background:rgba(255,105,70,.08);color:var(--accent);font-weight:950;font-size:12px;text-transform:uppercase;letter-spacing:.08em;border:1px solid rgba(255,105,70,.22)}h1{font-size:clamp(44px,6.4vw,82px);line-height:.96;margin:20px 0;letter-spacing:-.075em;color:var(--fg)}h2{font-size:clamp(30px,4vw,56px);line-height:1;margin:12px 0;letter-spacing:-.06em}h3{letter-spacing:-.035em}.hero-actions,.quick-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.trust-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:32px;align-items:stretch}.trust-row div,.mini-route-card,.info-card,.location-card,.step-card,.contact-card,.vehicle-inner{background:linear-gradient(180deg,rgba(15,27,46,.94),rgba(12,21,39,.94));border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.trust-row div{min-width:0;padding:14px 17px;height:100%}.trust-row b{display:block;font-size:19px;color:var(--accent)}.trust-row span{font-size:12px;color:var(--muted);font-weight:800}.hero-visual{min-height:500px;border-radius:42px;background:linear-gradient(145deg,#111112,#202022 64%,#261046);box-shadow:var(--shadow),var(--glow);overflow:hidden;border:1px solid rgba(255,105,70,.24);display:grid;align-items:center;justify-items:center;transform-style:preserve-3d;transition:transform .18s ease}.hero-visual:before{content:"";position:absolute;inset:-25%;background:radial-gradient(circle,rgba(255,105,70,.20) 0 13%,transparent 14% 35%),linear-gradient(45deg,transparent 0 48%,rgba(255,255,255,.07) 49% 51%,transparent 52%);animation:pulseBg 9s ease-in-out infinite}.hero-card-label{position:absolute;left:26px;top:24px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:var(--fg);border-radius:999px;padding:9px 13px;font-size:12px;font-weight:950;z-index:3}.car-showcase{position:relative;width:min(90%,580px);aspect-ratio:1.2;display:grid;place-items:center;transform:translateZ(40px)}.orbit{position:absolute;border:2px solid rgba(255,105,70,.24);border-radius:50%;filter:drop-shadow(0 0 18px rgba(255,105,70,.2))}.orbit-one{width:78%;height:52%;transform:rotateX(68deg) rotateZ(-10deg)}.orbit-two{width:60%;height:40%;transform:rotateX(70deg) rotateZ(25deg);border-color:rgba(255,204,8,.35)}.css-car{position:relative;width:76%;height:27%;border-radius:72px 86px 34px 34px;background:linear-gradient(135deg,#ffffff 0%,#8fa0b5 38%,#33445e 75%,#101a2c 100%);box-shadow:0 38px 90px rgba(0,0,0,.45);animation:floatCar 5s ease-in-out infinite}.css-car:before{content:"";position:absolute;left:17%;right:20%;top:-50%;height:70%;border-radius:88px 88px 10px 10px;background:linear-gradient(135deg,#dff9ff 0%,var(--accent) 48%,#2f2f33 100%)}.windshield{position:absolute;left:38%;top:-32%;width:25%;height:35%;border-radius:40px 40px 4px 4px;background:rgba(7,13,26,.75);z-index:2}.wheel{position:absolute;bottom:-20%;width:17%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,#4c4c50 0 30%,#111112 31% 68%,var(--accent) 70% 77%,#111112 78%);box-shadow:0 0 0 7px rgba(0,0,0,.2)}.wheel.left{left:14%}.wheel.right{right:14%}.floor-shadow{position:absolute;width:70%;height:18%;bottom:15%;border-radius:50%;background:radial-gradient(ellipse,rgba(0,0,0,.55),transparent 68%);filter:blur(2px)}.hero-mini-card{position:absolute;right:24px;bottom:24px;background:rgba(15,27,46,.92);border:1px solid var(--line);border-radius:24px;padding:17px 20px;box-shadow:0 18px 45px rgba(0,0,0,.3);z-index:4}.hero-mini-card b{display:block}.hero-mini-card small{color:var(--muted);font-weight:800}@keyframes floatCar{50%{transform:translateY(-18px) rotateY(10deg)}}@keyframes pulseBg{50%{transform:rotate(5deg) scale(1.05)}}.booking-panel{position:relative;z-index:5;margin:0 0 26px;background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:32px;box-shadow:var(--shadow);overflow:hidden}.home-booking{margin:-42px 5vw 24px}.booking-tabs{display:flex;gap:8px;padding:14px 16px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.02)}.booking-tabs button,.category-strip button{border:0;border-radius:999px;padding:11px 17px;background:transparent;color:var(--fg2);font-weight:950;cursor:pointer}.booking-tabs .active,.category-strip .active{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#111112}.booking-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr auto;gap:12px;align-items:end;padding:18px}label{display:block;color:var(--muted);font-size:12px;margin-bottom:7px;font-weight:950}input,select,textarea{width:100%;min-height:50px;border-radius:16px;border:1px solid var(--line2);background:#0b1426;color:var(--fg);padding:0 13px;font:inherit;font-weight:700}textarea{padding:14px;min-height:140px}.search-btn{min-height:50px}.route-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:34px}.mini-route-card{padding:24px;min-height:188px;display:flex;flex-direction:column;justify-content:space-between;transition:.22s ease}.mini-route-card:hover{transform:translateY(-5px);border-color:rgba(255,105,70,.4);box-shadow:var(--shadow),var(--glow)}.mini-route-card b{font-size:22px}.mini-route-card span{color:var(--accent);font-weight:950}.section-head{max-width:890px;margin-bottom:30px}.section-head.split{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:end;max-width:none}.category-strip{display:flex;gap:10px;overflow:auto;padding:0 0 22px}.category-strip button{background:rgba(255,255,255,.04);border:1px solid var(--line);white-space:nowrap}.vehicles-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}.vehicle-card{position:relative;perspective:1000px}.vehicle-inner{height:100%;min-height:455px;padding:16px;transition:transform .18s ease,box-shadow .18s ease;transform-style:preserve-3d;overflow:hidden}.vehicle-inner:hover{box-shadow:var(--shadow),var(--glow)}.vehicle-img{height:220px;border-radius:25px;background:linear-gradient(145deg,#242426,#171719);display:grid;place-items:center;overflow:hidden;margin-bottom:18px;position:relative;border:1px solid var(--line)}.vehicle-img:before{content:"";position:absolute;inset:auto -20% 0;height:48%;background:radial-gradient(ellipse,rgba(255,105,70,.15),transparent 65%)}.vehicle-img img{position:relative;z-index:2;width:100%;height:100%;object-fit:cover;filter:drop-shadow(0 24px 34px rgba(0,0,0,.28));transition:transform .3s ease}.vehicle-card:hover img{transform:scale(1.06)}.vehicle-placeholder{position:relative;z-index:2;width:76%;height:36%;border-radius:75px 85px 30px 30px;background:linear-gradient(135deg,#ffffff,#b9b3ad 45%,#4c4c50);filter:drop-shadow(0 24px 28px rgba(0,0,0,.28))}.vehicle-placeholder:before{content:"";position:absolute;left:18%;right:19%;top:-42%;height:64%;border-radius:70px 70px 6px 6px;background:linear-gradient(135deg,#ffffff,var(--accent) 70%,#2f2f33)}.vehicle-card h3{font-size:24px;margin:4px 6px 8px}.vehicle-card p{margin:0 6px}.meta{display:flex;gap:8px;flex-wrap:wrap;margin:16px 6px}.meta span{padding:7px 11px;border-radius:999px;background:rgba(255,255,255,.05);color:var(--fg2);font-size:12px;font-weight:900;border:1px solid var(--line)}.price-row{display:flex;align-items:end;justify-content:space-between;gap:12px;margin:18px 6px 0}.price{font-size:23px;font-weight:950;color:var(--accent);letter-spacing:-.04em}.price small{display:block;color:var(--muted);font-size:11px;font-weight:800;letter-spacing:0}.card-actions{display:flex;gap:10px;margin:18px 6px 4px}.card-actions .btn{flex:1}.info-grid,.location-grid,.step-grid,.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.info-card,.location-card,.step-card,.contact-card{padding:28px}.info-card b,.location-card b{font-size:25px}.location-card a{display:inline-flex;margin-top:8px;color:var(--accent);font-weight:950}.step-card b{width:46px;height:46px;display:grid;place-items:center;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#111112}.split-page{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}.contact-grid{grid-template-columns:1fr 1fr}.vehicle-modal{max-width:920px;width:92vw;border:0;border-radius:34px;background:var(--panel);color:var(--fg);box-shadow:0 30px 120px rgba(0,0,0,.55);padding:26px;overflow:hidden}.vehicle-modal::backdrop{background:rgba(3,7,14,.75);backdrop-filter:blur(7px)}.modal-close{position:absolute;right:18px;top:12px;border:0;background:var(--bg3);color:var(--fg);font-size:33px;line-height:1;border-radius:50%;width:42px;height:42px;cursor:pointer;z-index:4}.spin-preview{height:390px;display:grid;place-items:center;perspective:900px;background:linear-gradient(145deg,#242426,#171719);border:1px solid var(--line);border-radius:27px;margin-bottom:18px}.spin-preview img{max-width:82%;max-height:90%;object-fit:contain;animation:spinVehicle 8s linear infinite;filter:drop-shadow(0 30px 38px rgba(0,0,0,.28))}.spin-preview .vehicle-placeholder{animation:spinVehicle 8s linear infinite;width:54%;height:28%;transform-style:preserve-3d}@keyframes spinVehicle{to{transform:rotateY(360deg)}}footer{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:42px 5vw;border-top:1px solid var(--line);background:#111112}.footer-actions{display:flex;gap:12px;flex-wrap:wrap}.mobile-note{display:none}@media(max-width:1100px){.desktop-nav{display:none}.mobile-note{display:block;color:var(--muted);font-size:12px}.hero,.section-head.split,.split-page{grid-template-columns:1fr}.booking-grid{grid-template-columns:1fr 1fr}.search-btn{grid-column:1/-1}.vehicles-grid,.route-grid{grid-template-columns:repeat(2,1fr)}.trust-row{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:720px){.top-strip{display:none}.site-header{padding:12px 4vw}.header-actions .ghost{display:none}.hero{padding:42px 5vw;min-height:auto}.hero-visual{min-height:360px}.home-booking{margin:0 4vw 16px}.booking-grid,.vehicles-grid,.location-grid,.step-grid,.info-grid,.contact-grid,.route-grid,.trust-row{grid-template-columns:1fr}.booking-tabs{overflow:auto}.page-shell{padding:40px 5vw 60px}h1{font-size:43px}footer{align-items:flex-start;flex-direction:column}.card-actions{flex-direction:column}}

/* Logo oficial optimizado */
.brand-logo-img{width:126px;height:auto;display:block;object-fit:contain;filter:drop-shadow(0 10px 24px rgba(0,0,0,.38));transition:transform .2s ease}
.brand:hover .brand-logo-img{transform:scale(1.03)}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
@media(max-width:720px){.brand-logo-img{width:94px}.brand-text{display:none}.site-header{gap:10px}.header-actions{gap:6px}.btn{padding:0 12px;min-height:42px}}


/* ==========================================================
   TEMA UNIFICADO CAR RENTAL - público y manager igualados
   ========================================================== */
:root{--bg:#0d0d10!important;--bg2:#141416!important;--bg3:#202022!important;--panel:#1b1b1e!important;--panel2:#252529!important;--line:#3b3b40!important;--line2:#56565d!important;--fg:#ffffff!important;--fg2:#e5e2de!important;--muted:#b9b3ad!important;--accent:#ff6946!important;--accent2:#ffcc08!important;--accent3:#f23b3b!important;--ok:#25d366!important;--warn:#ffcc08!important;--radius:24px!important;--shadow:0 24px 70px rgba(0,0,0,.38)!important;--glow:0 0 42px rgba(255,105,70,.16)!important;--brand-gradient:linear-gradient(135deg,#ff6946 0%,#ff8a3d 48%,#ffcc08 100%)}
body{background:radial-gradient(circle at 12% 5%,rgba(255,105,70,.13),transparent 34%),radial-gradient(circle at 90% 8%,rgba(255,204,8,.12),transparent 32%),var(--bg)!important;color:var(--fg)!important;}
.site-header,.top-strip,footer{background:rgba(13,13,16,.92)!important;border-color:var(--line)!important;backdrop-filter:blur(18px)}
.desktop-nav a:hover,.desktop-nav a.active{border-color:var(--accent)!important;color:#fff!important;}
.btn.primary,.booking-tabs .active,.category-strip .active,.step-card b{background:var(--brand-gradient)!important;color:#111112!important;box-shadow:0 16px 34px rgba(255,105,70,.20)!important;}
.btn:not(.primary):hover{border-color:rgba(255,105,70,.45)!important;background:rgba(255,105,70,.08)!important;color:#fff!important;}
.trust-row div,.mini-route-card,.info-card,.location-card,.step-card,.contact-card,.vehicle-inner,.booking-panel,.vehicle-modal,.hero-mini-card{background:linear-gradient(180deg,rgba(32,32,34,.96),rgba(20,20,22,.96))!important;border-color:var(--line)!important;box-shadow:var(--shadow)!important;}
.hero-visual,.vehicle-img,.spin-preview{background:linear-gradient(145deg,#111112,#202022 64%,#2f2f33)!important;border-color:rgba(255,105,70,.24)!important;}
.hero:before{background:linear-gradient(90deg,transparent 0 58%,rgba(255,105,70,.06) 58% 100%)!important;}
input,select,textarea{background:#111112!important;color:#fff!important;border-color:var(--line)!important;}
input:focus,select:focus,textarea:focus{border-color:rgba(255,105,70,.55)!important;box-shadow:0 0 0 3px rgba(255,105,70,.12)!important;outline:none!important;}
.meta span{background:rgba(255,255,255,.045)!important;border-color:var(--line)!important;color:var(--fg2)!important;}
.price,.location-card a,.top-strip a{color:var(--accent)!important;}
.eyebrow,.section-head span,.page-kicker{background:rgba(255,105,70,.09)!important;color:var(--accent)!important;border-color:rgba(255,105,70,.24)!important;}
.vehicle-placeholder:before,.css-car:before{background:linear-gradient(135deg,#ffffff,var(--accent) 70%,#2f2f33)!important;}
.brand-logo-img{filter:drop-shadow(0 12px 24px rgba(0,0,0,.42))!important;}

/* ==========================================================
   UPGRADE DINÁMICO 2026-05-30
   Más movimiento, profundidad, interacción y experiencia premium
   ========================================================== */
body{
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background:
    linear-gradient(115deg,transparent 0 42%,rgba(255,105,70,.055) 42% 43%,transparent 44% 100%),
    radial-gradient(circle at var(--mouse-x,50%) var(--mouse-y,25%),rgba(255,204,8,.12),transparent 26%);
  transition:background-position .2s ease;
}
.dynamic-hero{
  isolation:isolate;
}
.motion-bg{
  position:absolute;
  inset:0;
  overflow:hidden;
  pointer-events:none;
  z-index:1;
}
.motion-bg span{
  position:absolute;
  width:14px;
  height:14px;
  border-radius:999px;
  background:linear-gradient(135deg,rgba(255,105,70,.95),rgba(255,204,8,.75));
  box-shadow:0 0 32px rgba(255,105,70,.35);
  opacity:.55;
  animation:particleDrive 12s linear infinite;
}
.motion-bg span:nth-child(1){left:4%;top:20%;animation-delay:0s;animation-duration:14s}
.motion-bg span:nth-child(2){left:18%;top:72%;animation-delay:-3s;animation-duration:11s;width:9px;height:9px}
.motion-bg span:nth-child(3){left:48%;top:10%;animation-delay:-7s;animation-duration:16s;width:19px;height:19px}
.motion-bg span:nth-child(4){left:74%;top:78%;animation-delay:-2s;animation-duration:13s;width:11px;height:11px}
.motion-bg span:nth-child(5){left:92%;top:28%;animation-delay:-9s;animation-duration:12s;width:16px;height:16px}
@keyframes particleDrive{
  0%{transform:translate3d(-20vw,28px,0) scale(.7);opacity:0}
  15%{opacity:.55}
  50%{transform:translate3d(24vw,-42px,0) scale(1.15)}
  100%{transform:translate3d(112vw,22px,0) scale(.75);opacity:0}
}
.hero-content{
  animation:heroEnter .85s ease both;
}
.hero-visual{
  animation:visualEnter 1s .12s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes heroEnter{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes visualEnter{
  from{opacity:0;transform:translateX(50px) scale(.94) rotateY(-12deg)}
  to{opacity:1;transform:translateX(0) scale(1) rotateY(0)}
}
.hero-visual::after{
  content:"";
  position:absolute;
  inset:-35%;
  background:conic-gradient(from 0deg,transparent,rgba(255,105,70,.18),transparent,rgba(255,204,8,.12),transparent);
  animation:haloSpin 14s linear infinite;
  pointer-events:none;
}
@keyframes haloSpin{to{transform:rotate(360deg)}}
.car-showcase,.hero-card-label,.hero-mini-card,.floating-badge{z-index:5}
.speed-lines{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:4;
  overflow:hidden;
}
.speed-lines span{
  position:absolute;
  width:34%;
  height:2px;
  left:-40%;
  border-radius:999px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),rgba(255,105,70,.8),transparent);
  animation:speedLine 2.7s linear infinite;
}
.speed-lines span:nth-child(1){top:28%;animation-delay:0s}
.speed-lines span:nth-child(2){top:44%;animation-delay:-.7s;width:28%}
.speed-lines span:nth-child(3){top:62%;animation-delay:-1.4s;width:40%}
.speed-lines span:nth-child(4){top:74%;animation-delay:-2s;width:24%}
@keyframes speedLine{
  to{left:115%}
}
.floating-badge{
  position:absolute;
  padding:10px 13px;
  border-radius:999px;
  background:rgba(13,13,16,.74);
  border:1px solid rgba(255,105,70,.32);
  color:#fff;
  font-size:12px;
  font-weight:950;
  backdrop-filter:blur(14px);
  box-shadow:0 18px 40px rgba(0,0,0,.22);
  animation:badgeFloat 4.8s ease-in-out infinite;
}
.badge-one{right:28px;top:96px}
.badge-two{left:32px;bottom:92px;animation-delay:-2.1s}
@keyframes badgeFloat{
  50%{transform:translateY(-14px) translateX(6px)}
}
.css-car{
  animation:floatCar 5s ease-in-out infinite, carGlow 2.6s ease-in-out infinite!important;
}
@keyframes carGlow{
  50%{filter:drop-shadow(0 0 28px rgba(255,105,70,.32))}
}
.wheel{
  animation:wheelSpin 1.8s linear infinite;
}
@keyframes wheelSpin{to{transform:rotate(360deg)}}
.orbit-one{animation:orbitSpin 9s linear infinite}
.orbit-two{animation:orbitSpinReverse 7s linear infinite}
@keyframes orbitSpin{to{transform:rotateX(68deg) rotateZ(350deg)}}
@keyframes orbitSpinReverse{to{transform:rotateX(70deg) rotateZ(-335deg)}}
.scroll-cue{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--muted);
  font-weight:900;
  font-size:12px;
  margin-top:18px;
  letter-spacing:.02em;
}
.scroll-cue span{
  width:18px;
  height:30px;
  border:2px solid rgba(255,255,255,.25);
  border-radius:999px;
  position:relative;
}
.scroll-cue span::after{
  content:"";
  position:absolute;
  left:50%;top:6px;
  width:4px;height:7px;
  border-radius:999px;
  background:var(--accent);
  transform:translateX(-50%);
  animation:scrollDot 1.35s ease-in-out infinite;
}
@keyframes scrollDot{
  80%{top:15px;opacity:.25}
}
.motion-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  padding:8px 5vw 30px;
}
.stat-card{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,105,70,.18);
  border-radius:28px;
  padding:24px;
  background:linear-gradient(180deg,rgba(32,32,34,.88),rgba(17,17,18,.92));
  box-shadow:0 20px 60px rgba(0,0,0,.28);
  transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease;
}
.stat-card::before{
  content:"";
  position:absolute;
  inset:-60% auto auto -45%;
  width:70%;
  aspect-ratio:1;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,105,70,.22),transparent 66%);
  animation:pulseOrb 4.4s ease-in-out infinite;
}
.stat-card:hover{
  transform:translateY(-7px) scale(1.015);
  border-color:rgba(255,105,70,.55);
  box-shadow:0 28px 80px rgba(0,0,0,.36),0 0 42px rgba(255,105,70,.16);
}
.stat-card strong{
  position:relative;
  display:block;
  font-size:clamp(36px,5vw,58px);
  line-height:1;
  letter-spacing:-.07em;
  color:var(--accent);
}
.stat-card span{
  position:relative;
  display:block;
  margin-top:8px;
  color:var(--fg2);
  font-weight:850;
}
@keyframes pulseOrb{50%{transform:scale(1.22);opacity:.7}}
.reveal-on-scroll{
  opacity:0;
  transform:translateY(34px);
  transition:opacity .72s ease,transform .72s cubic-bezier(.2,.8,.2,1);
}
.reveal-on-scroll.is-visible{
  opacity:1;
  transform:translateY(0);
}
.magnetic-card{
  transform-style:preserve-3d;
}
.trust-row div,.mini-route-card,.vehicle-inner,.booking-panel{
  position:relative;
  overflow:hidden;
}
.trust-row div::after,.mini-route-card::after,.vehicle-inner::after,.booking-panel::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent 0 35%,rgba(255,255,255,.11) 46%,transparent 58% 100%);
  transform:translateX(-120%);
  transition:transform .8s ease;
  pointer-events:none;
}
.trust-row div:hover::after,.mini-route-card:hover::after,.vehicle-inner:hover::after,.booking-panel:hover::after{
  transform:translateX(120%);
}
.btn.primary{
  position:relative;
  overflow:hidden;
}
.btn.primary::after{
  content:"";
  position:absolute;
  inset:-2px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);
  transform:translateX(-115%);
  transition:transform .55s ease;
}
.btn.primary:hover::after{transform:translateX(115%)}
.desktop-nav a{
  position:relative;
}
.desktop-nav a::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:4px;
  height:2px;
  border-radius:999px;
  background:var(--brand-gradient);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .24s ease;
}
.desktop-nav a:hover::after{transform:scaleX(1)}
.home-booking:hover{
  box-shadow:0 30px 90px rgba(0,0,0,.38),0 0 38px rgba(255,105,70,.14)!important;
}
@media(max-width:900px){
  .motion-stats{grid-template-columns:repeat(3,minmax(0,1fr));padding-top:20px}
  .floating-badge{display:none}
}
@media(max-width:720px){
  .motion-stats{grid-template-columns:1fr}
}


/* ==========================================================
   CARRUSEL DE VEHÍCULOS FLOTANTES
   Imágenes transparentes, transición automática y efecto premium
   ========================================================== */
.floating-car-section{
  position:relative;
  padding:86px 5vw 42px;
  overflow:hidden;
}
.floating-car-section::before{
  content:"";
  position:absolute;
  inset:9% 5% 6%;
  border-radius:42px;
  background:
    radial-gradient(circle at 22% 30%,rgba(255,105,70,.18),transparent 35%),
    radial-gradient(circle at 78% 54%,rgba(255,204,8,.12),transparent 38%);
  filter:blur(24px);
  pointer-events:none;
}
.floating-carousel{
  position:relative;
  max-width:1180px;
  margin:38px auto 0;
  display:grid;
  grid-template-columns:62px minmax(0,1fr) 62px;
  align-items:center;
  gap:18px;
}
.floating-car-stage{
  position:relative;
  min-height:540px;
  border:1px solid rgba(255,105,70,.22);
  border-radius:38px;
  background:
    linear-gradient(135deg,rgba(255,255,255,.075),rgba(255,255,255,.018)),
    radial-gradient(circle at 50% 38%,rgba(255,105,70,.16),transparent 44%),
    linear-gradient(180deg,rgba(15,27,46,.86),rgba(8,13,24,.96));
  box-shadow:0 34px 110px rgba(0,0,0,.44),0 0 54px rgba(255,105,70,.12);
  overflow:hidden;
  display:grid;
  place-items:center;
  padding:42px;
}
.floating-car-stage::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,transparent 0 46%,rgba(255,255,255,.05) 47% 48%,transparent 49% 100%),
    repeating-linear-gradient(90deg,rgba(255,255,255,.035) 0 1px,transparent 1px 74px);
  mask-image:linear-gradient(to bottom,transparent,black 18%,black 80%,transparent);
  opacity:.45;
  animation:roadGrid 8s linear infinite;
}
.floating-car-stage::after{
  content:"";
  position:absolute;
  left:8%;
  right:8%;
  bottom:25%;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.38),transparent);
}
@keyframes roadGrid{to{background-position:74px 0,74px 0}}
.car-glow{
  position:absolute;
  width:min(48vw,500px);
  height:235px;
  border-radius:50%;
  background:rgba(255,105,70,.20);
  filter:blur(58px);
  animation:pulseFloatingGlow 3.2s ease-in-out infinite alternate;
}
.car-ring{
  position:absolute;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.10);
  filter:drop-shadow(0 0 18px rgba(255,105,70,.15));
  pointer-events:none;
}
.car-ring-one{
  width:620px;
  height:620px;
  animation:ringSpin 18s linear infinite;
}
.car-ring-two{
  width:430px;
  height:430px;
  border-color:rgba(255,204,8,.15);
  animation:ringSpin 13s linear infinite reverse;
}
.floating-car-image{
  position:relative;
  z-index:3;
  width:min(720px,88%);
  max-height:340px;
  object-fit:contain;
  filter:drop-shadow(0 36px 34px rgba(0,0,0,.58));
  animation:floatingVehicle 3.25s ease-in-out infinite;
  transition:opacity .34s ease,transform .48s cubic-bezier(.2,.8,.2,1),filter .34s ease;
}
.floating-car-image.is-changing{
  opacity:0;
  transform:translateX(58px) scale(.94) rotateY(18deg);
  filter:blur(8px) drop-shadow(0 36px 34px rgba(0,0,0,.58));
}
.car-shadow{
  position:absolute;
  z-index:2;
  width:min(470px,62%);
  height:58px;
  bottom:148px;
  border-radius:50%;
  background:rgba(0,0,0,.45);
  filter:blur(18px);
  animation:floatingVehicleShadow 3.25s ease-in-out infinite;
}
.floating-car-info{
  position:absolute;
  z-index:5;
  left:34px;
  bottom:34px;
  max-width:440px;
  padding:22px;
  border-radius:26px;
  background:rgba(8,13,24,.72);
  border:1px solid rgba(255,255,255,.11);
  backdrop-filter:blur(18px);
  box-shadow:0 22px 58px rgba(0,0,0,.36);
}
.floating-car-info span{
  display:inline-block;
  color:var(--accent2);
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.78rem;
  margin-bottom:8px;
}
.floating-car-info h3{
  margin:0 0 8px;
  color:#fff;
  font-size:clamp(25px,3vw,38px);
  line-height:1;
}
.floating-car-info p{
  margin:0 0 18px;
  color:rgba(255,255,255,.76);
  line-height:1.55;
}
.car-arrow{
  position:relative;
  z-index:6;
  width:58px;
  height:58px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  cursor:pointer;
  color:#fff;
  font-size:2.4rem;
  line-height:1;
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(12px);
  transition:transform .22s ease,background .22s ease,border-color .22s ease;
}
.car-arrow:hover{
  transform:scale(1.08);
  background:rgba(255,105,70,.24);
  border-color:rgba(255,105,70,.48);
}
.car-dots{
  position:relative;
  z-index:4;
  display:flex;
  justify-content:center;
  gap:10px;
  margin-top:24px;
}
.car-dot{
  width:10px;
  height:10px;
  border:0;
  border-radius:999px;
  cursor:pointer;
  background:rgba(255,255,255,.28);
  transition:width .24s ease,background .24s ease,transform .24s ease;
}
.car-dot:hover{transform:scale(1.15)}
.car-dot.active{
  width:36px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
}
@keyframes floatingVehicle{
  0%,100%{transform:translateY(0) rotateZ(-.4deg)}
  50%{transform:translateY(-20px) rotateZ(.45deg)}
}
@keyframes floatingVehicleShadow{
  0%,100%{transform:scale(1);opacity:.44}
  50%{transform:scale(.82);opacity:.26}
}
@keyframes pulseFloatingGlow{
  from{transform:scale(.95);opacity:.58}
  to{transform:scale(1.09);opacity:.9}
}
@keyframes ringSpin{to{transform:rotate(360deg)}}
@media(max-width:900px){
  .floating-carousel{grid-template-columns:1fr}
  .car-arrow{position:absolute;top:43%;transform:translateY(-50%)}
  .car-arrow:hover{transform:translateY(-50%) scale(1.08)}
  .car-arrow.prev{left:14px}
  .car-arrow.next{right:14px}
  .floating-car-stage{min-height:585px;padding:26px}
  .floating-car-info{left:18px;right:18px;bottom:22px;max-width:none}
  .car-shadow{bottom:214px;width:280px}
  .floating-car-image{width:92%;max-height:285px;margin-top:-80px}
}
@media(max-width:560px){
  .floating-car-section{padding-top:58px}
  .floating-car-stage{min-height:610px;border-radius:30px}
  .car-ring-one{width:460px;height:460px}
  .car-ring-two{width:310px;height:310px}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal-on-scroll{opacity:1!important;transform:none!important}
}

/* ==========================================================
   VIDEO EN CARRUSEL DE VEHÍCULOS
   ========================================================== */
.floating-car-media-wrap{
  position:relative;
  z-index:3;
  width:100%;
  min-height:380px;
  display:grid;
  place-items:center;
}
.floating-car-media-wrap .car-shadow{
  bottom:18px;
}
.floating-car-image,
.floating-car-video{
  position:relative;
  z-index:4;
  width:min(760px,90%);
  max-height:385px;
  object-fit:contain;
  border-radius:22px;
  filter:drop-shadow(0 36px 34px rgba(0,0,0,.52));
  animation:floatingVehicle 3.25s ease-in-out infinite;
  transition:opacity .34s ease,transform .48s cubic-bezier(.2,.8,.2,1),filter .34s ease;
}
.floating-car-video{
  background:transparent;
  outline:none;
  pointer-events:none;
}
.floating-car-video::-webkit-media-controls,
.floating-car-video::-webkit-media-controls-enclosure,
.floating-car-video::-webkit-media-controls-panel{
  display:none!important;
  opacity:0!important;
}
.floating-car-image.is-changing,
.floating-car-video.is-changing{
  opacity:0;
  transform:translateX(38px) scale(.96) rotateY(12deg);
  filter:blur(7px) drop-shadow(0 36px 34px rgba(0,0,0,.52));
}
.car-info-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
.video-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
}
.video-modal.open{display:block}
.video-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.76);
  backdrop-filter:blur(10px);
}
.video-modal-panel{
  position:relative;
  z-index:2;
  width:min(980px,92vw);
  margin:5vh auto;
  padding:18px;
  border-radius:28px;
  background:rgba(12,16,26,.96);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 32px 90px rgba(0,0,0,.52);
}
.video-modal-panel video{
  width:100%;
  max-height:80vh;
  display:block;
  border-radius:20px;
  background:#000;
}
.video-close{
  position:absolute;
  z-index:4;
  top:10px;
  right:12px;
  width:42px;
  height:42px;
  border:0;
  border-radius:999px;
  cursor:pointer;
  font-size:1.7rem;
  color:#fff;
  background:rgba(255,255,255,.14);
  box-shadow:0 10px 24px rgba(0,0,0,.28);
}
.video-close:hover{background:rgba(255,255,255,.24)}
@media (max-width:850px){
  .floating-car-media-wrap{min-height:300px}
  .floating-car-image,
  .floating-car-video{width:96%;max-height:285px;margin-top:-50px}
  .floating-car-media-wrap .car-shadow{bottom:30px}
}

/* ==========================================================
   KIA RIO VIBRANT · INICIO + CATÁLOGO + CARRUSEL
   Integración visual premium solicitada 2026-05-31
   ========================================================== */
.kia-hero-visual{
  min-height:620px;
  display:grid;
  place-items:center;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  overflow:visible!important;
  padding:0!important;
  isolation:isolate;
}
.kia-hero-visual::after{
  opacity:.45;
  filter:blur(22px);
}
.kia-hero-car-wrap{
  position:relative;
  width:min(760px,100%);
  min-height:430px;
  display:grid;
  place-items:center;
  z-index:7;
  transform-style:preserve-3d;
}
.kia-hero-car{
  width:min(760px,112%);
  max-width:none;
  position:relative;
  z-index:4;
  object-fit:contain;
  filter:drop-shadow(0 34px 36px rgba(0,0,0,.62)) drop-shadow(0 0 30px rgba(255,105,70,.09));
  animation:kiaHeroFloat 5.5s ease-in-out infinite;
}
.kia-hero-shadow{
  position:absolute;
  left:13%;
  right:8%;
  bottom:54px;
  height:72px;
  border-radius:50%;
  background:radial-gradient(ellipse,rgba(255,255,255,.38),rgba(255,105,70,.14) 34%,rgba(0,0,0,.62) 62%,transparent 74%);
  filter:blur(13px);
  z-index:1;
}
.kia-spec-panel{
  position:absolute;
  left:clamp(12px,2vw,30px);
  bottom:clamp(18px,4vw,48px);
  width:min(430px,92%);
  z-index:8;
  padding:22px;
  border-radius:30px;
  background:linear-gradient(180deg,rgba(20,20,22,.82),rgba(12,12,14,.62));
  border:1px solid rgba(255,105,70,.28);
  backdrop-filter:blur(16px);
  box-shadow:0 26px 80px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.08);
}
.kia-spec-panel .clean-label{
  position:static;
  margin-bottom:12px;
  width:max-content;
  display:inline-flex;
  background:rgba(255,105,70,.12)!important;
}
.kia-spec-panel h2{
  margin:0 0 16px;
  font-size:clamp(28px,3.7vw,48px);
  letter-spacing:-.07em;
}
.kia-spec-panel h2 strong{
  color:var(--accent);
}
.kia-spec-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:11px;
}
.kia-spec-grid span{
  display:flex;
  align-items:center;
  gap:9px;
  min-height:46px;
  padding:10px 12px;
  border-radius:16px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.09);
  color:var(--fg);
  font-weight:900;
}
.kia-spec-grid b{
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:rgba(255,105,70,.12);
  border:1px solid rgba(255,105,70,.32);
  color:var(--accent);
  font-size:14px;
}
.kia-spec-panel small{
  display:block;
  margin-top:14px;
  color:var(--muted);
  font-weight:850;
}
@keyframes kiaHeroFloat{
  50%{transform:translateY(-15px) rotateY(5deg) scale(1.015)}
}
.home-catalog-section{
  padding:24px 5vw 26px;
  position:relative;
}
.home-catalog-section::before{
  content:"";
  position:absolute;
  inset:12% 5% 0;
  border-radius:46px;
  background:radial-gradient(circle at 16% 30%,rgba(255,105,70,.16),transparent 32%),radial-gradient(circle at 85% 38%,rgba(255,204,8,.095),transparent 34%);
  filter:blur(24px);
  pointer-events:none;
}
.home-catalog-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1.15fr repeat(3,1fr);
  gap:18px;
  align-items:stretch;
}
.home-car-card{
  min-height:315px;
  padding:18px;
  border-radius:30px;
  background:linear-gradient(180deg,rgba(32,32,34,.88),rgba(14,14,16,.94));
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 28px 80px rgba(0,0,0,.32);
  position:relative;
  overflow:hidden;
  transition:border-color .22s ease, box-shadow .22s ease, transform .22s ease;
}
.home-car-card:hover{
  border-color:rgba(255,105,70,.48);
  box-shadow:0 34px 90px rgba(0,0,0,.42),0 0 38px rgba(255,105,70,.13);
}
.home-car-card::before{
  content:"";
  position:absolute;
  inset:auto 8% 86px;
  height:58px;
  border-radius:50%;
  background:radial-gradient(ellipse,rgba(255,255,255,.24),rgba(255,105,70,.11),transparent 70%);
  filter:blur(10px);
}
.home-car-card img{
  position:relative;
  display:block;
  width:100%;
  height:170px;
  object-fit:contain;
  margin:0 auto 12px;
  filter:drop-shadow(0 22px 24px rgba(0,0,0,.48));
  z-index:2;
}
.home-car-card.featured{
  border-color:rgba(255,105,70,.54);
  background:linear-gradient(180deg,rgba(42,31,27,.94),rgba(13,13,15,.96));
}
.home-car-card.featured img{
  height:205px;
  width:112%;
  margin-left:-5%;
}
.featured-ribbon{
  position:absolute;
  right:14px;
  top:14px;
  z-index:4;
  padding:7px 11px;
  border-radius:999px;
  color:#111112;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  font-weight:950;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.home-car-card h3{
  position:relative;
  z-index:2;
  margin:0 0 12px;
  font-size:21px;
}
.home-car-meta{
  position:relative;
  z-index:2;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.home-car-meta span{
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.095);
  color:var(--fg2);
  font-size:12px;
  font-weight:900;
}
.home-car-card .btn{
  position:relative;
  z-index:3;
  margin-top:16px;
  width:100%;
}
.floating-car-image[src*="kia-rio-vibrant"]{
  width:min(980px,108%);
  max-height:390px;
  object-fit:contain;
  filter:drop-shadow(0 34px 38px rgba(0,0,0,.58)) drop-shadow(0 0 26px rgba(255,105,70,.13));
}
.btn.is-disabled,
.btn:disabled{
  opacity:.58;
  cursor:not-allowed;
  transform:none!important;
  box-shadow:none!important;
}
@media(max-width:1100px){
  .kia-hero-visual{min-height:560px}
  .kia-spec-panel{position:relative;left:auto;bottom:auto;margin-top:-26px;width:100%}
  .kia-hero-car-wrap{min-height:360px}
  .home-catalog-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:720px){
  .kia-hero-visual{min-height:auto;gap:0;padding-top:18px!important}
  .kia-hero-car-wrap{min-height:260px;width:112%;margin-left:-6%}
  .kia-hero-car{width:120%}
  .kia-spec-panel{padding:18px;border-radius:24px}
  .kia-spec-grid{grid-template-columns:1fr}
  .home-catalog-section{padding-top:50px}
  .home-catalog-grid{grid-template-columns:1fr}
}


/* ==========================================================
   MODELO 3D GLB · KIA RIO VIBRANT
   Visor real con model-viewer para inicio y modal de vehículos
   ========================================================== */
.kia-hero-model{
  width:min(820px,118%);
  height:470px;
  max-width:none;
  position:relative;
  z-index:4;
  background:transparent;
  --poster-color:transparent;
  filter:drop-shadow(0 34px 38px rgba(0,0,0,.62)) drop-shadow(0 0 30px rgba(255,105,70,.1));
  animation:kiaHeroFloat 5.5s ease-in-out infinite;
}
.kia-hero-model::part(default-progress-bar){
  height:3px;
  background-color:rgba(255,105,70,.85);
}
.kia-hero-fallback{
  width:100%;
  height:100%;
  object-fit:contain;
}
.kia-hero-car-wrap car-glb-viewer{
  cursor:grab;
}
.kia-hero-car-wrap car-glb-viewer:active{
  cursor:grabbing;
}
.vehicle-modal-model{
  width:min(900px,100%);
  height:440px;
  display:block;
  margin:auto;
  border-radius:28px;
  background:radial-gradient(circle at 50% 72%,rgba(255,255,255,.12),rgba(255,105,70,.08) 25%,transparent 62%);
  --poster-color:transparent;
}
.spin-preview.has-3d-model{
  min-height:460px;
  background:radial-gradient(circle at 50% 75%,rgba(255,255,255,.12),rgba(255,105,70,.07) 32%,transparent 70%);
}
@media(max-width:1100px){
  .kia-hero-model{height:390px;width:115%}
  .vehicle-modal-model{height:380px}
}
@media(max-width:720px){
  .kia-hero-model{height:300px;width:128%}
  .vehicle-modal-model{height:310px}
  .spin-preview.has-3d-model{min-height:330px}
}


/* FIX 3D Kia Rio: inicio gira lento, catálogo/carrusel imagen fija, detalles interactivo */
.kia-hero-visual{
  overflow:visible!important;
}
.kia-hero-car-wrap{
  position:relative;
  z-index:2;
  width:100%;
  min-height:500px;
  display:grid;
  place-items:center;
  overflow:visible;
}
.kia-hero-model{
  width:min(900px,122%)!important;
  height:520px!important;
  display:block!important;
  background:transparent!important;
  --poster-color:transparent;
  filter:drop-shadow(0 36px 40px rgba(0,0,0,.62)) drop-shadow(0 0 35px rgba(255,105,70,.12));
}
.kia-hero-model img{
  width:100%;
  height:100%;
  object-fit:contain;
}
.kia-hero-shadow{
  position:absolute;
  left:13%;
  right:10%;
  bottom:52px;
  height:70px;
  border-radius:999px;
  background:radial-gradient(ellipse, rgba(255,255,255,.22), rgba(255,105,70,.11) 36%, transparent 72%);
  filter:blur(16px);
  pointer-events:none;
}
.home-card-actions{
  position:relative;
  z-index:4;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:10px;
  margin-top:16px;
}
.home-card-actions .btn{margin-top:0!important;width:100%;}
.vehicle-modal::backdrop{background:rgba(0,0,0,.74);backdrop-filter:blur(12px);}
.home-vehicle-modal{max-width:min(980px,92vw);}

@media(max-width:1100px){.kia-hero-model{height:420px!important;width:118%!important}.kia-hero-car-wrap{min-height:410px}.home-card-actions{grid-template-columns:1fr}}
@media(max-width:720px){.kia-hero-model{height:310px!important;width:132%!important}.kia-hero-car-wrap{min-height:310px}.kia-hero-shadow{bottom:34px}}


/* FIX LOCAL 3D: visor GLB propio sin CDN */
car-glb-viewer{display:block;contain:content;}
.kia-hero-model{background:transparent!important;}
.kia-hero-model::part(canvas), .vehicle-modal-model::part(canvas){background:transparent!important;}
.kia-hero-fallback{display:none!important;}
.spin-preview:has(car-glb-viewer), .spin-preview.has-3d-model{min-height:460px;background:radial-gradient(circle at 50% 75%,rgba(255,255,255,.12),rgba(255,105,70,.07) 32%,transparent 70%);}
@media(max-width:720px){.spin-preview:has(car-glb-viewer), .spin-preview.has-3d-model{min-height:330px}}

/* ==========================================================
   FIX PERFORMANCE + UI 3D COLORFAST
   - Inicio más liviano: sin autoplay de videos.
   - Panel de especificaciones compacto para no tapar el carro.
   - Visor GLB con texturas reales y canvas transparente.
   ========================================================== */
.floating-car-video{display:none!important;}
.floating-car-image{display:block;object-fit:contain!important;}
.kia-hero-car-wrap{min-height:455px!important;align-items:center!important;}
.kia-hero-model{height:455px!important;width:min(820px,118%)!important;filter:drop-shadow(0 34px 42px rgba(0,0,0,.60)) drop-shadow(0 0 22px rgba(255,105,70,.10))!important;}
.kia-spec-panel{
  left:auto!important;
  right:18px!important;
  bottom:18px!important;
  width:min(310px,42%)!important;
  padding:14px!important;
  border-radius:22px!important;
  background:linear-gradient(180deg,rgba(13,13,15,.72),rgba(13,13,15,.48))!important;
  backdrop-filter:blur(10px)!important;
  box-shadow:0 16px 48px rgba(0,0,0,.28),inset 0 1px 0 rgba(255,255,255,.06)!important;
}
.kia-spec-panel .clean-label{font-size:10px!important;padding:7px 10px!important;margin-bottom:8px!important;}
.kia-spec-panel h2{font-size:clamp(20px,2.1vw,30px)!important;margin:0 0 10px!important;letter-spacing:-.055em!important;}
.kia-spec-grid{gap:7px!important;}
.kia-spec-grid span{min-height:34px!important;padding:7px 8px!important;border-radius:12px!important;font-size:11px!important;gap:7px!important;}
.kia-spec-grid b{width:22px!important;height:22px!important;font-size:11px!important;}
.kia-spec-panel small{display:none!important;}
car-glb-viewer{background:transparent!important;}
car-glb-viewer::part(canvas){background:transparent!important;}
.vehicle-modal-model{height:430px!important;background:transparent!important;}
.spin-preview.has-3d-model{background:radial-gradient(circle at 50% 78%,rgba(255,255,255,.10),rgba(255,105,70,.055) 34%,transparent 70%)!important;}
@media(max-width:1100px){
  .kia-hero-car-wrap{min-height:400px!important;}
  .kia-hero-model{height:400px!important;width:116%!important;}
  .kia-spec-panel{position:relative!important;right:auto!important;bottom:auto!important;width:100%!important;margin:-28px auto 0!important;max-width:520px!important;}
  .kia-spec-panel small{display:block!important;font-size:11px;}
}
@media(max-width:720px){
  .kia-hero-car-wrap{min-height:300px!important;}
  .kia-hero-model{height:300px!important;width:130%!important;}
  .kia-spec-panel{padding:12px!important;border-radius:18px!important;margin-top:-20px!important;}
  .kia-spec-grid{grid-template-columns:1fr 1fr!important;}
  .kia-spec-grid span{font-size:10.5px!important;}
  .vehicle-modal-model{height:320px!important;}
}


/* FAST VEHICLES PATCH 2026-05-31 */
.vehicle-img img{content-visibility:auto;}
.spin-preview.is-loading{min-height:360px;display:grid;place-items:center;text-align:center;gap:8px;color:#fff;background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.08);border-radius:22px;}
.spin-preview.is-loading small{display:block;color:rgba(255,255,255,.62);font-weight:500;margin-top:6px;}
.vehicle-modal-model{min-height:420px;}
@media (max-width: 760px){.spin-preview.is-loading{min-height:280px}.vehicle-modal-model{min-height:320px}}

/* ==========================================================
   AMPLIACIÓN VISTA 3D EN CATÁLOGO / MODAL
   - El modal ocupa más pantalla.
   - El modelo 3D queda mucho más grande.
   - La ficha de información baja y no tapa la visualización.
   ========================================================== */
.vehicle-modal{
  width:min(96vw,1280px)!important;
  max-width:min(96vw,1280px)!important;
  max-height:94vh!important;
  padding:18px 22px 22px!important;
  border-radius:34px!important;
}
.vehicle-modal #modalContent{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:14px!important;
}
.vehicle-modal .spin-preview.has-3d-model,
.vehicle-modal .spin-preview:has(car-glb-viewer){
  height:min(68vh,720px)!important;
  min-height:610px!important;
  margin:0 0 8px!important;
  border-radius:30px!important;
  overflow:visible!important;
  background:radial-gradient(circle at 50% 78%,rgba(255,255,255,.12),rgba(255,105,70,.07) 34%,transparent 72%)!important;
}
.vehicle-modal .vehicle-modal-model{
  width:100%!important;
  height:100%!important;
  min-height:610px!important;
  max-width:1180px!important;
  margin:0 auto!important;
  transform:scale(1.08)!important;
  transform-origin:center center!important;
}
.vehicle-modal .eyebrow{
  width:max-content!important;
  margin-top:0!important;
}
.vehicle-modal h2{
  font-size:clamp(28px,3.2vw,48px)!important;
  margin:0!important;
}
.vehicle-modal p{
  margin:0!important;
}
.vehicle-modal .meta{
  margin:8px 0!important;
}
.vehicle-modal .price{
  margin-top:0!important;
}
.vehicle-modal .card-actions{
  margin-top:10px!important;
  max-width:520px!important;
}

/* Tarjeta del catálogo un poco más amplia para que el carro fijo respire mejor */
.vehicles-grid{
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr))!important;
}
.vehicle-img{
  height:250px!important;
}
.vehicle-img img{
  object-fit:contain!important;
  padding:8px!important;
}

@media(max-width:900px){
  .vehicle-modal{
    width:96vw!important;
    max-height:94vh!important;
    padding:14px!important;
  }
  .vehicle-modal .spin-preview.has-3d-model,
  .vehicle-modal .spin-preview:has(car-glb-viewer){
    height:58vh!important;
    min-height:430px!important;
  }
  .vehicle-modal .vehicle-modal-model{
    min-height:430px!important;
    transform:scale(1.03)!important;
  }
  .vehicle-img{height:230px!important;}
}
@media(max-width:560px){
  .vehicle-modal .spin-preview.has-3d-model,
  .vehicle-modal .spin-preview:has(car-glb-viewer){
    height:48vh!important;
    min-height:340px!important;
  }
  .vehicle-modal .vehicle-modal-model{
    min-height:340px!important;
    transform:scale(1.02)!important;
  }
  .vehicle-img{height:210px!important;}
}

/* ==========================================================
   MULTI 3D HERO PROFESIONAL 2026-05-31
   - Inicio con carrusel de modelos 3D, un GLB activo a la vez.
   - Visualización más amplia: el modelo ocupa más área y no queda pequeño.
   - Catálogo/carrusel con imágenes fijas para mantener velocidad.
   ========================================================== */
.hero.dynamic-hero{
  grid-template-columns:minmax(380px,.82fr) minmax(620px,1.28fr)!important;
  align-items:center!important;
  gap:clamp(18px,3vw,54px)!important;
}
.kia-hero-visual{
  min-height:620px!important;
  padding:8px 0 0!important;
  overflow:visible!important;
}
.hero-3d-carousel-wrap,
.kia-hero-car-wrap{
  width:112%!important;
  margin-left:-8%!important;
  min-height:570px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:visible!important;
}
.hero-3d-model,
.kia-hero-model{
  width:min(1120px,128%)!important;
  height:560px!important;
  max-width:none!important;
  opacity:1;
  transition:opacity .24s ease, transform .24s ease, filter .24s ease!important;
}
.hero-3d-model.is-switching{
  opacity:.36;
  transform:scale(.985)!important;
  filter:blur(1.2px) drop-shadow(0 30px 40px rgba(0,0,0,.55))!important;
}
.hero-3d-spec-panel.kia-spec-panel{
  right:10px!important;
  bottom:20px!important;
  width:min(292px,34%)!important;
  max-width:292px!important;
  padding:12px!important;
}
.hero-3d-spec-panel .kia-spec-grid{
  grid-template-columns:1fr 1fr!important;
}
.hero-3d-dots{
  display:flex;
  gap:7px;
  align-items:center;
  margin:9px 0 0;
}
.hero-3d-dot{
  width:23px;
  height:6px;
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.22);
  cursor:pointer;
  transition:width .2s ease,background .2s ease,box-shadow .2s ease;
}
.hero-3d-dot.active{
  width:42px;
  background:var(--accent);
  box-shadow:0 0 18px rgba(255,105,70,.36);
}
.home-car-card.featured-soft{
  border-color:rgba(255,105,70,.38)!important;
  box-shadow:0 18px 50px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.06)!important;
}
.home-card-actions.compact-actions{
  grid-template-columns:1fr!important;
  margin-top:10px!important;
}
.floating-car-stage .floating-car-image[src*="kia-picanto"]{
  width:min(760px,92%)!important;
  max-height:320px!important;
  border-radius:20px!important;
  object-fit:cover!important;
}
@media(max-width:1180px){
  .hero.dynamic-hero{grid-template-columns:1fr!important;}
  .kia-hero-visual{min-height:560px!important;}
  .hero-3d-carousel-wrap,.kia-hero-car-wrap{width:116%!important;margin-left:-8%!important;min-height:470px!important;}
  .hero-3d-model,.kia-hero-model{height:465px!important;width:124%!important;}
  .hero-3d-spec-panel.kia-spec-panel{position:relative!important;right:auto!important;bottom:auto!important;width:min(560px,94%)!important;max-width:560px!important;margin:-40px auto 0!important;}
}
@media(max-width:720px){
  .kia-hero-visual{min-height:500px!important;}
  .hero-3d-carousel-wrap,.kia-hero-car-wrap{min-height:335px!important;width:132%!important;margin-left:-16%!important;}
  .hero-3d-model,.kia-hero-model{height:335px!important;width:140%!important;}
  .hero-3d-spec-panel.kia-spec-panel{margin:-20px auto 0!important;width:96%!important;}
  .hero-3d-spec-panel .kia-spec-grid{grid-template-columns:1fr 1fr!important;}
}

/* ==========================================================
   FIX PERFORMANCE/UI 2026-05-31 · Catálogo limpio + 3D liviano
   ========================================================== */
.motion-bg,
.speed-lines,
.car-glow,
.car-ring,
.floating-badge,
.hero-card-label.clean-label{
  display:none!important;
}
body::before,
body::after,
.hero::before,
.hero::after,
.kia-hero-visual::before,
.kia-hero-visual::after,
.floating-car-stage::before,
.floating-car-stage::after{
  filter:none!important;
  animation:none!important;
}
.kia-hero-visual{
  background:transparent!important;
  box-shadow:none!important;
}
.kia-hero-shadow,
.car-shadow{
  opacity:.42!important;
  filter:blur(18px)!important;
}
.hero-3d-spec-panel.kia-spec-panel{
  width:min(250px,30%)!important;
  max-width:250px!important;
  padding:10px!important;
  border-radius:16px!important;
  background:rgba(13,14,18,.72)!important;
  backdrop-filter:blur(10px)!important;
}
.hero-3d-spec-panel h2{
  font-size:clamp(18px,1.7vw,27px)!important;
  line-height:1.02!important;
  margin-bottom:8px!important;
}
.hero-3d-spec-panel .kia-spec-grid{
  gap:6px!important;
}
.hero-3d-spec-panel .kia-spec-grid span{
  padding:7px 8px!important;
  font-size:11px!important;
  border-radius:10px!important;
}
.hero-3d-dots{
  margin-top:8px!important;
}
.hero-3d-dot{
  height:5px!important;
  box-shadow:none!important;
}
.hero-3d-model,
.kia-hero-model{
  filter:drop-shadow(0 24px 26px rgba(0,0,0,.45))!important;
}
.home-car-card,
.vehicle-card .vehicle-inner,
.floating-car-stage{
  transform:none!important;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease!important;
}
.home-car-card:hover,
.vehicle-card .vehicle-inner:hover,
.floating-car-stage:hover{
  transform:none!important;
}
.home-card-actions,
.card-actions,
.car-info-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:10px!important;
}
.home-card-actions .btn,
.card-actions .btn,
.car-info-actions .btn{
  justify-content:center!important;
  min-height:42px!important;
  padding-inline:12px!important;
}
.vehicle-card .vehicle-img img,
.home-car-card img,
.floating-car-image{
  object-fit:contain!important;
}
.vehicle-modal .spin-preview.has-3d-model.is-loading{
  min-height:72vh!important;
  background:rgba(255,255,255,.025)!important;
}
@media(max-width:1180px){
  .hero-3d-spec-panel.kia-spec-panel{
    width:min(520px,94%)!important;
    max-width:520px!important;
  }
}
@media(max-width:720px){
  .home-card-actions,.card-actions,.car-info-actions{grid-template-columns:1fr!important;}
  .hero-3d-spec-panel.kia-spec-panel{width:96%!important;max-width:none!important;}
}

/* ==========================================================
   SIN 3D · GALERÍAS Y TARJETAS GIRATORIAS
   ========================================================== */
.hero-gallery-wrap{width:min(94%,720px);min-height:420px;display:grid;place-items:center;position:relative;z-index:2;}
.hero-gallery-image{width:min(760px,116%)!important;height:auto!important;max-height:450px;object-fit:contain;filter:drop-shadow(0 34px 42px rgba(0,0,0,.60));transition:opacity .18s ease,transform .24s ease;}
.hero-gallery-image.is-switching{opacity:.18;transform:translateY(8px) scale(.985);}
.hero-gallery-spec-panel{z-index:5;}
.vehicle-card.flip-card{perspective:1400px;min-height:565px;}
.vehicle-card.flip-card .vehicle-inner{position:relative;min-height:565px;padding:0;overflow:visible;transition:transform .65s cubic-bezier(.2,.7,.2,1);transform-style:preserve-3d;}
.vehicle-card.flip-card.is-flipped .vehicle-inner{transform:rotateY(180deg);}
.flip-face{position:absolute;inset:0;padding:16px;border-radius:var(--radius);backface-visibility:hidden;background:linear-gradient(180deg,rgba(15,27,46,.96),rgba(12,21,39,.96));border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;}
.flip-back{transform:rotateY(180deg);justify-content:space-between;}
.vehicle-gallery{margin-bottom:14px;}
.gallery-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:9px;}
.gallery-thumb{height:54px;border:1px solid var(--line);border-radius:15px;background:rgba(255,255,255,.04);padding:3px;cursor:pointer;overflow:hidden;transition:.18s ease;}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;border-radius:12px;display:block;}
.gallery-thumb.active,.gallery-thumb:hover{border-color:rgba(255,105,70,.78);box-shadow:0 0 0 2px rgba(255,105,70,.15);}
.detail-kicker{align-self:flex-start;padding:8px 12px;border-radius:999px;background:rgba(255,105,70,.10);border:1px solid rgba(255,105,70,.25);color:var(--accent);font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.08em;}
.spec-list{list-style:none;margin:12px 0 0;padding:0;display:grid;gap:9px;}
.spec-list li{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 12px;border-radius:16px;background:rgba(255,255,255,.045);border:1px solid var(--line);}
.spec-list span{font-size:12px;color:var(--muted);font-weight:900;}
.spec-list b{font-size:13px;color:var(--fg);text-align:right;}
.detail-price{margin:16px 0 0;padding:16px;border-radius:22px;background:linear-gradient(135deg,rgba(255,105,70,.14),rgba(255,204,8,.09));border:1px solid rgba(255,105,70,.24);}
.detail-price small{display:block;color:var(--muted);font-weight:900;font-size:12px;}
.detail-price strong{display:block;color:var(--accent);font-size:30px;line-height:1.05;letter-spacing:-.05em;}
.home-catalog-grid .vehicle-card.flip-card{min-height:565px;}
.home-catalog-grid .vehicle-card.flip-card .vehicle-inner{min-height:565px;}
.home-catalog-grid .featured-ribbon{display:none!important;}
.vehicle-card.flip-card .vehicle-img img{object-fit:contain;padding:10px;}
.vehicle-card.flip-card:hover img{transform:scale(1.03);}
.vehicle-card.flip-card .card-actions{margin-top:auto;}
.vehicle-card.flip-card .price-row{margin-top:auto;}
car-glb-viewer,.hero-3d-model,.vehicle-modal-model{display:none!important;}
@media(max-width:720px){.vehicle-card.flip-card,.vehicle-card.flip-card .vehicle-inner,.home-catalog-grid .vehicle-card.flip-card,.home-catalog-grid .vehicle-card.flip-card .vehicle-inner{min-height:610px}.hero-gallery-wrap{min-height:300px}.hero-gallery-image{max-height:310px}.gallery-thumb{height:48px}.detail-price strong{font-size:25px}}

/* === Detalle interactivo con galería: aparece solo al hacer clic en Ver detalles === */
.vehicle-card.flip-card{min-height:640px;}
.vehicle-card.flip-card .vehicle-inner{min-height:640px;}
.vehicle-card.flip-card .flip-face{height:100%;}
.vehicle-card.flip-card .flip-front{
  display:flex;
  flex-direction:column;
}
.vehicle-card.flip-card .flip-front .vehicle-img{
  height:280px;
  margin-bottom:18px;
}
.vehicle-card.flip-card .vehicle-cover-img img{
  object-fit:contain!important;
  padding:18px!important;
  width:100%;
  height:100%;
}
.vehicle-card.flip-card .flip-back{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:18px;
  overflow:hidden;
}
.detail-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.detail-close{
  width:36px;
  height:36px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.06);
  color:var(--fg);
  font-size:24px;
  line-height:1;
  cursor:pointer;
}
.detail-close:hover{border-color:rgba(255,105,70,.75);color:var(--accent);}
.detail-gallery{
  display:grid;
  gap:10px;
  margin:0 0 4px;
}
.detail-gallery-stage{
  height:230px;
  border-radius:24px;
  background:linear-gradient(145deg,#0f0f10,#202023 65%,#2b2b2e);
  border:1px solid rgba(255,105,70,.24);
  display:grid;
  place-items:center;
  overflow:hidden;
  position:relative;
}
.detail-gallery-stage::after{
  content:"";
  position:absolute;
  left:12%;right:12%;bottom:18px;
  height:22px;
  background:radial-gradient(ellipse,rgba(0,0,0,.48),transparent 70%);
  pointer-events:none;
}
.detail-gallery-stage img{
  width:100%;
  height:100%;
  max-width:96%;
  max-height:96%;
  object-fit:contain!important;
  padding:10px;
  filter:drop-shadow(0 28px 34px rgba(0,0,0,.42));
  transform:none!important;
  position:relative;
  z-index:2;
}
.detail-thumbs{
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:7px;
  margin-top:0;
}
.detail-thumbs .gallery-thumb{
  height:62px;
  border-radius:14px;
  position:relative;
}
.detail-thumbs .gallery-thumb img{
  object-fit:contain;
  padding:3px;
  background:rgba(0,0,0,.18);
}
.detail-thumbs .gallery-thumb span{
  position:absolute;
  left:4px;right:4px;bottom:3px;
  display:block;
  font-size:8px;
  line-height:1;
  color:rgba(255,255,255,.72);
  text-align:center;
  text-transform:uppercase;
  letter-spacing:.04em;
  pointer-events:none;
}
.compact-specs{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:8px!important;
  margin:4px 0 0!important;
}
.compact-specs li{
  padding:8px 10px!important;
  min-height:auto!important;
}
.compact-specs li span{font-size:10px;}
.compact-specs li b{font-size:12px;}
.vehicle-card.flip-card .flip-back .detail-price{
  margin-top:auto;
}
.vehicle-card.flip-card .flip-back .card-actions{
  margin-top:8px;
}
@media(max-width:1100px){
  .vehicle-card.flip-card,.vehicle-card.flip-card .vehicle-inner{min-height:660px;}
  .detail-gallery-stage{height:240px;}
}
@media(max-width:720px){
  .vehicle-card.flip-card,.vehicle-card.flip-card .vehicle-inner,.home-catalog-grid .vehicle-card.flip-card,.home-catalog-grid .vehicle-card.flip-card .vehicle-inner{min-height:710px!important;}
  .vehicle-card.flip-card .flip-front .vehicle-img{height:245px;}
  .detail-gallery-stage{height:220px;}
  .detail-thumbs{grid-template-columns:repeat(3,1fr);}
  .detail-thumbs .gallery-thumb{height:58px;}
  .compact-specs{grid-template-columns:1fr;}
}


/* Fix robusto: garantiza que el botón Ver detalles pueda voltear la tarjeta y que no haya capas bloqueando el clic */
.vehicle-card.flip-card .flip-front{z-index:2;pointer-events:auto;}
.vehicle-card.flip-card .flip-back{z-index:1;pointer-events:none;}
.vehicle-card.flip-card.is-flipped .flip-front{z-index:1;pointer-events:none;}
.vehicle-card.flip-card.is-flipped .flip-back{z-index:3;pointer-events:auto;}
.vehicle-card.flip-card .btn,[data-flip-target],.gallery-thumb{position:relative;z-index:8;}
.vehicle-card.flip-card .vehicle-inner{will-change:transform;}

/* === FIX DEFINITIVO: Ver detalles abre modal con galería interactiva === */
body.modal-open{overflow:hidden;}
.detail-card .vehicle-inner{min-height:520px;display:flex;flex-direction:column;overflow:hidden;}
.detail-card .vehicle-img img{object-fit:contain!important;padding:12px;}
.detail-card .card-actions{margin-top:auto;position:relative;z-index:12;}
.detail-card [data-open-vehicle-details],.detail-card a.btn{pointer-events:auto;position:relative;z-index:20;}
.cr-vehicle-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;padding:22px;}
.cr-vehicle-modal.open{display:flex;}
.cr-modal-backdrop{position:absolute;inset:0;background:rgba(3,5,10,.82);backdrop-filter:blur(12px);}
.cr-modal-panel{position:relative;z-index:2;width:min(1180px,96vw);max-height:92vh;overflow:auto;border-radius:28px;background:#0a0a0c;color:#f2f0eb;border:1px solid rgba(255,255,255,.09);box-shadow:0 40px 130px rgba(0,0,0,.72);}
.cr-modal-shell{position:relative;padding:28px;overflow:hidden;}
.cr-modal-shell::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(232,200,74,.13),transparent 65%);pointer-events:none;}
.cr-modal-close{position:absolute;top:18px;right:18px;z-index:5;width:44px;height:44px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:#f2f0eb;font-size:30px;line-height:1;cursor:pointer;}
.cr-modal-close:hover{border-color:#e8c84a;color:#e8c84a;}
.cr-modal-hero{position:relative;z-index:2;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:18px;padding-right:52px;}
.cr-eyebrow{display:inline-flex;margin:0 0 8px;padding:8px 13px;border-radius:999px;background:rgba(232,200,74,.08);color:#e8c84a;border:1px solid rgba(232,200,74,.22);font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;}
.cr-modal-hero h2{font-family:Inter,system-ui,sans-serif;font-size:clamp(34px,5vw,64px);line-height:.94;margin:8px 0 8px;color:#f2f0eb;letter-spacing:-.065em;text-transform:uppercase;}
.cr-modal-sub{max-width:480px;margin:0;color:rgba(242,240,235,.58);font-size:14px;line-height:1.6;}
.cr-modal-badges{display:flex;flex-direction:column;gap:8px;align-items:flex-end;}
.cr-modal-badges span{padding:8px 13px;border-radius:999px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08);font-size:12px;color:rgba(242,240,235,.62);font-weight:800;}
.cr-modal-grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.45fr) minmax(300px,.55fr);gap:16px;}
.cr-gallery-box,.cr-info-box{background:#16161c;border:1px solid rgba(255,255,255,.075);border-radius:20px;padding:14px;}
.cr-modal-stage{position:relative;min-height:360px;border-radius:17px;display:grid;place-items:center;overflow:hidden;background:linear-gradient(145deg,#1b1b21,#0f0f13);border:1px solid rgba(255,255,255,.07);user-select:none;}
.cr-modal-stage::after{content:"";position:absolute;left:0;right:0;bottom:0;height:38%;background:linear-gradient(to top,rgba(10,10,12,.9),transparent);pointer-events:none;}
.cr-modal-stage img{position:relative;z-index:2;width:100%;height:100%;max-height:430px;object-fit:contain;padding:18px;filter:drop-shadow(0 34px 36px rgba(0,0,0,.55));}
.cr-drag-hint{position:absolute;top:18px;left:18px;z-index:4;display:flex;align-items:center;gap:8px;background:rgba(10,10,12,.74);border:1px solid rgba(255,255,255,.09);backdrop-filter:blur(10px);border-radius:999px;padding:8px 14px;font-size:12px;color:rgba(242,240,235,.62);}
.cr-drag-hint span{color:#e8c84a;font-size:18px;}
.cr-angle-bar{position:absolute;z-index:4;left:50%;bottom:16px;transform:translateX(-50%);display:flex;align-items:center;gap:10px;color:rgba(242,240,235,.55);font-size:11px;letter-spacing:.08em;}
.cr-angle-bar i{display:block;width:120px;height:2px;background:rgba(255,255,255,.12);border-radius:99px;overflow:hidden;}
.cr-angle-bar em{display:block;width:42%;height:100%;background:#e8c84a;border-radius:99px;}
.cr-modal-thumbs{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-top:10px;}
.cr-modal-thumb{position:relative;min-height:78px;border-radius:12px;overflow:hidden;border:2px solid transparent;background:rgba(255,255,255,.04);cursor:pointer;padding:0;transition:.18s ease;}
.cr-modal-thumb:hover,.cr-modal-thumb.active{border-color:#e8c84a;transform:translateY(-2px);}
.cr-modal-thumb img{width:100%;height:100%;object-fit:contain;padding:5px;display:block;filter:brightness(.78);}
.cr-modal-thumb.active img,.cr-modal-thumb:hover img{filter:brightness(1);}
.cr-modal-thumb span{position:absolute;left:0;right:0;bottom:0;padding:14px 4px 4px;text-align:center;background:linear-gradient(to top,rgba(0,0,0,.88),transparent);color:rgba(255,255,255,.72);font-size:9px;text-transform:uppercase;letter-spacing:.06em;}
.cr-info-box{display:flex;flex-direction:column;gap:14px;}
.cr-spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.cr-spec{padding:13px;border-radius:15px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.07);}
.cr-spec span{display:block;color:rgba(242,240,235,.45);font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:900;margin-bottom:5px;}
.cr-spec b{font-size:14px;color:#f2f0eb;}
.cr-price-box{margin-top:auto;border-radius:18px;border:1px solid rgba(232,200,74,.22);background:linear-gradient(135deg,rgba(232,200,74,.12),rgba(232,200,74,.035));padding:18px;}
.cr-price-box small{display:block;color:rgba(242,240,235,.48);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;}
.cr-price-box strong{display:block;color:#e8c84a;font-size:32px;line-height:1;margin-top:6px;letter-spacing:-.04em;}
.cr-modal-actions{display:flex;flex-direction:column;gap:10px;}
.cr-modal-actions .btn{width:100%;}
@media(max-width:880px){.cr-modal-panel{max-height:94vh}.cr-modal-shell{padding:20px}.cr-modal-hero{display:block;padding-right:46px}.cr-modal-badges{align-items:flex-start;margin-top:12px}.cr-modal-grid{grid-template-columns:1fr}.cr-modal-stage{min-height:280px}.cr-modal-thumbs{grid-template-columns:repeat(3,1fr)}.cr-spec-grid{grid-template-columns:1fr}.cr-price-box strong{font-size:27px}}


/* ==========================================================
   FIX Picanto + Modal galería con colores del logo
   ========================================================== */
.cr-vehicle-modal{z-index:10000!important;}
.cr-modal-backdrop{background:rgba(13,13,16,.86)!important;backdrop-filter:blur(14px)!important;}
.cr-modal-panel{
  background:linear-gradient(180deg,rgba(32,32,34,.98),rgba(13,13,16,.98))!important;
  color:var(--fg)!important;
  border:1px solid rgba(255,105,70,.24)!important;
  box-shadow:0 40px 130px rgba(0,0,0,.72),0 0 60px rgba(255,105,70,.12)!important;
}
.cr-modal-shell::before{
  background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(255,105,70,.16),transparent 64%),radial-gradient(circle at 88% 8%,rgba(255,204,8,.12),transparent 32%)!important;
}
.cr-modal-close{background:rgba(255,105,70,.10)!important;color:var(--fg)!important;border-color:rgba(255,105,70,.30)!important;}
.cr-modal-close:hover{border-color:var(--accent2)!important;color:var(--accent2)!important;background:rgba(255,204,8,.10)!important;}
.cr-eyebrow{background:rgba(255,105,70,.10)!important;color:var(--accent)!important;border-color:rgba(255,105,70,.28)!important;}
.cr-modal-hero h2{color:var(--fg)!important;}
.cr-modal-sub{color:var(--fg2)!important;}
.cr-modal-badges span{background:rgba(255,255,255,.045)!important;border-color:var(--line)!important;color:var(--fg2)!important;}
.cr-gallery-box,.cr-info-box{background:linear-gradient(180deg,rgba(27,27,30,.97),rgba(18,18,20,.97))!important;border-color:rgba(255,105,70,.18)!important;}
.cr-modal-stage{background:linear-gradient(145deg,#111112,#202022 64%,#2f2f33)!important;border-color:rgba(255,105,70,.22)!important;}
.cr-modal-stage img{object-fit:contain!important;max-width:100%!important;max-height:430px!important;}
.cr-drag-hint{background:rgba(13,13,16,.78)!important;border-color:rgba(255,105,70,.24)!important;color:var(--fg2)!important;}
.cr-drag-hint span,.cr-angle-bar b{color:var(--accent2)!important;}
.cr-angle-bar i{background:rgba(255,255,255,.14)!important;}
.cr-angle-bar em{background:linear-gradient(90deg,var(--accent),var(--accent2))!important;}
.cr-modal-thumb{background:rgba(255,255,255,.045)!important;border-color:transparent!important;}
.cr-modal-thumb:hover,.cr-modal-thumb.active{border-color:var(--accent)!important;box-shadow:0 10px 26px rgba(255,105,70,.18)!important;}
.cr-modal-thumb span{background:linear-gradient(to top,rgba(13,13,16,.92),transparent)!important;color:var(--fg2)!important;}
.cr-spec{background:rgba(255,255,255,.045)!important;border-color:var(--line)!important;}
.cr-spec span{color:var(--muted)!important;}
.cr-spec b{color:var(--fg)!important;}
.cr-price-box{background:linear-gradient(135deg,rgba(255,105,70,.14),rgba(255,204,8,.07))!important;border-color:rgba(255,105,70,.28)!important;}
.cr-price-box strong{color:var(--accent2)!important;}
.vehicle-img img[src*="kia-picanto-xline"],.hero-3d-car img[src*="kia-picanto-xline"],#floatingCarImage[src*="kia-picanto-xline"],#heroCarImage[src*="kia-picanto-xline"]{object-fit:contain!important;filter:drop-shadow(0 30px 32px rgba(0,0,0,.42));}


/* ==========================================================
   FIX 2026-06-05 · Galería modal 360, colores del logo e inicio limpio
   ========================================================== */
.cr-modal-shell::before{
  background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(255,105,70,.16),transparent 65%)!important;
}
.cr-modal-close:hover{border-color:var(--accent)!important;color:var(--accent)!important;}
.cr-eyebrow{background:rgba(255,105,70,.09)!important;color:var(--accent)!important;border-color:rgba(255,105,70,.28)!important;}
.cr-modal-badges span{background:rgba(255,105,70,.08)!important;border-color:rgba(255,105,70,.22)!important;color:var(--fg2)!important;}
.cr-gallery-box{background:linear-gradient(180deg,rgba(15,27,46,.70),rgba(8,13,24,.92))!important;border-color:rgba(255,105,70,.22)!important;}
.cr-modal-stage{cursor:grab;touch-action:none;background:radial-gradient(circle at 50% 58%,rgba(255,105,70,.16),transparent 48%),linear-gradient(145deg,#101116,#171719)!important;}
.cr-modal-stage.is-dragging{cursor:grabbing;}
.cr-drag-hint span,.cr-angle-bar em{color:var(--accent)!important;background:var(--accent)!important;}
.cr-modal-thumb:hover,.cr-modal-thumb.active{border-color:var(--accent)!important;box-shadow:0 0 0 1px rgba(255,105,70,.18),0 14px 28px rgba(0,0,0,.28)!important;}
.cr-price-box{background:linear-gradient(135deg,rgba(255,105,70,.16),rgba(255,204,8,.08))!important;border-color:rgba(255,105,70,.32)!important;}
.cr-price-box strong{color:var(--accent2)!important;}

/* Quitar el cuadro/fondo pesado del carrusel de fotos del inicio */
.floating-car-stage{
  background:transparent!important;
  border-color:transparent!important;
  box-shadow:none!important;
  overflow:visible!important;
}
.floating-car-stage::before,.floating-car-stage::after,.car-glow,.car-ring{display:none!important;}
.floating-car-media-wrap{width:100%!important;display:grid!important;place-items:center!important;}
.floating-car-image{width:min(920px,98%)!important;max-height:430px!important;object-fit:contain!important;}
.floating-car-stage .floating-car-image[src*="kia-picanto"]{
  width:min(1060px,112%)!important;
  max-height:500px!important;
  transform:scale(1.22)!important;
  object-fit:contain!important;
  object-position:center!important;
}
#heroCarImage[src*="kia-picanto"]{
  width:min(1180px,140%)!important;
  height:610px!important;
  transform:scale(1.12)!important;
  object-fit:contain!important;
}
.vehicle-img img[src*="kia-picanto-xline"]{object-fit:contain!important;padding:4px!important;}
.cr-modal-stage img[src*="kia-picanto-xline"]{padding:6px!important;transform:scale(1.06);}
@media(max-width:720px){
  .floating-car-stage .floating-car-image[src*="kia-picanto"]{width:125%!important;max-height:390px!important;transform:scale(1.14)!important;}
  #heroCarImage[src*="kia-picanto"]{height:380px!important;width:150%!important;transform:scale(1.06)!important;}
}

/* FIX 360: toda el área de la imagen grande rota al arrastrar */
.cr-modal-stage{cursor:grab!important;touch-action:none!important;}
.cr-modal-stage.is-dragging{cursor:grabbing!important;}
.cr-modal-stage img{pointer-events:none!important;-webkit-user-drag:none;user-drag:none;user-select:none!important;}
.cr-drag-hint,.cr-angle-bar{pointer-events:none!important;}

/* ==========================================================
   FIX visual promedio 2026-06-05 · Tamaño uniforme galería/inicio
   ========================================================== */
.cr-modal-stage{
  height:clamp(330px,48vw,430px)!important;
  min-height:330px!important;
  display:grid!important;
  place-items:center!important;
}
.cr-modal-stage img{
  width:100%!important;
  height:100%!important;
  max-width:100%!important;
  max-height:100%!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:20px!important;
  transform:none!important;
}
.cr-modal-stage img[src*="kia-picanto-xline"]{
  transform:none!important;
  padding:20px!important;
}
.cr-modal-thumb img{
  width:100%!important;
  height:78px!important;
  object-fit:contain!important;
  object-position:center!important;
  padding:6px!important;
  transform:none!important;
}
.vehicle-img img[src*="kia-picanto-xline"],
.vehicle-img img[src*="kia-rio-vibrant"]{
  width:100%!important;
  height:260px!important;
  object-fit:contain!important;
  object-position:center!important;
  padding:12px!important;
  transform:none!important;
}
.floating-car-image,
.floating-car-stage .floating-car-image[src*="kia-picanto"],
#heroCarImage[src*="kia-picanto"],
#heroCarImage[src*="kia-rio"]{
  width:min(940px,98%)!important;
  height:min(430px,48vw)!important;
  max-height:430px!important;
  object-fit:contain!important;
  object-position:center!important;
  transform:none!important;
  padding:0!important;
}
@media(max-width:720px){
  .cr-modal-stage{height:310px!important;min-height:310px!important;}
  .cr-modal-stage img{padding:14px!important;}
  .floating-car-image,
  .floating-car-stage .floating-car-image[src*="kia-picanto"],
  #heroCarImage[src*="kia-picanto"],
  #heroCarImage[src*="kia-rio"]{
    width:100%!important;
    height:330px!important;
    max-height:330px!important;
    transform:none!important;
  }
}

/* ==========================================================
   FIX 2026-06-05 · Evitar que las imágenes queden sobre la barra 360
   ========================================================== */
.cr-modal-stage{
  height:clamp(380px,48vw,460px)!important;
  min-height:380px!important;
  padding:18px 18px 74px!important;
  box-sizing:border-box!important;
  display:grid!important;
  place-items:center!important;
}
.cr-modal-stage img{
  width:100%!important;
  height:100%!important;
  max-width:100%!important;
  max-height:100%!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:0!important;
  margin:0!important;
  transform:none!important;
}
.cr-modal-stage img[src*="kia-picanto-xline"],
.cr-modal-stage img[src*="kia-rio-vibrant"]{
  padding:0!important;
  margin:0!important;
  transform:none!important;
}
.cr-angle-bar{
  bottom:18px!important;
  padding:8px 12px!important;
  border-radius:999px!important;
  background:rgba(13,13,16,.72)!important;
  border:1px solid rgba(255,105,70,.20)!important;
  backdrop-filter:blur(10px)!important;
}
.cr-modal-stage::after{
  height:26%!important;
}
@media(max-width:720px){
  .cr-modal-stage{
    height:340px!important;
    min-height:340px!important;
    padding:14px 12px 68px!important;
  }
  .cr-angle-bar{
    bottom:14px!important;
    transform:translateX(-50%) scale(.92)!important;
  }
}


/* Normalización visual Viva R 2022 */
.vehicle-img img[src*="viva-r-2022"],
.cr-modal-stage img[src*="viva-r-2022"],
.cr-modal-thumb img[src*="viva-r-2022"]{
  object-fit:contain!important;
  object-position:center center!important;
  padding:10px;
}


/* Normalización visual Viva R y NKD 2025 */
.vehicle-img img[src*="viva-r-2020"],
.vehicle-img img[src*="viva-r-2022"],
.vehicle-img img[src*="nkd-2025"],
.cr-modal-stage img[src*="viva-r-2020"],
.cr-modal-stage img[src*="viva-r-2022"],
.cr-modal-stage img[src*="nkd-2025"],
.cr-modal-thumb img[src*="viva-r-2020"],
.cr-modal-thumb img[src*="viva-r-2022"],
.cr-modal-thumb img[src*="nkd-2025"]{
  object-fit:contain!important;
  object-position:center center!important;
  padding:10px;
}


/* Ajustes finales responsive / PWA */
@media (max-width: 480px){
  .site-header{padding:10px 14px}
  .brand-logo-img{max-width:92px;height:auto}
  .header-actions .btn{font-size:12px;padding:0 10px}
  .vehicles-grid{grid-template-columns:1fr!important;gap:18px}
  .vehicle-inner{min-height:auto}
  .vehicle-img{height:190px}
  .cr-modal-panel{width:96vw;max-height:94vh}
  .cr-modal-shell{padding:16px}
  .cr-modal-stage{min-height:245px}
  .cr-modal-thumbs{grid-template-columns:repeat(2,1fr)}
  .cr-modal-thumb span{font-size:11px}
}
@media (min-width: 1200px){
  .vehicles-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}


/* =========================================================
   Calendario premium Car Rental DR - Inicio
   Mejora visual del selector de fechas sin afectar catálogo
   ========================================================= */
.date-field{position:relative}
.date-field:after{
  content:"";
  position:absolute;
  right:15px;
  bottom:14px;
  width:22px;
  height:22px;
  pointer-events:none;
  opacity:.95;
  background:
    linear-gradient(var(--accent),var(--accent)) 5px 7px/12px 2px no-repeat,
    linear-gradient(var(--accent),var(--accent)) 5px 12px/12px 2px no-repeat,
    linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  border-radius:7px;
  box-shadow:0 0 0 1px rgba(255,105,70,.25),0 8px 18px rgba(255,105,70,.18);
}
.cr-date-input{
  cursor:pointer;
  padding-right:48px!important;
  background:
    radial-gradient(circle at 18% 0%,rgba(255,105,70,.12),transparent 32%),
    linear-gradient(180deg,rgba(15,27,46,.98),rgba(8,14,27,.98))!important;
  border-color:rgba(255,105,70,.24)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 12px 28px rgba(0,0,0,.12);
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.cr-date-input:hover,
.cr-date-input:focus,
.cr-date-input.is-open{
  outline:0;
  border-color:rgba(255,105,70,.65)!important;
  box-shadow:0 0 0 4px rgba(255,105,70,.12),0 18px 38px rgba(0,0,0,.24);
}
.cr-date-input::placeholder{color:rgba(236,241,255,.48);font-weight:900}
.cr-date-popover{
  position:fixed;
  z-index:9999;
  width:min(355px,calc(100vw - 28px));
  background:
    radial-gradient(circle at 12% 0%,rgba(255,105,70,.18),transparent 36%),
    radial-gradient(circle at 92% 8%,rgba(255,204,8,.14),transparent 34%),
    linear-gradient(180deg,rgba(15,27,46,.98),rgba(7,13,26,.98));
  border:1px solid rgba(255,105,70,.24);
  border-radius:28px;
  box-shadow:0 30px 75px rgba(0,0,0,.48),0 0 0 1px rgba(255,255,255,.04) inset;
  padding:16px;
  color:var(--fg);
  backdrop-filter:blur(20px);
  transform-origin:top center;
  animation:crCalendarIn .16s ease both;
}
@keyframes crCalendarIn{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.cr-date-popover:before{
  content:"";
  position:absolute;
  top:-7px;
  left:40px;
  width:14px;
  height:14px;
  transform:rotate(45deg);
  background:rgba(15,27,46,.98);
  border-left:1px solid rgba(255,105,70,.24);
  border-top:1px solid rgba(255,105,70,.24);
}
.cr-date-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:4px 4px 14px;
}
.cr-date-title{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}
.cr-date-title b{
  font-size:17px;
  letter-spacing:-.03em;
  color:var(--fg);
}
.cr-date-title span{
  font-size:11px;
  color:var(--muted);
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.cr-date-nav{
  display:flex;
  gap:8px;
}
.cr-date-nav button,
.cr-date-day{
  border:0;
  font:inherit;
}
.cr-date-nav button{
  width:38px;
  height:38px;
  border-radius:14px;
  cursor:pointer;
  color:var(--fg);
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.09);
  font-weight:950;
  transition:.18s ease;
}
.cr-date-nav button:hover{
  transform:translateY(-1px);
  border-color:rgba(255,105,70,.45);
  background:rgba(255,105,70,.12);
}
.cr-weekdays,
.cr-days{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:7px;
}
.cr-weekdays{
  margin-bottom:8px;
  color:var(--muted);
  font-size:11px;
  font-weight:950;
  text-align:center;
  text-transform:uppercase;
}
.cr-date-day{
  height:40px;
  border-radius:15px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.045);
  color:var(--fg2);
  font-weight:950;
  cursor:pointer;
  border:1px solid transparent;
  transition:.15s ease;
}
.cr-date-day:not(.is-muted):not(:disabled):hover{
  color:var(--fg);
  transform:translateY(-1px);
  border-color:rgba(255,105,70,.35);
  background:rgba(255,105,70,.11);
}
.cr-date-day.is-muted{
  opacity:.28;
  cursor:default;
}
.cr-date-day.is-today{
  border-color:rgba(255,204,8,.55);
  color:var(--fg);
}
.cr-date-day.is-selected{
  color:#111112;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 12px 28px rgba(255,105,70,.22);
}
.cr-date-day:disabled{
  opacity:.24;
  cursor:not-allowed;
  filter:grayscale(.3);
}
.cr-date-foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-top:13px;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,.08);
}
.cr-date-foot small{
  color:var(--muted);
  font-weight:850;
  line-height:1.35;
}
.cr-date-clear{
  border:1px solid rgba(255,105,70,.28);
  background:rgba(255,105,70,.08);
  color:var(--accent);
  border-radius:999px;
  padding:9px 12px;
  font-weight:950;
  cursor:pointer;
}
@media (max-width:760px){
  .cr-date-popover{
    left:14px!important;
    right:14px!important;
    width:auto;
    bottom:18px!important;
    top:auto!important;
    border-radius:30px;
  }
  .cr-date-popover:before{display:none}
  .cr-date-day{height:43px}
}


/* =========================================================
   Ubicaciones con mapas - Zarzal y Roldanillo
   ========================================================= */
.location-grid--maps{
  grid-template-columns:repeat(2,minmax(0,1fr));
  align-items:stretch;
}
.location-card--map{
  padding:0;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height:560px;
  border-color:rgba(255,105,70,.22);
}
.location-card__content{
  padding:26px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.location-card--map b{
  font-size:clamp(28px,3vw,42px);
  letter-spacing:-.06em;
  color:var(--fg);
}
.location-badge{
  width:max-content;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,105,70,.1);
  color:var(--accent);
  border:1px solid rgba(255,105,70,.24);
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.location-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:4px;
}
.map-frame{
  position:relative;
  flex:1;
  min-height:300px;
  border-top:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(circle at 20% 0%,rgba(255,105,70,.14),transparent 38%),
    linear-gradient(180deg,rgba(255,255,255,.04),rgba(0,0,0,.12));
}
.map-frame iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  filter:saturate(.95) contrast(1.02);
}
.location-card--map:hover{
  transform:translateY(-4px);
  border-color:rgba(255,105,70,.42);
  box-shadow:var(--shadow),0 0 0 1px rgba(255,105,70,.08);
}
@media (max-width:900px){
  .location-grid--maps{grid-template-columns:1fr}
  .location-card--map{min-height:520px}
}
@media (max-width:620px){
  .location-card__content{padding:21px}
  .map-frame{min-height:260px}
  .location-actions .btn{width:100%}
}


/* =========================================================
   Ajustes inicio: selectores premium y carruseles solo nombre
   ========================================================= */
.booking-grid .field:has(.cr-select-input){
  position:relative;
}
.booking-grid .field:has(.cr-select-input)::after{
  content:"⌄";
  position:absolute;
  right:17px;
  bottom:13px;
  width:24px;
  height:24px;
  border-radius:9px;
  display:grid;
  place-items:center;
  pointer-events:none;
  color:#111112;
  font-weight:950;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 8px 20px rgba(255,105,70,.2);
}
.cr-select-input{
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
  padding-right:52px!important;
  background:
    radial-gradient(circle at 18% 0%,rgba(255,105,70,.12),transparent 32%),
    linear-gradient(180deg,rgba(15,27,46,.98),rgba(8,14,27,.98))!important;
  border-color:rgba(255,105,70,.24)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 12px 28px rgba(0,0,0,.12);
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.cr-select-input:hover,
.cr-select-input:focus{
  outline:0;
  border-color:rgba(255,105,70,.65)!important;
  box-shadow:0 0 0 4px rgba(255,105,70,.12),0 18px 38px rgba(0,0,0,.24);
}
.cr-select-input option{
  background:#0b1426;
  color:#ecf1ff;
  font-weight:800;
}
.hero-name-only-specs{
  display:none!important;
}
.hero-gallery-spec-panel{
  text-align:center;
}
.hero-gallery-spec-panel h2{
  margin-bottom:0!important;
}
.floating-car-info.only-name{
  left:50%;
  right:auto;
  bottom:22px;
  transform:translateX(-50%);
  width:max-content;
  max-width:calc(100% - 42px);
  min-width:min(360px,calc(100% - 42px));
  text-align:center;
  padding:16px 22px;
  border-radius:24px;
  background:linear-gradient(180deg,rgba(15,27,46,.94),rgba(8,14,27,.94));
  border:1px solid rgba(255,105,70,.24);
  box-shadow:0 20px 48px rgba(0,0,0,.32),0 0 0 1px rgba(255,255,255,.04) inset;
}
.floating-car-info.only-name h3{
  margin:0;
  font-size:clamp(24px,3vw,38px);
  line-height:1;
  color:var(--fg);
  letter-spacing:-.055em;
}
@media (max-width:760px){
  .floating-car-info.only-name{
    min-width:0;
    width:calc(100% - 34px);
    bottom:16px;
    padding:14px 18px;
  }
}


/* =========================================================
   FIX fotos vehículos 2026-06-07
   - Sin textos Frontal/Lateral/Trasera en miniaturas
   - Motos centradas y completas
   - Carrusel de inicio recuperado
   ========================================================= */
.cr-modal-thumb span,
.detail-thumbs .gallery-thumb span,
.gallery-thumb span{
  display:none!important;
}
.cr-modal-thumb{
  min-height:86px!important;
  display:grid!important;
  place-items:center!important;
  padding:6px!important;
}
.cr-modal-thumb img{
  width:100%!important;
  height:100%!important;
  max-height:82px!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:4px!important;
}

/* Todas las motos: imagen completa, centrada y con aire */
.vehicle-img img[src*="yamaha-"],
.vehicle-img img[src*="viva-r"],
.vehicle-img img[src*="nkd-"],
.cr-modal-stage img[src*="yamaha-"],
.cr-modal-stage img[src*="viva-r"],
.cr-modal-stage img[src*="nkd-"],
.cr-modal-thumb img[src*="yamaha-"],
.cr-modal-thumb img[src*="viva-r"],
.cr-modal-thumb img[src*="nkd-"]{
  object-fit:contain!important;
  object-position:center center!important;
  transform:none!important;
}

/* Tarjetas de motos: más espacio vertical para no cortar manubrios o llantas */
.vehicle-img img[src*="yamaha-"],
.vehicle-img img[src*="viva-r"],
.vehicle-img img[src*="nkd-"]{
  width:100%!important;
  height:250px!important;
  max-height:250px!important;
  padding:18px!important;
  margin:auto!important;
}

/* Modal motos: más visión completa y sin corte */
.cr-modal-stage img[src*="yamaha-"],
.cr-modal-stage img[src*="viva-r"],
.cr-modal-stage img[src*="nkd-"]{
  width:100%!important;
  height:100%!important;
  max-width:100%!important;
  max-height:100%!important;
  padding:18px!important;
}

/* Miniaturas motos: completas, sin crop */
.cr-modal-thumb img[src*="yamaha-"],
.cr-modal-thumb img[src*="viva-r"],
.cr-modal-thumb img[src*="nkd-"]{
  padding:3px!important;
  max-height:78px!important;
}

/* Carrusel inferior de inicio: recuperar vista limpia, centrada y sin zoom excesivo */
.floating-car-stage{
  min-height:520px!important;
  padding:36px!important;
  overflow:visible!important;
}
.floating-car-media-wrap{
  width:100%!important;
  min-height:410px!important;
  display:grid!important;
  place-items:center!important;
  overflow:visible!important;
}
.floating-car-image{
  display:block!important;
  width:min(900px,96%)!important;
  height:390px!important;
  max-height:390px!important;
  object-fit:contain!important;
  object-position:center center!important;
  transform:none!important;
  padding:0!important;
  margin:auto!important;
  filter:drop-shadow(0 34px 42px rgba(0,0,0,.46));
}
.floating-car-image[src*="kia-picanto"],
.floating-car-image[src*="kia-carens"],
.floating-car-image[src*="renault-duster"],
.floating-car-image[src*="kia-rio"]{
  width:min(900px,96%)!important;
  height:390px!important;
  max-height:390px!important;
  transform:none!important;
  object-fit:contain!important;
}

/* Carrusel superior: que la imagen no se agrande ni se corte */
.hero-gallery-wrap{
  overflow:visible!important;
}
.hero-gallery-image{
  width:min(820px,100%)!important;
  height:430px!important;
  max-height:430px!important;
  object-fit:contain!important;
  object-position:center center!important;
  transform:none!important;
}
#heroCarImage[src*="kia-picanto"],
#heroCarImage[src*="kia-rio"],
#heroCarImage[src*="kia-carens"],
#heroCarImage[src*="renault-duster"]{
  width:min(820px,100%)!important;
  height:430px!important;
  max-height:430px!important;
  transform:none!important;
  object-fit:contain!important;
}

@media(max-width:720px){
  .floating-car-stage{min-height:390px!important;padding:22px!important}
  .floating-car-media-wrap{min-height:300px!important}
  .floating-car-image,
  .floating-car-image[src*="kia-picanto"],
  .floating-car-image[src*="kia-carens"],
  .floating-car-image[src*="renault-duster"],
  .floating-car-image[src*="kia-rio"]{
    height:280px!important;
    max-height:280px!important;
    width:100%!important;
  }
  .hero-gallery-image,
  #heroCarImage[src*="kia-picanto"],
  #heroCarImage[src*="kia-rio"],
  #heroCarImage[src*="kia-carens"],
  #heroCarImage[src*="renault-duster"]{
    height:315px!important;
    max-height:315px!important;
    width:100%!important;
  }
  .vehicle-img img[src*="yamaha-"],
  .vehicle-img img[src*="viva-r"],
  .vehicle-img img[src*="nkd-"]{
    height:215px!important;
    max-height:215px!important;
    padding:14px!important;
  }
}


/* =========================================================
   FIX Galería 360 sin imagen mocha 2026-06-07
   ========================================================= */
.cr-modal-panel{
  overflow:visible!important;
}
.cr-gallery-box{
  overflow:visible!important;
}
.cr-modal-stage{
  height:clamp(430px,56vw,560px)!important;
  min-height:430px!important;
  padding:16px 16px 78px!important;
  overflow:hidden!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  box-sizing:border-box!important;
}
.cr-modal-stage img,
#crModalMainImage{
  width:100%!important;
  height:100%!important;
  max-width:100%!important;
  max-height:100%!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:0!important;
  margin:0!important;
  transform:none!important;
  display:block!important;
}

/* Motos en 360: más aire para manubrio y llantas, sin corte */
.cr-modal-stage img[src*="yamaha-"],
.cr-modal-stage img[src*="viva-r"],
.cr-modal-stage img[src*="nkd-"],
#crModalMainImage[src*="yamaha-"],
#crModalMainImage[src*="viva-r"],
#crModalMainImage[src*="nkd-"]{
  width:96%!important;
  height:96%!important;
  max-width:96%!important;
  max-height:96%!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:12px!important;
  transform:none!important;
}

/* La barra 360 queda por encima, pero sin tapar la imagen */
.cr-angle-bar{
  bottom:18px!important;
  z-index:8!important;
}
.cr-drag-hint{
  z-index:8!important;
}

/* Miniaturas completas, sin nombres y sin recorte */
.cr-modal-thumbs{
  margin-top:14px!important;
}
.cr-modal-thumb{
  overflow:hidden!important;
  min-height:92px!important;
}
.cr-modal-thumb img{
  width:100%!important;
  height:86px!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:4px!important;
}

@media(max-width:900px){
  .cr-modal-stage{
    height:clamp(390px,62vw,500px)!important;
    min-height:390px!important;
    padding:14px 12px 74px!important;
  }
}
@media(max-width:620px){
  .cr-modal-stage{
    height:390px!important;
    min-height:390px!important;
    padding:12px 8px 68px!important;
  }
  .cr-modal-stage img[src*="yamaha-"],
  .cr-modal-stage img[src*="viva-r"],
  .cr-modal-stage img[src*="nkd-"],
  #crModalMainImage[src*="yamaha-"],
  #crModalMainImage[src*="viva-r"],
  #crModalMainImage[src*="nkd-"]{
    width:98%!important;
    height:98%!important;
    max-width:98%!important;
    max-height:98%!important;
    padding:8px!important;
  }
}


/* =========================================================
   FIX Modal galería 360 con scroll interno 2026-06-07
   - Evita que la imagen se salga del cuadro
   - Permite scroll dentro del modal en pantallas pequeñas
   ========================================================= */
body.modal-open{
  overflow:hidden!important;
}
.cr-vehicle-modal.open{
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding:18px!important;
  align-items:flex-start!important;
}
.cr-modal-panel{
  width:min(1180px,96vw)!important;
  max-height:none!important;
  margin:22px auto!important;
  overflow:visible!important;
}
.cr-modal-shell{
  max-height:none!important;
  overflow:visible!important;
}

/* Distribución más estable: imagen y datos sin salirse */
.cr-modal-grid{
  align-items:start!important;
}
.cr-gallery-box{
  min-width:0!important;
  overflow:visible!important;
}

/* Área 360 balanceada: más alta que antes, pero dentro del modal */
.cr-modal-stage{
  width:100%!important;
  height:min(52vh,500px)!important;
  min-height:360px!important;
  max-height:500px!important;
  padding:14px 14px 72px!important;
  overflow:hidden!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  box-sizing:border-box!important;
}
.cr-modal-stage img,
#crModalMainImage{
  width:100%!important;
  height:100%!important;
  max-width:100%!important;
  max-height:100%!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:0!important;
  margin:0!important;
  transform:none!important;
}

/* Motos: se ven completas, pero no invaden el modal */
.cr-modal-stage img[src*="yamaha-"],
.cr-modal-stage img[src*="viva-r"],
.cr-modal-stage img[src*="nkd-"],
#crModalMainImage[src*="yamaha-"],
#crModalMainImage[src*="viva-r"],
#crModalMainImage[src*="nkd-"]{
  width:94%!important;
  height:94%!important;
  max-width:94%!important;
  max-height:94%!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:8px!important;
}

/* La barra 360 queda fija dentro del cuadro sin tapar demasiado */
.cr-angle-bar{
  bottom:16px!important;
  z-index:9!important;
  max-width:calc(100% - 32px)!important;
}
.cr-drag-hint{
  top:14px!important;
  z-index:9!important;
}

/* Miniaturas compactas para que el modal no crezca demasiado */
.cr-modal-thumbs{
  margin-top:12px!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
}
.cr-modal-thumb{
  min-height:76px!important;
  height:76px!important;
  padding:5px!important;
}
.cr-modal-thumb img{
  width:100%!important;
  height:100%!important;
  max-height:68px!important;
  object-fit:contain!important;
  object-position:center center!important;
  padding:3px!important;
}

/* En pantallas medianas: una columna y scroll del modal */
@media(max-width:980px){
  .cr-vehicle-modal.open{
    padding:12px!important;
  }
  .cr-modal-panel{
    width:96vw!important;
    margin:12px auto!important;
  }
  .cr-modal-grid{
    grid-template-columns:1fr!important;
  }
  .cr-modal-stage{
    height:min(50vh,430px)!important;
    min-height:330px!important;
    max-height:430px!important;
    padding:12px 10px 68px!important;
  }
  .cr-modal-thumbs{
    grid-template-columns:repeat(4,minmax(0,1fr))!important;
  }
}

/* En celular: todo cabe y el modal desplaza verticalmente */
@media(max-width:620px){
  .cr-vehicle-modal.open{
    padding:8px!important;
  }
  .cr-modal-panel{
    width:98vw!important;
    margin:8px auto!important;
  }
  .cr-modal-shell{
    padding:14px!important;
  }
  .cr-modal-hero{
    padding-right:42px!important;
  }
  .cr-modal-stage{
    height:330px!important;
    min-height:330px!important;
    max-height:330px!important;
    padding:10px 8px 62px!important;
  }
  .cr-modal-stage img[src*="yamaha-"],
  .cr-modal-stage img[src*="viva-r"],
  .cr-modal-stage img[src*="nkd-"],
  #crModalMainImage[src*="yamaha-"],
  #crModalMainImage[src*="viva-r"],
  #crModalMainImage[src*="nkd-"]{
    width:96%!important;
    height:96%!important;
    max-width:96%!important;
    max-height:96%!important;
    padding:6px!important;
  }
  .cr-modal-thumbs{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:8px!important;
  }
  .cr-modal-thumb{
    height:68px!important;
    min-height:68px!important;
  }
  .cr-modal-thumb img{
    max-height:60px!important;
  }
  .cr-angle-bar{
    bottom:12px!important;
    transform:translateX(-50%) scale(.88)!important;
  }
}


/* =========================================================
   Reparación selectores y calendarios funcionales 2026-06-07
   ========================================================= */
.booking-panel{overflow:visible!important}
.booking-panel .field{position:relative;z-index:30}
.booking-panel .booking-grid{position:relative;z-index:40;overflow:visible!important}
.booking-tabs-single button{pointer-events:none}
.native-select-hidden{
  position:absolute!important;
  opacity:0!important;
  pointer-events:none!important;
  width:1px!important;
  height:1px!important;
  left:-9999px!important;
}
.cr-custom-select{
  position:relative;
  width:100%;
  z-index:20;
}
.cr-custom-select.open{z-index:10030}
.cr-custom-select-btn{
  width:100%;
  min-height:54px;
  border-radius:18px;
  border:1px solid rgba(255,105,70,.26);
  padding:0 52px 0 14px;
  text-align:left;
  cursor:pointer;
  color:var(--fg);
  font:inherit;
  font-weight:900;
  background:
    radial-gradient(circle at 16% 0%,rgba(255,105,70,.14),transparent 34%),
    linear-gradient(180deg,rgba(15,27,46,.98),rgba(8,14,27,.98));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.055),0 14px 30px rgba(0,0,0,.16);
}
.cr-custom-select-btn::after{
  content:"⌄";
  position:absolute;
  right:16px;
  top:50%;
  transform:translateY(-50%);
  width:25px;
  height:25px;
  border-radius:10px;
  display:grid;
  place-items:center;
  color:#111112;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 10px 22px rgba(255,105,70,.22);
}
.cr-custom-select.open .cr-custom-select-btn,
.cr-custom-select-btn:hover{
  border-color:rgba(255,105,70,.68);
  box-shadow:0 0 0 4px rgba(255,105,70,.12),0 20px 42px rgba(0,0,0,.26);
}
.cr-custom-select-list{
  position:absolute;
  left:0;
  right:0;
  top:calc(100% + 8px);
  display:none;
  padding:8px;
  border-radius:18px;
  background:
    radial-gradient(circle at 12% 0%,rgba(255,105,70,.16),transparent 36%),
    linear-gradient(180deg,#111b30,#08101f);
  border:1px solid rgba(255,105,70,.28);
  box-shadow:0 24px 60px rgba(0,0,0,.48);
  max-height:260px;
  overflow:auto;
  z-index:10040;
}
.cr-custom-select.open .cr-custom-select-list{display:block}
.cr-custom-select-option{
  width:100%;
  min-height:42px;
  border:0;
  border-radius:13px;
  background:transparent;
  color:var(--fg2);
  text-align:left;
  padding:0 12px;
  font:inherit;
  font-weight:900;
  cursor:pointer;
}
.cr-custom-select-option:hover,
.cr-custom-select-option.active{
  color:#111112;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
}
.cr-date-input,
.reservation-date-input{
  cursor:pointer!important;
  min-height:54px!important;
  border-radius:18px!important;
  background:
    radial-gradient(circle at 16% 0%,rgba(255,105,70,.14),transparent 34%),
    linear-gradient(180deg,rgba(15,27,46,.98),rgba(8,14,27,.98))!important;
  border:1px solid rgba(255,105,70,.26)!important;
  color:var(--fg)!important;
  font-weight:900!important;
  padding:0 48px 0 14px!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.055),0 14px 30px rgba(0,0,0,.16)!important;
}
.cr-date-input:hover,
.cr-date-input:focus,
.cr-date-input.is-open{
  outline:0!important;
  border-color:rgba(255,105,70,.68)!important;
  box-shadow:0 0 0 4px rgba(255,105,70,.12),0 20px 42px rgba(0,0,0,.26)!important;
}
.date-field::after{
  content:"📅"!important;
  position:absolute!important;
  right:15px!important;
  bottom:14px!important;
  width:24px!important;
  height:24px!important;
  border-radius:10px!important;
  display:grid!important;
  place-items:center!important;
  pointer-events:none!important;
  background:linear-gradient(135deg,var(--accent),var(--accent2))!important;
  color:#111112!important;
  font-size:13px!important;
  box-shadow:0 10px 22px rgba(255,105,70,.22)!important;
}
.cr-date-popover{
  position:fixed;
  z-index:10000;
  width:min(355px,calc(100vw - 28px));
  padding:16px;
  border-radius:28px;
  background:
    radial-gradient(circle at 12% 0%,rgba(255,105,70,.18),transparent 36%),
    radial-gradient(circle at 92% 8%,rgba(255,204,8,.14),transparent 34%),
    linear-gradient(180deg,rgba(15,27,46,.99),rgba(7,13,26,.99));
  border:1px solid rgba(255,105,70,.32);
  color:var(--fg);
  box-shadow:0 34px 82px rgba(0,0,0,.54),0 0 0 1px rgba(255,255,255,.05) inset;
  backdrop-filter:blur(20px);
}
.cr-date-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 4px 14px}
.cr-date-title{display:flex;flex-direction:column;gap:2px}
.cr-date-title span{font-size:11px;color:var(--muted);font-weight:950;text-transform:uppercase;letter-spacing:.08em}
.cr-date-title b{font-size:17px;color:var(--fg)}
.cr-date-nav{display:flex;gap:8px}
.cr-date-nav button{
  width:38px;height:38px;border-radius:14px;cursor:pointer;color:var(--fg);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);font-weight:950;
}
.cr-date-nav button:hover{border-color:rgba(255,105,70,.45);background:rgba(255,105,70,.12)}
.cr-weekdays,.cr-days{display:grid;grid-template-columns:repeat(7,1fr);gap:7px}
.cr-weekdays{margin-bottom:8px;color:var(--muted);font-size:11px;font-weight:950;text-align:center;text-transform:uppercase}
.cr-date-day{
  height:40px;border-radius:15px;display:grid;place-items:center;background:rgba(255,255,255,.045);
  color:var(--fg2);font-weight:950;cursor:pointer;border:1px solid transparent;
}
.cr-date-day:not(.is-muted):not(:disabled):hover{color:var(--fg);border-color:rgba(255,105,70,.35);background:rgba(255,105,70,.11)}
.cr-date-day.is-muted{opacity:.28;cursor:default}
.cr-date-day.is-today{border-color:rgba(255,204,8,.55);color:var(--fg)}
.cr-date-day.is-selected{color:#111112;background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:0 14px 32px rgba(255,105,70,.28)}
.cr-date-day:disabled{opacity:.24;cursor:not-allowed;filter:grayscale(.3)}
.cr-time-row{display:grid;grid-template-columns:58px 1fr;align-items:center;gap:12px;margin-top:13px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}
.cr-time-clock{width:54px;height:54px;border-radius:50%;position:relative;background:radial-gradient(circle at 35% 25%,rgba(255,204,8,.30),transparent 34%),linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:0 14px 30px rgba(255,105,70,.28),inset 0 0 0 4px rgba(17,17,18,.20)}
.cr-time-clock span{position:absolute;inset:9px;border-radius:50%;background:#111112;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.cr-time-clock i,.cr-time-clock b{position:absolute;left:50%;top:50%;display:block;width:3px;border-radius:999px;background:var(--accent2);transform-origin:50% 100%}
.cr-time-clock i{height:14px;transform:translate(-50%,-100%) rotate(35deg)}
.cr-time-clock b{height:19px;background:var(--accent);transform:translate(-50%,-100%) rotate(120deg)}
.cr-time-clock:after{content:"";position:absolute;left:50%;top:50%;width:7px;height:7px;border-radius:50%;background:#fff;transform:translate(-50%,-50%);box-shadow:0 0 0 3px rgba(255,255,255,.12)}
.cr-time-picker{min-width:0}
.cr-time-picker label{margin:0 0 8px;color:var(--muted);font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.08em}
.cr-time-pills{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px;max-height:128px;overflow:auto;padding-right:2px}
.cr-time-pill{min-height:36px;border-radius:999px;border:1px solid rgba(255,105,70,.20);background:rgba(255,255,255,.055);color:var(--fg2);font-weight:950;cursor:pointer}
.cr-time-pill:hover{border-color:rgba(255,204,8,.45);background:rgba(255,105,70,.12);color:#fff}
.cr-time-pill.is-selected{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:transparent;color:#111112;box-shadow:0 12px 24px rgba(255,105,70,.24)}
.cr-date-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:13px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}
.cr-date-foot small{color:var(--muted);font-weight:850;line-height:1.35}
.cr-date-clear{border:1px solid rgba(255,105,70,.28);background:rgba(255,105,70,.08);color:var(--accent);border-radius:999px;padding:9px 12px;font-weight:950;cursor:pointer}
.cr-date-accept{border:0;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#111112;border-radius:999px;padding:9px 13px;font-weight:950;cursor:pointer}
.reservation-grid{grid-template-columns:1fr 1fr 1fr 1fr auto;gap:14px!important}
.reservation-whatsapp-btn{min-height:54px!important;border-radius:18px!important;min-width:190px;white-space:nowrap}
@media(max-width:1120px){
  .reservation-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .reservation-whatsapp-btn{grid-column:1/-1;width:100%}
}
@media(max-width:620px){
  .reservation-grid{grid-template-columns:1fr}
  .cr-time-row{grid-template-columns:1fr}
  .cr-time-clock{margin:auto}
  .cr-time-pills{grid-template-columns:repeat(3,minmax(0,1fr));max-height:150px}
}
@media(max-width:760px){
  .cr-date-popover{left:14px!important;right:14px!important;width:auto!important;bottom:18px!important;top:auto!important}
}


/* =========================================================
   Mini chatbot CAR RENTAL DR
   ========================================================= */
.cr-chat-widget{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:9998;
  font-family:Inter,system-ui,sans-serif;
}
.cr-chat-bubble{
  min-width:138px;
  min-height:54px;
  border:0;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  cursor:pointer;
  color:#111112;
  font-weight:950;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 18px 42px rgba(0,0,0,.34),0 0 0 1px rgba(255,255,255,.08) inset;
  transition:transform .18s ease, box-shadow .18s ease;
}
.cr-chat-bubble:hover{
  transform:translateY(-2px);
  box-shadow:0 24px 54px rgba(0,0,0,.40),0 0 30px rgba(255,105,70,.18);
}
.cr-chat-bubble span{
  width:31px;
  height:31px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:rgba(17,17,18,.13);
}
.cr-chat-panel{
  position:absolute;
  right:0;
  bottom:68px;
  width:min(380px,calc(100vw - 28px));
  max-height:min(620px,calc(100vh - 110px));
  display:none;
  overflow:hidden;
  border-radius:28px;
  background:
    radial-gradient(circle at 12% 0%,rgba(255,105,70,.18),transparent 36%),
    radial-gradient(circle at 92% 8%,rgba(255,204,8,.12),transparent 34%),
    linear-gradient(180deg,rgba(15,27,46,.98),rgba(7,13,26,.99));
  border:1px solid rgba(255,105,70,.26);
  box-shadow:0 32px 82px rgba(0,0,0,.52),0 0 0 1px rgba(255,255,255,.05) inset;
  backdrop-filter:blur(20px);
}
.cr-chat-widget.open .cr-chat-panel{
  display:flex;
  flex-direction:column;
  animation:crChatIn .18s ease both;
}
@keyframes crChatIn{
  from{opacity:0;transform:translateY(10px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.cr-chat-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  padding:16px 17px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.cr-chat-head strong{
  display:block;
  color:var(--fg);
  letter-spacing:-.035em;
}
.cr-chat-head small{
  display:block;
  color:var(--accent);
  font-size:11px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-top:2px;
}
.cr-chat-close{
  width:38px;
  height:38px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.05);
  color:var(--fg);
  font-size:24px;
  cursor:pointer;
}
.cr-chat-body{
  padding:16px;
  overflow:auto;
  min-height:230px;
  max-height:340px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.cr-chat-msg{
  width:max-content;
  max-width:86%;
  padding:11px 13px;
  border-radius:18px;
  font-size:14px;
  line-height:1.45;
  font-weight:750;
  white-space:pre-line;
}
.cr-chat-msg.bot{
  align-self:flex-start;
  color:var(--fg2);
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
}
.cr-chat-msg.user{
  align-self:flex-end;
  color:#111112;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
}
.cr-chat-quick{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:2px;
}
.cr-chat-quick button{
  border:1px solid rgba(255,105,70,.24);
  background:rgba(255,105,70,.08);
  color:var(--accent);
  border-radius:999px;
  padding:8px 10px;
  cursor:pointer;
  font-weight:900;
  font-size:12px;
}
.cr-chat-quick button:hover{
  background:rgba(255,105,70,.15);
}
.cr-chat-form{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  padding:13px;
  border-top:1px solid rgba(255,255,255,.08);
}
.cr-chat-form input{
  min-height:46px;
  border-radius:16px;
  border:1px solid rgba(255,105,70,.22);
  background:rgba(8,14,27,.95);
  color:var(--fg);
  padding:0 12px;
  font:inherit;
  font-weight:800;
}
.cr-chat-form input:focus{
  outline:0;
  border-color:rgba(255,105,70,.62);
  box-shadow:0 0 0 4px rgba(255,105,70,.12);
}
.cr-chat-form button{
  border:0;
  border-radius:16px;
  padding:0 13px;
  cursor:pointer;
  color:#111112;
  font-weight:950;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
}
.cr-chat-whatsapp{
  margin:0 13px 13px;
  min-height:44px;
  border-radius:16px;
  display:grid;
  place-items:center;
  color:#111112;
  font-weight:950;
  background:linear-gradient(135deg,#25d366,#b7ffcc);
  box-shadow:0 12px 28px rgba(37,211,102,.16);
}
@media(max-width:620px){
  .cr-chat-widget{
    right:14px;
    bottom:14px;
  }
  .cr-chat-bubble{
    min-width:58px;
    width:58px;
    height:58px;
    padding:0;
  }
  .cr-chat-bubble b{
    display:none;
  }
  .cr-chat-panel{
    right:-2px;
    bottom:72px;
    width:calc(100vw - 24px);
    max-height:calc(100vh - 100px);
  }
}


/* =========================================================
   Contacto premium CAR RENTAL DR
   ========================================================= */
.contact-page .section-head.split{
  align-items:end;
}
.contact-grid-premium{
  grid-template-columns:1fr 1.1fr;
  align-items:stretch;
}
.contact-card-main,
.contact-card-form{
  position:relative;
  overflow:hidden;
  border-color:rgba(255,105,70,.22)!important;
}
.contact-card-main::before,
.contact-card-form::before{
  content:"";
  position:absolute;
  inset:-40% -20% auto auto;
  width:240px;
  height:240px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,105,70,.18),transparent 68%);
  pointer-events:none;
}
.contact-badge{
  width:max-content;
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,105,70,.09);
  color:var(--accent);
  border:1px solid rgba(255,105,70,.25);
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:12px;
}
.contact-card-main h2,
.contact-card-form h2{
  margin:6px 0 10px;
  font-size:clamp(28px,3vw,42px);
  line-height:1;
  letter-spacing:-.055em;
}
.contact-info-list{
  display:grid;
  gap:12px;
  margin:22px 0;
}
.contact-info-list div{
  padding:14px 15px;
  border-radius:18px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.075);
}
.contact-info-list small{
  display:block;
  color:var(--muted);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:4px;
}
.contact-info-list b{
  color:var(--fg);
  font-size:18px;
}
.contact-whatsapp-form{
  display:grid;
  gap:10px;
  position:relative;
  z-index:2;
}
.contact-whatsapp-form input,
.contact-whatsapp-form textarea,
.contact-whatsapp-form select{
  width:100%;
  border-radius:18px!important;
  border:1px solid rgba(255,105,70,.24)!important;
  background:
    radial-gradient(circle at 16% 0%,rgba(255,105,70,.12),transparent 34%),
    linear-gradient(180deg,rgba(15,27,46,.98),rgba(8,14,27,.98))!important;
  color:var(--fg)!important;
  font-weight:850!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.055),0 14px 30px rgba(0,0,0,.12)!important;
}
.contact-whatsapp-form input,
.contact-whatsapp-form select{
  min-height:52px!important;
  padding:0 14px!important;
}
.contact-whatsapp-form textarea{
  min-height:132px!important;
  padding:14px!important;
  resize:vertical;
}
.contact-whatsapp-form input:focus,
.contact-whatsapp-form textarea:focus,
.contact-whatsapp-form select:focus{
  outline:0!important;
  border-color:rgba(255,105,70,.68)!important;
  box-shadow:0 0 0 4px rgba(255,105,70,.12),0 20px 42px rgba(0,0,0,.22)!important;
}
.contact-whatsapp-form select option{
  background:#0b1426;
  color:#ecf1ff;
}
.contact-support-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  margin-top:22px;
}
@media(max-width:980px){
  .contact-grid-premium,
  .contact-support-grid{
    grid-template-columns:1fr;
  }
}


/* Acceso oculto Manager */
.hidden-manager-toast{
  position:fixed;
  left:50%;
  bottom:28px;
  transform:translateX(-50%);
  z-index:10000;
  padding:12px 18px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#111112;
  font-weight:950;
  box-shadow:0 20px 50px rgba(0,0,0,.35);
  animation:hiddenManagerToast .55s ease both;
}
@keyframes hiddenManagerToast{
  from{opacity:0;transform:translateX(-50%) translateY(12px)}
  to{opacity:1;transform:translateX(-50%) translateY(0)}
}


/* =========================================================
   Logo actualizado CAR RENTAL DR
   ========================================================= */
.brand-logo-img{
  object-fit:contain!important;
  object-position:center center!important;
  background:transparent!important;
}
.site-header .brand-logo-img{
  width:64px!important;
  height:64px!important;
  border-radius:16px!important;
}
@media(max-width:620px){
  .site-header .brand-logo-img{
    width:54px!important;
    height:54px!important;
  }
}

/* =========================================================
   Ajustes moviles finales
   Evitan que tarjetas, hero, galeria y formularios se peguen
   o se salgan de la pantalla en celulares.
   ========================================================= */
html,
body{
  max-width:100%;
  overflow-x:hidden;
}

.site-header,
.page-shell,
.hero,
.booking-panel,
.vehicle-card,
.vehicle-inner,
.location-card,
.contact-card,
.info-card,
.step-card,
.mini-route-card,
.cr-modal-panel{
  min-width:0;
  max-width:100%;
}

@media(max-width:760px){
  body{
    width:100%;
  }

  .site-header{
    padding:10px 14px!important;
    gap:10px!important;
    align-items:center;
  }

  .brand{
    min-width:0;
    flex:1 1 auto;
    gap:9px;
  }

  .brand-text{
    min-width:0;
  }

  .brand b{
    display:block;
    max-width:44vw;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    font-size:15px!important;
    letter-spacing:0!important;
  }

  .brand small{
    display:none!important;
  }

  .header-actions{
    flex:0 0 auto;
    gap:6px!important;
  }

  .header-actions .btn{
    min-height:38px!important;
    padding:0 11px!important;
    font-size:12px!important;
  }

  .page-shell{
    padding:30px 14px 48px!important;
  }

  .hero,
  .hero.dynamic-hero{
    grid-template-columns:1fr!important;
    min-height:auto!important;
    padding:32px 14px 24px!important;
    gap:18px!important;
  }

  .hero-content{
    min-width:0;
  }

  h1{
    font-size:clamp(34px,10.5vw,44px)!important;
    line-height:1.02!important;
    letter-spacing:-.035em!important;
  }

  h2,
  .cr-modal-hero h2{
    font-size:clamp(28px,8.5vw,38px)!important;
    line-height:1.04!important;
    letter-spacing:-.03em!important;
  }

  p{
    line-height:1.62;
  }

  .trust-row,
  .route-grid,
  .vehicles-grid,
  .info-grid,
  .location-grid,
  .location-grid--maps,
  .step-grid,
  .contact-grid,
  .contact-grid-premium,
  .contact-support-grid,
  .booking-grid,
  .reservation-grid,
  .section-head.split,
  .split-page{
    grid-template-columns:1fr!important;
  }

  .home-booking{
    margin:0 14px 18px!important;
  }

  .booking-panel{
    border-radius:22px!important;
    overflow:visible!important;
  }

  .booking-tabs,
  .category-strip{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }

  .booking-tabs::-webkit-scrollbar,
  .category-strip::-webkit-scrollbar{
    display:none;
  }

  .booking-grid,
  .reservation-grid{
    padding:14px!important;
    gap:12px!important;
  }

  input,
  select,
  textarea,
  .btn,
  .search-btn,
  .reservation-whatsapp-btn{
    max-width:100%;
  }

  .reservation-whatsapp-btn,
  .search-btn{
    width:100%;
    min-width:0!important;
  }

  .vehicle-card.flip-card,
  .vehicle-card.flip-card .vehicle-inner,
  .home-catalog-grid .vehicle-card.flip-card,
  .home-catalog-grid .vehicle-card.flip-card .vehicle-inner{
    min-height:0!important;
  }

  .vehicle-card.flip-card .vehicle-inner{
    display:block;
  }

  .vehicle-card.flip-card .flip-face{
    position:relative!important;
    height:auto!important;
    backface-visibility:visible!important;
    transform:none!important;
  }

  .vehicle-card.flip-card .flip-back{
    display:none;
  }

  .vehicle-card.flip-card.is-flipped .flip-front{
    display:none;
  }

  .vehicle-card.flip-card.is-flipped .flip-back{
    display:flex;
  }

  .vehicle-card.flip-card .flip-front .vehicle-img{
    height:210px!important;
  }

  .hero-visual,
  .kia-hero-visual{
    min-height:auto!important;
    border-radius:26px!important;
  }

  .hero-gallery-wrap,
  .hero-3d-carousel-wrap,
  .kia-hero-car-wrap{
    width:100%!important;
    min-height:250px!important;
    margin-left:0!important;
  }

  .hero-gallery-image,
  #heroCarImage,
  .hero-3d-model,
  .kia-hero-model{
    width:100%!important;
    max-width:100%!important;
    height:auto!important;
    max-height:310px!important;
    transform:none!important;
  }

  .hero-3d-spec-panel.kia-spec-panel{
    width:100%!important;
    max-width:100%!important;
    margin:8px 0 0!important;
  }

  .hero-3d-spec-panel .kia-spec-grid{
    grid-template-columns:1fr 1fr!important;
  }

  .cr-modal-panel{
    width:calc(100vw - 20px)!important;
    max-height:94vh!important;
    border-radius:20px!important;
  }

  .cr-modal-shell{
    padding:16px!important;
  }

  .cr-modal-hero{
    padding-right:44px!important;
    margin-bottom:14px!important;
  }

  .cr-modal-grid{
    grid-template-columns:1fr!important;
    gap:12px!important;
  }

  .cr-modal-stage{
    min-height:245px!important;
    height:245px!important;
  }

  .cr-modal-stage img{
    padding:10px!important;
    max-height:235px!important;
  }

  .cr-modal-thumbs{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }

  footer{
    padding:30px 14px!important;
  }
}
