:root{
  --black:#05080a;
  --black-2:#080c0f;
  --dark:#0b0f12;
  --yellow:#ffc400;
  --yellow-2:#f2b900;
  --white:#ffffff;
  --soft:#f6f6f6;
  --text:#13171b;
  --muted:#62676d;
  --border:#e8e8e8;
  --footer-line:rgba(255,255,255,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:Inter,Arial,sans-serif;
  color:var(--text);
  background:#fff;
  line-height:1.55;
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}
.container{
  width:min(100%,1120px);
  margin:0 auto;
  padding:0 58px;
}
.site-header{
  height:80px;
  background:linear-gradient(180deg,#070b0d 0%,#050708 100%);
  color:#fff;
  position:relative;
  z-index:10;
}
.header-inner{
  height:80px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:178px;
}
.brand-icon{
  width:53px;
  height:36px;
  color:#fff;
  display:inline-flex;
}
.brand-icon svg{
  width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;
}
.brand-text{
  display:flex;
  flex-direction:column;
  font-family:Montserrat,Arial,sans-serif;
  font-weight:900;
  line-height:.9;
  letter-spacing:.3px;
}
.brand-text strong{font-size:21px;color:#fff;font-weight:900}
.brand-text b{font-size:20px;color:var(--yellow);font-weight:900}
.main-nav{
  display:flex;
  align-items:center;
  gap:31px;
  margin-left:auto;
}
.main-nav a{
  position:relative;
  color:#fff;
  font-family:Montserrat,Arial,sans-serif;
  font-size:13px;
  font-weight:800;
  text-transform:uppercase;
  padding:30px 0 29px;
  transition:.2s ease;
}
.main-nav a:hover,.main-nav a.active{color:var(--yellow)}
.main-nav a.active::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:18px;
  height:2px;
  background:var(--yellow);
}
.header-phone{
  height:46px;
  min-width:205px;
  background:var(--yellow);
  color:#050505;
  border-radius:4px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-weight:900;
  font-family:Montserrat,Arial,sans-serif;
  font-size:14px;
  margin-left:14px;
  box-shadow:0 8px 24px rgba(255,196,0,.19);
}
.header-phone svg,.btn svg,.footer-contact svg,.float-whatsapp svg{
  width:18px;height:18px;fill:currentColor;stroke:none;
}
.menu-toggle{display:none;background:transparent;border:0;width:42px;height:42px;align-items:center;justify-content:center;flex-direction:column;gap:6px;cursor:pointer}
.menu-toggle span{width:24px;height:3px;background:#fff;border-radius:999px;display:block}
.hero{
  height:452px;
  position:relative;
  background:#040607;
  color:#fff;
  overflow:hidden;
}
.hero-bg{
  position:absolute;
  inset:0;
  background-image:url('../img/hero-guincho.jpg');
  background-repeat:no-repeat;
  background-size:cover;
  background-position:center right;
  filter:saturate(.95) contrast(1.05);
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(2,5,7,.97) 0%,rgba(2,5,7,.89) 32%,rgba(2,5,7,.3) 58%,rgba(2,5,7,.12) 100%),
    linear-gradient(180deg,rgba(0,0,0,.24),rgba(0,0,0,.12));
}
.hero-inner{position:relative;height:100%;display:flex;align-items:center}
.hero-copy{max-width:470px;padding-top:6px}
.eyebrow,.section-kicker{
  font-family:Montserrat,Arial,sans-serif;
  color:var(--yellow);
  text-transform:uppercase;
  letter-spacing:1.4px;
  font-size:14px;
  font-weight:900;
}
.hero h1{
  font-family:Montserrat,Arial,sans-serif;
  font-size:47px;
  line-height:1.14;
  letter-spacing:.2px;
  font-weight:900;
  margin:20px 0 14px;
}
.yellow-line{display:block;width:48px;height:3px;background:var(--yellow);margin:0 0 23px}
.hero-text{font-size:19px;color:#f4f4f4;line-height:1.7;margin-bottom:30px}
.hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.btn{
  min-height:46px;
  padding:0 24px;
  border-radius:4px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  text-transform:uppercase;
  font-family:Montserrat,Arial,sans-serif;
  font-size:13px;
  font-weight:900;
  border:1px solid transparent;
  transition:.2s ease;
  cursor:pointer;
}
.btn-primary{background:var(--yellow);color:#050505;border-color:var(--yellow)}
.btn-primary:hover{background:#ffd226;transform:translateY(-1px)}
.btn-outline{color:#fff;background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.58);min-width:245px}
.btn-outline:hover{border-color:var(--yellow);color:var(--yellow)}
.services{
  background:#fff;
  padding:31px 0 28px;
  text-align:center;
}
.services h2,.why h2,.fleet h2{
  font-family:Montserrat,Arial,sans-serif;
  color:#151719;
  font-size:28px;
  line-height:1.1;
  font-weight:900;
  margin-top:3px;
}
.service-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:22px;
  margin:24px 8px 19px;
}
.service-card{
  background:#fff;
  min-height:214px;
  border:1px solid var(--border);
  border-radius:8px;
  box-shadow:0 5px 25px rgba(0,0,0,.08);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  padding:14px 12px 20px;
}
.service-icon{width:100%;height:96px;margin-bottom:18px;object-fit:cover;border-radius:6px;background:#f3f3f3;display:block}
.service-card h3,.fleet-card h3,.why-item h3{
  font-family:Montserrat,Arial,sans-serif;
  font-size:16px;
  font-weight:900;
  line-height:1.2;
  color:#161a1d;
}
.service-card p{
  font-size:14px;
  line-height:1.55;
  margin-top:10px;
  color:#30363a;
}
.services-btn{background:var(--yellow);color:#050505;min-width:258px;margin:0 auto 0}
.why{
  background:
    radial-gradient(circle at 55% -40%,rgba(255,255,255,.08),transparent 44%),
    linear-gradient(180deg,#080d10 0%,#05080a 100%);
  color:#fff;
  text-align:center;
  padding:23px 0 34px;
}
.why h2{color:#fff;font-size:27px;margin-bottom:23px}
.why-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  align-items:stretch;
}
.why-item{
  min-height:126px;
  padding:0 25px;
  border-right:1px solid rgba(255,255,255,.22);
  display:flex;
  flex-direction:column;
  align-items:center;
}
.why-item:last-child{border-right:none}
.why-icon{
  width:62px;height:62px;color:var(--yellow);margin:1px 0 10px;display:flex;align-items:center;justify-content:center;
}
.why-icon svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:4;stroke-linecap:round;stroke-linejoin:round}
.why-item h3{color:#fff;font-size:16px;margin-bottom:3px}
.why-item p{color:#f3f3f3;font-size:15px;line-height:1.55}
.fleet{
  background:#fff;
  text-align:center;
  padding:22px 0 18px;
  position:relative;
}
.fleet h2{font-size:27px;margin-bottom:15px}
.fleet-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin:0 24px;
}
.fleet-card img{
  width:100%;
  height:106px;
  object-fit:cover;
  border-radius:6px;
  background:#f3f3f3;
  margin-bottom:9px;
}
.fleet-card h3{font-size:15px;line-height:1.1}
.fleet-card p{font-size:13px;line-height:1.2;color:#222;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fleet-arrow{
  position:absolute;
  top:51%;
  transform:translateY(-50%);
  width:42px;height:42px;border-radius:50%;border:0;background:#fff;color:#222;
  box-shadow:0 2px 15px rgba(0,0,0,.12);
  display:flex;align-items:center;justify-content:center;z-index:2;cursor:pointer;
}
.fleet-arrow svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.fleet-prev{left:24px}.fleet-next{right:24px}
.site-footer{
  background:
    radial-gradient(circle at 25% 0%,rgba(255,255,255,.06),transparent 35%),
    linear-gradient(180deg,#090e10,#05080a);
  color:#fff;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.05fr .78fr 1.05fr 1.36fr;
  gap:31px;
  padding-top:37px;
  padding-bottom:31px;
}
.footer-grid>div,.footer-grid>form{border-left:1px solid var(--footer-line);padding-left:32px}
.footer-grid>div:first-child{border-left:0;padding-left:0}
.brand-footer{min-width:0;margin-bottom:18px}
.footer-brand p{font-size:16px;line-height:1.55;color:#f4f4f4;max-width:242px}
.socials{display:flex;gap:18px;margin-top:21px}
.socials a{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.09);display:grid;place-items:center;color:#fff;font-weight:800;font-size:16px}
.footer-grid h3{
  font-family:Montserrat,Arial,sans-serif;
  color:var(--yellow);
  text-transform:uppercase;
  font-size:14px;
  line-height:1;
  margin-bottom:18px;
  font-weight:900;
  letter-spacing:.5px;
}
.footer-links{display:flex;flex-direction:column}
.footer-links a{font-size:15px;color:#fff;margin-bottom:13px;line-height:1}
.footer-links a:hover{color:var(--yellow)}
.footer-contact p{display:flex;align-items:center;gap:12px;font-size:14px;line-height:1.35;color:#fff;margin-bottom:16px}
.footer-contact svg{width:18px;height:18px;color:#fff;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}
.contact-form h3{margin-bottom:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.contact-form input,.contact-form textarea{
  width:100%;border:0;border-radius:4px;background:#f7f7f7;color:#1d2226;font-size:13px;padding:0 15px;outline:none;
}
.contact-form input{height:38px}
.contact-form textarea{height:70px;resize:none;padding-top:14px;margin-bottom:13px}
.form-button{width:100%;height:40px;min-height:40px;border:0}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.07);
  text-align:center;
  color:#fff;
  font-size:13px;
  padding:22px 0 24px;
}
.float-whatsapp{
  position:fixed;
  right:20px;bottom:20px;
  width:54px;height:54px;border-radius:50%;background:#25d366;color:#fff;
  display:none;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,.24);z-index:50;
}
.float-whatsapp svg{width:30px;height:30px}
@media (min-width:1120px){
  .container{width:1120px;padding-left:58px;padding-right:58px}
}
@media (max-width:1020px){
  .container{padding:0 28px}
  .main-nav{gap:18px}
  .main-nav a{font-size:12px}
  .header-phone{min-width:176px;font-size:12px}
  .hero h1{font-size:42px}
  .service-grid,.fleet-grid{gap:16px;margin-left:0;margin-right:0}
  .footer-grid{grid-template-columns:1fr 1fr;gap:34px}
  .footer-grid>div,.footer-grid>form{border-left:0;padding-left:0}
}
@media (max-width:780px){
  .site-header,.header-inner{height:72px}
  .brand{min-width:auto}
  .brand-icon{width:48px}
  .brand-text strong{font-size:18px}.brand-text b{font-size:17px}
  .menu-toggle{display:flex;margin-left:auto}
  .main-nav{
    position:absolute;top:72px;left:0;right:0;background:#070b0d;display:none;flex-direction:column;align-items:flex-start;gap:0;padding:10px 28px 22px;border-top:1px solid rgba(255,255,255,.08)
  }
  .main-nav.open{display:flex}
  .main-nav a{width:100%;padding:14px 0}.main-nav a.active::after{display:none}
  .header-phone{display:none}
  .hero{height:auto;min-height:610px}
  .hero-bg{background-position:63% 50%;opacity:.62}
  .hero-overlay{background:linear-gradient(180deg,rgba(2,5,7,.94),rgba(2,5,7,.72) 55%,rgba(2,5,7,.92))}
  .hero-inner{min-height:610px;align-items:flex-start;padding-top:80px;padding-bottom:56px}
  .hero-copy{max-width:100%}
  .hero h1{font-size:38px}
  .hero-text{font-size:17px}
  .hero-actions{flex-direction:column;align-items:stretch}.btn-outline,.btn-primary{width:100%;min-width:0}
  .services{padding:34px 0 35px}.services h2,.why h2,.fleet h2{font-size:25px;line-height:1.22}
  .service-grid{grid-template-columns:1fr 1fr;margin-top:24px}
  .why-grid{grid-template-columns:1fr 1fr;gap:28px}.why-item{border-right:0;padding:0 10px}
  .fleet-grid{grid-template-columns:1fr 1fr}.fleet-arrow{display:none}
  .footer-grid{grid-template-columns:1fr}.footer-brand p{max-width:none}.float-whatsapp{display:flex}
}
@media (max-width:520px){
  .container{padding:0 20px}
  .hero h1{font-size:31px}.eyebrow,.section-kicker{font-size:12px}.hero-text{font-size:16px}
  .service-grid,.why-grid,.fleet-grid{grid-template-columns:1fr}
  .service-card{min-height:170px}.form-row{grid-template-columns:1fr}
  .footer-grid{padding-top:32px}
}
