/* =========================================================
   EL TTT STORE — El Titi Store (parody)
   Clean lttstore-style e-commerce, spiced up caliente.
   ========================================================= */

:root{
  --ink:#0c0c0d;
  --ink-soft:#3a3a3e;
  --paper:#ffffff;
  --cream:#fff7ec;
  --cream-2:#fdefe0;
  --line:#ececec;

  --chili:#e6261f;
  --hot:#ff2d78;
  --gold:#ffb800;
  --lime:#1faa59;

  --shadow-sm:0 2px 8px rgba(0,0,0,.06);
  --shadow:0 14px 40px rgba(0,0,0,.10);
  --shadow-lg:0 30px 70px rgba(0,0,0,.18);

  --r:18px;
  --r-lg:28px;
  --maxw:1240px;

  --display:'Anton',system-ui,sans-serif;
  --body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,canvas{display:block;max-width:100%}
em{font-style:italic}

/* ---------- Reusable ---------- */
.ink-pop{color:var(--chili)}
.ink-pop--hot{color:var(--hot)}
.ink-pop--gold{color:var(--gold)}

.btn{
  --bg:var(--ink);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--body);font-weight:800;font-size:.95rem;
  letter-spacing:.02em;
  padding:.85em 1.5em;border:2px solid var(--ink);border-radius:999px;
  background:var(--bg);color:var(--fg);cursor:pointer;
  transition:transform .15s ease,box-shadow .2s ease,background .2s,color .2s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn:active{transform:translateY(0)}
.btn--solid{--bg:var(--chili);--fg:#fff;border-color:var(--chili)}
.btn--solid:hover{--bg:#c41d17}
.btn--ghost{--bg:transparent;--fg:var(--ink)}
.btn--ghost:hover{--bg:var(--ink);--fg:#fff}
.btn--lg{font-size:1.05rem;padding:1em 1.9em}
.btn--block{width:100%}

.kicker{
  display:inline-block;font-weight:800;text-transform:uppercase;
  letter-spacing:.14em;font-size:.78rem;color:var(--chili);
  background:var(--cream-2);padding:.4em .9em;border-radius:999px;
}
.kicker--light{background:rgba(255,255,255,.16);color:#fff}

/* ---------- Age Gate ---------- */
.agegate{
  position:fixed;inset:0;z-index:200;display:grid;place-items:center;
  background:rgba(12,12,13,.86);backdrop-filter:blur(8px);padding:1.2rem;
}
.agegate[hidden]{display:none}
.agegate__card{
  background:var(--paper);max-width:430px;width:100%;border-radius:var(--r-lg);
  padding:2.4rem 2rem;text-align:center;box-shadow:var(--shadow-lg);
  animation:pop .4s cubic-bezier(.2,1.4,.4,1) both;
}
.agegate__chili{font-size:3rem;animation:wiggle 1.4s ease-in-out infinite}
.agegate__card h2{font-family:var(--display);font-size:2rem;letter-spacing:.01em;margin:.4rem 0 .6rem}
.agegate__card p{color:var(--ink-soft);margin-bottom:1.4rem}
.agegate__btns{display:flex;flex-direction:column;gap:.7rem}
.agegate__fine{display:block;margin-top:1.2rem;color:#aaa;font-size:.72rem}

/* ---------- Ticker ---------- */
.ticker{
  background:var(--ink);color:#fff;overflow:hidden;white-space:nowrap;
  font-weight:700;font-size:.82rem;letter-spacing:.06em;
}
.ticker__track{
  display:inline-flex;gap:1.4rem;align-items:center;padding:.6rem 0;
  animation:scroll-left 26s linear infinite;
}
.ticker__track span{display:inline-block}
.ticker__track span:nth-child(even){color:var(--gold)}

/* ---------- Header ---------- */
.header{
  position:sticky;top:0;z-index:90;background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line);
  transition:box-shadow .25s;
}
.header.is-stuck{box-shadow:var(--shadow-sm)}
.header__inner{
  max-width:var(--maxw);margin:0 auto;padding:.75rem 1.4rem;
  display:flex;align-items:center;gap:1rem;
}
.logo{display:flex;flex-direction:column;line-height:.9;margin-right:auto}
.logo__mark{
  font-family:var(--display);font-size:1.8rem;letter-spacing:.02em;
  color:var(--ink);position:relative;
}
.logo__mark--sm{font-size:1.5rem}
.logo__split{color:var(--chili)}
.logo__sub{font-size:.58rem;font-weight:800;letter-spacing:.34em;color:var(--ink-soft)}

.nav{display:flex;gap:1.6rem;margin:0 auto}
.nav a{font-weight:700;font-size:.92rem;position:relative;padding:.2rem 0}
.nav a::after{
  content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;
  background:var(--chili);transition:width .22s ease;
}
.nav a:hover::after{width:100%}

.header__actions{display:flex;align-items:center;gap:.3rem}
.iconbtn{
  background:none;border:none;cursor:pointer;font-size:1.2rem;
  width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  transition:background .2s,transform .15s;
}
.iconbtn:hover{background:var(--cream-2);transform:translateY(-1px)}
.cart{position:relative}
.cart__count{
  position:absolute;top:2px;right:2px;background:var(--chili);color:#fff;
  font-size:.68rem;font-weight:800;min-width:18px;height:18px;border-radius:999px;
  display:grid;place-items:center;padding:0 4px;
  transform:scale(0);transition:transform .25s cubic-bezier(.2,1.6,.4,1);
}
.cart__count.is-on{transform:scale(1)}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:26px;height:3px;background:var(--ink);border-radius:2px;transition:.25s}
.burger.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--cream)}
.hero__bg{
  position:absolute;inset:0;
  background:
    radial-gradient(60% 70% at 78% 30%, rgba(255,45,120,.22), transparent 60%),
    radial-gradient(50% 60% at 12% 80%, rgba(255,184,0,.28), transparent 60%),
    repeating-linear-gradient(45deg, rgba(0,0,0,.018) 0 12px, transparent 12px 24px);
}
.hero__inner{
  position:relative;max-width:var(--maxw);margin:0 auto;
  padding:clamp(2.5rem,6vw,5rem) 1.4rem;
  display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center;
}
.hero__eyebrow{
  display:inline-block;font-weight:800;letter-spacing:.12em;font-size:.72rem;
  color:var(--chili);margin-bottom:1rem;
}
.hero__title{
  font-family:var(--display);
  font-size:clamp(3rem,8vw,6.2rem);line-height:.9;letter-spacing:.01em;
  text-transform:uppercase;
}
.hero__lead{
  max-width:36ch;margin:1.4rem 0 1.8rem;font-size:1.08rem;color:var(--ink-soft);
}
.hero__cta{display:flex;gap:.8rem;flex-wrap:wrap}
.hero__trust{
  list-style:none;display:flex;gap:1.4rem;flex-wrap:wrap;margin-top:1.8rem;
  font-weight:700;font-size:.88rem;color:var(--ink-soft);
}

.hero__art{position:relative;display:grid;place-items:center;min-height:380px}
.hero__mascot{
  width:min(100%,420px);filter:drop-shadow(0 24px 40px rgba(0,0,0,.22));
  animation:float 5s ease-in-out infinite;
}
.hero__badge{
  position:absolute;top:4%;right:6%;z-index:3;
  width:96px;height:96px;border-radius:50%;
  background:var(--chili);color:#fff;font-family:var(--display);
  display:grid;place-items:center;text-align:center;line-height:.9;font-size:1.2rem;
  box-shadow:var(--shadow);border:3px solid #fff;
}
.hero__badge--spin{animation:spin 9s linear infinite}
.hero__pricetag{
  position:absolute;bottom:6%;left:0;z-index:3;
  background:var(--ink);color:#fff;font-weight:700;font-style:italic;
  padding:.6em 1.1em;border-radius:999px;box-shadow:var(--shadow);
  transform:rotate(-4deg);
}
.hero__floaties{position:absolute;inset:0;pointer-events:none;z-index:1}
.floatie{position:absolute;font-size:1.6rem;opacity:.8;animation:floatUp linear infinite}

/* ---------- Value strip ---------- */
.strip{background:var(--ink);color:#fff;overflow:hidden;padding:.9rem 0;border-top:3px solid var(--gold)}
.strip__track{
  display:inline-flex;gap:1.6rem;align-items:center;white-space:nowrap;
  font-family:var(--display);font-size:1.1rem;letter-spacing:.04em;
  animation:scroll-left 22s linear infinite;
}
.strip__track i{color:var(--gold);font-style:normal}

/* ---------- Sections ---------- */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vw,5.5rem) 1.4rem}
.section--alt{max-width:none;background:var(--cream);}
.section--alt > *{max-width:var(--maxw);margin-inline:auto}
.section__head{text-align:center;margin-bottom:2.6rem}
.section__title{
  font-family:var(--display);font-size:clamp(2.2rem,5vw,3.6rem);
  text-transform:uppercase;letter-spacing:.01em;margin:.7rem 0 .5rem;
}
.section__sub{max-width:52ch;margin:0 auto;color:var(--ink-soft)}
.noscript{text-align:center;color:var(--ink-soft);grid-column:1/-1}

/* ---------- Product grid ---------- */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.product{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .2s ease,box-shadow .25s ease,border-color .2s;
}
.product:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.product__media{
  position:relative;aspect-ratio:1/1;
  background:linear-gradient(135deg,#f6d7b8,#e7a987);
  overflow:hidden;
}
.product__media canvas{
  width:100%;height:100%;object-fit:cover;
  image-rendering:pixelated;image-rendering:crisp-edges;
  filter:saturate(1.05);
}
.product__censor{
  position:absolute;left:50%;top:52%;transform:translate(-50%,-50%) rotate(-7deg);
  background:var(--ink);color:#fff;font-weight:900;letter-spacing:.18em;
  font-size:.82rem;padding:.45em 1.1em;border-radius:4px;
  box-shadow:0 6px 18px rgba(0,0,0,.35);white-space:nowrap;
  transition:transform .3s ease,opacity .3s;
}
.product:hover .product__censor{transform:translate(-50%,-50%) rotate(-7deg) scale(1.06)}
.product__badge{
  position:absolute;top:.7rem;left:.7rem;z-index:2;
  font-weight:800;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.35em .7em;border-radius:999px;color:#fff;background:var(--ink);
}
.product__badge--hot{background:var(--hot)}
.product__badge--new{background:var(--lime)}
.product__badge--sale{background:var(--chili)}
.product__18{
  position:absolute;bottom:.6rem;right:.6rem;z-index:2;
  background:rgba(255,255,255,.9);color:var(--ink);font-weight:900;
  font-size:.66rem;padding:.25em .5em;border-radius:6px;letter-spacing:.06em;
}
.product__body{padding:1rem 1.1rem 1.2rem;display:flex;flex-direction:column;gap:.35rem;flex:1}
.product__name{font-weight:800;font-size:1.02rem;line-height:1.2}
.product__tag{font-size:.84rem;color:var(--ink-soft);flex:1}
.product__stars{color:var(--gold);font-size:.82rem;letter-spacing:.06em}
.product__stars b{color:var(--ink-soft);font-weight:600}
.product__row{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem}
.product__price{font-family:var(--display);font-size:1.3rem}
.product__price small{color:#bbb;text-decoration:line-through;font-size:.8rem;font-family:var(--body);margin-left:.35rem}
.product__add{
  border:2px solid var(--ink);background:#fff;color:var(--ink);
  font-weight:800;font-size:.82rem;padding:.5em 1em;border-radius:999px;cursor:pointer;
  transition:background .18s,color .18s,transform .15s;
}
.product__add:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.product__add.is-added{background:var(--lime);border-color:var(--lime);color:#fff}

/* ---------- Collections ---------- */
.collections{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.collection{
  position:relative;border-radius:var(--r-lg);padding:2.2rem 1.6rem;min-height:230px;
  display:flex;flex-direction:column;justify-content:flex-end;color:#1a1a1a;overflow:hidden;
  background:
    radial-gradient(120% 120% at 80% -10%, color-mix(in srgb,var(--c) 70%,#fff), transparent 60%),
    color-mix(in srgb,var(--c) 22%,#fff);
  border:2px solid color-mix(in srgb,var(--c) 45%,#fff);
  transition:transform .2s,box-shadow .25s;
}
.collection::before{
  content:"";position:absolute;inset:0;z-index:0;opacity:.25;
  background-image:radial-gradient(circle at 2px 2px, rgba(0,0,0,.35) 1.4px, transparent 1.6px);
  background-size:14px 14px;
}
.collection > *{position:relative;z-index:1}
.collection:hover{transform:translateY(-6px) rotate(-1deg);box-shadow:var(--shadow)}
.collection h3{font-family:var(--display);font-size:1.9rem;letter-spacing:.01em}
.collection p{font-weight:600;margin:.3rem 0 .8rem}
.collection__go{font-weight:800}

/* ---------- Features ---------- */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.feature{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:1.8rem 1.4rem;transition:transform .2s,box-shadow .25s;
}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.feature__icon{font-size:2.2rem;margin-bottom:.6rem}
.feature h3{font-size:1.1rem;margin-bottom:.4rem}
.feature p{color:var(--ink-soft);font-size:.92rem}

/* ---------- Club ---------- */
.club{
  background:
    radial-gradient(70% 120% at 100% 0%, rgba(255,45,120,.4), transparent 55%),
    radial-gradient(60% 120% at 0% 100%, rgba(255,184,0,.35), transparent 55%),
    var(--ink);
  color:#fff;
}
.club__inner{
  max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vw,5rem) 1.4rem;
  display:grid;grid-template-columns:1.1fr .9fr;gap:2.4rem;align-items:center;
}
.club__copy h2{font-family:var(--display);font-size:clamp(2.4rem,6vw,4rem);text-transform:uppercase;margin:.6rem 0}
.club__copy p{color:rgba(255,255,255,.82);max-width:46ch;margin-bottom:1.4rem}
.club__form{display:flex;gap:.6rem;flex-wrap:wrap;max-width:440px}
.club__form input,.newsletter__form input{
  flex:1;min-width:200px;padding:.9em 1.1em;border-radius:999px;border:2px solid transparent;
  font-family:var(--body);font-size:.95rem;outline:none;
}
.club__form input:focus,.newsletter__form input:focus{border-color:var(--gold)}
.club__note{margin-top:.8rem;font-weight:700;color:var(--gold);min-height:1.2em}

.pricecard{
  background:#fff;color:var(--ink);border-radius:var(--r-lg);padding:2rem 1.8rem;
  box-shadow:var(--shadow-lg);position:relative;
}
.pricecard__tag{
  position:absolute;top:-.8rem;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--ink);font-weight:900;font-size:.68rem;
  letter-spacing:.1em;padding:.35em .9em;border-radius:999px;
}
.pricecard h3{font-family:var(--display);font-size:1.7rem;margin:.4rem 0 .2rem;text-transform:uppercase}
.pricecard__num{font-family:var(--display);font-size:2.4rem;margin-bottom:1rem}
.pricecard__num b{font-size:3.4rem}
.pricecard__num small{font-family:var(--body);font-size:1rem;color:var(--ink-soft)}
.pricecard ul{list-style:none;margin-bottom:1.4rem;display:grid;gap:.5rem}
.pricecard li{font-weight:600;font-size:.94rem}
.pricecard small{display:block;margin-top:.7rem;color:#bbb;text-align:center}

/* ---------- Reviews ---------- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.review{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:1.8rem;transition:transform .2s,box-shadow .25s;
}
.review:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.review__stars{color:var(--gold);font-size:1.1rem;margin-bottom:.7rem;letter-spacing:.1em}
.review blockquote{font-size:1.05rem;font-weight:500;font-style:italic;margin-bottom:.9rem}
.review figcaption{font-weight:800;font-size:.85rem;color:var(--ink-soft)}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto;display:grid;gap:.8rem}
.faq__item{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:.4rem 1.3rem;overflow:hidden;
}
.faq__item summary{
  cursor:pointer;font-weight:800;font-size:1.05rem;padding:1rem 0;list-style:none;
  display:flex;justify-content:space-between;align-items:center;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--display);font-size:1.6rem;color:var(--chili);transition:transform .2s}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item p{padding-bottom:1.1rem;color:var(--ink-soft)}

/* ---------- Newsletter ---------- */
.newsletter{
  background:var(--cream-2);
  background-image:radial-gradient(circle at 2px 2px, rgba(0,0,0,.05) 1.5px, transparent 1.6px);
  background-size:18px 18px;
}
.newsletter__inner{max-width:680px;margin:0 auto;padding:clamp(3rem,7vw,5rem) 1.4rem;text-align:center}
.newsletter__inner h2{font-family:var(--display);font-size:clamp(2.2rem,5vw,3.4rem);text-transform:uppercase}
.newsletter__inner p{color:var(--ink-soft);margin:.6rem auto 1.6rem;max-width:44ch}
.newsletter__form{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}
.newsletter__form input{border-color:#e3cdb6;background:#fff;max-width:340px}
.newsletter__note{margin-top:.9rem;font-weight:700;color:var(--chili);min-height:1.2em}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#fff;padding:3.4rem 1.4rem 1.6rem}
.footer__cols{
  max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;
}
.footer__brand p{color:rgba(255,255,255,.6);max-width:34ch;margin:.8rem 0 1rem;font-size:.92rem}
.footer__brand .logo__mark{color:#fff}
.footer__social{display:flex;gap:.6rem}
.footer__social a{
  width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);
  display:grid;place-items:center;font-size:1.1rem;transition:background .2s,transform .15s;
}
.footer__social a:hover{background:var(--chili);transform:translateY(-2px)}
.footer__col h4{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:.9rem;color:var(--gold)}
.footer__col a{display:block;color:rgba(255,255,255,.7);padding:.28rem 0;font-size:.92rem;transition:color .2s}
.footer__col a:hover{color:#fff}
.footer__pay{
  max-width:var(--maxw);margin:2.4rem auto 0;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.12);
  display:flex;gap:1rem;flex-wrap:wrap;
}
.footer__pay span{
  font-weight:800;font-size:.74rem;letter-spacing:.06em;color:rgba(255,255,255,.55);
  border:1px solid rgba(255,255,255,.2);padding:.3em .7em;border-radius:6px;
}
.footer__legal{max-width:var(--maxw);margin:1.4rem auto 0;color:rgba(255,255,255,.4);font-size:.78rem}

/* ---------- Toast ---------- */
.toast{
  position:fixed;left:50%;bottom:1.6rem;transform:translateX(-50%) translateY(140%);
  background:var(--ink);color:#fff;font-weight:700;padding:.9em 1.4em;border-radius:999px;
  box-shadow:var(--shadow-lg);z-index:150;transition:transform .35s cubic-bezier(.2,1.4,.4,1);
  border:2px solid var(--gold);
}
.toast.is-on{transform:translateX(-50%) translateY(0)}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-in{opacity:1;transform:none}

/* ---------- Animations ---------- */
@keyframes scroll-left{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
@keyframes floatUp{from{transform:translateY(20px);opacity:0}10%{opacity:.85}90%{opacity:.85}to{transform:translateY(-120px);opacity:0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes wiggle{0%,100%{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}
@keyframes pop{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* ---------- Responsive ---------- */
@media (max-width:1000px){
  .grid{grid-template-columns:repeat(3,1fr)}
  .features{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:820px){
  .nav{
    position:fixed;inset:0 0 0 auto;width:min(78vw,320px);background:#fff;
    flex-direction:column;justify-content:center;gap:1.6rem;padding:2rem;
    transform:translateX(110%);transition:transform .3s ease;box-shadow:var(--shadow-lg);
    margin:0;z-index:95;
  }
  .nav.is-open{transform:none}
  .nav a{font-size:1.3rem}
  .burger{display:flex}
  .hero__inner{grid-template-columns:1fr;text-align:center}
  .hero__copy{order:2}
  .hero__art{order:1;min-height:320px}
  .hero__lead{margin-inline:auto}
  .hero__cta,.hero__trust{justify-content:center}
  .club__inner{grid-template-columns:1fr}
  .collections,.reviews{grid-template-columns:1fr}
}
@media (max-width:620px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .features{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:1fr 1fr}
  .hero__title{font-size:clamp(2.6rem,13vw,4rem)}
}
@media (max-width:420px){
  .grid{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:1fr}
}
