/* ========================================================================
   FERRO PARTS — SITE CSS (LIMPIO)
   Autor: Jumpweb
   Última edición: hoy
   ------------------------------------------------------------------------
   Secciones:
   00) Variables / Reset / Base
   01) Fuentes
   02) Header (desktop + móvil con modal fullscreen)
   03) Hero (slides)
   04) Banda “Disponibilidad inmediata”
   05) Quiénes somos
   06) Repuestos (botonera + visor)
   07) Contact CTA + Marcas
   08) Footer
   ======================================================================== */


/* ========== 00) Variables / Reset / Base ================================= */

:root{
  --ink: #fff;
  --maxw: 1180px;
  --brand-brown: #3b0f0f;
  --brand-cyan:  #078aa3;
    /* Ajustá estos valores a gusto */
  --hero-top-desktop: 250px;  /* antes ~150–200 */
  --hero-top-mobile: 170px;   /* antes ~150 */
}
}

*{ box-sizing:border-box; }
html, body{ margin:0; overflow-x:hidden; }
img{ display:block; max-width:100%; height:auto; }
body{
  font-family:"DINOT", system-ui, Arial, sans-serif;
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Respeta preferencias del usuario (reduce motion) */
@media (prefers-reduced-motion: reduce){
  *{
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}


/* ========== 01) Fuentes =================================================== */

@font-face{
  font-family:"DINOT";
  src:url("/assets/fonts/DINOT-Light.otf") format("opentype");
  font-weight:300; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"DINOT";
  src:url("/assets/fonts/DINOT-Regular.otf") format("opentype");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"DINOT";
  src:url("/assets/fonts/DINOT-Medium.otf") format("opentype");
  font-weight:500; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"DINOT";
  src:url("/assets/fonts/DINOT-Bold.otf") format("opentype");
  font-weight:700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"DINOT";
  src:url("/assets/fonts/DINOT-Black.otf") format("opentype");
  font-weight:900; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Norwester";
  src:url("/assets/fonts/norwester.otf") format("opentype");
  font-weight:700; font-style:normal; font-display:swap;
}


/* ========== 02) Header (desktop + móvil) ================================= */

/* Contenedor base */
.site-header{
  position:absolute; left:0; right:0; top:0;
  z-index:200; background:transparent;
  overflow-x:hidden; /* asegura que nada del header genere scroll horizontal */
}
.site-header .wrap{
  max-width:var(--maxw); margin:0 auto;
  padding:0px 18px 12px;
  display:grid; grid-template-columns:auto 1fr auto;
  align-items:start; gap:18px;
}

/* Marca */
.site-header .brand{ align-self:start; }
.site-header .brand img{ width:128px; height:auto; }

/* Nav (desktop) */
.main-nav{
  position:relative; justify-self:center;
  display:flex; align-items:flex-end; gap:32px;
  padding:10px 0 12px;
}
.main-nav::after{
  content:""; position:absolute; bottom:0; height:1px;
  left:0; right:0; width:100%;                /* SIN 100vw → evita overflow */
  background:rgba(255,255,255,.35);
}
.main-nav a{
  position:relative; color:#fff; font-weight:700;
  letter-spacing:.04em; text-decoration:none;
  padding:12px 0 13px; font-size:14px;
}
.main-nav a + a{
  margin-left:24px; padding-left:24px;
  border-left:1px solid rgba(255,255,255,.35);
  margin-bottom:-1px; margin-top:25px;
}
/* Hover underline (desktop) */
.main-nav a::after{
  content:""; position:absolute; left:0; bottom:-1px; width:100%; height:2px;
  background:#fff; transform:scaleX(0); transform-origin:left; transition:transform .25s;
}
.main-nav a:hover::after{ transform:scaleX(1); }

/* Wordmark (desktop) */
.wordmark{
  color:#fff; text-align:right; line-height:1.05;
  font-family:"Norwester","DINOT",system-ui,Arial,sans-serif;
  font-weight:700; letter-spacing:.10em; font-size:14px; text-transform:uppercase;
  align-self:center; display:flex; align-items:center; justify-content:flex-end;
}
.wordmark-img{ width:clamp(140px,14vw,220px); height:auto; margin-top:-35px; }

/* Botón hamburguesa (oculto en desktop) */
.menu-toggle{
  appearance:none; border:0; background:transparent; cursor:pointer;
  width:42px; height:42px; padding:6px; margin-left:auto; display:none;
  align-items:center; justify-content:center; flex-direction: column;
  gap:4px;
  -webkit-tap-highlight-color: transparent;
}
.menu-toggle .bar{
  display:block; width:100%; height:2px; background:#fff; border-radius:2px;
  transition:transform .25s ease, opacity .2s ease;
}

/* ===== Mobile (≤900px): modal fullscreen ===== */
@media (max-width:900px){

  .site-header .wrap{
    grid-template-columns:auto 1fr; align-items:center;
  }
  .site-header .brand img{ width:100px; }
  .wordmark{ display:none; }

  /* botón visible arriba derecha */
  .menu-toggle{
    display:flex;
    position:fixed; top:max(10px, env(safe-area-inset-top)); right:12px;
    z-index:1001;
  }

  /* Nav a pantalla completa (centrado, colores de marca) */
  .main-nav{
    position:fixed; inset:0;
    width:100%; height:100%; box-sizing:border-box;
    padding:20px 28px 32px;
    background: linear-gradient(180deg, rgba(59,15,15,.98) 0%, rgba(26,7,7,.98) 100%);
    backdrop-filter: blur(2px);
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    gap:14px;
    opacity:0; pointer-events:none; transition:opacity .28s ease;
    z-index:1000;
  }
  .main-nav::after{ display:none; }   /* sin línea inferior en el modal */
  .main-nav a::after{ display:none; } /* sin subrayado animado en el modal */
  .main-nav a + a{ margin:0; padding-left:0; border-left:0; }
  .main-nav a{
    color:#fff; text-transform:uppercase; letter-spacing:.08em;
    font-size:clamp(18px,4.2vw,22px); padding:12px 0; font-weight:800;
  }

  body.nav-open .main-nav{ opacity:1; pointer-events:auto; }
  .nav-backdrop{ display:none !important; } /* no usamos capa separada */
}

/* Botón en “X” al abrir */
body.nav-open .menu-toggle .bar:nth-child(1){ transform:translateY(6px) rotate(45deg); }
body.nav-open .menu-toggle .bar:nth-child(2){ opacity:0; }
body.nav-open .menu-toggle .bar:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

/* Sin scroll de fondo con modal abierto */
body.nav-open{ overflow:hidden; }


/* ========== 03) Hero (slides) ============================================ */



.hero{ position:relative; height:84vh; overflow:hidden; }
.slides{ position:relative; height:100%; }
.slide{
  position:absolute; inset:0; opacity:0; transition:opacity .6s ease;
  background:#000; background-size:cover; background-position:center; background-repeat:no-repeat;
}
.slide.is-active{ opacity:1; }

.slide .overlay{
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.70) 0%, rgba(0,0,0,.40) 35%, rgba(0,0,0,.25) 100%);
}
.slide .content{
  position:relative; z-index:2; max-width:var(--maxw); margin:0 auto; padding:180px 18px 80px;
}
.slide h1{
  font-family:"Norwester","DINOT",system-ui,Arial,sans-serif;
  font-weight:700; letter-spacing:.02em;
  font-size:clamp(28px, 5vw + 6px, 64px); line-height:1.05; margin:0;
  text-transform:uppercase;
  max-width:21ch;
  text-shadow:0 8px 30px rgba(0,0,0,.55);
}


/* ========== 04) Banda “Disponibilidad inmediata” ========================= */

.band-availability{
  background:var(--brand-cyan); color:#fff; margin:0; position:relative;
  box-shadow:0 12px 24px rgba(0,0,0,.15);
}
.band-availability::before,
.band-availability::after{
  content:""; position:absolute; left:0; right:0; height:1px;
  background:rgba(255,255,255,.28); pointer-events:none;
}
.band-availability::before{ top:0; }
.band-availability::after{ bottom:0; }

.band-availability .wrap{
  max-width:var(--maxw); margin:0 auto;
  padding:40px 18px;
  display:flex; align-items:center; gap:28px; justify-content:flex-start;
}
.band-availability .icon{
  width:86px; height:auto; filter:drop-shadow(0 2px 0 rgba(0,0,0,.12));
}
.band-availability .copy{ text-align:left; }
.band-availability .title{
  margin:0; font-weight:700; letter-spacing:.01em; line-height:1.2;
  font-size:clamp(20px, 1.7vw + 8px, 28px);
}
.band-availability .subtitle{
  margin:.25rem 0 0; font-weight:400; opacity:.92; letter-spacing:.01em; line-height:1.3;
  font-size:clamp(15px, 1.2vw + 6px, 22px);
}

@media (max-width:900px){
  .band-availability .wrap{ gap:18px; }
  .band-availability .icon{ width:68px; }
}
@media (max-width:640px){
  .band-availability .wrap{ flex-direction:column; text-align:center; gap:12px; }
  .band-availability .copy{ text-align:center; }
  .band-availability .icon{ width:54px; }
}


/* ========== 05) Quiénes somos ============================================ */

.about{
  --about-bg: url('/assets/img/AdobeStock_629236232.jpg');
  position:relative; overflow:hidden; color:#fff;
  background:
    linear-gradient(90deg, rgba(0,0,0,.85) 0%, rgba(0,0,0,.65) 38%, rgba(0,0,0,.35) 62%, rgba(0,0,0,.08) 100%),
    var(--about-bg) center / cover no-repeat #000;
  background-position:left top, center 42%;
  border-top:1px solid rgba(255,255,255,.18);
  border-bottom:1px solid rgba(255,255,255,.18);
  min-height:900px;
  display:grid; place-items:center start;
  padding:56px 0;
  margin-bottom:120px;
}
.about__inner{
  max-width:var(--maxw); width:92%; margin:0 auto; padding:0 18px; display:grid;
}
.about__card{
  max-width:520px; min-height:480px; padding:32px 28px;
  background:rgba(0,0,0,.72);
  border:4px solid var(--brand-cyan);
  box-shadow:0 12px 28px rgba(0,0,0,.25);
  display:flex; flex-direction:column; justify-content:flex-start;
}
.about__card h2{
  margin:0 0 14px;
  font-family:"DINOT",system-ui,Arial,sans-serif;
  font-weight:700; letter-spacing:.04em; color:#079bb5;
  font-size:clamp(18px, 1.2vw + 14px, 26px);
}
.about__card p{
  margin:0 0 14px; font-weight:400; line-height:1.45;
  font-size:clamp(14px, 1vw + 10px, 18px); color:rgba(255,255,255,.95);
}

@media (max-width:860px){
  .about{ min-height:700px; padding:56px 0; }
  .about__card{ max-width:100%; min-height:auto; }
}
@media (max-width:600px){
  .about{ min-height:560px; padding:42px 0; }
  .about__card{ border-width:3px; padding:18px 16px; }
}


/* ========== 06) Repuestos (botonera + visor) ============================== */

#repuestos * { box-sizing: border-box; }

#repuestos{
  --c-accent: #0797AC;
  --c-accent-dark: #007c8e;
  --c-active: #3E0D0D;
  --c-frame: #4a0c0c;
  --c-ink: #0B1C24;
  margin: 64px 0;
}

/* Grid principal */
#repuestos .products__wrap{
  max-width: 1220px;
  margin: 0 auto;
  padding: 10px 12px;
  display: grid;
  grid-template-columns: minmax(0,1fr) 560px; /* Izq | Der */
  grid-template-rows: auto auto;              /* F1: lista+visor | F2: “más” */
  gap: 22px 28px;
  align-items: start;
}

/* Título */
#repuestos .products__title{
  grid-column: 1 / -1;
  grid-row: 1;
  margin: -85px 0 12px;
  font-weight: 800;
  font-size: clamp(22px, 3vw, 32px);
  color: var(--c-frame);
}

/* Columna izquierda (botonera) */
#repuestos .products__left{ grid-column:1; grid-row:1; }

/* Botonera 2 columnas */
#repuestos .products__list{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px 20px;
}

/* Botones */
#repuestos .pbtn{
  appearance: none; border: 0; cursor: pointer;
  background: var(--c-accent); color: #fff;
  min-height: 46px; padding: 10px 12px;
  display: flex; align-items: center; justify-content: center;
  text-align: center; font-weight: 700; font-size: 15px; line-height: 1.2;
  white-space: normal; overflow-wrap: anywhere;
  transition: filter .15s ease, transform .04s ease, background .15s ease;
}
#repuestos .pbtn:hover{ filter: brightness(1.07); background: var(--c-accent-dark); }
#repuestos .pbtn:active{ transform: translateY(1px); }
#repuestos .pbtn.is-active{ background: var(--c-active); }

/* Visor derecha */
#repuestos .products__viewer{
  grid-column:2; grid-row:1;
  margin:0;
  /*  align-self:start;*/
  border: 8px solid var(--c-frame);
  border-radius: 8px;
  background:#fff;
  padding: 14px;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
#repuestos .products__viewer img{
  display:block; width:100%; height:100%; object-fit:contain;
}

/* Desktop: misma altura para lista y visor */
@media (min-width: 1101px){
  #repuestos .products__wrap{
    grid-template-rows: auto 1fr auto; /* fila 2 (lista+visor) se estira */
    align-items: stretch;
  }

  /* Izquierda: que la lista LLENE su celda */
  #repuestos .products__left{ align-self: stretch; }
  #repuestos .products__list{
    height: 100%;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px 20px;
    grid-auto-rows: 1fr;     /* cada fila (botón) reparte la altura disponible */
  }
  #repuestos .pbtn{ min-height: 0; }     /* permite crecer con los fr */

  /* Derecha: que el visor también se estire */
  #repuestos .products__viewer{
    align-self: stretch !important;
    display: flex;
  }
  #repuestos .products__viewer img{ height: 100%; object-fit: contain; }
}




/* “y mucho más…” — centrado en la COLUMNA 1 */
#repuestos .products__more{
  grid-column: 1;        /* ya no ocupa las dos columnas */
  grid-row: 3;           /* asumiendo filas: 1=título, 2=lista+visor, 3=“más” */
  justify-self: center;  /* centra horizontalmente dentro de la columna 1 */
  text-align: center;    /* centra el texto */
  margin: 12px 0 0;      /* sin desplazamiento lateral */
  font-weight: 800;
  letter-spacing: .2px;
  color: var(--c-frame);
}


/* Repuestos: responsive */
@media (max-width: 1100px){
  #repuestos .products__wrap{
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
  }
  #repuestos .products__viewer{
    grid-column:1; grid-row:2;
    height:auto; max-height: 68vh;
  }
  #repuestos .products__more{ grid-column:1; grid-row:3; text-align:center; }
}
@media (max-width:700px){
  #repuestos .products__list{ grid-template-columns:1fr }
  #repuestos .pbtn{ min-height:58px; font-size:16px; padding:12px 16px; }
}

/* ===== Modal de repuestos — solo en mobile ===== */
@media (max-width:900px){
  /* ocultamos el visor embebido en mobile */
  #repuestos .products__viewer{ display:none !important; }

  .prod-modal{
    position:fixed; inset:0; z-index:1200;
    display:grid; place-items:center;
    background:rgba(0,0,0,.75);
    opacity:0; pointer-events:none; transition:opacity .25s ease;
  }
  .prod-modal.is-open{ opacity:1; pointer-events:auto; }

  .prod-modal__dialog{
    position:relative; margin:0; padding:0;
    max-width:min(960px,94vw);
    max-height:min(86vh,100dvh - 64px);
    border:6px solid #4a0c0c;       /* marrón FerroParts */
    background:#fff; border-radius:10px; overflow:hidden;
    box-shadow:0 20px 60px rgba(0,0,0,.35);
  }
  .prod-modal__img{ width:100%; height:100%; object-fit:contain; background:#fff; }

  .prod-modal__close{
    position:absolute; top:6px; right:8px;
    width:38px; height:38px; border:0; border-radius:8px; cursor:pointer;
    background:#3b0f0f; color:#fff; font-size:28px; font-weight:900;
    display:flex; align-items:center; justify-content:center;
  }
}
body.prod-modal-open{ overflow:hidden; } /* bloquea scroll cuando está abierto */


/* ========== 07) Contact CTA + Marcas ===================================== */

.contact-cta{ background:#fff; margin:0 0 56px; }
.contact-cta__inner{
  max-width:var(--maxw); margin:0 auto; padding:24px 40px;
  background:var(--brand-brown); color:#fff;
  display:grid; grid-template-columns:160px 1fr 180px; align-items:center; justify-items:center;
  column-gap:24px; border-radius:0;
}
.contact-cta__icon{ width:128px; height:auto; justify-self:start; }
.contact-cta__title{
  margin:0; text-align:center; letter-spacing:.12em; font-weight:600;
  font-size:clamp(28px, 2.4vw + 14px, 44px);
}
.contact-cta__qr{ width:170px; height:auto; background:#fff; padding:10px; border-radius:0; justify-self:end; }

@media (max-width:1000px){
  .contact-cta__inner{ grid-template-columns:120px 1fr 150px; padding:20px 24px; }
  .contact-cta__icon{ width:100px; }
  .contact-cta__qr{ width:150px; }
  .contact-cta__title{ font-size:clamp(22px, 2vw + 12px, 36px); }
}
@media (max-width:680px){
  .contact-cta__inner{ grid-template-columns:1fr; row-gap:12px; }
  .contact-cta__icon{ justify-self:center; }
  .contact-cta__qr{ justify-self:center; }
}

/* Marcas */
.brands{ background:#fff; padding:24px 0 40px; margin-bottom:30px; }
.brands__wrap{
  max-width:var(--maxw); margin:0 auto; padding:0 18px;
  display:flex; justify-content:center; align-items:center; gap:160px;
}
.brands__wrap img{ height:110px; width:auto; object-fit:contain; }
@media (max-width:1000px){
  .brands__wrap{ gap:64px; }
  .brands__wrap img{ height:90px; }
}
@media (max-width:600px){
  .brands__wrap{ gap:32px; }
  .brands__wrap img{ height:64px; }
}


/* ========== 08) Footer ==================================================== */

#contacto-detalle.site-footer{
  background: var(--brand-cyan) !important;
  color: #fff;
}
#contacto-detalle .wrap{ max-width:var(--maxw); margin:0 auto; padding:28px 18px 22px; }
#contacto-detalle h2{
  margin:0 0 10px;
  font-family:"DINOT", system-ui, Arial, sans-serif;
  font-weight:900; letter-spacing:.06em; font-size:22px;
}
#contacto-detalle .hr{ height:1px; background:rgba(255,255,255,.45); margin:8px 0 18px; }

#contacto-detalle .footer-cols{
  display:grid; grid-template-columns:1.2fr .8fr; gap:28px;
}
#contacto-detalle .col--left{
  display:grid; grid-template-columns:307px 1fr; gap:28px; align-items:start;
}
#contacto-detalle .footer-logo{ width:220px; height:auto; }
#contacto-detalle .footer-info{ padding-top:6px; }
#contacto-detalle .footer-info .addr{ margin:0 0 14px; line-height:1.4; font-size:16px; }
#contacto-detalle .footer-info .mails a{ color:#fff; text-decoration:none; font-weight:700; }
#contacto-detalle .footer-info .mails a:hover{ text-decoration:underline; }
#contacto-detalle .footer-info .whatsapp{ display:flex; align-items:center; gap:10px; margin:10px 0 0; font-weight:800; font-size:22px; }
#contacto-detalle .wa-ico{ width:28px; height:28px; color:#fff; }

#contacto-detalle .col--right{
  border-left:1px solid rgba(255,255,255,.45);
  padding-left:28px;
  display:flex; align-items:flex-start; justify-content:center;
  max-width:100%;
}

/* Tarjeta ISO */
#contacto-detalle .iso-card{
  background:transparent; padding:0; border:0; box-shadow:none;
  display:inline-block; text-align:center;
}
#contacto-detalle .iso-card img{
  width:360px; max-width:100%; height:auto; display:block; margin:0 auto;
}
#contacto-detalle .iso-card figcaption{
  margin-top:10px; font-size:12px; letter-spacing:.04em; line-height:1.35;
  text-transform:uppercase; color:#fff; opacity:.95; font-weight:700;
}

#contacto-detalle .hr--bottom{ margin-top:22px; }
#contacto-detalle .copy{ margin:10px 0 0; font-size:14px; letter-spacing:.02em; opacity:.95; }

@media (max-width:1000px){
  #contacto-detalle .footer-cols{ grid-template-columns:1fr; }
  #contacto-detalle .col--left{ grid-template-columns:220px 1fr; gap:20px; }
  #contacto-detalle .footer-logo{ width:220px; }
  #contacto-detalle .col--right{
    border-left:0; padding-left:0;
    border-top:1px solid rgba(255,255,255,.45);
    margin-top:16px; padding-top:16px; text-align:center;
  }
  #contacto-detalle .iso-card img{ width:300px; }
}
@media (max-width:600px){
  #contacto-detalle .col--left{ grid-template-columns:1fr; }
  #contacto-detalle .footer-logo{ width:200px; margin:0 auto; }
  #contacto-detalle .footer-info{ text-align:center; }
  #contacto-detalle .footer-info .whatsapp{ justify-content:center; }
  #contacto-detalle .iso-card img{ width:260px; }
}
