:root{--red:#e71946;--red-dark:#b80d31;--ink:#111217;--muted:#65666d;--paper:#fff;--soft:#f4f4f6;--line:#e6e6e9;--radius:22px;--shadow:0 18px 55px rgba(16,17,22,.10)}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--ink);background:var(--paper);font-family:Inter,ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button,input,select{font:inherit}
.topbar{padding:9px 20px;text-align:center;background:var(--ink);color:#fff;font-size:12px;letter-spacing:.05em}
.site-header{height:84px;padding:0 clamp(22px,5vw,78px);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:30;background:rgba(255,255,255,.94);backdrop-filter:blur(18px);border-bottom:1px solid rgba(0,0,0,.06)}
.brand img{width:142px;display:block}
.nav{display:flex;align-items:center;gap:32px;font-size:14px;font-weight:700}
.nav>a:not(.nav-cta):hover{color:var(--red)}
.nav>a.active{color:var(--red)}
.nav-cta{padding:13px 20px;border-radius:999px;background:var(--red);color:#fff}
.menu-button{display:none;border:0;background:none;font-size:26px}
.hero{min-height:660px;padding:74px clamp(22px,7vw,110px);display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);gap:55px;align-items:center;overflow:hidden;background:radial-gradient(circle at 80% 15%,rgba(231,25,70,.18),transparent 30%),linear-gradient(135deg,#0b0b0d,#1b1c22 65%,#0c0d10);color:#fff}
.eyebrow{margin:0 0 16px;color:#ff5f7f;font-size:12px;font-weight:900;letter-spacing:.18em}
.eyebrow.dark{color:var(--red)}
.hero h1{max-width:760px;margin:0;font-size:clamp(46px,6vw,84px);line-height:.98;letter-spacing:-.055em}
.hero h1 span{color:#ff496d}
.hero-text{max-width:650px;margin:25px 0 0;color:#c9c9cf;font-size:19px;line-height:1.65}
.hero-actions{display:flex;gap:13px;flex-wrap:wrap;margin-top:34px}
.button{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 25px;border-radius:999px;font-weight:800;transition:.2s ease}
.button:hover{transform:translateY(-2px)}
.button-primary{background:var(--red);color:#fff;box-shadow:0 12px 32px rgba(231,25,70,.3)}
.button-ghost{border:1px solid rgba(255,255,255,.28);color:#fff}
.hero-proof{display:flex;gap:30px;flex-wrap:wrap;margin-top:38px;color:#a7a8ae;font-size:13px}
.hero-proof strong{display:block;color:#fff;font-size:15px}
.hero-visual{position:relative;min-height:470px;display:grid;place-items:center}
.orb{position:absolute;border-radius:50%;filter:blur(2px)}
.orb-one{width:360px;height:360px;background:linear-gradient(145deg,#e71946,#631127);opacity:.42}
.orb-two{width:250px;height:250px;right:0;bottom:25px;background:#31343d;opacity:.8}
.showcase-card{width:min(390px,90%);aspect-ratio:.82;padding:52px 40px;position:relative;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;border:1px solid rgba(255,255,255,.18);border-radius:38px;background:linear-gradient(160deg,rgba(255,255,255,.13),rgba(255,255,255,.04));box-shadow:0 45px 90px rgba(0,0,0,.4);backdrop-filter:blur(18px);transform:rotate(4deg)}
.showcase-card img{width:210px;margin:auto}
.showcase-card p{font-size:25px;font-weight:850;margin:0 0 20px}
.showcase-tags{display:flex;gap:8px;flex-wrap:wrap}
.showcase-tags span{padding:8px 11px;border-radius:999px;background:rgba(255,255,255,.1);font-size:11px}
.floating-card{position:absolute;z-index:4;padding:14px 18px;border-radius:15px;background:#fff;color:var(--ink);font-size:13px;font-weight:800;box-shadow:var(--shadow)}
.card-top{right:0;top:80px}.card-bottom{left:0;bottom:75px;color:#fff;background:var(--red)}
.trust-strip{max-width:1250px;margin:-34px auto 0;padding:24px 32px;position:relative;z-index:5;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;border-radius:20px;background:#fff;box-shadow:var(--shadow)}
.trust-strip article{display:flex;align-items:center;gap:13px}
.trust-strip article>span{width:42px;height:42px;display:grid;place-items:center;border-radius:13px;background:#fff0f3;color:var(--red);font-weight:900}
.trust-strip strong,.trust-strip small{display:block}.trust-strip strong{font-size:14px}.trust-strip small{margin-top:4px;color:var(--muted);font-size:12px}
.section{max-width:1250px;margin:auto;padding:105px 24px}
.section-heading{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:35px}
.section-heading h2,.about h2,.contact-cta h2{margin:0;font-size:clamp(34px,4vw,55px);line-height:1.06;letter-spacing:-.04em}
.section-heading>a,.text-link{color:var(--red);font-weight:850}
.product-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}
.product-card{min-width:0;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:#fff;transition:.25s ease}
.product-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.product-image{aspect-ratio:1.08;display:grid;place-items:center;position:relative;overflow:hidden;background:linear-gradient(145deg,#f7f7f8,#ebebee)}
.product-image img{width:100%;height:100%;object-fit:contain;padding:18px;transition:.25s ease}
.product-card:hover .product-image img{transform:scale(1.04)}
.product-placeholder{width:92px;height:92px;display:grid;place-items:center;border-radius:28px;background:#191a1f;color:#fff;font-size:30px;font-weight:900;box-shadow:0 15px 30px rgba(0,0,0,.15)}
.product-badge{position:absolute;top:13px;left:13px;padding:7px 10px;border-radius:999px;background:var(--red);color:#fff;font-size:10px;font-weight:900;letter-spacing:.08em}
.product-body{padding:20px}
.product-category{color:var(--red);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.1em}
.product-body h3{min-height:47px;margin:9px 0 8px;font-size:17px;line-height:1.35}
.product-code{color:var(--muted);font-size:11px}
.product-bottom{display:flex;justify-content:space-between;align-items:end;gap:12px;margin-top:20px}
.price small,.price strong{display:block}.price small{color:var(--muted);font-size:10px}.price strong{font-size:21px}
.card-actions{display:flex;gap:7px}
.icon-button{width:40px;height:40px;border:1px solid var(--line);border-radius:12px;background:#fff;cursor:pointer;font-weight:900}
.buy-button{padding:0 14px;border:0;border-radius:12px;background:#20b45a;color:#fff;font-size:12px;font-weight:900;cursor:pointer}
.catalog-section{background:var(--soft)}
.catalog-inner{padding-top:92px;padding-bottom:100px}
.catalog-title p:not(.eyebrow){margin:12px 0 0;color:var(--muted)}
.results-count{padding:9px 13px;border-radius:999px;background:#fff;color:var(--muted);font-size:12px}
.filters{display:grid;grid-template-columns:1fr 260px;gap:14px;margin-bottom:28px}
.search-box{height:56px;padding:0 18px;display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:15px;background:#fff}
.search-box span{font-size:24px}.search-box input{width:100%;border:0;outline:0;background:transparent}
.filters select{padding:0 16px;border:1px solid var(--line);border-radius:15px;background:#fff}
.loading-card,.empty-state{grid-column:1/-1;padding:45px;text-align:center;border-radius:var(--radius);background:#fff;color:var(--muted)}
.empty-state strong,.empty-state span{display:block}.empty-state span{margin-top:8px;color:var(--muted)}
.about{padding-top:110px;padding-bottom:110px}
.about-panel{padding:65px;display:grid;grid-template-columns:280px 1fr;gap:70px;align-items:center;border-radius:34px;background:var(--ink);color:#fff}
.about-mark{aspect-ratio:1;display:grid;place-items:center;border-radius:50%;background:linear-gradient(145deg,var(--red),#5f0c20);font-size:78px;font-weight:950;letter-spacing:-.08em}
.about-panel p:not(.eyebrow){max-width:700px;color:#c7c7cc;font-size:17px;line-height:1.7}
.contact-cta{padding:75px max(24px,calc((100vw - 1200px)/2));display:flex;align-items:center;justify-content:space-between;gap:30px;background:var(--red);color:#fff}
.contact-cta p:not(.eyebrow){margin-bottom:0;color:#ffd5de}
.contact-cta .eyebrow{color:#fff}.button-light{background:#fff;color:var(--red)}
footer{padding:70px max(24px,calc((100vw - 1200px)/2)) 26px;background:#0b0b0d;color:#fff}
.footer-main{display:grid;grid-template-columns:1.3fr .7fr 1fr;gap:70px}
.footer-brand img{width:180px}.footer-brand p{max-width:340px;color:#92939a;line-height:1.6}
.footer-main>div:not(.footer-brand){display:flex;flex-direction:column;gap:12px}.footer-main strong{margin-bottom:7px}.footer-main a,.footer-main span{color:#a9aab0;font-size:14px}
.footer-main a:hover{color:#fff}
.footer-bottom{margin-top:60px;padding-top:25px;display:flex;justify-content:space-between;border-top:1px solid #292a2f;color:#777981;font-size:12px}
.whatsapp-float{width:58px;height:58px;display:grid;place-items:center;position:fixed;right:23px;bottom:23px;z-index:35;border-radius:50%;background:#20b45a;color:#fff;font-weight:950;box-shadow:0 15px 35px rgba(0,0,0,.23)}
.page-hero{min-height:430px;padding:95px max(24px,calc((100vw - 1200px)/2));display:flex;flex-direction:column;justify-content:center;background:radial-gradient(circle at 85% 20%,rgba(231,25,70,.23),transparent 28%),linear-gradient(135deg,#0b0b0d,#1d1e24);color:#fff}
.page-hero h1{max-width:1000px;margin:0;font-size:clamp(48px,7vw,88px);line-height:.98;letter-spacing:-.055em}
.page-hero>p:last-child{max-width:700px;margin:24px 0 0;color:#c8c8ce;font-size:18px;line-height:1.65}
.standalone-catalog .catalog-inner{padding-top:80px}
.story-grid{display:grid;grid-template-columns:350px 1fr;gap:80px;align-items:center}
.story-number{aspect-ratio:1;display:grid;place-items:center;border-radius:50%;background:linear-gradient(145deg,var(--red),#680f25);color:#fff;font-size:92px;font-weight:950}
.story h2{margin:0;font-size:clamp(38px,5vw,65px);line-height:1.04;letter-spacing:-.045em}
.story p:not(.eyebrow){color:var(--muted);font-size:17px;line-height:1.75}
.values{padding-top:30px}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.value-grid article{padding:36px;border:1px solid var(--line);border-radius:24px}
.value-grid span{color:var(--red);font-size:12px;font-weight:900}
.value-grid h3{font-size:23px}.value-grid p{color:var(--muted);line-height:1.6}
.contact-page{display:grid;gap:24px}
.contact-card{padding:55px;border-radius:30px;background:var(--soft)}
.primary-contact{display:grid;grid-template-columns:160px 1fr;gap:45px;align-items:center}
.contact-icon{width:150px;height:150px;display:grid;place-items:center;border-radius:50%;background:#20b45a;color:#fff;font-size:42px;font-weight:950}
.contact-card h2{margin:0;font-size:52px}.contact-card p:not(.eyebrow){color:var(--muted);font-size:17px}.contact-card .button{margin-top:14px}
.contact-options{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.contact-options article{padding:32px;border:1px solid var(--line);border-radius:22px}.contact-options article>span{color:var(--red);font-size:24px}.contact-options h3{margin-bottom:8px}.contact-options p,.contact-options a{color:var(--muted)}
.product-modal{width:min(900px,calc(100% - 30px));padding:0;border:0;border-radius:26px;box-shadow:0 30px 100px rgba(0,0,0,.35)}
.product-modal::backdrop{background:rgba(7,8,10,.72);backdrop-filter:blur(5px)}
.modal-close{width:42px;height:42px;position:absolute;right:15px;top:15px;z-index:3;border:0;border-radius:50%;background:#fff;font-size:26px;cursor:pointer}
.modal-layout{display:grid;grid-template-columns:1fr 1fr}.modal-image{min-height:440px;display:grid;place-items:center;background:var(--soft)}.modal-image img{width:100%;height:100%;max-height:520px;object-fit:contain;padding:35px}.modal-info{padding:55px 45px}.modal-info h2{margin:10px 0;font-size:34px;line-height:1.08}.modal-info p{color:var(--muted);line-height:1.6}.modal-price{margin:25px 0;font-size:30px;font-weight:900}.modal-info .button{width:100%}
@media(max-width:1000px){.hero{grid-template-columns:1fr;padding-top:90px}.hero-visual{min-height:410px}.product-grid{grid-template-columns:repeat(2,1fr)}.trust-strip{margin:-15px 18px 0;grid-template-columns:repeat(2,1fr)}.about-panel{grid-template-columns:200px 1fr}.nav{gap:18px}.story-grid{grid-template-columns:230px 1fr}.value-grid{grid-template-columns:1fr}.contact-options{grid-template-columns:1fr}}
@media(max-width:720px){.topbar{font-size:10px}.site-header{height:70px;padding:0 18px}.brand img{width:118px}.menu-button{display:block}.nav{display:none;position:absolute;left:15px;right:15px;top:76px;padding:18px;flex-direction:column;align-items:stretch;border-radius:18px;background:#fff;box-shadow:var(--shadow)}.nav.open{display:flex}.nav-cta{text-align:center}.hero{min-height:auto;padding:70px 22px 55px;grid-template-columns:1fr}.hero h1{font-size:48px}.hero-text{font-size:16px}.hero-proof{gap:18px}.hero-visual{min-height:350px}.showcase-card{width:260px}.showcase-card img{width:150px}.floating-card{font-size:11px}.trust-strip{padding:20px;grid-template-columns:1fr}.section{padding:76px 18px}.section-heading{align-items:start;flex-direction:column}.product-grid{grid-template-columns:1fr}.filters{grid-template-columns:1fr}.filters select{height:54px}.about-panel{padding:35px 25px;grid-template-columns:1fr;gap:32px}.about-mark{width:150px}.contact-cta{padding:60px 24px;align-items:start;flex-direction:column}.footer-main{grid-template-columns:1fr;gap:38px}.footer-bottom{gap:12px;flex-direction:column}.modal-layout{grid-template-columns:1fr}.modal-image{min-height:260px}.modal-info{padding:35px 24px}.page-hero{min-height:360px;padding:70px 24px}.page-hero h1{font-size:48px}.story-grid{grid-template-columns:1fr;gap:35px}.story-number{width:160px}.primary-contact{padding:35px 24px;grid-template-columns:1fr}.contact-icon{width:110px;height:110px}}

.whatsapp-float .whatsapp-icon{width:31px;height:31px;display:block;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.whatsapp-float .whatsapp-icon path+path{fill:currentColor;stroke:none}

.product-page{background:var(--soft)}
.product-detail-shell{max-width:1250px;min-height:700px;padding-top:75px;padding-bottom:100px}
.product-detail-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(420px,.9fr);overflow:hidden;border-radius:32px;background:#fff;box-shadow:var(--shadow)}
.detail-media{min-height:610px;position:relative;display:grid;place-items:center;background:linear-gradient(145deg,#f7f7f8,#e9e9ed)}
.detail-media img{width:100%;height:100%;max-height:650px;padding:45px;object-fit:contain}
.detail-media .product-placeholder{width:170px;height:170px;border-radius:42px;font-size:54px}
.detail-content{padding:65px 55px}
.detail-breadcrumb{display:flex;gap:9px;margin-bottom:34px;color:var(--muted);font-size:13px}
.detail-breadcrumb a:hover{color:var(--red)}
.detail-content h1{margin:12px 0;font-size:clamp(36px,4vw,57px);line-height:1.04;letter-spacing:-.045em}
.detail-code{color:var(--muted);font-size:13px}
.detail-description{margin:28px 0;color:var(--muted);font-size:16px;line-height:1.7}
.detail-specs{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.detail-specs div{padding:15px;border-radius:14px;background:var(--soft)}
.detail-specs small,.detail-specs strong{display:block}
.detail-specs small{margin-bottom:6px;color:var(--muted);font-size:11px}
.detail-specs strong{font-size:14px}
.detail-specs .available{color:#159447}
.detail-purchase{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:34px;padding-top:28px;border-top:1px solid var(--line)}
.detail-price small,.detail-price strong{display:block}
.detail-price small{color:var(--muted);font-size:11px}
.detail-price strong{font-size:32px}
.detail-whatsapp{background:#20b45a;color:#fff}
.detail-note{font-size:12px!important}
.detail-not-found{padding:90px;text-align:center;border-radius:28px;background:#fff}
.detail-not-found h1{font-size:48px}
.detail-not-found p{margin-bottom:28px;color:var(--muted)}
@media(max-width:850px){.product-detail-grid{grid-template-columns:1fr}.detail-media{min-height:390px}.detail-content{padding:40px 28px}}
@media(max-width:560px){.product-detail-shell{padding-top:25px}.detail-media{min-height:300px}.detail-content h1{font-size:34px}.detail-specs{grid-template-columns:1fr}.detail-purchase{align-items:stretch;flex-direction:column}.detail-whatsapp{width:100%}}

/* Tarjeta de producto: precio y compra centrados */
.product-body{display:flex;flex-direction:column}
.product-body h3{min-height:0;margin:10px 0 4px}
.product-bottom{display:grid;grid-template-columns:1fr auto;align-items:end;gap:12px;margin-top:10px;padding-top:3px}
.product-bottom .price{text-align:left}
.product-bottom .card-actions{display:flex;width:auto;justify-content:flex-end}
.product-bottom .buy-button{width:auto;min-width:94px;min-height:42px;padding:0 18px;display:inline-flex;align-items:center;justify-content:center;border-radius:11px;background:var(--red);color:#fff;font-size:13px;line-height:1.2;text-align:center;white-space:nowrap}


/* Estados de productos sin stock */
.product-badge.stock-pending{
  background:#111319;
  color:#fff;
  white-space:nowrap;
}
.buy-button-pending,
.button-pending,
.detail-whatsapp-pending{
  background:#111319;
  color:#fff;
}
.buy-button-pending:hover,
.button-pending:hover,
.detail-whatsapp-pending:hover{
  background:#ed1745;
}
.pending-stock{
  color:#ed1745;
}
