:root{
  --primary:#ea9000;
  --primary-dark:#c47700;
  --secondary:#ffffff;
  --tertiary:#1c1c1c;
  --tertiary-soft:#2a2a2a;
}
*{scroll-behavior:smooth}
body{
  font-family:'Poppins',system-ui,-apple-system,sans-serif;
  background:var(--secondary);
  color:var(--tertiary);
  overflow-x:hidden;
}
h1,h2,h3,h4,h5{font-weight:700;letter-spacing:-.5px}
a{text-decoration:none}

/* NAVBAR */
.navbar-custom{
  background:var(--tertiary);
  padding:.9rem 0;
  transition:all .3s ease;
  box-shadow:0 2px 20px rgba(0,0,0,.15);
}
.navbar-custom.scrolled{padding:.5rem 0;background:rgba(28,28,28,.97);backdrop-filter:blur(10px)}
.navbar-custom .navbar-brand{
  color:var(--secondary);
  font-weight:800;
  font-size:1.4rem;
  letter-spacing:1px;
}
.navbar-custom .navbar-brand span{color:var(--primary)}
.navbar-custom .nav-link{
  color:var(--secondary)!important;
  font-weight:600;
  font-size:.85rem;
  letter-spacing:1.2px;
  margin:0 .5rem;
  position:relative;
  text-transform:uppercase;
  transition:color .3s;
}
.navbar-custom .nav-link::after{
  content:'';position:absolute;left:50%;bottom:-4px;
  width:0;height:2px;background:var(--primary);
  transition:all .3s ease;
}
.navbar-custom .nav-link:hover,
.navbar-custom .nav-link.active{color:var(--primary)!important}
.navbar-custom .nav-link:hover::after,
.navbar-custom .nav-link.active::after{width:100%;left:0}
.nav-icons a{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:50%;
  background:var(--primary);color:var(--secondary);
  margin-left:6px;font-size:1.1rem;
  transition:all .3s ease;
}
.nav-icons a:hover{background:var(--primary-dark);transform:translateY(-3px) scale(1.08)}
.navbar-toggler{border:none;color:var(--primary);font-size:1.5rem}
.navbar-toggler:focus{box-shadow:none}

/* HERO */
.hero{
  position:relative;
  background-image: url("../img/fondoBanner-01.png");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  min-height:90vh;
  display:flex;align-items:center;
  overflow:hidden;
  padding:120px 0 0;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 20% 80%,rgba(255,255,255,.15) 0%,transparent 50%);
}
.hero-shape{
  position:absolute;bottom:-1px;left:0;width:100%;height:120px;
  background:var(--tertiary);
  clip-path:polygon(0 60%,100% 0,100% 100%,0 100%);
}
.hero h1{
  color:var(--secondary);
  font-size:clamp(2.2rem,5vw,4rem);
  font-weight:800;
  line-height:1.1;
  text-shadow:0 4px 20px rgba(0,0,0,.2);
}
.hero p.lead{color:rgba(255,255,255,.95);font-size:1.2rem;font-weight:400}
.hero-img{
  position:relative;z-index:2;
  filter:drop-shadow(0 25px 40px rgba(0,0,0,.4));
  animation:floatCar 5s ease-in-out infinite;
}
@keyframes floatCar{
  0%,100%{transform:translateY(0) rotate(-1deg)}
  50%{transform:translateY(-15px) rotate(1deg)}
}

/* BUTTONS */
.btn-primary-custom{
  background:var(--tertiary);color:var(--secondary)!important;
  padding:14px 32px;border-radius:50px;font-weight:600;
  border:2px solid var(--tertiary);
  display:inline-flex;align-items:center;gap:10px;
  transition:all .3s ease;font-size:1rem;
  box-shadow:0 8px 25px rgba(0,0,0,.25);
}
.btn-primary-custom:hover{
  background:var(--primary);border-color:var(--primary);
  transform:translateY(-3px);
  box-shadow:0 12px 30px rgba(234,144,0,.5);
}
.btn-outline-custom{
  background:transparent;color:var(--secondary)!important;
  border:2px solid var(--secondary);
  padding:14px 32px;border-radius:50px;font-weight:600;
  display:inline-flex;align-items:center;gap:10px;
  transition:all .3s ease;
}
.btn-outline-custom:hover{background:var(--secondary);color:var(--primary)!important;transform:translateY(-3px)}

/* SECTIONS */
section{padding:90px 0}
.section-title{margin-bottom:60px;text-align:center}
.section-title .eyebrow{
  display:inline-block;color:var(--primary);font-weight:700;
  letter-spacing:3px;font-size:.85rem;text-transform:uppercase;
  margin-bottom:12px;
}
.section-title h2{font-size:clamp(1.8rem,3.5vw,2.8rem);color:var(--tertiary)}
.section-title p{color:#666;max-width:600px;margin:15px auto 0}

/* STATS */
.stats-section{
  background:linear-gradient(135deg,var(--primary) 0%,#ff9d1a 100%);
  color:var(--secondary);position:relative;overflow:hidden;
}
.stats-section::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 0l30 30-30 30L0 30z' fill='%23ffffff' fill-opacity='.05'/%3E%3C/svg%3E");
}
.stats-section .section-title h2,
.stats-section .section-title p{color:var(--secondary)}
.stats-section .eyebrow{color:rgba(255,255,255,.85)!important}
.stat-item{text-align:center;position:relative;z-index:2}
.stat-icon{
  width:120px;height:120px;border-radius:50%;
  border:3px solid var(--secondary);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 25px;font-size:3rem;
  transition:all .4s ease;
}
.stat-item:hover .stat-icon{
  background:var(--secondary);color:var(--primary);
  transform:rotate(360deg) scale(1.05);
}
.stat-number{font-size:3rem;font-weight:800;margin-bottom:5px}

/* FEATURE CARDS */
.feature-card{
  background:var(--secondary);
  border-radius:20px;
  padding:40px 30px;
  height:100%;
  border:1px solid #eee;
  transition:all .4s ease;
  position:relative;overflow:hidden;
}
.feature-card::before{
  content:'';position:absolute;top:0;left:0;width:100%;height:4px;
  background:var(--primary);transform:scaleX(0);transform-origin:left;
  transition:transform .4s ease;
}
.feature-card:hover{transform:translateY(-10px);box-shadow:0 25px 50px rgba(0,0,0,.12)}
.feature-card:hover::before{transform:scaleX(1)}
.feature-icon{
  width:75px;height:75px;border-radius:18px;
  background:linear-gradient(135deg,var(--primary),#ffb347);
  display:flex;align-items:center;justify-content:center;
  font-size:2rem;color:var(--secondary);margin-bottom:25px;
  transition:all .4s ease;
}
.feature-card:hover .feature-icon{transform:rotate(-10deg) scale(1.1)}
.feature-card h4{color:var(--tertiary);margin-bottom:15px}
.feature-card p{color:#666;margin:0;line-height:1.7}

/* CTA STRIP */
.cta-strip{
  background:var(--tertiary);
  position:relative;overflow:hidden;
  padding:70px 0;
}
.cta-strip::before{
  content:'';position:absolute;top:0;right:-100px;
  width:400px;height:100%;
  background:var(--primary);
  transform:skewX(-20deg);opacity:.9;
}
.cta-strip h3{color:var(--secondary);font-size:2rem;position:relative;z-index:2}
.cta-strip p{color:rgba(255,255,255,.7);margin:0;position:relative;z-index:2}

/* TESTIMONIALS / PROCESS */
.process-step{
  text-align:center;padding:30px 20px;position:relative;
}
.process-step .step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:60px;height:60px;border-radius:50%;
  background:var(--primary);color:var(--secondary);
  font-size:1.5rem;font-weight:800;margin-bottom:20px;
  box-shadow:0 10px 25px rgba(234,144,0,.4);
}
.process-step h5{color:var(--tertiary)}
.process-step p{color:#666;font-size:.95rem}

/* TRUST BADGES */
.trust-badge{
  display:flex;align-items:center;gap:15px;
  background:#f8f8f8;padding:20px 25px;border-radius:14px;
  border-left:4px solid var(--primary);
}
.trust-badge i{font-size:2rem;color:var(--primary)}
.trust-badge h6{margin:0;font-weight:700;color:var(--tertiary)}
.trust-badge small{color:#888}

/* FORMS */
.form-card{
  background:var(--secondary);
  border-radius:24px;
  padding:50px;
  box-shadow:0 30px 60px rgba(0,0,0,.1);
  border-top:5px solid var(--primary);
}
.form-label{font-weight:600;color:var(--tertiary);font-size:.9rem;margin-bottom:8px}
.form-control,.form-select{
  border:2px solid #eee;border-radius:12px;
  padding:13px 18px;font-size:.95rem;
  transition:all .3s ease;
}
.form-control:focus,.form-select:focus{
  border-color:var(--primary);box-shadow:0 0 0 4px rgba(234,144,0,.15);
}
.btn-submit{
  background:var(--primary);color:var(--secondary);
  border:none;padding:15px 40px;border-radius:50px;
  font-weight:700;letter-spacing:.5px;width:100%;
  transition:all .3s ease;font-size:1.05rem;
}
.btn-submit:hover{background:var(--tertiary);transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.25)}

/* PAGE HEADER */
.page-header{
  background:linear-gradient(135deg,var(--tertiary) 0%,#2c2c2c 100%);
  padding:160px 0 80px;position:relative;overflow:hidden;
  color:var(--secondary);
}
.page-header::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:6px;
  background:linear-gradient(90deg,var(--primary),#ffb347,var(--primary));
}
.page-header h1{font-size:clamp(2rem,4vw,3.2rem);margin:0}
.page-header p{color:rgba(255,255,255,.7);margin-top:10px;font-size:1.1rem}
.breadcrumb-custom{
  display:flex;gap:10px;align-items:center;
  color:rgba(255,255,255,.6);font-size:.9rem;margin-bottom:15px;
}
.breadcrumb-custom a{color:var(--primary)}

/* CONTACT INFO */
.contact-info-card{
  background:var(--secondary);border-radius:18px;
  padding:35px 30px;text-align:center;height:100%;
  border:1px solid #eee;transition:all .3s ease;
}
.contact-info-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px rgba(0,0,0,.1);border-color:var(--primary)}
.contact-info-card .ci-icon{
  width:70px;height:70px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),#ffb347);
  color:var(--secondary);font-size:1.8rem;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;
}
.contact-info-card h5{color:var(--tertiary)}
.contact-info-card a{color:#444;font-weight:500}
.contact-info-card a:hover{color:var(--primary)}

/* FOOTER */
footer{
  background:#0e0e0e;color:#bbb;
  padding:70px 0 25px;
}
footer h5{color:var(--secondary);margin-bottom:22px;font-size:1.1rem}
footer h5 span{color:var(--primary)}
footer a{color:#bbb;display:block;padding:5px 0;font-size:.92rem;transition:color .3s}
footer a:hover{color:var(--primary);padding-left:6px}
footer .footer-social a{
  display:inline-flex;width:40px;height:40px;border-radius:50%;
  background:#1f1f1f;align-items:center;justify-content:center;
  margin-right:8px;color:var(--secondary);padding:0;
}
footer .footer-social a:hover{background:var(--primary);padding-left:0;transform:translateY(-3px)}
.footer-bottom{
  border-top:1px solid #1f1f1f;margin-top:50px;padding-top:25px;
  text-align:center;font-size:.85rem;color:#777;
}

/* WHATSAPP FLOAT */
.whatsapp-float{
  position:fixed;bottom:25px;right:25px;z-index:9999;
  width:60px;height:60px;border-radius:50%;
  background:#25d366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:2rem;text-decoration:none;
  box-shadow:0 10px 30px rgba(37,211,102,.5);
  animation:pulseWa 2s infinite;
}
.whatsapp-float:hover{color:#fff;transform:scale(1.1)}
@keyframes pulseWa{
  0%{box-shadow:0 0 0 0 rgba(37,211,102,.6),0 10px 30px rgba(37,211,102,.5)}
  70%{box-shadow:0 0 0 20px rgba(37,211,102,0),0 10px 30px rgba(37,211,102,.5)}
  100%{box-shadow:0 0 0 0 rgba(37,211,102,0),0 10px 30px rgba(37,211,102,.5)}
}

/* COOKIES MODAL */
.modal-cookies .modal-content{
  border-radius:20px;border:none;overflow:hidden;
}
.modal-cookies .modal-body{padding:35px 30px}
.modal-cookies h4{font-weight:800;color:var(--tertiary);margin-bottom:18px;line-height:1.3}
.modal-cookies p{color:#444;font-size:.92rem;line-height:1.6}
.modal-cookies .btn-accept{
  background:var(--tertiary);color:var(--secondary);
  border:none;width:100%;padding:14px;border-radius:10px;
  font-weight:700;margin-bottom:10px;
}
.modal-cookies .btn-accept:hover{background:var(--primary);color:var(--secondary)}
.modal-cookies .btn-more{
  background:transparent;color:var(--tertiary);
  border:2px solid #ddd;width:100%;padding:12px;border-radius:10px;
  font-weight:700;
}
.modal-cookies .btn-more:hover{border-color:var(--primary);color:var(--primary)}

/* DRIVING ANIMATION */
.road-strip{
  position:relative;height:8px;background:var(--tertiary);
  margin:0;overflow:hidden;
}
.road-strip::after{
  content:'';position:absolute;top:50%;left:0;width:100%;height:2px;
  background-image:linear-gradient(90deg,var(--primary) 50%,transparent 50%);
  background-size:40px 2px;
  transform:translateY(-50%);
  animation:roadMove 1.5s linear infinite;
}
@keyframes roadMove{from{background-position:0 0}to{background-position:-40px 0}}

@media (max-width:991px){
  .navbar-collapse{background:var(--tertiary);padding:20px;border-radius:12px;margin-top:15px}
  .nav-icons{margin-top:15px;text-align:center}
  .hero{min-height:auto;padding:130px 0 80px}
  section{padding:60px 0}
  .form-card{padding:30px 20px}
  .cta-strip::before{display:none}
}