/* ============================================================
   AGROLED — Sistema de diseño premium "Grow Room"
   Paleta: ink violeta + lima ácido (CTA) + firma de espectro LED
   ============================================================ */
:root{
  /* Paleta "Grow Room": ink violeta + lima ácido + espectro LED */
  --bg:#14111f;        --bg-1:#1e1834;       --surface:#272039;     --surface-2:#322a48;
  --line:#3c3457;      --line-2:#4f4470;
  --text:#f3f1f8;      --muted:#a7a1bd;      --muted-2:#6f6889;
  --accent:#c2f04a;    --accent-2:#b1e636;   --accent-rgb:194,240,74;  --accent-soft:rgba(194,240,74,.13);  --ink:#16230a;
  --amber:#fbbf24;
  --hot:#fb6aa3;       --hot-soft:rgba(251,106,163,.15);
  --danger:#fb7185;
  --spectrum:linear-gradient(100deg,#8b5cf6,#d946ef,#fb6aa3,#fbbf24,#c2f04a);
  --radius:16px; --radius-sm:11px; --radius-lg:26px; --pill:999px;
  --shadow:0 18px 50px -12px rgba(0,0,0,.62);
  --shadow-sm:0 6px 20px -6px rgba(0,0,0,.5);
  --glow:0 0 36px rgba(var(--accent-rgb),.32);
  --wrap:1200px;
  --s1:.875rem; --s0:1rem; --s2:1.125rem; --s3:1.4rem; --s4:1.85rem;
  --s5:2.4rem; --s6:clamp(2.6rem,5.5vw,4.4rem);
  --ff:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --fd:'Sora',var(--ff);
  --fast:.16s ease; --med:.28s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--ff);background:var(--bg);color:var(--text);font-size:var(--s0);line-height:1.6;
  -webkit-font-smoothing:antialiased;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--fd);line-height:1.12;font-weight:700;letter-spacing:-.02em}
main{flex:1}
.wrap{width:min(var(--wrap),90%);margin-inline:auto}
.narrow{width:min(820px,92%);margin-inline:auto}
.muted{color:var(--muted)}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:6px}
.skip-link{position:absolute;left:-999px;top:0;background:var(--accent);color:var(--ink);padding:.6rem 1rem;z-index:300;font-weight:700}
.skip-link:focus{left:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
[hidden]{display:none!important}
.kicker{display:inline-block;font-family:var(--ff);font-weight:700;font-size:var(--s1);letter-spacing:.12em;text-transform:uppercase;
  background:var(--spectrum);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:.5rem}
.kicker--amber{background:none;color:var(--hot)}
.stars{color:var(--amber);letter-spacing:2px;font-size:.95rem}
.stars--sm{font-size:.85rem}.stars--sm small{color:var(--muted);font-size:.75rem}

/* ---------- Botones ---------- */
.btn{--bg-b:var(--surface-2);--fg-b:var(--text);--bd-b:var(--line-2);
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--ff);
  background:var(--bg-b);color:var(--fg-b);border:1px solid var(--bd-b);padding:.72rem 1.25rem;border-radius:var(--pill);
  font-weight:700;font-size:var(--s0);cursor:pointer;line-height:1;white-space:nowrap;
  transition:transform var(--fast),background var(--fast),border-color var(--fast),box-shadow var(--fast)}
.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0)}
.btn--primary{--bg-b:var(--accent);--fg-b:var(--ink);--bd-b:transparent;box-shadow:0 8px 24px -6px rgba(var(--accent-rgb),.5)}
.btn--primary:hover{--bg-b:var(--accent-2);box-shadow:0 12px 30px -6px rgba(var(--accent-rgb),.65)}
.btn--ghost{--bg-b:transparent;--bd-b:var(--line-2)}
.btn--ghost:hover{--bd-b:var(--accent);--fg-b:var(--accent)}
.btn--glass{--bg-b:rgba(255,255,255,.06);--bd-b:rgba(255,255,255,.16);backdrop-filter:blur(8px)}
.btn--glass:hover{--bd-b:var(--accent);--fg-b:var(--accent)}
.btn--lg{padding:1rem 1.8rem;font-size:var(--s2)}
.btn--sm{padding:.5rem .9rem;font-size:var(--s1)}
.btn--block{width:100%}
.btn--disabled{opacity:.5;cursor:not-allowed;--bg-b:var(--surface-2)}
.btn--add{--bg-b:var(--accent-soft);--fg-b:var(--accent);--bd-b:transparent;width:46px;height:46px;padding:0;border-radius:13px}
.btn--add:hover{--bg-b:var(--accent);--fg-b:var(--ink)}
.btn--buy{flex:1}
.link{color:var(--accent);font-weight:700}.link:hover{text-decoration:underline}

/* ---------- Announce bar ---------- */
.announce{background:linear-gradient(90deg,#140f24,#0c0a16);border-bottom:1px solid var(--line);overflow:hidden}
.announce__track{display:flex;gap:3rem;padding:.55rem 0;font-size:var(--s1);color:var(--muted);white-space:nowrap;
  animation:marq 26s linear infinite;width:max-content}
.announce__track span{display:inline-flex;align-items:center}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(20,17,31,.82);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.header__in{display:flex;align-items:center;gap:1.4rem;padding:.9rem 0}
.brand{display:inline-flex;align-items:center;gap:.65rem;flex-shrink:0}
.brand img{border-radius:11px}
.brand__txt{font-family:var(--fd);font-weight:800;font-size:var(--s3);letter-spacing:.02em}
.brand__txt span{color:var(--accent)}
.search{flex:1;display:flex;align-items:center;gap:.4rem;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--pill);padding:.3rem .35rem .3rem 1rem;transition:border-color var(--fast),box-shadow var(--fast)}
.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.search__ico{color:var(--muted-2);flex-shrink:0}
.search input{flex:1;background:none;border:0;color:var(--text);padding:.5rem .2rem;font:inherit;outline:none;min-width:0}
.search button{border:0;border-radius:var(--pill);background:var(--accent);color:var(--ink);font-weight:700;padding:.55rem 1.2rem;cursor:pointer;flex-shrink:0;transition:background var(--fast)}
.search button:hover{background:var(--accent-2)}
.header__actions{display:flex;align-items:center;gap:.5rem}
.iconbtn{position:relative;display:grid;place-items:center;width:46px;height:46px;border-radius:13px;border:1px solid var(--line-2);color:var(--text);transition:border-color var(--fast),color var(--fast),background var(--fast)}
.iconbtn:hover{border-color:var(--accent);color:var(--accent)}
.cart-link:hover{background:var(--accent-soft)}
.cart-count{position:absolute;top:-5px;right:-5px;min-width:20px;height:20px;padding:0 5px;background:var(--accent);color:var(--ink);border-radius:var(--pill);font-size:.7rem;font-weight:800;display:grid;place-items:center;box-shadow:var(--glow)}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:46px;height:46px;background:none;border:1px solid var(--line-2);border-radius:13px;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span{width:20px;height:2px;background:var(--text);border-radius:2px;transition:var(--fast)}
.mainnav{border-top:1px solid var(--line);overflow-x:auto;scrollbar-width:none}
.mainnav::-webkit-scrollbar{display:none}
.mainnav__in{display:flex;gap:.3rem;padding:.35rem 0}
.mainnav a{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .9rem;border-radius:9px;font-size:var(--s1);font-weight:600;color:var(--muted);white-space:nowrap;transition:background var(--fast),color var(--fast)}
.mainnav a:hover{background:var(--surface);color:var(--text)}
.mainnav__all{color:var(--text)!important}
.mainnav__hot{color:var(--hot)!important}
.nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:110;backdrop-filter:blur(2px)}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);
  background:#14111f url("/assets/img/hero-bg.svg") center/cover no-repeat;
  background-attachment:fixed}
.hero__glow{position:absolute;inset:0;background:
  radial-gradient(700px 380px at 78% -8%,rgba(124,58,237,.22),transparent 60%),
  radial-gradient(680px 420px at 92% 30%,rgba(var(--accent-rgb),.18),transparent 62%),
  radial-gradient(500px 300px at 50% 120%,rgba(219,39,119,.12),transparent 60%);pointer-events:none}
.hero__in{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:2.6rem;align-items:center;padding:clamp(4rem,8.5vw,7.5rem) 0}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;color:var(--muted);font-weight:600;font-size:var(--s1);
  background:rgba(255,255,255,.04);border:1px solid var(--line-2);padding:.4rem .9rem;border-radius:var(--pill);margin-bottom:1.3rem}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:var(--glow)}
.hero h1{font-size:var(--s6);font-weight:800;margin-bottom:1.2rem}
.hero__sub{color:var(--muted);font-size:var(--s2);max-width:50ch;margin-bottom:1.9rem}
.hero__sub strong{color:var(--text)}
.hero__cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:1.8rem}
.hero__proof{display:flex;align-items:center;gap:.8rem;color:var(--muted);font-size:var(--s1)}
.hero__proof strong{color:var(--text)}
.hero__cards{position:relative;height:420px}
.hero__card{position:absolute;background:#fff;border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow);width:200px;animation:float 6s ease-in-out infinite}
.hero__card img{width:100%;height:150px;object-fit:contain}
.hero__card span{display:block;text-align:center;color:#0a0f0d;font-weight:700;font-size:var(--s1);margin-top:.4rem}
.hero__card.hc0{top:6%;right:30%;z-index:3}
.hero__card.hc1{top:34%;right:2%;z-index:2;animation-delay:.6s}
.hero__card.hc2{top:60%;right:40%;z-index:1;width:170px;animation-delay:1.2s}
.hero__spectrum{position:absolute;inset:auto -10% -12% auto;width:300px;height:300px;border-radius:50%;background:var(--spectrum);filter:blur(60px);opacity:.5;z-index:0}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* ---------- Secciones ---------- */
.section{padding:clamp(3.6rem,6vw,6.5rem) 0}
/* Contraste/ritmo entre secciones contiguas */
.section + .section,.section + .band,.band + .section{border-top:1px solid var(--line)}
.section__head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:2.4rem}
.section__head h2{font-size:var(--s5)}
.band{background:var(--bg-1);border-block:1px solid var(--line)}
.band--offers{background:linear-gradient(180deg,var(--bg-1),var(--bg))}
.page-head{padding:1.6rem 0 2rem}
.page-head h1{font-size:var(--s5)}
.page-head p{color:var(--muted);margin-top:.5rem}
.page-head--center{text-align:center;padding-top:2.4rem}
.page-head--center p{max-width:60ch;margin-inline:auto}

/* ---------- Categorías ---------- */
.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.catcard{position:relative;display:flex;flex-direction:column;border-radius:var(--radius);border:1px solid var(--line);
  background:linear-gradient(160deg,var(--surface-2),var(--surface));overflow:hidden;transition:transform var(--med),border-color var(--med),box-shadow var(--med)}
.catcard:hover{transform:translateY(-5px);border-color:var(--accent);box-shadow:var(--shadow)}
.catcard__media{position:relative;aspect-ratio:16/10;background:radial-gradient(120% 120% at 50% 0%,#fff,#eef0ea);overflow:hidden}
.catcard__media img{width:100%;height:100%;object-fit:contain;padding:1.4rem 1.4rem 1.8rem;transition:transform var(--med)}
.catcard:hover .catcard__media img{transform:scale(1.05)}
.catcard__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(10,9,16,.55));pointer-events:none}
.catcard__ico{position:absolute;left:1rem;bottom:1rem;z-index:2;display:grid;place-items:center;width:42px;height:42px;border-radius:12px;
  background:rgba(10,9,16,.55);border:1px solid rgba(255,255,255,.14);color:var(--accent);backdrop-filter:blur(6px)}
.catcard__body{padding:1.3rem 1.5rem 1.6rem}
.catcard h3{font-size:var(--s4);margin-bottom:.2rem}
.catcard p{color:var(--muted)}
.catcard__go{display:inline-flex;gap:.4rem;margin-top:1rem;color:var(--accent);font-weight:700;transition:gap var(--fast)}
.catcard:hover .catcard__go{gap:.7rem}

/* ---------- Grid productos / tarjeta ---------- */
.grid--products{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform var(--med),border-color var(--med),box-shadow var(--med)}
.card:hover{transform:translateY(-5px);border-color:var(--line-2);box-shadow:var(--shadow)}
.card--out{opacity:.74}
.card__media{position:relative;display:block;aspect-ratio:1;background:#fff;overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:contain;padding:14px;transition:transform var(--med)}
.card:hover .card__media img{transform:scale(1.06)}
.card__badges{position:absolute;top:10px;left:10px;z-index:2;display:flex;flex-direction:column;gap:.35rem}
.badge{font-size:.72rem;font-weight:800;padding:.28rem .6rem;border-radius:var(--pill);text-transform:uppercase;letter-spacing:.03em}
.badge--sale{background:var(--hot);color:#33071a}
.badge--out{background:#2a2336;color:#cdb3e0;border:1px solid #463a5e}
.card__quick{position:absolute;left:50%;bottom:10px;transform:translate(-50%,14px);opacity:0;background:rgba(8,11,10,.85);color:#fff;border:1px solid var(--line-2);
  padding:.4rem .9rem;border-radius:var(--pill);font-size:var(--s1);font-weight:600;backdrop-filter:blur(6px);transition:var(--med);white-space:nowrap}
.card:hover .card__quick{opacity:1;transform:translate(-50%,0)}
.card__body{display:flex;flex-direction:column;gap:.5rem;padding:.95rem 1rem 1.05rem;flex:1}
.card__top{display:flex;justify-content:space-between;align-items:center}
.card__brand{font-size:.72rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}
.card__title{font-family:var(--ff);font-size:.97rem;font-weight:600;line-height:1.32}
.card__title a:hover{color:var(--accent)}
.card__foot{margin-top:auto;display:flex;align-items:flex-end;justify-content:space-between;gap:.5rem;padding-top:.3rem}
.price{display:flex;flex-direction:column;line-height:1.05}
.price__old{color:var(--muted-2);text-decoration:line-through;font-size:var(--s1)}
.price__now{font-family:var(--fd);font-weight:800;font-size:var(--s3)}
.card__stock{display:flex;align-items:center;gap:.45rem;font-size:.78rem;font-weight:600}
.card__stock .d{width:7px;height:7px;border-radius:50%}
.card__stock.in{color:#d3ef93}.card__stock.in .d{background:var(--accent);box-shadow:0 0 8px var(--accent)}
.card__stock.out{color:#bda6d6}.card__stock.out .d{background:#bda6d6}

/* ---------- Trustbar ---------- */
.trustbar{background:var(--bg-1);border-top:1px solid var(--line)}
.trustbar__in{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.6rem 0}
.trust{display:flex;align-items:center;gap:.8rem}
.trust__ico{width:46px;height:46px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--line);border-radius:13px;flex-shrink:0;color:var(--accent)}
.trust strong{display:block;font-size:.95rem}.trust small{color:var(--muted)}

/* ---------- Why ---------- */
.band--why{background:var(--bg-1)}
.why{padding:clamp(2.6rem,5vw,4.5rem) 0}
.why__head{max-width:60ch;margin-bottom:2rem}
.why__head h2{font-size:var(--s5)}
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.why__item{padding:1.6rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}
.why__ico{display:inline-grid;place-items:center;width:46px;height:46px;border-radius:13px;background:var(--accent-soft);color:var(--accent);font-size:1.3rem;margin-bottom:.9rem}
.why__item h3{font-size:var(--s2);margin-bottom:.4rem}
.why__item p{color:var(--muted);font-size:var(--s1)}

/* ---------- Reviews ---------- */
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.review{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem}
.review blockquote{font-size:var(--s2);line-height:1.5;margin:.7rem 0 1.1rem}
.review figcaption{color:var(--muted);font-size:var(--s1)}
.review figcaption strong{color:var(--text)}
.verified{color:var(--accent);font-weight:600}
.hero__proof-ic{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-weight:800;font-size:.85rem}
.card__tag,.product__tag{font-size:.7rem;font-weight:700;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);padding:.18rem .5rem;border-radius:var(--pill);letter-spacing:.02em}
.product__tag{margin-left:.3rem}

/* ---------- FAQ ---------- */
.faq__list{display:flex;flex-direction:column;gap:.7rem;max-width:920px}
.faq__item{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);overflow:hidden;transition:border-color var(--fast)}
.faq__item[open]{border-color:var(--line-2)}
.faq__item summary{cursor:pointer;list-style:none;padding:1.15rem 1.4rem;font-family:var(--fd);font-weight:600;font-size:var(--s2);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";color:var(--accent);font-size:1.5rem;font-weight:400;flex-shrink:0;transition:transform var(--fast)}
.faq__item[open] summary::after{content:"–"}
.faq__a{padding:0 1.4rem 1.25rem;color:var(--muted);max-width:75ch}
.seo-text{padding:1rem 0 4rem;max-width:none}
.seo-text h2{font-size:var(--s3)}

/* ---------- Post cards ---------- */
.grid--posts{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.post-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform var(--med),border-color var(--med)}
.post-card:hover{transform:translateY(-4px);border-color:var(--line-2)}
.post-card__media{aspect-ratio:16/9;background:var(--surface-2);overflow:hidden;display:block}
.post-card__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--med)}
.post-card:hover .post-card__media img{transform:scale(1.05)}
.post-card__ph{display:grid;place-items:center;height:100%;font-family:var(--fd);font-weight:800;color:var(--muted-2);letter-spacing:.1em}
.post-card__body{padding:1.2rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.post-card__date{color:var(--muted-2);font-size:.8rem}
.post-card__body h2,.post-card__body h3{font-size:var(--s2);line-height:1.3}
.post-card__body h2 a:hover,.post-card__body h3 a:hover{color:var(--accent)}
.post-card__body p{color:var(--muted);font-size:var(--s1)}
.post-card__body .link{margin-top:auto}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--bg-1);border-top:1px solid var(--line)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 300px at 50% -30%,rgba(var(--accent-rgb),.16),transparent 60%)}
.cta-band__in{position:relative;text-align:center;padding:clamp(3rem,6vw,5rem) 0;max-width:680px;margin-inline:auto}
.cta-band__in h2{font-size:var(--s5);margin-bottom:.7rem}
.cta-band__in p{color:var(--muted);margin-bottom:1.8rem;font-size:var(--s2)}

/* ---------- Breadcrumb ---------- */
.breadcrumb{padding:1.2rem 0 0;color:var(--muted);font-size:var(--s1)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{margin:0 .45rem;color:var(--muted-2)}
.breadcrumb .current{color:var(--muted)}

/* ---------- Shop / filtros ---------- */
.shop{display:grid;grid-template-columns:260px 1fr;gap:1.8rem;padding-bottom:4.5rem;align-items:start}
.filters{position:sticky;top:150px;display:flex;flex-direction:column;gap:.6rem}
.filters__head{display:none;justify-content:space-between;align-items:center;font-family:var(--fd);font-weight:700;font-size:var(--s3);margin-bottom:.5rem}
.filters__close{background:none;border:0;color:var(--muted);font-size:1.3rem;cursor:pointer}
.filters details{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);padding:.3rem 1rem}
.filters summary{cursor:pointer;font-weight:700;padding:.7rem 0;list-style:none;font-family:var(--fd)}
.filters summary::-webkit-details-marker{display:none}
.filters summary::after{content:"+";float:right;color:var(--muted)}
.filters details[open] summary::after{content:"–"}
.filters ul{list-style:none;padding:.1rem 0 .7rem;display:flex;flex-direction:column;gap:.1rem}
.filters a{display:block;padding:.45rem .55rem;border-radius:8px;font-size:var(--s1);color:var(--muted);transition:background var(--fast),color var(--fast)}
.filters a:hover{background:var(--surface-2);color:var(--text)}
.filters a.is-on{background:var(--accent-soft);color:var(--accent);font-weight:700}
.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.3rem;gap:1rem}
.filters__open{display:none}
.toolbar__sort{margin-left:auto}
.toolbar label{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:var(--s1)}
.toolbar select{background:var(--surface);color:var(--text);border:1px solid var(--line-2);border-radius:9px;padding:.5rem .8rem;font:inherit;cursor:pointer}
.empty{padding:3rem;border:1px dashed var(--line-2);border-radius:var(--radius);text-align:center;color:var(--muted)}

/* ---------- Producto ---------- */
.product{display:grid;grid-template-columns:1.05fr 1fr;gap:2.6rem;padding:1.4rem 0 3rem;align-items:start}
.product__gallery{position:sticky;top:150px;background:#fff;border-radius:var(--radius-lg);padding:1.6rem;border:1px solid var(--line)}
.product__badges{position:absolute;top:1.2rem;left:1.2rem;z-index:2;display:flex;gap:.4rem}
.product__gallery>img{width:100%;aspect-ratio:1;object-fit:contain}
.thumbs{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}
.thumb{width:66px;height:66px;border-radius:11px;border:2px solid #eee;background:#fff;padding:5px;cursor:pointer;overflow:hidden}
.thumb.is-on{border-color:var(--accent-2)}
.thumb img{width:100%;height:100%;object-fit:contain}
.product__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.7rem}
.product__brand{color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:var(--s1)}
.product__info h1{font-size:var(--s5);margin-bottom:1rem}
.product__price{display:flex;align-items:baseline;flex-wrap:wrap;gap:.7rem;margin-bottom:.8rem}
.product__price .price__now{font-size:var(--s5)}
.product__price .price__old{font-size:var(--s3)}
.price__save{background:var(--hot-soft);color:var(--hot);font-weight:700;font-size:var(--s1);padding:.25rem .6rem;border-radius:var(--pill)}
.product__tax{color:var(--muted);font-size:var(--s1);width:100%}
.stockline{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:var(--s1);margin-bottom:1.2rem}
.stockline .d{width:9px;height:9px;border-radius:50%}
.stockline.in{color:#d3ef93}.stockline.in .d{background:var(--accent);box-shadow:0 0 10px var(--accent)}
.stockline.out{color:#bda6d6}.stockline.out .d{background:#bda6d6}
.product__short{color:var(--muted);margin-bottom:1.6rem;font-size:var(--s2)}
.product__buy{display:flex;gap:.8rem;align-items:center;margin-bottom:1.6rem;flex-wrap:wrap}
.qty{display:flex;align-items:center;border:1px solid var(--line-2);border-radius:var(--pill);background:var(--surface);overflow:hidden}
.qty__btn{width:46px;height:52px;background:none;border:0;color:var(--text);font-size:1.3rem;cursor:pointer}
.qty__btn:hover{color:var(--accent)}
.qty input{width:48px;height:52px;text-align:center;background:none;border:0;color:var(--text);font-size:var(--s2);font-weight:700;-moz-appearance:textfield}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none}
.product__guarantees{list-style:none;display:grid;gap:.7rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.4rem;margin-bottom:1.4rem}
.product__guarantees li{display:flex;align-items:center;gap:.7rem;font-size:var(--s1);color:var(--muted)}
.product__guarantees .ico{color:var(--accent);flex-shrink:0}
.product__meta{list-style:none;display:flex;flex-direction:column;gap:.5rem;color:var(--muted);font-size:var(--s1)}
.product__meta a:hover{color:var(--accent)}
.product__desc{padding:1.4rem 0 3rem}
.product__desc h2{font-size:var(--s4);margin-bottom:1.1rem}
.rte{color:var(--muted);max-width:78ch}
.rte h1,.rte h2,.rte h3,.rte h4{color:var(--text);margin:1.6rem 0 .7rem;font-family:var(--fd)}
.rte h2{font-size:var(--s4)}.rte h3{font-size:var(--s3)}.rte h4{font-size:var(--s2)}
.rte p{margin-bottom:1.05rem}
.rte ul,.rte ol{margin:0 0 1.1rem 1.3rem;display:flex;flex-direction:column;gap:.45rem}
.rte a{color:var(--accent);text-decoration:underline}
.rte strong{color:var(--text)}
.rte img{border-radius:var(--radius);margin:1rem 0}
.rte table{width:100%;border-collapse:collapse;margin:1.2rem 0;font-size:var(--s1)}
.rte td,.rte th{border:1px solid var(--line);padding:.65rem .85rem;text-align:left}
.rte th{background:var(--surface)}

/* ---------- Buybar móvil ---------- */
.buybar{position:fixed;left:0;right:0;bottom:0;z-index:90;background:rgba(8,11,10,.95);backdrop-filter:blur(12px);border-top:1px solid var(--line);transform:translateY(110%);transition:transform var(--med)}
.buybar.show{transform:none}
.buybar__in{display:flex;align-items:center;gap:1rem;padding:.7rem 0}
.buybar__info{display:flex;flex-direction:column;line-height:1.2;flex:1;min-width:0}
.buybar__info strong{font-size:var(--s1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.buybar__info span{color:var(--accent);font-weight:800}
.buybar form{flex-shrink:0}

/* ---------- Carrito ---------- */
.cartpage{display:grid;grid-template-columns:1fr 380px;gap:1.8rem;align-items:start;padding-bottom:4.5rem}
.freeship{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.3rem;margin-bottom:1.1rem}
.freeship p{font-size:var(--s1);margin-bottom:.6rem}
.freeship strong{color:var(--accent)}
.freeship__bar{height:8px;background:var(--surface-2);border-radius:var(--pill);overflow:hidden}
.freeship__bar span{display:block;height:100%;background:var(--accent);border-radius:var(--pill);transition:width var(--med)}
.cart-table{display:flex;flex-direction:column;gap:.6rem}
.cart-row{display:grid;grid-template-columns:80px 1fr 96px 92px 32px;gap:1rem;align-items:center;padding:1rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}
.cart-row__img img{border-radius:10px;background:#fff;padding:5px;object-fit:contain;width:80px;height:80px}
.cart-row__info{display:flex;flex-direction:column;gap:.15rem}
.cart-row__info a{font-weight:700}.cart-row__info a:hover{color:var(--accent)}
.cart-row__brand,.cart-row__unit{font-size:var(--s1);color:var(--muted)}
.cart-row__warn{font-size:.8rem;color:var(--hot)}
.cart-row__qty{width:100%;height:44px;text-align:center;background:var(--surface-2);border:1px solid var(--line-2);border-radius:10px;color:var(--text);font-weight:700}
.cart-row__sub{font-family:var(--fd);font-weight:800;text-align:right}
.cart-row__del{background:none;border:0;color:var(--muted);font-size:1.05rem;cursor:pointer;width:32px;height:32px;border-radius:50%}
.cart-row__del:hover{color:var(--danger);background:var(--surface-2)}
.cart-actions{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;flex-wrap:wrap;gap:1rem}
.summary{position:sticky;top:150px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:1.6rem}
.summary h2{font-size:var(--s4);margin-bottom:1.1rem}
.summary__row{display:flex;justify-content:space-between;padding:.6rem 0;color:var(--muted)}
.summary__row .free{color:var(--accent)}
.summary__total{border-top:1px solid var(--line);margin-top:.4rem;padding-top:1rem;color:var(--text);font-family:var(--fd);font-size:var(--s3);font-weight:800}
.summary .btn{margin-top:1rem}
.summary__safe{text-align:center;color:var(--muted);font-size:var(--s1);margin-top:.9rem}
.empty-cart{text-align:center;padding:3.5rem 0 4.5rem;display:flex;flex-direction:column;gap:1.2rem;align-items:center}
.empty-cart__ico{font-size:3rem}

/* ---------- Artículo blog ---------- */
.article__head{padding:1.4rem 0 1.2rem;text-align:center}
.article__date{color:var(--accent);font-weight:600;font-size:var(--s1)}
.article__head h1{font-size:clamp(2rem,4vw,3rem);margin-top:.5rem}
.article__hero{margin:1rem auto 2rem}
.article__hero img{width:100%;border-radius:var(--radius-lg);max-height:520px;object-fit:cover}
.article__body{font-size:var(--s2);line-height:1.75}
.article__cta{margin:3rem auto;text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2.4rem}
.article__cta h2{font-size:var(--s4);margin-bottom:.6rem}
.article__cta p{color:var(--muted);margin-bottom:1.4rem}

/* ---------- Avisos / formularios ---------- */
.notice{text-align:center;padding:4rem 0;display:flex;flex-direction:column;gap:1rem;align-items:center}
.notice h1{font-size:var(--s5)}
.notice p{color:var(--muted);max-width:54ch}
.notice .btn{margin-top:.4rem}
.notice--ok .notice__ico{width:78px;height:78px;border-radius:50%;background:var(--accent);color:var(--ink);display:grid;place-items:center;font-size:2.4rem;font-weight:900;box-shadow:var(--glow)}
.order-ref{background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:.7rem 1.2rem}
.contact{display:grid;grid-template-columns:1fr 1.3fr;gap:2rem;padding-bottom:4.5rem;align-items:start}
.contact__info{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:1.8rem}
.contact__info h2{font-size:var(--s4);margin-bottom:.9rem}
.contact__info p{color:var(--muted);margin-bottom:.9rem}
.contact__info a{color:var(--accent)}
.contact__hours{font-size:var(--s1)}
.contact__form label{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem;font-weight:600;font-size:var(--s1)}
.contact__form input,.contact__form textarea{background:var(--surface);border:1px solid var(--line-2);border-radius:11px;color:var(--text);padding:.85rem 1rem;font:inherit;transition:border-color var(--fast),box-shadow var(--fast)}
.contact__form input:focus,.contact__form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);outline:none}
.hp{position:absolute;left:-9999px}
.alert{padding:1rem 1.2rem;border-radius:11px;margin-bottom:1.2rem;font-weight:600}
.alert--ok{background:var(--accent-soft);color:var(--accent);border:1px solid rgba(var(--accent-rgb),.3)}
.alert--err{background:rgba(251,113,133,.1);color:var(--danger);border:1px solid rgba(251,113,133,.3)}

/* ---------- Footer ---------- */
.site-footer{background:#060807;border-top:1px solid var(--line);padding-top:3.2rem}
.footer__grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.1fr;gap:2rem;padding-bottom:2.6rem}
.brand--footer{margin-bottom:1.1rem}
.footer__about{color:var(--muted);font-size:var(--s1);max-width:36ch;margin-bottom:1.1rem}
.footer__contact{color:var(--muted);font-size:var(--s1);line-height:1.8}
.footer__contact a:hover{color:var(--accent)}
.site-footer h2{font-family:var(--ff);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);margin-bottom:1.1rem}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.site-footer ul a{color:var(--muted);font-size:var(--s1)}
.site-footer ul a:hover{color:var(--accent)}
.paybadges{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:1.2rem}
.paybadges span{border:1px solid var(--line-2);border-radius:7px;padding:.32rem .6rem;font-size:.72rem;font-weight:700;color:var(--muted)}
.paybadges--sm{margin-top:1rem;justify-content:center}
.footer__bottom{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding:1.5rem 0;color:var(--muted-2);font-size:var(--s1);flex-wrap:wrap;gap:.5rem}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:1080px){
  .grid--products{grid-template-columns:repeat(3,1fr)}
  .grid--posts{grid-template-columns:repeat(2,1fr)}
  .trustbar__in,.why__grid{grid-template-columns:repeat(2,1fr)}
  .reviews__grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
  .hero__cards{height:340px}
}
@media(max-width:900px){
  .hero__in{grid-template-columns:1fr}
  .hero__cards{display:none}
  .cats{grid-template-columns:1fr}
  .product{grid-template-columns:1fr;gap:1.6rem}
  .product__gallery{position:static}
  .cartpage{grid-template-columns:1fr}
  .summary{position:static}
  .contact{grid-template-columns:1fr}
  .search{order:4;flex-basis:100%}
  .header__in{flex-wrap:wrap}
  .nav-toggle{display:flex}
  .mainnav{position:fixed;inset:0 0 0 auto;width:min(82%,330px);background:var(--bg-1);border-left:1px solid var(--line);transform:translateX(100%);transition:transform var(--med);z-index:120;overflow-y:auto}
  .mainnav.open{transform:none}
  .mainnav__in{flex-direction:column;padding:5rem 1.3rem 2rem;gap:.2rem}
  .mainnav a{padding:1rem;font-size:var(--s2);border-bottom:1px solid var(--line)}
  body.nav-open{overflow:hidden}
  /* filtros como drawer */
  .shop{grid-template-columns:1fr}
  .filters__open{display:inline-flex}
  .filters{position:fixed;inset:0 0 0 auto;width:min(86%,340px);background:var(--bg-1);border-left:1px solid var(--line);
    transform:translateX(100%);transition:transform var(--med);z-index:130;overflow-y:auto;padding:1.4rem;top:0}
  .filters.open{transform:none}
  .filters__head{display:flex}
  .buybar__info strong{max-width:38vw}
}
@media(max-width:600px){
  .grid--products{grid-template-columns:repeat(2,1fr)}
  .grid--posts,.why__grid,.footer__grid{grid-template-columns:1fr}
  .trustbar__in{grid-template-columns:1fr 1fr}
  .cart-row{grid-template-columns:64px 1fr auto;grid-template-areas:"img info info" "img qty sub"}
  .cart-row__img{grid-area:img}.cart-row__info{grid-area:info}
  .cart-row__qty{grid-area:qty;width:84px}.cart-row__sub{grid-area:sub}
  .cart-row__del{position:absolute;top:.6rem;right:.6rem}
  .cart-row{position:relative}
  .page-head h1,.section__head h2{font-size:var(--s4)}
  .card__quick{display:none}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* Reveal on scroll — lo activa app.js solo si NO hay prefers-reduced-motion (progressive enhancement) */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s cubic-bezier(.22,.61,.36,1)}
.reveal.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* ---------- Mini-carrito deslizante ---------- */
.minicart{position:fixed;top:0;right:0;height:100%;width:min(380px,90vw);z-index:200;display:flex;flex-direction:column;gap:1.1rem;
  background:var(--surface);border-left:1px solid var(--line-2);box-shadow:var(--shadow);padding:1.5rem;
  transform:translateX(105%);transition:transform .32s cubic-bezier(.4,0,.2,1);overflow-y:auto}
.minicart.open{transform:none}
.minicart__head{display:flex;align-items:center;justify-content:space-between}
.minicart__head strong{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--fd);color:var(--accent)}
.minicart__close{background:none;border:0;color:var(--muted);font-size:1.7rem;line-height:1;cursor:pointer}
.minicart__close:hover{color:var(--text)}
.minicart__item{display:flex;gap:.9rem;align-items:center;background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.7rem}
.minicart__item img{width:64px;height:64px;object-fit:contain;background:#fff;border-radius:8px;flex-shrink:0}
.minicart__item strong{display:block;font-family:var(--ff);font-size:var(--s1);font-weight:600;line-height:1.3;color:var(--text)}
.minicart__item span{color:var(--accent);font-weight:700}
.minicart__ship p{font-size:var(--s1);color:var(--muted);margin-bottom:.5rem}
.minicart__ship .mc-free{color:var(--accent);font-weight:700;display:flex;align-items:center;gap:.4rem}
.mc-bar{height:7px;border-radius:var(--pill);background:var(--line-2);overflow:hidden}
.mc-bar span{display:block;height:100%;background:var(--accent);border-radius:var(--pill);transition:width .4s ease}
.minicart__sub{display:flex;justify-content:space-between;align-items:center;padding-top:.6rem;border-top:1px solid var(--line);font-size:var(--s2)}
.minicart__sub strong{font-family:var(--fd)}
.minicart__cta{display:grid;gap:.6rem}
.minicart__cont{background:none;border:0;color:var(--muted);text-decoration:underline;cursor:pointer;padding:.3rem;font:inherit}
.minicart__cont:hover{color:var(--text)}
.minicart-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:190;backdrop-filter:blur(2px)}
@media(max-width:760px){.hero{background-attachment:scroll}}

/* ---------- Blog: meta + índice de contenidos ---------- */
.article__meta{color:var(--muted);font-size:var(--s1);margin-bottom:.5rem;font-weight:600}
.toc{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.4rem;margin:1.8rem auto 0}
.toc__title{font-family:var(--fd);font-weight:700;margin-bottom:.5rem}
.toc ol{margin:0;padding-left:1.1rem;display:grid;gap:.35rem}
.toc a{color:var(--muted)}.toc a:hover{color:var(--accent);text-decoration:underline}
.rte h2{scroll-margin-top:96px}
/* ---------- 404 ---------- */
.notfound{text-align:center;padding:clamp(2.5rem,6vw,5rem) 0}
.notfound__code{display:inline-block;font-family:var(--fd);font-weight:800;font-size:clamp(3rem,10vw,5.5rem);line-height:1;background:var(--spectrum);-webkit-background-clip:text;background-clip:text;color:transparent}
.search--404{max-width:520px;margin:1.5rem auto}
.notfound__cats{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin:1.5rem 0}
.notfound__links{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;margin-top:.5rem}

/* ---------- Hardening responsive / contenido ---------- */
.rte{overflow-wrap:break-word}
.rte img{height:auto;border-radius:var(--radius-sm)}
.rte table{display:block;width:100%;overflow-x:auto;border-collapse:collapse;-webkit-overflow-scrolling:touch}
.rte td,.rte th{border:1px solid var(--line);padding:.5rem .7rem;text-align:left}
@media(max-width:600px){
  /* font-size 16px en inputs evita el auto-zoom de iOS */
  input,select,textarea{font-size:16px}
  .section__head{flex-wrap:wrap}
}

/* ---------- Volver arriba ---------- */
.totop{position:fixed;right:1.1rem;bottom:1.1rem;z-index:140;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  background:var(--surface-2);color:var(--text);border:1px solid var(--line-2);cursor:pointer;box-shadow:var(--shadow-sm);
  opacity:0;transform:translateY(10px);transition:opacity var(--med),transform var(--med),background var(--fast),color var(--fast)}
.totop.show{opacity:1;transform:none}
.totop:hover{background:var(--accent);color:var(--ink);border-color:transparent}
@media(max-width:600px){.totop{right:.8rem;bottom:.8rem}}
