*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--red:#f41e0d;--dark:#0F0F0F;--gold:#B8860B;--gray:#6B7280;--light:#f9f9f9;--font-d:'Playfair Display',Georgia,serif;--font-b:'Montserrat','Helvetica Neue',sans-serif}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--dark);background:#fff;overflow-x:hidden}
p{text-align:justify}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:var(--font-b);cursor:pointer;border:none;background:none}
.container{max-width:1400px;margin:0 auto;padding:0 clamp(1rem,3vw,3rem)}

.topbar{background:#111;height:38px;display:flex;align-items:center;overflow:hidden;position:fixed;top:0;left:0;right:0;z-index:1001}
.topbar::before,.topbar::after{content:'';position:absolute;top:0;bottom:0;width:42px;z-index:2;pointer-events:none}
.topbar::before{left:0;background:linear-gradient(90deg,#111 0%,rgba(17,17,17,.92) 45%,rgba(17,17,17,0) 100%)}
.topbar::after{right:0;background:linear-gradient(270deg,#111 0%,rgba(17,17,17,.92) 45%,rgba(17,17,17,0) 100%)}
.topbar-track{display:flex;align-items:center;flex:0 0 auto;width:max-content;white-space:nowrap;will-change:transform;animation:scroll-text 42s linear infinite}
.topbar-group{display:flex;align-items:center;flex:0 0 auto}
.topbar-item{display:inline-flex;align-items:center;padding:0 2rem;font-size:.6rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#fff}
.topbar-item::after{content:'•';color:var(--red);margin-left:2rem;flex-shrink:0}
@keyframes scroll-text{from{transform:translateX(0)}to{transform:translateX(calc(-1 * var(--topbar-loop-width, 50%)))}}
@media(max-width:768px){.topbar::before,.topbar::after{width:26px}}

.header{position:fixed;top:38px;left:0;right:0;height:64px;background:#fff;display:flex;align-items:center;box-shadow:0 1px 3px rgba(0,0,0,.08);z-index:1002}
.header-in{width:100%;display:flex;align-items:center;gap:1.5rem;justify-content:center;padding:0 clamp(1rem,3vw,3rem);position:relative}
.logo{flex-shrink:0;position:absolute;left:clamp(1rem,3vw,3rem);display:flex;align-items:center;gap:.6rem}
.logo-img{height:50px;width:auto;display:block}
.logo-txt-img{height:40px;width:auto;display:block}
.nav{display:flex;gap:1.8rem;align-items:center;flex-shrink:0}
.nav a{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--dark);padding:.1rem 0;transition:color .3s}
.nav a.active,.nav a:hover{color:var(--red)}
.header-socials{display:flex;align-items:center;gap:.4rem;margin-right:.25rem}
.header-social{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--dark);border:1px solid rgba(255,255,255,.06);box-shadow:0 2px 10px rgba(0,0,0,.08);transition:transform .25s ease,background .25s ease,border-color .25s ease,box-shadow .25s ease}
.header-social-icon{width:13px;height:13px;display:block;object-fit:contain}
.header-social:hover{transform:translateY(-1px);background:var(--red);border-color:var(--red);box-shadow:0 6px 18px rgba(244,30,13,.22)}
.header-acts{display:flex;gap:1rem;align-items:center;flex-shrink:0;position:absolute;right:clamp(1rem,3vw,3rem)}
.header-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:opacity .3s;position:relative}
.header-btn svg{width:18px;height:18px;stroke:var(--dark);fill:none;stroke-width:2}
.cart-c{position:absolute;top:-4px;right:-6px;background:var(--red);color:#fff;font-size:.5rem;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.menu-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0}
.menu-btn svg{width:20px;height:20px;stroke:var(--dark);fill:none;stroke-width:2}
@media(min-width:1025px){.menu-btn{display:none}}
@media(max-width:1024px){.nav{display:none}.menu-btn{display:flex}.header .header-acts .menu-btn{display:flex!important;visibility:visible!important;opacity:1!important}}
@media(max-width:768px){.header{height:48px;top:38px}.logo{gap:.35rem}.logo-img{height:28px}.logo-txt-img{height:22px}.header-acts{gap:.3rem}.header-socials{gap:.2rem;margin-right:0}.header-social{width:22px;height:22px}.header-social-icon{width:10px;height:10px}.header-btn{width:26px;height:26px}.header-btn svg{width:16px;height:16px}.menu-btn{width:26px;height:26px}}
@media(max-width:520px){.header-acts{gap:.25rem}.cart-c{width:14px;height:14px;font-size:.45rem;right:-5px;top:-3px}.logo-img{height:24px}.logo-txt-img{height:18px}.header-social{width:20px;height:20px}.header-social-icon{width:9px;height:9px}}

main{margin-top:102px}
@media(max-width:480px){main{margin-top:48px}}

.section-tag{font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:.75rem}
.section-title{font-family:var(--font-d);font-weight:900;font-size:clamp(2rem,3.5vw,3rem);margin-bottom:2.5rem;color:var(--dark)}
.btn{padding:1rem 2rem;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;transition:all .3s;cursor:pointer;display:inline-block}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:#a93226;transform:translateY(-2px)}
.btn-outline{border:2px solid var(--dark);color:var(--dark);background:transparent}
.btn-outline:hover{background:var(--dark);color:#fff}

footer{background:#0a0a0a;color:#fff;padding:3rem 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}
.footer-col h4{font-weight:700;margin-bottom:1rem;color:var(--red)}
.footer-col ul{list-style:none}
.footer-col a{font-size:.9rem;color:rgba(255,255,255,.6);transition:color .3s;display:block;margin-bottom:.5rem}
.footer-col a:hover{color:#fff}
.footer-socials{display:flex;flex-wrap:wrap;gap:.75rem;margin:0 0 1.5rem}
.footer-social{width:40px;height:40px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);transition:transform .25s ease,border-color .25s ease,background .25s ease,box-shadow .25s ease}
.footer-social-icon{width:18px;height:18px;display:block;object-fit:contain;filter:brightness(0) invert(1);opacity:.95}
.footer-social:hover{transform:translateY(-2px);border-color:var(--red);background:rgba(244,30,13,.12)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:2rem;text-align:center;font-size:.85rem;color:rgba(255,255,255,.4)}
.footer-bottom span:last-child{color:var(--red) !important}

.mob-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;opacity:0;pointer-events:none;transition:opacity .3s}
.mob-overlay.open{opacity:1;pointer-events:auto}
.mob-nav{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:85vw;background:#fff;z-index:2001;transform:translateX(-100%);transition:transform .3s;padding:2rem;display:flex;flex-direction:column}
.mob-nav.open{transform:translateX(0)}
.mob-close{position:absolute;top:1.5rem;right:1.5rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer}
.mob-close svg{width:24px;height:24px;stroke:var(--dark);fill:none}
.mob-nav ul{list-style:none;display:flex;flex-direction:column;gap:1rem;margin-top:2rem}
.mob-nav a{font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.85rem;color:var(--dark)}
.mob-nav a:hover{color:var(--red)}

/* ORIGIN BANNER */
.origin-banner{background:#000;padding:clamp(1.5rem,4vw,4rem) 0;overflow:hidden;text-align:center}
.origin-banner span{font-family:var(--font-d);font-size:clamp(1.2rem,6.2vw,9rem);font-weight:900;color:#fff;letter-spacing:.03em;text-transform:uppercase;display:block;line-height:1.15;white-space:nowrap}

/* WSP FLOAT BTN */
.wsp-btn{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9000;width:56px;height:56px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(37,211,102,.45);transition:transform .2s,box-shadow .2s;text-decoration:none}
.wsp-btn:hover{transform:scale(1.1);box-shadow:0 6px 24px rgba(37,211,102,.55)}
.wsp-btn svg{width:30px;height:30px;fill:#fff}
