/* ============================================
   SUPERMERCADO DEL MOTORISTA — HOMEPAGE
   supermercadodelmotorista.es
   ============================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --negro:    #050505;
  --blanco:   #f8f5f0;
  --gris-1:   #0f0f0f;
  --gris-2:   #181818;
  --gris-3:   #282828;
  --gris-txt: #666;
  --naranja:  #e65100;
  --naranja-h:#bf4400;
  --borde:    rgba(255,255,255,0.06);
}

html { scroll-behavior: smooth; }

body {
  background: var(--negro);
  color: var(--blanco);
  font-family: 'DM Sans', sans-serif;
  font-weight: 300;
  overflow-x: hidden;
  cursor: none;
}

/* ── CURSOR ── */
.cursor { position:fixed;width:8px;height:8px;background:var(--blanco);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .15s,height .15s,background .15s; }
.cursor-ring { position:fixed;width:36px;height:36px;border:1px solid rgba(248,245,240,0.4);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s,border-color .3s; }
body:has(a:hover) .cursor, body:has(button:hover) .cursor { width:14px;height:14px;background:var(--naranja); }
body:has(a:hover) .cursor-ring, body:has(button:hover) .cursor-ring { width:52px;height:52px;border-color:var(--naranja); }

/* ── NAV ── */
.sdm-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  display: flex; align-items: center;
  padding: 0 clamp(1.5rem, 5vw, 4rem);
  height: 64px;
  background: rgba(5,5,5,0); backdrop-filter: blur(0px);
  border-bottom: 1px solid transparent;
  transition: background .4s, backdrop-filter .4s, border-color .4s;
}
.sdm-nav.scrolled {
  background: rgba(5,5,5,0.92);
  backdrop-filter: blur(16px);
  border-bottom-color: var(--borde);
}
.sdm-nav-logo {
  display: flex; flex-direction: column; line-height: 1; text-decoration: none;
}
.sdm-nav-logo-top { font-family:'Anton',sans-serif;font-size:.95rem;letter-spacing:.08em;color:var(--blanco);text-transform:uppercase; }
.sdm-nav-logo-sub { font-family:'DM Mono',monospace;font-size:.48rem;letter-spacing:.35em;color:var(--naranja);margin-top:2px;text-transform:uppercase; }
.sdm-nav-links { display:flex;align-items:center;gap:2.5rem;margin-left:3rem;list-style:none; }
.sdm-nav-links a { font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gris-txt);text-decoration:none;transition:color .2s; }
.sdm-nav-links a:hover { color:var(--blanco); }
.sdm-nav-cta {
  margin-left: auto; display:inline-flex;align-items:center;gap:.6rem;
  padding:.6rem 1.4rem;background:var(--naranja);color:var(--blanco);
  font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.2em;
  text-transform:uppercase;text-decoration:none;transition:background .2s;
}
.sdm-nav-cta:hover { background:var(--naranja-h); }
@media(max-width:768px){.sdm-nav-links{display:none;}}

/* ── HERO ── */
.sdm-hero {
  position: relative; width: 100%; height: 100svh; min-height: 620px;
  overflow: hidden; display: flex; align-items: flex-end;
  background: var(--negro);
}

/* Slideshow de imágenes rotatorio */
.sdm-hero-slides { position:absolute;inset:0;z-index:0; }
.sdm-hero-slide {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 30%;
  filter: grayscale(0.15) contrast(1.1) brightness(0.6);
  opacity: 0;
  transition: opacity 1.4s cubic-bezier(.4,0,.2,1), transform 6s ease-out;
  transform: scale(1.05);
}
.sdm-hero-slide.active {
  opacity: 1;
  transform: scale(1);
}

/* Indicadores de marca (dots con nombre) */
.sdm-hero-brand-dots {
  position: absolute; bottom: 2rem; right: clamp(1.5rem,5vw,4rem);
  z-index: 3; display: flex; flex-direction: column; gap: .6rem;
  opacity: 0; animation: sdm-up .8s 1s cubic-bezier(.22,1,.36,1) forwards;
}
.sdm-brand-dot {
  display: flex; align-items: center; gap: .8rem;
  cursor: none; background: none; border: none; padding: 0;
  text-align: right; flex-direction: row-reverse;
}
.sdm-brand-dot-label {
  font-family: 'DM Mono', monospace; font-size: .52rem;
  letter-spacing: .3em; text-transform: uppercase;
  color: rgba(248,245,240,.3); transition: color .3s;
}
.sdm-brand-dot-line {
  width: 20px; height: 1px;
  background: rgba(248,245,240,.2); transition: width .3s, background .3s;
}
.sdm-brand-dot.active .sdm-brand-dot-label { color: var(--blanco); }
.sdm-brand-dot.active .sdm-brand-dot-line { width: 36px; background: var(--naranja); }
.sdm-brand-dot:hover .sdm-brand-dot-label { color: rgba(248,245,240,.7); }
.sdm-hero-velo {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(to top, rgba(5,5,5,1) 0%, rgba(5,5,5,.55) 35%, rgba(5,5,5,0) 65%),
    linear-gradient(to right, rgba(5,5,5,.65) 0%, transparent 55%);
}
.sdm-hero-line {
  position:absolute;top:0;left:0;right:0;height:3px;z-index:3;
  background:linear-gradient(to right,#e65100 0%,#cc0000 35%,transparent 65%);
}
.sdm-hero-content {
  position:relative;z-index:2;
  padding:clamp(1.5rem,5vw,4rem);
  padding-bottom:clamp(3rem,7vw,6rem);
  width:100%;
}
.sdm-hero-eyebrow {
  font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.45em;
  text-transform:uppercase;color:var(--naranja);margin-bottom:1.2rem;
  opacity:0;animation:sdm-up .7s .1s cubic-bezier(.22,1,.36,1) forwards;
}
.sdm-hero-titulo {
  font-family:'Anton',sans-serif;
  font-size:clamp(3.2rem,11vw,11rem);
  line-height:.88;letter-spacing:-.01em;color:var(--blanco);
  opacity:0;animation:sdm-up .8s .2s cubic-bezier(.22,1,.36,1) forwards;
}
.sdm-hero-titulo span { display:block;color:var(--naranja); }
.sdm-hero-sub {
  margin-top:2rem;display:flex;align-items:center;gap:2rem;flex-wrap:wrap;
  opacity:0;animation:sdm-up .8s .4s cubic-bezier(.22,1,.36,1) forwards;
}
.sdm-hero-tagline {
  font-size:clamp(.78rem,1.2vw,.88rem);font-weight:200;font-style:italic;
  color:rgba(248,245,240,.48);max-width:360px;line-height:1.75;
}
.sdm-hero-cta {
  display:inline-flex;align-items:center;gap:.8rem;
  padding:.9rem 2.4rem;background:var(--naranja);color:var(--blanco);
  font-family:'DM Mono',monospace;font-size:.68rem;letter-spacing:.22em;
  text-transform:uppercase;text-decoration:none;border:none;cursor:none;
  flex-shrink:0;transition:background .2s,transform .15s;
}
.sdm-hero-cta:hover{background:var(--naranja-h);transform:translateY(-2px);}
.sdm-hero-cta-ghost {
  display:inline-flex;align-items:center;gap:.8rem;
  padding:.9rem 2.4rem;border:1px solid rgba(248,245,240,.2);
  color:rgba(248,245,240,.6);font-family:'DM Mono',monospace;font-size:.68rem;
  letter-spacing:.22em;text-transform:uppercase;text-decoration:none;
  cursor:none;flex-shrink:0;transition:border-color .2s,color .2s,transform .15s;
}
.sdm-hero-cta-ghost:hover{border-color:var(--blanco);color:var(--blanco);transform:translateY(-2px);}
.sdm-hero-stats {
  position:absolute;right:clamp(1.5rem,5vw,4rem);bottom:clamp(3rem,7vw,6rem);
  z-index:2;display:flex;flex-direction:column;align-items:flex-end;gap:1.4rem;
  opacity:0;animation:sdm-up .8s .6s cubic-bezier(.22,1,.36,1) forwards;
}
.sdm-hero-stat-n { font-family:'Anton',sans-serif;font-size:2.8rem;color:var(--naranja);line-height:1; }
.sdm-hero-stat-l { font-family:'DM Mono',monospace;font-size:.52rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gris-txt); }
.sdm-scroll-ind {
  position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  opacity:0;animation:sdm-up .8s 1.2s forwards;
}
.sdm-scroll-line { width:1px;height:48px;background:linear-gradient(to bottom,var(--naranja),transparent);animation:sdm-pulse 2s 1.8s ease-in-out infinite; }
.sdm-scroll-ind span { font-family:'DM Mono',monospace;font-size:.52rem;letter-spacing:.35em;color:var(--gris-txt); }

@keyframes sdm-up { from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);} }
@keyframes sdm-pulse { 0%,100%{opacity:.4;}50%{opacity:1;} }

/* ── TICKER ── */
.sdm-ticker { background:var(--naranja);overflow:hidden;padding:.85rem 0; }
.sdm-ticker-inner {
  display:flex;gap:4rem;width:max-content;
  animation:sdm-ticker 30s linear infinite;
}
.sdm-ticker-item {
  font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--negro);white-space:nowrap;
  display:flex;align-items:center;gap:1.2rem;
}
.sdm-ticker-sep { opacity:.4;font-size:.5rem; }
@keyframes sdm-ticker { from{transform:translateX(0);}to{transform:translateX(-50%);} }

/* ── CARRUSEL DE MARCAS (componente reutilizado de tutiendamotera) ── */
.ttm-bc-wrap{position:relative;width:100%;overflow:hidden;background:#050505;}
.ttm-bc-header{display:flex;align-items:center;justify-content:space-between;padding:36px 48px 24px;}
.ttm-bc-label{display:flex;align-items:center;gap:14px;}
.ttm-bc-label::before{content:'';display:block;width:32px;height:1px;background:rgba(255,255,255,0.25);}
.ttm-bc-title{font-size:10px;letter-spacing:.45em;text-transform:uppercase;color:rgba(255,255,255,0.35);font-family:'DM Mono','Courier New',monospace;font-weight:400;}
.ttm-bc-nav{display:flex;gap:8px;}
.ttm-bc-nav button{width:40px;height:40px;background:transparent;border:1px solid rgba(255,255,255,0.15);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s;flex-shrink:0;}
.ttm-bc-nav button:hover{background:#fff;color:#050505;border-color:#fff;}
.ttm-bc-nav button svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.ttm-bc-track-outer{overflow:hidden;padding:0 48px 48px;}
.ttm-bc-track{display:flex;gap:16px;transition:transform .6s cubic-bezier(.22,1,.36,1);will-change:transform;cursor:grab;user-select:none;}
.ttm-bc-track.grabbing{cursor:grabbing;}
.ttm-bc-card{flex:0 0 calc(33.333% - 11px);min-width:280px;position:relative;overflow:hidden;aspect-ratio:3/4;display:block;text-decoration:none;background:#0d0d0d;}
@media(max-width:900px){.ttm-bc-card{flex:0 0 calc(50% - 8px);}.ttm-bc-header,.ttm-bc-track-outer{padding-left:24px;padding-right:24px;}}
@media(max-width:580px){.ttm-bc-card{flex:0 0 85vw;aspect-ratio:2/3;}}
.ttm-bc-card__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .8s cubic-bezier(.22,1,.36,1);}
.ttm-bc-card:hover .ttm-bc-card__img{transform:scale(1.06);}
.ttm-bc-card__velo{position:absolute;inset:0;background:linear-gradient(to top,rgba(5,5,5,.95) 0%,rgba(5,5,5,.5) 40%,rgba(5,5,5,.08) 100%);z-index:1;}
.ttm-bc-card__velo--solid{background:linear-gradient(160deg,#0a0a0a 0%,#161616 100%);}
.ttm-bc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent,rgba(255,255,255,.3));z-index:4;transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.22,1,.36,1);}
.ttm-bc-card:hover::before{transform:scaleX(1);}
.ttm-bc-card__num{position:absolute;top:20px;right:20px;font-family:'Anton','Arial Black',sans-serif;font-size:4rem;line-height:1;color:rgba(255,255,255,.04);z-index:2;letter-spacing:-.02em;transition:color .4s;}
.ttm-bc-card:hover .ttm-bc-card__num{color:rgba(255,255,255,.07);}
.ttm-bc-card__body{position:absolute;bottom:0;left:0;right:0;padding:32px 28px;z-index:3;}
.ttm-bc-card__tag{display:inline-block;font-family:'DM Mono','Courier New',monospace;font-size:8px;letter-spacing:.4em;text-transform:uppercase;color:var(--accent,rgba(255,255,255,.5));margin-bottom:12px;font-weight:400;padding:4px 10px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);}
.ttm-bc-card__name{display:block;font-family:'Anton','Arial Black',sans-serif;font-size:clamp(2.4rem,4.5vw,3.8rem);line-height:.88;letter-spacing:.01em;color:#fff;margin-bottom:10px;text-shadow:0 2px 24px rgba(0,0,0,.6);}
.ttm-bc-card__slogan{display:block;font-family:'DM Mono','Courier New',monospace;font-size:10px;line-height:1.6;letter-spacing:.08em;color:rgba(255,255,255,.5);margin-bottom:22px;font-weight:300;font-style:italic;}
.ttm-bc-card__cta{display:inline-flex;align-items:center;gap:14px;padding:13px 24px;background:transparent;color:#fff;border:1px solid rgba(255,255,255,.25);font-family:'DM Mono','Courier New',monospace;font-size:9px;letter-spacing:.3em;text-transform:uppercase;font-weight:400;text-decoration:none;position:relative;overflow:hidden;transition:border-color .3s,color .3s;}
.ttm-bc-card__cta::before{content:'';position:absolute;inset:0;background:var(--accent,#fff);transform:scaleX(0);transform-origin:left;transition:transform .45s cubic-bezier(.22,1,.36,1);z-index:0;}
.ttm-bc-card__cta:hover::before{transform:scaleX(1);}
.ttm-bc-card__cta:hover{border-color:var(--accent,#fff);color:#050505;}
.ttm-bc-card__cta span,.ttm-bc-card__cta svg{position:relative;z-index:1;}
.ttm-bc-card__cta svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s;}
.ttm-bc-card:hover .ttm-bc-card__cta svg{transform:translateX(4px);}
.ttm-bc-card__cta--coming{border-color:rgba(255,255,255,.12);color:rgba(255,255,255,.4);}
.ttm-bc-card__cta--coming::before{background:rgba(255,255,255,.06);}
.ttm-bc-card__cta--coming:hover{color:rgba(255,255,255,.7);}
.ttm-bc-dots{display:flex;gap:6px;justify-content:center;padding:0 0 40px;}
.ttm-bc-dot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.18);cursor:pointer;transition:all .25s;border:none;padding:0;}
.ttm-bc-dot.active{background:#fff;width:24px;border-radius:2px;}

/* ── NOSOTROS ── */
.sdm-nosotros {
  padding: 7vh clamp(1.5rem,5vw,4rem);
  background: var(--gris-1);
  border-top: 1px solid var(--borde);
  border-bottom: 1px solid var(--borde);
}
.sdm-nosotros-grid { display:grid;grid-template-columns:1fr 1fr;gap:5vw;align-items:center; }
@media(max-width:768px){.sdm-nosotros-grid{grid-template-columns:1fr;}}
.sdm-sec-eyebrow { font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.45em;text-transform:uppercase;color:var(--naranja);margin-bottom:.8rem; }
.sdm-sec-titulo { font-family:'Anton',sans-serif;font-size:clamp(2rem,5vw,4rem);letter-spacing:.02em;line-height:1; }
.sdm-sec-desc { font-size:.88rem;font-weight:200;font-style:italic;color:rgba(248,245,240,.45);max-width:500px;line-height:1.7;margin-top:.8rem; }
.sdm-stats-grid { display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--gris-3); }
.sdm-stat { background:var(--gris-2);padding:2rem 1.8rem;border-top:2px solid transparent;transition:border-color .3s; }
.sdm-stat:hover { border-top-color:var(--naranja); }
.sdm-stat-n { font-family:'Anton',sans-serif;font-size:clamp(2.5rem,5vw,4rem);color:var(--naranja);line-height:1;margin-bottom:.4rem; }
.sdm-stat-l { font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gris-txt); }

/* ── CONTACTO ── */
.sdm-contacto {
  padding: 8vh clamp(1.5rem,5vw,4rem);
  position: relative; overflow: hidden;
}
.sdm-contacto::before {
  content:'MOTORISTA';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);font-family:'Anton',sans-serif;
  font-size:clamp(6rem,18vw,18rem);color:rgba(255,255,255,.015);
  white-space:nowrap;pointer-events:none;letter-spacing:.05em;
}
.sdm-contacto-inner { position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:2.5rem; }
.sdm-contacto-titulo { font-family:'Anton',sans-serif;font-size:clamp(2.5rem,7vw,6rem);letter-spacing:.02em;line-height:.9; }
.sdm-contacto-titulo em { font-style:normal;color:var(--naranja); }
.sdm-contacto-sub { font-size:.88rem;font-weight:200;font-style:italic;color:rgba(248,245,240,.45);max-width:480px;line-height:1.7; }
.sdm-contacto-btns { display:flex;flex-wrap:wrap;gap:1rem;justify-content:center; }
.btn-whatsapp { display:inline-flex;align-items:center;gap:.8rem;padding:1rem 2.6rem;background:#25D366;color:#fff;font-family:'DM Mono',monospace;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;text-decoration:none;transition:background .2s,transform .15s; }
.btn-whatsapp:hover{background:#1da850;transform:translateY(-2px);}
.btn-tel { display:inline-flex;align-items:center;gap:.8rem;padding:1rem 2.6rem;background:transparent;border:1px solid rgba(230,81,0,.4);color:var(--blanco);font-family:'DM Mono',monospace;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;text-decoration:none;transition:border-color .2s,color .2s,transform .15s; }
.btn-tel:hover{border-color:var(--naranja);color:var(--naranja);transform:translateY(-2px);}
.sdm-datos { display:flex;flex-wrap:wrap;gap:2.5rem;justify-content:center;border-top:1px solid var(--borde);padding-top:2.5rem;width:100%;max-width:700px; }
.sdm-dato { display:flex;flex-direction:column;align-items:center;gap:.4rem; }
.sdm-dato-label { font-family:'DM Mono',monospace;font-size:.52rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gris-txt); }
.sdm-dato-valor { font-size:.88rem;font-weight:400;color:var(--blanco); }

/* ── FOOTER ── */
.sdm-footer {
  background:var(--gris-1);border-top:1px solid var(--borde);
  padding:3rem clamp(1.5rem,5vw,4rem);
  display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;justify-content:space-between;
}
.sdm-footer-logo-top { font-family:'Anton',sans-serif;font-size:1.1rem;letter-spacing:.08em;color:var(--blanco); }
.sdm-footer-logo-sub { font-family:'DM Mono',monospace;font-size:.48rem;letter-spacing:.35em;color:var(--naranja);margin-top:3px;text-transform:uppercase; }
.sdm-footer-meta { font-family:'DM Mono',monospace;font-size:.55rem;letter-spacing:.2em;color:var(--gris-txt);text-transform:uppercase; }
.sdm-footer-line { width:100%;height:1px;background:linear-gradient(to right,var(--naranja),#cc0000 30%,transparent 70%);margin-bottom:.5rem; }

/* ── VIEWPORT CONTAINMENT (HiDPI fix) ── */
.entry-content, .wp-site-blocks, body {
  max-width: 100vw !important;
  overflow-x: hidden !important;
}
.ttm-bc-wrap, .ttm-bc-track-outer {
  max-width: 100vw !important;
  box-sizing: border-box !important;
}
.sdm-hero { max-width: 100vw !important; }
.sdm-ticker { max-width: 100vw !important; }
.sdm-nosotros { max-width: 100vw !important; }
.sdm-contacto { max-width: 100vw !important; }
.sdm-footer { max-width: 100vw !important; }