:root{
  --bg:#0b1220;
  --card:#0f1b2f;
  --text:#e5e7eb;
  --muted:#a8b3c7;
  --line:rgba(255,255,255,.08);
  --accent:#22c55e;
  --accent2:#16a34a;
  --radius:18px;
  --shadow:0 18px 55px rgba(0,0,0,.45);
}

*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,system-ui,Segoe UI,sans-serif}
body{background:radial-gradient(1000px 600px at 20% 0%, rgba(34,197,94,.15), transparent 55%), var(--bg); color:var(--text)}
a{color:inherit;text-decoration:none}
.container{max-width:1100px;margin:0 auto;padding:18px}

.hero{padding:42px;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(145deg, rgba(15,27,47,.92), rgba(11,18,32,.92));box-shadow:var(--shadow)}
.hero h1{font-size:40px;letter-spacing:.5px}
.hero p{color:var(--muted);margin:10px 0 18px}

.btn{display:inline-block;padding:10px 14px;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#02100a;border:0;cursor:pointer;font-weight:700}
.btn.secondary{background:transparent;color:var(--text);border:1px solid var(--line)}
.filters{display:flex;gap:10px;align-items:center;margin:14px 0;flex-wrap:wrap}
input,select{width:100%;max-width:340px;padding:10px 12px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.card{border:1px solid var(--line);border-radius:var(--radius);background:rgba(15,27,47,.75);padding:14px;box-shadow:var(--shadow)}
.card img{width:100%;height:160px;object-fit:cover;border-radius:14px;border:1px solid var(--line)}
.price{color:var(--muted);margin:8px 0 10px}

.cart{border:1px solid var(--line);border-radius:var(--radius);padding:14px;background:rgba(15,27,47,.55)}
.row{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}
.row.total{border-bottom:0}

.checkout{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.box{border:1px solid var(--line);border-radius:var(--radius);padding:14px;background:rgba(15,27,47,.55)}
.flash{margin:12px auto;max-width:1100px;border-radius:14px;padding:10px 12px;border:1px solid var(--line)}
.flash.ok{background:rgba(34,197,94,.14)}
.flash.error{background:rgba(239,68,68,.14)}

@media (max-width:900px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .checkout{grid-template-columns:1fr}
}
@media (max-width:520px){
  .grid{grid-template-columns:1fr}
}

/* ===== Admin polish + responsive ===== */
.admin-toolbar{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0 18px}
.grid-cards{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:14px;
}
.card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.card-thumb{height:150px;background:rgba(0,0,0,.2)}
.card-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.card-body{padding:12px}
.card-title{font-weight:800;letter-spacing:.2px;margin-bottom:6px}
.card-meta{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.75);font-size:14px}
.card-meta .dot{opacity:.4}
.card-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.card-actions form{margin:0}

.thumb-row{display:flex;gap:10px;align-items:center}
.thumb{width:64px;height:64px;border-radius:12px;object-fit:cover;border:1px solid rgba(255,255,255,.12)}
.muted{opacity:.7;font-size:14px}

.form-grid{display:grid;gap:12px}
.form-row label{display:block;margin-bottom:6px;opacity:.85}
.form-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}

/* botón danger si no existe */
.btn.danger{background:#b91c1c;color:#fff;border:none}
.btn.danger:hover{filter:brightness(1.1)}

/* Responsive tweaks */
@media (max-width: 520px){
  .card-thumb{height:170px}
  .container{padding-left:14px;padding-right:14px}
  .card-actions .btn{width:100%}
  .card-actions form{width:100%}
  .card-actions form .btn{width:100%}
}


.table-wrap{overflow:auto}
.table th, .table td{padding:10px 10px; vertical-align:middle}
.table thead th{opacity:.85; font-size:14px}
.row-actions{display:flex; gap:10px; flex-wrap:wrap}
.thumb{width:56px;height:56px;border-radius:12px;object-fit:cover;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.25)}
.muted{opacity:.7}
.btn.danger{background:#b91c1c;color:#fff;border:none}
.btn.danger:hover{filter:brightness(1.1)}

/* Mobile: la tabla scrollea horizontal */
@media (max-width: 720px){
  .table{min-width:760px}
}

/* =========================
   RESILIENCIA - SHOP UI
   ========================= */
.shop{padding:10px 0}
.shop-head{display:flex;gap:14px;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;margin-bottom:14px}
.shop-title{margin:0;font-size:26px;letter-spacing:.2px}
.shop-sub{opacity:.8;font-size:13px;margin-top:4px}

.filters{width:100%}
.filters-row{display:grid;grid-template-columns:1.2fr .8fr .7fr auto;gap:10px;align-items:end}
.filters .f label{display:block;font-size:12px;opacity:.8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.filters input,.filters select{
  width:100%;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);
  background:#0b0d12;color:#fff
}
.filters input:focus,.filters select:focus{outline:none;border-color:rgba(31,111,235,.7);box-shadow:0 0 0 3px rgba(31,111,235,.18)}
.f-actions{display:flex;gap:10px}
.btn-site{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:#1f6feb;color:#fff;text-decoration:none;cursor:pointer;
  font-weight:800
}
.btn-site:hover{filter:brightness(1.06)}
.btn-site.ghost{background:transparent}
.btn-site.disabled{opacity:.55;cursor:not-allowed;background:#141824}

.grid{display:grid;grid-template-columns:repeat(4, minmax(0,1fr));gap:12px}
.card-prod{
  background:#0f1115;border:1px solid rgba(255,255,255,.08);border-radius:16px;
  overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,.20);
  display:flex;flex-direction:column;min-height:100%
}
.card-prod.is-out{opacity:.92}
/* =========================
   CARD IMAGENES UNIFORMES
   ========================= */

/* contenedor con proporción fija */
.card-media{
  position:relative;
  width:100%;
  aspect-ratio: 4 / 5;   /* 👈 CUADRADO PERFECTO */
  overflow:hidden;
  background:#0b0d12;
  border-bottom:1px solid rgba(255,255,255,.06);
}

/* imagen recortada prolija */
.card-media img{
  width:100%;
  height:100%;
  object-fit:cover;      /* 👈 magia */
  object-position:center;
  display:block;
}

.noimg{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-weight:900;letter-spacing:.12em;opacity:.6
}
.noimg.big{min-height:320px}
.badge-stock{
  position:absolute;top:10px;left:10px;
  padding:7px 10px;border-radius:999px;font-size:12px;font-weight:900;
  border:1px solid rgba(255,255,255,.14);backdrop-filter: blur(6px);
}
.badge-stock.in{background:rgba(34,197,94,.16);border-color:rgba(34,197,94,.35)}
.badge-stock.out{background:rgba(239,68,68,.16);border-color:rgba(239,68,68,.35)}
.card-body{padding:12px;display:flex;flex-direction:column;gap:8px;flex:1}
.card-name{color:#fff;text-decoration:none;font-weight:900;font-size:15px;line-height:1.2}
.card-name:hover{text-decoration:underline}
.card-desc{opacity:.78;font-size:13px;min-height:34px}
.card-bottom{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto}
.price{font-weight:900;font-size:16px}

.inline{margin:0}

.pager{display:flex;align-items:center;justify-content:center;gap:8px;margin:18px 0 4px}
.pg{
  width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:12px;border:1px solid rgba(255,255,255,.12);
  text-decoration:none;color:#fff;background:rgba(255,255,255,.04);font-weight:900
}
.pg:hover{filter:brightness(1.06)}
.pg.active{background:rgba(31,111,235,.22);border-color:rgba(31,111,235,.55)}
.pg.disabled{opacity:.45;pointer-events:none}
.dots{opacity:.6}

.empty{
  grid-column:1/-1;
  padding:18px;border-radius:16px;
  background:#0f1115;border:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;gap:8px;align-items:flex-start
}
.empty-title{font-weight:900;font-size:18px}
.empty-sub{opacity:.8}

/* Detail */
.detail{padding:10px 0}
.backlink{display:inline-block;margin-bottom:10px;text-decoration:none;color:#fff;opacity:.85}
.backlink:hover{opacity:1;text-decoration:underline}
.detail-card{
  display:grid;grid-template-columns: 1fr 1fr;gap:14px;
  background:#0f1115;border:1px solid rgba(255,255,255,.08);
  border-radius:18px;overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,.25)
}
.detail-media{position:relative;background:#0b0d12;min-height:320px}
.detail-media img{width:100%;height:100%;object-fit:cover;display:block;min-height:320px}
.detail-body{padding:14px;display:flex;flex-direction:column;gap:10px}
.detail-title{margin:0;font-size:24px}
.detail-meta{display:flex;gap:8px;flex-wrap:wrap}
.chip{
  padding:7px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);
  font-size:12px;opacity:.9
}
.detail-price{font-size:22px;font-weight:900}
.detail-desc{opacity:.85;line-height:1.45}
.buybox{margin-top:6px}
.buyform{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.qty{display:flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:6px;background:#0b0d12}
.qty input{
  width:70px;text-align:center;border:none;outline:none;background:transparent;color:#fff;font-weight:900
}
.qbtn{
  width:38px;height:38px;border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);color:#fff;font-weight:900;cursor:pointer
}
.qbtn:hover{filter:brightness(1.06)}
.help-mini{opacity:.75;font-size:12px;margin-top:6px}
.detail-note{
  margin-top:auto;
  padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.10);
  background:rgba(31,111,235,.08);opacity:.95
}

/* Responsive */
@media (max-width: 1100px){ .grid{grid-template-columns:repeat(3,minmax(0,1fr))} }
@media (max-width: 860px){
  .filters-row{grid-template-columns:1fr 1fr; }
  .f-actions{grid-column:1/-1; justify-content:flex-start}
  .grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .detail-card{grid-template-columns:1fr}
}
@media (max-width: 520px){
  .grid{grid-template-columns:1fr}
  .shop-title{font-size:22px}
}


/* =========================
   HOME LANDING (Resiliencia)
   ========================= */

.home-hero{
  padding: 26px 0 10px;
}
.home-hero__inner{
  display:grid;
  grid-template-columns: 1.25fr .9fr;
  gap: 18px;
  align-items: start;
}
@media (max-width: 980px){
  .home-hero__inner{grid-template-columns:1fr}
}

.home-kicker{opacity:.9; font-weight:800; letter-spacing:.02em}
.home-title{font-size:44px; line-height:1.05; margin:10px 0 8px; font-weight:900}
.home-sub{opacity:.88; max-width: 60ch}

@media (max-width: 520px){
  .home-title{font-size:34px}
}

.home-search{
  display:grid;
  grid-template-columns: 1fr 180px 140px;
  gap: 10px;
  margin-top: 16px;
}
@media (max-width: 720px){
  .home-search{grid-template-columns: 1fr; }
}

.home-search__input,
.home-search__select{
  width:100%;
  padding: 12px 12px;
  border-radius: 12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  color:#fff;
}
.home-search__btn{
  border-radius: 12px;
  border:1px solid rgba(31,111,235,.6);
  background: #1f6feb;
  color:#fff;
  font-weight:900;
  cursor:pointer;
}
.home-search__btn:hover{filter:brightness(1.08)}

.home-cta{display:flex; gap:10px; flex-wrap:wrap; margin-top: 14px}
.home-badges{display:flex; gap:10px; flex-wrap:wrap; margin-top: 14px}
.pill{
  padding: 8px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  font-size: 13px;
  opacity: .95;
}

.hero-card{
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.28);
  border-radius: 18px;
  padding: 14px;
  box-shadow: 0 20px 70px rgba(0,0,0,.35);
}
.hero-card__title{font-weight:900; margin-bottom: 10px; opacity:.95}

.hero-mini-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.hero-mini{
  display:grid;
  grid-template-columns: 70px 1fr;
  gap: 10px;
  padding: 10px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  text-decoration:none;
  color:#fff;
}
.hero-mini:hover{filter:brightness(1.06)}
.hero-mini__img{
  width:70px;
  aspect-ratio: 1 / 1;
  overflow:hidden;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.12);
  background:#0b0d12;
}
.hero-mini__img img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
.hero-mini__name{font-weight:900; line-height:1.1}
.hero-mini__stock{font-size:12px; opacity:.85; margin-top: 6px}
.hero-mini__stock.ok{color:#39d98a}
.hero-mini__stock.bad{color:#ff6b6b}

.home-section{padding: 18px 0}
.home-section__head{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.home-section__head h2{margin:0; font-size: 22px}
.link{color:#9ec5ff; text-decoration:none; opacity:.95}
.link:hover{text-decoration:underline}

.empty{
  padding: 14px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  opacity:.9;
}

.cat-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width: 980px){ .cat-grid{grid-template-columns: repeat(2, 1fr)} }
@media (max-width: 520px){ .cat-grid{grid-template-columns: 1fr} }

.cat-card{
  padding: 14px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  text-decoration:none;
  color:#fff;
}
.cat-card:hover{filter:brightness(1.06)}
.cat-card__icon{font-size: 22px}
.cat-card__name{font-weight:900; margin-top: 6px}
.cat-card__hint{opacity:.8; margin-top: 6px; font-size: 13px}

.prod-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width: 1100px){ .prod-grid{grid-template-columns: repeat(3, 1fr)} }
@media (max-width: 780px){ .prod-grid{grid-template-columns: repeat(2, 1fr)} }
/* 👇 OJO: acá antes lo tenías en 1fr. Lo dejamos en 2 para mobile */
@media (max-width: 520px){ .prod-grid{grid-template-columns: repeat(2, minmax(0,1fr)); gap:10px;} }
/* si querés ultra chico a 1 columna */
@media (max-width: 360px){ .prod-grid{grid-template-columns: 1fr;} }

.prod-card{
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.25);
  overflow:hidden;
  text-decoration:none;
  color:#fff;
}
.prod-card:hover{filter:brightness(1.06)}

.prod-media{
  position:relative;
  width:100%;
  aspect-ratio: 1 / 1; /* ✅ todas las imágenes iguales */
  background:#0b0d12;
  overflow:hidden;
}
.prod-media img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.stock-badge{
  position:absolute;
  top:10px;
  left:10px;
  padding: 8px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.25);
  backdrop-filter: blur(6px);
}
.stock-badge.ok{color:#39d98a; border-color: rgba(57,217,138,.35)}
.stock-badge.bad{color:#ff6b6b; border-color: rgba(255,107,107,.35)}

.prod-body{padding: 12px}
.prod-name{font-weight:900; font-size: 15px; line-height:1.2; min-height: 2.4em}
.prod-foot{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 10px;
}
.prod-price{font-weight: 900; opacity:.95}
.prod-cta{
  padding: 10px 12px;
  border-radius: 12px;
  border:1px solid rgba(31,111,235,.6);
  background:#1f6feb;
  font-weight:900;
}

.noimg{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%;
  font-weight: 900;
  opacity: .55;
  letter-spacing:.14em;
}
.noimg.big{font-size: 14px}


/* =========================
   PDP (Detalle de planta)
   ========================= */
.pdp{padding:18px 0 40px}
.pdp-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.pdp-back{color:#9ec5ff;text-decoration:none;opacity:.95}
.pdp-back:hover{text-decoration:underline}
.pdp-crumb{display:flex;gap:8px;align-items:center;opacity:.9}

.pdp-grid{
  display:grid;
  grid-template-columns: 1fr 1.05fr;
  gap: 14px;
}
@media (max-width: 980px){
  .pdp-grid{grid-template-columns:1fr}
}

.pdp-media{min-width:0}
.pdp-mainimg{
  position:relative;
  border-radius:18px;
  border:1px solid rgba(255,255,255_strip??);
  background: rgba(0,0,0,.22);
  overflow:hidden;
  aspect-ratio: 1 / 1;
}
.pdp-mainimg img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  cursor:zoom-in;
}
.pdp-noimg{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;letter-spacing:.14em;opacity:.55;
}
.pdp-badge{
  position:absolute;top:12px;left:12px;
  padding:8px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.25);
  backdrop-filter: blur(6px);
  font-size:12px;font-weight:900;
}
.pdp-badge.ok{color:#39d98a;border-color:rgba(57,217,138,.35)}
.pdp-badge.bad{color:#ff6b6b;border-color:rgba(255,107,107,.35)}

.pdp-zoom{
  position:absolute;top:12px;right:12px;
  width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  color:#fff;cursor:pointer;
}
.pdp-zoom:hover{filter:brightness(1.08)}

.pdp-thumbs{
  display:flex;gap:10px;flex-wrap:wrap;
  margin-top:10px;
}
.thumbbtn{
  width:74px;height:74px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  overflow:hidden;
  cursor:pointer;
  opacity:.85;
}
.thumbbtn img{width:100%;height:100%;object-fit:cover;display:block}
.thumbbtn.active{opacity:1;border-color:rgba(31,111,235,.6)}
.thumbbtn:disabled{opacity:.35;cursor:not-allowed}
.thumb-noimg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;opacity:.6}

.pdp-note{margin-top:10px;font-size:13px;opacity:.75}

.pdp-info{min-width:0}
.pdp-titlewrap{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap
}
.pdp-title{margin:0;font-size:34px;line-height:1.05;font-weight:900}
@media (max-width:520px){ .pdp-title{font-size:28px} }
.pdp-price{font-size:22px;font-weight:900;opacity:.95}

.pdp-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.meta-pill{
  padding:8px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  font-size:13px;
}
.meta-pill.ok{color:#39d98a;border-color:rgba(57,217,138,.35)}
.meta-pill.bad{color:#ff6b6b;border-color:rgba(255,107,107,.35)}

.pdp-desc{
  margin-top:12px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  border-radius:16px;
  padding:12px;
  line-height:1.55;
}

.card{background:#0f1115;border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.25)}
.card-h{padding:14px 14px 10px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;gap:10px;align-items:center;justify-content:space-between}
.card-b{padding:14px}

.pdp-care{margin-top:12px}
.care-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
@media (max-width: 720px){
  .care-grid{grid-template-columns:1fr}
}
.care-item{
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  border-radius:14px;
  padding:12px;
}
.care-k{font-weight:900;opacity:.9}
.care-v{margin-top:6px;opacity:.9}

.pdp-buy{margin-top:12px}
.buy-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.qty{
  display:flex;align-items:center;gap:8px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  border-radius:14px;
  padding:8px;
}
.qty-btn{
  width:42px;height:42px;border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  color:#fff;cursor:pointer;font-weight:900;
}
.qty-btn:hover{filter:brightness(1.08)}
.qty-in{
  width:70px;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  color:#fff;
  text-align:center;
}
.buy-btn{min-width: 180px}

.buy-hint{margin-top:10px;font-size:13px;opacity:.75}

/* Zoom modal */
.zoom-backdrop{
  position:fixed;inset:0;
  background: rgba(0,0,0,.75);
  display:none;align-items:center;justify-content:center;
  padding:16px;z-index:9999;
}
.zoom-backdrop.open{display:flex}
.zoom-modal{
  width:min(980px, 100%);
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:#0f1115;
  overflow:hidden;
  position:relative;
  box-shadow:0 20px 70px rgba(0,0,0,.55);
}
.zoom-modal img{
  width:100%;
  height:auto;
  display:block;
}
.zoom-close{
  position:absolute;top:12px;right:12px;
  width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  color:#fff;cursor:pointer;font-weight:900;
}
.zoom-close:hover{filter:brightness(1.08)}

/* Sticky mobile bar */
.stickybar{
  display:none;
  position:fixed;
  left:0; right:0; bottom:0;
  padding: 10px 12px;
  background: rgba(10,12,18,.86);
  border-top: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(10px);
  z-index: 9998;
}
.stickybar__left{min-width:0}
.stickybar__name{font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stickybar__price{opacity:.9;font-weight:900}
.stickybar__right{display:flex;align-items:center}
.stickybar__btn{
  padding:12px 14px;
  border-radius: 14px;
  border:1px solid rgba(31,111,235,.6);
  background:#1f6feb;
  font-weight:900;
  color:#fff;
  cursor:pointer;
}
.stickybar__btn:disabled{
  opacity:.55;
  cursor:not-allowed;
}
@media (max-width: 820px){
  .stickybar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 12px;
  }
  body{padding-bottom: 76px;} /* espacio para no tapar */
}


/* =========================
   PDP EXTRA: ficha + relacionadas + whatsapp
   ========================= */
.pdp-spec{margin-top:12px}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width: 720px){ .spec-grid{grid-template-columns:1fr} }
.spec-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 12px;border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}
.spec-k{opacity:.8;font-weight:800}
.spec-v{font-weight:900}
.spec-ok{color:#39d98a}
.spec-bad{color:#ff6b6b}

/* WhatsApp button */
.btn.wa{
  background: rgba(34,197,94,.12);
  border-color: rgba(34,197,94,.35);
}
.btn.wa:hover{filter:brightness(1.1)}

/* Sticky WA */
.stickybar__wa{
  width:44px;height:44px;border-radius:14px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(34,197,94,.35);
  background: rgba(34,197,94,.12);
  color:#bff3d2;
  text-decoration:none;
  font-weight:900;
}

/* Relacionadas */
.rel-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width: 1100px){ .rel-grid{grid-template-columns: repeat(3, 1fr);} }
@media (max-width: 820px){  .rel-grid{grid-template-columns: repeat(2, 1fr);} }
@media (max-width: 520px){  .rel-grid{grid-template-columns: 1fr;} }

.rel-card{
  text-decoration:none;color:#fff;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  border-radius:18px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition: transform .12s ease, filter .12s ease;
}
.rel-card:hover{transform: translateY(-2px);filter:brightness(1.05)}
.rel-img{
  position:relative;
  aspect-ratio: 4 / 3;
  background: rgba(0,0,0,.22);
}
.rel-img img{width:100%;height:100%;object-fit:cover;display:block}
.rel-noimg{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;letter-spacing:.14em;opacity:.55;
}
.rel-badge{
  position:absolute;top:10px;left:10px;
  padding:7px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.25);
  backdrop-filter: blur(6px);
  font-size:12px;font-weight:900;
}
.rel-badge.ok{color:#39d98a;border-color:rgba(57,217,138,.35)}
.rel-badge.bad{color:#ff6b6b;border-color:rgba(255,107,107,.35)}
.rel-body{padding:12px}
.rel-name{
  font-weight:900;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.rel-foot{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.rel-price{font-weight:900;opacity:.95}
.rel-go{
  padding:8px 10px;border-radius:12px;
  border:1px solid rgba(31,111,235,.55);
  background: rgba(31,111,235,.18);
  font-weight:900;
}


/* =========================
   CART + CHECKOUT MODERNO
   ========================= */
.cart, .ck{padding: 10px 0}
.cart-head, .ck-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;
  margin-bottom:12px;
}
.cart-title, .ck-title{margin:0;font-size:34px;letter-spacing:-.02em}
.cart-sub{margin-top:4px}
.cart-actions, .ck-actions{display:flex;gap:10px;flex-wrap:wrap}

/* Cards helpers (si ya los tenés, no pasa nada) */
.card{background:#0f1115;border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.25)}
.card-h{padding:14px 14px 10px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;gap:10px;align-items:center;justify-content:space-between}
.card-b{padding:14px}
.muted{opacity:.8}
.w100{width:100%}

/* Buttons (si ya existen, mantienen look) */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;padding:10px 12px;border:1px solid rgba(255,255,255,.12);background:#141824;color:#fff;text-decoration:none;cursor:pointer}
.btn:hover{filter:brightness(1.08)}
.btn.primary{background:#1f6feb;border-color:rgba(31,111,235,.6)}
.btn.danger{background:#b42318;border-color:rgba(180,35,24,.6)}
.btn.ghost{background:transparent}
.btn.small{padding:8px 10px;border-radius:11px;font-size:13px}

/* CART grid */
.cart-grid{
  display:grid;
  grid-template-columns: 1.6fr .9fr;
  gap: 12px;
}
@media (max-width: 980px){
  .cart-grid{grid-template-columns:1fr}
}

.cart-empty{padding:18px;text-align:center}

.cart-rows{padding:8px 10px}
.cart-row{
  display:grid;
  grid-template-columns: 82px 1fr 330px 140px 120px;
  gap:12px;
  align-items:center;
  padding:12px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.cart-row:last-child{border-bottom:none}

@media (max-width: 980px){
  .cart-row{
    grid-template-columns: 82px 1fr;
    grid-template-areas:
      "img info"
      "qty qty"
      "sub sub"
      "rm rm";
    align-items:start;
  }
  .cart-img{grid-area:img}
  .cart-info{grid-area:info}
  .cart-qty{grid-area:qty}
  .cart-subtotal{grid-area:sub}
  .cart-remove{grid-area:rm}
}

.cart-img{
  width:82px;height:82px;border-radius:16px;overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.2);
  display:block;
}
.cart-img img{width:100%;height:100%;object-fit:cover;display:block}
.cart-noimg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-weight:900;opacity:.6;letter-spacing:.14em}

.cart-name a{color:#fff;text-decoration:none;font-weight:900}
.cart-meta{margin-top:4px;font-size:13px}

.qty-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.qty-btn{
  width:42px;height:42px;border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#fff;font-weight:900;font-size:18px;
  cursor:pointer;
}
.qty-in{
  width:84px;height:42px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:#0b0d12;color:#fff;
  text-align:center;font-weight:900;
}
.qty-save{height:42px}

.cart-subval{font-weight:900;font-size:18px}
.cart-remove{display:flex;justify-content:flex-end}
@media (max-width: 980px){ .cart-remove{justify-content:flex-start} }

.sum-row{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.sum-total{
  display:flex;justify-content:space-between;gap:10px;
  padding:12px 0;margin-top:6px;
  font-weight:900;font-size:18px;
}

/* CHECKOUT grid */
.ck-grid{
  display:grid;
  grid-template-columns: 1.25fr .85fr;
  gap: 12px;
}
@media (max-width: 980px){
  .ck-grid{grid-template-columns:1fr}
}

.form-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 720px){
  .form-grid{grid-template-columns:1fr}
}

.field{display:flex;flex-direction:column;gap:6px}
.label{font-size:12px;letter-spacing:.04em;text-transform:uppercase;opacity:.85}
.input{
  width:100%;padding:10px 12px;border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:#0b0d12;color:#fff;
}
.input:focus{outline:none;border-color:rgba(31,111,235,.7);box-shadow:0 0 0 3px rgba(31,111,235,.18)}
.help{font-size:12px}

/* Segmented control */
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg-btn{
  padding:10px 12px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:#fff;font-weight:900;
  cursor:pointer;
}
.seg-btn.active{
  border-color:rgba(31,111,235,.55);
  background:rgba(31,111,235,.18);
}

/* Tabs */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.tab{
  padding:10px 12px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:#fff;font-weight:900;
  cursor:pointer;
}
.tab.active{
  border-color:rgba(31,111,235,.55);
  background:rgba(31,111,235,.18);
}
.paybox{
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  border-radius:16px;
  padding:12px;
}

/* Summary */
.sum-items{display:flex;flex-direction:column;gap:10px}
.sum-item{
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  border-radius:14px;
  padding:10px 12px;
}
.sum-name{font-weight:900}
.sum-meta{font-size:12px;margin-top:2px}
.sum-sub{margin-top:8px;font-weight:900}

/* Sticky mobile */
.ck-sticky{
  position:fixed;left:0;right:0;bottom:0;
  padding:10px 12px;
  background: rgba(15,17,21,.92);
  border-top:1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
  display:none;
  z-index: 999;
}
.ck-sticky__left{display:flex;flex-direction:column}
.ck-sticky__v{font-weight:900;font-size:18px}
.ck-sticky__btn{
  height:44px;border-radius:14px;
  border:1px solid rgba(31,111,235,.55);
  background: rgba(31,111,235,.28);
  color:#fff;font-weight:900;
  padding:0 14px;cursor:pointer;
}
.ck-sticky{display:none;justify-content:space-between;align-items:center;gap:12px}
@media (max-width: 980px){
  .ck-sticky{display:flex}
  body{padding-bottom:72px}
}

/* ==========================================================
   FIXES FINAL (GANAN POR CASCADA)
   ========================================================== */

/* Evita scroll horizontal + “zoom raro” por overflow */
html, body { max-width: 100%; overflow-x: hidden; }
img, svg, video { max-width: 100%; height: auto; }

/* HOME title: wrap + tamaño fluido */
.home-title{
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.06;
  font-size: clamp(28px, 7vw, 44px);
}

/* NAV mobile: botones en 2 columnas (si tu navbar es ul/links) */
@media (max-width: 520px){
  header nav .container,
  nav .container{
    display:flex;
    flex-direction: column;
    align-items:flex-start;
    gap: 10px;
  }

  header nav ul,
  nav ul,
  .nav-links{
    width:100%;
    display:grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 10px;
  }

  header nav ul li,
  nav ul li{ list-style:none; }

  header nav ul a,
  nav ul a,
  .nav-links a{
    width:100%;
    justify-content:center;
    padding: 12px 10px;
    border-radius: 14px;
    white-space: nowrap;
  }
}

/* Prod cards más compactas en mobile */
@media (max-width: 520px){
  .prod-body{ padding:10px; }
  .prod-name{ font-size:13px; min-height:2.6em; }
  .prod-cta{ padding:8px 10px; border-radius:12px; }
}

/* =========================
   Force Light Theme (hotfix)
   ========================= */
body{
  background:#f6f7fb !important;
  color:#0b1220 !important;
}
a{ color: inherit; }

/* ==========================================================
   RESILIENCIA - NAVBAR FINAL (override seguro)
   ========================================================== */

/* Header sticky light */
.site-header{
  position: sticky;
  top: 0;
  z-index: 999;
  background: rgba(245,247,250,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(0,0,0,.06);
}

/* layout base */
.site-nav{
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
}

/* Brand */
.nav-brand{
  font-weight: 900;
  letter-spacing: .5px;
  text-decoration: none;
  color: #0b1220;
}

/* Desktop menu center */
.nav-links{
  display: flex;
  gap: 10px;
  margin: 0 auto; /* centra el bloque */
}

/* Login right */
.nav-login{
  margin-left: auto;
}

/* Botones del header (look claro tipo “pill”) */
.site-header .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:14px;
  font-weight:800;
  border:1px solid rgba(0,0,0,.10);
  background: #ffffff;
  color:#0b1220;
}
.site-header .btn.secondary{
  background:#ffffff;
  color:#0b1220;
  border:1px solid rgba(0,0,0,.10);
}
.site-header .btn:hover{ filter: brightness(0.98); }

/* Burger (mobile) */
.nav-burger{
  display:none;
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  align-items:center;
  justify-content:center;
  padding:0;
  cursor:pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
}

.nav-burger span{
  display:block;
  width:20px;
  height:2.5px;
  background:#0b1220;
  border-radius:999px;
  margin:2.5px 0; /* separa líneas prolijo */
}

/* Drawer overlay */
.nav-drawer{
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: none;
}
.nav-drawer.is-open{ display: block; }

.nav-drawer-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.35);
}

/* panel flotante, NO empuja contenido */
.nav-drawer-panel{
  position:absolute;
  top: 72px;
  left: 12px;
  right: 12px;
  background:#fff;
  border-radius:18px;
  border:1px solid rgba(0,0,0,.10);
  box-shadow:0 12px 30px rgba(0,0,0,.18);
  padding: 18px 14px 14px;
}

.nav-drawer-x{
  position:absolute;
  top: 12px;
  right: 12px;
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.nav-drawer-x:hover{
  background: rgba(0,0,0,.04);
}

.nav-drawer-item{
  display:block;
  padding: 16px 14px;
  margin-top: 10px;
  border-radius: 14px;
  text-decoration:none;
  font-weight: 800;
  color:#0b1220;
  background: rgba(0,0,0,.03);
  border: 1px solid rgba(0,0,0,.06);
}
.nav-drawer-item:hover{ background: rgba(0,0,0,.05); }

.nav-drawer-item:first-of-type{
  margin-top: 32px;
}

/* Mobile behavior:
   - burger izquierda
   - logo centrado
   - login derecha
*/
@media (max-width: 820px){
  .nav-links{ display:none !important; }
  .nav-burger{ display:flex; }

  .nav-brand{
    position:absolute;
    left:50%;
    transform: translateX(-50%);
  }

  .nav-login{ margin-left:auto; }
}

/* Desktop behavior:
   - logo izquierda
   - links centro
   - login derecha
*/
@media (min-width: 821px){
  .nav-brand{ position: static; transform:none; }
  .nav-links{ margin: 0 auto; }
  .nav-login{ margin-left: auto; }
}

/* ==========================================================
   WhatsApp flotante - solo ícono oficial (override seguro)
   ========================================================== */
.wa-float{
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: #25D366;
  box-shadow: 0 14px 40px rgba(0,0,0,.18);
  z-index: 1300;
}

.wa-float .wa-txt{ display:none !important; }

/* convertimos el wa-ico en svg */
.wa-ico{
  font-size: 0 !important; /* por si quedó emoji */
  width: 26px;
  height: 26px;
  display:block;
  background: no-repeat center/contain;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Cpath fill='%23fff' d='M19.11 17.53c-.28-.14-1.64-.81-1.9-.9-.26-.1-.45-.14-.64.14-.19.28-.73.9-.9 1.08-.17.19-.33.21-.61.07-.28-.14-1.2-.44-2.28-1.41-.84-.75-1.4-1.68-1.56-1.96-.16-.28-.02-.43.12-.57.12-.12.28-.33.42-.49.14-.16.19-.28.28-.47.09-.19.05-.36-.02-.5-.07-.14-.64-1.54-.88-2.11-.23-.55-.47-.48-.64-.49l-.55-.01c-.19 0-.5.07-.76.36-.26.28-1 1-1 2.44 0 1.44 1.03 2.83 1.17 3.03.14.19 2.03 3.1 4.92 4.35.69.3 1.23.48 1.65.62.69.22 1.31.19 1.8.12.55-.08 1.64-.67 1.87-1.32.23-.65.23-1.21.16-1.32-.07-.12-.26-.19-.54-.33z'/%3E%3Cpath fill='%23fff' d='M26.67 5.33A14.63 14.63 0 0 0 16 1C7.73 1 1 7.73 1 16c0 2.64.69 5.22 2 7.5L1 31l7.67-1.99A14.9 14.9 0 0 0 16 31c8.27 0 15-6.73 15-15 0-4.01-1.56-7.78-4.33-10.67zM16 28.5c-2.25 0-4.45-.61-6.35-1.76l-.46-.27-4.55 1.18 1.21-4.43-.3-.46A12.33 12.33 0 0 1 3.5 16C3.5 9.1 9.1 3.5 16 3.5S28.5 9.1 28.5 16 22.9 28.5 16 28.5z'/%3E%3C/svg%3E");
}

/* FIX: burger clickeable (por si el logo absoluto lo tapa) */
.nav-burger{
  position: relative;
  z-index: 20;
  pointer-events: auto;
}

.nav-login{
  position: relative;
  z-index: 20;
}

.nav-brand{
  position: relative;
  z-index: 10;
}