:root{
  --cream:#FFF4EC; --cream2:#FFE9DC; --ink:#1A1310; --pop:#FF2D55; --pop2:#FF5C7A;
  --red:#E2123B; --yellow:#FFC93C; --pink:#FFD9E2; --white:#fff;
  --shadow:0 18px 40px rgba(226,18,59,.18); --shadow-soft:0 10px 30px rgba(26,19,16,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--cream);color:var(--ink);
  overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.disp,h1,h2,h3,.h2{font-family:'Bricolage Grotesque','Inter',sans-serif;font-weight:800;letter-spacing:-.02em;line-height:.98}
.hl{color:var(--pop);position:relative;white-space:nowrap}
.hl::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.06em;height:.34em;
  background:var(--yellow);z-index:-1;border-radius:.2em;transform:rotate(-1.5deg)}
.pill{display:inline-flex;align-items:center;gap:.4em;background:var(--ink);color:var(--cream);
  font-weight:700;font-size:.82rem;padding:8px 15px;border-radius:999px}
.pill--yellow{background:var(--yellow);color:var(--ink)}
.pill--wiggle{animation:wiggle 2.6s ease-in-out infinite}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-weight:700;
  font-size:1rem;padding:16px 26px;border-radius:999px;border:2.5px solid var(--ink);cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;background:var(--white);color:var(--ink)}
.btn:hover{transform:translateY(-3px) rotate(-1deg)}
.btn--pop{background:var(--pop);color:#fff;box-shadow:6px 6px 0 var(--ink)}
.btn--pop:hover{box-shadow:9px 9px 0 var(--ink);background:var(--pop2)}
.btn--ghost{background:transparent}
.btn--full{width:100%}
.h2{font-size:clamp(2rem,5.5vw,3.6rem);text-align:center}

/* TICKER */
.ticker{background:var(--ink);color:var(--cream);overflow:hidden;padding:9px 0;font-size:.8rem;font-weight:600}
.ticker__t{display:inline-flex;white-space:nowrap;animation:scroll 26s linear infinite}
.ticker__t span{padding:0 22px;display:inline-flex;gap:7px}

/* NAV */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  gap:18px;padding:14px clamp(16px,4vw,46px);background:rgba(255,244,236,.82);backdrop-filter:blur(10px);
  border-bottom:2px solid var(--ink)}
.brand{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.35rem;letter-spacing:-.03em;line-height:.85}
.brand span{display:block;color:var(--pop);font-size:.62em;letter-spacing:.32em}
.nav__links{display:flex;gap:26px;font-weight:600;font-size:.95rem}
.nav__links a:hover{color:var(--pop)}
.nav__cta{background:var(--ink);color:var(--cream);font-weight:700;padding:11px 20px;border-radius:999px;font-size:.92rem}
.nav__cta:hover{background:var(--pop)}

/* HERO */
.hero{position:relative;padding:clamp(40px,7vw,90px) clamp(16px,4vw,46px) clamp(60px,9vw,120px);overflow:hidden}
.hero__blob{position:absolute;border-radius:50%;filter:blur(10px);z-index:0;opacity:.55}
.hero__blob--1{width:46vw;height:46vw;background:var(--pink);top:-12vw;right:-10vw}
.hero__blob--2{width:30vw;height:30vw;background:var(--yellow);bottom:-8vw;left:-8vw;opacity:.4}
.hero__grid{position:relative;z-index:2;max-width:1200px;margin:0 auto;display:grid;
  grid-template-columns:1.05fr .95fr;align-items:center;gap:clamp(20px,4vw,60px)}
.hero__copy h1{font-size:clamp(2.8rem,8vw,6rem);margin:.2em 0 .35em}
.hero__copy .hl{font-style:italic}
.hero__copy p{font-size:clamp(1.05rem,1.6vw,1.3rem);max-width:30ch;color:#4b3b34;line-height:1.5;margin-bottom:1.5em}
.hero__btns{display:flex;gap:14px;flex-wrap:wrap}
.hero__rating{margin-top:22px;font-weight:600;font-size:.92rem;color:#5b4a42}
.hero__rating b{color:var(--ink)}
/* hero art */
.hero__art{position:relative;display:flex;align-items:center;justify-content:center;min-height:420px}
.shirt{position:relative;width:min(330px,80%);aspect-ratio:4/4.6;background:#fff;border:3px solid var(--ink);
  border-radius:26px 26px 30px 30px;box-shadow:var(--shadow);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:4px;padding:26px 18px;transform:rotate(-4deg)}
.shirt__l1{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.5rem;line-height:1}
.shirt__l2{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.9rem;color:var(--pop);font-style:italic;margin:2px 0}
.shirt__qr{width:108px;height:108px;margin:6px 0}
.shirt__qr img,.shirt__qr canvas{width:100%!important;height:100%!important;border-radius:6px}
.shirt__l3{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.7rem;color:var(--pop);letter-spacing:.06em}
.phone{position:absolute;right:-6%;bottom:2%;width:128px;height:248px;background:var(--ink);border-radius:26px;
  padding:9px;z-index:5;box-shadow:0 16px 30px rgba(0,0,0,.28);transform:rotate(7deg)}
.phone__notch{width:46px;height:8px;background:#333;border-radius:9px;margin:2px auto 6px}
.phone__scan{position:relative;height:calc(100% - 16px);background:#0c0c0c;border-radius:16px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;overflow:hidden}
.phone__scan::after{content:"";position:absolute;left:8%;right:8%;height:2px;background:var(--pop);
  box-shadow:0 0 12px var(--pop);animation:scanline 2.2s ease-in-out infinite}
.phone__qr{width:84px;height:84px;background:#fff;border-radius:8px;padding:5px}
.phone__qr img,.phone__qr canvas{width:100%!important;height:100%!important}
.phone__hint{color:#9ad;font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.float{position:absolute;font-size:2rem;z-index:6}
.float--heart{top:4%;left:2%;animation:float 4s ease-in-out infinite}
.float--spark{top:30%;right:0%;animation:float 5s ease-in-out infinite .4s}
.float--fire{bottom:6%;left:8%;animation:float 4.6s ease-in-out infinite .8s}

/* MARQUEE */
.marq{background:var(--pop);color:#fff;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);
  padding:14px 0;overflow:hidden;transform:rotate(-1deg);margin:30px 0;width:103%;margin-left:-1.5%}
.marq__t{display:inline-flex;white-space:nowrap;animation:scroll 22s linear infinite;align-items:center}
.marq__t span{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.5rem;padding:0 20px;letter-spacing:.02em}
.marq__t i{font-style:normal;color:var(--yellow);font-size:1.3rem}

/* CÓMO */
.como{padding:clamp(50px,8vw,100px) clamp(16px,4vw,46px);max-width:1150px;margin:0 auto}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.step{background:#fff;border:3px solid var(--ink);border-radius:24px;padding:30px 26px;position:relative;
  box-shadow:var(--shadow-soft);transition:transform .18s}
.step:hover{transform:translateY(-6px) rotate(1deg)}
.step--mid{background:var(--pink)}
.step__n{position:absolute;top:-18px;left:24px;width:42px;height:42px;background:var(--pop);color:#fff;
  border:3px solid var(--ink);border-radius:50%;display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:800;font-size:1.3rem}
.step__emoji{font-size:2.6rem;margin:8px 0 14px}
.step h3{font-size:1.5rem;margin-bottom:8px}
.step p{color:#5b4a42;line-height:1.55}

/* PERSONALIZADOR */
.crea{padding:clamp(50px,8vw,100px) clamp(16px,4vw,46px);background:var(--cream2);
  border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.crea__head{text-align:center;max-width:640px;margin:0 auto 50px}
.crea__head .pill{margin-bottom:16px}
.crea__sub{margin-top:12px;color:#5b4a42;font-size:1.05rem}
.crea__grid{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.crea__panel{background:#fff;border:3px solid var(--ink);border-radius:28px;padding:clamp(22px,3vw,38px);box-shadow:var(--shadow)}
.field{display:block;margin-bottom:22px}
.field>span{font-weight:700;display:block;margin-bottom:8px}
.field__in{display:flex;align-items:center;border:2.5px solid var(--ink);border-radius:14px;overflow:hidden;background:#fff}
.field__in i{font-style:normal;font-weight:800;padding:0 4px 0 16px;color:var(--pop);font-size:1.25rem}
.field__in input{flex:1;border:0;outline:0;padding:15px 14px 15px 4px;font-size:1.15rem;font-weight:600;background:transparent}
.opt{margin-bottom:20px}
.opt__label{font-weight:700;display:block;margin-bottom:9px}
.opt__row{display:flex;flex-wrap:wrap;gap:9px}
.chip{border:2.5px solid var(--ink);background:#fff;border-radius:12px;padding:10px 15px;font-weight:700;cursor:pointer;
  font-size:.95rem;transition:all .12s;display:flex;flex-direction:column;line-height:1.1;align-items:flex-start}
.chip small{font-weight:600;color:#8a766c;font-size:.72rem}
.chip:hover{transform:translateY(-2px)}
.chip.on{background:var(--ink);color:#fff}
.chip.on small{color:#ffd9e2}
.crea__price{font-family:'Bricolage Grotesque';font-weight:800;font-size:2rem;margin:6px 0 18px;display:flex;align-items:center;gap:12px}
.crea__price s{font-family:'Inter';font-size:1.1rem;color:#b7a79e;font-weight:500}
.crea__price .save{font-family:'Inter';font-size:.78rem;background:var(--yellow);border:2px solid var(--ink);
  padding:3px 9px;border-radius:999px;font-style:normal;font-weight:700}
.crea__note{margin-top:12px;font-size:.82rem;color:#8a766c;text-align:center}
.crea__preview{display:flex;flex-direction:column;align-items:center;gap:16px}
.prevshirt{width:min(320px,86%);aspect-ratio:4/4.7;background:#fff;border:3px solid var(--ink);border-radius:26px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px 18px;box-shadow:var(--shadow);transform:rotate(3deg)}
.prevshirt__l1{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.55rem;line-height:1.05}
.prevshirt__l2{font-family:'Bricolage Grotesque';font-weight:800;font-size:2rem;color:var(--pop);font-style:italic;margin:3px 0}
.prevshirt__qr{width:122px;height:122px;margin:8px 0;display:grid;place-items:center;background:#f3f3f3;border-radius:8px}
.prevshirt__qr img,.prevshirt__qr canvas{width:100%!important;height:100%!important;border-radius:6px}
.prevshirt__l3{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.8rem;color:var(--pop);letter-spacing:.06em}
.prevtag{background:var(--ink);color:#fff;font-weight:700;padding:8px 16px;border-radius:999px;font-size:.9rem;transform:rotate(-2deg)}

/* TIENDA */
.tienda{padding:clamp(50px,8vw,100px) clamp(16px,4vw,46px);max-width:1150px;margin:0 auto}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.card{background:#fff;border:3px solid var(--ink);border-radius:26px;overflow:hidden;box-shadow:var(--shadow-soft);
  transition:transform .18s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-7px) rotate(-1deg)}
.card__img{position:relative;aspect-ratio:1/1;background:var(--cream2);overflow:hidden}
.card__img img{width:100%;height:100%;object-fit:cover}
.card__tag{position:absolute;top:12px;left:12px;background:var(--yellow);border:2px solid var(--ink);
  font-weight:700;font-size:.72rem;padding:5px 11px;border-radius:999px;transform:rotate(-3deg)}
.card__b{padding:18px 20px 22px}
.card__b h3{font-size:1.2rem;line-height:1.15;margin-bottom:6px}
.card__pr{font-weight:800;font-size:1.15rem;margin-bottom:14px}
.card__pr s{color:#b7a79e;font-weight:500;font-size:.92rem;margin-left:7px}
.card .btn{font-size:.92rem;padding:13px 20px;width:100%}

/* REVIEWS chat */
.revs{padding:clamp(50px,8vw,100px) clamp(16px,4vw,46px);max-width:780px;margin:0 auto}
.chats{display:flex;flex-direction:column;gap:18px;margin-top:46px}
.chat{display:flex;flex-direction:column;gap:5px;max-width:78%}
.chat--r{align-self:flex-end;align-items:flex-end}
.bubble{background:#fff;border:2.5px solid var(--ink);border-radius:20px 20px 20px 5px;padding:14px 18px;
  font-weight:600;font-size:1.05rem;box-shadow:var(--shadow-soft)}
.bubble--r{background:var(--pop);color:#fff;border-radius:20px 20px 5px 20px}
.who{font-size:.78rem;font-weight:700;color:#8a766c;padding:0 6px}

/* FAQ */
.faq{padding:clamp(50px,8vw,90px) clamp(16px,4vw,46px);max-width:760px;margin:0 auto}
.acc{margin-top:40px;display:flex;flex-direction:column;gap:12px}
.acc details{background:#fff;border:2.5px solid var(--ink);border-radius:16px;padding:4px 20px;box-shadow:var(--shadow-soft)}
.acc summary{font-weight:700;font-size:1.08rem;cursor:pointer;padding:16px 0;list-style:none;display:flex;justify-content:space-between;align-items:center}
.acc summary::-webkit-details-marker{display:none}
.acc summary::after{content:"+";font-family:'Bricolage Grotesque';font-size:1.6rem;color:var(--pop)}
.acc details[open] summary::after{content:"–"}
.acc p{padding:0 0 18px;color:#5b4a42;line-height:1.6}

/* FOOTER */
.foot{background:var(--ink);color:var(--cream);text-align:center;padding:60px 22px 40px;border-top:3px solid var(--ink)}
.foot__brand{font-family:'Bricolage Grotesque';font-weight:800;font-size:2rem;line-height:.85}
.foot__brand span{display:block;color:var(--pop);font-size:.55em;letter-spacing:.4em}
.foot__tag{margin:14px 0 24px;color:#d8c8bf}
.foot__links{display:flex;flex-wrap:wrap;gap:8px 22px;justify-content:center;font-size:.9rem;font-weight:600;margin-bottom:26px}
.foot__links a{color:#e7dad2;border-bottom:1px solid transparent}
.foot__links a:hover{color:#fff;border-color:var(--pop)}
.foot__cr{font-size:.8rem;color:#9b8a81}

/* ANIM */
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes wiggle{0%,100%{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes scanline{0%,100%{top:14%}50%{top:78%}}

/* RESPONSIVE */
@media(max-width:880px){
  .nav__links{display:none}
  .hero__grid{grid-template-columns:1fr;text-align:center}
  .hero__copy p{margin-left:auto;margin-right:auto}
  .hero__btns,.hero__copy .pill{justify-content:center}
  .hero__art{margin-top:30px;min-height:380px}
  .steps{grid-template-columns:1fr}
  .crea__grid{grid-template-columns:1fr}
  .crea__preview{order:-1}
  .cards{grid-template-columns:1fr}
  .chat{max-width:90%}
}

/* ===== i18n: language button + modal ===== */
.nav__right{display:flex;align-items:center;gap:12px}
.nav__lang{background:#fff;border:2.5px solid var(--ink);border-radius:999px;font-weight:700;
  padding:9px 13px;cursor:pointer;font-size:.85rem;font-family:inherit;line-height:1}
.nav__lang:hover{background:var(--yellow)}
.lang-modal{position:fixed;inset:0;background:rgba(20,16,15,.55);backdrop-filter:blur(5px);
  display:none;align-items:center;justify-content:center;z-index:200;padding:20px}
.lang-modal.on{display:flex;animation:fadein .2s ease}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.lang-box{background:var(--cream);border:3px solid var(--ink);border-radius:28px;max-width:470px;width:100%;
  padding:clamp(24px,4vw,36px);box-shadow:0 24px 60px rgba(0,0,0,.32);text-align:center}
.lang-box h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.9rem;margin-bottom:6px}
.lang-box p{color:#5b4a42;margin-bottom:22px}
.lang-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.lang-opt{display:flex;align-items:center;gap:11px;background:#fff;border:2.5px solid var(--ink);
  border-radius:15px;padding:15px 16px;font-weight:700;cursor:pointer;font-size:1rem;font-family:inherit;
  transition:transform .12s,background .12s;text-align:left}
.lang-opt:hover{transform:translateY(-2px);background:var(--pink)}
.lang-opt .fl{font-size:1.45rem}
@media(max-width:520px){.lang-grid{grid-template-columns:1fr}}

/* ===== hero image + gloss ===== */
.hero__gloss{font-style:italic;color:#8a766c;margin:-.2em 0 1em;font-size:1.02rem}
.heroimg{width:min(340px,84%);aspect-ratio:4/5;border:3px solid var(--ink);border-radius:26px;overflow:hidden;
  box-shadow:var(--shadow);transform:rotate(-3deg)}
.heroimg img{width:100%;height:100%;object-fit:cover;display:block}

/* ===== concert gallery ===== */
.concert{padding:10px 0 30px}
.concert__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:1150px;margin:0 auto;padding:0 clamp(16px,4vw,46px)}
.concert figure{margin:0;border:3px solid var(--ink);border-radius:22px;overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-soft)}
.concert figure img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.concert figure:hover img{transform:scale(1.05)}
@media(max-width:760px){.concert__grid{grid-template-columns:1fr 1fr}.concert figure:last-child{grid-column:1/-1;aspect-ratio:16/9}}
