:root{
  --bg:#fffdfb;
  --text:#222069;
  --muted:#325;
  --pink:#f8c7de;
  --violet:#205a69;
  --blue:#c9ecff;
  --yellow:#325;
  --danger:#f7b7c3;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial,sans-serif;
  background-image:url('fondo-acuarela.png');
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  background-attachment:fixed;
  color:var(--text);
}

.topbar{
  position:sticky;top:0;z-index:20;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:16px 28px;
  background:rgba(255,255,255,.58);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.45);
  box-shadow:0 8px 24px rgba(170,157,188,.12);
}
.brand{display:flex;align-items:center;gap:14px}
.brand-badge{
  width:44px;height:44px;border-radius:14px;display:grid;place-items:center;
  font-weight:800;color:#6f5b67;background:linear-gradient(135deg,#fff6d2,#ffffff);
  box-shadow:0 10px 24px rgba(255,240,168,.26);
}
.brand h1{margin:0;font-size:20px;color:#5f566b}
.brand p{margin:2px 0 0;color:var(--muted);font-size:13px}
.nav{display:flex;gap:12px;flex-wrap:wrap}
.nav a{
  display:inline-block;
  padding:10px 18px;
  border-radius:16px;
  background:#f7cfc1;
  color:#6b4b3e;
  text-decoration:none;
  font-weight:700;
  font-size:14px;
  opacity:1;
  border:1px solid rgba(107, 75, 62, 0.12);
  box-shadow:0 4px 10px rgba(0, 0, 0, 0.06);
  transition:transform 0.22s ease, background 0.22s ease, box-shadow 0.22s ease;
}
.nav a:hover{
  color:#6b4b3e;
  background:#f4bfae;
  transform:scale(1.07);
  box-shadow:0 8px 18px rgba(0, 0, 0, 0.10);
}

.hero{position:relative;min-height:620px;display:flex;align-items:flex-end;overflow:hidden}
.hero-slider,.hero-slide{position:absolute;inset:0}
.hero-slide{opacity:0;transition:opacity .45s ease}
.hero-slide.active{opacity:1}
.hero-slide img,.hero-slide video{width:100%;height:100%;object-fit:cover;filter:saturate(1.05)}
.hero-slide video{display:block}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(255,255,255,.18),rgba(255,255,255,.36) 40%,rgba(255,255,255,.72) 100%),
    linear-gradient(90deg,rgba(248,199,222,.16),transparent 50%,rgba(201,236,255,.12));
}
.hero-content{position:relative;z-index:2;max-width:920px;padding:110px 28px 70px}
.eyebrow{display:inline-block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#325;margin-bottom:14px}
.hero h2{font-size:58px;line-height:1.02;margin:0 0 16px;max-width:760px}
.hero p{margin:0;color:#325;font-size:18px;line-height:1.6;max-width:760px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero-tags{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.hero-tags span{
  background:rgba(255,255,255,.58);border:1px solid rgba(255,255,255,.46);backdrop-filter:blur(12px);
  border-radius:999px;padding:10px 14px;color:#6f6580;font-weight:700;
}
.slider-btn{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:42px;height:42px;border:none;border-radius:999px;
  background:rgba(255,255,255,.16);backdrop-filter:blur(10px);color:white;font-size:28px;cursor:pointer;
  border:1px solid rgba(255,255,255,.18);
}
.slider-btn.prev{left:18px}.slider-btn.next{right:18px}
.slider-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:8px}
.dot{width:11px;height:11px;border-radius:50%;border:none;background:rgba(255,255,255,.35);cursor:pointer}
.dot.active{background:white}

.section{padding:78px 28px;max-width:1200px;margin:0 auto}
.section.alt{
  background:rgba(255,255,255,.34);
  border-top:1px solid rgba(255,255,255,.42);
  border-bottom:1px solid rgba(255,255,255,.42);
  max-width:none;
  padding-left:max(28px, calc((100vw - 1200px)/2 + 28px));
  padding-right:max(28px, calc((100vw - 1200px)/2 + 28px));
}
.section-head{text-align:center;max-width:760px;margin:0 auto 32px}
.section-head h3{margin:0 0 10px;font-size:38px}
.section-head p{margin:0;color:var(--muted);line-height:1.65}

.glass-panel,.gallery-card,.cart-item{
  background:linear-gradient(135deg, rgba(255,255,255,.72), rgba(255,255,255,.46));
  border:1px solid rgba(255,255,255,.54);
  box-shadow:0 18px 45px rgba(176,164,194,.16), inset 0 1px 0 rgba(255,255,255,.34);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}

.products-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.product-card{
  position:relative;overflow:hidden;border-radius:26px;padding:16px 16px 12px;
  background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.56));
  border:1px solid rgba(255,255,255,.54);
  box-shadow:0 18px 45px rgba(176,164,194,.18), inset 0 1px 0 rgba(255,255,255,.22);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.gallery-card::before,.mockup-card::before{
  content:"";position:absolute;inset:-20% auto auto -20%;width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle, rgba(247,168,215,.35), transparent 70%);pointer-events:none;
}
.gallery-card::after,.mockup-card::after{
  content:"";position:absolute;inset:auto -18% -18% auto;width:140px;height:140px;border-radius:50%;
  background:radial-gradient(circle, rgba(155,220,255,.32), transparent 70%);pointer-events:none;
}
.product-card:hover,.gallery-card:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 55px rgba(0,0,0,.28),0 0 0 1px rgba(255,255,255,.08),inset 0 1px 0 rgba(255,255,255,.24);
  border-color:rgba(255,255,255,.18);
}
.product-card h3{position:relative;z-index:1;margin:0 0 8px;font-size:18px;line-height:1.25}
.product-card p{position:relative;z-index:1;margin:0 0 18px;color:#756d86;min-height:68px;line-height:1.45}
.precio{position:relative;z-index:1;color:#7a6789;font-size:18px;font-weight:800;margin-bottom:14px}
.product-image,.producto-img{
  width:100%;
  height:250px;
  object-fit:cover;
  border-radius:20px;
  margin-bottom:14px;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22), 0 10px 24px rgba(0,0,0,.10);
  display:block;
}
.sunset-glass{background:linear-gradient(180deg, #f4c85f 0%, #e462b0 52%, #8147d7 100%)}
.blue-glass{background:linear-gradient(135deg, #1f4b9a 0%, #57b9e6 58%, #a388d6 100%)}
.rainbow-glass{background:linear-gradient(135deg, #ff6bc4 0%, #f1d14c 55%, #60b8db 100%)}
.mint-glass{background:linear-gradient(135deg, #74d9d2 0%, #7ca2ff 100%)}
.violet-glass{background:linear-gradient(135deg, #9e8cff 0%, #ff8ac4 100%)}
.peach-glass{background:linear-gradient(135deg, #ffd29b 0%, #ff8a9d 100%)}
.rose-glass{background:linear-gradient(135deg, #ffa9c8 0%, #bc8cff 100%)}
.aqua-glass{background:linear-gradient(135deg, #82f1e0 0%, #66b4ff 100%)}

.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.gallery-card{
  position:relative;min-height:150px;overflow:hidden;border-radius:26px;
  display:flex;align-items:flex-end;padding:0;font-weight:800;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.gallery-card img{
  width:100%;
  height:100%;
  min-height:220px;
  object-fit:cover;
  display:block;
}
.gallery-card.empty{
  min-height:220px;
  padding:20px;
  color:var(--muted);
  align-items:center;
  justify-content:center;
  text-align:center;
}

.calc-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}
.calc-card,.upload-card,.summary-box,.contact-box,.coupon-box,.mockup-controls,.mockup-stage{
  padding:22px;border-radius:26px;
}
.feature-list{margin:0 0 18px;padding-left:18px;color:var(--muted);line-height:1.7}
.calc-card label,.mockup-controls label{display:block;margin:14px 0 8px;font-weight:700}
.calc-card select,.calc-card input,.coupon-box input,.mockup-controls input,.mockup-controls select{
  width:100%;padding:14px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.54);
  background:rgba(255,255,255,.66);color:#625973;outline:none;backdrop-filter:blur(8px);
}
.check-row{display:flex !important;align-items:center;gap:10px}
.check-row input{width:auto}
.hidden{display:none}
.calc-total{display:flex;justify-content:space-between;align-items:center;margin:20px 0 10px;font-size:18px;color:var(--muted)}
.calc-total span{font-size:30px;color:#1e3a8a;font-weight:800}
.preview-box{
  min-height:310px;border-radius:22px;display:flex;justify-content:center;align-items:center;padding:16px;margin-top:16px;
  position:relative;overflow:hidden;text-align:center;color:var(--muted);
  background:linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(10px);
}
.preview-box img{max-width:100%;max-height:100%;display:none;border-radius:16px}
.preview-box.has-image img{display:block}
.preview-box.has-image span{display:none}

.mockup-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:18px}
.mockup-help,.send-note{color:var(--muted);line-height:1.6}
.mockup-actions{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.mockup-stage{position:relative;min-height:540px}
.mockup-card{
  position:relative;min-height:494px;overflow:hidden;border-radius:30px;
  background:linear-gradient(180deg, #fafafa, #e9eef5 100%);
  border:1px solid rgba(19,26,41,.08);
  box-shadow:0 28px 60px rgba(0,0,0,.18);
}
.mockup-gradient{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 15% 15%, rgba(255,255,255,.95), transparent 22%),
    radial-gradient(circle at 85% 10%, rgba(215,222,232,.85), transparent 22%),
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(231,237,244,.92));
}
.mockup{
  position:absolute;inset:24px 24px 86px 24px;
  display:none;align-items:center;justify-content:center;
}
.mockup.active{display:flex}
.mockup-product{position:relative;display:flex;align-items:center;justify-content:center}
.mockup-image-area{
  position:relative;overflow:hidden;
  background:#f5f5f5;
  border:1px solid rgba(35,45,62,.10);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.50);
}
.mockup-image{
  width:100%;height:100%;object-fit:cover;display:none;
}
.mockup-image.visible{display:block}

.cuadro-frame{
  width:380px;height:270px;padding:16px;border-radius:8px;
  background:linear-gradient(145deg, #1b1b1b, #555);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 22px 40px rgba(0,0,0,.24);
}
.rectangular{width:100%;height:100%;border-radius:12px}

.camiseta-shape{
  width:300px;height:340px;border-radius:34px 34px 28px 28px;
  background:linear-gradient(180deg, #ffffff 0%, #eceff4 100%);
  box-shadow:0 24px 42px rgba(0,0,0,.16);
}
.camiseta-shape::before,.camiseta-shape::after{
  content:"";position:absolute;top:22px;width:82px;height:98px;
  background:linear-gradient(180deg, #ffffff 0%, #eceff4 100%);border-radius:24px;filter:brightness(.98);
}
.camiseta-shape::before{left:-34px;transform:rotate(-24deg)}
.camiseta-shape::after{right:-34px;transform:rotate(24deg)}
.tshirt-print{
  width:150px;height:176px;border-radius:12px;position:absolute;top:86px;
  background:#f4f4f4;
}

.mug-shape{
  width:330px;height:206px;border-radius:24px;
  background:linear-gradient(180deg, #ffffff 0%, #e8ecf2 100%);
  box-shadow:0 24px 40px rgba(0,0,0,.18);
}
.mockup-handle{
  position:absolute;right:-42px;top:48px;width:84px;height:104px;border-radius:50%;
  border:16px solid rgba(233,237,243,.96);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.30);
}
.mug-print{
  width:188px;height:122px;border-radius:14px;position:absolute;left:52px;top:42px;
  background:#f4f4f4;
}

.keychain-shape{
  width:190px;height:250px;border-radius:32px;
  background:linear-gradient(180deg, #ffffff 0%, #e9edf3 100%);
  box-shadow:0 18px 38px rgba(0,0,0,.18);
}
.mockup-ring{
  position:absolute;top:-34px;left:50%;transform:translateX(-50%);
  width:68px;height:68px;border-radius:50%;
  border:10px solid rgba(255,255,255,.76);
}
.keychain-print{
  width:130px;height:170px;border-radius:18px;position:absolute;top:48px;
  background:#f4f4f4;
}

.mockup-caption{
  position:absolute;left:24px;right:24px;bottom:22px;z-index:2;
  padding:16px 18px;border-radius:18px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(19,26,41,.08);
  box-shadow:0 8px 20px rgba(0,0,0,.08);
}
.mockup-caption strong{display:block;font-size:18px;margin-bottom:4px;color:#1c2431}
.mockup-caption span{color:#5f6c82}

.promo-bar{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:18px;margin-bottom:18px;border-radius:26px;
}
.promo-bar div{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:14px;color:var(--muted);
}
.coupon-box{display:flex;gap:12px;align-items:center;margin-bottom:10px}
.coupon-msg{min-height:22px;text-align:center;color:#bce7ff;margin:0 0 18px}
.cart-list{display:flex;flex-direction:column;gap:12px;margin-bottom:18px}
.cart-item{padding:18px;border-radius:24px;display:flex;justify-content:space-between;gap:14px;align-items:center}
.cart-item-info strong{display:block;font-size:18px;margin-bottom:6px}
.cart-item-info span{display:block;color:#325;line-height:1.5}
.cart-controls{display:flex;gap:8px;flex-wrap:wrap}
.mini-btn{
  border:none;background:rgba(29,53,82,.72);backdrop-filter:blur(8px);color:white;padding:10px 12px;border-radius:12px;cursor:pointer;
  font-weight:700;border:1px solid rgba(255,255,255,.10);
}
.mini-btn.delete{background:rgba(77,30,49,.72)}
.summary-box p{margin:0 0 12px;display:flex;justify-content:space-between;gap:14px;color:var(--muted)}
.summary-box strong{color:white}
.summary-total{margin-top:18px !important;padding-top:16px;border-top:1px solid rgba(255,255,255,.10);font-size:22px}
.summary-total strong{color:var(--yellow);font-size:28px}
.cart-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:20px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;text-decoration:none;padding:14px 20px;border-radius:14px;
  font-weight:800;cursor:pointer;transition:transform .15s ease, opacity .15s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,#fff3bf,#ffe7f3);color:#6c5966}
.btn-secondary{background:linear-gradient(135deg,rgba(217,196,255,.72),rgba(201,236,255,.66));color:#665c78;border:1px solid rgba(255,255,255,.46)}
.btn-danger{background:linear-gradient(135deg,rgba(247,183,195,.78),rgba(255,220,226,.78));color:#7b5964;border:1px solid rgba(255,255,255,.46)}
.full{width:100%}

.contact-box p{margin:0 0 12px;color:var(--muted)}
.contact-box strong{color:white}
.footer{border-top:1px solid rgba(255,255,255,.42);text-align:center;padding:30px 20px 40px;color:var(--muted);background:rgba(255,255,255,.28)}

@media (max-width: 980px){
  .hero h2{font-size:42px}
  .calc-layout,.mockup-layout{grid-template-columns:1fr}
  .promo-bar{grid-template-columns:1fr}
  .coupon-box{flex-direction:column}
  .coupon-box .btn{width:100%}
}
@media (max-width: 760px){
  .topbar{padding:14px 18px;flex-direction:column;align-items:flex-start}
  .hero{min-height:560px}
  .hero-content{padding:90px 18px 56px}
  .hero h2{font-size:34px}
  .section{padding:60px 18px}
  .section.alt{padding-left:18px;padding-right:18px}
  .cart-item{flex-direction:column;align-items:flex-start}
  .cuadro-frame{width:280px;height:200px}
  .camiseta-shape{width:230px;height:270px}
  .tshirt-print{width:118px;height:138px;top:68px}
  .mug-shape{width:250px;height:160px}
  .mug-print{width:138px;height:96px;left:40px;top:30px}
  .mockup-handle{right:-34px;top:36px;width:72px;height:88px;border-width:14px}
  .keychain-shape{width:160px;height:220px}
  .keychain-print{width:112px;height:148px}
}


/* TITULO CATALOGO */
.titulo-catalogo{
  font-size:32px;
  font-weight:800;
}

/* TARJETAS PRODUCTO */
.producto{
  transform:scale(1.05);
  backdrop-filter: blur(12px);
  background: rgba(255,255,255,0.25);
  border-radius:18px;
  border:1px solid rgba(255,255,255,0.3);
  box-shadow:0 8px 25px rgba(0,0,0,0.1);
  padding:15px;
}

/* CENTRAR BOTON Y PRECIO */
.producto .precio,
.producto button{
  display:block;
  margin:10px auto;
  text-align:center;
}


/* ===== AJUSTE CATÁLOGO v27 ===== */
.product-card{
  background:linear-gradient(135deg, rgba(255,255,255,.78), rgba(255,255,255,.54)) !important;
  border:1px solid rgba(255,255,255,.58) !important;
  box-shadow:0 18px 45px rgba(176,164,194,.16), inset 0 1px 0 rgba(255,255,255,.28) !important;
  backdrop-filter:blur(18px) !important;
  -webkit-backdrop-filter:blur(18px) !important;
}

.product-card:hover{
  transform:translateY(-8px) scale(1.08) !important;
  box-shadow:0 28px 60px rgba(0,0,0,.22), 0 0 0 1px rgba(255,255,255,.12), inset 0 1px 0 rgba(255,255,255,.24) !important;
}

.product-card .precio{
  display:block !important;
  width:100% !important;
  text-align:center !important;
  margin:0 auto 14px auto !important;
}

.product-card .btn{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  width:fit-content !important;
  margin:0 auto !important;
}



.product-options-box{
  margin-top:10px;
}


.stock-disponible{
  display:block;
  width:100%;
  text-align:center !important;
  margin:12px auto 4px auto;
}

.mockup-adjust{
  margin:16px 0 12px;
  padding:14px;
  border-radius:18px;
  background:linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.14);
}

.mockup-adjust h4{
  margin:0 0 12px;
  font-size:15px;
}

.mockup-adjust input[type="range"]{
  width:100%;
  margin-top:6px;
}

.mockup-image-area{
  display:flex;
  align-items:center;
  justify-content:center;
}

.mockup-image{
  width:100%;
  height:100%;
  object-fit:cover;
  transform-origin:center center;
  transition:transform .18s ease;
}

.cuadro-frame{
  background:linear-gradient(145deg, #151515, #4b4b4b);
  box-shadow:0 24px 44px rgba(0,0,0,.28);
}

.camiseta-shape{
  background:linear-gradient(180deg, #ffffff 0%, #e6ebf2 100%);
  box-shadow:0 28px 46px rgba(0,0,0,.18);
}


.product-card .product-meta{
  display:block;
  width:100%;
  text-align:center !important;
  margin:6px auto !important;
}


.mockup-tip{
  margin:0 0 12px;
  color:var(--muted);
  line-height:1.5;
  font-size:13px;
}

.mockup-image-area{
  cursor:grab;
}

.mockup-image-area:active{
  cursor:grabbing;
}

.mockup-image{
  object-fit:contain !important;
}

/* Camiseta más real */
.camiseta-shape{
  width:350px;
  height:400px;
  background:transparent !important;
  box-shadow:none !important;
  position:relative;
}

.camiseta-shape::before,
.camiseta-shape::after{
  display:none !important;
}

.camiseta-shape::after{
  display:none !important;
}

.camiseta-shape{
  background-image:url('camisetas.png') !important;
  background-repeat:no-repeat !important;
  background-position:center center !important;
  background-size:contain !important;
}

.tshirt-print{
  width:165px;
  height:185px;
  border-radius:14px;
  position:absolute;
  top:108px;
  left:92px;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
}

/* Cuadro más limpio para mover diseño */
.rectangular{
  background:#f3f3f3;
}

@media (max-width: 760px){
  .camiseta-shape{
    width:260px;
    height:305px;
  }
  .tshirt-print{
    width:122px;
    height:136px;
    top:83px;
    left:69px;
  }
}


/* ===== v34: controles sobre el modelo ===== */
.mockup-stage{
  display:flex;
  flex-direction:column;
}

.mockup-stage > .mockup-adjust{
  margin:0 0 16px 0;
}


/* ===== v35 mockups reales y fusión ===== */
.mockup-image{
  mix-blend-mode:multiply;
  opacity:.95;
  filter:contrast(1.05) brightness(0.98);
}

.camiseta-shape{
  background-image:url('camisetas.png') !important;
  background-repeat:no-repeat !important;
  background-position:center center !important;
  background-size:contain !important;
  background-color:transparent !important;
  box-shadow:none !important;
}

.tshirt-print{
  top:38% !important;
  left:50% !important;
  width:42% !important;
  height:34% !important;
  transform:translate(-50%, -50%);
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
}

.mug-shape{
  background-image:url('mug_real.png') !important;
  background-repeat:no-repeat !important;
  background-position:center center !important;
  background-size:contain !important;
  background-color:transparent !important;
  box-shadow:none !important;
}

.mockup-handle{
  display:none !important;
}

.mug-print{
  top:52% !important;
  left:45% !important;
  width:45% !important;
  height:52% !important;
  transform:translate(-50%, -50%);
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
}

.mug-print .mockup-image{
  transform:translate(0,0) perspective(600px) rotateY(-8deg) scale(1);
  transform-origin:center center;
}

.hoodie-shape{
  width:360px;
  height:400px;
  position:relative;
  background-image:url('hoodie_real.png');
  background-repeat:no-repeat;
  background-position:center center;
  background-size:contain;
}

.hoodie-print{
  position:absolute;
  top:50%;
  left:50%;
  width:40%;
  height:30%;
  transform:translate(-50%, -50%);
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
}

@media (max-width: 760px){
  .hoodie-shape{
    width:260px;
    height:300px;
  }
}


/* ===== PALETA PASTEL TIPO MARCA ===== */
.hero h2,
.section-head h3,
.product-card h3,
.mockup-caption strong,
.summary-box strong,
.contact-box strong{
  color:#325;
}

.topbar,
.mockup-adjust,
.calc-card,
.upload-card,
.summary-box,
.contact-box,
.coupon-box,
.mockup-controls,
.mockup-stage,
.promo-bar{
  box-shadow:0 14px 34px rgba(176,164,194,.12);
}

.slider-btn{
  background:rgba(255,255,255,.68);
  color:#7a6d87;
  border:1px solid rgba(255,255,255,.48);
}

.dot{background:rgba(182,164,198,.42)}
.dot.active{background:#caa9d8}

.preview-box{
  background:linear-gradient(135deg, rgba(255,255,255,.56), rgba(255,255,255,.34));
  border:1px solid rgba(255,255,255,.46);
}

.coupon-msg{
  color:#7d7890;
}


/* LOGO EN RECUADRO (ARREGLO 5) */
.mockup-logo-box{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  width:420px;
  height:240px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.mockup-logo{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
}
.hero-subtitle{
  color:#000000; /* más oscuro pero elegante */
}
