/* ============================================================
   VIDANAT — "Herbolario cálido / Natural"
   Tema claro crema · verde hoja · serif Fraunces + sans Inter
   Suave, orgánico, premium-eco (sin retícula técnica)
   ============================================================ */
:root{
  /* papel / tinta (crema cálida + verde profundo) */
  --paper:#f4f1e8; --paper-2:#faf8f1; --card:#fffdf8; --white:#ffffff;
  --ink:#23311f; --ink-2:#3f5138; --ink-soft:#7c8472;
  --line:#e3dfd0; --line-2:#d0cbb8; --grid:#e8e4d5;
  /* acento verde hoja + paleta natural */
  --accent:#2f7d4f; --accent-2:#246340; --on-accent:#fff;
  --c-blue:#3a7ca5; --c-green:#3a8f4f; --c-yellow:#caa23a; --c-red:#c0492f; --c-grey:#8a8470; --c-orange:#d08a3a;
  /* tipografia */
  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
  --font-mono:"Inter",system-ui,sans-serif;
  /* espacio (8px) */
  --c1:8px;--c2:16px;--c3:24px;--c4:32px;--c5:48px;--c6:72px;
  --radius:14px;
  /* sombras suaves (sustituyen a las sombras duras del tema anterior) */
  --shadow-sm:0 2px 8px rgba(35,49,31,.07);
  --shadow:0 8px 24px rgba(35,49,31,.10);
  /* fondo suave para fotos de producto (spotlight claro; NO debe ocultar el producto) */
  --product-bg:
    radial-gradient(88% 74% at 50% 14%, rgba(255,255,255,.99), rgba(255,255,255,0) 80%),
    linear-gradient(158deg, #fffdf8 0%, #f6f3ea 58%, #ece8da 100%);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--ink);background-color:var(--paper);
  font-family:var(--font-body);font-size:16.5px;line-height:1.62;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
p{margin:0 0 1rem}
:focus-visible{outline:2.5px solid var(--accent);outline-offset:2px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
h1,h2,h3{font-family:var(--font-display);line-height:1.12;margin:0 0 .4em;font-weight:600;letter-spacing:-.015em}
h1{font-size:clamp(2.1rem,5.2vw,3.7rem)}
h2{font-size:clamp(1.5rem,3.2vw,2.3rem)}
h3{font-size:1.1rem;letter-spacing:-.005em;font-weight:600}
.muted{color:var(--ink-soft)}
.mono{font-family:var(--font-mono)}
.skip{position:absolute;left:-999px}
.skip:focus{left:12px;top:12px;background:var(--ink);color:var(--paper);padding:10px 16px;z-index:100}

/* etiqueta tecnica (mono, mayuscula) */
.tag{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}

/* CONTENEDOR (patron fijo) */
.container{width:100%;max-width:1240px;margin-inline:auto;padding-inline:16px}
@media(min-width:768px){.container{padding-inline:24px}}

/* ---- registro / crosshair util ---- */
.reg{position:relative}
.reg::before,.reg::after{content:"";position:absolute;width:11px;height:11px;pointer-events:none;z-index:2}
.reg::before{top:-1px;left:-1px;border-top:1.5px solid var(--ink);border-left:1.5px solid var(--ink)}
.reg::after{bottom:-1px;right:-1px;border-bottom:1.5px solid var(--ink);border-right:1.5px solid var(--ink)}

/* ===================== BOTONES ===================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;
  font-family:var(--font-mono);font-weight:600;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;
  padding:13px 22px;border:1.5px solid var(--ink);background:transparent;color:var(--ink);
  border-radius:var(--radius);min-height:46px;transition:.16s ease;position:relative}
.btn-primary{background:var(--accent);border-color:var(--ink);color:var(--on-accent);
  box-shadow:4px 4px 0 var(--ink)}
.btn-primary:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-block{width:100%}

/* ===================== HEADER ===================== */
.site-header{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:1.5px solid var(--ink)}
.util{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  background:var(--ink);color:var(--paper);}
.util .container{display:flex;justify-content:space-between;gap:16px;padding-block:5px;overflow:hidden;white-space:nowrap}
.util b{color:var(--c-yellow)}
.header-inner{display:flex;align-items:center;gap:var(--c2);padding-block:11px}
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo-mark{width:28px;height:28px;flex-shrink:0}
.logo-text{font-family:var(--font-display);font-size:1.3rem;font-weight:800;text-transform:uppercase;letter-spacing:-.03em}
.logo-text strong{color:var(--accent);font-weight:800}
.search{position:relative;flex:1;display:flex;background:var(--white);border:1.5px solid var(--ink);border-radius:var(--radius);min-width:0}
/* autocompletar */
.ac-box{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:70;background:var(--white);
  border:1.5px solid var(--ink);box-shadow:6px 8px 0 rgba(23,23,15,.9);max-height:70vh;overflow:auto}
.ac-box[hidden]{display:none}
.ac-h{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);
  padding:8px 12px 4px;border-bottom:1px dashed var(--line-2)}
.ac-cat{display:block;padding:9px 12px;font-family:var(--font-mono);font-size:.82rem;border-bottom:1px dashed var(--line)}
.ac-cat:hover,.ac-item:hover{background:var(--paper)}
.ac-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px dashed var(--line)}
.ac-item img{width:40px;height:40px;object-fit:contain;background:var(--product-bg);border:1px solid var(--line);flex-shrink:0;mix-blend-mode:multiply}
.ac-n{flex:1;font-size:.84rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ac-p{font-family:var(--font-display);font-weight:800;font-size:.95rem;white-space:nowrap}
.ac-all{display:block;padding:11px 12px;text-align:center;font-family:var(--font-mono);font-size:.76rem;
  text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-weight:600;background:var(--paper)}
.ac-all:hover{background:var(--ink);color:var(--paper)}
.ac-empty{padding:14px 12px;font-family:var(--font-mono);font-size:.82rem;color:var(--ink-soft)}
/* ofertas flash */
.flash-badge{position:absolute;top:8px;left:8px;z-index:2;background:var(--accent);color:#fff;font-family:var(--font-mono);
  font-weight:700;font-size:.74rem;letter-spacing:.02em;padding:4px 8px;border:1.5px solid var(--ink);box-shadow:2px 2px 0 var(--ink)}
.price.flash{color:var(--accent)}
.price.flash s,.pdp .price.flash s{color:var(--ink-soft);text-decoration:line-through;font-family:var(--font-mono);font-weight:400}
.flash-note{font-family:var(--font-mono);font-size:.74rem;color:var(--ink-soft);margin:8px 0 0}
.flash-note .js-countdown{color:var(--accent);font-weight:700}
.flash-block h2{color:var(--accent)}
.flash-timer{display:flex;align-items:center;gap:10px}
.ft-l{font-family:var(--font-mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft)}
.ft-c{font-family:var(--font-mono);font-weight:700;font-size:1rem;background:var(--ink);color:var(--paper);padding:6px 10px;letter-spacing:.05em;border:1.5px solid var(--ink);font-variant-numeric:tabular-nums}

/* ---- packs / kits ---- */
.navpacks{color:var(--accent);font-weight:700}
.navpacks:hover{background:var(--accent)!important;color:#fff!important}
.packs-grid{display:grid;grid-template-columns:1fr;gap:var(--c3)}
@media(min-width:760px){.packs-grid{grid-template-columns:1fr 1fr}}
.pack-card{background:var(--card);border:1.5px solid var(--ink);box-shadow:6px 6px 0 var(--ink);display:flex;flex-direction:column;
  padding:var(--c3) var(--c4);transition:transform .16s,box-shadow .16s;min-width:0}
.pack-card h3{overflow-wrap:anywhere}
.packs-grid > .pack-card:hover{transform:translate(-2px,-2px);box-shadow:9px 9px 0 var(--ink)}
.pack-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.pack-tag{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.16em;color:#fff;background:var(--ink);padding:3px 9px;display:inline-block}
.pack-titles h2{font-size:1.3rem;margin:8px 0 0}
.pack-badge{font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:#fff;background:var(--accent);
  border:1.5px solid var(--ink);box-shadow:2px 2px 0 var(--ink);padding:6px 11px;flex-shrink:0}
.pack-desc{color:var(--ink-2);font-size:.92rem;margin:0 0 var(--c2);max-width:52ch;line-height:1.55}
/* tira visual de productos del kit */
.pack-thumbs{display:flex;align-items:center;gap:0;margin:0 0 var(--c2)}
.pack-thumbs .pt{width:52px;height:52px;background:var(--product-bg);border:1.5px solid var(--ink);margin-right:-10px;
  display:flex;align-items:center;justify-content:center;padding:5px;position:relative;z-index:1}
.pack-thumbs .pt:nth-child(2){z-index:2}.pack-thumbs .pt:nth-child(3){z-index:3}.pack-thumbs .pt:nth-child(4){z-index:4}.pack-thumbs .pt:nth-child(5){z-index:5}
.pack-thumbs .pt img{max-width:100%;max-height:100%;object-fit:contain;mix-blend-mode:multiply}
.pack-thumbs .pt-n{margin-left:18px;font-family:var(--font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
.pack-thumbs--mini .pt{width:38px;height:38px;margin-right:-8px}
/* contenido desplegable */
.pack-list{border-top:1px dashed var(--line-2);margin-bottom:var(--c2)}
.pack-list>summary{display:flex;align-items:center;justify-content:space-between;cursor:pointer;list-style:none;
  padding:11px 0;font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-2)}
.pack-list>summary::-webkit-details-marker{display:none}
.pack-list ul{list-style:none;margin:0 0 8px;padding:0;display:flex;flex-direction:column;gap:8px}
.pack-list li{display:flex;align-items:center;gap:10px}
.pack-list .pcimg img{width:38px;height:38px;object-fit:contain;background:var(--product-bg);border:1px solid var(--line);mix-blend-mode:multiply}
.pack-list .pcname{flex:1;font-size:.83rem;line-height:1.3}.pack-list .pcname:hover{color:var(--accent)}
.pack-list .pcprice{font-family:var(--font-mono);font-size:.8rem;color:var(--ink-soft);white-space:nowrap}
.pack-foot{margin-top:auto;border-top:1.5px solid var(--ink);padding-top:var(--c2)}
.pack-price{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.pp-now{font-family:var(--font-display);font-weight:800;font-size:1.9rem;color:var(--accent);line-height:1}
.pp-was s{font-family:var(--font-mono);color:var(--ink-soft)}
.pp-save{font-family:var(--font-mono);font-size:.74rem;background:var(--c-green);color:#fff;border:1.5px solid var(--ink);padding:3px 9px}
/* mini (home) */
.pack-card--mini{padding:var(--c3);box-shadow:4px 4px 0 var(--ink);transition:.16s}
.pack-card--mini .pack-top{margin-bottom:8px}
.pack-card--mini h3{font-family:var(--font-display);text-transform:uppercase;font-size:1.05rem;margin:0 0 12px;letter-spacing:-.01em}
.pack-card--mini .pack-badge{font-size:.92rem;padding:4px 8px}
.pack-card--mini:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink);background:var(--white)}
.pack-card--mini .pp-now{font-size:1.4rem}
.pack-card--mini .pack-price{margin-bottom:0}
.packs-grid--home{grid-template-columns:1fr 1fr}
@media(max-width:480px){.packs-grid--home{grid-template-columns:1fr}}
@media(min-width:900px){.packs-grid--home{grid-template-columns:repeat(4,1fr)}}
@media(max-width:520px){.pack-card--mini h3{font-size:.95rem}.pack-card{padding:var(--c2) var(--c3)}.pack-thumbs .pt{width:46px;height:46px}}

/* barra de progreso (envío gratis / recargo) */
.ship-progress{margin:0 0 var(--c2);padding:12px;background:var(--white);border:1.5px solid var(--ink)}
.sp-msg{font-size:.86rem;margin:0 0 8px;line-height:1.4}
.sp-msg.ok{color:var(--c-green);font-weight:700}
.sp-bar{height:9px;background:var(--line);border:1.5px solid var(--ink);overflow:hidden}
.sp-bar span{display:block;height:100%;background:var(--accent);transition:width .4s}
.sp-bar span.full{background:var(--c-green)}
.search input{flex:1;background:transparent;border:0;color:var(--ink);padding:11px 16px;font-size:16px;font-family:var(--font-mono);min-width:0}
.search input::placeholder{color:var(--ink-soft);text-transform:none}
.search input:focus{outline:none}
.search button{background:var(--ink);border:0;color:var(--paper);padding:0 16px;cursor:pointer;margin:-1px}
.search button:hover{background:var(--accent)}
.header-actions{display:flex;align-items:center;gap:var(--c2);flex-shrink:0;padding-right:2px}
.cart-link{position:relative;display:flex;padding:5px}
.cart-count{position:absolute;top:-5px;right:-5px;background:var(--accent);color:#fff;font-family:var(--font-mono);
  font-size:.66rem;font-weight:700;min-width:17px;height:17px;border-radius:2px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--ink)}
.cart-count.is-empty{display:none}
/* ---- mega-menú ---- */
.mainnav{border-top:1px dashed var(--line-2);background:var(--paper)}
.mainnav-inner{display:flex;align-items:stretch}
.navtoggle{display:none;align-items:center;gap:10px;background:none;border:0;cursor:pointer;
  font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink);padding:12px 0;width:100%}
.navgroups{display:flex;list-style:none;margin:0;padding:0;align-items:stretch}
.navgroup{position:relative;display:flex}
.navgroup-btn{display:flex;align-items:center;gap:8px;background:none;border:0;border-right:1px dashed var(--line-2);cursor:pointer;
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);padding:12px 18px;transition:.15s}
.navgroup-btn:hover{background:var(--ink);color:var(--paper)}
.caret{width:7px;height:7px;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;transform:rotate(45deg);transition:transform .2s}
.navdrop{position:absolute;top:100%;left:0;min-width:320px;background:var(--white);border:1.5px solid var(--ink);
  box-shadow:8px 10px 0 rgba(23,23,15,.9);padding:8px;display:none;z-index:60}
.navdrop a{display:block;padding:11px 12px;border-bottom:1px dashed var(--line)}
.navdrop a:last-child{border-bottom:0}
.navdrop a:hover{background:var(--paper)}
.navdrop b{display:block;font-family:var(--font-display);font-size:.98rem;text-transform:uppercase;letter-spacing:-.01em}
.navdrop span{font-family:var(--font-mono);font-size:.72rem;color:var(--ink-soft)}
.navgroup--cta{margin-left:auto;align-items:center}
.navall{font-family:var(--font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-weight:600;padding:12px 0 12px 18px}
.navall:hover{text-decoration:underline}
@media(min-width:900px){
  .navgroup:hover .navdrop,.navgroup:focus-within .navdrop,.navgroup-btn[aria-expanded="true"]+.navdrop{display:block}
  .navgroup:hover .caret{transform:rotate(225deg)}
}
@media(max-width:899px){
  .navtoggle{display:flex;justify-content:space-between}
  .navtoggle svg{order:-1}
  .navgroups{display:none;flex-direction:column;width:100%;border-top:1px dashed var(--line-2);padding-bottom:8px}
  .mainnav.open .navgroups{display:flex}
  .navgroup{width:100%;flex-direction:column}
  .navgroup-btn{width:100%;justify-content:space-between;border-right:0;border-bottom:1px dashed var(--line-2)}
  .navgroup-btn[aria-expanded="true"] .caret{transform:rotate(225deg)}
  .navdrop{position:static;min-width:0;box-shadow:none;border:0;border-bottom:1px dashed var(--line-2);padding:0 0 8px}
  .navgroup-btn[aria-expanded="true"]+.navdrop{display:block}
  .navgroup--cta{margin-left:0}.navall{padding:14px 0}
}
@media(max-width:640px){.logo-text{font-size:1.15rem}.util .container{font-size:.62rem}}

/* ===================== HERO (slider) ===================== */
.hero{position:relative;border-bottom:1.5px solid var(--ink);overflow:hidden;background:var(--paper-2)}
.hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(900px 460px at 82% -8%,rgba(46,125,255,.16),transparent 60%),
             radial-gradient(680px 400px at 8% 112%,rgba(239,80,34,.10),transparent 60%)}
.hero-grid{position:absolute;inset:0;z-index:0;background-image:
  linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:24px 24px;opacity:.6}
.hero-slider{position:relative;z-index:1;display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;scroll-behavior:smooth}
.hero-slider::-webkit-scrollbar{display:none}
.hero-slide{flex:0 0 100%;min-width:100%;scroll-snap-align:start}
.hero-inner{display:grid;grid-template-columns:1fr;gap:var(--c4);padding-block:var(--c5) var(--c6);align-items:center}
@media(min-width:900px){.hero-inner{grid-template-columns:1.1fr .9fr;padding-block:var(--c6) calc(var(--c6) + 8px)}}
.hero-copy{min-width:0}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.72rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink);border:1.5px solid var(--ink);padding:5px 12px;background:var(--white)}
.hero .eyebrow::before{content:"";width:8px;height:8px;background:var(--c-green);border-radius:50%;box-shadow:0 0 0 3px rgba(47,158,68,.25)}
.hero h1,.slide-title{margin-top:var(--c3);font-family:var(--font-display);font-weight:800;text-transform:uppercase;
  line-height:1.04;letter-spacing:-.025em;font-size:clamp(2.1rem,5vw,3.6rem)}
.slide-title{margin-bottom:0}
.hero h1 em,.slide-title em{font-style:normal;color:var(--accent)}
.hero p.lead{font-size:1.1rem;color:var(--ink-2);max-width:48ch;margin:var(--c3) 0;line-height:1.6}
.hero-cta{display:flex;gap:var(--c2);flex-wrap:wrap}
.hero-spec{margin-top:var(--c4);display:grid;grid-template-columns:repeat(3,auto);gap:var(--c3) var(--c4);justify-content:start}
.hero-spec .k{font-family:var(--font-display);font-size:1.7rem;font-weight:800;line-height:1}
.hero-spec .l{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
/* ilustración enmarcada */
.hero-art{position:relative;aspect-ratio:1/.9;background:var(--white);border:1.5px solid var(--ink);box-shadow:8px 8px 0 var(--ink)}
.hero-art svg{width:100%;height:100%}
.hero-art .lbl{font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;fill:var(--ink-soft)}
.hero-art .edge{stroke:var(--ink);stroke-width:1.6;stroke-dasharray:5 4;fill:none;animation:draw 1.4s ease forwards;stroke-dashoffset:200;opacity:.85}
.hero-art .node{fill:var(--white);stroke:var(--ink);stroke-width:1.6}
.hero-art .hl{stroke:var(--ink);stroke-width:2.2;stroke-linecap:round;fill:none}
.hero-art .pulse{transform-origin:center;animation:pulse 2.4s ease-in-out infinite}
@media(max-width:899px){.hero-art{max-width:340px;margin:0 auto;width:100%}}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes pulse{0%,100%{opacity:.25}50%{opacity:.9}}
/* dots */
.hero-dots{position:relative;z-index:1;display:flex;gap:9px;justify-content:center;padding:0 0 var(--c3)}
.hero-dots button{width:30px;height:5px;border:0;background:var(--line-2);cursor:pointer;padding:0;transition:.2s}
.hero-dots button.active{background:var(--accent);width:44px}
.hero-arrow{position:absolute;top:44%;transform:translateY(-50%);z-index:3;width:46px;height:46px;display:flex;
  align-items:center;justify-content:center;background:var(--paper);color:var(--ink);border:1.5px solid var(--ink);
  box-shadow:3px 3px 0 var(--ink);cursor:pointer;transition:.15s}
.hero-arrow:hover{background:var(--ink);color:var(--paper);transform:translateY(-50%) translate(-1px,-1px)}
.hero-arrow.prev{left:16px}.hero-arrow.next{right:16px}
@media(min-width:1340px){.hero-arrow.prev{left:calc((100% - 1240px)/2 - 60px)}.hero-arrow.next{right:calc((100% - 1240px)/2 - 60px)}}
@media(max-width:899px){
  .hero-arrow{top:auto;bottom:12px;transform:none;width:42px;height:42px}
  .hero-arrow:hover{transform:translate(-1px,-1px)}
  .hero-dots{padding-bottom:22px}
}

/* ===================== SECCIONES ===================== */
section.block{padding-block:var(--c5)}
.sec-head{display:flex;justify-content:space-between;align-items:end;gap:var(--c2);margin-bottom:var(--c3);
  padding-bottom:var(--c2);border-bottom:1.5px solid var(--ink)}
.sec-head .tag{display:block;margin-bottom:6px}
.sec-head a{font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-weight:600}
.sec-head a:hover{text-decoration:underline}

/* ---- grid categorias (patch panel) ---- */
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:-1px}
@media(min-width:768px){.cat-grid{grid-template-columns:repeat(4,1fr)}}
.cat-grid{gap:0;border:1.5px solid var(--ink);background:var(--ink)}
.cat-card{background:var(--card);padding:var(--c3) var(--c2);position:relative;
  outline:1px solid var(--line);transition:.16s;display:block}
.cat-card:hover{background:var(--white);z-index:1}
.cat-card .port{width:100%;height:8px;background:var(--c-grey);margin-bottom:14px;position:relative}
.cat-card:nth-child(6n+1) .port{background:var(--c-blue)}
.cat-card:nth-child(6n+2) .port{background:var(--c-green)}
.cat-card:nth-child(6n+3) .port{background:var(--c-yellow)}
.cat-card:nth-child(6n+4) .port{background:var(--c-red)}
.cat-card:nth-child(6n+5) .port{background:var(--accent)}
.cat-card:nth-child(6n+6) .port{background:var(--c-grey)}
.cat-card b{display:block;font-family:var(--font-display);font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:-.01em;line-height:1.1}
.cat-card small{font-family:var(--font-mono);font-size:.7rem;color:var(--ink-soft);letter-spacing:.05em}
.cat-card .ix{position:absolute;top:10px;right:12px;font-family:var(--font-mono);font-size:.64rem;color:var(--line-2)}

/* ---- grid productos ---- */
.prod-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--c2)}
@media(min-width:640px){.prod-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.prod-grid{grid-template-columns:repeat(4,1fr);gap:var(--c3)}}

/* datasheet card */
.card{background:var(--card);border:1.5px solid var(--ink);display:flex;flex-direction:column;position:relative;transition:.16s;min-width:0}
.card:hover{box-shadow:6px 6px 0 var(--ink);transform:translate(-2px,-2px);background:var(--white)}
.card .cardtab{display:flex;justify-content:space-between;align-items:center;gap:8px;overflow:hidden;
  padding:7px 10px;border-bottom:1px dashed var(--line-2);font-family:var(--font-mono);font-size:.62rem;
  letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}
.card .cardtab span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.card .cardtab .dot{overflow:visible;flex:0 0 auto}
.card .cardtab .dot{width:9px;height:9px;border:1.5px solid var(--ink);background:var(--c-grey)}
.card.cb-blue .dot{background:var(--c-blue)} .card.cb-green .dot{background:var(--c-green)}
.card.cb-yellow .dot{background:var(--c-yellow)} .card.cb-red .dot{background:var(--c-red)}
.card.cb-orange .dot{background:var(--accent)} .card.cb-grey .dot{background:var(--c-grey)}
.card .thumb{aspect-ratio:1;background:var(--product-bg);display:flex;align-items:center;justify-content:center;padding:18px;position:relative;box-shadow:inset 0 0 0 1px rgba(23,23,15,.05)}
.card .thumb::before,.card .thumb::after{content:"+";position:absolute;font-family:var(--font-mono);color:var(--line-2);font-size:.8rem}
.card .thumb::before{top:6px;left:8px}.card .thumb::after{bottom:6px;right:8px}
.card .thumb img{max-height:100%;width:auto;object-fit:contain;mix-blend-mode:multiply}
.card .body{padding:var(--c2);display:flex;flex-direction:column;gap:7px;flex:1;border-top:1px dashed var(--line-2)}
.card .brand{font-family:var(--font-mono);font-size:.66rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.card .name{font-size:.92rem;font-weight:500;line-height:1.32;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.4em}
.card .stock{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.04em;text-transform:uppercase;color:var(--c-green);display:flex;align-items:center;gap:6px}
.card .stock.low{color:var(--accent-2)}
.card .stock::before{content:"";width:7px;height:7px;background:currentColor;border-radius:50%}
.card .price-row{margin-top:auto;display:flex;align-items:flex-end;justify-content:space-between;gap:8px;padding-top:10px;border-top:1px solid var(--line)}
.card .price{font-family:var(--font-display);font-size:1.4rem;font-weight:800;letter-spacing:-.02em;line-height:1}
.card .price span{font-size:.62rem;font-family:var(--font-mono);color:var(--ink-soft);display:block;font-weight:400}
.card form{margin:0}
.iconbtn{background:var(--ink);color:var(--paper);border:0;width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:.15s}
.iconbtn:hover{background:var(--accent)}

/* ---- pilar de categoría (SEO) ---- */
.cat-intro{max-width:none;margin:var(--c2) 0 var(--c4)}
.cat-intro p{color:var(--ink-2)}
.cat-intro p:last-child{margin-bottom:0}
@media(min-width:900px){.cat-intro{columns:2;column-gap:var(--c5)}.cat-intro p{break-inside:avoid}}
.shop-h2{font-size:1.1rem;margin-bottom:var(--c2);padding-bottom:8px;border-bottom:1px dashed var(--line-2)}
.cat-content{max-width:none;margin-top:var(--c5);border-top:1.5px solid var(--ink);padding-top:var(--c3)}
.cat-content .prose p,.cat-content .prose li{max-width:74ch}
.seo-block .prose h3{margin-top:var(--c3)}
/* filtros colapsables (móvil) */
.filters-toggle{display:none}
@media(max-width:1023px){
  .filters{padding:0}
  .filters-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--ink);color:var(--paper);
    border:0;font-family:var(--font-mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;padding:14px 16px;cursor:pointer}
  .filters-toggle::after{content:"+";font-size:1.2rem;line-height:1}
  .filters.open .filters-toggle::after{content:"−"}
  .filters form{display:none;padding:var(--c3)}
  .filters.open form{display:block}
}
.rel-links{display:flex;flex-wrap:wrap;gap:var(--c2)}
.rel-links a{font-family:var(--font-mono);font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;
  border:1.5px solid var(--ink);padding:9px 14px;background:var(--white)}
.rel-links a:hover{background:var(--ink);color:var(--paper)}

/* ---- listado + filtros ---- */
.shop{display:grid;grid-template-columns:1fr;gap:var(--c3);padding-block:var(--c3) var(--c5)}
@media(min-width:1024px){.shop{grid-template-columns:248px 1fr}}
.filters{background:var(--card);border:1.5px solid var(--ink);padding:var(--c3);height:max-content}
.filters .fhead{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft);border-bottom:1px dashed var(--line-2);padding-bottom:8px;margin:0 0 8px}
.filters label{display:flex;align-items:center;gap:9px;padding:5px 0;font-family:var(--font-mono);font-size:.8rem;cursor:pointer}
.filters label:hover{color:var(--accent)}
.filters select{width:100%;background:var(--white);color:var(--ink);border:1.5px solid var(--ink);border-radius:var(--radius);padding:10px;font-family:var(--font-mono);font-size:.8rem}
.breadcrumb{display:flex;gap:10px;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);padding-block:var(--c3) var(--c2);flex-wrap:wrap}
.breadcrumb a:hover{color:var(--accent)}
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:var(--c2);margin-bottom:var(--c2);flex-wrap:wrap;font-family:var(--font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}

/* ---- ficha producto ---- */
.pdp{display:grid;grid-template-columns:1fr;gap:var(--c4);padding-block:var(--c2) var(--c4)}
@media(min-width:900px){.pdp{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:var(--c5);align-items:start}.pdp-media{position:sticky;top:104px}}
/* Móvil: orden lógico imagen -> comprar (título/precio/añadir) -> specs (no specs antes del título) */
@media(max-width:899px){
  .pdp{display:flex;flex-direction:column}
  .pdp-media{display:contents}
  .pdp .gallery{order:1}
  .pdp-buy{order:2}
  .pdp .spec-tiles{order:3;margin-top:0}
}
.pdp .gallery{background:var(--product-bg);border:1.5px solid var(--ink);box-shadow:8px 8px 0 var(--ink);padding:var(--c5);display:flex;align-items:center;justify-content:center;aspect-ratio:1;position:relative;overflow:hidden}
.pdp .gallery::after{content:"";position:absolute;left:50%;bottom:10%;width:58%;height:20px;transform:translateX(-50%);z-index:0;
  background:radial-gradient(50% 100% at 50% 0,rgba(23,23,15,.13),transparent 70%);filter:blur(3px)}
.pdp .gallery img{max-height:100%;object-fit:contain;mix-blend-mode:multiply;position:relative;z-index:1;transition:transform .45s cubic-bezier(.2,.7,.2,1)}
.pdp .gallery:hover img{transform:scale(1.07)}
.gallery-tag{position:absolute;top:12px;left:14px;z-index:2;font-family:var(--font-mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.pdp .brand{font-family:var(--font-mono);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;color:var(--accent)}
.pdp h1{font-size:clamp(1.6rem,3.5vw,2.4rem);margin:10px 0}
.pdp .price{font-family:var(--font-display);font-size:2.6rem;font-weight:800;letter-spacing:-.03em;margin:6px 0}
.pdp .vat{font-family:var(--font-mono);color:var(--ink-soft);font-size:.8rem;font-weight:400;text-transform:uppercase;letter-spacing:.06em}
.buybox{background:var(--card);border:1.5px solid var(--ink);padding:var(--c3);margin:var(--c3) 0}
.qty{display:inline-flex;border:1.5px solid var(--ink);overflow:hidden;margin-right:12px;background:var(--white)}
.qty button{background:var(--white);color:var(--ink);border:0;width:44px;height:46px;font-size:1.2rem;cursor:pointer}
.qty button:hover{background:var(--ink);color:var(--paper)}
.qty input{width:48px;text-align:center;background:transparent;border:0;color:var(--ink);font-family:var(--font-mono);font-size:1rem}
.specs{width:100%;border-collapse:collapse;margin-top:var(--c2);font-family:var(--font-mono);font-size:.82rem}
.specs td{padding:11px 8px;border-bottom:1px dashed var(--line-2)}
.specs tr:nth-child(odd) td{background:rgba(255,255,255,.4)}
.specs td:first-child{color:var(--ink-soft);width:38%;text-transform:uppercase;letter-spacing:.04em;font-size:.72rem}
.usp{display:flex;gap:var(--c3);flex-wrap:wrap;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);margin-top:var(--c2)}
.usp span{display:flex;align-items:center;gap:8px}

/* ---- ficha producto v2 ---- */
.gallery img{width:auto}
/* chips de características reales */
.chiprow{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:var(--c2) 0 0}
.chiprow li{display:inline-flex;align-items:center;gap:6px;border:1.5px solid var(--ink);background:var(--white);
  font-family:var(--font-mono);font-size:.74rem;padding:5px 10px}
.chiprow .ck{color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em;font-size:.62rem}
/* caja de precio + compra */
.pricebox{background:var(--card);border:1.5px solid var(--ink);box-shadow:6px 6px 0 var(--ink);padding:var(--c3);margin:var(--c3) 0}
.pricebox .price{margin:0}
.pricebox .stock{font-family:var(--font-mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--c-green);display:flex;align-items:center;gap:7px;margin:8px 0 16px}
.pricebox .stock::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor}
.pricebox .stock.low{color:var(--accent-2)}
.addform{display:flex;gap:12px;flex-wrap:wrap;align-items:stretch}
.addform .qty{margin:0}
.addbtn{flex:1;min-width:180px}
.trust-list{list-style:none;padding:0;margin:var(--c2) 0 0;display:flex;flex-direction:column;gap:10px;
  font-size:.86rem;color:var(--ink-2)}
.trust-list li{display:flex;align-items:center;gap:10px}
.trust-list svg{color:var(--accent);flex-shrink:0}
/* subnav anclas */
.pdp-nav{display:flex;gap:0;overflow-x:auto;scrollbar-width:none;
  background:var(--paper);border-top:1.5px solid var(--ink);border-bottom:1.5px solid var(--ink);margin-top:var(--c2)}
.pdp-nav::-webkit-scrollbar{display:none}
.pdp-nav a{font-family:var(--font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;
  padding:13px 18px;white-space:nowrap;border-right:1px dashed var(--line-2);color:var(--ink-2)}
.pdp-nav a:hover{background:var(--ink);color:var(--paper)}
/* secciones contenido */
.pdp-content{padding-top:var(--c2)}
.pdp-sec{padding-block:var(--c3);border-bottom:1px dashed var(--line-2)}
.pdp-sec>h2{margin-bottom:var(--c2)}
.usolist,.tiplist{list-style:none;padding:0;margin:0;display:grid;gap:12px}
@media(min-width:680px){.usolist{grid-template-columns:1fr 1fr}}
.usolist li,.tiplist li{position:relative;padding-left:30px;color:var(--ink-2);line-height:1.5}
.usolist li::before{content:"";position:absolute;left:0;top:7px;width:14px;height:14px;background:var(--accent);
  border:1.5px solid var(--ink)}
.tiplist li::before{content:"›";position:absolute;left:6px;top:-2px;font-family:var(--font-display);font-weight:800;
  font-size:1.3rem;color:var(--accent)}
/* acordeones */
details.acc{padding-block:0}
details.acc>summary{display:flex;align-items:center;justify-content:space-between;cursor:pointer;list-style:none;
  padding:var(--c3) 0}
details.acc>summary::-webkit-details-marker{display:none}
details.acc>summary h2{margin:0}
.chev{width:12px;height:12px;border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);
  transform:rotate(45deg);transition:transform .2s;flex-shrink:0}
details[open]>summary .chev{transform:rotate(-135deg)}
.faqlist{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.faqitem{border-bottom:1px solid var(--line)}
.faqitem>summary{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;
  list-style:none;padding:16px 0}
.faqitem>summary::-webkit-details-marker{display:none}
.faqitem h3{margin:0;font-family:var(--font-body);font-size:1rem;font-weight:600;text-transform:none;letter-spacing:0}
.faqitem p{margin:0 0 16px;color:var(--ink-2);max-width:72ch}
.faqitem .chev{width:10px;height:10px}
/* barra sticky compra (solo móvil) */
.buybar{position:fixed;left:0;right:0;bottom:0;z-index:55;display:none;align-items:center;gap:12px;
  background:var(--paper);border-top:1.5px solid var(--ink);box-shadow:0 -4px 0 rgba(23,23,15,.06);
  padding:10px 16px;padding-bottom:calc(10px + env(safe-area-inset-bottom))}
.buybar-info{display:flex;flex-direction:column;line-height:1.1}
.buybar-info strong{font-family:var(--font-display);font-size:1.3rem;font-weight:800}
.buybar-info small{font-family:var(--font-mono);font-size:.66rem;text-transform:uppercase;color:var(--c-green)}
.buybar form{flex:1;margin:0}.buybar .btn{width:100%}
@media(max-width:899px){
  .buybar{display:flex}
  body{padding-bottom:76px}
}

/* ---- ficha producto v3 (visual) ---- */
.spec-tiles{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin:var(--c2) 0 0;padding:0;
  border:1.5px solid var(--ink);background:var(--ink)}
.spec-tiles li{background:var(--card);padding:12px 14px;display:flex;flex-direction:column;gap:3px;outline:1px solid var(--line)}
.spec-tiles .st-k{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.spec-tiles .st-v{font-family:var(--font-display);font-weight:700;font-size:.98rem;letter-spacing:-.01em;line-height:1.1}
@media(max-width:520px){.spec-tiles{grid-template-columns:repeat(3,1fr)}.spec-tiles .st-v{font-size:.82rem}}
.pdp-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.chip{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.05em;
  text-transform:uppercase;padding:5px 11px;border:1.5px solid var(--ink)}
.chip-cat{background:var(--white)}.chip-cat:hover{background:var(--ink);color:var(--paper)}
.chip-brand{background:var(--accent);color:#fff}
.pdp-lead{color:var(--ink-2);font-size:1.02rem;line-height:1.55;margin:10px 0 0;max-width:52ch}
.pdp .pricebox{background:var(--card);border:1.5px solid var(--ink);box-shadow:6px 6px 0 var(--ink);padding:var(--c3);margin:var(--c3) 0}
.price-line{display:flex;align-items:baseline;flex-wrap:wrap;gap:10px}
.pdp .price-line .price{margin:0}
.price-old s{font-family:var(--font-mono);color:var(--ink-soft);font-size:1.1rem}
.price-tag{font-family:var(--font-mono);font-weight:700;font-size:.8rem;background:var(--accent);color:#fff;
  border:1.5px solid var(--ink);padding:3px 8px}
.price-vat{font-family:var(--font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);margin-left:auto}
.stockbar{height:7px;background:var(--line);border:1.5px solid var(--ink);margin:16px 0 8px;overflow:hidden}
.stockbar span{display:block;height:100%;background:var(--c-green)}
.stockbar.low span{background:var(--accent)}
.pdp .stock{font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;margin:0;color:var(--c-green)}
.pdp .stock.low{color:var(--accent-2)}
.delivery{display:flex;align-items:center;gap:9px;font-size:.9rem;color:var(--ink-2);margin:12px 0 0}
.delivery svg{color:var(--accent);flex-shrink:0}
.addform{margin-top:var(--c2)}
.addbtn{font-size:1.02rem;padding:15px 22px}
.ship-hint{font-family:var(--font-mono);font-size:.74rem;color:var(--ink-soft);text-align:center;margin:12px 0 0}
.trust-grid{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:1px;margin:var(--c3) 0 0;padding:0;
  border:1.5px solid var(--ink);background:var(--ink)}
.trust-grid li{background:var(--card);display:flex;align-items:center;gap:10px;padding:13px 14px;
  font-family:var(--font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.03em;color:var(--ink-2)}
.trust-grid svg{color:var(--accent);flex-shrink:0}
/* usos como tarjetas, tips numerados */
.usolist{counter-reset:none}
.usolist li{padding:14px 16px 14px 44px;background:var(--card);border:1.5px solid var(--ink);position:relative}
.usolist li::before{content:"";position:absolute;left:15px;top:17px;width:14px;height:14px;background:var(--accent);border:1.5px solid var(--ink)}
.tiplist{counter-reset:tip;display:block}
.tiplist li{counter-increment:tip;position:relative;padding:6px 0 6px 46px;margin-bottom:14px;min-height:32px;display:flex;align-items:center}
.tiplist li::before{content:counter(tip);position:absolute;left:0;top:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:800;background:var(--ink);color:var(--paper);font-size:1rem}
@media(min-width:900px){.pdp-buy{position:relative}}

/* filtro disponibles (toggle destacado) */
.filter-stock{display:flex;align-items:center;gap:9px;cursor:pointer;background:var(--white);border:1.5px solid var(--ink);
  padding:11px 12px;margin-bottom:18px;font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}
.filter-stock input{width:16px;height:16px;accent-color:var(--c-green);flex-shrink:0;margin:0}
.filter-stock .dotok{width:9px;height:9px;border-radius:50%;background:var(--c-green)}

/* contenedores de contenido con FONDO CLARO (panel) — ficha y categoría */
.pdp-content{display:flex;flex-direction:column;gap:var(--c2);padding-top:var(--c2)}
.pdp-content > .pdp-sec{background:var(--card);border:1.5px solid var(--ink);padding:var(--c3) var(--c4);margin:0}
.pdp-content > details.pdp-sec{padding:0 var(--c4)}
.pdp-content > details.pdp-sec > summary{padding:var(--c3) 0}
.cat-content{display:flex;flex-direction:column;gap:var(--c2);max-width:none;margin-top:var(--c5);border-top:0;padding-top:0}
.cat-content > .pdp-sec{background:var(--card);border:1.5px solid var(--ink);padding:var(--c3) var(--c4);margin:0}
.pdp-content .usolist li,.cat-content .usolist li{background:var(--white)}
@media(max-width:600px){
  .pdp-content > .pdp-sec,.cat-content > .pdp-sec{padding:var(--c2) var(--c3)}
  .pdp-content > details.pdp-sec{padding:0 var(--c3)}
}

/* ---- carrito / checkout ---- */
.cart-row{display:grid;grid-template-columns:64px 1fr auto;gap:var(--c2);align-items:center;padding:var(--c2) 0;border-bottom:1px dashed var(--line-2)}
.cart-row .thumb{background:var(--product-bg);border:1.5px solid var(--ink);padding:6px}
.summary{background:var(--card);border:1.5px solid var(--ink);box-shadow:6px 6px 0 var(--ink);padding:var(--c3);height:max-content}
.summary h2{font-size:1.1rem}
.summary .line{display:flex;justify-content:space-between;padding:9px 0;font-family:var(--font-mono);font-size:.86rem;border-bottom:1px dashed var(--line-2)}
.summary .total{font-family:var(--font-display);font-size:1.5rem;font-weight:800;border-bottom:0;margin-top:6px;padding-top:14px;border-top:1.5px solid var(--ink)}
.grid-2{display:grid;grid-template-columns:1fr;gap:var(--c4)}
@media(min-width:900px){.grid-2{grid-template-columns:1.4fr 1fr}}
.field{margin-bottom:var(--c2)}
.field label{display:block;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin-bottom:6px}
.field input,.field textarea{width:100%;background:var(--white);border:1.5px solid var(--ink);border-radius:var(--radius);padding:12px 14px;color:var(--ink);font-size:16px;font-family:var(--font-mono)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:3px 3px 0 var(--accent)}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--c2)}
.consent{display:flex;align-items:flex-start;gap:9px;font-size:.86rem;color:var(--ink-2);line-height:1.45;cursor:pointer}
.consent input{margin-top:3px;width:17px;height:17px;accent-color:var(--accent);flex-shrink:0}
.consent a{text-decoration:underline;color:var(--ink)}
.badge{display:inline-block;background:var(--white);color:var(--ink);border:1.5px solid var(--ink);padding:5px 14px;font-family:var(--font-mono);font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.notice{background:var(--white);border:1.5px solid var(--ink);border-left:5px solid var(--accent);padding:var(--c2) var(--c3);margin:var(--c2) 0;font-size:.92rem}
.pager{display:flex;align-items:center;justify-content:center;gap:var(--c3);margin-top:var(--c4);font-family:var(--font-mono);font-size:.8rem;text-transform:uppercase}
.empty{text-align:center;padding:var(--c6) 0;color:var(--ink-soft);font-family:var(--font-mono)}
.prose h2{font-size:1.1rem;margin-top:var(--c4);padding-bottom:8px;border-bottom:1px dashed var(--line-2)}
.prose h3{font-family:var(--font-mono);font-size:.86rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin-top:var(--c3)}
.prose p,.prose li{color:var(--ink-2);max-width:68ch;line-height:1.72}
.prose p{margin:0 0 1.1rem}.prose p:last-child{margin-bottom:0}
.prose ul{padding-left:1.2em}.prose li{margin-bottom:7px}
.prose strong{color:var(--ink);font-weight:700}
.prose .todo{background:#fff3cd;border:1px dashed var(--accent);padding:2px 6px;font-family:var(--font-mono);font-size:.85em}

/* "más vendidos" tira de USPs (datasheet strip) */
.strip{display:grid;grid-template-columns:repeat(2,1fr);border:1.5px solid var(--ink);background:var(--ink);gap:1px}
@media(min-width:768px){.strip{grid-template-columns:repeat(4,1fr)}}
.strip>div{background:var(--card);padding:var(--c3);display:flex;flex-direction:column;gap:4px}
.strip b{font-family:var(--font-display);text-transform:uppercase;font-size:1rem}
.strip small{font-family:var(--font-mono);font-size:.7rem;color:var(--ink-soft);letter-spacing:.04em}
/* por qué nosotros */
.why-grid{display:grid;grid-template-columns:1fr;gap:1px;border:1.5px solid var(--ink);background:var(--ink)}
@media(min-width:560px){.why-grid{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.why-grid{grid-template-columns:repeat(4,1fr)}}
.why-card{background:var(--card);padding:var(--c4) var(--c3)}
.why-card svg{width:32px;height:32px;color:var(--accent);margin-bottom:14px}
.why-card h3{font-family:var(--font-display);text-transform:uppercase;font-size:1.05rem;margin:0 0 8px;letter-spacing:-.01em}
.why-card p{color:var(--ink-2);font-size:.9rem;line-height:1.55;margin:0}
/* marcas */
.brands-strip{display:flex;flex-wrap:wrap;gap:10px}
.brand-chip{font-family:var(--font-mono);font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;
  border:1.5px solid var(--ink);background:var(--white);padding:9px 16px;transition:.15s}
.brand-chip:hover{background:var(--ink);color:var(--paper)}
/* CTA a medida (packs) */
.pack-cta{display:flex;align-items:center;justify-content:space-between;gap:var(--c4);flex-wrap:wrap;
  background:var(--card);border:1.5px solid var(--ink);box-shadow:8px 8px 0 var(--ink);padding:var(--c4) var(--c5);margin:var(--c5) 0 var(--c4)}
.pack-cta h2{margin:8px 0}
.pack-cta p{color:var(--ink-2);max-width:56ch;margin:0;line-height:1.55}
.pack-cta .btn{flex-shrink:0}
@media(max-width:760px){.pack-cta{padding:var(--c3)}}

/* ---- blog / guías ---- */
.guides-grid{display:grid;grid-template-columns:1fr;gap:var(--c3)}
@media(min-width:640px){.guides-grid{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.guides-grid{grid-template-columns:repeat(3,1fr)}}
.guide-card{background:var(--card);border:1.5px solid var(--ink);display:flex;flex-direction:column;transition:.16s;overflow:hidden}
.guide-card:hover{box-shadow:6px 6px 0 var(--ink);transform:translate(-2px,-2px);background:var(--white)}
.guide-thumb{border-bottom:1.5px solid var(--ink);aspect-ratio:360/210;display:flex;align-items:center;justify-content:center}
.guide-thumb,.guide-hero{background-color:var(--paper-2);
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-size:18px 18px}
.guide-illus{width:100%;height:100%;display:block}
/* sistema de ilustraciones técnicas (coherente en blog y hero) */
.il-fill{fill:var(--white);stroke:var(--ink);stroke-width:2.4;stroke-linejoin:round}
.il-ink{fill:none;stroke:var(--ink);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.il-cable{fill:none;stroke:var(--ink);stroke-width:5;stroke-linecap:round}
.il-dash{fill:none;stroke:var(--ink);stroke-width:2.2;stroke-dasharray:6 5;stroke-linecap:round}
.il-acc{fill:var(--accent)}
.il-acc-s{fill:none;stroke:var(--accent);stroke-width:2.8;stroke-linecap:round;stroke-linejoin:round}
.il-pin{stroke:#c8a23a;stroke-width:2.6;stroke-linecap:round}
.il-lbl{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;fill:var(--ink-soft)}
.guide-body{padding:var(--c3);display:flex;flex-direction:column;gap:8px;flex:1}
.guide-body h2,.guide-body h3{font-family:var(--font-display);font-size:1.1rem;margin:2px 0 0;text-transform:none;letter-spacing:-.01em;line-height:1.2}
.guide-body p{color:var(--ink-2);font-size:.9rem;line-height:1.5;margin:0;flex:1}
.guide-more{font-family:var(--font-mono);font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);font-weight:600}
.guide{max-width:760px;margin:0 auto;padding-top:var(--c2)}
.guide-head h1{margin-top:10px}
.guide-hero{background:var(--paper-2);border:1.5px solid var(--ink);box-shadow:6px 6px 0 var(--ink);margin:var(--c3) 0 var(--c4);aspect-ratio:360/190;overflow:hidden}
.guide-content h2{font-size:1.35rem;margin-top:var(--c4)}
.guide-content h3{font-size:1.02rem;margin-top:var(--c3)}
.guide-content p,.guide-content li{max-width:none}
.guide-cta{display:flex;align-items:center;justify-content:space-between;gap:var(--c3);flex-wrap:wrap;
  background:var(--card);border:1.5px solid var(--ink);box-shadow:5px 5px 0 var(--accent);padding:var(--c3);margin:var(--c4) 0}
.guide-cta p{margin:4px 0 0;font-size:.9rem}
.guide-cta .btn{flex-shrink:0}
@media(max-width:600px){.guide-cta .btn{width:100%}}

/* ===================== FOOTER ===================== */
.site-footer{border-top:1.5px solid var(--ink);background:var(--paper-2);margin-top:var(--c6)}
.footer-trust{display:flex;flex-wrap:wrap;gap:10px var(--c3);padding-block:var(--c3);border-bottom:1px dashed var(--line-2);
  font-family:var(--font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-2)}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--c4) var(--c2);padding-block:var(--c5) var(--c4)}
@media(min-width:768px){.footer-grid{grid-template-columns:2.2fr 1fr 1fr 1fr 1fr;gap:var(--c4)}}
.footer-brand{grid-column:1/-1}
@media(min-width:768px){.footer-brand{grid-column:auto}}
.footer-brand .muted{max-width:42ch;margin:12px 0}
.footer-mail a{font-family:var(--font-mono);font-weight:600;border-bottom:2px solid var(--accent)}
.footer-mail{font-size:.86rem;margin:0}
.site-footer h3{font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft);margin-bottom:var(--c2);border-bottom:1px dashed var(--line-2);padding-bottom:8px}
.site-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;font-family:var(--font-mono);font-size:.82rem}
.site-footer a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:var(--c2);flex-wrap:wrap;border-top:1.5px solid var(--ink);padding-block:var(--c3);font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
.legal-links{display:flex;gap:var(--c2)}

.toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,160%);z-index:80;background:var(--ink);color:var(--paper);
  border:1.5px solid var(--ink);box-shadow:5px 5px 0 var(--accent);padding:13px 20px;font-family:var(--font-mono);
  font-size:.86rem;display:flex;gap:16px;align-items:center;transition:transform .35s cubic-bezier(.2,.85,.2,1);max-width:92vw}
.toast.show{transform:translate(-50%,0)}
.toast a{color:var(--c-yellow);font-weight:700;white-space:nowrap}
@media(max-width:899px){.toast{left:16px;right:16px;bottom:88px;transform:translateY(180%)}.toast.show{transform:translateY(0)}}
#toTop{position:fixed;right:18px;bottom:18px;z-index:40;width:46px;height:46px;border:1.5px solid var(--ink);background:var(--accent);color:#fff;font-size:1.2rem;cursor:pointer;box-shadow:3px 3px 0 var(--ink)}
#toTop:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}

/* ---- mini-carrito lateral (drawer) ---- */
body.no-scroll{overflow:hidden}
.drawer-overlay{position:fixed;inset:0;background:rgba(23,23,15,.5);z-index:90;opacity:0;transition:opacity .3s}
.drawer-overlay.show{opacity:1}
.drawer-overlay[hidden]{display:none}
.minicart{position:fixed;top:0;right:0;height:100%;width:min(420px,94vw);background:var(--paper);border-left:1.5px solid var(--ink);
  z-index:91;transform:translateX(101%);transition:transform .32s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 0 var(--ink)}
.minicart.show{transform:translateX(0)}
.mc-body{display:flex;flex-direction:column;height:100%;overflow:hidden}
.mc-head{display:flex;align-items:center;justify-content:space-between;padding:var(--c3);border-bottom:1.5px solid var(--ink);flex-shrink:0}
.mc-head h2{margin:0;font-size:1.15rem}
.mc-close{background:none;border:0;font-size:1.7rem;line-height:1;cursor:pointer;color:var(--ink);padding:0 4px}
.mc-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;color:var(--ink-soft);font-family:var(--font-mono);padding:var(--c5) var(--c3)}
.mc-items{flex:1;overflow-y:auto;padding:0 var(--c3)}
.mc-row{display:grid;grid-template-columns:56px 1fr auto;gap:12px;padding:var(--c3) 0;border-bottom:1px dashed var(--line-2)}
.mc-img{background:var(--product-bg);border:1.5px solid var(--ink);padding:4px;align-self:start;width:56px;height:56px;display:flex;align-items:center;justify-content:center}
.mc-img img{max-width:100%;max-height:100%;object-fit:contain;mix-blend-mode:multiply}
.mc-name{font-weight:500;font-size:.88rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mc-name:hover{color:var(--accent)}
.mc-meta{font-family:var(--font-mono);font-size:.74rem;color:var(--ink-soft);margin:3px 0 7px}
.mc-qty{display:flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:.84rem}
.mc-qty button{width:27px;height:27px;border:1.5px solid var(--ink);background:var(--white);cursor:pointer;font-size:1rem;line-height:1}
.mc-qty button:hover{background:var(--ink);color:var(--paper)}
.mc-del{width:auto;height:auto;border:0;background:none;color:var(--ink-soft);font-size:.74rem;text-decoration:underline;margin-left:6px;font-family:var(--font-mono);cursor:pointer}
.mc-del:hover{color:var(--accent)}
.mc-line{font-family:var(--font-display);font-weight:800;white-space:nowrap;font-size:1rem}
.mc-foot{border-top:1.5px solid var(--ink);padding:var(--c3);background:var(--card);flex-shrink:0}
.mc-foot .ship-progress{margin-bottom:var(--c2)}
.mc-totals{margin-bottom:var(--c2)}
.mc-totals .line{display:flex;justify-content:space-between;padding:5px 0;font-family:var(--font-mono);font-size:.86rem}
.mc-totals .total{font-family:var(--font-display);font-size:1.35rem;font-weight:800;border-top:1.5px solid var(--ink);margin-top:6px;padding-top:11px}
@media(max-width:480px){.minicart{width:100vw}}

/* cookies */
.cookies[hidden]{display:none}
.cookies{position:fixed;left:16px;right:16px;bottom:16px;z-index:60;background:var(--ink);color:var(--paper);
  border:1.5px solid var(--ink);box-shadow:6px 6px 0 var(--accent);padding:var(--c2) var(--c3);
  display:flex;gap:var(--c2);align-items:center;justify-content:space-between;flex-wrap:wrap;font-size:.86rem}
.cookies p{margin:0;max-width:60ch}
.cookies .btn{border-color:var(--paper);color:var(--paper)}
.cookies .btn-primary{background:var(--accent);border-color:var(--paper);color:#fff;box-shadow:none}
@media(max-width:600px){.cookies{flex-direction:column;align-items:stretch}}

/* ── Marcas (hub + silo) ─────────────────────────────────────── */
.brand-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--c2);margin-top:var(--c3)}
.brand-card{display:flex;flex-direction:column;gap:6px;padding:20px 22px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius);text-decoration:none;color:var(--ink);
  position:relative;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}
.brand-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);
  border-radius:var(--radius) 0 0 var(--radius)}
.brand-card:hover{border-color:var(--line-2);transform:translateY(-2px);box-shadow:0 6px 18px rgba(23,23,15,.08)}
.brand-name{font-weight:700;font-size:1.08rem;letter-spacing:.01em}
.brand-count{font-family:var(--font-mono);font-size:.78rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em}
.brand-go{margin-top:6px;font-family:var(--font-mono);font-size:.76rem;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}
.brand-cats{margin:18px 0 4px}
a.chip-brand:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ── Descuento por volumen (ficha) ───────────────────────────── */
.volbox{margin-top:16px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper-2);padding:14px 16px}
.volbox-h{margin:0 0 10px;font-weight:700;font-size:.92rem}
.volbox-h span{font-weight:400;color:var(--ink-soft);font-size:.82rem}
.voltiers{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.voltier{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 10px;border-radius:var(--radius);
  font-family:var(--font-mono);font-size:.86rem;border:1px solid transparent;transition:background .15s ease,border-color .15s ease}
.voltier .vq{color:var(--ink-2);text-transform:uppercase;letter-spacing:.03em}
.voltier .vp{font-weight:700}
.voltier .vp em{font-style:normal;color:var(--accent);margin-left:6px;font-size:.8rem}
.voltier.is-active{background:var(--white);border-color:var(--line-2);box-shadow:inset 3px 0 0 var(--accent)}
/* badge de ahorro por volumen en carrito */
.vol-badge{display:inline-block;margin-left:8px;padding:2px 7px;border-radius:999px;background:var(--accent);color:#fff;
  font-family:var(--font-mono);font-size:.7rem;font-weight:700;letter-spacing:.03em;vertical-align:middle}

/* ── Carrito mejorado ────────────────────────────────────────── */
.cart-layout{align-items:start}
.cart-items{display:flex;flex-direction:column}
.cart-thumb{padding:6px;align-self:start}
.cart-thumb img{width:64px;height:64px;object-fit:contain;display:block;mix-blend-mode:multiply}
.cart-info{min-width:0}
.cart-name{font-weight:600;color:var(--ink);text-decoration:none;line-height:1.32;display:block}
.cart-name:hover{color:var(--accent)}
.cart-sub{margin:5px 0 0;font-size:.84rem;color:var(--ink-soft);display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.cart-stepper{display:inline-flex;align-items:center;border:1.5px solid var(--ink);margin-top:10px;width:max-content;background:var(--white)}
.cart-stepper button{width:32px;height:32px;border:0;background:var(--paper-2);color:var(--ink);font-size:1.05rem;cursor:pointer;line-height:1;transition:background .15s,color .15s}
.cart-stepper button:hover{background:var(--ink);color:var(--paper)}
.cart-stepper input{width:46px;height:32px;text-align:center;border:0;border-left:1.5px solid var(--ink);border-right:1.5px solid var(--ink);background:var(--white);color:var(--ink);font-family:var(--font-mono);font-size:.9rem}
.cart-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;text-align:right}
.cart-line{font-size:1.05rem;font-family:var(--font-mono)}
.cart-was{font-size:.78rem;color:var(--ink-soft);text-decoration:line-through;font-family:var(--font-mono)}
.cart-remove{border:0;background:none;color:var(--ink-soft);cursor:pointer;font-size:.78rem;padding:2px 0;font-family:var(--font-mono);letter-spacing:.02em}
.cart-remove:hover{color:var(--accent)}
.cart-keep{display:inline-block;margin-top:18px;font-family:var(--font-mono);font-size:.84rem;color:var(--ink-2);text-decoration:none}
.cart-keep:hover{color:var(--accent)}
.cart-honest{margin:10px 0;font-size:.82rem;line-height:1.5}
.sum-vat{margin:6px 0 0;text-align:right;font-size:.76rem;color:var(--ink-soft);font-family:var(--font-mono)}
.sum-cta{margin-top:16px;font-size:1.02rem}
.sum-secure{margin-top:12px;display:flex;align-items:center;justify-content:center;gap:7px;font-size:.78rem;color:var(--ink-soft);font-family:var(--font-mono)}
.sum-trust{list-style:none;margin:16px 0 0;padding:14px 0 0;border-top:1.5px dashed var(--line-2);display:flex;flex-direction:column;gap:10px;font-size:.83rem;color:var(--ink-2)}
.sum-trust li{display:flex;gap:10px;align-items:center}
.sum-trust svg{flex:none;color:var(--accent)}
/* estado vacío */
.cart-empty{text-align:center;padding:var(--c6) var(--c2);color:var(--ink-soft)}
.cart-empty svg{color:var(--line-2)}
.cart-empty p{margin:14px 0 0;font-size:1.05rem;color:var(--ink)}
.cart-empty p.muted{font-size:.9rem;color:var(--ink-soft)}
.cart-empty-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:22px}

/* ── Móvil: compactar + 100% responsive (sin recortes ni scroll horizontal) ── */
@media(max-width:640px){
  /* Barra superior: el segundo texto se recortaba (nowrap+overflow). Dejamos solo
     el claim de envío, centrado y sin clip. */
  .util .container{justify-content:center;gap:0;overflow:visible;white-space:normal;text-align:center;line-height:1.45}
  .util .container span:first-child{display:none}
  /* Hero: métricas en 3 columnas iguales que siempre caben (antes auto -> desbordaba) */
  .hero-spec{grid-template-columns:repeat(3,1fr);gap:var(--c2) var(--c1);justify-content:stretch}
  .hero-spec>div{min-width:0}
  .hero-spec .k{font-size:1.3rem}
  .hero-spec .l{font-size:.58rem;letter-spacing:.05em}
  .hero p.lead{font-size:1rem}
  /* Cabeceras de sección: que el enlace baje en vez de apretar el título */
  .sec-head{flex-wrap:wrap;align-items:start}
  /* Respiración algo más compacta en bloques */
  .block{padding-block:var(--c4)}
  /* Tabla de volumen y resúmenes: nada se sale */
  .voltier{font-size:.8rem}
  .summary{padding:var(--c2)}
}
@media(max-width:380px){
  .hero-spec{grid-template-columns:repeat(2,1fr)}
  .spec-tiles{grid-template-columns:repeat(2,1fr)}
  .cart-row{grid-template-columns:56px 1fr auto;gap:var(--c1)}
  .logo-text{font-size:1.05rem}
}
/* Salvaguarda universal anti-desborde (imágenes ya cubiertas; añadimos media y tablas) */
svg,video,table,iframe{max-width:100%}

/* ============================================================
   VIDANAT skin — capa final que reconvierte la base "blueprint"
   en herbolario cálido (sombras suaves, esquinas redondeadas,
   sin mayúsculas datasheet ni crosshairs). Overrides intencionados.
   ============================================================ */

/* — Botones — */
.btn{border-radius:999px;text-transform:none;letter-spacing:0;font-weight:600;font-family:var(--font-body)}
.btn-primary{box-shadow:var(--shadow-sm);border-color:var(--accent);background:var(--accent)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-ghost{border-color:var(--line-2)}
.btn-ghost:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* — Barra superior: verde cálido en vez de negro — */
.util{background:var(--accent);color:#fff;letter-spacing:.03em;text-transform:none;font-size:.74rem}
.util b{color:#fff;text-decoration:underline}

/* — Header / buscador / logo — */
.site-header{border-bottom:1px solid var(--line)}
.search{border:1.5px solid var(--line-2);border-radius:999px;overflow:hidden}
.search input{font-family:var(--font-body);text-transform:none}
.search button{background:var(--accent)}
.search button:hover{background:var(--accent-2)}
.logo-text{text-transform:none;letter-spacing:-.01em;font-weight:700;font-size:1.5rem}
.logo-text strong{color:var(--accent)}
.cart-count{border:0;border-radius:999px;background:var(--accent)}

/* — Navegación — */
.mainnav{border-top:1px solid var(--line)}
.navgroup-btn,.navall{text-transform:none;letter-spacing:0;font-family:var(--font-body);font-size:.95rem}
.navgroup-btn{color:var(--ink-2);border-right:1px solid var(--line)}
.navgroup-btn:hover{background:var(--accent);color:#fff}
.navdrop{border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}
.navdrop b{font-family:var(--font-display);text-transform:none}
.navdrop span{font-family:var(--font-body)}
.navpacks{color:var(--accent)}
.navpacks:hover{background:var(--accent)!important;color:#fff!important}
.navall{color:var(--accent);font-weight:600}

/* — Crosshairs / marcas técnicas fuera — */
.reg::before,.reg::after{display:none}
.card .thumb::before,.card .thumb::after{display:none}

/* — Hero: glow verde, sin retícula — */
.hero{background:linear-gradient(180deg,var(--paper-2),var(--paper))}
.hero::before{background:
  radial-gradient(900px 460px at 82% -8%,rgba(47,125,79,.14),transparent 60%),
  radial-gradient(680px 400px at 8% 112%,rgba(58,143,79,.10),transparent 60%)}
.hero-grid{display:none}
.hero .eyebrow{border-radius:999px;border-color:var(--line-2);background:var(--white)}
.hero h1,.slide-title{text-transform:none;letter-spacing:-.015em;font-weight:600}
.hero h1 em,.slide-title em{color:var(--accent);font-style:italic}
.hero-art{border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow)}
.hero-dots button.active{background:var(--accent)}
.hero-arrow{border:1px solid var(--line);border-radius:999px;box-shadow:var(--shadow-sm)}
.hero-arrow:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* — Tarjeta de producto — */
.card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px);background:var(--card)}
.card .cardtab{text-transform:none;letter-spacing:.01em;border-bottom:1px solid var(--line)}
.card .cardtab .dot{border:0;border-radius:50%}
.card .body{border-top:1px solid var(--line)}
.card .brand{letter-spacing:.05em}
.card .price{font-family:var(--font-display);font-weight:700}
.iconbtn{background:var(--accent);border-radius:10px}
.iconbtn:hover{background:var(--accent-2)}

/* — Categorías (cards) — */
.cat-card b{text-transform:none}

/* — Listado / filtros / breadcrumb — */
.filters{border:1px solid var(--line);border-radius:var(--radius)}
.filters select{border:1px solid var(--line-2);border-radius:10px;font-family:var(--font-body)}
.filters label,.filters .fhead{font-family:var(--font-body)}
.filters-toggle{background:var(--accent)!important;border-radius:10px;text-transform:none!important;letter-spacing:0!important}
.breadcrumb,.toolbar{font-family:var(--font-body);text-transform:none;letter-spacing:0}
.rel-links a{border:1px solid var(--line-2);border-radius:999px;text-transform:none;letter-spacing:0;font-family:var(--font-body)}
.rel-links a:hover{background:var(--accent);border-color:var(--accent)}
.shop-h2,.cat-content{border-color:var(--line)}

/* — Ficha de producto — */
.pdp .gallery{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.pdp .brand{font-family:var(--font-body);letter-spacing:.06em}

/* — Packs / kits — */
.pack-card,.pack-card--mini{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.packs-grid>.pack-card:hover,.pack-card--mini:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.pack-badge{border:0;box-shadow:none;border-radius:999px;font-family:var(--font-display)}
.pack-tag{border-radius:999px}
.pack-card--mini h3,.pack-titles h2{text-transform:none;font-family:var(--font-display)}
.pp-now{font-family:var(--font-display)}
.pp-save{border:0;border-radius:999px}

/* — Ofertas flash — */
.flash-badge{border:0;box-shadow:none;border-radius:999px}
.ft-c{border:0;border-radius:8px}

/* — Autocompletar buscador — */
.ac-box{border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}
.ac-all{text-transform:none;letter-spacing:0;color:var(--accent)}

/* — Grid de categorías: tarjetas individuales (sin "patch panel" oscuro) — */
.cat-grid{background:transparent;border:0;gap:var(--c2);
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.cat-card{outline:0;border:1px solid var(--line);border-radius:var(--radius);background:var(--card)}
.cat-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.cat-card .port{height:6px;border-radius:999px;margin-bottom:16px}
.cat-card:nth-child(6n+1) .port{background:#3a8f4f}
.cat-card:nth-child(6n+2) .port{background:#2f7d4f}
.cat-card:nth-child(6n+3) .port{background:#caa23a}
.cat-card:nth-child(6n+4) .port{background:#7cb342}
.cat-card:nth-child(6n+5) .port{background:#56a86a}
.cat-card:nth-child(6n+6) .port{background:#246340}
.cat-card .ix{color:var(--line-2)}
/* secciones: separador suave */
.sec-head{border-bottom:1px solid var(--line)}
.sec-head .tag{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-weight:600}
.sec-head a{font-family:var(--font-body);text-transform:none;letter-spacing:0}

/* — Chips de subcategoría (categoría) — */
.subchips{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 var(--c4)}
.subchip{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border:1px solid var(--line-2);
  border-radius:999px;font-size:.9rem;color:var(--ink-2);background:var(--card);transition:.15s}
.subchip span{font-size:.74rem;color:var(--ink-soft);background:var(--paper);border-radius:999px;padding:1px 7px;font-variant-numeric:tabular-nums}
.subchip:hover{border-color:var(--accent);color:var(--accent)}
.subchip.is-active{background:var(--accent);border-color:var(--accent);color:#fff}
.subchip.is-active span{background:rgba(255,255,255,.22);color:#fff}

/* ============================================================
   VIDANAT skin · v2 — completar el paso a herbolario cálido.
   Convierte lo que quedaba "blueprint": sombras duras offset,
   bordes negros gruesos, rejillas patch-panel oscuras, mayúsculas
   datasheet y hovers que invertían a negro. Todo a suave/orgánico.
   ============================================================ */

/* — Anillo de foco suave global (sustituye sombras duras de foco) — */
.field input:focus,.field textarea:focus,.filters select:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(47,125,79,.16)}

/* — Inputs / labels más cálidos — */
.field input,.field textarea{border:1.5px solid var(--line-2);font-family:var(--font-body)}
.field label{font-family:var(--font-body);text-transform:none;letter-spacing:0;font-size:.82rem;
  font-weight:600;color:var(--ink-2)}

/* — Cajas de precio / compra (ficha) — */
.buybox,.pricebox,.pdp .pricebox{border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);background:var(--card)}
.price-tag,.pp-save{border:0;border-radius:999px}
.price-old s,.price.flash s{font-family:var(--font-body)}
.stockbar{border:0;border-radius:999px;background:var(--line);height:6px}
.stockbar span{border-radius:999px}

/* — Selector de cantidad (qty / stepper / mini-cart) — */
.qty,.cart-stepper{border:1.5px solid var(--line-2);border-radius:999px;overflow:hidden}
.qty button,.cart-stepper button,.mc-qty button{background:var(--paper-2);color:var(--ink);transition:.15s}
.qty button:hover,.cart-stepper button:hover,.mc-qty button:hover{background:var(--accent);color:#fff}
.cart-stepper input{border-left:1px solid var(--line);border-right:1px solid var(--line)}
.mc-qty button{border:1px solid var(--line-2);border-radius:8px}

/* — Subnav anclas ficha — */
.pdp-nav{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper-2)}
.pdp-nav a{border-right:1px solid var(--line);text-transform:none;letter-spacing:0;font-family:var(--font-body)}
.pdp-nav a:hover{background:var(--accent);color:#fff}

/* — Chips de características — */
.chip,.chiprow li{border:1px solid var(--line-2);border-radius:999px;background:var(--white)}
.chip-brand{background:var(--accent);border-color:var(--accent);color:#fff}

/* — Listas de usos / tips (ficha) — */
.usolist li{border:1px solid var(--line);border-radius:var(--radius);background:var(--card)}
.usolist li::before{border:0;border-radius:50%}
.tiplist li::before{background:var(--accent);border-radius:50%}

/* — Rejillas "patch-panel" → tarjetas suaves con aire — */
.strip,.why-grid,.spec-tiles,.trust-grid{background:transparent;border:0;gap:var(--c2)}
.strip>div,.why-card,.spec-tiles li,.trust-grid li{
  border:1px solid var(--line);border-radius:var(--radius);outline:0;background:var(--card)}
.spec-tiles li{padding:13px 15px}
.strip b,.why-card h3{text-transform:none;font-family:var(--font-display)}
.spec-tiles .st-k,.trust-grid li{text-transform:none;letter-spacing:.01em}
.spec-tiles .st-k{letter-spacing:.04em}

/* — Marcas (chips) — */
.brand-chip{border:1px solid var(--line-2);border-radius:999px;text-transform:none;letter-spacing:0;
  font-family:var(--font-body)}
.brand-chip:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* — CTAs grandes (packs / guías) — */
.pack-cta,.guide-cta{border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm)}

/* — Guías / blog — */
.guide-card{border:1px solid var(--line);border-radius:var(--radius)}
.guide-card:hover{box-shadow:var(--shadow);transform:translateY(-3px);background:var(--card)}
.guide-thumb{border-bottom:1px solid var(--line)}
.guide-thumb,.guide-hero{background-image:none;background:linear-gradient(160deg,var(--paper-2),#eef1e6)}
.guide-hero{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.guide-body h2,.guide-body h3{text-transform:none}
.guide-more{text-transform:none;letter-spacing:0;font-family:var(--font-body)}

/* — Avisos / badges — */
.badge{border:1px solid var(--line-2);border-radius:999px;text-transform:none;letter-spacing:0;
  font-family:var(--font-body);background:var(--paper-2)}
.notice{border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:var(--radius)}

/* — Resumen carrito / checkout — */
.summary{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.summary .total{border-top:1px solid var(--line)}
.cart-row .thumb,.cart-thumb,.mc-img,.pack-thumbs .pt{border:1px solid var(--line);border-radius:10px}
.sum-trust{border-top:1px dashed var(--line)}

/* — Sticky de compra (móvil) — */
.buybar{border-top:1px solid var(--line);box-shadow:0 -6px 24px rgba(35,49,31,.08)}
.buybar-info small{text-transform:none;letter-spacing:0;font-family:var(--font-body)}

/* — Overlays: toast, volver arriba, cookies, mini-cart — */
.toast{border:0;border-radius:14px;box-shadow:var(--shadow)}
#toTop{border:0;border-radius:50%;box-shadow:var(--shadow)}
#toTop:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.cookies{border:0;border-radius:16px;box-shadow:var(--shadow)}
.minicart{border-left:1px solid var(--line);box-shadow:-12px 0 40px rgba(35,49,31,.12)}
.mc-head,.mc-foot{border-color:var(--line)}
.mc-totals .total{border-top:1px solid var(--line)}

/* — Footer — */
.site-footer{border-top:1px solid var(--line)}
.footer-bottom{border-top:1px solid var(--line);text-transform:none;letter-spacing:0;font-family:var(--font-body)}
.site-footer h3{font-family:var(--font-body);text-transform:none;letter-spacing:0;font-size:.8rem;
  font-weight:700;color:var(--ink);border-bottom:1px solid var(--line)}
.site-footer ul,.footer-trust{font-family:var(--font-body);text-transform:none;letter-spacing:0}
.footer-mail a{font-family:var(--font-body)}

/* — Tabla de specs (ficha) más suave — */
.specs td{border-bottom:1px solid var(--line)}
.usp{text-transform:none;letter-spacing:0;font-family:var(--font-body)}

/* — Filtro instantáneo dentro de categoría grande — */
.grid-find{display:flex;align-items:center;gap:10px;background:var(--white);border:1.5px solid var(--line-2);
  border-radius:999px;padding:10px 16px;margin:0 0 var(--c2)}
.grid-find svg{color:var(--ink-soft);flex-shrink:0}
.grid-find input{flex:1;border:0;background:transparent;font-size:16px;font-family:var(--font-body);color:var(--ink);min-width:0}
.grid-find input:focus{outline:none}
.grid-find:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(47,125,79,.14)}
.linklike{background:none;border:0;color:var(--accent);font:inherit;cursor:pointer;text-decoration:underline;padding:0}
.prod-grid .card[hidden]{display:none}
