/* ============================================================
   B'ris Royale — Main Stylesheet
   ============================================================ */

/* --- Reset & Custom Properties --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --gold:#C6A15B;
  --gold-light:#dfc07a;
  --gold-dim:rgba(198,161,91,.15);
  --white:#fff;
  --black:#000;
  --g9:#080808;
  --g8:#111;
  --g7:#181818;
  --g6:#222;
  --g5:#333;
  --brand:'Barlow Condensed',sans-serif;
  --body:'Barlow',sans-serif;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --spring:cubic-bezier(.34,1.56,.64,1);
}

html{scroll-behavior:smooth;overflow-x:hidden}
body{background:#000;color:#fff;font-family:var(--body);cursor:none;overflow-x:hidden}

/* --- Custom Cursor --- */
#cur{position:fixed;width:8px;height:8px;background:#fff;border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s var(--spring),height .3s var(--spring),background .3s;mix-blend-mode:difference}
#curR{position:fixed;width:36px;height:36px;border:1px solid rgba(198,161,91,.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .4s var(--spring),height .4s var(--spring),border-color .3s}
#cur.h{width:20px;height:20px;background:var(--gold)}
#curR.h{width:56px;height:56px;border-color:var(--gold)}

/* --- Page Routing --- */
.page{display:none;min-height:100vh}
.page.active{display:block}

/* --- Page Transition Veil --- */
#veil{position:fixed;inset:0;background:#000;z-index:2000;pointer-events:none;clip-path:inset(100% 0 0 0)}
#veil.in{animation:veilIn .45s var(--ease) forwards}
#veil.out{animation:veilOut .45s var(--ease) forwards}
@keyframes veilIn{from{clip-path:inset(100% 0 0 0)}to{clip-path:inset(0% 0 0 0)}}
@keyframes veilOut{from{clip-path:inset(0% 0 0 0)}to{clip-path:inset(0 0 100% 0)}}

/* --- Navigation --- */
nav{position:fixed;top:0;left:0;right:0;z-index:500;display:flex;align-items:center;justify-content:space-between;padding:1.4rem 3rem;background:linear-gradient(to bottom,rgba(0,0,0,.95),transparent)}
.nav-logo-img{height:36px;width:auto;display:block;filter:brightness(0)invert(1);}
.nav-links{display:flex;gap:2.5rem;align-items:center}
.nav-links a{font-family:var(--brand);font-size:.85rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.55);text-decoration:none;transition:color .3s;cursor:none}
.nav-links a:hover{color:var(--gold)}
.nav-cart-wrap{position:relative}
.cart-badge{position:absolute;top:-8px;right:-12px;width:15px;height:15px;background:var(--gold);border-radius:50%;font-size:.5rem;display:flex;align-items:center;justify-content:center;color:#000;font-weight:700}

/* --- Hero Section --- */
.hero{position:relative;height:100vh;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}
.hero-canvas{position:absolute;inset:0;z-index:0;width:100%;height:100%}
.hero-radial{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 90%,rgba(198,161,91,.06) 0%,transparent 65%);z-index:1}
.hero-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}
.hero-eyebrow{font-family:var(--brand);font-size:.75rem;font-weight:400;letter-spacing:.5em;text-transform:uppercase;color:var(--gold);margin-bottom:2.5rem;opacity:0;animation:fadeUp .7s var(--ease) .2s forwards}
.hero-logo-wrap{margin-bottom:2rem;opacity:0;animation:fadeUp .9s var(--ease) .4s forwards}
.hero-logo-wrap img{width:min(560px,80vw);height:auto;filter:brightness(0) invert(1)}
.hero-tagline{font-family:var(--brand);font-size:clamp(1rem,2.5vw,1.3rem);font-weight:300;letter-spacing:.5em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:3.5rem;opacity:0;animation:fadeUp .7s var(--ease) .7s forwards}
.hero-cta{font-family:var(--brand);font-size:.82rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;padding:.85rem 2.8rem;border:1px solid rgba(198,161,91,.4);color:var(--gold);text-decoration:none;position:relative;overflow:hidden;transition:color .4s,border-color .4s;cursor:none;opacity:0;animation:fadeUp .7s var(--ease) .9s forwards;display:inline-block}
.hero-cta::before{content:'';position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.hero-cta:hover::before{transform:scaleX(1)}
.hero-cta:hover{color:#000;border-color:var(--gold)}
.hero-cta span{position:relative;z-index:1}
.scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;opacity:0;animation:fadeUp .5s var(--ease) 1.2s forwards;display:flex;flex-direction:column;align-items:center;gap:.6rem}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,transparent,var(--gold));animation:pulse 2s ease-in-out infinite}
.scroll-txt{font-family:var(--brand);font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:rgba(255,255,255,.25)}

@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:.9}}

/* --- Shared Section Labels --- */
.sec-label{font-family:var(--brand);font-size:.68rem;font-weight:500;letter-spacing:.45em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.sec-title{font-family:var(--brand);font-weight:900;font-style:italic;text-transform:uppercase;line-height:.95;letter-spacing:-.01em}

/* --- Featured Grid --- */
.featured{padding:7rem 0;background:#000}
.featured-inner{max-width:1440px;margin:0 auto;padding:0 3rem}
.featured-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem}
.featured-top-title{font-family:var(--brand);font-size:clamp(2rem,4vw,3.5rem);font-weight:900;font-style:italic;text-transform:uppercase;line-height:1}
.see-all{font-family:var(--brand);font-size:.72rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.3);text-decoration:none;transition:color .3s;cursor:none}
.see-all:hover{color:var(--gold)}
.feat-grid{display:grid;grid-template-columns:5fr 3fr 4fr;gap:2px}
.feat-item{position:relative;overflow:hidden;cursor:none}
.feat-item:nth-child(1){grid-row:span 2}
.feat-bg{position:absolute;inset:0;transition:transform .9s var(--ease)}
.feat-item:hover .feat-bg{transform:scale(1.06)}
.feat-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.1) 55%,transparent 100%)}
.feat-visual{min-height:420px;position:relative}
.feat-img{width:100%;justify-self:center;align-self:center;}
.feat-item:nth-child(1){min-height:640px}
.feat-body{position:absolute;bottom:0;left:0;right:0;padding:2rem;transform:translateY(12px);transition:transform .5s var(--ease)}
.feat-item:hover .feat-body{transform:translateY(0)}
.feat-num{font-family:var(--brand);font-size:.6rem;letter-spacing:.35em;color:var(--gold);margin-bottom:.4rem}
.feat-name{font-family:var(--brand);font-size:clamp(1.4rem,2.5vw,2.2rem);font-weight:900;font-style:italic;text-transform:uppercase;line-height:1;margin-bottom:.4rem}
.feat-sub{font-family:var(--brand);font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.4);opacity:0;transform:translateY(8px);transition:opacity .35s .1s,transform .35s .1s}
.feat-item:hover .feat-sub{opacity:1;transform:translateY(0)}
.feat-btn{display:inline-block;margin-top:.9rem;padding:.4rem 1.1rem;border:1px solid rgba(198,161,91,.35);font-family:var(--brand);font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);opacity:0;transform:translateY(8px);transition:opacity .35s .15s,transform .35s .15s,background .3s,color .3s}
.feat-item:hover .feat-btn{opacity:1;transform:translateY(0)}
.feat-btn:hover{background:var(--gold);color:#000}

/* --- Fragrance Colour Variants --- */
.v-amber{background:radial-gradient(ellipse at 35% 65%,#5c2200 0%,#1a0800 50%,#000 100%)}
.v-noir{background:radial-gradient(ellipse at 55% 45%,#0e0925 0%,#05031a 50%,#000 100%)}
.v-rose{background:radial-gradient(ellipse at 50% 60%,#3a0818 0%,#150208 50%,#000 100%)}
.v-oud{background:radial-gradient(ellipse at 40% 55%,#2a1400 0%,#100800 60%,#000 100%)}
.v-smoke{background:radial-gradient(ellipse at 50% 50%,#0d0c0a 0%,#050505 60%,#000 100%)}
.v-blue{background:radial-gradient(ellipse at 50% 50%,#040d2a 0%,#010510 60%,#000 100%)}

/* --- Marquee --- */
.marquee-wrap{overflow:hidden;padding:4rem 0;background:#050505;border-top:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.04)}
.marquee-track{display:flex;width:max-content;animation:marquee 22s linear infinite}
.marquee-item{font-family:var(--brand);font-size:clamp(1.8rem,3vw,2.8rem);font-weight:900;font-style:italic;text-transform:uppercase;color:rgba(255,255,255,.07);padding:0 2.5rem;white-space:nowrap}
.marquee-sep{color:var(--gold);align-self:center;font-size:.7rem;padding:0 .5rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* --- Story Section --- */
.story{padding:10rem 0;background:#000}
.story-inner{max-width:960px;margin:0 auto;padding:0 3rem;text-align:center}
.story-headline{font-family:var(--brand);font-size:clamp(2.5rem,7vw,7rem);font-weight:900;font-style:italic;text-transform:uppercase;line-height:.92;margin-bottom:2.5rem}
.story-headline .gold{color:var(--gold)}
.story-body{font-family:var(--body);font-size:1rem;font-weight:200;line-height:2;color:rgba(255,255,255,.5);max-width:560px;margin:0 auto 3.5rem}
.gold-rule{width:50px;height:1px;background:var(--gold);margin:2.5rem auto}
.story-quote{font-family:var(--brand);font-size:clamp(1rem,2.5vw,1.6rem);font-weight:300;font-style:italic;color:rgba(255,255,255,.3);line-height:1.5}

/* --- Scroll Reveal --- */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.vis{opacity:1;transform:translateY(0)}

/* --- Product Page --- */
.prod-hero{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
.prod-vis{background:var(--g9);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.prod-vis::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(198,161,91,.07) 0%,transparent 65%);pointer-events:none}
.bottle-svg{width:200px;filter:drop-shadow(0 0 50px rgba(198,161,91,.18));transition:filter .6s,transform .9s var(--spring)}
.prod-vis:hover .bottle-svg{filter:drop-shadow(0 0 90px rgba(198,161,91,.38));transform:scale(1.04) rotate(-2.5deg)}
.prod-info{padding:7rem 4rem 4rem 5rem;display:flex;flex-direction:column;justify-content:center;background:#000}
.prod-coll{font-family:var(--brand);font-size:.65rem;font-weight:500;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem}
.prod-name{font-family:var(--brand);font-size:clamp(3rem,6vw,6rem);font-weight:900;font-style:italic;text-transform:uppercase;line-height:.9;margin-bottom:1.5rem}
.prod-tag{font-family:var(--body);font-size:.9rem;font-weight:200;line-height:1.85;color:rgba(255,255,255,.45);max-width:360px;margin-bottom:3rem}
.prod-price{font-family:var(--brand);font-size:2.5rem;font-weight:900;font-style:italic;color:var(--gold);margin-bottom:.4rem}
.size-note{font-family:var(--brand);font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:2rem}
.sizes{display:flex;gap:.6rem;margin-bottom:2.5rem}
.sz{font-family:var(--brand);font-size:.78rem;font-weight:700;letter-spacing:.15em;padding:.5rem 1.2rem;border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.4);cursor:none;transition:border-color .3s,color .3s,background .3s}
.sz.on,.sz:hover{border-color:var(--gold);color:var(--gold)}
.atc{width:100%;padding:1.1rem;background:var(--gold);font-family:var(--brand);font-size:.85rem;font-weight:900;letter-spacing:.3em;text-transform:uppercase;color:#000;border:none;cursor:none;position:relative;overflow:hidden;transition:transform .3s var(--spring)}
.atc:hover{transform:scale(1.02)}
.atc::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.18);transform:translateX(-110%);transition:transform .45s var(--ease)}
.atc:hover::after{transform:translateX(110%)}
.perks{display:flex;gap:2rem;margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.05)}
.perk{font-family:var(--brand);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.2)}

/* --- Editorial Sections --- */
.editorial{padding:9rem 0;overflow:hidden}
.ed-grid{display:grid;grid-template-columns:1fr 1fr;max-width:1440px;margin:0 auto}
.ed-text{padding:6rem 5rem;display:flex;flex-direction:column;justify-content:center}
.ed-vis{min-height:580px;position:relative;overflow:hidden}
.ed-num{font-family:var(--brand);font-size:.6rem;letter-spacing:.45em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem}
.ed-head{font-family:var(--brand);font-size:clamp(2rem,4vw,4rem);font-weight:900;font-style:italic;text-transform:uppercase;line-height:.95;margin-bottom:2rem}
.ed-copy{font-family:var(--body);font-size:.9rem;font-weight:200;line-height:1.95;color:rgba(255,255,255,.45);max-width:380px}
.ed-copy em{color:rgba(255,255,255,.75);font-style:normal}
.ghost-word{position:absolute;font-family:var(--brand);font-weight:900;font-style:italic;text-transform:uppercase;font-size:8rem;color:rgba(198,161,91,.05);line-height:1;pointer-events:none;white-space:nowrap}

/* --- Notes / Bars --- */
.notes{padding:8rem 4rem;background:#050505}
.notes-inner{max-width:1200px;margin:0 auto}
.notes-hd{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:5rem}
.notes-hed{font-family:var(--brand);font-size:clamp(2.5rem,5vw,5rem);font-weight:900;font-style:italic;text-transform:uppercase;line-height:.95}
.notes-intro{font-family:var(--body);font-size:.8rem;font-weight:200;color:rgba(255,255,255,.35);line-height:1.8;max-width:260px;text-align:right}
.bars{display:flex;gap:2px;height:260px;align-items:flex-end}
.bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:.8rem;cursor:none}
.bar{width:100%;background:rgba(198,161,91,.18);border-top:2px solid rgba(198,161,91,.4);transition:background .3s,border-color .3s}
.bar-wrap:hover .bar{background:rgba(198,161,91,.55);border-color:var(--gold)}
.bar-lbl{font-family:var(--brand);font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3);writing-mode:vertical-rl;transform:rotate(180deg);height:56px;display:flex;align-items:center;transition:color .3s}
.bar-wrap:hover .bar-lbl{color:var(--gold)}

/* --- Accordion --- */
.accord{margin-top:4rem}
.ac-item{border-top:1px solid rgba(255,255,255,.06);padding:1.8rem 0;cursor:none}
.ac-hd{display:flex;justify-content:space-between;align-items:center}
.ac-lbl{font-family:var(--brand);font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:.3rem}
.ac-name{font-family:var(--brand);font-size:clamp(1.2rem,2.5vw,2.2rem);font-weight:900;font-style:italic;text-transform:uppercase;transition:color .3s}
.ac-item:hover .ac-name{color:var(--gold)}
.ac-arrow{width:26px;height:26px;border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;transition:transform .4s var(--spring),background .3s,border-color .3s}
.ac-item:hover .ac-arrow{transform:rotate(45deg);background:var(--gold);border-color:var(--gold);color:#000}
.ac-body{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.ac-item.open .ac-body{max-height:160px}
.ac-body p{font-family:var(--body);padding:.5rem 0 1.2rem;font-size:.85rem;font-weight:200;color:rgba(255,255,255,.45);line-height:1.95;max-width:560px}

/* --- Collection Page --- */
.coll-hd{padding:5rem 4rem 2rem;max-width:1440px;margin:0 auto}
.coll-title{font-family:var(--brand);font-size:clamp(4rem,10vw,10rem);font-weight:900;font-style:italic;text-transform:uppercase;line-height:.85;margin-bottom:1rem}
.coll-sub{font-family:var(--brand);font-size:.72rem;letter-spacing:.35em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:2.5rem}
.filters{display:flex;gap:2.5rem;border-bottom:1px solid rgba(255,255,255,.06);padding-bottom:1.8rem}
.f-btn{font-family:var(--brand);font-size:.7rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.3);background:none;border:none;cursor:none;transition:color .3s;padding:.3rem 0;position:relative}
.f-btn.on,.f-btn:hover{color:var(--gold)}
.f-btn.on::after{content:'';position:absolute;bottom:-1.85rem;left:0;right:0;height:1px;background:var(--gold)}
.coll-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:2px;padding:3rem 4rem;max-width:1440px;margin:0 auto}
.ci{position:relative;overflow:hidden;cursor:none}
.ci:nth-child(1){grid-column:span 5;grid-row:span 2}
.ci:nth-child(2){grid-column:span 4}
.ci:nth-child(3){grid-column:span 3}
.ci:nth-child(4){grid-column:span 4}
.ci:nth-child(5){grid-column:span 3}
.ci:nth-child(6){grid-column:span 5}
.ci-bg{width:100%;height:100%;min-height:280px;display:grid;transition:transform .7s var(--ease)}
.ci:hover .ci-bg{transform:scale(1.05)}
.ci-reveal{position:absolute;inset:0;background:rgba(0,0,0,.8);opacity:0;transition:opacity .4s;display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem}
.ci:hover .ci-reveal{opacity:1}
.ci-num{font-family:var(--brand);font-size:.55rem;letter-spacing:.3em;color:var(--gold);margin-bottom:.3rem}
.ci-name{font-family:var(--brand);font-size:1.4rem;font-weight:900;font-style:italic;text-transform:uppercase;line-height:1;margin-bottom:.3rem}
.ci-price{font-family:var(--brand);font-size:.7rem;letter-spacing:.15em;color:rgba(255,255,255,.4)}
.ci-glow{position:absolute;inset:-60%;background:radial-gradient(circle,rgba(198,161,91,.12) 0%,transparent 60%);opacity:0;transition:opacity .5s;pointer-events:none}
.ci:hover .ci-glow{opacity:1}

/* --- About Page --- */
.about-hero{height:100vh;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem;overflow:hidden}
.about-hero-logo{width:min(420px,70vw);margin-bottom:2.5rem;filter:brightness(0) invert(1);opacity:.12}
.about-hl{font-family:var(--brand);font-size:clamp(3rem,8vw,8rem);font-weight:900;font-style:italic;text-transform:uppercase;line-height:.88;position:relative;z-index:1}
.about-hl .gold{color:var(--gold)}
.about-intro{font-family:var(--body);font-size:1rem;font-weight:200;color:rgba(255,255,255,.35);max-width:480px;line-height:1.95;margin-top:2.5rem;position:relative;z-index:1}
.orb{position:absolute;border-radius:50%;filter:blur(70px);pointer-events:none;animation:floatOrb linear infinite}
@keyframes floatOrb{0%{transform:translate(0,0)}33%{transform:translate(25px,-18px)}66%{transform:translate(-18px,12px)}100%{transform:translate(0,0)}}
.about-blocks{padding:6rem 0}
.ab{display:grid;grid-template-columns:1fr 1fr;min-height:55vh}
.ab:nth-child(even){direction:rtl}
.ab:nth-child(even)>*{direction:ltr}
.ab-vis{min-height:420px;position:relative;overflow:hidden}
.ab-txt{padding:5rem 4rem;display:flex;flex-direction:column;justify-content:center;background:#000}
.ab-num{font-family:var(--brand);font-size:6rem;font-weight:900;font-style:italic;text-transform:uppercase;color:rgba(255,255,255,.03);line-height:1;margin-bottom:-1.5rem}
.ab-lbl{font-family:var(--brand);font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem}
.ab-head{font-family:var(--brand);font-size:clamp(1.5rem,3vw,3rem);font-weight:900;font-style:italic;text-transform:uppercase;line-height:.95;margin-bottom:1.5rem}
.ab-copy{font-family:var(--body);font-size:.88rem;font-weight:200;line-height:1.95;color:rgba(255,255,255,.4);max-width:360px}

/* --- Cart Page --- */
.cart-wrap{display:grid;grid-template-columns:1fr 380px;gap:0;max-width:1440px;margin:0 auto;padding:5rem 4rem}
.cart-lft{padding-right:5rem}
.cart-hed{font-family:var(--brand);font-size:clamp(2.5rem,6vw,6rem);font-weight:900;font-style:italic;text-transform:uppercase;line-height:.9;margin-bottom:.5rem}
.cart-sub{font-family:var(--brand);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:3.5rem}
.cart-item{display:grid;grid-template-columns:88px 1fr auto;gap:1.2rem;padding:1.8rem 0;border-top:1px solid rgba(255,255,255,.06);align-items:center}
.ci-thumb{height:88px;border-radius:2px;overflow:hidden}
.ci-thumb-bg{width:100%;height:100%;transition:transform .4s}
.cart-item:hover .ci-thumb-bg{transform:scale(1.07)}
.ci-iname{font-family:var(--brand);font-size:1.3rem;font-weight:900;font-style:italic;text-transform:uppercase;line-height:1;margin-bottom:.3rem}
.ci-isub{font-family:var(--brand);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3)}
.ci-qty{display:flex;align-items:center;gap:.8rem;margin-top:.7rem}
.q-btn{width:22px;height:22px;border:1px solid rgba(255,255,255,.15);background:none;color:#fff;cursor:none;font-size:.7rem;display:flex;align-items:center;justify-content:center;transition:border-color .3s,background .3s,color .3s}
.q-btn:hover{border-color:var(--gold);background:var(--gold);color:#000}
.q-n{font-family:var(--brand);font-size:.8rem;min-width:18px;text-align:center}
.rm{font-family:var(--brand);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.18);background:none;border:none;cursor:none;transition:color .3s;margin-top:.8rem;display:block}
.rm:hover{color:rgba(255,255,255,.5)}
.ci-iprice{font-family:var(--brand);font-size:1.5rem;font-weight:900;font-style:italic;color:var(--gold)}
.cart-sum{background:#080808;padding:2.5rem;position:sticky;top:6rem;align-self:start}
.sum-title{font-family:var(--brand);font-size:1.6rem;font-weight:900;font-style:italic;text-transform:uppercase;margin-bottom:2rem}
.sum-row{display:flex;justify-content:space-between;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.04);font-family:var(--brand)}
.sum-lbl{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.sum-val{font-size:.85rem;color:rgba(255,255,255,.7)}
.sum-tot{display:flex;justify-content:space-between;padding:1.2rem 0;font-family:var(--brand)}
.sum-tot .sum-lbl{font-size:.78rem;color:#fff;font-weight:700}
.sum-tot .sum-val{font-size:1.4rem;font-weight:900;font-style:italic;color:var(--gold)}
.promo{width:100%;background:transparent;border:1px solid rgba(255,255,255,.08);padding:.8rem 1rem;color:#fff;font-family:var(--brand);font-size:.75rem;letter-spacing:.12em;margin:1.2rem 0;transition:border-color .3s}
.promo:focus{outline:none;border-color:var(--gold)}
.promo::placeholder{color:rgba(255,255,255,.2)}
.checkout{width:100%;padding:1.1rem;background:var(--gold);font-family:var(--brand);font-size:.82rem;font-weight:900;letter-spacing:.3em;text-transform:uppercase;color:#000;border:none;cursor:none;transition:transform .3s var(--spring),box-shadow .3s;position:relative;overflow:hidden}
.checkout:hover{transform:scale(1.02);box-shadow:0 16px 50px rgba(198,161,91,.2)}
.checkout::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.2);transform:translateX(-110%);transition:transform .45s var(--ease)}
.checkout:hover::after{transform:translateX(110%)}
.sec-note{font-family:var(--brand);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;gap:.6rem;margin-top:1.2rem}
.sdot{width:3px;height:3px;border-radius:50%;background:var(--gold)}

/* --- Responsive --- */
@media(max-width:900px){
  nav{padding:1rem 1.5rem}
  .feat-grid{grid-template-columns:1fr}
  .feat-item:nth-child(1){grid-row:auto}
  .prod-hero{grid-template-columns:1fr}
  .prod-vis{height:50vh}
  .prod-info{padding:3rem 1.5rem}
  .ed-grid,.ab,.cart-wrap{grid-template-columns:1fr}
  .ab:nth-child(even){direction:ltr}
  .coll-grid{grid-template-columns:1fr 1fr}
  .ci{grid-column:span 1 !important;grid-row:auto !important}
  .cart-lft{padding-right:0}
  .notes{padding:5rem 1.5rem}
  .coll-hd,.coll-grid{padding-left:1.5rem;padding-right:1.5rem}
}
