/* index.css - estilos especificos de index.html */

/* Accesibilidad */
.skip-link{
  position:absolute; left:-999px; top:auto;
  width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left:12px; top:12px; width:auto; height:auto;
  padding:10px 12px;
  background:#fff; color:#0b0c0f;
  border:1px solid rgba(0,0,0,.12);
  border-radius:12px;
  z-index:9999;
  box-shadow:0 16px 40px rgba(0,0,0,.12);
}

/* ====== Pagos ====== */
.payments{ padding: 28px 0 0; }
.payments .payments-card{
  overflow:hidden;
  text-align:center;
}
.payments-title{
  margin: 0 0 6px;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted, #6b7280);
}

.payments .pay-grid{
  list-style:none;
  margin:0;
  padding: 0;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap: 10px;
}

.payments .pay-badge{
  display:flex;
  align-items:center;
  justify-content:center;
  width: 56px;
  height: 36px;
  border-radius: 6px;
  border: 1px solid rgba(0,0,0,.1);
  background: #fff;
  padding: 4px;
  transition: transform .12s ease, box-shadow .14s ease;
}
.payments .pay-badge:hover{
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}
.payments .pay-badge svg,
.payments .pay-badge img{
  display:block;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
}

.site-footer{
  padding: 28px 0 22px;
  color: rgba(17,24,39,.66);
  border-top: 1px solid rgba(0,0,0,.06);
  margin-top: 18px;
}
.footer-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px 18px;
  text-align: left;
  margin-bottom: 20px;
}
.footer-col{
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.footer-heading{
  margin: 0 0 4px;
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(17,24,39,.42);
}
.footer-col a,
.footer-col span{
  font-size: .88rem;
  font-weight: 700;
  line-height: 1.5;
}
.site-footer a{
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color .14s, border-color .14s;
}
.site-footer a:hover{
  border-bottom-color: rgba(225,6,0,.35);
  color:#0b0c0f;
}
.footer-socials{
  display: flex;
  gap: 14px;
  font-size: 1.2rem;
}
.footer-socials a{
  border-bottom: none !important;
  opacity: .6;
  transition: opacity .14s, transform .12s;
}
.footer-socials a:hover{
  opacity: 1;
  transform: translateY(-1px);
}
.footer-bottom{
  text-align: center;
  padding-top: 16px;
  border-top: 1px solid rgba(0,0,0,.06);
  font-size: .82rem;
  color: rgba(17,24,39,.48);
}
@media (max-width: 640px){
  .footer-grid{
    grid-template-columns: repeat(2, 1fr);
    gap: 20px 16px;
  }
}

.deferred-section{
  content-visibility:auto;
  contain-intrinsic-size: 1px 720px;
}

.legal-card-link-wrap{
  width:100%;
}
.legal-docs-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
  align-items:stretch;
}
.legal-card-link{
  display:block;
  padding:18px 20px;
  border:1px solid rgba(0,0,0,.1);
  border-radius:18px;
  background:#fff;
  color:#0b0c0f;
  text-decoration:none;
  box-shadow:0 12px 28px rgba(15,23,42,.04);
}
.legal-card-link:hover{
  border-color:#d7dde8;
  box-shadow:0 16px 36px rgba(15,23,42,.08);
}
.legal-card-link strong{
  display:block;
  margin-bottom:8px;
  font-size:1.05rem;
}
.legal-card-link span{
  display:block;
  line-height:1.6;
  color:#1f2937;
}
.legal-card-eyebrow{
  margin-bottom:8px;
  font-size:.74rem;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(17,24,39,.55);
}
@media (max-width: 760px){
  .legal-docs-grid{
    grid-template-columns:1fr;
  }
}

.dgt-tooltip{
  position:relative;
  display:block;
  margin-left:auto;
  flex-shrink:0;
  line-height:0;
}

.dgt-tooltip-toggle{
  appearance:none;
  border:0;
  background:transparent;
  padding:0;
  margin:0;
  display:block;
  cursor:pointer;
  line-height:0;
  margin-left:auto;
}

.dgt-tooltip-toggle .dgt-badge{
  display:block;
}

.dgt-tooltip-toggle:focus-visible{
  outline:2px solid rgba(225,6,0,.45);
  outline-offset:4px;
  border-radius:12px;
}

.dgt-floating-tooltip{
  --dgt-arrow-left: 24px;
  position:fixed;
  left:0;
  top:0;
  width:max-content;
  max-width:min(280px, calc(100vw - 20px));
  padding:11px 12px;
  border-radius:14px;
  border:1px solid rgba(17,24,39,.12);
  background:rgba(255,255,255,.98);
  color:rgba(17,24,39,.82);
  box-shadow:0 18px 38px rgba(15,23,42,.16);
  font-size:.84rem;
  line-height:1.45;
  font-weight:700;
  opacity:0;
  visibility:hidden;
  transform:translateY(-4px);
  transition:opacity 150ms ease, transform 150ms ease, visibility 150ms ease;
  z-index:200;
  pointer-events:none;
}

.dgt-floating-tooltip::before{
  content:"";
  position:absolute;
  left:var(--dgt-arrow-left);
  top:-8px;
  width:14px;
  height:14px;
  background:rgba(255,255,255,.98);
  border-top:1px solid rgba(17,24,39,.12);
  border-left:1px solid rgba(17,24,39,.12);
  transform:translateX(-50%) rotate(45deg);
}

.dgt-floating-tooltip.is-visible{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}

.dgt-floating-tooltip.is-above{
  transform:translateY(0);
}

.dgt-floating-tooltip.is-above::before{
  top:auto;
  bottom:-8px;
  transform:translateX(-50%) rotate(225deg);
}

@media (max-width:640px){
  .dgt-floating-tooltip{
    max-width:min(220px, calc(100vw - 20px));
    font-size:.8rem;
    line-height:1.42;
    padding:10px 11px;
  }

  .dgt-floating-tooltip::before{
    left:var(--dgt-arrow-left);
  }
}

/* ===== HERO BANNER ===== */
.hero-banner{
  padding: 14px 0 4px;
  --banner-h-desktop: 240px;
  --banner-h-mobile: 118px;
}

.hero-banner .hero-img{
  display:block;
  border-radius:22px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(17,24,39,.08);
  box-shadow:0 16px 40px rgba(15,23,42,.07);
  text-decoration:none;
}

.hero-banner .hero-img img{
  width:100%;
  height:var(--banner-h-desktop);
  object-fit:cover;
  object-position:center;
  display:block;
}

@media (max-width: 640px){
  .hero-banner .hero-img{
    border-radius:18px;
  }

  .hero-banner .hero-img img{
    height:var(--banner-h-mobile);
    object-fit:contain;
    object-position:center;
    background:#fff;
  }
}

/* ===== HOME CATEGORY NAV ===== */
.home-category-strip{
  padding: 12px 0 6px;
}

.home-category-shell{
  display:grid;
  gap:12px;
}

.home-category-title{
  margin:0;
  font-size:.78rem;
  font-weight:900;
  letter-spacing:.09em;
  text-transform:uppercase;
  color:rgba(17,24,39,.54);
}

.home-category-nav{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:10px;
  width:100%;
}

.home-category-chip{
  appearance:none;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:48px;
  padding:11px 14px;
  border:1px solid rgb(17 24 39 / 0%);
  border-radius:10px;
  background:linear-gradient(180deg, rgb(237 237 237 / 98%), rgb(239 239 239 / 96%));
  color:rgb(17 24 39 / 80%);
  font-size:.94rem;
  font-weight:800;
  line-height:1.2;
  text-align:center;
  cursor:pointer;
  box-shadow:0 6px 14px rgba(15,23,42,.03);
  touch-action:manipulation;
  transition:border-color .16s ease, color .16s ease, box-shadow .16s ease, transform .12s ease;
}

.home-category-chip i{
  font-size:1rem;
  opacity:.8;
  flex:0 0 auto;
}

.home-category-chip span{
  display:block;
}

.chip-count{
  font-size:.82rem;
  font-weight:800;
  color:rgba(17,24,39,.44);
}
.chip-count::before{ content:"("; }
.chip-count::after{ content:")"; }
.home-category-chip.is-active .chip-count{
  color:rgba(17,24,39,.56);
}

.home-category-chip:hover{ 
  border-color:rgba(17,24,39,.18);
  color:#0f172a;
  transform:translateY(-1px);
}

.home-category-chip.is-active{
  background:#ffffff00;
  color:#0b0c0f;
  border-color:rgba(17, 24, 39, 0);
  box-shadow:inset 0 -2px 0 rgba(17,24,39,.88), 0 8px 18px rgba(15,23,42,.04);
}

.home-category-chip.is-active i{
  opacity:1;
}

.catalog-empty-state{
  margin-top:12px;
  margin-bottom:8px;
  padding:18px 16px;
  border:1px solid rgba(17,24,39,.07);
  border-radius:16px;
  background:rgba(255,255,255,.92);
  box-shadow:0 8px 18px rgba(15,23,42,.03);
  text-align:center;
}

.catalog-empty-state h2{
  margin:0 0 8px;
  font-family:'Russo One', sans-serif;
  font-size:clamp(.98rem, .92rem + .4vw, 1.16rem);
  letter-spacing:.03em;
  text-transform:uppercase;
}

.catalog-empty-state p{
  margin:0;
  color:rgba(17,24,39,.70);
  line-height:1.62;
}

@media (max-width: 900px){
  .home-category-nav{
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 640px){
  .home-category-strip{
    padding: 10px 0 4px;
  }

  .home-category-title{
    font-size:.7rem;
  }

  .home-category-nav{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:10px;
  }

  .home-category-chip{
    min-height:56px;
    padding:12px 10px;
    font-size:.96rem;
    font-weight:800;
    white-space:normal;
    gap:9px;
  }

  .home-category-chip[data-home-category="accessories"]{
    grid-column:1 / -1;
  }

  .home-category-chip i{
    font-size:1.04rem;
  }
}

/* ===== SEO Intro ===== */
.seo-intro{
  position: relative;
  overflow: hidden;
  margin-top: 18px;
  margin-bottom: 14px;
  padding: 24px 24px 22px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(249,250,251,.94));
  box-shadow: 0 14px 34px rgba(0,0,0,.07);
  text-align: center;
}

.seo-intro::before{
  content: "";
  display: block;
  width: 72px;
  height: 2px;
  margin: 0 auto 12px;
  border-radius: 999px;
  background: rgba(17,24,39,.18);
}

.seo-intro h2{
  margin: 0 0 12px;
  font-family: 'Russo One', sans-serif;
  text-transform: uppercase;
  font-size: clamp(1.12rem, .9rem + .95vw, 1.55rem);
  letter-spacing: .055em;
  line-height: 1.25;
  color: #0b0c0f;
}

.seo-intro p{
  margin: 0;
  max-width: 760px;
  margin-inline: auto;
  color: rgba(17,24,39,.74);
  font-size: clamp(.94rem, .9rem + .18vw, 1rem);
  line-height: 1.75;
}

.seo-intro p + p{
  margin-top: 10px;
}

.seo-intro a{
  color: inherit;
  text-decoration: none;
  font-weight: 800;
  border-bottom: 1px solid rgba(0,0,0,.18);
}

.seo-intro a:hover{
  border-bottom-color: rgba(0,0,0,.40);
}

@media (max-width: 640px){
  .seo-intro{
    margin-top: 14px;
    padding: 16px 14px;
    border-radius: 16px;
  }

  .seo-intro::before{
    width: 56px;
    margin-bottom: 10px;
  }
}
