/*
Theme Name:     PULP — Cult Merch
Theme URI:      https://pulp.cult/
Description:    Plantilla cinematográfica para tienda de merchandising de culto. Child theme de Hello Elementor. Estética giallo italiano + kaiju + Troma DIY. Incluye sistema de drops, badges VHS, hover grindhouse y overrides de WooCommerce.
Author:         PULP Studio
Author URI:     https://pulp.cult/
Template:       hello-elementor
Version:        1.0.0
Text Domain:    pulp-child
License:        GNU General Public License v2 or later
License URI:    http://www.gnu.org/licenses/gpl-2.0.html
Tags:           e-commerce, dark, custom-colors, custom-menu, theme-options, translation-ready, woocommerce
*/

/* ============================================================
   PULP · DESIGN SYSTEM
   1. Tokens (colors, type, spacing, radii)
   2. Reset + base
   3. Typography helpers
   4. Layout
   5. Effects (grain, scanlines, vignette)
   6. Buttons + forms
   7. Header / Ticker / Footer
   8. Components (poster card, badges, tape, stamp, countdown)
   9. WooCommerce overrides
   10. Elementor widget tweaks
   11. Responsive
   ============================================================ */

/* 1 · TOKENS ---------------------------------------------- */
:root{
  --pulp-ink:       #0a0606;
  --pulp-ink-2:     #140c0c;
  --pulp-ink-3:     #1d1313;
  --pulp-paper:     #f1e3b8;
  --pulp-paper-dim: #c9bb91;
  --pulp-paper-mute:#8a8064;
  --pulp-blood:     #d4001a;
  --pulp-blood-deep:#8a0010;
  --pulp-pink:      #ff2e88;
  --pulp-cyan:      #00e5ff;
  --pulp-yellow:    #ffb800;
  --pulp-rule:      #3a2a2a;

  --pulp-ff-slab:   "Alfa Slab One", Georgia, serif;
  --pulp-ff-editor: "DM Serif Display", Georgia, serif;
  --pulp-ff-body:   "Archivo", system-ui, -apple-system, sans-serif;
  --pulp-ff-mono:   "Space Mono", ui-monospace, Menlo, monospace;
  --pulp-ff-jp:     "Shippori Mincho", serif;

  --pulp-step-1:  8px;
  --pulp-step-2:  16px;
  --pulp-step-3:  24px;
  --pulp-step-4:  32px;
  --pulp-step-5:  48px;
  --pulp-step-6:  80px;

  --pulp-container: 1480px;
}

/* 2 · RESET + BASE --------------------------------------- */
html, body{ background: var(--pulp-ink); color: var(--pulp-paper); }
body{ font-family: var(--pulp-ff-body); -webkit-font-smoothing: antialiased; overflow-x: hidden; }
a{ color: inherit; }
::selection{ background: var(--pulp-blood); color: var(--pulp-paper); }
img, svg{ display: block; max-width: 100%; }
hr.pulp-rule{ border: 0; border-top: 1px solid var(--pulp-rule); margin: var(--pulp-step-4) 0; }
hr.pulp-rule--paper{ border-top: 1px dashed var(--pulp-paper-dim); }

/* 3 · TYPOGRAPHY ----------------------------------------- */
.pulp-slab     { font-family: var(--pulp-ff-slab); letter-spacing: .005em; text-transform: uppercase; }
.pulp-editorial{ font-family: var(--pulp-ff-editor); font-style: italic; }
.pulp-mono     { font-family: var(--pulp-ff-mono); }
.pulp-jp       { font-family: var(--pulp-ff-jp); }
.pulp-upper    { text-transform: uppercase; }

.pulp-display-1{ font-family: var(--pulp-ff-slab); font-size: clamp(64px, 9vw, 148px); line-height: .88; text-transform: uppercase; }
.pulp-display-2{ font-family: var(--pulp-ff-slab); font-size: clamp(48px, 6vw, 108px); line-height: .9;  text-transform: uppercase; }
.pulp-h1       { font-family: var(--pulp-ff-slab); font-size: clamp(40px, 4.5vw, 72px); line-height: .95; text-transform: uppercase; }
.pulp-h2       { font-family: var(--pulp-ff-slab); font-size: clamp(28px, 3vw, 48px);   line-height: .95; text-transform: uppercase; }
.pulp-h3       { font-family: var(--pulp-ff-slab); font-size: 24px; line-height: 1.05;  text-transform: uppercase; }
.pulp-quote    { font-family: var(--pulp-ff-editor); font-style: italic; font-size: clamp(22px, 2vw, 30px); line-height: 1.3; color: var(--pulp-paper-dim); }
.pulp-meta     { font-family: var(--pulp-ff-mono); font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--pulp-paper-mute); }

/* Bilingual label */
.pulp-bl{ display: inline-flex; flex-direction: column; line-height: 1; }
.pulp-bl .es{ font-weight: 700; }
.pulp-bl .en{ font-family: var(--pulp-ff-mono); font-size: 10px; letter-spacing: .18em; color: var(--pulp-paper-mute); text-transform: uppercase; margin-top: 4px; }
.pulp-bl .en::before{ content: "// "; }

/* 4 · LAYOUT --------------------------------------------- */
.pulp-wrap{ max-width: var(--pulp-container); margin: 0 auto; padding: 0 32px; }
.pulp-grid{ display: grid; gap: 18px; }
.pulp-grid-2{ grid-template-columns: repeat(2, 1fr); }
.pulp-grid-3{ grid-template-columns: repeat(3, 1fr); }
.pulp-grid-4{ grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px){ .pulp-grid-4, .pulp-grid-3{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px){ .pulp-grid-4, .pulp-grid-3, .pulp-grid-2{ grid-template-columns: 1fr; } }

/* 5 · EFFECTS -------------------------------------------- */
.pulp-grain{ position: fixed; inset: 0; pointer-events: none; z-index: 9000; mix-blend-mode: overlay; opacity: .35; }
.pulp-grain::before{
  content:""; position:absolute; inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.89  0 0 0 0 0.72  0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-size: 240px 240px;
}
.pulp-scanlines{ position: fixed; inset: 0; pointer-events: none; z-index: 8900; opacity: .18; background-image: repeating-linear-gradient(0deg, rgba(255,255,255,0.05) 0 1px, transparent 1px 3px); }
.pulp-vignette{ position: fixed; inset: 0; pointer-events: none; z-index: 8800; background: radial-gradient(120% 90% at 50% 40%, transparent 50%, rgba(0,0,0,.7) 100%); }

/* 6 · BUTTONS + FORMS ------------------------------------ */
.pulp-btn{
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--pulp-ff-slab); text-transform: uppercase; letter-spacing: .04em;
  padding: 14px 22px; font-size: 14px;
  border: 2px solid var(--pulp-paper); color: var(--pulp-paper); background: var(--pulp-ink);
  transition: transform .15s, background .15s, color .15s, box-shadow .15s;
  cursor: pointer; text-decoration: none;
}
.pulp-btn:hover{ background: var(--pulp-paper); color: var(--pulp-ink); transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--pulp-blood); }
.pulp-btn--blood{ background: var(--pulp-blood); border-color: var(--pulp-blood); }
.pulp-btn--blood:hover{ background: var(--pulp-paper); color: var(--pulp-blood); box-shadow: 6px 6px 0 var(--pulp-cyan); }
.pulp-btn--ghost{ background: transparent; }

.pulp-stamp{
  display: inline-block; border: 1.5px solid currentColor; padding: 3px 8px;
  font-family: var(--pulp-ff-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase;
}
.pulp-tape{
  display: inline-block; background: var(--pulp-yellow); color: var(--pulp-ink); padding: 4px 10px;
  transform: rotate(-2deg); font-family: var(--pulp-ff-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase;
  box-shadow: 2px 2px 0 rgba(0,0,0,.3);
}

input[type="text"], input[type="email"], input[type="search"], input[type="tel"],
input[type="password"], select, textarea{
  background: var(--pulp-ink-2); border: 1px solid var(--pulp-rule); color: var(--pulp-paper);
  font-family: var(--pulp-ff-mono); font-size: 13px; padding: 12px 14px; letter-spacing: .05em; width: 100%;
}
input::placeholder{ color: var(--pulp-paper-mute); }
input:focus, select:focus, textarea:focus{ outline: 1px solid var(--pulp-blood); border-color: var(--pulp-blood); }

/* 7 · HEADER / TICKER / FOOTER --------------------------- */
.pulp-ticker{ overflow: hidden; background: var(--pulp-blood); color: var(--pulp-paper); border-top: 1px solid var(--pulp-ink); border-bottom: 1px solid var(--pulp-ink); }
.pulp-ticker__track{ display: inline-flex; gap: 48px; padding: 10px 0; animation: pulp-tk 38s linear infinite; white-space: nowrap; font-family: var(--pulp-ff-mono); font-size: 12px; letter-spacing: .22em; text-transform: uppercase; }
.pulp-ticker .dot{ color: var(--pulp-yellow); }
@keyframes pulp-tk{ from{ transform: translateX(0); } to{ transform: translateX(-50%); } }

.pulp-marquee{ overflow: hidden; border-top: 1px solid var(--pulp-rule); border-bottom: 1px solid var(--pulp-rule); background: var(--pulp-ink-2); }
.pulp-marquee__track{ display: inline-flex; gap: 48px; padding: 10px 0; animation: pulp-tk 60s linear infinite; white-space: nowrap; font-family: var(--pulp-ff-editor); font-style: italic; font-size: 22px; color: var(--pulp-paper-dim); }

body.pulp footer.site-footer,
body.pulp .pulp-footer{ background: var(--pulp-ink-2); border-top: 1px solid var(--pulp-rule); padding: 60px 0 24px; margin-top: 80px; }

/* 8 · COMPONENTS ----------------------------------------- */
.pulp-poster{
  position: relative; aspect-ratio: 3/4; overflow: hidden;
  background: var(--pulp-ink-2); border: 1px solid var(--pulp-rule);
  transition: transform .15s; cursor: pointer;
}
.pulp-poster:hover{ transform: translate(-3px, -3px); }
.pulp-poster__crop{ position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: space-between; padding: 18px; }
.pulp-poster__crop::before{
  content:""; position:absolute; inset:0; pointer-events:none; mix-blend-mode: multiply; opacity:.55;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/></svg>");
}
.pulp-poster__top{ display: flex; justify-content: space-between; font-family: var(--pulp-ff-mono); font-size: 9px; letter-spacing: .18em; text-transform: uppercase; z-index: 2; position: relative; }
.pulp-poster__title{ font-family: var(--pulp-ff-slab); font-size: 36px; line-height: .9; text-transform: uppercase; z-index: 2; position: relative; }
.pulp-poster__sub{ font-family: var(--pulp-ff-editor); font-style: italic; font-size: 14px; margin-top: 8px; z-index: 2; position: relative; }
.pulp-poster__foot{ display: flex; justify-content: space-between; align-items: flex-end; font-family: var(--pulp-ff-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; z-index: 2; position: relative; }
.pulp-poster__price{ font-family: var(--pulp-ff-slab); font-size: 18px; }
.pulp-poster__hover{
  position: absolute; left: 0; right: 0; bottom: 0;
  background: var(--pulp-ink); color: var(--pulp-paper); padding: 10px 14px;
  display: flex; justify-content: space-between; align-items: center;
  transform: translateY(100%); transition: transform .18s;
  font-family: var(--pulp-ff-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase;
  border-top: 1px solid var(--pulp-blood); z-index: 5;
}
.pulp-poster:hover .pulp-poster__hover{ transform: translateY(0); }

/* Badges */
.pulp-badge{
  position: absolute; font-family: var(--pulp-ff-slab);
  font-size: 10px; letter-spacing: .08em; text-transform: uppercase;
  padding: 5px 8px; z-index: 3;
}
.pulp-badge--new      { background: var(--pulp-blood);  color: var(--pulp-paper); top: 10px; left: 10px; transform: rotate(-3deg); }
.pulp-badge--last     { background: var(--pulp-yellow); color: var(--pulp-ink);   top: 10px; right: 10px; }
.pulp-badge--drop     { background: var(--pulp-ink);    color: var(--pulp-cyan); border: 1px solid var(--pulp-cyan); top: 10px; left: 10px; }
.pulp-badge--preorder { background: var(--pulp-paper);  color: var(--pulp-ink);   top: 10px; left: 10px; }
.pulp-badge--sale     { background: var(--pulp-blood);  color: var(--pulp-paper); top: 10px; left: 10px; transform: rotate(-3deg); }
.pulp-badge--out      { background: var(--pulp-paper-mute); color: var(--pulp-ink); top: 10px; left: 10px; }

/* Countdown */
.pulp-countdown{ display: inline-flex; gap: 10px; }
.pulp-countdown__cell{ display: flex; flex-direction: column; align-items: center; padding: 10px 14px; border: 1px solid var(--pulp-paper); min-width: 80px; background: var(--pulp-ink); }
.pulp-countdown__n{ font-family: var(--pulp-ff-slab); font-size: 42px; line-height: 1; }
.pulp-countdown__l{ font-family: var(--pulp-ff-mono); font-size: 10px; letter-spacing: .22em; color: var(--pulp-paper-mute); margin-top: 6px; text-transform: uppercase; }

/* Censored / glitch */
.pulp-censored{ background: var(--pulp-ink); color: transparent; padding: 0 6px; display: inline; }
.pulp-stars{ color: var(--pulp-yellow); font-family: var(--pulp-ff-mono); letter-spacing: .1em; }

/* Sticky cart pill */
.pulp-sticky-cart{
  position: fixed; right: 24px; bottom: 24px; z-index: 7000;
  background: var(--pulp-paper); color: var(--pulp-ink);
  padding: 12px 16px; display: flex; align-items: center; gap: 10px;
  font-family: var(--pulp-ff-slab); font-size: 14px; text-transform: uppercase;
  box-shadow: 6px 6px 0 var(--pulp-blood); cursor: pointer; border: 2px solid var(--pulp-ink);
  text-decoration: none;
}
.pulp-sticky-cart__count{ background: var(--pulp-blood); color: var(--pulp-paper); font-family: var(--pulp-ff-mono); font-size: 11px; padding: 3px 7px; }
.pulp-sticky-cart[data-count="0"]{ display: none; }

/* 9 · WOOCOMMERCE OVERRIDES ------------------------------ */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product{ background: var(--pulp-ink-2); border: 1px solid var(--pulp-rule); padding: 0; transition: transform .15s; }
.woocommerce ul.products li.product:hover{ transform: translate(-3px, -3px); }
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  font-family: var(--pulp-ff-slab); text-transform: uppercase; font-size: 22px; line-height: 1; padding: 14px 18px 6px;
}
.woocommerce ul.products li.product .price{
  font-family: var(--pulp-ff-slab); color: var(--pulp-paper); padding: 0 18px 14px;
}
.woocommerce ul.products li.product .price del{ color: var(--pulp-paper-mute); font-family: var(--pulp-ff-mono); font-size: 14px; }
.woocommerce ul.products li.product .price ins{ background: transparent; color: var(--pulp-blood); text-decoration: none; }
.woocommerce ul.products li.product img{ margin: 0; }
.woocommerce ul.products li.product .button{
  font-family: var(--pulp-ff-slab); background: var(--pulp-blood); color: var(--pulp-paper);
  text-transform: uppercase; letter-spacing: .04em; border-radius: 0; padding: 12px 18px;
  margin: 0 18px 18px;
}
.woocommerce ul.products li.product .button:hover{ background: var(--pulp-paper); color: var(--pulp-blood); }

/* Single product */
.woocommerce div.product .product_title{ font-family: var(--pulp-ff-slab); font-size: clamp(40px, 5vw, 78px); line-height: .9; text-transform: uppercase; }
.woocommerce div.product p.price, .woocommerce div.product span.price{ font-family: var(--pulp-ff-slab); font-size: 36px; color: var(--pulp-paper); }
.woocommerce div.product p.price ins{ color: var(--pulp-blood); background: transparent; }
.woocommerce div.product .woocommerce-product-rating .star-rating span::before{ color: var(--pulp-yellow); }

/* Variation swatches forced dark */
.woo-variation-swatches .variable-items-wrapper .variable-item:not(.radio-variable-item){
  border-radius: 0 !important; box-shadow: none !important; border: 1px solid var(--pulp-rule) !important;
}
.woo-variation-swatches .variable-items-wrapper .variable-item.selected{
  border-color: var(--pulp-blood) !important; box-shadow: 0 0 0 1px var(--pulp-blood) !important;
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs{ border: 0; padding: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li{
  background: transparent; border: 0; border-bottom: 1px solid var(--pulp-rule);
  margin: 0; padding: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{
  font-family: var(--pulp-ff-slab); text-transform: uppercase; font-size: 14px; padding: 14px 22px;
  color: var(--pulp-paper-dim);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{ color: var(--pulp-paper); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active{ border-bottom: 2px solid var(--pulp-blood); }

/* Cart / Checkout */
.woocommerce-cart table.cart, .woocommerce-checkout table.shop_table{
  background: transparent; border: 1px solid var(--pulp-rule);
}
.woocommerce-cart table.cart th, .woocommerce-checkout table.shop_table th{
  font-family: var(--pulp-ff-slab); text-transform: uppercase; font-size: 12px; letter-spacing: .04em;
  background: var(--pulp-ink-2); color: var(--pulp-paper); border-color: var(--pulp-rule);
}
.woocommerce-cart table.cart td, .woocommerce-checkout table.shop_table td{
  border-color: var(--pulp-rule); color: var(--pulp-paper);
}
.woocommerce form .form-row label{ font-family: var(--pulp-ff-mono); font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--pulp-paper-mute); }

/* WooCommerce buttons (universal) */
.woocommerce .button, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce a.button.alt, .woocommerce button.button.alt{
  background: var(--pulp-blood); color: var(--pulp-paper);
  font-family: var(--pulp-ff-slab); text-transform: uppercase; letter-spacing: .04em;
  border-radius: 0; padding: 14px 22px; border: 2px solid var(--pulp-blood);
}
.woocommerce .button:hover, .woocommerce a.button:hover, .woocommerce button.button:hover{
  background: var(--pulp-paper); color: var(--pulp-blood); transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--pulp-cyan);
}

/* Notices */
.woocommerce-message, .woocommerce-info, .woocommerce-error{
  background: var(--pulp-ink-2); border-top: 3px solid var(--pulp-blood); color: var(--pulp-paper);
  font-family: var(--pulp-ff-mono); font-size: 13px;
}

/* On-sale flash */
.woocommerce span.onsale{
  background: var(--pulp-blood); color: var(--pulp-paper); border-radius: 0;
  font-family: var(--pulp-ff-slab); font-size: 12px; letter-spacing: .04em;
  min-height: auto; min-width: auto; line-height: 1; padding: 6px 10px;
  transform: rotate(-3deg); top: 12px; left: 12px;
}

/* 10 · ELEMENTOR TWEAKS ---------------------------------- */
.elementor-button-wrapper .elementor-button{ font-family: var(--pulp-ff-slab); text-transform: uppercase; letter-spacing: .04em; border-radius: 0; }
.elementor-heading-title{ text-wrap: balance; }
.elementor-widget-heading .elementor-heading-title.pulp-display-1,
.elementor-widget-heading .elementor-heading-title.pulp-display-2{ text-wrap: balance; }
.elementor-widget-text-editor a{ color: var(--pulp-blood); border-bottom: 1px solid currentColor; }

/* 11 · RESPONSIVE ---------------------------------------- */
@media (max-width: 980px){
  .pulp-poster__title{ font-size: 28px; }
  .pulp-wrap{ padding: 0 20px; }
  .pulp-sticky-cart{ right: 12px; bottom: 12px; }
}
@media (max-width: 640px){
  .pulp-display-1{ font-size: 56px; }
  .pulp-display-2{ font-size: 44px; }
  .pulp-h1{ font-size: 36px; }
}
