/* ═══════════════════════════════════════════════
   XM SPORT — main.css
═══════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
    --black: #0a0a0a; --white: #f5f5f0; --red: #e8000d; --red-dark: #b5000a;
    --gray: #888; --gray2: #2a2a2a; --gray3: #1a1a1a;
    --nav-h: 68px; --ticker-h: 0px;
    --font-display: 'Bebas Neue', 'Barlow Condensed', sans-serif;
    --font-sub: 'Barlow Condensed', sans-serif;
    --font-body: 'Barlow', sans-serif;
}
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); background: var(--black); color: var(--white); overflow-x: hidden; -webkit-font-smoothing: antialiased; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }

/* ── NAV — logo como texto XM ────────────────── */
.nav { position:sticky; top:0; z-index:150; height:var(--nav-h); background:var(--black); border-bottom:1px solid rgba(255,255,255,.06); display:flex; align-items:center; padding:0 28px; transition:background .3s,box-shadow .3s; }
.nav.scrolled { background:rgba(10,10,10,.97); box-shadow:0 4px 32px rgba(0,0,0,.6); backdrop-filter:blur(16px); }
.nav-logo { display:flex; align-items:center; gap:11px; flex-shrink:0; margin-right:36px; }
.nav-logo-img { width:46px; height:46px; border-radius:50%; object-fit:cover; border:2px solid rgba(255,255,255,.12); transition:border-color .2s; background:#fff; }
.nav-logo:hover .nav-logo-img { border-color:rgba(255,255,255,.3); }
.nav-links { display:flex; align-items:center; gap:2px; flex:1; }
.nav-link { font-family:var(--font-display); font-weight:700; font-size:.85rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(245,245,240,.55); padding:8px 13px; border-radius:5px; transition:color .15s,background .15s; position:relative; white-space:nowrap; }
.nav-link:hover { color:var(--white); background:rgba(255,255,255,.05); }
.nav-link.active { color:var(--white); }
.nav-link.active::after { content:''; position:absolute; bottom:-1px; left:13px; right:13px; height:2px; background:var(--white); border-radius:2px 2px 0 0; }
.nav-dropdown { position:relative; }
.nav-dropdown-toggle { display:flex; align-items:center; gap:5px; cursor:pointer; }
.nav-dropdown-toggle .chevron { font-size:.6rem; transition:transform .2s; opacity:.5; }
.nav-dropdown:hover .chevron { transform:rotate(180deg); }
.nav-dropdown-menu { position:absolute; top:calc(100% + 12px); left:0; background:var(--gray3); border:1px solid rgba(255,255,255,.08); border-radius:10px; padding:8px; min-width:180px; opacity:0; pointer-events:none; transform:translateY(-6px); transition:opacity .18s,transform .18s; box-shadow:0 20px 60px rgba(0,0,0,.6); z-index:200; }
.nav-dropdown.open .nav-dropdown-menu { opacity:1; pointer-events:all; transform:translateY(0); }
.nav-dropdown.open .chevron { transform:rotate(180deg); }
.nav-dd-item { display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius:6px; font-family:var(--font-display); font-weight:700; font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; color:rgba(245,245,240,.6); transition:color .14s,background .14s; cursor:pointer; }
.nav-dd-item:hover { color:var(--white); background:rgba(255,255,255,.06); }
.nav-dd-item i { width:16px; text-align:center; font-size:.75rem; color:rgba(245,245,240,.4); }
.nav-search { display:flex; align-items:center; gap:12px; margin-left:auto; position:relative; }
.search-bar { display:flex; align-items:center; background:var(--gray3); border:1px solid rgba(255,255,255,.08); border-radius:8px; padding:0 14px; gap:10px; height:38px; width:220px; transition:border-color .2s,width .3s; overflow:hidden; }
.search-bar:focus-within { border-color:rgba(255,255,255,.25); width:280px; }
.search-bar i { color:var(--gray); font-size:.78rem; flex-shrink:0; }
.search-bar:focus-within i { color:var(--white); }
.search-bar input { background:none; border:none; outline:none; color:var(--white); font-family:var(--font-body); font-size:.84rem; width:100%; }
.search-bar input::placeholder { color:var(--gray); }
.search-results { position:absolute; top:calc(100% + 10px); right:0; width:340px; background:var(--gray3); border:1px solid rgba(255,255,255,.1); border-radius:12px; overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,.7); display:none; z-index:300; }
.search-results.show { display:block; }
.search-results-header { padding:10px 14px; font-family:var(--font-display); font-weight:700; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gray); border-bottom:1px solid rgba(255,255,255,.06); }
.search-result-item { display:flex; align-items:center; gap:12px; padding:11px 14px; border-bottom:1px solid rgba(255,255,255,.04); transition:background .14s; text-decoration:none; color:inherit; }
.search-result-item:last-child { border-bottom:none; }
.search-result-item:hover { background:rgba(255,255,255,.05); }
.search-result-thumb { width:42px; height:42px; border-radius:7px; object-fit:cover; background:var(--gray2); flex-shrink:0; }
.search-result-thumb-ph { width:42px; height:42px; border-radius:7px; background:var(--gray2); flex-shrink:0; display:flex; align-items:center; justify-content:center; color:var(--gray); font-size:.8rem; }
.search-result-name { font-family:var(--font-display); font-weight:700; font-size:.88rem; color:var(--white); text-transform:uppercase; line-height:1.2; }
.search-result-dep { font-size:.72rem; color:var(--gray); margin-top:2px; }
.search-result-price { margin-left:auto; font-family:var(--font-display); font-weight:700; font-size:.85rem; color:var(--red); flex-shrink:0; }
.search-empty { padding:24px 14px; text-align:center; color:var(--gray); font-size:.82rem; }
.search-empty i { display:block; font-size:1.5rem; margin-bottom:8px; opacity:.3; }
.btn-cotizar { display:inline-flex; align-items:center; gap:7px; padding:9px 18px; background:var(--red); color:#fff; font-family:var(--font-display); font-weight:800; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; border-radius:7px; border:none; cursor:pointer; transition:background .15s,transform .12s; white-space:nowrap; flex-shrink:0; text-decoration:none; }
.btn-cotizar:hover { background:var(--red-dark); }
.nav-ham { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:6px; border-radius:6px; transition:background .14s; margin-left:8px; flex-shrink:0; background:none; border:none; }
.nav-ham:hover { background:rgba(255,255,255,.07); }
.nav-ham span { display:block; width:22px; height:2px; background:var(--white); border-radius:2px; transition:transform .25s,opacity .25s; transform-origin:center; }
.nav-ham.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-ham.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav-ham.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.mobile-menu { position:fixed; top:calc(var(--nav-h) + var(--ticker-h)); left:0; right:0; background:var(--black); border-bottom:1px solid rgba(255,255,255,.08); padding:16px 20px 24px; z-index:140; transform:translateY(-110%); transition:transform .3s cubic-bezier(.4,0,.2,1); box-shadow:0 20px 40px rgba(0,0,0,.8); overflow-y:auto; max-height:calc(100vh - var(--nav-h) - var(--ticker-h)); }
.mobile-menu.open { transform:translateY(0); }
.mobile-link { display:flex; align-items:center; justify-content:space-between; padding:13px 4px; border-bottom:1px solid rgba(255,255,255,.05); font-family:var(--font-display); font-weight:800; font-size:1.15rem; letter-spacing:.08em; text-transform:uppercase; color:rgba(245,245,240,.7); transition:color .14s; cursor:pointer; }
.mobile-link:last-of-type { border-bottom:none; }
.mobile-link:hover { color:var(--white); }
.mobile-link i { font-size:.75rem; color:var(--gray); transition:transform .2s; }
.mobile-link.open i { transform:rotate(180deg); }
.mobile-sports { padding:4px 4px 4px 16px; display:none; flex-direction:column; gap:2px; border-bottom:1px solid rgba(255,255,255,.05); }
.mobile-sports.open { display:flex; }
.mobile-sport-item { display:flex; align-items:center; gap:10px; padding:9px 10px; border-radius:7px; font-family:var(--font-display); font-weight:700; font-size:.88rem; letter-spacing:.06em; text-transform:uppercase; color:rgba(245,245,240,.6); transition:color .14s,background .14s; text-decoration:none; }
.mobile-sport-item:hover { color:var(--white); background:rgba(255,255,255,.04); }
.mobile-sport-item i { color:rgba(245,245,240,.35); font-size:.78rem; width:14px; text-align:center; }
.mobile-cta { margin-top:18px; }
.mobile-cta .btn-cotizar { width:100%; justify-content:center; font-size:.9rem; padding:13px; }
.nav-overlay { position:fixed; inset:0; z-index:130; background:rgba(0,0,0,.75); backdrop-filter:blur(3px); display:none; }
.nav-overlay.show { display:block; }
.nav-search-mobile { display:none; flex:1; margin:0 10px; position:relative; }
.search-bar-mobile { display:flex; align-items:center; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1); border-radius:8px; padding:0 12px; gap:8px; height:36px; width:100%; transition:border-color .2s; }
.search-bar-mobile:focus-within { border-color:rgba(255,255,255,.25); }
.search-bar-mobile i { color:var(--gray); font-size:.75rem; flex-shrink:0; }
.search-bar-mobile input { background:none; border:none; outline:none; color:var(--white); font-family:var(--font-body); font-size:.83rem; width:100%; }
.search-bar-mobile input::placeholder { color:var(--gray); }
.search-results-mobile { position:fixed; top:calc(var(--nav-h) + var(--ticker-h) + 4px); left:12px; right:12px; width:auto; z-index:400; background:var(--gray3); border:1px solid rgba(255,255,255,.1); border-radius:12px; overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,.8); display:none; }
.search-results-mobile.show { display:block; }
.mobile-search, .mobile-results { display:none !important; }
@media (max-width:1024px) { .search-bar{width:180px} .search-bar:focus-within{width:220px} .nav-link{font-size:.8rem;padding:7px 10px} }
@media (max-width:860px) { .nav-links,.search-bar,.btn-cotizar{display:none} .nav-ham{display:flex} .nav{padding:0 16px} .nav-logo{margin-right:auto} .nav-search-mobile{display:flex} }
@media (max-width:480px) { .nav-logo-img{width:38px;height:38px} :root{--nav-h:58px} }

/* ── HERO ────────────────────────────────────── */
.hero { position:relative; width:100%; height:100vh; min-height:600px; overflow:hidden; background:var(--black); }
.hero-slides { position:absolute; inset:0; }
.hero-slide { position:absolute; inset:0; opacity:0; transition:opacity 1s ease; }
.hero-slide.active { opacity:1; }
.hero-slide-img { width:100%; height:100%; object-fit:cover; transform:scale(1.06); transition:transform 8s ease; }
.hero-slide.active .hero-slide-img { transform:scale(1); }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(to right,rgba(10,10,10,.82) 40%,rgba(10,10,10,.2) 100%),linear-gradient(to top,rgba(10,10,10,.7) 0%,transparent 60%); z-index:1; }
.hero-fallback { position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 20% 50%,rgba(40,40,40,.8) 0%,transparent 70%),#0a0a0a; overflow:hidden; }
.hero-fallback-grid { position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px); background-size:60px 60px; }
.hero-fallback-shape { position:absolute; border-radius:50%; filter:blur(80px); opacity:.12; pointer-events:none; }
.hero-content { position:absolute; inset:0; z-index:2; display:flex; flex-direction:column; justify-content:center; padding:0 6vw; max-width:900px; }
.hero-eyebrow { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-sub); font-weight:700; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:rgba(245,245,240,.5); margin-bottom:18px; opacity:0; transform:translateY(12px); transition:opacity .7s ease .2s,transform .7s ease .2s; }
.hero-eyebrow-line { width:28px; height:1px; background:rgba(245,245,240,.35); }
/* Bebas Neue: sin italic, sin weight — solo tamaño y tracking */
.hero-title { font-family:var(--font-display); font-size:clamp(4.5rem,10vw,8.5rem); line-height:.9; letter-spacing:.03em; text-transform:uppercase; color:var(--white); margin-bottom:22px; opacity:0; transform:translateY(16px); transition:opacity .8s ease .35s,transform .8s ease .35s; }
.hero-title em { font-style:normal; color:rgba(245,245,240,.22); }
.hero-subtitle { font-family:var(--font-body); font-size:clamp(.9rem,1.8vw,1.1rem); color:rgba(245,245,240,.6); line-height:1.65; max-width:440px; margin-bottom:34px; opacity:0; transform:translateY(12px); transition:opacity .7s ease .5s,transform .7s ease .5s; }
.hero-ctas { display:flex; align-items:center; gap:12px; flex-wrap:wrap; opacity:0; transform:translateY(10px); transition:opacity .7s ease .65s,transform .7s ease .65s; }
.hero-btn-primary { display:inline-flex; align-items:center; gap:9px; padding:13px 28px; background:var(--white); color:var(--black); font-family:var(--font-sub); font-weight:800; font-size:.88rem; letter-spacing:.12em; text-transform:uppercase; border-radius:4px; text-decoration:none; transition:background .18s,transform .14s; flex-shrink:0; }
.hero-btn-primary:hover { background:#e0e0da; transform:translateY(-2px); }
.hero-btn-secondary { display:inline-flex; align-items:center; gap:8px; padding:13px 22px; background:transparent; color:rgba(245,245,240,.8); font-family:var(--font-sub); font-weight:700; font-size:.88rem; letter-spacing:.12em; text-transform:uppercase; border-radius:4px; border:1px solid rgba(245,245,240,.2); text-decoration:none; transition:border-color .18s,color .18s,transform .14s; flex-shrink:0; }
.hero-btn-secondary:hover { border-color:rgba(245,245,240,.5); color:var(--white); transform:translateY(-2px); }
.hero-stats { position:absolute; bottom:48px; left:6vw; z-index:2; display:flex; align-items:center; gap:36px; opacity:0; transform:translateY(10px); transition:opacity .7s ease .8s,transform .7s ease .8s; }
.hero-stat-item { display:flex; flex-direction:column; gap:3px; }
.hero-stat-num { font-family:var(--font-display); font-size:2.2rem; color:var(--white); line-height:1; }
.hero-stat-lbl { font-family:var(--font-sub); font-size:.65rem; font-weight:700; color:rgba(245,245,240,.4); text-transform:uppercase; letter-spacing:.14em; }
.hero-stat-div { width:1px; height:36px; background:rgba(255,255,255,.12); }
.hero-controls { position:absolute; bottom:48px; right:6vw; z-index:2; display:flex; align-items:center; gap:8px; }
.hero-dot { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.3); cursor:pointer; transition:background .2s,transform .2s; border:none; padding:0; }
.hero-dot.active { background:var(--white); transform:scale(1.3); }
.hero-progress { position:absolute; bottom:0; left:0; height:2px; background:rgba(255,255,255,.15); width:100%; z-index:2; }
.hero-progress-bar { height:100%; background:rgba(255,255,255,.5); width:0%; transition:width linear; }
.hero-scroll { position:absolute; bottom:48px; left:50%; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:6px; opacity:0; animation:fadeInUp .6s ease 1.2s forwards; }
.hero-scroll-line { width:1px; height:40px; background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent); animation:scrollLine 2s ease-in-out infinite; }
.hero-scroll-txt { font-family:var(--font-sub); font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(245,245,240,.35); writing-mode:vertical-rl; transform:rotate(180deg); }
@keyframes fadeInUp { from{opacity:0;transform:translateX(-50%) translateY(10px)} to{opacity:1;transform:translateX(-50%) translateY(0)} }
@keyframes scrollLine { 0%,100%{opacity:1} 50%{opacity:.3} }
.hero.loaded .hero-eyebrow,.hero.loaded .hero-title,.hero.loaded .hero-subtitle,.hero.loaded .hero-ctas,.hero.loaded .hero-stats { opacity:1; transform:translateY(0); }
@media (max-width:860px) { .hero-content{padding:0 5vw;max-width:100%} .hero-title{font-size:clamp(3.5rem,12vw,6rem)} .hero-stats{gap:22px;bottom:36px} .hero-controls{bottom:36px} .hero-scroll{display:none} .hero-slide-img{object-position:right center} }
@media (max-width:480px) { .hero{min-height:100svh} .hero-content{padding:0 20px;justify-content:flex-end;padding-bottom:120px} .hero-title{font-size:clamp(3.2rem,14vw,4.5rem);margin-bottom:14px} .hero-stats{left:20px;gap:18px;bottom:28px} .hero-controls{right:20px;bottom:28px} .hero-stat-div{display:none} }

/* ── SECCIONES ───────────────────────────────── */
.section { padding:96px 6vw; }
.section-eyebrow { display:inline-flex; align-items:center; gap:10px; font-family:var(--font-sub); font-weight:700; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:rgba(245,245,240,.35); margin-bottom:16px; }
.section-eyebrow-line { width:24px; height:1px; background:rgba(245,245,240,.2); }
.section-title { font-family:var(--font-display); font-size:clamp(3rem,5.5vw,5rem); line-height:.92; letter-spacing:.03em; text-transform:uppercase; color:var(--white); margin-bottom:12px; }
.section-title em { font-style:normal; color:rgba(245,245,240,.2); }
.section-sub { font-size:1rem; color:rgba(245,245,240,.45); line-height:1.7; max-width:480px; margin-bottom:52px; }
.section-header { display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:48px; flex-wrap:wrap; }
.link-ver-todo { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-sub); font-weight:700; font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(245,245,240,.45); text-decoration:none; transition:color .18s; white-space:nowrap; flex-shrink:0; padding-bottom:4px; border-bottom:1px solid rgba(245,245,240,.15); }
.link-ver-todo:hover { color:var(--white); border-color:rgba(245,245,240,.4); }
.link-ver-todo i { font-size:.7rem; transition:transform .18s; }
.link-ver-todo:hover i { transform:translateX(4px); }
@media (max-width:760px) { .section{padding:64px 5vw} }
@media (max-width:480px) { .section{padding:52px 20px} .section-title{font-size:clamp(2.2rem,8vw,3rem)} .section-header{flex-direction:column;align-items:flex-start;margin-bottom:28px} }

/* ── MARQUEE — fondo NEGRO ───────────────────── */
.xm-marquee {
    background: var(--black);
    overflow: hidden;
    padding: 14px 0;
    border-top: 1px solid rgba(255,255,255,.07);
    border-bottom: 1px solid rgba(255,255,255,.07);
}
.xm-marquee-track {
    display: flex;
    white-space: nowrap;
    will-change: transform;
}
.xm-marquee-item {
    display: inline-flex;
    align-items: center;
    gap: 20px;
    padding: 0 36px;
    font-family: var(--font-display);
    font-size: 1.15rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(245,245,240,.55);
    flex-shrink: 0;
}
.xm-marquee-dot {
    width: 5px; height: 5px;
    background: rgba(245,245,240,.25);
    border-radius: 50%;
    flex-shrink: 0;
}
/* ── MODELOS DESTACADOS — fondo BLANCO ───────── */
#modelos { background: var(--white); color: var(--black); }
#modelos .section-eyebrow { color: rgba(10,10,10,.35); }
#modelos .section-eyebrow-line { background: rgba(10,10,10,.2); }
#modelos .section-title { color: var(--black); }
/* secciones blancas — em más visible */
#modelos .section-title em    { color: rgba(10,10,10,.35); }
#como-funciona .section-title em { color: rgba(10,10,10,.35); }
#modelos .section-sub { color: rgba(10,10,10,.5); }
#modelos .link-ver-todo { color: rgba(10,10,10,.45); border-bottom-color: rgba(10,10,10,.15); }
#modelos .link-ver-todo:hover { color: var(--black); border-bottom-color: rgba(10,10,10,.4); }

.mods-scroll {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 14px;
}
.mods-card {
    position: relative;
    border-radius: 10px;
    overflow: hidden;
    background: var(--gray3);
}
.mods-big { grid-row: span 2; }
.mods-img-link { display:block; width:100%; height:100%; min-height:260px; }
.mods-big .mods-img-link { min-height:100%; }
.mods-img-link img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease; }
.mods-card:hover .mods-img-link img { transform:scale(1.04); }
.mods-ph { width:100%; height:100%; min-height:260px; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.1); font-size:3rem; }
.mods-card::after { content:''; position:absolute; inset:0; background:linear-gradient(to top,rgba(10,10,10,.92) 0%,rgba(10,10,10,.3) 45%,transparent 100%); pointer-events:none; }
.mods-info { position:absolute; bottom:0; left:0; right:0; padding:16px; z-index:1; display:flex; flex-direction:column; gap:4px; }
.mods-big .mods-info { padding:22px; }
/* Textos sobre imagen — siempre blancos (van sobre gradiente oscuro) */
#modelos .mods-dep    { color: rgba(245,245,240,.5); }
#modelos .mods-nombre { color: var(--white); }
#modelos .mods-nombre:hover { color: #e0e0da; }
#modelos .mods-precio { color: rgba(245,245,240,.55); }
#modelos .mods-ph     { color: rgba(10,10,10,.1); }
/* Placeholder cuando no hay modelos */
#modelos > p { color: rgba(10,10,10,.3) !important; }
.mods-dep { font-family:var(--font-display); font-weight:700; font-size:.65rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(245,245,240,.5); }
.mods-nombre { font-family:var(--font-display); font-weight:900; font-size:1.05rem; text-transform:uppercase; letter-spacing:.03em; color:var(--white); line-height:1.1; text-decoration:none; display:block; }
.mods-big .mods-nombre { font-size:1.55rem; }
.mods-nombre:hover { color:#e0e0da; }
.mods-precio { font-family:var(--font-display); font-weight:700; font-size:.8rem; color:rgba(245,245,240,.55); }
.mods-wa { display:inline-flex; align-items:center; gap:6px; padding:7px 13px; background:rgba(37,211,102,.9); color:#fff; font-family:var(--font-display); font-weight:800; font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; border-radius:5px; text-decoration:none; margin-top:6px; opacity:0; transform:translateY(6px); transition:opacity .2s,transform .2s; width:fit-content; }
.mods-card:hover .mods-wa { opacity:1; transform:translateY(0); }
.mods-wa:hover { background:rgba(25,180,80,.95); }
/* En mobile el WA siempre visible */
@media (max-width:480px) { .mods-wa { opacity:1; transform:translateY(0); } }

@media (max-width:1100px) { .mods-scroll{grid-template-columns:2fr 1fr} }
@media (max-width:760px) {
    .mods-scroll {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        gap: 12px;
        padding-bottom: 8px;
    }
    .mods-scroll::-webkit-scrollbar { display: none; }
    .mods-card { flex: 0 0 72vw; min-width: 220px; }
    .mods-big { flex: 0 0 80vw; }
    .mods-img-link { min-height: 280px; }
    .mods-big .mods-img-link { min-height: 340px; }
    .mods-wa { opacity: 1; transform: translateY(0); }
}
@media (max-width:480px) {
    .mods-card { flex: 0 0 78vw; }
    .mods-big { flex: 0 0 85vw; }
}

/* ── SERVICIOS — fondo NEGRO ─────────────────── */
#servicios {
    background: #0f0f0f;
    border-top: 1px solid rgba(255,255,255,.05);
    border-bottom: 1px solid rgba(255,255,255,.05);
}
#servicios .section-eyebrow { color: rgba(245,245,240,.35); }
#servicios .section-eyebrow-line { background: rgba(245,245,240,.2); }
#servicios .section-title { color: var(--white); }
#servicios .section-title em { color: rgba(245,245,240,.2); }
.servicios-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; margin-top:52px; border:1px solid rgba(255,255,255,.07); border-radius:6px; overflow:hidden; }
.servicio-item { padding:40px 32px; background: rgba(255,255,255,.02); border-right:1px solid rgba(255,255,255,.07); transition:background .25s; position:relative; overflow:hidden; }
.servicio-item:last-child { border-right:none; }
.servicio-item:hover { background: rgba(255,255,255,.05); }
.servicio-item::before { content:''; position:absolute; top:0; left:0; width:3px; height:0; background:var(--white); transition:height .35s; }
.servicio-item:hover::before { height:100%; }
.servicio-icon { width:44px; height:44px; display:flex; align-items:center; justify-content:center; font-size:1.15rem; color:rgba(245,245,240,.4); margin-bottom:22px; border:1px solid rgba(255,255,255,.09); border-radius:4px; transition:color .2s,border-color .2s,transform .2s; }
.servicio-item:hover .servicio-icon { color:var(--white); border-color:rgba(255,255,255,.25); transform:translateX(4px); }
.servicio-nombre { font-family:var(--font-display); font-size:1.5rem; letter-spacing:.04em; text-transform:uppercase; color:var(--white); margin-bottom:10px; line-height:1; }
.servicio-desc { font-size:.84rem; color:rgba(245,245,240,.38); line-height:1.65; font-family:var(--font-body); }
@media (max-width:860px) { .servicios-grid{grid-template-columns:repeat(2,1fr)} .servicio-item{border-bottom:1px solid rgba(255,255,255,.07)} .servicio-item:nth-child(2n){border-right:none} }
@media (max-width:480px) { .servicios-grid{grid-template-columns:1fr} .servicio-item{border-right:none;padding:28px 22px} }

/* ── CÓMO FUNCIONA — fondo BLANCO ───────────── */
#como-funciona { background: var(--white); color: var(--black); }
#como-funciona .section-eyebrow { color: rgba(10,10,10,.35); }
#como-funciona .section-eyebrow-line { background: rgba(10,10,10,.2); }
#como-funciona .section-title { color: var(--black); }
#como-funciona .section-title em { color: rgba(10,10,10,.35); }
#como-funciona .section-sub { color: rgba(10,10,10,.5); }
#como-funciona > div[style] { text-align:center; margin-top:64px; }
.pasos-wrap { display:grid; grid-template-columns:repeat(3,1fr); margin-top:52px; position:relative; gap:0; background:rgba(0,0,0,.08); border:1px solid rgba(0,0,0,.1); border-radius:6px; overflow:hidden; }
.pasos-wrap::before { display:none; }
.paso-item { padding:44px 36px; text-align:left; position:relative; z-index:1; background:#fff; transition:background .25s; border-right:1px solid rgba(0,0,0,.08); }
.paso-item:last-child { border-right:none; }
.paso-item:hover { background:#f5f5f5; }
.paso-num-wrap { display:inline-flex; align-items:center; justify-content:center; width:52px; height:52px; border-radius:4px; background:rgba(0,0,0,.05); border:1px solid rgba(0,0,0,.1); margin:0 0 24px; position:relative; transition:border-color .25s,background .25s; }
.paso-item:hover .paso-num-wrap { border-color:rgba(0,0,0,.25); background:rgba(0,0,0,.09); }
.paso-num { font-family:var(--font-display); font-size:1.6rem; color:rgba(10,10,10,.25); line-height:1; transition:color .25s; }
.paso-item:hover .paso-num { color:var(--black); }
.paso-icon { position:absolute; top:-8px; right:-8px; width:22px; height:22px; border-radius:50%; background:#e8e8e8; border:1px solid rgba(0,0,0,.1); display:flex; align-items:center; justify-content:center; font-size:.62rem; color:rgba(10,10,10,.4); }
.paso-titulo { font-family:var(--font-display); font-size:1.65rem; letter-spacing:.04em; text-transform:uppercase; color:var(--black); margin-bottom:12px; line-height:1; }
.paso-desc { font-size:.84rem; color:rgba(10,10,10,.45); line-height:1.7; max-width:100%; margin:0; font-family:var(--font-body); }
/* Botón "Empezar ahora" en sección blanca */
#como-funciona .hero-btn-primary { background: var(--black); color: var(--white); }
#como-funciona .hero-btn-primary:hover { background: #222; }
@media (max-width:760px) { .pasos-wrap{grid-template-columns:1fr;gap:0} .paso-item{padding:32px 24px;border-right:none;border-bottom:1px solid rgba(0,0,0,.08)} .paso-item:last-child{border-bottom:none} }

/* ── CONTACTO — estilo XM ────────────────────── */
#contacto { background:#0f0f0f; border-top:1px solid rgba(255,255,255,.05); }
.contacto-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.contacto-items { display:flex; flex-direction:column; gap:6px; margin-bottom:36px; }
.contacto-item { display:flex; align-items:center; gap:14px; padding:15px 18px; border-radius:4px; background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06); border-left:2px solid rgba(255,255,255,.1); text-decoration:none; transition:background .18s,border-color .18s; color:inherit; }
.contacto-item:hover { background:rgba(255,255,255,.06); border-left-color:rgba(255,255,255,.3); }
.contacto-item-icon { width:36px; height:36px; border-radius:4px; background:rgba(255,255,255,.06); display:flex; align-items:center; justify-content:center; font-size:.85rem; color:rgba(245,245,240,.5); flex-shrink:0; transition:color .18s; }
.contacto-item:hover .contacto-item-icon { color:var(--white); }
.contacto-item-lbl { font-family:var(--font-sub); font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:rgba(245,245,240,.3); margin-bottom:3px; }
.contacto-item-val { font-family:var(--font-display); font-size:1.1rem; color:var(--white); text-transform:uppercase; letter-spacing:.03em; line-height:1; }
.contacto-wa-btn { display:inline-flex; align-items:center; gap:10px; padding:13px 26px; background:#25d366; color:#fff; border-radius:4px; font-family:var(--font-sub); font-weight:800; font-size:.88rem; letter-spacing:.1em; text-transform:uppercase; text-decoration:none; transition:background .18s,transform .14s; align-self:flex-start; }
@media (max-width:860px) { .contacto-wa-btn { align-self:center; width:100%; justify-content:center; } }
.contacto-wa-btn:hover { background:#1dba58; transform:translateY(-2px); }
.contacto-wa-btn i { font-size:1rem; }
.contacto-mapa { border-radius:4px; overflow:hidden; border:1px solid rgba(255,255,255,.08); height:520px; }
.contacto-mapa iframe { width:100%; height:100%; border:none; filter:grayscale(100%) invert(90%) contrast(90%); opacity:.85; transition:filter .3s,opacity .3s; }
.contacto-mapa:hover iframe { filter:grayscale(60%) invert(80%) contrast(90%); opacity:1; }
@media (max-width:860px) { .contacto-grid{grid-template-columns:1fr;gap:36px} .contacto-mapa{height:300px} }
.footer { background:var(--black); border-top:1px solid rgba(255,255,255,.06); padding:52px 6vw 32px; }
.footer-top { display:flex; align-items:flex-start; justify-content:space-between; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.06); flex-wrap:wrap; }
.footer-logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.footer-logo img { width:42px; height:42px; border-radius:50%; object-fit:cover; border:1px solid rgba(255,255,255,.1); background:#fff; }
.footer-logo-text { font-family:var(--font-display); font-size:1.4rem; letter-spacing:.1em; color:var(--white); text-transform:uppercase; line-height:1; }
.footer-logo-sub { font-family:var(--font-sub); font-size:.65rem; font-weight:600; color:rgba(245,245,240,.3); text-transform:uppercase; letter-spacing:.14em; display:block; margin-top:4px; }
.footer-links { display:flex; gap:48px; flex-wrap:wrap; }
.footer-col-title { font-family:var(--font-sub); font-weight:800; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(245,245,240,.35); margin-bottom:14px; }
.footer-col-items { display:flex; flex-direction:column; gap:8px; }
.footer-link { font-size:.84rem; color:rgba(245,245,240,.5); text-decoration:none; transition:color .15s; }
.footer-link:hover { color:var(--white); }
.footer-social { display:flex; gap:8px; margin-top:16px; }
.footer-social-btn { width:36px; height:36px; border-radius:8px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; color:rgba(245,245,240,.45); font-size:.82rem; text-decoration:none; transition:background .15s,color .15s; }
.footer-social-btn:hover { background:rgba(255,255,255,.1); color:var(--white); }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; padding-top:28px; gap:12px; flex-wrap:wrap; }
.footer-copy { font-size:.75rem; color:rgba(245,245,240,.2); }
.footer-made { font-size:.72rem; color:rgba(245,245,240,.15); }
@media (max-width:600px) { .footer-top{flex-direction:column;gap:32px} .footer-links{gap:32px} .footer-bottom{flex-direction:column;align-items:flex-start} .footer{padding:40px 20px 24px} }
