/* ===== TGB June Sale — estilos (mobile-first, identidad The GelBottle) ===== */
:root{
  --ink:#0b0b0c;
  --paper:#ffffff;
  --paper-2:#faf7fb;
  --lav:#cda1cd;
  --lav-2:#ecd5ec;
  --lav-deep:#7c5fa6;
  --brand:#cda1cd;
  --sale:#d8112a;
  --muted:#8c8794;
  --line:#e8e4ed;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Jost",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --maxw:1180px;
  --r:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
.u-eyebrow{font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;font-weight:500}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px}

/* ============ HOME ============ */
.home-hero{
  background:linear-gradient(180deg,#cda1cd 0%,#e6cde6 100%);
  text-align:center;padding:26px 0 32px;
}
.home-hero .u-eyebrow{color:#fff;opacity:.85}
.brand-logo{display:block;width:90%;max-width:486px;height:auto;margin:18px auto 6px}
.hero-disc{margin:22px 0 6px;font-family:var(--serif)}
.hero-disc .lead{font-size:1.05rem;font-style:italic;color:#3a3340}
.hero-disc .big{font-family:var(--serif);font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:clamp(3.795rem,20.24vw,6.325rem);line-height:.95;color:#fff}
.hero-disc .big .tm{font-family:var(--sans);font-size:.377em;font-weight:400;letter-spacing:.02em;position:relative;top:-.25em;left:-.06em}
.hero-disc .lead2{display:block;font-family:var(--sans);font-style:normal;font-weight:500;text-transform:uppercase;letter-spacing:.28em;font-size:.9rem;color:#3a3340;margin-top:30px}
.hero-note{color:#fff;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;margin:14px 0 4px;opacity:.9}

.cats{display:grid;gap:16px;padding:18px 18px 40px;max-width:560px;margin:0 auto}
.cat-card{
  position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;
  display:flex;flex-direction:column;justify-content:space-between;
  background:var(--lav);color:#fff;text-align:center;
  box-shadow:0 10px 30px rgba(60,40,90,.10);
}
.cat-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.cat-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.18) 0%,rgba(0,0,0,0) 22%,rgba(0,0,0,0) 70%,rgba(0,0,0,.4) 100%);z-index:1}
.cat-card__title{position:relative;z-index:2;font-family:var(--serif);font-weight:600;letter-spacing:.06em;font-size:1.7rem;margin:0;padding:9% 16px 0;text-shadow:0 1px 12px rgba(0,0,0,.45)}
.cat-card__body{position:relative;z-index:2;padding:0 16px 4%}
.cat-card .btn-ghost{display:block;background:rgba(255,255,255,.95);color:var(--ink);
  padding:13px;border:0;border-radius:8px;letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;font-weight:500}
.home-foot{text-align:center;color:var(--muted);font-size:.72rem;padding:0 18px 40px}

/* ============ LISTADO ============ */
.topbar{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.96);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.topbar__row{display:flex;align-items:center;gap:10px;padding:10px 14px}
.iconbtn{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;
  background:#fff;display:grid;place-items:center;font-size:1.1rem;flex:0 0 auto}
.crumb{font-family:var(--serif);font-size:.95rem;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.crumb b{font-weight:600}
.searchwrap{padding:0 14px 10px}
.search{width:100%;border:1px solid var(--line);border-radius:30px;padding:11px 16px;
  font-family:inherit;font-size:.9rem;background:var(--paper-2)}
.search:focus{outline:none;border-color:var(--lav-deep)}

.listhead{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:18px 18px 6px;max-width:var(--maxw);margin:0 auto}
.listhead h1{font-family:var(--serif);font-weight:600;font-size:1.9rem;margin:0}
.listhead .sub{color:var(--muted);font-size:.8rem;margin-top:2px}
.toolsrow{display:flex;align-items:center;justify-content:space-between;
  padding:6px 18px 14px;max-width:var(--maxw);margin:0 auto}
.count{color:var(--sale);font-weight:500;font-size:.82rem}
.count span{color:var(--muted);font-weight:300}
.sortsel{border:1px solid var(--line);border-radius:8px;padding:8px 10px;background:#fff;font-family:inherit;font-size:.8rem}

.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
  padding:0 14px 60px;max-width:var(--maxw);margin:0 auto}
.card{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;
  display:flex;flex-direction:column;cursor:pointer;transition:transform .15s,box-shadow .15s}
.card:active{transform:scale(.99)}
.card:hover{box-shadow:0 8px 24px rgba(60,40,90,.10)}
.card__media{position:relative;aspect-ratio:1/1.18;background:var(--paper-2);overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover}
.badge-sale{position:absolute;top:8px;left:8px;background:var(--sale);color:#fff;
  font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;padding:4px 9px;border-radius:20px;z-index:2}
.badge-stock{position:absolute;top:8px;right:8px;background:rgba(11,11,12,.82);color:#fff;
  font-size:.58rem;letter-spacing:.06em;padding:3px 8px;border-radius:20px;z-index:2}
.swatch-dot{position:absolute;bottom:8px;right:8px;width:22px;height:22px;border-radius:50%;
  border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.25);z-index:2}
.card__body{padding:10px 11px 13px}
.card__code{color:var(--lav-deep);font-size:.66rem;letter-spacing:.1em;font-weight:600}
.card__name{font-family:var(--serif);font-size:1.06rem;font-weight:600;line-height:1.1;margin:2px 0 8px}
.price{display:flex;align-items:baseline;gap:7px;flex-wrap:wrap}
.price .now{color:var(--sale);font-weight:600;font-size:1.02rem}
.price .was{color:var(--muted);text-decoration:line-through;font-size:.8rem}
.price .ask{color:var(--muted);font-size:.82rem;font-style:italic}
.empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:50px 0}

/* ============ MODAL ============ */
.modal{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:14px}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(20,12,30,.55);backdrop-filter:blur(2px)}
.modal__card{position:relative;z-index:1;background:#fff;border-radius:18px;width:100%;
  max-width:440px;max-height:92vh;overflow:auto;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.modal__close{position:absolute;top:10px;right:10px;z-index:5;width:34px;height:34px;border:0;
  border-radius:50%;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.18);font-size:1.3rem;line-height:1}
.gallery{background:var(--paper-2)}
.gallery__stage{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;aspect-ratio:1/1.05}
.gallery__stage::-webkit-scrollbar{display:none}
.gallery__item{flex:0 0 100%;scroll-snap-align:center;display:grid;place-items:center;background:var(--paper-2)}
.gallery__item img{width:100%;height:100%;object-fit:cover}
.gallery__item iframe{width:100%;height:100%;border:0;aspect-ratio:1/1.05}
.gallery__thumbs{display:flex;gap:8px;padding:10px;justify-content:center;flex-wrap:wrap}
.thumb{width:46px;height:46px;border-radius:8px;overflow:hidden;border:2px solid transparent;background:#fff;padding:0}
.thumb.is-active{border-color:var(--lav-deep)}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb.video{display:grid;place-items:center;background:var(--ink);color:#fff;font-size:1rem}
.modal__info{padding:6px 20px 22px}
.modal__code{color:var(--lav-deep);font-size:.7rem;letter-spacing:.12em;font-weight:600}
.modal__name{font-family:var(--serif);font-weight:700;font-size:2rem;line-height:1;margin:3px 0 12px}
.priceline{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.priceline .now{color:var(--sale);font-weight:600;font-size:1.7rem;font-family:var(--serif)}
.priceline .was{color:var(--muted);text-decoration:line-through}
.off{background:var(--lav);color:var(--lav-deep);font-weight:600;font-size:.72rem;
  letter-spacing:.06em;padding:4px 10px;border-radius:20px}
.desc{background:var(--lav-2);border-left:3px solid var(--lav-deep);border-radius:8px;
  padding:13px 14px;font-size:.9rem;font-style:italic;color:#3c3543;line-height:1.55;margin-bottom:14px}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.tag{background:var(--paper-2);border:1px solid var(--line);color:#5a5560;font-size:.72rem;
  padding:5px 11px;border-radius:20px}
.btn-buy{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;background:var(--ink);
  color:#fff;border:0;border-radius:10px;padding:15px;font-size:.95rem;font-weight:500;letter-spacing:.04em}
.btn-buy:hover{background:#25202c}
.btn-buy svg{width:18px;height:18px}

/* ============ Desktop ============ */
@media(min-width:560px){.grid{grid-template-columns:repeat(3,1fr);gap:16px}}
@media(min-width:820px){
  .grid{grid-template-columns:repeat(4,1fr)}
  .cats{grid-template-columns:1fr 1fr;max-width:var(--maxw)}
}
@media(min-width:1024px){.modal__card{max-width:900px;display:grid;grid-template-columns:1fr 1fr;max-height:88vh}
  .gallery{border-radius:18px 0 0 18px}
  .gallery__stage,.gallery__item iframe{aspect-ratio:auto;height:100%}
  .modal__info{align-self:center}
}

/* ============ BIAB catálogo (overrides) ============ */
.cat-card__sub{position:relative;z-index:2;font-size:.74rem;letter-spacing:.04em;opacity:.92;
  margin-top:6px;padding:0 16px;text-shadow:0 1px 8px rgba(0,0,0,.45)}
.card__line{color:var(--lav-deep);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600}
/* precio neutro: es catálogo, no oferta */
.price .now{color:var(--ink)}
.priceline .now{color:var(--ink)}
.count{color:var(--lav-deep)}
/* control de tamaño (sólo Hema-Free) */
.segwrap{display:flex;gap:8px;padding:4px 18px 10px;max-width:var(--maxw);margin:0 auto}
.seg{flex:1;border:1px solid var(--line);background:#fff;border-radius:30px;padding:9px 10px;
  font-family:inherit;font-size:.78rem;letter-spacing:.04em;color:#5a5560}
.seg.is-active{background:var(--lav-deep);border-color:var(--lav-deep);color:#fff}
/* tarjeta con portada propia: el botón queda abajo (como las demás) */
.cat-card--portada{justify-content:flex-end}
@media(min-width:820px){.cats{grid-template-columns:repeat(3,1fr)}}
