/* ============================================================================
   JUSTO MAKARIO — Tema custom sobre base-theme Tienda Nube
   Diseño portado 1:1 desde "index v3.html". NO cambia el look.
   Único ajuste: las reglas globales peligrosas (reset, cursor, bg) se "blindan"
   a body.template-home para no romper checkout ni páginas internas.
   ============================================================================ */

:root{ --black:#0c0a09; --white:#faf8f5; --red:#ae0000; --warm:#f0ebe2; --mid:#e8e2d8; }

/* Box-sizing global (seguro). El reset de margin/padding se limita a la home. */
*,*::before,*::after{box-sizing:border-box;}
body.template-home,
body.template-home *,
body.template-home *::before,
body.template-home *::after{margin:0;padding:0;}

html{scroll-behavior:auto;}
/* Tipografía de marca en TODO el sitio (consistencia) */
body{font-family:'Outfit',sans-serif;overflow-x:hidden;}
/* Fondo, color y cursor oculto SOLO en la home (no afecta internas/checkout) */
body.template-home{background:#fff;color:#0c0a09;cursor:none;}
body.template-home a{color:inherit;text-decoration:none;}
::selection{background:var(--red);color:#fff;}

/* ─── CURSOR ─── */
#c-dot{position:fixed;width:8px;height:8px;background:#0c0a09;border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);mix-blend-mode:difference;}
#c-ring{position:fixed;width:44px;height:44px;border:1.5px solid rgba(0,0,0,.35);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .35s,height .35s,border-color .3s,background .3s;}
body.ch #c-ring{width:68px;height:68px;border-color:var(--red);background:rgba(174,0,0,.05);}
body.dark-mode #c-dot{background:#fff;}
body.dark-mode #c-ring{border-color:rgba(255,255,255,.35);}

/* ─── LOADER ─── */
#loader{position:fixed;inset:0;background:#0c0a09;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;transition:opacity .7s,transform .7s;}
#loader.out{opacity:0;transform:scale(1.03);pointer-events:none;}
.l-logo{font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#fff;margin-bottom:48px;}
.l-bar{width:200px;height:1px;background:rgba(255,255,255,.1);}
#l-fill{height:100%;width:0%;background:#fff;}
#l-pct{font-size:11px;color:rgba(255,255,255,.3);margin-top:14px;letter-spacing:.08em;}

/* ─── NAV ─── */
#nav{position:fixed;top:0;left:0;right:0;z-index:500;display:flex;align-items:center;justify-content:space-between;padding:0 48px;height:64px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:background .4s,border-bottom .4s;border-bottom:1px solid transparent;}
#nav.scrolled{background:rgba(12,10,9,.94);border-bottom-color:rgba(255,255,255,.06);}
#nav.scrolled .n-logo,#nav.scrolled .n-links a,#nav.scrolled .n-icons a{color:#fff;}
.n-logo{font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#0c0a09;transition:color .4s;}
.n-links{display:flex;gap:36px;list-style:none;position:absolute;left:50%;transform:translateX(-50%);}
.n-links a{font-size:12px;letter-spacing:.05em;color:#0c0a09;transition:color .4s;opacity:.8;}
.n-links a:hover{opacity:1;}
.n-icons{display:flex;align-items:center;gap:20px;}
.n-icons a{font-size:12px;color:#0c0a09;transition:color .4s;opacity:.7;}
.n-icons a:hover{opacity:1;}
.cart-b{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;background:var(--red);color:#fff;font-size:9px;border-radius:50%;margin-left:3px;vertical-align:middle;}
.s-prog{position:fixed;top:64px;left:0;right:0;height:2px;z-index:499;background:rgba(0,0,0,.06);}
#s-fill{height:100%;width:0%;background:var(--red);}
/* En páginas internas (no home) la nav arranca siempre sólida y visible */
body:not(.template-home) #nav{background:rgba(12,10,9,.94);border-bottom-color:rgba(255,255,255,.06);position:sticky;}
body:not(.template-home) #nav .n-logo,
body:not(.template-home) #nav .n-links a,
body:not(.template-home) #nav .n-icons a{color:#fff;}
body:not(.template-home) .s-prog{display:none;}

/* ─── MARQUEE ─── */
.mq{background:var(--red);padding:14px 0;overflow:hidden;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);}
.mq-track{display:flex;animation:mq 22s linear infinite;white-space:nowrap;}
.mq-item{display:inline-flex;align-items:center;gap:24px;padding:0 32px;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.9);}
.mq-dot{width:3px;height:3px;background:rgba(255,255,255,.4);border-radius:50%;flex-shrink:0;}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─── HERO ─── */
#hero{height:100vh;background:#0c0a09;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden;padding:0 24px;}
.h-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 60% 40%,#1a1a1a 0%,#0c0a09 70%);}
.h-content{position:relative;z-index:2;}
.h-eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:28px;opacity:0;}
.h-title{font-size:clamp(52px,8vw,128px);font-weight:600;color:#fff;line-height:1.0;letter-spacing:-.02em;margin-bottom:28px;overflow:hidden;}
.h-title .word{display:inline-block;overflow:hidden;}
.h-title .char{display:inline-block;transform:translateY(110%);}
.h-sub{font-size:clamp(16px,1.6vw,22px);font-weight:300;color:rgba(255,255,255,.6);max-width:520px;margin:0 auto 48px;line-height:1.5;opacity:0;}
.h-ctas{display:flex;gap:20px;align-items:center;justify-content:center;flex-wrap:wrap;opacity:0;}
.btn-min{background:transparent;color:#fff;font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:500;letter-spacing:.06em;padding:0 0 6px;border:none;border-bottom:1px solid rgba(255,255,255,.4);cursor:none;transition:border-color .2s,color .2s;}
.btn-min:hover{border-color:#fff;color:#fff;}
.btn-min.filled{background:#fff;color:#0c0a09;padding:14px 36px;border:none;border-bottom:none;transition:background .2s,color .2s,transform .2s;}
.btn-min.filled:hover{background:var(--red);color:#fff;transform:translateY(-1px);}
.h-scroll-hint{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;z-index:2;animation:bh 2s ease-in-out infinite;}
.h-scroll-hint span{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.3);}
.h-hint-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.35),transparent);}
@keyframes bh{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* ─── KICKER ─── */
#kicker{height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:#fff;padding:0 24px;}
.k-main{font-size:clamp(36px,6vw,88px);font-weight:600;letter-spacing:-.025em;color:#0c0a09;line-height:1.05;margin-bottom:24px;}
.k-sub{font-size:clamp(16px,1.4vw,20px);font-weight:300;color:rgba(0,0,0,.4);letter-spacing:.04em;}
.k-arrow{margin-top:48px;display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(0,0,0,.28);animation:bd 2s ease-in-out infinite;}
.k-arrow svg{width:20px;height:20px;}
@keyframes bd{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* ─── SCROLL CANVAS ─── */
#scroll-section{position:relative;height:600vh;background:var(--warm);}
#sticky-stage{position:sticky;top:0;width:100vw;height:100vh;overflow:hidden;}
#frame-canvas{position:absolute;inset:0;width:100%;height:100%;}
.ct{position:absolute;z-index:10;pointer-events:none;transition:opacity .5s;}
.ct.off{opacity:0;}
.ct::before{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:170%;height:220%;background:radial-gradient(ellipse at center, rgba(0,0,0,.62) 0%, rgba(0,0,0,.32) 42%, transparent 72%);z-index:-1;pointer-events:none;}
#ct1,#ct2{top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;}
#ct3{bottom:64px;left:50%;transform:translateX(-50%);text-align:center;}
.ct-glass{position:relative;background:none;backdrop-filter:none;-webkit-backdrop-filter:none;padding:0;color:#fff;border:none;box-shadow:none;}
.ct-eyebrow{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--red);margin-bottom:14px;text-shadow:0 2px 16px rgba(0,0,0,.55);}
.ct-title{font-family:'Space Grotesk',sans-serif;font-size:clamp(32px,4.2vw,64px);font-weight:700;letter-spacing:-.03em;line-height:1.02;color:#fff;text-shadow:0 4px 32px rgba(0,0,0,.55);}
.ct-body{font-size:clamp(15px,1.3vw,17px);font-weight:300;color:rgba(255,255,255,.88);margin:14px auto 0;max-width:440px;text-shadow:0 2px 20px rgba(0,0,0,.5);}
.btn-canvas{margin-top:22px;display:inline-block;background:transparent;color:#0c0a09;font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:0 0 5px;border:none;border-bottom:1px solid rgba(0,0,0,.35);cursor:none;transition:border-color .2s,color .2s;}
.ct .btn-canvas{color:#fff;border-bottom:1px solid rgba(255,255,255,.55);text-shadow:0 2px 16px rgba(0,0,0,.5);}
.ct .btn-canvas:hover{border-bottom-color:var(--red);color:var(--red);}
.btn-canvas:hover{border-color:#0c0a09;}
#sh{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:10;text-align:center;transition:opacity .5s;}
#sh.off{opacity:0;}
#sh span{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(0,0,0,.4);}
#sh-l{width:1px;height:32px;margin:6px auto 0;background:linear-gradient(to bottom,rgba(0,0,0,.3),transparent);animation:grow 1.6s ease-in-out infinite;}
@keyframes grow{0%,100%{transform:scaleY(1);opacity:.8}50%{transform:scaleY(.5);opacity:.3}}

/* ─── STATS PINNED ─── */
#stats-pin{position:relative;height:400vh;}
#stats-sticky{position:sticky;top:0;width:100vw;height:100vh;background:var(--black);overflow:hidden;}
.stat-pane{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 48px;will-change:transform,opacity;}
.stat-big{font-family:'Space Grotesk',sans-serif;font-size:clamp(96px,18vw,240px);font-weight:700;letter-spacing:-.05em;line-height:.88;color:#fff;}
.stat-big em{color:var(--red);font-style:normal;}
.stat-label{font-size:clamp(16px,2vw,24px);font-weight:300;color:rgba(250,248,245,.45);margin-top:24px;letter-spacing:.04em;}
.stat-divider{width:32px;height:2px;background:var(--red);margin:20px auto 0;}
.stat-dots{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;gap:10px;}
.sd{width:20px;height:2px;background:rgba(255,255,255,.15);transition:background .4s,width .4s;}
.sd.on{background:var(--red);width:32px;}

/* ─── COLLECTIONS BOOK ─── */
#coll-pin{position:relative;height:700vh;}
#coll-sticky{position:sticky;top:0;width:100vw;height:100vh;overflow:hidden;perspective:1200px;perspective-origin:50% 50%;background:#0c0a09;}
.book-header{position:absolute;top:0;left:0;right:0;padding:72px 64px 0;z-index:30;pointer-events:none;display:flex;align-items:flex-end;justify-content:space-between;}
.book-header h2{font-family:'Space Grotesk',sans-serif;font-size:clamp(24px,3vw,40px);font-weight:700;letter-spacing:-.02em;color:#fff;}
.book-counter{font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:500;letter-spacing:.1em;color:rgba(255,255,255,.4);}
.book-prog{position:absolute;bottom:0;left:0;height:2px;background:var(--red);z-index:30;transition:width .08s linear;}
.col-card-3d{position:absolute;inset:0;will-change:transform,opacity;transform-origin:center center;transform-style:preserve-3d;}
.col-card-inner{position:absolute;inset:0;overflow:hidden;}
.col-ph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background-size:cover;background-position:center;background-repeat:no-repeat;}
.col-ph span{font-size:9px;letter-spacing:.1em;text-transform:uppercase;font-family:monospace;color:rgba(255,255,255,.15);}
.col-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(12,10,9,.6) 0%,rgba(12,10,9,.1) 50%,rgba(12,10,9,.5) 100%);}
.col-info{position:absolute;bottom:0;left:0;right:0;padding:64px 72px;color:#fff;}
.col-eyebrow{font-family:'Space Grotesk',sans-serif;font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:8px;}
.col-name{font-family:'Space Grotesk',sans-serif;font-size:clamp(40px,6vw,88px);font-weight:700;letter-spacing:-.04em;line-height:.92;}
.col-price{font-size:15px;font-weight:300;color:rgba(255,255,255,.55);margin-top:14px;}
/* Botón premium por colección (glass blanco) — CENTRADO en el medio de la pantalla */
.col-cta.jm-premium-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);margin:0!important;z-index:6;padding:16px 38px!important;font-size:13px!important;letter-spacing:.1em!important;}
.col-cta.jm-premium-btn .jm-btn-label{gap:10px;}
.col-cta.jm-premium-btn svg{width:15px;height:15px;transition:transform .3s cubic-bezier(.22,1,.36,1);}
.col-cta.jm-premium-btn:hover{transform:translate(-50%,-50%) translateY(-3px);}
.col-cta.jm-premium-btn:hover svg{transform:translateX(4px);}
.cb1{background:repeating-linear-gradient(-45deg,#c8c0b4,#c8c0b4 8px,#bfb7aa 8px,#bfb7aa 16px);}
.cb2{background:repeating-linear-gradient(-45deg,#b8b0a0,#b8b0a0 8px,#b0a896 8px,#b0a896 16px);}
.cb3{background:repeating-linear-gradient(-45deg,#d0cbc2,#d0cbc2 8px,#c8c3b8 8px,#c8c3b8 16px);}
.cb4{background:repeating-linear-gradient(-45deg,#c0b8a8,#c0b8a8 8px,#b8b0a0 8px,#b8b0a0 16px);}
.cb5{background:repeating-linear-gradient(-45deg,#cac3b8,#cac3b8 8px,#c2bbb0 8px,#c2bbb0 16px);}
.cb6{background:repeating-linear-gradient(-45deg,#d4cec4,#d4cec4 8px,#ccc6bb 8px,#ccc6bb 16px);}

/* ─── PRODUCTS · CIRCULAR 3D GALLERY ─── */
#prod-pin{position:relative;height:400vh;background:var(--warm);}
#prod-sticky{position:sticky;top:0;width:100vw;height:100vh;overflow:hidden;background:var(--warm);}
.prod-header{position:absolute;top:0;left:0;right:0;padding:72px 64px 0;z-index:30;pointer-events:none;display:flex;align-items:flex-end;justify-content:space-between;}
.prod-header h2{font-family:'Space Grotesk',sans-serif;font-size:clamp(24px,3vw,40px);font-weight:700;letter-spacing:-.02em;color:var(--black);}
.prod-header span{font-size:12px;color:rgba(12,10,9,.4);letter-spacing:.06em;}
#cg-stage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;perspective:1900px;perspective-origin:50% 50%;}
#cg-rotor{position:absolute;top:50%;left:50%;width:0;height:0;transform-style:preserve-3d;will-change:transform;}
.cg-item{position:absolute;width:300px;height:400px;left:0;top:0;margin-left:-150px!important;margin-top:-200px!important;transition:opacity .3s linear;will-change:transform,opacity;}
.cg-card{position:relative;width:100%;height:100%;overflow:hidden;background:#fff;box-shadow:0 30px 80px rgba(0,0,0,.2),0 8px 24px rgba(0,0,0,.08);border:1px solid rgba(0,0,0,.04);}
.cg-img{position:absolute;inset:0;background:#ede9e3;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;}
.cg-img span{font-size:9px;letter-spacing:.12em;text-transform:uppercase;font-family:monospace;color:rgba(0,0,0,.22);}
.cg-info{position:absolute;bottom:0;left:0;right:0;padding:24px 22px 22px;background:linear-gradient(to top,rgba(0,0,0,.78) 0%,rgba(0,0,0,.4) 50%,transparent 100%);color:#fff;}
.cg-eyebrow{font-family:'Space Grotesk',sans-serif;font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:6px;}
.cg-name{font-family:'Space Grotesk',sans-serif;font-size:17px;font-weight:700;letter-spacing:-.01em;margin-bottom:3px;}
.cg-variant{font-size:11px;color:rgba(255,255,255,.6);margin-bottom:14px;}
.cg-row{display:flex;align-items:center;justify-content:space-between;}
.cg-price{font-family:'Space Grotesk',sans-serif;font-size:17px;font-weight:700;}
.cg-btn{background:transparent;color:#fff;font-family:'Space Grotesk',sans-serif;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:0 0 3px;border:none;border-bottom:1px solid rgba(255,255,255,.45);cursor:none;transition:border-color .2s,color .2s;}
.cg-btn:hover{border-color:var(--red);color:var(--red);}
.cg-hint{position:absolute;bottom:48px;left:50%;transform:translateX(-50%);z-index:30;text-align:center;}
.cg-hint span{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(12,10,9,.4);}
.cg-hint-bar{display:flex;gap:8px;justify-content:center;margin-top:10px;}
.cg-hint-bar div{width:24px;height:2px;background:rgba(12,10,9,.2);}
.cg-see-all{position:absolute;bottom:130px;left:50%;transform:translateX(-50%);z-index:30;background:transparent;color:var(--black);font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;padding:18px 44px;border:1px solid rgba(12,10,9,.25);cursor:pointer;transition:background .3s cubic-bezier(.22,1,.36,1),color .3s,border-color .3s,transform .3s,letter-spacing .3s;display:inline-flex;align-items:center;gap:14px;white-space:nowrap;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background-color:rgba(250,248,245,.55);}
.cg-see-all:hover{background-color:var(--black);color:var(--white);border-color:var(--black);letter-spacing:.2em;transform:translateX(-50%) translateY(-3px);}
.cg-see-all:hover svg{transform:translateX(4px);}
.cg-see-all svg{width:14px;height:14px;transition:transform .3s cubic-bezier(.22,1,.36,1);}

/* ─── MOBILE BOTTOM TAB BAR ─── */
#tabbar{display:none;position:fixed;bottom:16px;left:50%;transform:translateX(-50%);z-index:600;background:rgba(12,10,9,.92);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:6px;box-shadow:0 12px 40px rgba(0,0,0,.5),0 4px 12px rgba(0,0,0,.3);}
.tab{display:flex;align-items:center;gap:0;background:transparent;border:none;cursor:pointer;color:rgba(250,248,245,.5);transition:color .3s,background .35s cubic-bezier(.34,1.6,.64,1),padding .35s cubic-bezier(.34,1.6,.64,1);padding:10px 14px;border-radius:999px;position:relative;flex-shrink:0;}
.tab svg{width:20px;height:20px;stroke-width:1.8;flex-shrink:0;}
.tab.active{color:#fff;background:rgba(174,0,0,.18);padding:10px 16px 10px 14px;}
.tab.active svg{animation:tabBounce .55s cubic-bezier(.34,1.6,.64,1);color:var(--red);}
@keyframes tabBounce{0%,100%{transform:translateY(0)}25%{transform:translateY(-4px)}50%{transform:translateY(0)}75%{transform:translateY(-2px)}}
.tab-label{font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:600;letter-spacing:.02em;max-width:0;overflow:hidden;white-space:nowrap;opacity:0;margin-left:0;transition:max-width .4s cubic-bezier(.22,1,.36,1),opacity .25s ease,margin-left .35s cubic-bezier(.22,1,.36,1);color:var(--red);}
.tab.active .tab-label{max-width:100px;opacity:1;margin-left:6px;}
.tab-badge{position:absolute;top:2px;right:2px;min-width:14px;height:14px;background:var(--red);color:#fff;font-size:8px;font-weight:700;border-radius:7px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid #0c0a09;}
.tab.active .tab-badge{display:none;}

/* ─── PRODUCT MODAL (preview) ─── */
#pm-overlay{position:fixed;inset:0;z-index:9000;background:rgba(12,10,9,.72);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .35s ease;display:flex;align-items:center;justify-content:center;padding:40px 24px;}
#pm-overlay.open{opacity:1;pointer-events:auto;}
.pm-card{background:#fff;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;transform:scale(.92) translateY(20px);opacity:0;transition:transform .45s cubic-bezier(.22,1,.36,1),opacity .35s;position:relative;box-shadow:0 30px 80px rgba(0,0,0,.4);}
#pm-overlay.open .pm-card{transform:scale(1) translateY(0);opacity:1;}
.pm-close{position:absolute;top:16px;right:16px;width:36px;height:36px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border:none;border-radius:50%;cursor:none;display:flex;align-items:center;justify-content:center;z-index:5;transition:background .2s;}
.pm-close:hover{background:var(--red);color:#fff;}
.pm-close svg{width:16px;height:16px;}
.pm-img{aspect-ratio:4/3;width:100%;background:repeating-linear-gradient(-45deg,#ede9e3,#ede9e3 8px,#e6e1da 8px,#e6e1da 16px);background-size:cover;background-position:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;}
.pm-img span{font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-family:monospace;color:rgba(0,0,0,.22);}
.pm-body{padding:32px 32px 36px;}
.pm-eyebrow{font-family:'Space Grotesk',sans-serif;font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:10px;}
.pm-name{font-family:'Space Grotesk',sans-serif;font-size:28px;font-weight:700;letter-spacing:-.02em;color:#0c0a09;margin-bottom:6px;line-height:1.1;}
.pm-variant{font-size:14px;color:rgba(0,0,0,.55);margin-bottom:24px;}
.pm-desc{font-size:14px;font-weight:300;color:rgba(0,0,0,.65);line-height:1.7;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid rgba(0,0,0,.08);}
.pm-row{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.pm-price{font-family:'Space Grotesk',sans-serif;font-size:26px;font-weight:700;color:#0c0a09;}
.pm-btn-add{background:var(--red);color:#fff;font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:14px 32px;border:none;cursor:none;transition:background .2s,transform .2s;}
.pm-btn-add:hover{background:#8a0000;transform:translateY(-1px);}
.cg-item{cursor:pointer;}
.cg-card{transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s;}
.cg-item.front .cg-card{box-shadow:0 40px 100px rgba(0,0,0,.28),0 10px 30px rgba(0,0,0,.12);}

/* ─── NOSOTROS ─── */
#nosotros{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;}
.nos-left{background:#0c0a09;padding:120px 80px;display:flex;flex-direction:column;justify-content:center;}
.nos-ey{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:24px;}
.nos-ttl{font-family:'Space Grotesk',sans-serif;font-size:clamp(28px,3vw,44px);font-weight:700;letter-spacing:-.025em;line-height:1.15;color:#fff;margin-bottom:28px;}
.nos-body{font-size:16px;font-weight:300;color:rgba(255,255,255,.5);line-height:1.7;max-width:380px;margin-bottom:40px;}
.btn-ig{display:inline-flex;align-items:center;gap:10px;background:transparent;color:#fff;font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:500;letter-spacing:.06em;padding:0 0 5px;border:none;border-bottom:1px solid rgba(255,255,255,.3);cursor:none;transition:border-color .2s;}
.btn-ig:hover{border-color:#fff;}
.nos-right{background:var(--warm);display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:2px;}
.ig-tile{aspect-ratio:1;background:#0c0a09;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(20px);transition:opacity .6s,transform .6s;}
.ig-tile.v{opacity:1;transform:translateY(0);}
.ig-tile span{font-size:8px;letter-spacing:.1em;text-transform:uppercase;font-family:monospace;color:rgba(0,0,0,.22);}

/* ─── CTA ─── */
#cta-final{height:80vh;background:var(--red);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 24px;}
.cta-ttl{font-family:'Space Grotesk',sans-serif;font-size:clamp(36px,5.5vw,80px);font-weight:700;letter-spacing:-.03em;line-height:1.0;color:#fff;margin-bottom:44px;max-width:700px;}
.btn-cta{background:#fff;color:var(--red);font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:18px 56px;border:none;cursor:none;transition:background .2s,color .2s,transform .2s;}
.btn-cta:hover{background:#0c0a09;color:#fff;transform:translateY(-2px);}

/* ─── BRAND LOGO (wordmark) ─── */
.brand{display:inline-flex;flex-direction:column;align-items:flex-start;line-height:1;}
.brand-mark{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:18px;letter-spacing:-.01em;color:#0c0a09;display:inline-flex;align-items:flex-start;line-height:.95;}
.brand-mark sup{font-size:.45em;font-weight:600;margin-left:2px;margin-top:.15em;color:rgba(0,0,0,.55);}
.brand-tag{font-family:'Outfit',sans-serif;font-weight:300;font-size:9.5px;letter-spacing:.02em;color:rgba(0,0,0,.5);margin-top:3px;}
#nav.scrolled .brand-mark{color:#fff;}
#nav.scrolled .brand-mark sup{color:rgba(255,255,255,.55);}
#nav.scrolled .brand-tag{color:rgba(255,255,255,.5);}
body:not(.template-home) #nav .brand-mark{color:#fff;}
body:not(.template-home) #nav .brand-mark sup{color:rgba(255,255,255,.55);}
body:not(.template-home) #nav .brand-tag{color:rgba(255,255,255,.5);}
.brand.brand-loader .brand-mark{color:#fff;font-size:24px;}
.brand.brand-loader .brand-mark sup{color:rgba(255,255,255,.6);}
.brand.brand-loader .brand-tag{color:rgba(255,255,255,.45);font-size:11px;letter-spacing:.04em;margin-top:6px;}

/* ─── FOOTER ─── */
footer.jm-footer{position:relative;background:#0c0a09;color:rgba(255,255,255,.65);overflow:hidden;border-top:1px solid rgba(255,255,255,.05);}
.ft-bg{position:absolute;inset:0;z-index:0;background:radial-gradient(125% 125% at 50% 10%, rgba(15,15,17,0.4) 50%, rgba(174,0,0,0.18) 100%);pointer-events:none;}
.ft-inner{position:relative;z-index:5;max-width:1280px;margin:0 auto;padding:88px 48px 0;}
.ft-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:64px;padding-bottom:56px;}
.ft-brand-block{display:flex;flex-direction:column;gap:18px;}
.ft-brand-block .brand-mark{color:#fff;font-size:22px;}
.ft-brand-block .brand-mark sup{color:rgba(255,255,255,.55);}
.ft-brand-block .brand-tag{color:rgba(255,255,255,.45);font-size:11.5px;letter-spacing:.04em;margin-top:5px;}
.ft-brand-desc{font-size:13px;line-height:1.75;color:rgba(255,255,255,.4);max-width:260px;margin-top:8px;}
.ft-col h4{font-family:'Space Grotesk',sans-serif;color:#fff;font-size:14px;font-weight:600;margin-bottom:22px;letter-spacing:-.01em;}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:11px;}
.ft-col a{font-size:13.5px;color:rgba(255,255,255,.6);transition:color .25s;cursor:none;position:relative;display:inline-flex;align-items:center;gap:8px;}
.ft-col a:hover{color:var(--red);}
.ft-pulse{display:inline-block;width:6px;height:6px;background:var(--red);border-radius:50%;animation:ftPulse 1.6s ease-in-out infinite;}
@keyframes ftPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}
.ft-contact-row{display:flex;align-items:center;gap:12px;font-size:13.5px;color:rgba(255,255,255,.6);}
.ft-contact-row svg{width:18px;height:18px;color:var(--red);flex-shrink:0;}
.ft-contact-row a{color:inherit;transition:color .25s;}
.ft-contact-row a:hover{color:var(--red);}
.ft-divider{border:none;border-top:1px solid rgba(255,255,255,.08);margin:8px 0;}
.ft-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;padding:28px 0 32px;font-size:12px;color:rgba(255,255,255,.4);}
.ft-socials{display:flex;gap:22px;align-items:center;}
.ft-socials a{color:rgba(255,255,255,.45);transition:color .25s,transform .25s;display:inline-flex;cursor:none;}
.ft-socials a:hover{color:var(--red);transform:translateY(-2px);}
.ft-socials svg{width:18px;height:18px;}
.ft-hero-text{position:relative;z-index:3;width:100%;height:clamp(200px,28vw,360px);margin-top:-40px;margin-bottom:-80px;display:flex;align-items:center;justify-content:center;}
.ft-hero-svg{width:100%;height:100%;display:block;user-select:none;cursor:pointer;}
.ft-hero-svg text{font-family:'Space Grotesk',sans-serif;font-weight:800;font-size:80px;letter-spacing:-.04em;}

/* ─── UTILS ─── */
.ru{opacity:0;transform:translateY(36px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);}
.ru.v{opacity:1;transform:translateY(0);}

@media(max-width:1024px){.n-links{display:none;}#nosotros{grid-template-columns:1fr;min-height:auto;}.nos-right{display:grid!important;aspect-ratio:1;}.nos-right .ig-tile,.ig-tile{opacity:1!important;transform:none!important;}.ft-grid{grid-template-columns:1fr 1fr;}}

/* iOS / móvil: usar la ALTURA VISIBLE real (svh) en secciones full-height,
   así la barra del navegador no corta el contenido (tarjetas de galería, etc.) */
@media(max-width:900px){
  #hero{height:100vh;height:100svh;}
  #sticky-stage,#stats-sticky,#coll-sticky,#prod-sticky{height:100vh;height:100svh;}
}
@media(max-width:768px){
  body.template-home{cursor:auto;}
  #c-dot,#c-ring{display:none;}
  a,button,.col-card-3d,.cg-item,.ig-tile,.col-info,.cg-info,.btn-min,.btn-canvas,.btn-ig,.cg-btn,.btn-cta,.ft-col li{cursor:pointer;}
  #nav{padding:0 20px;height:56px;}
  .n-logo{font-size:11px;}
  .n-icons{gap:12px;}
  .n-icons a{font-size:10px;}
  .cart-b{font-size:8px;width:14px;height:14px;}
  .s-prog{top:56px;}
  #hero{padding:0 24px;}
  .h-eyebrow{font-size:10px;margin-bottom:20px;}
  .h-title{font-size:clamp(56px,14vw,88px);}
  .h-sub{font-size:15px;padding:0 8px;}
  .h-ctas{flex-direction:column;gap:18px;}
  .btn-min{font-size:12px;}
  .btn-min.filled{padding:14px 36px;width:100%;max-width:280px;}
  .h-scroll-hint{bottom:32px;}
  .mq{padding:11px 0;}
  .mq-item{font-size:10px;padding:0 22px;gap:18px;letter-spacing:.12em;}
  #kicker{padding:0 24px;height:70vh;}
  .k-main{font-size:clamp(32px,9vw,52px);}
  .k-sub{font-size:14px;}
  .k-arrow{margin-top:32px;}
  .ct-glass{padding:24px 26px;max-width:88vw;}
  .ct-eyebrow{font-size:9px;margin-bottom:8px;}
  .ct-title{font-size:clamp(24px,7vw,40px);}
  .ct-body{font-size:13px;}
  .btn-canvas{font-size:12px;margin-top:16px;}
  #ct3{bottom:48px;}
  #sh{bottom:28px;}
  #sh span{font-size:9px;}
  .stat-pane{padding:0 24px;}
  .stat-big{font-size:clamp(72px,24vw,140px);}
  .stat-label{font-size:clamp(13px,3.5vw,18px);margin-top:18px;}
  .stat-divider{width:24px;margin-top:18px;}
  .book-header{padding:64px 24px 0;}
  .book-header h2{font-size:clamp(18px,5vw,28px);}
  .book-counter{font-size:10px;}
  .col-info{padding:36px 28px 120px!important;}
  .col-eyebrow{font-size:9px;}
  .col-name{font-size:clamp(34px,11vw,58px);}
  .col-price{font-size:13px;}
  .col-cta.jm-premium-btn{padding:14px 30px!important;font-size:12px!important;}
  .prod-header{padding:64px 24px 0;}
  .prod-header h2{font-size:clamp(18px,5vw,28px);}
  .prod-header span{font-size:10px;}
  #cg-stage{perspective:2200px;}
  #cg-rotor{transform-origin:center center;}
  /* Tarjetas RESPONSIVAS: se adaptan a la altura visible del celular (svh).
     Cap en px para que no crezcan demasiado en pantallas altas. */
  .cg-item{
    height:min(250px,34svh);
    width:min(180px,24.5svh);
    margin-top:calc(min(250px,34svh) * -0.5)!important;
    margin-left:calc(min(180px,24.5svh) * -0.5)!important;
  }
  .cg-name{font-size:12px;}
  .cg-variant{font-size:9px;margin-bottom:8px;}
  .cg-eyebrow{font-size:7px;letter-spacing:.14em;margin-bottom:4px;}
  .cg-price{font-size:13px;}
  .cg-btn{font-size:8px;letter-spacing:.08em;}
  .cg-info{padding:13px 12px 11px;}
  .cg-img span{font-size:7px;}
  .cg-hint{bottom:28px;display:none;}
  .cg-see-all{bottom:max(56px,8svh);font-size:11px;padding:14px 28px;letter-spacing:.13em;gap:9px;}
  .cg-hint span{font-size:9px;}
  .pm-card{max-width:88vw;}
  .pm-img{aspect-ratio:1;}
  .pm-name{font-size:24px;}
  .pm-price{font-size:24px;}
  .pm-row{flex-direction:column;align-items:stretch;gap:14px;}
  .pm-btn-add{width:100%;text-align:center;}
  .nos-left{padding:110px 30px 92px!important;}
  .nos-ey{margin-bottom:18px!important;}
  .nos-ttl{font-size:clamp(28px,8vw,40px);margin-bottom:22px!important;line-height:1.1;}
  .nos-body{font-size:15px;line-height:1.85;margin-bottom:30px!important;}
  .btn-ig{font-size:12px;}
  .nos-right{gap:8px!important;padding:0 0 40px!important;background:#0c0a09;}
  #cta-final{padding:0 24px;height:70vh;}
  .cta-ttl{font-size:clamp(32px,9vw,56px);}
  .btn-cta{padding:16px 44px;font-size:12px;}
  #tabbar{display:flex;}
  body.template-home{padding-bottom:88px;}
  .ft-inner{padding:64px 24px 0;}
  .ft-grid{grid-template-columns:1fr 1fr;gap:32px 24px;padding-bottom:40px;}
  .ft-brand-block{grid-column:span 2;}
  .ft-col h4{font-size:13px;margin-bottom:16px;}
  .ft-col a{font-size:13px;}
  .ft-bottom{flex-direction:column;gap:18px;text-align:center;padding:24px 0 28px;}
  .ft-socials{justify-content:center;}
  .ft-hero-text{height:clamp(110px,30vw,180px);margin-top:-20px;margin-bottom:-40px;}
  .ft-hero-svg text{font-size:60px;}
}

/* ============================================================================
   JUSTO MAKARIO — Páginas internas modernas en sintonía con el home
   (producto, categoría, búsqueda, blog). Solo estética, sin tocar la lógica.
   ============================================================================ */

/* Títulos internos en la tipografía de marca */
body:not(.template-home) h1,
body:not(.template-home) h2,
body:not(.template-home) h3,
body:not(.template-home) .h1,
body:not(.template-home) .h2{font-family:'Space Grotesk',sans-serif;letter-spacing:-.02em;color:var(--black);}

/* Botones primarios = lenguaje del home (rojo, sin redondeo, mayúsculas) */
body:not(.template-home) .btn-primary{font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-radius:0;border:none;}
body:not(.template-home) .btn-primary:hover{background:#8a0000;}

/* PRODUCTO ------------------------------------------------------------------ */
body.template-product #single-product{animation:jmFadeUp .7s cubic-bezier(.22,1,.36,1) both;}
@keyframes jmFadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
body.template-product .js-price-display,
body.template-product #price_display{font-family:'Space Grotesk',sans-serif;font-weight:700;color:var(--black);}
body.template-product .price-compare,
body.template-product .js-compare-price-display{color:rgba(12,10,9,.45);text-decoration:line-through;}
/* En el producto, la barra de compra reemplaza la tab bar mobile */
body.template-product #tabbar{display:none;}

/* GRILLA de producto (categoría/búsqueda/relacionados) — tarjeta tipo home */
body:not(.template-home) .item-product .item-name{font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:-.01em;}
body:not(.template-home) .item-product .item-price{font-family:'Space Grotesk',sans-serif;font-weight:700;color:var(--black);}
/* (Sin transform en la imagen de la tarjeta: Recife usa transform para el hover de imagen secundaria) */

/* BLOG ---------------------------------------------------------------------- */
body.template-blog h1,
body.template-blog-post h1{font-family:'Space Grotesk',sans-serif;letter-spacing:-.025em;}
body.template-blog .blog-post-title,
body.template-blog-post .blog-post-title{font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-.02em;}
body.template-blog .blog-post-item{transition:transform .4s cubic-bezier(.22,1,.36,1);}
body.template-blog .blog-post-item:hover{transform:translateY(-4px);}

/* ─── BARRA DE COMPRA FIJA (sticky) — reusa el botón real de Agregar ─── */
#jm-buy-bar{position:fixed;left:0;right:0;bottom:0;z-index:550;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 24px;background:rgba(12,10,9,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transform:translateY(120%);transition:transform .4s cubic-bezier(.22,1,.36,1);box-shadow:0 -8px 30px rgba(0,0,0,.18);}
#jm-buy-bar.show{transform:translateY(0);}
.jm-bb-info{display:flex;flex-direction:column;min-width:0;}
.jm-bb-name{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50vw;}
.jm-bb-price{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:18px;color:#fff;}
.jm-bb-btn{background:var(--red);color:#fff;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;border:none;padding:14px 28px;cursor:pointer;white-space:nowrap;transition:background .2s,transform .2s;}
.jm-bb-btn:hover{background:#8a0000;transform:translateY(-1px);}
@media(max-width:768px){
  #jm-buy-bar{padding:10px 16px;}
  .jm-bb-btn{padding:12px 18px;font-size:12px;}
  .jm-bb-name{font-size:12px;max-width:38vw;}
  .jm-bb-price{font-size:16px;}
}

/* ─── MOTION GLOBAL (internas): reveal al scrollear, micro-interacciones ─── */
.jm-reveal{opacity:0;transform:translateY(26px);transition:opacity .75s cubic-bezier(.22,1,.36,1),transform .75s cubic-bezier(.22,1,.36,1);will-change:opacity,transform;}
.jm-reveal.jm-in{opacity:1;transform:none;}
body:not(.template-home) main, body:not(.template-home) #single-product, body:not(.template-home) .section-single-product{}
/* Fade-in suave de página interna */
body:not(.template-home) .container{}
/* Imágenes con aparición suave (complementa lazyload del base) */
body:not(.template-home) .item-image img{transition:opacity .6s ease;}
/* Accesibilidad: respetar usuarios que reducen movimiento */
@media (prefers-reduced-motion: reduce){
  .jm-reveal{opacity:1!important;transform:none!important;transition:none!important;}
  body.template-product #single-product{animation:none!important;}
  .mq-track{animation:none!important;}
}

/* ─── INSTAGRAM FEED real dentro de "Nosotros" (mosaico 3x3) ─── */
.nos-right #instagram-feed.ig-grid{grid-column:1 / -1;grid-row:1 / -1;display:grid;grid-template-columns:repeat(3,1fr);gap:2px;width:100%;height:100%;}
.nos-right .ig-tile{aspect-ratio:1;overflow:hidden;display:block;position:relative;}
.nos-right .ig-tile-link{display:block;width:100%;height:100%;}
.nos-right .ig-tile-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.22,1,.36,1);}
.nos-right .ig-tile:hover .ig-tile-img{transform:scale(1.06);}

/* ─── Cards de producto en listados: look moderno + efectos ─── */
body:not(.template-home) .item-product{transition:transform .4s cubic-bezier(.22,1,.36,1);}
body:not(.template-home) .item-product .item-image{overflow:hidden;}
body:not(.template-home) .item-product:hover{transform:translateY(-6px);}
body:not(.template-home) .item-product .item-name{font-family:'Space Grotesk',sans-serif;font-weight:600;}

/* ============================================================================
   JUSTO MAKARIO — Categoría (listado) y Producto (detalle) robustos y modernos
   ============================================================================ */

/* ─── CATEGORÍA ─── */
.jm-cat{max-width:1280px;margin:0 auto;padding:120px 32px 90px;}
.jm-cat-head{text-align:center;margin-bottom:56px;}
.jm-cat-eyebrow{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--red);margin-bottom:12px;}
.jm-cat-title{font-family:'Space Grotesk',sans-serif;font-size:clamp(32px,5vw,64px);font-weight:700;letter-spacing:-.03em;color:var(--black);line-height:1;}
.jm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;}
.jm-card{display:block;text-decoration:none;color:inherit;background:#fff;transition:transform .45s cubic-bezier(.22,1,.36,1),box-shadow .45s;}
.jm-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px rgba(0,0,0,.12);}
.jm-card-media{position:relative;aspect-ratio:1;overflow:hidden;background:#f0ebe2;}
.jm-card-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.22,1,.36,1);}
.jm-card:hover .jm-card-img{transform:scale(1.07);}
.jm-card-img-empty{background:repeating-linear-gradient(-45deg,#ede9e3,#ede9e3 10px,#e6e1da 10px,#e6e1da 20px);}
.jm-card-badge{position:absolute;top:12px;left:12px;background:var(--red);color:#fff;font-family:'Space Grotesk',sans-serif;font-size:10px;font-weight:700;letter-spacing:.1em;padding:5px 10px;z-index:2;}
.jm-card-cta{position:absolute;left:0;right:0;bottom:0;background:rgba(12,10,9,.85);color:#fff;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;text-align:center;padding:12px;transform:translateY(100%);transition:transform .4s cubic-bezier(.22,1,.36,1);}
.jm-card:hover .jm-card-cta{transform:translateY(0);}
.jm-card-info{padding:16px 6px 8px;}
.jm-card-name{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--black);line-height:1.3;margin-bottom:8px;}
.jm-card-prices{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;}
.jm-card-old{font-size:13px;color:rgba(12,10,9,.4);text-decoration:line-through;}
.jm-card-price{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:700;color:var(--black);}
.jm-pagination{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:64px;}
.jm-pg-info{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:600;color:var(--black);}
.jm-pg-arrow{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(12,10,9,.2);color:var(--black);text-decoration:none;transition:background .25s,color .25s,border-color .25s;}
.jm-pg-arrow:hover{background:var(--black);color:#fff;border-color:var(--black);}
.jm-empty{text-align:center;padding:80px 0;color:rgba(12,10,9,.5);font-size:18px;}

/* ─── PRODUCTO ─── */
.jm-pdp{max-width:1240px;margin:0 auto;padding:110px 32px 80px;display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:start;}
.jm-pdp-main{aspect-ratio:1;background:#f0ebe2;overflow:hidden;}
.jm-pdp-main img{width:100%;height:100%;object-fit:cover;display:block;}
.jm-pdp-thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap;}
.jm-pdp-thumb{width:72px;height:72px;border:1px solid rgba(12,10,9,.12);background:#fff;padding:0;cursor:pointer;overflow:hidden;transition:border-color .25s;}
.jm-pdp-thumb.active,.jm-pdp-thumb:hover{border-color:var(--red);}
.jm-pdp-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.jm-pdp-info{position:sticky;top:90px;}
.jm-pdp-eyebrow{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--red);margin-bottom:14px;}
.jm-pdp-name{font-family:'Space Grotesk',sans-serif;font-size:clamp(28px,3.4vw,46px);font-weight:700;letter-spacing:-.03em;color:var(--black);line-height:1.05;margin-bottom:20px;}
.jm-pdp-prices{display:flex;align-items:baseline;gap:14px;margin-bottom:28px;flex-wrap:wrap;}
.jm-pdp-old{font-size:20px;color:rgba(12,10,9,.4);text-decoration:line-through;}
.jm-pdp-price{font-family:'Space Grotesk',sans-serif;font-size:34px;font-weight:700;color:var(--black);}
.jm-pdp-form{margin-bottom:28px;}
.jm-pdp-variants{margin-bottom:20px;}
.jm-pdp-qty{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;max-width:160px;}
.jm-pdp-qty label{font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(12,10,9,.6);}
.jm-pdp-qty input{padding:12px 14px;border:1px solid rgba(12,10,9,.2);font-size:16px;font-family:'Outfit',sans-serif;width:100%;}
.jm-btn-add{display:inline-block;width:100%;background:var(--red);color:#fff;font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:18px 32px;border:none;cursor:pointer;transition:background .25s,transform .25s;}
.jm-btn-add:hover{background:#8a0000;transform:translateY(-2px);}
.jm-btn-add.nostock{background:rgba(12,10,9,.3);cursor:not-allowed;}
.jm-pdp-trust{list-style:none;display:flex;flex-wrap:wrap;gap:8px 22px;padding:0;margin:0 0 28px;}
.jm-pdp-trust li{font-size:13px;color:rgba(12,10,9,.6);display:flex;align-items:center;gap:7px;}
.jm-pdp-trust li::before{content:'✓';color:var(--red);font-weight:700;}
.jm-pdp-desc{font-size:15px;line-height:1.75;color:rgba(12,10,9,.7);border-top:1px solid rgba(12,10,9,.1);padding-top:24px;}
.jm-pdp-desc img{max-width:100%;height:auto;}

@media(max-width:1024px){.jm-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:900px){.jm-pdp{grid-template-columns:1fr;gap:32px;padding:90px 16px 70px;}.jm-pdp-info{position:static;}}
@media(max-width:768px){.jm-grid{grid-template-columns:repeat(2,1fr);gap:14px;}.jm-cat{padding:96px 16px 70px;}}

/* ============================================================================
   JUSTO MAKARIO sobre RECIFE — el home usa nav/footer custom; las internas, Recife
   ============================================================================ */
/* Ocultar header y footer de Recife SOLO en el home (los modales quedan activos) */
body.template-home header.js-head-main{display:none !important;}
body.template-home footer.js-footer{display:none !important;}
/* El home arranca arriba de todo (sin el espacio del header de Recife) */
body.template-home{padding-top:0 !important;}

/* ============================================================================
   JUSTO MAKARIO — Botón premium (CTA del home): glass + luces que siguen el cursor
   ============================================================================ */
.jm-premium-btn{position:relative;isolation:isolate;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:17px 44px;border-radius:999px;font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:rgba(255,255,255,.08);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:none;cursor:none;overflow:hidden;transition:transform .3s cubic-bezier(.22,1,.36,1);text-decoration:none;}
.jm-premium-btn::before{content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:1;box-shadow:inset 0 0 0 1px rgba(255,255,255,.28), inset 0 0 16px 0 rgba(255,255,255,.12), inset 0 -3px 12px 0 rgba(255,255,255,.20), 0 2px 6px 0 rgba(0,0,0,.45), 0 10px 28px 0 rgba(0,0,0,.35);transition:transform .3s;}
.jm-premium-btn:hover{transform:translateY(-2px);}
.jm-premium-btn:active::before{transform:scale(.97);}
.jm-premium-btn .jm-btn-label{position:relative;z-index:2;display:inline-flex;align-items:center;gap:8px;}
.jm-premium-btn .jm-circle{position:absolute;width:16px;height:16px;border-radius:50%;filter:blur(12px);pointer-events:none;z-index:0;transform:translate(-50%,-50%);opacity:0;transition:opacity .3s;}
.jm-premium-btn .jm-circle.in{opacity:.85;}
.jm-premium-btn .jm-circle.out{opacity:0;transition:opacity 1.2s;}
@media(max-width:768px){.jm-premium-btn{cursor:pointer;padding:16px 36px;}}

/* ── "Ver todos los productos": botón GLASS premium NOTABLE (oscuro frosted) ── */
.cg-see-all.jm-premium-btn{position:absolute;left:50%;transform:translateX(-50%);color:#fff!important;background:rgba(12,10,9,.42)!important;-webkit-backdrop-filter:blur(20px) saturate(165%);backdrop-filter:blur(20px) saturate(165%);}
.cg-see-all.jm-premium-btn::before{box-shadow:inset 0 0 0 1px rgba(255,255,255,.34), inset 0 0 18px 0 rgba(255,255,255,.14), inset 0 -3px 14px 0 rgba(255,255,255,.22), 0 6px 18px 0 rgba(12,10,9,.30), 0 18px 44px 0 rgba(12,10,9,.30);}
.cg-see-all.jm-premium-btn:hover{transform:translateX(-50%) translateY(-3px);background:rgba(12,10,9,.56)!important;}
.cg-see-all.jm-premium-btn .jm-btn-label{gap:14px;}
.cg-see-all.jm-premium-btn svg{width:15px;height:15px;}

/* ── Cards de producto (categoría/búsqueda) — premium + tilt 3D ── */
body:not(.template-home) .item-product{transition:transform .15s ease-out;will-change:transform;}
body:not(.template-home) .item-image,
body:not(.template-home) .js-item-image-padding{border-radius:20px;overflow:hidden;}
body:not(.template-home) .item-image{box-shadow:0 16px 38px rgba(0,0,0,.10);transition:box-shadow .35s;}
body:not(.template-home) .item-product:hover .item-image{box-shadow:0 30px 70px rgba(0,0,0,.20);}
body:not(.template-home) .item-name{font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:-.01em;}
body:not(.template-home) .item-price{font-family:'Space Grotesk',sans-serif;font-weight:700;}

/* ============================================================================
   JUSTO MAKARIO — Ocultar popups de apps externas (pedido del cliente)
   - Ruleta "HOT SALE / Girá y Ganá"  (#mkrio-wheel-overlay)
   - Formulario/optin de mayoristas   (Privy/optin: #optin-*, .p-optin)
   Esto los oculta visualmente. Para apagarlos del todo (que no carguen),
   hay que desinstalarlos/desactivarlos desde el panel de la tienda.
   ============================================================================ */
#mkrio-wheel-overlay,
.mkrio-card,
.mkrio-visible,
[id^="mkrio-"],
[id^="optin-"],
[id^="optin-form-"],
.p-optin,
.p-inline,
.p-displayed,
.p-modal,
[class*="privy"]{display:none!important;visibility:hidden!important;pointer-events:none!important;}

/* ============================================================================
   JUSTO MAKARIO — HEADER PREMIUM (páginas internas) en sintonía con el home
   Claro + frosted + tipografía de marca + micro-interacciones. Light/futurista.
   Mantiene toda la lógica de Recife (búsqueda, carrito, cuenta, menú).
   ============================================================================ */

/* 1) Quitar barras superiores (marquee "BIENVENIDOS" + topbar IG/Mayoristas) */
body:not(.template-home) .js-adbar,
body:not(.template-home) .section-adbar,
body:not(.template-home) .js-topbar,
body:not(.template-home) .section-topbar{display:none!important;}

/* 2) Header: vidrio esmerilado claro, hairline y sombra sutil al hacer scroll */
body:not(.template-home) header.js-head-main{
  background:rgba(255,255,255,.72)!important;
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid rgba(12,10,9,.06);
  box-shadow:0 10px 40px -28px rgba(12,10,9,.45);
  transition:background .4s ease, box-shadow .4s ease, border-color .4s ease;
}
/* micro-acento futurista: hairline rojo degradé arriba de todo */
body:not(.template-home) header.js-head-main::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;z-index:5;
  background:linear-gradient(90deg,transparent,rgba(174,0,0,.0) 8%,var(--red) 50%,rgba(174,0,0,.0) 92%,transparent);
  opacity:.55;
}
body:not(.template-home) .head-banners{padding-top:6px;padding-bottom:6px;}

/* 3) Logo un toque más presente */
body:not(.template-home) .logo-img{transition:transform .4s cubic-bezier(.22,1,.36,1),filter .4s;}
body:not(.template-home) .js-logo-container:hover .logo-img{transform:translateY(-1px) scale(1.02);}

/* 4) Nav links: marca + subrayado animado rojo desde el centro */
body:not(.template-home) .nav-list-link{
  font-family:'Space Grotesk',sans-serif!important;
  font-size:13px!important;font-weight:600!important;
  letter-spacing:.13em!important;text-transform:uppercase!important;
  color:#0c0a09!important;position:relative;transition:color .3s ease;
}
body:not(.template-home) .nav-list-link::after{
  content:'';position:absolute;left:50%;right:50%;bottom:-3px;height:2px;
  background:var(--red);border-radius:2px;
  transition:left .38s cubic-bezier(.22,1,.36,1),right .38s cubic-bezier(.22,1,.36,1);
}
body:not(.template-home) .nav-list-link:hover,
body:not(.template-home) .nav-list-link.selected{color:var(--red)!important;}
body:not(.template-home) .nav-list-link:hover::after,
body:not(.template-home) .nav-list-link.selected::after{left:0;right:0;}

/* 5) Iconos de utilidad (búsqueda / cuenta / carrito): hover premium */
body:not(.template-home) .btn-utility,
body:not(.template-home) .utilities-item,
body:not(.template-home) .js-search-button,
body:not(.template-home) .cart-summary{
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),color .3s ease!important;
}
body:not(.template-home) .btn-utility:hover,
body:not(.template-home) .utilities-item:hover,
body:not(.template-home) .js-search-button:hover{transform:translateY(-2px) scale(1.08);color:var(--red)!important;}
body:not(.template-home) .cart-summary:hover{transform:translateY(-2px) scale(1.06);}

/* ============================================================================
   JUSTO MAKARIO — BOTONES PREMIUM (más grandes + efectos)
   ============================================================================ */

/* Home: CTAs premium más grandes y con más presencia */
.jm-premium-btn{padding:21px 58px!important;font-size:15px!important;letter-spacing:.12em!important;}
.cg-see-all.jm-premium-btn{padding:19px 50px!important;}
@media(max-width:768px){.jm-premium-btn{padding:18px 46px!important;font-size:14px!important;}}

/* Internas: botón "Agregar"/"Comprar" — sólido, mayúsculas, barrido de luz + lift */
body:not(.template-home) .btn-primary,
body:not(.template-home) .js-addtocart,
body:not(.template-home) .item-product .btn,
body:not(.template-home) .js-quickshop-button{
  font-family:'Space Grotesk',sans-serif!important;font-weight:700!important;
  letter-spacing:.1em!important;text-transform:uppercase!important;border-radius:0!important;border:none!important;
  position:relative!important;overflow:hidden!important;
  transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease,background-color .3s ease!important;
}
body:not(.template-home) .btn-primary,
body:not(.template-home) .js-addtocart{padding:18px 40px!important;font-size:14px!important;}
/* barrido de brillo */
body:not(.template-home) .btn-primary::after,
body:not(.template-home) .js-addtocart::after,
body:not(.template-home) .item-product .btn::after{
  content:'';position:absolute;top:0;left:-130%;width:55%;height:100%;z-index:1;pointer-events:none;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.4),transparent);
  transform:skewX(-20deg);transition:left .65s cubic-bezier(.22,1,.36,1);
}
body:not(.template-home) .btn-primary:hover,
body:not(.template-home) .js-addtocart:hover,
body:not(.template-home) .item-product .btn:hover,
body:not(.template-home) .js-quickshop-button:hover{transform:translateY(-3px)!important;box-shadow:0 20px 44px -14px rgba(174,0,0,.55)!important;}
body:not(.template-home) .btn-primary:hover::after,
body:not(.template-home) .js-addtocart:hover::after,
body:not(.template-home) .item-product .btn:hover::after{left:150%;}

/* ============================================================================
   JUSTO MAKARIO — MOTION en internas: reveal al entrar en viewport
   (el observer se inyecta en jm-card-tilt.tpl)
   ============================================================================ */
body:not(.template-home) .jm-up{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);will-change:opacity,transform;}
body:not(.template-home) .jm-up.jm-on{opacity:1;transform:none;}
@media (prefers-reduced-motion: reduce){
  body:not(.template-home) .jm-up{opacity:1!important;transform:none!important;transition:none!important;}
}

/* ============================================================================
   JUSTO MAKARIO — PASE PREMIUM/FUTURISTA en páginas internas (catálogo + producto)
   Más superficie, profundidad, acentos y micro-interacciones. Solo estética.
   ============================================================================ */

/* Atmósfera: fondo cálido sutil en vez de blanco plano */
body:not(.template-home){background:#f6f4f0!important;}
body:not(.template-home) .main-content,
body:not(.template-home) main{background:transparent;}

/* — Cabecera de página (categoría/listado) — */
body:not(.template-home) .page-header{padding-top:40px!important;}
body:not(.template-home) .breadcrumbs,
body:not(.template-home) .breadcrumbs a,
body:not(.template-home) .js-breadcrumb{font-family:'Space Grotesk',sans-serif!important;font-size:11px!important;letter-spacing:.16em!important;text-transform:uppercase!important;color:rgba(12,10,9,.42)!important;}
body:not(.template-home) .page-header h1,
body:not(.template-home) .page-title h1{font-size:clamp(34px,5vw,62px)!important;letter-spacing:-.03em!important;position:relative;display:inline-block;padding-bottom:14px;}
body:not(.template-home) .page-header h1::after{content:'';position:absolute;left:0;bottom:0;width:72px;height:4px;border-radius:4px;background:linear-gradient(90deg,var(--red),rgba(174,0,0,.15));}

/* — Tarjeta de producto = superficie premium con profundidad — */
body:not(.template-home) .item-product{
  background:#fff;border:1px solid rgba(12,10,9,.05);border-radius:24px;
  padding:12px 12px 20px!important;
  box-shadow:0 16px 38px -24px rgba(12,10,9,.45);
  transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s ease!important;
}
body:not(.template-home) .item-product:hover{transform:translateY(-8px)!important;box-shadow:0 36px 70px -28px rgba(12,10,9,.55)!important;}
body:not(.template-home) .item-image,
body:not(.template-home) .js-item-image-padding{border-radius:16px!important;overflow:hidden!important;}
body:not(.template-home) .item-image{box-shadow:none!important;}
body:not(.template-home) .item-name,
body:not(.template-home) .item-price,
body:not(.template-home) .item-info{padding-left:8px!important;padding-right:8px!important;}
body:not(.template-home) .item-name{margin-top:14px!important;}

/* Badge de descuento → píldora roja premium */
body:not(.template-home) .label-offer-percentage,
body:not(.template-home) .label-offer-percentage-text,
body:not(.template-home) .item-product .label{
  font-family:'Space Grotesk',sans-serif!important;font-weight:700!important;
  letter-spacing:.04em!important;border-radius:999px!important;
  box-shadow:0 8px 18px -8px rgba(174,0,0,.65)!important;backdrop-filter:blur(4px);
}

/* — Sidebar de filtros — */
body:not(.template-home) aside h6,
body:not(.template-home) .js-filters-container h6,
body:not(.template-home) [class*="filter"] h6{font-family:'Space Grotesk',sans-serif!important;letter-spacing:.05em!important;}
body:not(.template-home) .js-categories-list a,
body:not(.template-home) .js-accordion-private-content a{transition:color .25s ease,padding-left .25s cubic-bezier(.22,1,.36,1)!important;}
body:not(.template-home) .js-categories-list a:hover,
body:not(.template-home) .js-accordion-private-content a:hover{color:var(--red)!important;padding-left:5px!important;}

/* — DETALLE DE PRODUCTO — */
body.template-product .js-price-display{font-family:'Space Grotesk',sans-serif!important;letter-spacing:-.02em!important;}
body.template-product .product-slide,
body.template-product .js-product-slide,
body.template-product .js-product-gallery-cont{border-radius:20px;overflow:hidden;}
/* (Sin transform/zoom en la imagen del producto: Recife la centra con translateX(-50%) y el scale la rompía) */
/* miniaturas: estado activo rojo */
body.template-product .js-product-thumb.active,
body.template-product .product-thumb.active,
body.template-product [class*="thumb"].swiper-slide-thumb-active{outline:2px solid var(--red)!important;outline-offset:2px;border-radius:10px;}
/* swatches de variante */
body.template-product .js-insta-product-variants label,
body.template-product .js-product-variants label,
body.template-product [class*="swatch"]{transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s!important;}
body.template-product .js-product-variants label:hover,
body.template-product [class*="swatch"]:hover{transform:translateY(-2px) scale(1.04)!important;}
/* stepper de cantidad */
body.template-product .js-quantity input,
body.template-product input[name="quantity"]{font-family:'Space Grotesk',sans-serif!important;font-weight:700!important;}
/* acordeones (envío / local) con hover */
body.template-product .js-toggle-shipping,
body.template-product .js-accordion-private-container{transition:background .25s ease!important;border-radius:12px;}
body.template-product .js-toggle-shipping:hover{background:rgba(12,10,9,.03)!important;}
/* productos similares: respiro premium */
body.template-product .section-products-related{margin-top:24px;}

/* — Galería de producto en MÓVIL: limpio, sin miniaturas apretadas — */
@media(max-width:768px){
  body.template-product .product-thumbs-container,
  body.template-product .js-swiper-product-thumbs{display:none!important;}
  body.template-product .js-swiper-product,
  body.template-product .product-detail-slide{margin-bottom:10px!important;border-radius:16px;overflow:hidden;}
  body.template-product .js-product-slide{height:auto!important;}
  /* respiro entre imagen e info */
  body.template-product .col-md-7.pb-4{padding-bottom:8px!important;}
  body.template-product .js-product-info,.product-info{padding-top:8px;}
}

/* — Flechitas glass modernas para deslizar fotos del producto — */
.jm-gal-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:25;
  width:46px;height:46px;border-radius:50%;display:none;align-items:center;justify-content:center;
  border:none;cursor:pointer;color:#0c0a09;
  background:rgba(255,255,255,.55);
  -webkit-backdrop-filter:blur(12px) saturate(160%);backdrop-filter:blur(12px) saturate(160%);
  box-shadow:0 10px 26px -10px rgba(12,10,9,.55), inset 0 0 0 1px rgba(255,255,255,.65);
  transition:background .25s ease, box-shadow .25s ease, transform .2s ease, opacity .3s ease;
}
.jm-gal-arrow svg{width:20px;height:20px;stroke-width:2.4;}
.jm-gal-arrow.prev{left:14px;}
.jm-gal-arrow.next{right:14px;}
.jm-gal-arrow:hover{background:rgba(255,255,255,.85);box-shadow:0 14px 32px -10px rgba(12,10,9,.6), inset 0 0 0 1px rgba(255,255,255,.8);}
.jm-gal-arrow:active{transform:translateY(-50%) scale(.9);}
.jm-gal-arrow[disabled]{opacity:.32;pointer-events:none;}
/* animación de "hint" en la flecha siguiente para invitar a deslizar */
.jm-gal-arrow.next:not([disabled]){animation:jmSwipeHint 2.1s cubic-bezier(.22,1,.36,1) infinite;}
@keyframes jmSwipeHint{0%,72%,100%{transform:translateY(-50%) translateX(0);}82%{transform:translateY(-50%) translateX(6px);}}
/* burbuja-pista "Deslizá" que aparece unos segundos */
.jm-swipe-tip{
  position:absolute;left:50%;bottom:16px;transform:translateX(-50%);z-index:25;
  display:flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;
  background:rgba(12,10,9,.6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  color:#fff;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  box-shadow:0 8px 22px -8px rgba(0,0,0,.5);opacity:0;transition:opacity .5s ease;pointer-events:none;
}
.jm-swipe-tip.show{opacity:1;}
.jm-swipe-tip svg{width:16px;height:16px;animation:jmTipHand 1.6s ease-in-out infinite;}
@keyframes jmTipHand{0%,100%{transform:translateX(-3px);}50%{transform:translateX(3px);}}
/* contador de fotos (1/3) arriba a la derecha de la imagen */
.jm-gal-count{
  position:absolute;top:14px;right:14px;z-index:25;padding:5px 11px;border-radius:999px;
  background:rgba(12,10,9,.55);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  color:#fff;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:700;letter-spacing:.06em;
}
/* En desktop hay miniaturas, así que mostramos las flechas solo en móvil */
@media(max-width:900px){
  .jm-gal-arrow{display:flex;}
}
