/* ============================================================
   ZAVALL — THEME CSS v2.0.0 — WHITE MODERN LUXURY EDITION
============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Barlow:wght@200;300;400;500&family=Barlow+Condensed:wght@200;300;400;500&display=swap');

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{
  background:var(--zavall-white);
  color:var(--zavall-ink);
  font-family:var(--zavall-sans);
  font-weight:300;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:none;
}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
button,input,textarea,select{font-family:inherit}
ul,ol{list-style:none}

/* Scrollbar */
::-webkit-scrollbar{width:2px}
::-webkit-scrollbar-track{background:var(--zavall-white)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--zavall-gold),transparent)}
::selection{background:rgba(184,151,90,0.12);color:var(--zavall-gold)}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ── Screen reader ──────────────────────────────────────────── */
.screen-reader-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.screen-reader-text:focus{background:var(--zavall-white);clip:auto;height:auto;left:6px;top:7px;width:auto;z-index:100000;padding:10px 20px;border:1px solid var(--zavall-gold);color:var(--zavall-ink)}

/* ── Custom Cursor ──────────────────────────────────────────── */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);will-change:transform}
.cursor-dot{width:5px;height:5px;background:var(--zavall-ink);border-radius:50%;transition:transform .15s,background .2s}
.cursor-ring{width:34px;height:34px;border:1px solid rgba(13,13,13,0.22);border-radius:50%;transition:width .35s var(--zavall-ease),height .35s var(--zavall-ease),border-color .35s}
body:has(a:hover) .cursor-ring,body:has(button:hover) .cursor-ring{width:54px;height:54px;border-color:rgba(184,151,90,0.7)}
@media(pointer:coarse){.cursor-dot,.cursor-ring{display:none}body{cursor:auto}}

/* ── Scroll progress ────────────────────────────────────────── */
.scroll-bar{position:fixed;top:0;left:0;height:2px;z-index:9999;width:0%;background:linear-gradient(90deg,var(--zavall-gold),var(--zavall-gold-bright));box-shadow:0 0 6px rgba(184,151,90,0.4)}

/* ── Loader ─────────────────────────────────────────────────── */
.loader{position:fixed;inset:0;background:var(--zavall-white);z-index:99998;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.8rem;transition:opacity 1s var(--zavall-ease),visibility 1s}
.loader.out{opacity:0;visibility:hidden;pointer-events:none}
.loader-logo{font-family:var(--zavall-serif);font-size:clamp(2.5rem,5vw,3.8rem);font-weight:300;letter-spacing:.55em;text-transform:uppercase;color:var(--zavall-ink);opacity:0;animation:fadeUp .9s var(--zavall-ease-out) .2s forwards}
.loader-logo span{color:var(--zavall-gold)}
.loader-tagline{font-family:var(--zavall-cond);font-size:.6rem;letter-spacing:.65em;text-transform:uppercase;color:var(--zavall-gray-500);opacity:0;animation:fadeUp .9s var(--zavall-ease-out) .45s forwards}
.loader-bar-wrap{width:140px;height:1px;background:rgba(184,151,90,0.15)}
.loader-bar{height:100%;background:linear-gradient(90deg,transparent,var(--zavall-gold),var(--zavall-gold-bright));width:0%;animation:loaderFill 1.3s var(--zavall-ease-out) .5s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@keyframes loaderFill{from{width:0}to{width:100%}}

/* ── Curtain ────────────────────────────────────────────────── */
.curtain{position:fixed;inset:0;background:var(--zavall-white);z-index:99997;transform:scaleY(1);transform-origin:bottom;transition:transform .65s cubic-bezier(.76,0,.24,1)}
.curtain.out{transform:scaleY(0);transform-origin:top}

/* ── Announcement bar ───────────────────────────────────────── */
.announcement-bar{background:var(--zavall-ink);color:var(--zavall-white);text-align:center;padding:.5rem var(--zavall-gap);font-family:var(--zavall-cond);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;position:relative;z-index:1001}

/* ── Navigation ─────────────────────────────────────────────── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:1.4rem var(--zavall-gap);background:rgba(255,255,255,0.92);backdrop-filter:blur(20px) saturate(1.5);border-bottom:1px solid var(--zavall-border);transition:all .4s var(--zavall-ease)}
.site-header.at-top{background:var(--zavall-white);box-shadow:none}
.site-header.scrolled{box-shadow:var(--zavall-shadow-sm)}

.nav-brand{font-family:var(--zavall-serif);font-size:1.55rem;font-weight:300;letter-spacing:.5em;text-transform:uppercase;color:var(--zavall-ink)}

.nav-links{display:flex;gap:2.6rem;font-family:var(--zavall-cond);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;font-weight:400}
.nav-links a{color:var(--zavall-gray-500);position:relative;padding-bottom:3px;transition:color .3s}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--zavall-ink);transition:width .45s var(--zavall-ease)}
.nav-links a:hover{color:var(--zavall-ink)}
.nav-links a:hover::after{width:100%}

.nav-right{display:flex;align-items:center;gap:2rem}
.nav-cart{display:flex;align-items:center;gap:.7rem;font-family:var(--zavall-cond);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--zavall-ink);padding:.6rem 1.4rem;border:1px solid var(--zavall-border);position:relative;overflow:hidden;transition:color .4s}
.nav-cart::before{content:'';position:absolute;inset:0;background:var(--zavall-ink);transform:translateY(101%);transition:transform .4s var(--zavall-ease)}
.nav-cart:hover{color:var(--zavall-white)}
.nav-cart:hover::before{transform:none}
.nav-cart svg,.nav-cart span{position:relative;z-index:1}

.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.nav-hamburger span{display:block;width:22px;height:1px;background:var(--zavall-ink);transition:all .3s}

/* Mobile menu */
.mobile-menu{position:fixed;inset:0;background:var(--zavall-white);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{font-family:var(--zavall-serif);font-size:clamp(1.8rem,5vw,2.8rem);font-weight:300;letter-spacing:.15em;text-transform:uppercase;color:var(--zavall-ink);transition:color .3s}
.mobile-menu a:hover{color:var(--zavall-gold)}
.mobile-menu-close{position:absolute;top:2rem;right:var(--zavall-gap);font-size:1.5rem;background:none;border:none;color:var(--zavall-gray-400);cursor:pointer}

/* ── Hero ───────────────────────────────────────────────────── */
.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:flex-end;justify-content:flex-start;padding:0 var(--zavall-gap) calc(var(--zavall-gap)*1.4);overflow:hidden;background:var(--zavall-cream)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center top;opacity:.55;transition:opacity 1.2s}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(255,255,255,0.96) 0%,rgba(255,255,255,0.3) 50%,rgba(255,255,255,0.05) 100%);z-index:1}
.hero-content{position:relative;z-index:2;max-width:700px}

.hero-pretitle{font-family:var(--zavall-cond);font-size:.72rem;letter-spacing:.55em;text-transform:uppercase;color:var(--zavall-gold);margin-bottom:1.4rem;display:flex;align-items:center;gap:1rem}
.hero-pretitle::before{content:'';display:block;width:40px;height:1px;background:var(--zavall-gold)}

.hero-title{font-family:var(--zavall-serif);font-size:clamp(3.2rem,7vw,6.5rem);font-weight:300;line-height:1.04;color:var(--zavall-ink);margin-bottom:1.6rem}
.hero-title em{font-style:italic;color:var(--zavall-gray-600)}

.hero-subtitle{font-family:var(--zavall-sans);font-size:.95rem;font-weight:300;color:var(--zavall-gray-500);max-width:420px;line-height:1.7;margin-bottom:2.4rem}

.hero-ctas{display:flex;align-items:center;gap:1.8rem;flex-wrap:wrap}

.btn-primary{display:inline-flex;align-items:center;gap:.8rem;font-family:var(--zavall-cond);font-size:.75rem;letter-spacing:.28em;text-transform:uppercase;padding:1rem 2.2rem;background:var(--zavall-ink);color:var(--zavall-white);position:relative;overflow:hidden;transition:color .4s}
.btn-primary::before{content:'';position:absolute;inset:0;background:var(--zavall-gold);transform:translateX(-101%);transition:transform .4s var(--zavall-ease)}
.btn-primary:hover{color:var(--zavall-ink)}
.btn-primary:hover::before{transform:none}
.btn-primary span,.btn-primary svg{position:relative;z-index:1}

.btn-ghost{font-family:var(--zavall-cond);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--zavall-gray-500);display:flex;align-items:center;gap:.6rem;transition:color .3s}
.btn-ghost:hover{color:var(--zavall-ink)}
.btn-ghost svg{transition:transform .3s}
.btn-ghost:hover svg{transform:translateX(4px)}

.hero-scroll-hint{position:absolute;bottom:3rem;right:var(--zavall-gap);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.7rem;font-family:var(--zavall-cond);font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:var(--zavall-gray-400)}
.hero-scroll-line{width:1px;height:60px;background:linear-gradient(to bottom,var(--zavall-gold),transparent);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.4}50%{opacity:1}}

/* ── Sections shared ────────────────────────────────────────── */
section{padding:clamp(4rem,8vw,8rem) var(--zavall-gap)}
.section-label{font-family:var(--zavall-cond);font-size:.65rem;letter-spacing:.55em;text-transform:uppercase;color:var(--zavall-gold);margin-bottom:1rem;display:flex;align-items:center;gap:1.2rem}
.section-label::before{content:'';display:inline-block;width:30px;height:1px;background:var(--zavall-gold)}
.section-title{font-family:var(--zavall-serif);font-size:clamp(2.2rem,4vw,3.5rem);font-weight:300;color:var(--zavall-ink);line-height:1.1;margin-bottom:1.2rem}
.section-sub{font-size:.92rem;color:var(--zavall-gray-500);max-width:520px;line-height:1.75}

/* ── Fade-up ────────────────────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .8s var(--zavall-ease-out),transform .8s var(--zavall-ease-out)}
.fade-up.vis{opacity:1;transform:none}
.fade-up:nth-child(2){transition-delay:.1s}.fade-up:nth-child(3){transition-delay:.2s}.fade-up:nth-child(4){transition-delay:.3s}

/* ── Ticker ─────────────────────────────────────────────────── */
.ticker{overflow:hidden;border-top:1px solid var(--zavall-border);border-bottom:1px solid var(--zavall-border);padding:1.1rem 0;background:var(--zavall-white)}
.ticker-track{display:flex;gap:0;white-space:nowrap;animation:tickerRoll 22s linear infinite}
@keyframes tickerRoll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-item{font-family:var(--zavall-cond);font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;color:var(--zavall-gray-400);padding:0 2.5rem;display:flex;align-items:center;gap:2.5rem}
.ticker-item::after{content:'✦';color:var(--zavall-gold);font-size:.5rem}
.ticker:hover .ticker-track{animation-play-state:paused}

/* ── Products grid ──────────────────────────────────────────── */
.products-section{background:var(--zavall-off-white)}
.products-section__head{padding:0 var(--zavall-gap) 2.5rem}
.products-section__title-row{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;margin-bottom:2rem}
.products-empty{color:var(--zavall-gray-400);padding:3rem var(--zavall-gap);font-family:var(--zavall-cond);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase}

.cat-tabs{display:flex;gap:0;border-bottom:1px solid var(--zavall-border);margin-bottom:3rem;flex-wrap:wrap}
.cat-tab{font-family:var(--zavall-cond);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;padding:.9rem 1.8rem;border:none;background:none;color:var(--zavall-gray-400);cursor:pointer;position:relative;transition:color .3s}
.cat-tab::after{content:'';position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--zavall-ink);transition:width .4s var(--zavall-ease)}
.cat-tab.active,.cat-tab[aria-selected="true"]{color:var(--zavall-ink)}
.cat-tab.active::after,.cat-tab[aria-selected="true"]::after{width:100%}

.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1px;background:var(--zavall-border)}
.p-card{background:var(--zavall-white);position:relative;overflow:hidden}
.p-card-img-wrap{aspect-ratio:3/4;overflow:hidden;position:relative;background:var(--zavall-cream)}
.p-card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--zavall-ease)}
.p-card-img-placeholder{aspect-ratio:3/4;background:var(--zavall-pearl);display:flex;align-items:center;justify-content:center}
.p-card:hover .p-card-img-wrap img{transform:scale(1.04)}

.p-card-badge{position:absolute;top:1rem;left:1rem;font-family:var(--zavall-cond);font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;padding:.3rem .8rem}
.badge-new{background:var(--zavall-ink);color:var(--zavall-white)}
.badge-ltd{background:var(--zavall-gold);color:var(--zavall-white)}
.badge-sale{background:var(--zavall-red,#c0392b);color:var(--zavall-white)}

.p-card-body{padding:1.4rem 1.4rem 1.8rem}
.p-card-cat{font-family:var(--zavall-cond);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--zavall-gold);margin-bottom:.5rem}
.p-card-name{font-family:var(--zavall-serif);font-size:1.3rem;font-weight:300;color:var(--zavall-ink);margin-bottom:.8rem;line-height:1.2}

.p-card-sizes{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}
.p-card-size{font-family:var(--zavall-cond);font-size:.62rem;letter-spacing:.15em;padding:.3rem .65rem;border:1px solid var(--zavall-border);color:var(--zavall-gray-400);cursor:pointer;transition:all .25s;background:none}
.p-card-size:hover{border-color:var(--zavall-gray-400);color:var(--zavall-ink)}
.p-card-size.sel{border-color:var(--zavall-ink);color:var(--zavall-ink)}

.p-card-bottom{display:flex;align-items:center;justify-content:space-between}
.p-card-price{font-family:var(--zavall-serif);font-size:1.4rem;color:var(--zavall-ink)}
.p-card-price del{font-size:.9rem;color:var(--zavall-gray-400)}
.p-card-view{font-family:var(--zavall-cond);font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;padding:.7rem 1.4rem;border:1px solid var(--zavall-border);color:var(--zavall-ink);cursor:pointer;background:none;transition:all .3s;position:relative;overflow:hidden}
.p-card-view::before{content:'';position:absolute;inset:0;background:var(--zavall-ink);transform:translateX(-101%);transition:transform .4s var(--zavall-ease)}
.p-card-view:hover{color:var(--zavall-white)}
.p-card-view:hover::before{transform:none}
.p-card-view span{position:relative;z-index:1}

/* ── HOODIE MOCKUP SECTION ──────────────────────────────────── */
.hoodie-section{background:var(--zavall-white);padding:clamp(4rem,8vw,8rem) 0}
.hoodie-header{padding:0 var(--zavall-gap) 3rem}
.hoodie-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;padding:0 var(--zavall-gap)}
.hoodie-card{position:relative;overflow:hidden;cursor:pointer;background:var(--zavall-cream)}
.hoodie-card-inner{aspect-ratio:4/5;position:relative;overflow:hidden}
.hoodie-mockup{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--zavall-ease)}
.hoodie-card:hover .hoodie-mockup{transform:scale(1.03)}
.hoodie-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(255,255,255,0.88) 0%,transparent 50%);opacity:0;transition:opacity .4s}
.hoodie-card:hover .hoodie-overlay{opacity:1}
.hoodie-info{position:absolute;bottom:0;left:0;right:0;padding:2rem;transform:translateY(12px);opacity:0;transition:all .4s var(--zavall-ease)}
.hoodie-card:hover .hoodie-info{transform:none;opacity:1}
.hoodie-name{font-family:var(--zavall-serif);font-size:1.4rem;font-weight:300;color:var(--zavall-ink);margin-bottom:.4rem}
.hoodie-colorway{font-family:var(--zavall-cond);font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--zavall-gold)}
.hoodie-price{font-family:var(--zavall-serif);font-size:1.1rem;color:var(--zavall-gray-600);margin-top:.3rem}
.hoodie-colors{display:flex;gap:.5rem;margin-top:.8rem}
.hoodie-swatch{width:18px;height:18px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color .2s}
.hoodie-swatch.active{border-color:var(--zavall-ink)}
.hoodie-cta{margin-top:.8rem;display:inline-flex;align-items:center;gap:.5rem;font-family:var(--zavall-cond);font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--zavall-ink);padding:.6rem 1.2rem;border:1px solid var(--zavall-ink);transition:all .3s}
.hoodie-cta:hover{background:var(--zavall-ink);color:var(--zavall-white)}

/* Hoodie mockup SVG placeholders */
.hoodie-svg-wrap{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--zavall-pearl)}
.hoodie-svg-wrap svg{width:65%;height:65%;opacity:.85}

/* ── Lookbook ───────────────────────────────────────────────── */
.lookbook-section{background:var(--zavall-white);padding:clamp(4rem,8vw,8rem) 0}
.lookbook-header{padding:0 var(--zavall-gap) 3rem}
.lb-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:2px;padding:0 var(--zavall-gap)}
.lb-item{overflow:hidden;position:relative;background:var(--zavall-cream);opacity:0;transition:opacity .9s var(--zavall-ease-out),transform .9s var(--zavall-ease-out)}
.lb-item.vis{opacity:1;transform:none!important}
.lb-item:nth-child(1){grid-column:span 7;grid-row:span 2;transform:translateY(40px)}
.lb-item:nth-child(2){grid-column:span 5;transform:translateX(30px)}
.lb-item:nth-child(3){grid-column:span 5;transform:translateX(30px) translateY(20px)}
.lb-item img{width:100%;height:100%;object-fit:cover;min-height:260px;transition:transform .9s var(--zavall-ease)}
.lb-item:hover img{transform:scale(1.04)}
.lb-caption{position:absolute;bottom:0;left:0;right:0;padding:1.4rem 1.6rem;background:linear-gradient(to top,rgba(255,255,255,0.9),transparent);opacity:0;transform:translateY(8px);transition:opacity .4s,transform .4s}
.lb-item:hover .lb-caption{opacity:1;transform:none}
.lb-cap-name{font-family:var(--zavall-serif);font-size:1.1rem;color:var(--zavall-ink);margin-bottom:.2rem}
.lb-cap-tag{font-family:var(--zavall-cond);font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--zavall-gold)}

/* ── Horizontal scroll ──────────────────────────────────────── */
.horiz-section{height:300vh;position:relative}
.horiz-sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center}
.horiz-track{display:flex;gap:2px;will-change:transform}
.horiz-progress{position:absolute;bottom:2.5rem;left:var(--zavall-gap);right:var(--zavall-gap);height:1px;background:var(--zavall-border)}
.horiz-fill{height:100%;background:linear-gradient(90deg,var(--zavall-gold),var(--zavall-gold-bright));width:0%;transition:width .1s linear}
.h-card{width:min(380px,80vw);height:60vh;min-height:420px;flex-shrink:0;position:relative;overflow:hidden;background:var(--zavall-pearl)}
.h-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--zavall-ease)}
.h-card:hover img{transform:scale(1.04)}
.h-card-label{position:absolute;bottom:1.5rem;left:1.5rem;right:1.5rem}
.h-card-name{font-family:var(--zavall-serif);font-size:1.4rem;color:var(--zavall-ink);margin-bottom:.3rem}
.h-card-info{font-family:var(--zavall-cond);font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--zavall-gold)}

/* ── Countdown ──────────────────────────────────────────────── */
.countdown-section{background:var(--zavall-ink);text-align:center}
.countdown-section .section-title{color:var(--zavall-white)}
.cd-label{font-family:var(--zavall-cond);font-size:.68rem;letter-spacing:.55em;text-transform:uppercase;color:var(--zavall-gold);margin-bottom:2.5rem}
.cd-units{display:flex;justify-content:center;align-items:flex-start;gap:clamp(1rem,3vw,3rem)}
.cd-unit{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.cd-digit{font-family:var(--zavall-serif);font-size:clamp(3rem,8vw,6rem);font-weight:300;color:var(--zavall-white);line-height:1;min-width:1.5em;text-align:center}
.cd-digit.flip{animation:digitFlip .25s ease forwards}
@keyframes digitFlip{0%{transform:rotateX(-90deg);opacity:0}100%{transform:none;opacity:1}}
.cd-sep{font-family:var(--zavall-serif);font-size:clamp(3rem,8vw,6rem);color:var(--zavall-gold);opacity:.4;line-height:1;padding-top:.1rem}
.cd-unit-label{font-family:var(--zavall-cond);font-size:.58rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,0.4)}

/* ── Testimonials ───────────────────────────────────────────── */
.testi-section{background:var(--zavall-cream)}
.testi-wrap{max-width:720px;margin:0 auto;text-align:center;position:relative}
.testi-item{opacity:0;position:absolute;top:0;left:0;right:0;transition:opacity .6s}
.testi-item.on{opacity:1;position:relative}
.testi-quote{font-family:var(--zavall-serif);font-size:clamp(1.3rem,2.5vw,2rem);font-weight:300;font-style:italic;color:var(--zavall-ink);line-height:1.55;margin-bottom:2rem}
.testi-author{font-family:var(--zavall-cond);font-size:.68rem;letter-spacing:.35em;text-transform:uppercase;color:var(--zavall-gold)}
.testi-role{color:var(--zavall-gray-500);margin-top:.25rem;font-size:.8rem}
.t-dots{display:flex;justify-content:center;gap:.6rem;margin-top:2.5rem}
.t-dot{width:5px;height:5px;border-radius:50%;background:var(--zavall-gray-200);cursor:pointer;transition:all .3s;border:none;padding:0}
.t-dot.on{background:var(--zavall-ink);width:20px;border-radius:3px}

/* ── Newsletter ─────────────────────────────────────────────── */
.newsletter-section{background:var(--zavall-white);border-top:1px solid var(--zavall-border)}
.nl-inner{max-width:560px;margin:0 auto;text-align:center}
.nl-form{display:flex;gap:0;margin-top:2.5rem;border:1px solid var(--zavall-border)}
.nl-input{flex:1;background:none;border:none;outline:none;padding:1rem 1.4rem;color:var(--zavall-ink);font-family:var(--zavall-cond);font-size:.75rem;letter-spacing:.15em}
.nl-input::placeholder{color:var(--zavall-gray-400)}
.nl-btn{font-family:var(--zavall-cond);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;padding:1rem 1.8rem;background:var(--zavall-ink);color:var(--zavall-white);border:none;cursor:pointer;transition:background .3s}
.nl-btn:hover{background:var(--zavall-gold)}

/* ── Footer ─────────────────────────────────────────────────── */
.site-footer{background:var(--zavall-cream);border-top:1px solid var(--zavall-border);padding:clamp(3rem,6vw,6rem) var(--zavall-gap) 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand-name{font-family:var(--zavall-serif);font-size:1.8rem;font-weight:300;letter-spacing:.4em;text-transform:uppercase;color:var(--zavall-ink);margin-bottom:.8rem}
.footer-brand-statement{font-size:.88rem;color:var(--zavall-gray-500);line-height:1.7;max-width:280px;margin-bottom:1.5rem}
.footer-social{display:flex;gap:1rem;flex-wrap:wrap}
.footer-social a{font-family:var(--zavall-cond);font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--zavall-gray-500);transition:color .3s}
.footer-social a:hover{color:var(--zavall-gold)}
.footer-col-title{font-family:var(--zavall-cond);font-size:.68rem;letter-spacing:.35em;text-transform:uppercase;color:var(--zavall-ink);margin-bottom:1.4rem}
.footer-col a{display:block;font-size:.85rem;color:var(--zavall-gray-500);margin-bottom:.7rem;transition:color .3s}
.footer-col a:hover{color:var(--zavall-gold)}
.footer-bottom{border-top:1px solid var(--zavall-border);padding-top:1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-copy{font-family:var(--zavall-cond);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--zavall-gray-400)}
.footer-legal{display:flex;gap:1.5rem}
.footer-legal a{font-family:var(--zavall-cond);font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--zavall-gray-400);transition:color .3s}
.footer-legal a:hover{color:var(--zavall-gold)}

/* ── Breadcrumbs ────────────────────────────────────────────── */
.zavall-breadcrumbs{font-family:var(--zavall-cond);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--zavall-gray-400);margin-bottom:2rem}
.zavall-breadcrumbs a{color:var(--zavall-gray-400);transition:color .3s}
.zavall-breadcrumbs a:hover{color:var(--zavall-gold)}

/* ── WooCommerce overrides ──────────────────────────────────── */
.woocommerce .woocommerce-notices-wrapper{padding:0 var(--zavall-gap)}
.woocommerce .entry-title,.woocommerce-page .entry-title{font-family:var(--zavall-serif);color:var(--zavall-ink)}
.woocommerce button.button,.woocommerce a.button,.woocommerce input.button{background:var(--zavall-ink);color:var(--zavall-white);font-family:var(--zavall-cond);letter-spacing:.2em;text-transform:uppercase;border:none;border-radius:0;padding:.9rem 2rem;transition:background .3s}
.woocommerce button.button:hover,.woocommerce a.button:hover{background:var(--zavall-gold);color:var(--zavall-white)}
.woocommerce .star-rating span::before{color:var(--zavall-gold)}
.woocommerce .price{color:var(--zavall-ink);font-family:var(--zavall-serif)}

/* ── Split text / marquee utils ────────────────────────────── */
.sw{display:inline-block;overflow:hidden;vertical-align:bottom}
.sw-inner{display:inline-block;transform:translateY(110%);will-change:transform;transition:none}

/* ── Responsive ─────────────────────────────────────────────── */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .lb-grid{grid-template-columns:1fr 1fr}
  .lb-item:nth-child(1){grid-column:span 2;grid-row:span 1}
  .lb-item:nth-child(2),.lb-item:nth-child(3){grid-column:span 1}
  .hoodie-grid{grid-template-columns:repeat(2,1fr)}
  .hoodie-grid .hoodie-card:last-child{grid-column:span 2}
}
@media(max-width:768px){
  .nav-links,.nav-right{display:none}
  .nav-hamburger{display:flex}
  .footer-grid{grid-template-columns:1fr}
  .cd-sep{display:none}
  .nl-form{flex-direction:column}
  .lb-grid{grid-template-columns:1fr}
  .lb-item:nth-child(1){grid-column:span 1}
  .horiz-section{height:auto}
  .horiz-sticky{position:relative;height:auto;overflow-x:auto}
  .horiz-track{transform:none!important;padding:0 var(--zavall-gap)}
  .cursor-dot,.cursor-ring{display:none}
  body{cursor:auto}
  .hoodie-grid{grid-template-columns:1fr}
  .hoodie-grid .hoodie-card:last-child{grid-column:span 1}
}
@media(max-width:480px){
  .hero-ctas{flex-direction:column;align-items:flex-start}
  .products-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── Print ──────────────────────────────────────────────────── */
@media print{
  .cursor-dot,.cursor-ring,.loader,.curtain,.scroll-bar,.ticker,.site-header,.mobile-menu{display:none!important}
  body{background:#fff;color:#000;cursor:auto}
}
