/* =========================
   Nirvana Tienda (vanilla)
   Fuentes locales — sin CDN
   ========================= */

@font-face {
  font-family: "Cinzel";
  font-style: normal;
  font-weight: 400 900;
  font-display: swap;
  src: url("/assets/fonts/Cinzel-VariableFont_wght.3192c4e404.ttf") format("truetype");
}

:root{
  /* Base */
  --bg:#000;
  --surface: rgba(255,255,255,.03);
  --surface2: rgba(255,255,255,.05);
  --line: rgba(255,255,255,.10);
  --text:#eaeaea;
  --muted: rgba(255,255,255,.70);
  --muted2: rgba(255,255,255,.55);
  --accent: #f5f5f5;
  --accent-strong: #ffffff;
  --accent-muted: rgba(255,255,255,.22);

  /* Tipos */
  --heading: "Cinzel", serif;
  --body: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --elegant: Georgia, "Times New Roman", serif;

  /* Layout */
  --container: 1120px;
  --radius: 18px;
  --shadow: 0 18px 60px rgba(0,0,0,.55);
  --shadow2: 0 12px 40px rgba(0,0,0,.45);
  --nav-h: 76px;
  --promo-h: 34px;
  --t: .22s ease;
}

/* Light mode (opcional) */


*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: var(--body);
  background: var(--bg);
  color: var(--text);
  overflow-x:hidden;
  font-size: 17px;
  line-height: 1.55;
  color-scheme: dark;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

/* ayuda extra para controles nativos (select/options) */
html{ color-scheme: dark; }

img{ 
  display:block; 
  max-width:100%; 
  height: auto;
}
a{ color:inherit; text-decoration:none; }
button, input, select{ font:inherit; color:inherit; }
select, input{ -webkit-appearance:none; appearance:none; }

*:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.container{
  width: min(var(--container), calc(100% - 2.5rem));
  margin-inline:auto;
}

.skip{
  position:absolute; left:-9999px; top:auto;
  width:1px; height:1px; overflow:hidden;
}
.skip:focus{
  left:1rem; top:1rem; width:auto; height:auto;
  background: var(--surface2);
  border:1px solid var(--line);
  border-radius: 12px;
  padding:.75rem 1rem;
  z-index:9999;
}

/* ===== NAV ===== */
.nav{
  position:fixed;
  inset: 0 0 auto 0;
  display:flex;
  flex-direction:column;
  z-index: 60;
  background: rgba(0,0,0,.90);
  border-bottom:1px solid var(--line);
  backdrop-filter: blur(12px);
}

.promoBar{
  height: var(--promo-h);
  line-height: 1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 0 1rem;
  font-size: .95rem;
  color: rgba(255,255,255,.82);
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  white-space: nowrap !important;
  overflow: hidden;
  text-overflow: ellipsis;
}
.promoBar strong{ color: rgba(255,255,255,.95); }


.nav__inner{
  height: var(--nav-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
}

/* HERO ocupa toda la pantalla SIN mostrar la siguiente sección */
.hero{
  position: relative;
  min-height: 100svh;
  min-height: 100vh;
  display:flex;
  align-items:center;
  padding-top: calc(var(--nav-h) + var(--promo-h));
  overflow: hidden;
}

.brand{
  display:flex;
  align-items:center;
  gap:.75rem;
  letter-spacing: 2px;
  min-width: 190px;
}
.brand__logo{
  width: 42px;
  height: 42px;
  filter: drop-shadow(0 0 12px rgba(255,255,255,.22));
  transition: transform var(--t), filter var(--t);
}
.brand:hover .brand__logo{
  transform: scale(1.03);
  filter: drop-shadow(0 0 18px rgba(255,255,255,.35));
}
.brand__name{
  font-family: var(--heading);
  font-weight: 700;
  text-transform: uppercase;
  color: rgba(255,255,255,.92);
}
.brand__sub{
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: var(--muted2);
  margin-top: 2px;
}


.links{
  display:flex;
  align-items:center;
  gap: 1rem;
}
.links a{
  color: var(--muted);
  font-weight: 500;
  font-size: .95rem;
  padding: .4rem .6rem;
  border-radius: 10px;
  transition: background var(--t), color var(--t);
}
.links a:hover{
  background: var(--surface2);
  color: rgba(255,255,255,.95);
}


.actions{
  display:flex;
  align-items:center;
  gap: .6rem;
  flex: 0 0 auto;
  flex-wrap: nowrap;
}

.iconBtn{
  border: 1px solid var(--line);
  background: var(--surface2);
  padding: .5rem .7rem;
  border-radius: 12px;
  cursor:pointer;
  transition: transform var(--t), background var(--t);
}
.iconBtn:hover{ transform: translateY(-1px); background: color-mix(in srgb, var(--surface2) 75%, transparent); }

.cartBtn{
  display:flex;
  align-items:center;
  gap:.6rem;
  border: 1px solid var(--line);
  background: var(--surface2);
  padding: .5rem .75rem;
  border-radius: 999px;
  cursor:pointer;
  transition: transform var(--t), background var(--t);
}
.cartBtn:hover{ transform: translateY(-1px); background: color-mix(in srgb, var(--surface2) 75%, transparent); }

.badge{
  min-width: 24px;
  height: 24px;
  display:grid;
  place-items:center;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid var(--line);
  font-weight: 800;
  font-size: .9rem;
}

/* Botón hamburguesa */
.menuBtn{
  width: 48px;
  height: 48px;
  min-width: 48px;
  min-height: 48px;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 0;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: var(--surface2);
  cursor: pointer;
  transition: transform var(--t), background var(--t);
}
.menuBtn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.menuBtn:hover{ transform: translateY(-1px); background: color-mix(in srgb, var(--surface2) 75%, transparent); }
.menuBtn:active{ transform: translateY(0); }

.menuBtn__bar{
  display:block;
  width: 18px;
  height: 2px;
  background: rgba(255,255,255,.78);
  border-radius: 99px;
}


.hero__bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(1200px 700px at 20% 18%, rgba(255,255,255,.08), transparent 55%),
    radial-gradient(900px 600px at 80% 24%, rgba(255,255,255,.06), transparent 58%),
    linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.86)),
    url("/assets/2.6677cae42b.png") center/cover no-repeat;
  opacity: .26;
  filter: grayscale(100%) contrast(118%) saturate(110%);
}



.hero__inner{
  position:relative;
  z-index:1;
  text-align:center;
  padding: 1.8rem 0 4.8rem;
}

.hero__logo{
  width: 120px;
  margin: 0 auto 1.1rem;
  filter: drop-shadow(0 0 18px rgba(255,255,255,.18));
}

.hero h1{
  font-family: var(--heading);
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-size: clamp(2rem, 3.6vw, 3.25rem);
  margin: 0 0 .8rem;
}

.hero p{
  font-family: var(--elegant);
  color: rgba(255,255,255,.76);
  font-size: clamp(1.15rem, 1.55vw, 1.45rem);
  max-width: 62ch;
  margin: 0 auto 1.6rem;
  line-height: 1.65;
}


.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  padding: .9rem 1.2rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.05);
  cursor:pointer;
  font-weight: 650;
  font-size: .92rem;
  text-transform: uppercase;
  letter-spacing: .6px;
  transition: transform var(--t), background var(--t), color var(--t);
}
.btn:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.08);
}
.btn--primary{
  background: var(--accent);
  color: #111;
  border-color: transparent;
  box-shadow: 0 0 22px rgba(255,255,255,.10);
}
.btn--primary:hover{ background: var(--accent-strong); }
.btn--ghost{
  background: transparent;
}

.hero__meta{
  margin-top: 1.1rem;
  display:flex;
  justify-content:center;
  gap:.6rem;
  flex-wrap:wrap;
}
.pill{
  padding: .4rem .65rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.70);
  font-size: .9rem;
}

.scroll{
  position:absolute;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  display:grid;
  justify-items:center;
  gap: .35rem;
  font-size: .72rem;
  letter-spacing: 2px;
  color: var(--muted2);
  text-transform: uppercase;
}

.mouse{
  width: 22px; height: 36px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.35);
  position:relative;
}
.mouse::after{
  content:"";
  width: 3px; height: 7px;
  border-radius: 999px;
  background: rgba(255,255,255,.55);
  position:absolute;
  left:50%; top: 7px;
  transform: translateX(-50%);
  animation: wheel 1.4s infinite ease;
}
@keyframes wheel{
  0%{ opacity:.2; transform: translate(-50%, 0); }
  60%{ opacity:1; }
  100%{ opacity:.1; transform: translate(-50%, 12px); }
}

/* ===== FEATURES ===== */
.features{
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  padding: 3rem 0 1.6rem;
}
.features__grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 1rem;
}
.fcard{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1.2rem;
  box-shadow: var(--shadow2);
}
.ficon{
  width: 40px; height:40px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--surface2);
  display:grid;
  place-items:center;
  margin-bottom:.75rem;
  box-shadow: 0 0 22px rgba(255,255,255,.06);
  font-weight: 900;
}
.fcard h3{
  font-family: var(--heading);
  font-size: 1.05rem;
  margin: .2rem 0 .45rem;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.fcard p{
  margin:0;
  color: var(--muted);
  font-family: var(--elegant);
  font-size: 1.05rem;
  line-height: 1.6;
}

/* ===== KITS ===== */
.kits{
  padding: 3.5rem 0;
}
.sectionHead{
  text-align:center;
  margin-bottom: 1.6rem;
}
.sectionHead h2{
  font-family: var(--heading);
  text-transform: uppercase;
  letter-spacing: 2px;
  margin:0 0 .55rem;
  font-size: clamp(1.6rem, 2.4vw, 2.15rem);
}
.divider{
  width: 76px;
  height: 2px;
  background: rgba(255,255,255,.22);
  margin: 0 auto .75rem;
  border-radius: 99px;
}
.sectionHead p{
  margin: 0 auto;
  max-width: 70ch;
  color: var(--muted);
  font-family: var(--elegant);
  font-size: 1.12rem;
}

.toolbar{
  margin: 1.1rem 0 1.4rem;
  display:flex;
  gap:.75rem;
  flex-wrap: wrap;
  justify-content:center;
}
.field{
  display:flex;
  align-items:center;
  gap:.5rem;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 999px;
  padding: .55rem .75rem;
}
.field__icon{ color: var(--muted2); }
.field input, .field select{
  border:0;
  outline: none;
  background: transparent;
  min-width: 190px;
  font-size: .95rem;
}
.field select{
  cursor:pointer;
  color: var(--text);
  background: transparent;
  color-scheme: dark;
  appearance: auto;
  -webkit-appearance: auto;
}
.field select option{ background: #0b0b0b; color: var(--text); }
.field input::placeholder{ color: rgba(255,255,255,.55); }
.field select:focus, .field input:focus{ outline: none; }


.grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.1rem;
  align-items: stretch;
}

.card{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow2);
  display:flex;
  flex-direction:column;
  transition: transform var(--t), border-color var(--t);
}
.card:hover{
  transform: translateY(-4px);
  border-color: rgba(255,255,255,.18);
}

.badgeTop{
  position:absolute;
  top: 14px;
  left: 14px;
  background: var(--accent);
  color: #111;
  padding: .35rem .65rem;
  border-radius: 999px;
  font-weight: 900;
  font-size: .78rem;
  letter-spacing:.5px;
  text-transform: uppercase;
}

.card__media{
  position:relative;
  border-bottom: 1px solid var(--line);
  background: #0b0b0b;
  aspect-ratio: 1 / 1;
  overflow:hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.card__media img{
  width:100%;
  height:100%;
  object-fit: cover;
  object-position: center;
  transform: scale(1);
  transition: transform .4s ease;
  filter: contrast(105%) brightness(1.02);
  display: block;
}
.card:hover .card__media img{ transform: scale(1.05); }

.card__body{
  padding: 1.1rem 1.1rem 1.2rem;
  display:flex;
  flex-direction:column;
  gap:.55rem;
  flex:1;
}
.card__cat{
  font-size: .78rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted2);
}
.card__title{
  margin:0;
  font-family: var(--heading);
  letter-spacing: 1px;
  font-size: 1.15rem;
  text-transform: uppercase;
}
.card__desc{
  margin:0;
  color: var(--muted);
  font-family: var(--elegant);
  font-size: 1.12rem;
  line-height: 1.55;
  min-height: 3.1em;
}
.card__foot{
  margin-top:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: .8rem;
  padding-top: .4rem;
}
.price{
  font-weight: 900;
  letter-spacing: 1px;
  color: var(--accent);
}
.card__actions{
  display:flex;
  gap:.55rem;
}

.miniBtn{
  padding: .55rem .75rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.05);
  cursor:pointer;
  font-weight: 700;
  font-size: .88rem;
  transition: transform var(--t), background var(--t);
}
.miniBtn:hover{ transform: translateY(-1px); background: rgba(255,255,255,.08); }
.miniBtn--primary{
  background: rgba(255,255,255,.92);
  color: #111;
  border-color: transparent;
}

.empty{
  margin-top: 1.5rem;
  text-align:center;
  color: var(--muted);
  border: 1px dashed rgba(255,255,255,.14);
  border-radius: 16px;
  padding: 1.1rem;
}

/* ===== ABOUT ===== */
.about{
  padding: 3.2rem 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 92%, transparent);
}
.about__grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 1.2rem;
  align-items:start;
}
.panel{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1.2rem;
  box-shadow: var(--shadow2);
}
.panel h3{
  margin:0 0 .5rem;
  font-family: var(--heading);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.panel p{
  margin:0 0 .9rem;
  color: var(--muted);
  font-family: var(--elegant);
  font-size: 1.12rem;
  line-height: 1.65;
}
.note{
  margin-top: .75rem;
  font-size: .95rem;
  color: var(--muted2);
}
.socialRow{
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
}
.social{
  padding: .45rem .7rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: var(--muted);
}
.social:hover{ background: rgba(255,255,255,.08); color: rgba(255,255,255,.90); }

.list{
  list-style:none;
  padding:0;
  margin:.3rem 0 0;
  display:grid;
  gap:.55rem;
}
.list li{
  padding:.65rem .8rem;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface2);
  display:flex;
  justify-content:space-between;
  gap:.75rem;
}
.list__k{ color: var(--muted2); }
.list__v{ color: rgba(255,255,255,.92); font-weight: 700; }

/* ===== FOOTER ===== */
.footer{
  padding: 2rem 0;
}
.footer__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
  flex-wrap:wrap;
  border-top: 1px solid var(--line);
  padding-top: 1.2rem;
  color: var(--muted2);
}
.footer__left{
  display:flex;
  align-items:center;
  gap:.8rem;
}
.footer__logo{
  width: 42px;
  height: 42px;
  filter: drop-shadow(0 0 10px rgba(255,255,255,.18));
}
.footer__title{
  font-family: var(--heading);
  text-transform: uppercase;
  letter-spacing: 1px;
  color: rgba(255,255,255,.88);
}
.footer__right{
  display:flex;
  gap: 1rem;
}
.footer__right a:hover{ color: rgba(255,255,255,.95); }

/* ===== BACKDROP ===== */
.backdrop{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.65);
  z-index: 85;
  transition: opacity .2s ease;
}
.backdrop[hidden]{ display: none !important; }

/* ===== CART ===== */
.cart{
  position:fixed;
  top:0;
  right:0;
  width: min(420px, 92vw);
  height: 100%;
  background: rgba(0,0,0,.96);
  border-left: 1px solid var(--line);
  box-shadow: var(--shadow);
  transform: translateX(110%);
  transition: transform .22s ease;
  z-index: 90;
  display:flex;
  flex-direction:column;
}

.cart.isOpen{ transform: translateX(0); }

.cart__head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 1rem;
  border-bottom: 1px solid var(--line);
}
.cart__head h3{
  margin:0;
  font-family: var(--heading);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 1.05rem;
}
.cart__body{
  padding: 1rem;
  overflow:auto;
  flex:1;
  display:grid;
  gap: .8rem;
}
.citem{
  display:grid;
  grid-template-columns: 64px 1fr;
  gap:.8rem;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: .7rem;
  background: rgba(255,255,255,.03);
}
.citem img{
  width: 64px;
  height: 64px;
  object-fit: cover;
  object-position: center;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #0b0b0b;
  display: block;
}

.citem h4{
  margin:0;
  font-size: .95rem;
  font-family: var(--heading);
  letter-spacing: .5px;
  text-transform: uppercase;
}
.citem small{
  color: var(--muted);
  font-family: var(--elegant);
}
.crow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.6rem;
  margin-top:.5rem;
}
.qty{
  display:flex;
  align-items:center;
  gap:.35rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: .18rem .35rem;
  background: rgba(255,255,255,.03);
}
.qty button{
  width: 30px;
  height: 30px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  cursor:pointer;
}
.qty span{
  min-width: 24px;
  text-align:center;
  font-weight: 900;
}

.cart__foot{
  padding: 1rem;
  border-top: 1px solid var(--line);
  background: rgba(255,255,255,.03);
}
.totals{
  display:grid;
  gap:.35rem;
  margin-bottom: .8rem;
}
.totals div{
  display:flex;
  justify-content:space-between;
}
.tiny{
  margin: .75rem 0 0;
  font-size: .82rem;
  color: var(--muted2);
}

/* ===== MODAL ===== */
.modal{
  width: min(920px, calc(100% - 2rem));
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(0,0,0,.96);
  color: var(--text);
  box-shadow: var(--shadow);
  padding: 0;
}

.modal::backdrop{ background: rgba(0,0,0,.70); }
.modal__inner{
  margin:0;
  padding:0;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.modal__close{
  position:absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.06);
  cursor:pointer;
}
.modal__media{
  background: #0b0b0b;
  border-right: 1px solid var(--line);
  aspect-ratio: 1/1;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.modal__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  filter: contrast(105%) brightness(1.02);
}
.modal__content{
  padding: 1.2rem 1.2rem 1.25rem;
}
.modal__cat{
  font-size:.78rem;
  letter-spacing:2px;
  text-transform: uppercase;
  color: var(--muted2);
}
.modal__title{
  margin:.35rem 0 .5rem;
  font-family: var(--heading);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.modal__desc{
  margin:0 0 1rem;
  color: var(--muted);
  font-family: var(--elegant);
  font-size: 1.12rem;
  line-height: 1.65;
}
.modal__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: .8rem;
  flex-wrap: wrap;
}
.modal__price{
  font-weight: 900;
  letter-spacing: 1px;
  font-size: 1.1rem;
}

.muted{ color: var(--muted2); }

/* ===== MOBILE MENU ===== */
.mobileMenu{
  position: fixed;
  inset: 0 auto 0 0;
  width: min(360px, 92vw);
  height: 100%;
  background: rgba(0,0,0,.98);
  border-right: 1px solid var(--line);
  box-shadow: var(--shadow);
  transform: translateX(-100%);
  transition: transform .25s ease;
  z-index: 95;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  visibility: visible;
}
.mobileMenu.isOpen,
.mobileMenu[aria-hidden="false"]{
  transform: translateX(0);
}

.mobileMenu__title{
  font-family: var(--heading);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.mobileMenu__links{
  display:grid;
  gap:.35rem;
  padding: .9rem 0;
}
.mobileMenu__links a{
  padding: .7rem .75rem;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
  color: var(--muted);
}
.mobileMenu__links a:hover{ background: var(--surface2); color: rgba(255,255,255,.92); }
.mobileMenu__social{
  border-top: 1px solid var(--line);
  padding-top: .9rem;
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
}
.mobileMenu__social a{
  padding: .45rem .7rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--muted);
}

/* ===== RESPONSIVE ===== */
@media (max-width: 980px){
  .links{ display:none; }
  .menuBtn{ display: flex; }
  .features__grid{ grid-template-columns: 1fr; }
  .grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .about__grid{ grid-template-columns: 1fr; }
  .modal__inner{ grid-template-columns: 1fr; }
  .modal__media{ border-right:0; border-bottom:1px solid var(--line); }
}
@media (max-width: 560px){
  .container{ width: min(var(--container), calc(100% - 1.6rem)); }
  .brand__name{ display:none; }
  .grid{ grid-template-columns: 1fr; }
  .field input, .field select{ min-width: 160px; }
  .promoBar{ font-size: .85rem; }
  .cartBtn{ padding: .5rem .65rem; }
  .cartBtn > span:first-child{ display:none; }
}


.btn--small{ padding: .6rem .9rem; font-size: .9rem; }

/* Producto detalle (SEO page) */
.productDetail{ display:grid; grid-template-columns: 1fr 1fr; gap:0; max-width:900px; margin:0 auto; border:1px solid var(--line); border-radius:18px; overflow:hidden; background:var(--surface); }
.productDetail__media{ background:#0b0b0b; aspect-ratio:1; position:relative; }
.productDetail__media img{ width:100%; height:100%; object-fit:cover; display:block; }
.productDetail__badge{ position:absolute; top:14px; left:14px; background:var(--accent); color:#111; padding:.35rem .65rem; border-radius:999px; font-weight:900; font-size:.78rem; }
.productDetail__content{ padding:1.2rem; display:flex; flex-direction:column; justify-content:center; }
@media (max-width: 720px){ .productDetail{ grid-template-columns:1fr; } }
