/* ============================================================
   Yamaha Oriente Guarne — base.css v3
   Fuentes: Oswald + DM Sans
   Estética: Rounded modern · Negro + Rojo · Espaciado generoso
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@300;400;500;600;700&family=DM+Sans:ital,wght@0,300;0,400;0,500;1,300&display=swap');

:root {
  --red:       #E60012;
  --red-dark:  #B5000E;
  --black:     #060810;
  --gray-900:  #0F1117;
  --gray-800:  #1A1F2E;
  --gray-600:  #374151;
  --gray-400:  #6B7280;
  --gray-300:  #9CA3AF;
  --gray-200:  #D1D5DB;
  --gray-100:  #F3F4F6;
  --gray-50:   #F8F9FB;
  --white:     #FFFFFF;
  --border:    #E8EAED;
  --shadow-sm: 0 2px 8px rgba(6,8,16,.06);
  --shadow-md: 0 8px 32px rgba(6,8,16,.10);
  --shadow-lg: 0 20px 60px rgba(6,8,16,.14);
  --r-sm:  10px;
  --r-md:  16px;
  --r-lg:  24px;
  --r-xl:  32px;
  --nav-h: 72px;
  --font-display: 'Oswald', system-ui, sans-serif;
  --font-body:    'DM Sans', system-ui, sans-serif;
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-body); background:var(--white); color:var(--black); -webkit-font-smoothing:antialiased; overflow-x:hidden; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
.container { max-width:1240px; margin:0 auto; padding:0 40px; }

/* ── NAVBAR ─────────────────────────────────────────────────── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:500;
  height:var(--nav-h); background:transparent;
  transition:background .4s, backdrop-filter .4s;
}
nav.scrolled {
  background:rgba(6,8,16,.88);
  backdrop-filter:blur(20px);
  box-shadow:0 1px 0 rgba(255,255,255,.06);
}
.nav-inner {
  max-width:1240px; margin:0 auto; padding:0 40px;
  height:100%; display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.logo { display:flex; align-items:center; gap:12px; }
.logo-mark {
  width:36px; height:36px; background:var(--red);
  border-radius:8px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  transition:transform .2s, box-shadow .2s;
}
.logo:hover .logo-mark { transform:scale(1.06); box-shadow:0 4px 16px rgba(230,0,18,.4); }
.logo-mark svg { width:14px; height:14px; }
.logo-text { display:flex; flex-direction:column; line-height:1.2; }
.logo-name { font-family:var(--font-display); font-size:15px; font-weight:600; color:#fff; letter-spacing:1px; text-transform:uppercase; }
.logo-dealer { font-size:9px; font-weight:300; color:rgba(255,255,255,.45); letter-spacing:.8px; text-transform:uppercase; }
.nav-links { display:flex; gap:2px; }
.nav-links a {
  font-family:var(--font-display); font-size:12px; font-weight:400;
  color:rgba(255,255,255,.7); letter-spacing:1.5px; text-transform:uppercase;
  padding:8px 14px; border-radius:var(--r-sm); transition:all .2s;
}
.nav-links a:hover { color:#fff; background:rgba(255,255,255,.08); }
.nav-links a.active { color:#fff; background:rgba(255,255,255,.1); }
.nav-right { display:flex; align-items:center; gap:10px; }
.btn-wa-nav {
  display:flex; align-items:center; gap:6px;
  font-family:var(--font-display); font-size:11px; font-weight:500; letter-spacing:1px; text-transform:uppercase;
  color:rgba(255,255,255,.7); padding:8px 16px;
  border:1px solid rgba(255,255,255,.18); border-radius:var(--r-sm);
  transition:all .2s;
}
.btn-wa-nav:hover { border-color:rgba(255,255,255,.5); color:#fff; }
.btn-cta-nav {
  font-family:var(--font-display); font-size:11px; font-weight:600; letter-spacing:1px; text-transform:uppercase;
  background:var(--red); color:#fff; padding:10px 20px;
  border-radius:var(--r-sm); transition:all .2s;
}
.btn-cta-nav:hover { background:var(--red-dark); transform:translateY(-1px); box-shadow:0 4px 16px rgba(230,0,18,.35); }
.hamburger { display:none; flex-direction:column; gap:5px; padding:6px; }
.hamburger span { display:block; width:22px; height:1.5px; background:#fff; transition:all .25s; }
.hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }
.mobile-menu {
  display:none; position:fixed; top:var(--nav-h); left:0; right:0;
  background:rgba(6,8,16,.97); backdrop-filter:blur(24px);
  z-index:499; padding:16px 24px 40px; flex-direction:column;
  border-top:1px solid rgba(255,255,255,.06);
}
.mobile-menu.open { display:flex; }
.mobile-menu a {
  font-family:var(--font-display); font-size:17px; font-weight:400;
  color:rgba(255,255,255,.65); letter-spacing:2px; text-transform:uppercase;
  padding:16px 0; border-bottom:1px solid rgba(255,255,255,.05); transition:color .15s;
}
.mobile-menu a:hover { color:#fff; }
.mobile-menu-btns { display:flex; gap:10px; margin-top:24px; }
.mobile-menu-btns .btn-cta-nav { flex:1; text-align:center; padding:15px; border-radius:var(--r-sm); }

/* ── BOTONES ─────────────────────────────────────────────────── */
.btn-primary {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--font-display); font-size:12px; font-weight:600; letter-spacing:2px; text-transform:uppercase;
  background:var(--red); color:#fff; padding:15px 36px;
  border-radius:var(--r-sm); transition:all .2s;
}
.btn-primary:hover { background:var(--red-dark); transform:translateY(-2px); box-shadow:0 8px 24px rgba(230,0,18,.35); }
.btn-outline-white {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--font-display); font-size:12px; font-weight:400; letter-spacing:2px; text-transform:uppercase;
  border:1px solid rgba(255,255,255,.45); color:#fff; padding:14px 36px;
  border-radius:var(--r-sm); transition:all .2s; backdrop-filter:blur(8px);
}
.btn-outline-white:hover { border-color:#fff; background:rgba(255,255,255,.1); transform:translateY(-1px); }
.btn-outline {
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:11px; font-weight:500; letter-spacing:1.5px; text-transform:uppercase;
  border:1px solid var(--border); color:var(--gray-400); padding:11px 22px;
  border-radius:var(--r-sm); transition:all .2s;
}
.btn-outline:hover { border-color:var(--black); color:var(--black); }
.btn-ghost {
  font-family:var(--font-display); font-size:11px; font-weight:500; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--gray-400); transition:color .15s;
  display:inline-flex; align-items:center; gap:8px;
}
.btn-ghost:hover { color:var(--black); }
.btn-ghost::after { content:'→'; transition:transform .2s; }
.btn-ghost:hover::after { transform:translateX(4px); }

/* ── HERO ────────────────────────────────────────────────────── */
.hero {
  position:relative; height:100vh; min-height:620px;
  display:flex; align-items:center; justify-content:center; text-align:center;
  overflow:hidden; background:var(--gray-900);
}
.hero-bg { position:absolute; inset:0; z-index:0; }
.hero-bg video, .hero-bg img { width:100%; height:100%; object-fit:cover; object-position:center; }
.hero-bg-placeholder {
  position:absolute; inset:0;
  background:linear-gradient(135deg, #0F1117 0%, #001A4D 55%, #0F1117 100%);
}
.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(to bottom, rgba(6,8,16,.2) 0%, rgba(6,8,16,.55) 40%, rgba(6,8,16,.82) 100%);
}
.hero-line { position:absolute; top:0; left:0; right:0; z-index:2; height:3px; background:var(--red); }
.hero-content { position:relative; z-index:3; max-width:820px; padding:0 24px; }
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--font-display); font-size:11px; font-weight:400; letter-spacing:4px; text-transform:uppercase;
  color:var(--red); margin-bottom:24px;
}
.hero-eyebrow::before, .hero-eyebrow::after { content:''; width:24px; height:1px; background:var(--red); }
.hero-h1 {
  font-family:var(--font-display); font-size:clamp(54px,9vw,112px); font-weight:700;
  color:#fff; line-height:.9; letter-spacing:-1px; text-transform:uppercase; margin-bottom:24px;
}
.hero-h1 em { font-style:normal; color:var(--red); display:block; }
.hero-sub {
  font-size:15px; font-weight:300; color:rgba(255,255,255,.62);
  line-height:1.85; margin-bottom:44px; max-width:500px; margin-left:auto; margin-right:auto;
}
.hero-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.hero-scroll {
  position:absolute; bottom:108px; left:50%; transform:translateX(-50%);
  z-index:3; display:flex; flex-direction:column; align-items:center; gap:8px;
  font-family:var(--font-display); font-size:9px; letter-spacing:3px; text-transform:uppercase;
  color:rgba(255,255,255,.3); animation:scrollBounce 2.5s infinite;
}
.hero-scroll-line { width:1px; height:32px; background:linear-gradient(to bottom,rgba(255,255,255,.3),transparent); }
@keyframes scrollBounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(7px)} }
.hero-stats {
  position:absolute; bottom:0; left:0; right:0; z-index:3;
  display:grid; grid-template-columns:repeat(4,1fr);
  background:rgba(6,8,16,.7); backdrop-filter:blur(16px);
  border-top:1px solid rgba(255,255,255,.07);
}
.hero-stat { padding:20px 12px; text-align:center; border-right:1px solid rgba(255,255,255,.06); }
.hero-stat:last-child { border-right:none; }
.hero-stat-val { font-family:var(--font-display); font-size:28px; font-weight:600; color:#fff; letter-spacing:-1px; line-height:1; }
.hero-stat-val span { color:var(--red); font-size:20px; }
.hero-stat-label { font-size:9px; font-weight:300; color:rgba(255,255,255,.38); margin-top:4px; letter-spacing:1px; text-transform:uppercase; }

/* ── SECCIONES ───────────────────────────────────────────────── */
.section { padding:96px 0; }
.section-alt { background:var(--gray-50); }
.section-dark { background:var(--black); }
.section-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:52px; gap:24px; }
.section-eyebrow { font-family:var(--font-display); font-size:10px; font-weight:500; letter-spacing:4px; text-transform:uppercase; color:var(--red); margin-bottom:10px; display:block; }
.section-title { font-family:var(--font-display); font-size:clamp(28px,3.5vw,44px); font-weight:600; color:var(--black); letter-spacing:-.5px; line-height:1.05; text-transform:uppercase; }
.section-title em { color:var(--red); font-style:normal; }
.section-dark .section-eyebrow { color:rgba(255,255,255,.4); }
.section-dark .section-title { color:#fff; }

/* ── CATEGORÍAS ──────────────────────────────────────────────── */
.cats-grid {
  display:grid; grid-template-columns:repeat(6,1fr); gap:16px;
}
.cat-item {
  padding:28px 12px 24px; text-align:center;
  border-radius:var(--r-md); border:1px solid var(--border);
  background:var(--white); cursor:pointer;
  transition:all .25s; text-decoration:none; display:block;
  box-shadow:var(--shadow-sm);
}
.cat-item:hover {
  background:var(--black); border-color:var(--black);
  transform:translateY(-4px); box-shadow:var(--shadow-lg);
}
.cat-item:hover .cat-item-icon { transform:scale(1.2) rotate(-5deg); }
.cat-item:hover .cat-item-name { color:#fff; }
.cat-item:hover .cat-item-count { color:rgba(255,255,255,.4); }
.cat-item-icon { font-size:28px; margin-bottom:10px; display:block; transition:transform .25s; }
.cat-item-name { font-family:var(--font-display); font-size:11px; font-weight:500; color:var(--black); letter-spacing:1.5px; text-transform:uppercase; transition:color .2s; }
.cat-item-count { font-size:10px; font-weight:300; color:var(--gray-300); margin-top:4px; transition:color .2s; }

/* ── MOTOS GRID ──────────────────────────────────────────────── */
.motos-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.moto-card {
  background:var(--white); display:block; text-decoration:none;
  border-radius:var(--r-md); border:1px solid var(--border);
  overflow:hidden; transition:all .25s; box-shadow:var(--shadow-sm);
}
.moto-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:transparent; }
.mc-img { height:220px; background:white; position:relative; overflow:hidden; }
.mc-img img { width:100%; height:100%; object-fit:contain; transition:transform .5s ease; }
.moto-card:hover .mc-img img { transform:scale(1.07); }
.mc-img-placeholder { display:flex; align-items:center; justify-content:center; height:100%; font-size:64px; opacity:.15; }
.mc-badge { position:absolute; top:12px; left:12px; font-family:var(--font-display); font-size:9px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; padding:5px 12px; border-radius:20px; z-index:2; }
.mc-badge.red  { background:var(--red); color:#fff; }
.mc-badge.dark { background:var(--black); color:#fff; }
.mc-body { padding:20px 22px; }
.mc-series { font-family:var(--font-display); font-size:9px; font-weight:500; color:var(--gray-300); letter-spacing:2.5px; text-transform:uppercase; margin-bottom:5px; }
.mc-name { font-family:var(--font-display); font-size:18px; font-weight:600; color:var(--black); letter-spacing:-.2px; text-transform:uppercase; margin-bottom:12px; }
.mc-price { font-family:var(--font-display); font-size:20px; font-weight:600; color:var(--black); letter-spacing:-1px; }
.mc-price-old { font-size:12px; font-weight:300; color:var(--gray-300); text-decoration:line-through; margin-left:8px; }
.mc-footer { display:flex; gap:8px; margin-top:16px; padding-top:16px; border-top:1px solid var(--border); }
.mc-btn {
  flex:1; font-family:var(--font-display); font-size:10px; font-weight:600; letter-spacing:1.2px; text-transform:uppercase;
  border:1px solid var(--border); color:var(--gray-400); padding:10px 6px;
  border-radius:var(--r-sm); transition:all .15s; text-align:center; display:block;
}
.mc-btn:hover { border-color:var(--black); color:var(--black); background:var(--gray-50); }
.mc-btn.primary { background:var(--black); border-color:var(--black); color:#fff; }
.mc-btn.primary:hover { background:var(--red); border-color:var(--red); }

/* Skeleton */
.skeleton { background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%); background-size:200% 100%; animation:shimmer 1.5s infinite; border-radius:4px; }
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
.skeleton-card { background:var(--white); border-radius:var(--r-md); border:1px solid var(--border); overflow:hidden; }
.skeleton-img { height:210px; border-radius:0; }
.skeleton-body { padding:20px 22px; }
.skeleton-line { height:11px; margin-bottom:10px; }
.skeleton-line.short { width:55%; }
.skeleton-line.tall  { height:16px; width:75%; }

/* ── STATS ───────────────────────────────────────────────────── */
.stats-strip { background:var(--black); padding:0; }
.stats-inner { display:grid; grid-template-columns:repeat(4,1fr); }
.stat-item {
  text-align:center; padding:52px 16px;
  border-right:1px solid rgba(255,255,255,.05);
  position:relative; transition:background .2s;
}
.stat-item:hover { background:rgba(255,255,255,.02); }
.stat-item:last-child { border-right:none; }
.stat-val { font-family:var(--font-display); font-size:clamp(44px,5vw,64px); font-weight:700; color:#fff; letter-spacing:-2px; line-height:1; }
.stat-unit { font-size:32px; color:var(--red); font-weight:400; }
.stat-label { font-family:var(--font-display); font-size:10px; font-weight:400; color:rgba(255,255,255,.3); margin-top:10px; letter-spacing:2.5px; text-transform:uppercase; }

/* ── SERVICIOS ───────────────────────────────────────────────── */
.svc-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.svc-item {
  padding:36px 28px; border-radius:var(--r-md);
  border:1px solid var(--border); background:var(--white);
  transition:all .25s; box-shadow:var(--shadow-sm);
  position:relative; overflow:hidden;
}
.svc-item::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:3px; background:var(--red);
  transform:scaleX(0); transform-origin:left; transition:transform .3s;
}
.svc-item:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:transparent; }
.svc-item:hover::after { transform:scaleX(1); }
.svc-num { font-family:var(--font-display); font-size:48px; font-weight:700; color:var(--gray-100); margin-bottom:20px; letter-spacing:-2px; line-height:1; }
.svc-title { font-family:var(--font-display); font-size:14px; font-weight:600; color:var(--black); margin-bottom:10px; text-transform:uppercase; letter-spacing:.8px; }
.svc-desc { font-size:13px; font-weight:300; color:var(--gray-400); line-height:1.9; }

/* ── REVIEWS ─────────────────────────────────────────────────── */
.reviews-track-wrap { overflow:hidden; cursor:grab; user-select:none; 
  max-width: 100%;
}
.reviews-track-wrap:active { cursor:grabbing; }
.reviews-track { display:flex; gap:20px; transition:transform .45s cubic-bezier(.4,0,.2,1); 
  width: max-content;
}
.review-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r-md); padding:32px 28px;
  flex-shrink:0; box-shadow:var(--shadow-sm);
  transition:transform .25s, box-shadow .25s;
  overflow: hidden;
  max-width: 100%;
  box-sizing: border-box;
  width: 300px;        /* o el ancho que quieras para cada card */
  min-width: 300px;
  max-width: 300px;
}

.review-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.review-stars { color:var(--red); font-size:13px; letter-spacing:2px; margin-bottom:16px; }
.review-text { font-size:14px; font-weight:300; color:var(--gray-400); line-height:1.9; margin-bottom:20px; font-style:italic; 
    overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3; /* número de líneas visibles */
  -webkit-box-orient: vertical;
  word-break: break-word;
  max-width: 100%;
}
.review-author { display:flex; align-items:center; gap:12px; padding-top:18px; border-top:1px solid var(--border); }
.review-avatar { width:38px; height:38px; background:var(--black); border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:15px; font-weight:600; color:#fff; flex-shrink:0; }
.review-name { font-family:var(--font-display); font-size:13px; font-weight:600; color:var(--black); text-transform:uppercase; letter-spacing:.5px; }
.review-moto { font-size:11px; color:var(--gray-300); margin-top:2px; }
.reviews-controls { display:flex; justify-content:space-between; align-items:center; margin-top:28px; }
.reviews-dots { display:flex; gap:6px; }
.reviews-dot { width:6px; height:6px; border-radius:3px; background:var(--border); transition:all .2s; cursor:pointer; }
.reviews-dot.active { background:var(--red); width:20px; }
.reviews-arrows { display:flex; gap:8px; }
.reviews-arrow { width:40px; height:40px; border:1px solid var(--border); border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; font-size:14px; color:var(--gray-400); transition:all .2s; cursor:pointer; }
.reviews-arrow:hover { border-color:var(--black); color:var(--black); background:var(--gray-50); }

/* ── FAQ ─────────────────────────────────────────────────────── */
.faq-list { display:flex; flex-direction:column; gap:10px; }
.faq-item { border-radius:var(--r-md); border:1px solid var(--border); overflow:hidden; box-shadow:var(--shadow-sm); }
.faq-trigger { width:100%; display:flex; justify-content:space-between; align-items:center; padding:22px 28px; cursor:pointer; transition:background .15s; background:var(--white); }
.faq-trigger:hover { background:var(--gray-50); }
.faq-trigger.open { background:var(--black); border-radius:0; }
.faq-trigger.open .faq-q { color:#fff; }
.faq-trigger.open .faq-icon { color:var(--red); transform:rotate(45deg); }
.faq-q { font-family:var(--font-display); font-size:14px; font-weight:500; color:var(--black); text-align:left; text-transform:uppercase; letter-spacing:.5px; transition:color .15s; }
.faq-icon { font-size:20px; color:var(--gray-300); transition:transform .3s, color .15s; flex-shrink:0; margin-left:20px; line-height:1; }
.faq-body { max-height:0; overflow:hidden; transition:max-height .35s cubic-bezier(.4,0,.2,1), padding .35s; padding:0 28px; background:var(--white); }
.faq-body.open { max-height:320px; padding:20px 28px 28px; }
.faq-body p { font-size:14px; font-weight:300; color:var(--gray-500); line-height:1.9; }

/* ── BANNER CTA ──────────────────────────────────────────────── */
.banner-cta {
  background:var(--red); padding:72px 0; position:relative; overflow:hidden;
  border-radius:0;
}
.banner-cta::before {
  content:'YAMAHA'; position:absolute; right:-20px; top:50%; transform:translateY(-50%);
  font-family:var(--font-display); font-size:180px; font-weight:700;
  color:rgba(0,0,0,.1); pointer-events:none; white-space:nowrap; line-height:1;
}
.banner-cta-inner { display:flex; align-items:center; justify-content:space-between; gap:32px; position:relative; z-index:1; }
.banner-cta-text h2 { font-family:var(--font-display); font-size:clamp(22px,3.5vw,40px); font-weight:600; color:#fff; text-transform:uppercase; line-height:1.1; letter-spacing:-.5px; }
.banner-cta-text p { font-size:14px; font-weight:300; color:rgba(255,255,255,.75); margin-top:8px; }
.btn-white { background:#fff; color:var(--red); font-family:var(--font-display); font-size:12px; font-weight:600; letter-spacing:2px; text-transform:uppercase; padding:16px 36px; white-space:nowrap; flex-shrink:0; border-radius:var(--r-sm); transition:all .2s; }
.btn-white:hover { background:var(--black); color:#fff; transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,.3); }

/* ── FOOTER ──────────────────────────────────────────────────── */
footer { background:var(--black); padding:80px 0 36px; border-top:3px solid var(--red); }
.footer-grid { display:grid; grid-template-columns:2.2fr 1fr 1fr 1fr; gap:60px; margin-bottom:64px; }
.footer-brand-name { font-family:var(--font-display); font-size:18px; font-weight:600; color:#fff; letter-spacing:1px; text-transform:uppercase; margin-bottom:3px; }
.footer-brand-tag { font-family:var(--font-display); font-size:9px; font-weight:400; color:var(--red); letter-spacing:3px; text-transform:uppercase; }
.footer-brand-desc { font-size:13px; font-weight:300; color:rgba(255,255,255,.28); line-height:1.9; margin-top:18px; }
.footer-social { display:flex; gap:8px; margin-top:22px; }
.fsoc { width:36px; height:36px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:10px; font-weight:500; color:rgba(255,255,255,.3); cursor:pointer; transition:all .2s; text-decoration:none; }
.fsoc:hover { border-color:var(--red); color:#fff; background:var(--red); }
.footer-col h4 { font-family:var(--font-display); font-size:9px; font-weight:500; color:rgba(255,255,255,.28); letter-spacing:3px; text-transform:uppercase; margin-bottom:20px; }
.footer-col a { display:block; font-size:13px; font-weight:300; color:rgba(255,255,255,.42); margin-bottom:12px; transition:color .15s; }
.footer-col a:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.06); padding-top:28px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
.footer-copy { font-size:12px; font-weight:300; color:rgba(255,255,255,.2); }
.footer-legal { display:flex; gap:20px; }
.footer-legal a { font-size:12px; font-weight:300; color:rgba(255,255,255,.2); transition:color .15s; }
.footer-legal a:hover { color:rgba(255,255,255,.5); }

/* ── WA FLOAT ────────────────────────────────────────────────── */
.wa-float { position:fixed; bottom:28px; right:28px; background:#25D366; color:#fff; width:54px; height:54px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:24px; z-index:999; box-shadow:0 6px 24px rgba(37,211,102,.4); transition:transform .2s, box-shadow .2s; text-decoration:none; }
.wa-float:hover { transform:scale(1.1); box-shadow:0 10px 32px rgba(37,211,102,.5); }

/* ── REVEAL ──────────────────────────────────────────────────── */
[data-reveal] { opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
[data-reveal].revealed { opacity:1; transform:none; }
[data-reveal][data-delay="1"] { transition-delay:.1s; }
[data-reveal][data-delay="2"] { transition-delay:.2s; }
[data-reveal][data-delay="3"] { transition-delay:.3s; }
[data-reveal][data-delay="4"] { transition-delay:.4s; }

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media (max-width:1100px) {
  .cats-grid  { grid-template-columns:repeat(3,1fr); }
  .motos-grid { grid-template-columns:repeat(2,1fr); }
  .svc-grid   { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:40px; }
}

@media (max-width:768px) {
  :root { --nav-h:60px; }
  .container { padding:0 20px; }
  .nav-links, .btn-wa-nav { display:none; }
  .hamburger { display:flex; }
  .section { padding:64px 0; }
  .section-header { flex-direction:column; align-items:flex-start; gap:14px; }
  .cats-grid  { grid-template-columns:repeat(3,1fr); gap:12px; }
  .motos-grid { grid-template-columns:repeat(2,1fr) !important; gap:14px; }
  .svc-grid   { grid-template-columns:1fr 1fr; gap:14px; }
  .hero-stats { grid-template-columns:repeat(2,1fr); }
  .hero-h1    { font-size:52px; }
  .stats-inner { grid-template-columns:repeat(2,1fr); }
  .banner-cta-inner { flex-direction:column; text-align:center; }
  .btn-white  { width:100%; justify-content:center; }
  .footer-grid { grid-template-columns:1fr; gap:36px; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }

  /* Reviews mobile: 1 card a la vez, ancho completo */
  .review-card { min-width:calc(100vw - 40px); }
}

@media (max-width:600px) {
  .cats-grid  { grid-template-columns:repeat(2,1fr); gap:10px; }
  .motos-grid { grid-template-columns:1fr; }
  .svc-grid   { grid-template-columns:1fr; }
  .hero-h1    { font-size:42px; }
  .hero-stats { display:none; }
  .hero-actions { flex-direction:column; align-items:center; }
  .btn-primary, .btn-outline-white { width:100%; justify-content:center; }

  /* Reviews 480px: 1 card full */
  .review-card { min-width:calc(100vw - 40px); }
}

@media (min-width:601px) and (max-width:1023px) {
  /* Reviews tablet: 2 cards visibles */
  .review-card { min-width:calc(50% - 10px); }
}

@media (min-width:1024px) {
  /* Reviews desktop: 3 cards */
  .review-card { min-width:calc(33.333% - 14px); }
}

/* ── Navbar sólida para páginas sin hero oscuro ──────────────── */
nav.nav-solid {
  background: var(--black) !important;
  border-bottom: 1px solid rgba(255,255,255,.06) !important;
}
nav.nav-solid .logo-name,
nav.nav-solid .nav-links a,
nav.nav-solid .btn-wa-nav { color: rgba(255,255,255,.85); }
nav.nav-solid .logo-dealer { color: rgba(255,255,255,.4); }
