/* ===== RESET & VARIABLES ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg-dark:#0a0a0f;--bg-card:#13131a;--bg-card-hover:#1a1a25;
  --accent:#e63946;--accent-glow:rgba(230,57,70,.3);--accent-dark:#c1121f;
  --text:#f1f1f1;--text-muted:#8a8a9a;--text-light:#ccc;
  --border:rgba(255,255,255,.06);--glass:rgba(255,255,255,.03);
  --radius:16px;--radius-sm:10px;--radius-xs:6px;
  --shadow:0 8px 32px rgba(0,0,0,.4);--transition:.3s cubic-bezier(.4,0,.2,1);
  --font:'Inter',sans-serif;--font-display:'Outfit',sans-serif;
  --nav-h:70px;
}
html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h)}
body{font-family:var(--font);background:var(--bg-dark);color:var(--text);line-height:1.6;overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%; height:auto; display: block}
.container{max-width:1280px;margin:0 auto;padding:0 20px}
.accent{color:var(--accent)}
.section{
  padding: clamp(60px, 8vw, 120px) 0;
}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:50px;font-weight:600;font-size:.95rem;border:none;cursor:pointer;transition:var(--transition);font-family:var(--font)}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 8px 25px var(--accent-glow)}
.btn-outline{border:2px solid rgba(255,255,255,.2);color:#fff;background:transparent}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}
.btn-ghost:hover{color:var(--accent);border-color:var(--accent)}
.btn-whatsapp{background:#25d366;color:#fff}
.btn-whatsapp:hover{background:#1ebe5b;transform:translateY(-2px);box-shadow:0 8px 25px rgba(37,211,102,.3)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-dark)}
.btn-lg{padding:16px 36px;font-size:1.05rem}
.btn-sm{padding:10px 20px;font-size:.85rem}
.btn-full{width:100%;justify-content:center}

/* ===== NAVBAR ===== */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:12px 0;transition:var(--transition);background:transparent}
.navbar.scrolled{background:rgba(10,10,15,.95);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:8px 0}
.nav-container{max-width:1280px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800;font-size:1.3rem;z-index:1001}
.logo-icon{width:40px;height:40px;background:var(--accent);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.nav-menu{display:flex;align-items:center;gap:8px}
.nav-link{padding:8px 16px;border-radius:50px;font-size:.9rem;font-weight:500;color:var(--text-muted);transition:var(--transition)}
.nav-link:hover,.nav-link.active{color:#fff;background:rgba(255,255,255,.08)}
.nav-admin{color:var(--accent)!important;font-size:.8rem}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:5px;z-index:1001}
.nav-toggle span{width:24px;height:2px;background:#fff;transition:var(--transition);border-radius:2px}

/* ===== HERO ===== */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;justify-content:center;overflow:hidden; padding: 100px 0 60px;}
.hero-bg{position:absolute;inset:0}
.hero-bg-img{width:100%;height:100%;object-fit:cover;transform:scale(1.1); filter: brightness(0.85) contrast(1.1) saturate(1.2);}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,15,.6) 0%,rgba(10,10,15,.4) 50%,var(--bg-dark) 100%)}
.hero-particles{position:absolute;inset:0;pointer-events:none}
.hero-content{position:relative;z-index:2;text-align:center;max-width:1100px;padding:0 20px; margin: 0 auto;}
.hero-badge{display:inline-block;padding:8px 20px;background:rgba(230,57,70,.15);border:1px solid rgba(230,57,70,.3);border-radius:50px;font-size:.85rem;color:var(--accent);margin-bottom:24px;font-weight:500}
.hero-title{
  font-size: clamp(32px, 6vw, 64px);
  line-height: 1.1; color: #ffffff; text-shadow: 0 4px 20px rgba(0,0,0,0.6);
}
.hero-subtitle{font-size:clamp(1.1rem,2.5vw,1.5rem);color:var(--text-light);margin-bottom:8px;font-weight:500}
.hero-desc{font-size:1rem;color: #ffffff;margin-bottom:36px; text-shadow:    0 0 5px rgba(255,255,255,0.9),
    0 0 10px rgba(255,255,255,0.7),
    0 0 20px rgba(255,255,255,0.5)}
.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}
.hero-stats{display:flex;gap:48px;justify-content:center;flex-wrap:wrap}
.stat-item{text-align:center}
.stat-number{font-family:var(--font-display);font-size:2.5rem;font-weight:800;color:var(--accent)}
.stat-suffix{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--accent)}
.stat-label{display:block;font-size:.85rem;color:var(--text-muted);margin-top:4px}
.hero-scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2}
.scroll-arrow{width:24px;height:38px;border:2px solid rgba(255,255,255,.3);border-radius:12px;position:relative}
.scroll-arrow::after{content:'';position:absolute;top:8px;left:50%;transform:translateX(-50%);width:4px;height:8px;background:var(--accent);border-radius:2px;animation:scrollBounce 1.5s infinite}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0);opacity:1}50%{transform:translateX(-50%) translateY(10px);opacity:.3}}

/* ===== SECTION HEADERS ===== */
.section-header{text-align:center;margin-bottom:60px}
.section-badge{display:inline-block;padding:6px 16px;background:rgba(230,57,70,.1);border:1px solid rgba(230,57,70,.2);border-radius:50px;font-size:.8rem;color:var(--accent);margin-bottom:16px;font-weight:500}
.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:12px}
.section-desc{color:var(--text-muted);max-width:600px;margin:0 auto;font-size:1rem}

/* ===== FILTERS ===== */
.filters-bar{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;padding:24px;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:40px}
.filter-group{flex:1;min-width:160px}
.filter-group label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:6px;font-weight:500}
.filter-group select,.filter-group input{width:100%;padding:10px 14px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:var(--radius-xs);color:#fff;font-size:.9rem;font-family:var(--font);transition:var(--transition)}
.filter-group select:focus,.filter-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.filter-group select option{background:var(--bg-dark);color:#fff}
.price-range{display:flex;gap:8px;align-items:center}
.price-range input{width:50%}
.price-range span{color:var(--text-muted)}
.filter-search{min-width:200px}
.btn-filter{align-self:flex-end;height:42px}

/* ===== MOTOS GRID ===== */
.motos-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:20px;
}
.moto-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;transition:var(--transition);position:relative}
.moto-card:hover{transform:translateY(-6px);border-color:rgba(230,57,70,.3);box-shadow:0 16px 48px rgba(230,57,70,.1)}
.moto-card-img{position:relative;height:220px;overflow:hidden;background:linear-gradient(135deg,#111,#1a1a2e)}
.moto-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.moto-card:hover .moto-card-img img{transform:scale(1.08)}
.moto-card-badge{position:absolute;top:12px;left:12px;padding:4px 12px;background:var(--accent);border-radius:50px;font-size:.75rem;font-weight:600;color:#fff}
.moto-card-body{padding:20px}
.moto-card-brand{font-size:.8rem;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.moto-card-model{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:8px}
.moto-card-specs{display:flex;gap:12px;margin-bottom:16px}
.moto-spec{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--text-muted);padding:4px 10px;background:rgba(255,255,255,.04);border-radius:50px}
.moto-card-price{font-family:var(--font-display);font-size:1.6rem;font-weight:800;color:var(--accent);margin-bottom:16px}
.moto-card-price small{font-size:.8rem;color:var(--text-muted);font-weight:400}
.moto-card .btn{width:100%;justify-content:center}
.no-results{text-align:center;padding:60px 20px;color:var(--text-muted)}
.no-results i{font-size:3rem;margin-bottom:16px;opacity:.3}

/* ===== GALLERY ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.gallery-item{position:relative;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;aspect-ratio:4/3;background:var(--bg-card)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease,filter .3s ease}
.gallery-item:hover img{transform:scale(1.1);filter:brightness(1.1)}
.gallery-item::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.6) 0%,transparent 50%);opacity:0;transition:var(--transition)}
.gallery-item:hover::after{opacity:1}
.gallery-item-caption{position:absolute;bottom:0;left:0;right:0;padding:16px;z-index:2;transform:translateY(20px);opacity:0;transition:var(--transition);font-weight:600;font-size:.9rem}
.gallery-item:hover .gallery-item-caption{transform:translateY(0);opacity:1}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:var(--transition)}
.lightbox.active{opacity:1;visibility:visible}
.lightbox-img{max-width:90vw;max-height:85vh;border-radius:var(--radius-sm);object-fit:contain}
.lightbox-close{position:absolute;top:20px;right:20px;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--transition)}
.lightbox-close:hover{background:rgba(255,255,255,.1)}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:none;color:#fff;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.lightbox-nav:hover{background:var(--accent)}
.lightbox-prev{left:20px}
.lightbox-next{right:20px}
.lightbox-caption{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:var(--text-muted);font-size:.9rem}

/* ===== REPUESTOS ===== */
.repuestos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.repuesto-card{
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius);
  padding: 32px 24px;
  transition: var(--transition);
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* hover más pro */
.repuesto-card:hover{
  transform: translateY(-10px);
  border-color: rgba(230,57,70,.4);
  box-shadow: 0 20px 60px rgba(230,57,70,.15);
}

/* línea decorativa arriba */
.repuesto-card::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:3px;
  background: linear-gradient(90deg,var(--accent),transparent);
}

/* icono más moderno */
.repuesto-icon{
  width:75px;
  height:75px;
  margin:0 auto 18px;
  background: linear-gradient(135deg,var(--accent),#ff4d6d);
  border-radius: 22px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.8rem;
  color:#fff;
  box-shadow: 0 10px 25px rgba(230,57,70,.25);
  transition: var(--transition);
}

.repuesto-card:hover .repuesto-icon{
  transform: scale(1.1) rotate(5deg);
}

/* título */
.repuesto-card h3{
  font-family: var(--font-display);
  font-size: 1.4rem;
  margin-bottom: 10px;
}

/* lista más limpia */
.repuesto-list li{
  padding: 7px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  font-size: .85rem;
}

.repuesto-list li:last-child{
  border-bottom:none;
}
.repuesto-card:hover{transform:translateY(-6px);border-color:rgba(230,57,70,.3);box-shadow:0 16px 48px rgba(230,57,70,.08)}
.repuesto-icon{width:70px;height:70px;margin:0 auto 20px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:#fff}
.repuesto-card h3{font-family:var(--font-display);font-size:1.3rem;font-weight:700;margin-bottom:8px}
.repuesto-card p{color:var(--text-muted);font-size:.9rem;margin-bottom:16px}
.repuesto-list{text-align:left;margin-bottom:20px;padding:0 8px}
.repuesto-list li{padding:6px 0;border-bottom:1px solid var(--border);font-size:.85rem;color:var(--text-light)}
.repuesto-list li:last-child{border-bottom:none}
.repuesto-list li::before{content:'✓ ';color:var(--accent);font-weight:700}

/* ===== TALLER ===== */
.taller-section{background:linear-gradient(180deg,var(--bg-dark) 0%,#0d0d14 100%)}
.taller-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.taller-card{
  position: relative;
  background: linear-gradient(145deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius);
  padding: 34px 26px;
  overflow: hidden;
  transition: all .4s ease;
  transform: translateY(0);
}

/* brillo diagonal elegante */
.taller-card::before{
  content: "";
  position: absolute;
  top: -50%;
  left: -60%;
  width: 60%;
  height: 200%;
  background: linear-gradient(
    120deg,
    transparent,
    rgba(230,57,70,0.15),
    transparent
  );
  transform: rotate(25deg);
  transition: all .6s ease;
}

/* hover premium */
.taller-card:hover{
  transform: translateY(-12px);
  border-color: rgba(230,57,70,0.35);
  box-shadow: 0 25px 80px rgba(230,57,70,0.18);
}

/* efecto luz al pasar */
.taller-card:hover::before{
  left: 120%;
}
.taller-card:hover{transform:translateY(-6px);border-color:rgba(230,57,70,.3)}
.taller-card-icon{
  width: 60px;
  height: 60px;
  background: radial-gradient(circle at 30% 30%, #ff4d6d, var(--accent-dark));
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: #fff;
  margin-bottom: 16px;
  box-shadow: 0 10px 30px rgba(230,57,70,0.25);
  transition: .4s ease;
}

.taller-card:hover .taller-card-icon{
  transform: rotate(8deg) scale(1.1);
  box-shadow: 0 15px 40px rgba(230,57,70,0.35);
}
.taller-card-number{position:absolute;top:16px;right:20px;font-family:var(--font-display);font-size:3rem;font-weight:900;color:rgba(255,255,255,.03)}
.taller-card h3{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:8px}
.taller-card p{color:var(--text-muted);font-size:.9rem;margin-bottom:16px}
.taller-features{margin-bottom:20px}
.taller-features li{padding:4px 0;font-size:.85rem;color:var(--text-light);display:flex;align-items:center;gap:8px}
.taller-features li i{color:var(--accent);font-size:.7rem}

/* ===== CONTACTO ===== */
.contacto-section{background:linear-gradient(180deg,#0d0d14 0%,var(--bg-dark) 100%)}
.contacto-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contacto-form{display:flex;flex-direction:column;gap:20px}
.form-group label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:6px;font-weight:500}
.form-group input,.form-group textarea{width:100%;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:#fff;font-size:.95rem;font-family:var(--font);transition:var(--transition);resize:vertical}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.contacto-info{display:flex;flex-direction:column;gap:16px}
.info-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:var(--transition)}
.info-card:hover{border-color:rgba(230,57,70,.2)}
.info-icon{width:48px;height:48px;background:rgba(230,57,70,.1);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1.1rem;flex-shrink:0}
.info-card h4{font-size:.9rem;font-weight:600;margin-bottom:2px}
.info-card p{font-size:.85rem;color:var(--text-muted)}

/* ===== FOOTER ===== */
.footer{background:#06060a;padding:60px 0 0;border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px}
.footer-brand p{color:var(--text-muted);font-size:.9rem;margin-top:12px;line-height:1.7}
.footer-social{display:flex;gap:12px;margin-top:16px}
.footer-social a{width:40px;height:40px;background:rgba(255,255,255,.05);border-radius:10px;display:flex;align-items:center;justify-content:center;transition:var(--transition);color:var(--text-muted)}
.footer-social a:hover{background:var(--accent);color:#fff}
.footer-links h4{font-size:.9rem;font-weight:600;margin-bottom:16px;color:var(--text-light)}
.footer-links li{margin-bottom:8px}
.footer-links a,.footer-links li{font-size:.85rem;color:var(--text-muted);transition:var(--transition);display:flex;align-items:center;gap:6px}
.footer-links a:hover{color:var(--accent)}
.footer-bottom{text-align:center;padding:20px 0;border-top:1px solid var(--border);font-size:.8rem;color:var(--text-muted)}

/* ===== WHATSAPP FLOAT ===== */
.whatsapp-float{position:fixed;bottom:24px;right:24px;z-index:999;width:60px;height:60px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:#fff;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:var(--transition);animation:waPulse 2s infinite}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 8px 30px rgba(37,211,102,.5)}
.whatsapp-tooltip{position:absolute;right:72px;background:#25d366;color:#fff;padding:8px 16px;border-radius:8px;font-size:.8rem;white-space:nowrap;opacity:0;transform:translateX(10px);transition:var(--transition);pointer-events:none}
.whatsapp-float:hover .whatsapp-tooltip{opacity:1;transform:translateX(0)}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 30px rgba(37,211,102,.6),0 0 0 12px rgba(37,211,102,.1)}}

/* ===== BACK TO TOP ===== */
.back-to-top{position:fixed;bottom:24px;left:24px;z-index:999;width:44px;height:44px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;color:var(--text-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(20px);transition:var(--transition)}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ===== PAGE HEADER (subpages) ===== */
.page-header{padding:120px 0 60px;background:linear-gradient(180deg,#0d0d18 0%,var(--bg-dark) 100%);text-align:center;border-bottom:1px solid var(--border)}
.page-header-content{max-width:700px;margin:0 auto}
.page-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.2rem);font-weight:900;margin-bottom:12px}
.page-desc{color:var(--text-muted);font-size:1rem}

/* ===== SERVICES PREVIEW (home) ===== */
.services-preview{
  position: relative;
  padding: 80px 0;
  overflow: hidden;
}

.services-preview::before{
  content:"";
  position:absolute;
  inset:0;

  background: url("img/tiendaq.webp") center/cover no-repeat;

  filter: brightness(0.5) saturate(1.2);

  z-index:0;
}
.services-preview::after{
  content:"";
  position:absolute;
  inset:0;

  background: linear-gradient(
    180deg,
    rgba(10,10,15,0.7) 0%,
    rgba(10,10,15,0.5) 50%,
    rgba(10,10,15,0.9) 100%
  );

  z-index:1;
}

.services-preview .container{
  position: relative;
  z-index: 2;
  
}
.preview-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:24px;
  width:100%;
}
.preview-card{
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(12px);

  border:1px solid rgba(255,255,255,0.15);
  border-radius:var(--radius);

  padding:32px 24px;
  text-align:center;

  transition:var(--transition);
}
.preview-card:hover{transform:translateY(-6px);border-color:rgba(230,57,70,.3);box-shadow:0 12px 40px rgba(230,57,70,.08)}
.preview-icon{width:64px;height:64px;margin:0 auto 16px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:#fff;transition:var(--transition)}
.preview-card:hover .preview-icon{transform:scale(1.1)}
.preview-card h3{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin-bottom:8px}
.preview-card p{color:var(--text-muted);font-size:.88rem;margin-bottom:16px;line-height:1.6}
.preview-link{color:var(--accent);font-size:.85rem;font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:var(--transition)}
.preview-card:hover .preview-link{gap:10px}

/* ===== CTA BANNER ===== */
.cta-banner{padding:80px 0;background:linear-gradient(135deg,#14141f 0%,#1a0a0e 50%,#14141f 100%);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cta-content{text-align:center;max-width:600px;margin:0 auto}
.cta-content h2{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;margin-bottom:12px}
.cta-content p{color:var(--text-muted);margin-bottom:28px;font-size:1rem}

/* ===== SECTION CTA ===== */
.section-cta{text-align:center;margin-top:40px}

/* ===== WHY US (taller) ===== */
.why-us-section{
  position: relative;
  overflow: hidden;
  padding: 80px 0;
}

/* ===== FONDO ===== */
.why-us-section::before{
  content: "";
  position: absolute;
  inset: 0;

  background: url("img/garantiataller.webp") center/cover no-repeat;

  filter: brightness(0.45) contrast(1.1) saturate(1.2);
  transform: scale(1.08);

  z-index: 0;
}

/* ===== OVERLAY OSCURO ===== */
.why-us-section::after{
  content: "";
  position: absolute;
  inset: 0;

  background: radial-gradient(
    circle at center,
    rgba(230,57,70,0.15) 0%,
    rgba(10,10,15,0.75) 60%,
    rgba(10,10,15,0.92) 100%
  );

  z-index: 1;
}

/* ===== CONTENIDO ===== */
.why-us-section .container{
  position: relative;
  z-index: 2;
}

/* ===== GRID ===== */
.why-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 24px;
}

/* ===== CARD ===== */
.why-card{
  position: relative;
  background: rgba(255,255,255,0.05);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius);
  padding: 32px 24px;
  text-align: center;
  transition: all .4s ease;
  overflow: hidden;
}

/* brillo animado */
.why-card::before{
  content:"";
  position:absolute;
  top:-50%;
  left:-60%;
  width:60%;
  height:200%;
  background: linear-gradient(120deg, transparent, rgba(230,57,70,.25), transparent);
  transform: rotate(25deg);
  transition: .6s ease;
}

.why-card:hover{
  transform: translateY(-10px);
  border-color: rgba(230,57,70,.4);
  box-shadow: 0 25px 70px rgba(230,57,70,.15);
}

.why-card:hover::before{
  left:120%;
}

/* ===== ICONO ===== */
.why-icon{
  width: 64px;
  height: 64px;
  margin: 0 auto 16px;
  background: linear-gradient(135deg, var(--accent), #ff4d6d);
  border-radius: 18px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.5rem;
  color:#fff;
  box-shadow: 0 10px 25px rgba(230,57,70,.25);
  transition:.3s ease;
}

.why-card:hover .why-icon{
  transform: scale(1.1) rotate(5deg);
}

/* ===== TEXTO ===== */
.why-card h4{
  font-family: var(--font-display);
  font-size: 1.1rem;
  margin-bottom: 8px;
  color: #fff;
}

.why-card p{
  color: var(--text-muted);
  font-size: .9rem;
  line-height: 1.5;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px){
  .why-card{
    padding: 24px 18px;
  }

  .why-icon{
    width: 58px;
    height: 58px;
  }
}
.why-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}
.why-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;text-align:center;transition:var(--transition)}
.why-card:hover{transform:translateY(-4px);border-color:rgba(230,57,70,.2)}
.why-icon{width:56px;height:56px;margin:0 auto 14px;background:rgba(230,57,70,.1);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--accent)}
.why-card h4{font-family:var(--font-display);font-size:1rem;font-weight:700;margin-bottom:6px}
.why-card p{color:var(--text-muted);font-size:.85rem}

/* ===== FEATURED SECTION ===== */
.featured-section{background:linear-gradient(180deg,#0d0d14 0%,var(--bg-dark) 100%)}

/* ===== SCROLL REVEAL ===== */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ===== RESPONSIVE ===== */
/* =========================
   RESPONSIVE PRO
========================= */

@media (max-width: 1024px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 768px) {
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 25px;
    text-align: left;
  }

  .footer {
    padding: 40px 0 0;
  }
}
@media (max-width: 768px) {
  .nav-menu {
    position: fixed;
    top: 70px;
    left: -100%;
    width: 100%;
    height: calc(100vh - 70px);
    background: #0a0a0f;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding-top: 40px;
    transition: 0.3s;
    z-index: 999;
  }

  .nav-menu.active {
    left: 0;
  }

  .nav-toggle {
    display: flex;
  }
}
@media (max-width: 480px) {

  .hero-title {
    font-size: clamp(26px, 6vw, 32px);
  }

  .hero-actions {
    flex-direction: column;
  }

  .btn {
    width: 100%;
    text-align: center;
  }
}



.products-grid,
.benefits-grid,
.repuestos-grid,
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 20px;
}





/* ===== FIX MENU MOBILE ===== */

.hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  z-index:1001;
}

.hamburger span{
  width:25px;
  height:3px;
  background:#fff;
  border-radius:2px;
}

/* ===== MOBILE MENU ===== */
.nav-menu {
  display: flex;
  gap: 20px;
}

/* Mostrar en móvil */
/* MOBILE */

  .nav-menu.active {
    left: 0; /* 🔥 ESTE ES EL QUE HACE QUE APAREZCA */
  }

  .nav-toggle {
    display: flex;
    flex-direction: column;
    cursor: pointer;
  }



.nav-menu{
  z-index:1000;
}



/* FIX FINAL NAV */
.nav-toggle{
  display: none !important;
}

@media (max-width: 768px){
  .nav-toggle{
    display: flex !important;
  }
}


#motosGrid {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(3, 1fr);
}

/* Tablet */
@media (max-width: 992px) {
  #motosGrid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile */
@media (max-width: 600px) {
  #motosGrid {
    grid-template-columns: 1fr;
  }
}

/*  efecto de logo */
.page-header{
  position: relative;
  padding: 100px 0;
  background-color: #0f172a;
  overflow: hidden;
}


/*  KEYFRAMES */


/*  ASEGURA QUE EL TEXTO ESTÉ ENCIMA */
.page-header-content{
  position: relative;
  z-index: 2;
}



@media (max-width: 768px){

  .services-preview{
    padding: 60px 0;
  }

  .services-preview::before{
    background-position: center;
    background-size: cover;
  }

}

.dev-link{
  color: var(--accent);
  font-weight: 600;
  transition: 0.3s;
}

.dev-link:hover{
  color: #fff;
  text-decoration: underline;
}


.footer-logo-img{
  height: 38px;
  width: auto;
  object-fit: contain;
}

/* móvil */
@media (max-width: 480px){
  .footer-logo-img{
    height: 32px;
  }
}

.page-header{
  position: relative;
  overflow: hidden;
}



.page-header-content{
  position: relative;
  z-index: 2;
}

.navbar{
  z-index: 9999;
}







.page-header{
  position: relative;
  padding: 120px 0;
  background: #0f172a;
  overflow: hidden;
}

/* fondo tipo concesionaria */
.page-header::before{
  content: "";
  position: absolute;
  inset: 0;
  background: url("img/logo/logfar.png") center/cover no-repeat;
  opacity: 0.12;
  filter: blur(1px) brightness(1);
  transform: scale(1.1);
  z-index: 0;
}

/* capa oscura profesional */
.page-header::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(10,10,15,0.6),
    rgba(10,10,15,0.75)
  );
  z-index: 1;
}






/* animacion moto */

.moto-bg{
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

/* capa de motos */
.moto-bg::before{
  content: "🏍️ 🏍️ 🏍️ 🏍️ 🏍️ 🏍️ 🏍️";
  position: absolute;
  top: 50%;
  width: 200%;
  font-size: 22px;
  opacity: 0.05;
  white-space: nowrap;
  animation: moveMotos 25s linear infinite;
  transform: translateY(-50%);
}

@keyframes moveMotos{
  0%{
    transform: translateX(-50%) translateY(-50%);
  }
  100%{
    transform: translateX(50%) translateY(-50%);
  }
}





.repuestos-section {
  position: relative;
  overflow: hidden;
}

/* IMAGEN DE FONDO */
.repuestos-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("img/repuestosfar.webp") center center / cover no-repeat;
  transform: scale(1.05);
  z-index: 0;
}

/* CAPA OSCURA PARA LEGIBILIDAD */
.repuestos-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(10,10,15,0.85);
  z-index: 1;
}

/* CONTENIDO ENCIMA DEL FONDO */
.repuestos-section .container {
  position: relative;
  z-index: 2;
}




/* taller */



.taller-section{
  position: relative;
  overflow: hidden;
  background: #0a0a0f; /* fallback por si no carga la imagen */
}

/* IMAGEN DE FONDO RESPONSIVE PRO */
.taller-section::before{
  content: "";
  position: absolute;
  inset: 0;

  background-image: url("img/tallerfar.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  /* mejora visual */
  filter: brightness(0.45) contrast(1.1) saturate(1.2);

  transform: scale(1.08);
  z-index: 0;
}

/* CAPA OSCURA PARA LEGIBILIDAD */
.taller-section::after{
  content: "";
  position: absolute;
  inset: 0;

  background: radial-gradient(
    circle at center,
    rgba(10,10,15,0.4) 0%,
    rgba(10,10,15,0.75) 70%,
    rgba(10,10,15,0.9) 100%
  );

  z-index: 1;
}

/* contenido encima */
.taller-section .container{
  position: relative;
  z-index: 2;
}

/* ===== RESPONSIVE OPTIMIZADO ===== */

/* pantallas grandes */
@media (min-width: 1600px){
  .taller-section::before{
    background-position: center 30%;
  }
}

/* laptop */
@media (max-width: 1200px){
  .taller-section::before{
    background-position: center;
    transform: scale(1.1);
  }
}

/* tablet */
@media (max-width: 768px){
  .taller-section::before{
    background-position: center top;
    transform: scale(1.2);
  }
}

/* móvil pequeño */
@media (max-width: 480px){
  .taller-section::before{
    background-position: center top;
    transform: scale(1.35);
  }
}

@media (max-width: 768px){
  .taller-section::before{
    background-position: center top;
    transform: scale(1.3);
    background-attachment: scroll; /* IMPORTANTE en móviles */
  }
}








/* ===== CONTACTO PRO ===== */

.contacto-section{
  position: relative;
  overflow: hidden;
}

/* fondo estilo premium como taller */
.contacto-section::before{
  content:"";
  position:absolute;
  inset:0;
  background: url("img/ciudadsaningancio.jpg") center/cover no-repeat;
  filter: brightness(0.35) contrast(1.1);
  transform: scale(1.05);
  z-index:0;
}

.contacto-section::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(
    circle at center,
    rgba(10,10,15,0.6),
    rgba(10,10,15,0.95)
  );
  z-index:1;
}

.contacto-section .container{
  position: relative;
  z-index:2;
}

/* GRID */
.contacto-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:40px;
  align-items:start;
}

/* FORM */
.contacto-form-wrapper{
  background: rgba(255,255,255,0.04);
  border:1px solid var(--border);
  backdrop-filter: blur(12px);
  padding:30px;
  border-radius: var(--radius);
}

/* MAPA */
.map-container{
  margin-top:20px;
  border-radius: var(--radius);
  overflow:hidden;
  border:1px solid var(--border);
  height:220px;
}

.map-container iframe{
  width:100%;
  height:100%;
  border:0;
}

/* INPUTS */
.contacto-form input,
.contacto-form textarea{
  width:100%;
  padding:14px;
  background: var(--bg-card);
  border:1px solid var(--border);
  border-radius:10px;
  color:#fff;
}

/* INFO CARDS */
.info-card{
  background: rgba(255,255,255,0.04);
  border:1px solid var(--border);
  backdrop-filter: blur(10px);
}

/* RESPONSIVE */
@media (max-width: 900px){
  .contacto-grid{
    grid-template-columns:1fr;
  }

  .map-container{
    height:200px;
  }
}




.map-container iframe{
  width: 100%;
  border-radius: 12px;
  box-shadow: var(--shadow);
}