/* ═══════════════════════════════════════════
   DESIGN TOKENS — Bebeys luxury palette
═══════════════════════════════════════════ */
:root{
  /* Backgrounds */
  --void:#0a0a0a;--deep:#111111;--surface:#161616;--s2:#1c1c1c;--s3:#222222;
  /* Borders */
  --b:rgba(255,255,255,.08);--b2:rgba(255,255,255,.14);--b3:rgba(255,255,255,.24);
  /* Text */
  --w:white;--w80:rgba(255,255,255,.8);--w50:rgba(255,255,255,.5);--w20:rgba(255,255,255,.2);--w08:rgba(255,255,255,.06);
  /* Brand gold */
  --gold:#C9A84C;--gold2:#b8942e;--goldg:rgba(201,168,76,.3);--golds:rgba(201,168,76,.1);
  /* Status */
  --re:#ff4757;--gr:#2ecc71;
  /* Typography */
  --font-display:'Cormorant Garamond',serif;
  --font-body:'Montserrat',sans-serif;
  /* Radii & easing */
  --r:10px;--rl:18px;--rx:24px;
  --ease:cubic-bezier(.22,1,.36,1);--easeback:cubic-bezier(.34,1.56,.64,1);
  /* Aliases for app.js */
  --text-primary:var(--w);--text-muted:var(--w50);--bg-primary:var(--void);--bg-secondary:var(--deep);
  --border:var(--b);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--void);color:var(--w);line-height:1.6;overflow-x:hidden}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{font-family:var(--font-body);cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:var(--font-body)}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--void)}
::-webkit-scrollbar-thumb{background:var(--s3);border-radius:4px}

/* ── LAYOUT ── */
.container,.wrap{max-width:1300px;margin:0 auto;padding:0 40px}
@media(max-width:768px){.container,.wrap{padding:0 18px}}

/* ── HEADER ── */
header{position:fixed;top:0;left:0;right:0;z-index:200;height:68px;
  transition:background .4s,border-color .4s,backdrop-filter .4s;
  background:linear-gradient(to bottom,rgba(0,0,0,.62) 0%,rgba(0,0,0,.18) 75%,transparent 100%);
  border-bottom:1px solid rgba(255,255,255,.06)}
header.scrolled{background:rgba(10,10,10,.94);backdrop-filter:blur(20px);
  border-bottom-color:var(--b2)}
.hdr{height:68px;display:flex;align-items:center;justify-content:space-between;gap:16px}

/* Logo */
.logo{display:flex;align-items:center;gap:10px;cursor:pointer;flex-shrink:0;text-decoration:none}
.logo-emblem img{width:34px;height:34px}
.logo img{
  width: 70px;
  height: 70px;
  border-radius: 35%;
  padding: 8px;
}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-name{font-family:var(--font-display);font-size:20px;letter-spacing:5px;color:var(--w)}
.logo-sub{font-size:7px;letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-top:2px}

/* Desktop nav */
.mainnav{display:flex;gap:2px}
.mainnav a{padding:8px 13px;border-radius:8px;font-size:.8rem;font-weight:500;letter-spacing:.5px;
  color:var(--w50);transition:all .2s;white-space:nowrap;text-transform:uppercase}
.mainnav a:hover,.mainnav a.act{color:var(--w);background:var(--w08)}

/* Header right */
.hr{display:flex;align-items:center;gap:5px;flex-shrink:0}
.hb{width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  font-size:.92rem;color:var(--w50);transition:all .2s;border:1px solid transparent;position:relative}
.hb:hover{color:var(--w);background:var(--w08);border-color:var(--b)}
.cbadge{position:absolute;top:5px;right:5px;width:16px;height:16px;border-radius:50%;
  background:var(--gold);color:#000;font-size:.55rem;font-weight:800;
  display:none;align-items:center;justify-content:center}
.admin-btn{padding:6px 14px;border-radius:8px;border:1px solid rgba(201,168,76,.4);
  color:var(--gold);font-size:.72rem;font-weight:600;letter-spacing:.5px;background:var(--golds);
  transition:all .2s;display:none;align-items:center;gap:6px}
.admin-btn:hover{background:rgba(201,168,76,.2);border-color:var(--gold)}

/* Hamburger */
.mtogg{display:none;align-items:center;justify-content:center;width:40px;height:40px;
  border-radius:9px;border:1px solid var(--b);background:var(--w08);
  color:var(--w);font-size:1rem;transition:all .2s;flex-shrink:0}
@media(max-width:1024px) and (min-width:769px){.mainnav a{padding:7px 10px;font-size:.74rem}}
@media(max-width:768px){
  .mainnav{display:none}
  .mtogg{display:flex}
  .logo-name{font-size:17px}
  .logo img{width:46px;height:46px;padding:5px}
  #accountBtn{display:none}
  .hr{gap:3px}
  #themeToggle{display:flex}
  .hb{width:36px;height:36px}
}

/* ── MOBILE MENU ── */
.mbdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);z-index:300}
.mbdrop.on{display:block}
.mmenu{position:fixed;top:0;right:-320px;width:300px;height:100vh;background:var(--deep);
  border-left:1px solid var(--b);z-index:301;transition:right .38s var(--ease);
  display:flex;flex-direction:column;overflow-y:auto}
.mmenu.on{right:0}
.mmtop{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--b);min-height:68px}
.mmclose-btn{width:32px;height:32px;border-radius:8px;background:var(--s3);border:1px solid var(--b);
  color:var(--w50);display:flex;align-items:center;justify-content:center;font-size:.82rem;cursor:pointer;transition:all .2s}
.mmnav{list-style:none;padding:12px 10px;flex:1}
.mmnav li a{display:flex;align-items:center;gap:13px;padding:13px 14px;border-radius:10px;
  font-size:.88rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase;color:var(--w80);transition:all .2s}
.mmnav li a:hover,.mmnav li a.act{background:var(--w08);color:var(--w)}
.mmnav li a i{width:18px;text-align:center;color:var(--gold);font-size:.82rem;flex-shrink:0}
.mmfooter{margin:10px 12px 16px;padding:14px 16px;background:var(--s2);border-radius:var(--r);border:1px solid var(--b)}
.mmfooter p{font-size:.74rem;color:var(--w50);margin-bottom:6px;display:flex;align-items:center;gap:7px}
.mmfooter p i{color:var(--gold);font-size:.72rem}

/* ── SEARCH OVERLAY ── */
.searchov{display:none;position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.94);
  backdrop-filter:blur(16px);align-items:flex-start;justify-content:center;padding-top:100px}
.searchov.on{display:flex}
.sbox{width:90%;max-width:600px;animation:fadeUp .3s var(--easeback)}
.srow{display:flex;background:var(--s3);border:1px solid var(--b2);border-radius:var(--rl);overflow:hidden}
.srow input{flex:1;padding:16px 20px;background:none;border:none;outline:none;color:var(--w);font-size:.96rem;font-family:var(--font-body)}
.srow input::placeholder{color:var(--w20)}
.srow button{padding:0 20px;background:var(--gold);color:#000;font-size:.82rem;font-weight:700;transition:background .2s}
.srow button:hover{background:var(--gold2)}
.shint{font-size:.72rem;color:var(--w20);margin-top:9px;text-align:center}
#sres{margin-top:14px}
.sitem{display:flex;align-items:center;gap:13px;padding:11px 14px;border-radius:var(--r);cursor:pointer;transition:background .15s;border:1px solid transparent}
.sitem:hover{background:var(--s3);border-color:var(--b)}
.sitem img{width:48px;height:48px;object-fit:cover;border-radius:7px;background:var(--s2);flex-shrink:0}
.sitem-name{font-size:.84rem;font-weight:500}
.sitem-price{font-size:.76rem;color:var(--gold);font-weight:700;margin-top:2px}

/* ── CART DRAWER ── */
.cartov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);z-index:400}
.cartov.on{display:block}
.cdrawer{position:fixed;top:0;right:-430px;width:400px;height:100vh;background:var(--deep);
  border-left:1px solid var(--b);z-index:401;display:flex;flex-direction:column;
  transition:right .38s var(--ease)}
.cdrawer.on{right:0}
.cdh{padding:20px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between}
.cdh h3{font-family:var(--font-display);font-size:1.1rem;letter-spacing:2px}
.cdh button{width:30px;height:30px;border-radius:7px;background:var(--w08);color:var(--w50);
  display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all .2s}
.cdh button:hover{background:var(--s3);color:var(--w)}
.cditems{flex:1;overflow-y:auto;padding:14px}
.cempty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--w20);text-align:center;padding:40px}
.cempty .ico{width:64px;height:64px;border-radius:50%;background:var(--s3);display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--b)}
.cdi{display:flex;gap:11px;padding:12px;background:var(--s2);border:1px solid var(--b);border-radius:var(--r);margin-bottom:8px;transition:border-color .2s}
.cdi:hover{border-color:var(--b2)}
.cdi img{width:58px;height:58px;object-fit:cover;border-radius:7px;background:var(--s3);flex-shrink:0}
.cdii{flex:1;min-width:0}
.cdii .nm{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cdii .row{display:flex;align-items:center;justify-content:space-between;margin-top:9px}
.qc{display:flex;align-items:center;gap:7px}
.qb{width:24px;height:24px;border-radius:5px;background:var(--s3);color:var(--w80);
  display:flex;align-items:center;justify-content:center;font-size:.68rem;transition:all .2s;cursor:pointer}
.qb:hover{background:var(--gold);color:#000}
.qn{font-size:.8rem;font-weight:700;min-width:14px;text-align:center}
.cip{font-size:.84rem;font-weight:700}
.crm{font-size:.66rem;color:var(--w20);display:inline-flex;align-items:center;gap:3px;margin-top:5px;transition:color .2s;cursor:pointer}
.crm:hover{color:var(--re)}
.cdf{padding:16px 20px;border-top:1px solid var(--b)}

/* ── PRODUCT MODAL ── */
.modov{display:none;position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.88);
  backdrop-filter:blur(12px);align-items:center;justify-content:center;padding:18px}
.modov.on{display:flex}
.pmod{background:var(--deep);border:1px solid var(--b2);border-radius:var(--rx);
  width:100%;max-width:900px;height:min(88vh,640px);
  display:grid;grid-template-columns:1fr 1fr;position:relative;
  animation:fadeUp .4s var(--easeback);overflow:hidden}
.pmimg{background:var(--surface);border-radius:var(--rx) 0 0 var(--rx);overflow:hidden;
  position:relative;height:100%}
.pmimg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pmbody{padding:36px 30px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:var(--s3) transparent}
.pmclose{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;
  background:rgba(10,10,10,.7);backdrop-filter:blur(8px);color:var(--w80);
  display:flex;align-items:center;justify-content:center;
  font-size:.82rem;z-index:10;transition:all .2s;cursor:pointer;border:1px solid var(--b2)}
.pmclose:hover{background:var(--s3);color:var(--w)}
.pmcat{font-size:.68rem;text-transform:uppercase;letter-spacing:2.5px;color:var(--gold);font-weight:600}
.pmname{font-family:var(--font-display);font-size:1.6rem;font-weight:600;line-height:1.2}
.pmpr{display:flex;align-items:center;gap:11px;flex-wrap:wrap}
.pmprice{font-size:1.8rem;font-weight:700}
.pmorig{font-size:.9rem;color:var(--w20);text-decoration:line-through}
.pmsave{padding:3px 9px;background:rgba(201,168,76,.12);color:var(--gold);border-radius:20px;font-size:.72rem;font-weight:700;border:1px solid rgba(201,168,76,.2)}
.pmdesc{font-size:.84rem;color:var(--w50);line-height:1.7}
.pmavail{font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--w50)}
.pmacts{display:flex;gap:9px;margin-top:auto;padding-top:8px}
.btnadd{flex:1;padding:13px;background:var(--gold);color:#000;border-radius:var(--r);
  font-size:.86rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:7px;transition:all .3s var(--ease)}
.btnadd:hover{background:var(--gold2);transform:translateY(-2px)}
@media(max-width:700px){.pmod{grid-template-columns:1fr}.pmimg{border-radius:var(--rx) var(--rx) 0 0;min-height:220px}}
@media(max-width:600px){.cdrawer{width:100%;right:-105%}.cdrawer.on{right:0}}

/* ── GENERIC MODAL ── */
.gmodov{display:none;position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.92);
  backdrop-filter:blur(14px);align-items:center;justify-content:center;padding:18px}
.gmodov.on{display:flex}
.gmod{background:var(--deep);border:1px solid var(--b2);border-radius:var(--rx);
  width:100%;max-width:480px;padding:40px;position:relative;
  animation:fadeUp .4s var(--easeback);max-height:90vh;overflow-y:auto}
.gmod-wide{max-width:860px}
.gmod-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:8px;
  background:var(--w08);color:var(--w50);display:flex;align-items:center;justify-content:center;
  font-size:.8rem;transition:all .2s;cursor:pointer}
.gmod-close:hover{background:var(--s3);color:var(--w)}
@media(max-width:600px){.gmod{padding:22px 18px;border-radius:var(--rl);max-width:96vw}.gmod-wide{max-width:96vw}}

/* ── FORM ELEMENTS ── */
.afg{margin-bottom:14px}
.afg label{display:block;font-size:.68rem;font-weight:700;text-transform:uppercase;
  letter-spacing:1px;color:var(--w50);margin-bottom:6px}
.afg input,.afg select,.afg textarea{width:100%;padding:11px 14px;border-radius:9px;
  border:1px solid var(--b);background:var(--s3);color:var(--w);font-size:.84rem;outline:none;
  transition:border-color .2s;font-family:var(--font-body)}
.afg input:focus,.afg select:focus,.afg textarea:focus{border-color:var(--gold)}
.afg input::placeholder,.afg textarea::placeholder{color:var(--w20)}
.ferr{font-size:.76rem;color:var(--re);display:none;margin-bottom:10px}
.frow2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:540px){.frow2{grid-template-columns:1fr}}
.abtnprim{width:100%;padding:13px;background:var(--gold);color:#000;border-radius:var(--r);
  font-size:.88rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:7px;
  transition:all .2s var(--ease);border:none;cursor:pointer}
.abtnprim:hover{background:var(--gold2);transform:translateY(-1px)}

/* ── BUTTONS ── */
.btn-primary{padding:12px 26px;background:var(--gold);color:#000;border-radius:var(--r);
  font-size:.82rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;transition:all .2s var(--ease);border:none;cursor:pointer}
.btn-primary:hover{background:var(--gold2);transform:translateY(-2px)}
.btn-ghost{padding:12px 26px;border:1px solid var(--b2);color:var(--w80);border-radius:var(--r);
  font-size:.82rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;transition:all .2s;background:none;cursor:pointer}
.btn-ghost:hover{background:var(--w08);border-color:var(--b3);color:var(--w)}

/* ── PRODUCT GRID ── */
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:8px;padding:9px}
@media(max-width:1100px){.pgrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.pgrid{grid-template-columns:repeat(2,1fr);gap:14px}}
@media(max-width:480px){.pgrid{grid-template-columns:repeat(2,1fr);gap:10px}}

/* ── PRODUCT CARD ── */
.product-card{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);
  overflow:hidden;cursor:pointer;transition:all .3s var(--ease)}
.product-card:hover{border-color:rgba(201,168,76,.3);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.4)}
.product-img{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--surface)}
.product-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.product-card:hover .product-img img{transform:scale(1.05)}
/* ── Hover image (secondary) ── */
.product-img .img-primary{position:absolute;inset:0;z-index:1;transition:opacity .4s ease}
.product-img .img-hover{position:absolute;inset:0;z-index:2;opacity:0;transition:opacity .4s ease}
.product-img.has-hover:hover .img-primary{opacity:0}
.product-img.has-hover:hover .img-hover{opacity:1}
/* ── Modal hover image ── */
.pmimg .img-primary{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;transition:opacity .4s ease}
.pmimg .img-hover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2;opacity:0;transition:opacity .4s ease}
.pmimg.has-hover:hover .img-primary{opacity:0}
.pmimg.has-hover:hover .img-hover{opacity:1}
.pbadge{position:absolute;top:10px;left:10px;padding:3px 9px;border-radius:20px;font-size:.63rem;font-weight:700;letter-spacing:.5px}
.badge-new{background:rgba(201,168,76,.2);color:var(--gold);border:1px solid rgba(201,168,76,.3)}
.badge-sale{background:rgba(255,71,87,.14);color:var(--re);border:1px solid rgba(255,71,87,.2)}
.badge-excl{background:rgba(255,255,255,.06);color:var(--w80);border:1px solid var(--b)}
.pcov{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;gap:8px;
  opacity:0;transition:opacity .25s}
.product-card:hover .pcov{opacity:1}
.btas{padding:9px 16px;background:var(--gold);color:#000;border-radius:7px;font-size:.75rem;font-weight:700;
  border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px}
.btas:hover{background:var(--gold2)}
.btqs{width:36px;height:36px;border-radius:7px;border:1px solid var(--b2);background:var(--w08);
  color:var(--w);display:flex;align-items:center;justify-content:center;font-size:.8rem;cursor:pointer;transition:all .2s}
.btqs:hover{background:var(--w08);border-color:var(--gold)}
.product-info{padding:14px}
.product-category{font-size:.64rem;text-transform:uppercase;letter-spacing:2px;color:var(--gold);font-weight:600;margin-bottom:5px}
.product-name{font-family:var(--font-display);font-size:1rem;font-weight:500;line-height:1.3;margin-bottom:8px}
.product-price{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}
.price-current{font-size:.9rem;font-weight:700}
.price-original{font-size:.76rem;color:var(--w20);text-decoration:line-through}
.price-save{font-size:.64rem;font-weight:700;color:var(--gold);background:var(--golds);padding:2px 6px;border-radius:4px}
.product-avail{font-size:.62rem;color:var(--w20);text-transform:uppercase;letter-spacing:1px}
.nores{grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--w20)}
.nores i{font-size:2rem;display:block;margin-bottom:14px;opacity:.3}
.nores h3{font-size:.9rem;color:var(--w50);margin-bottom:7px}

/* ── PAGE SECTIONS ── */
.sec{padding:72px 0}
@media(max-width:600px){.sec{padding:44px 0}}
.pghead{padding:110px 0 44px;background:linear-gradient(180deg,var(--deep),var(--void))}
.pghead h1{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,4rem);letter-spacing:3px;margin:10px 0 8px}
.pghead p{font-size:.82rem;color:var(--w50);letter-spacing:.5px}
.bc{display:flex;align-items:center;gap:8px;font-size:.72rem;color:var(--w20);margin-bottom:8px;text-transform:uppercase;letter-spacing:.8px}
.bc button{color:var(--w50);transition:color .2s;background:none;border:none;cursor:pointer;font-family:var(--font-body);font-size:.72rem;letter-spacing:.8px}
.bc button:hover{color:var(--gold)}
.bc i{font-size:.56rem}
.shead{display:flex;flex-direction:column;gap:6px;margin-bottom:32px}
.slbl{font-size:.7rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);font-weight:600}
.srow{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap}
.stitle{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.2rem);line-height:1.1;letter-spacing:1px}
.linkall{font-size:.72rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--w50);
  display:flex;align-items:center;gap:7px;transition:color .2s;border:none;background:none;cursor:pointer;white-space:nowrap}
.linkall:hover{color:var(--gold)}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:68px}
/* Permanent black left panel */
.hero::before{content:'';position:absolute;top:0;left:0;width:50%;height:100%;background:#000;z-index:1;pointer-events:none}

/* ── Desktop: image slider — RIGHT HALF ONLY ── */
.hero-slider{position:absolute;top:0;left:50%;right:0;bottom:0;z-index:0;overflow:hidden}
.hero-slide{
  position:absolute;inset:0;
  display:block;
  opacity:0;pointer-events:none;
  transform:translateX(60px);
  transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1)}
.hero-slide.active{opacity:1;pointer-events:auto;transform:translateX(0)}
.hero-slide.leaving{opacity:0;transform:translateX(-60px);transition:opacity .5s ease,transform .5s ease}
.hero-slide-img{position:absolute;inset:0;overflow:hidden;background:var(--surface)}
.hero-slide-img img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:top center;
  transform:scale(1.04);
  transition:transform 7s ease}
.hero-slide.active .hero-slide-img img{transform:scale(1)}
.hero-slide-caption{
  position:absolute;bottom:0;left:0;right:0;
  padding:32px 28px;
  background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.4) 60%,transparent 100%);
  z-index:2;
  transform:translateY(14px);opacity:0;
  transition:opacity .6s .35s ease, transform .6s .35s ease}
.hero-slide.active .hero-slide-caption{opacity:1;transform:none}
.cap-tag{font-size:.58rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:5px}
.cap-name{font-family:var(--font-display);font-size:1.2rem;color:var(--w);letter-spacing:1px;line-height:1.2}
.cap-price{font-size:.84rem;color:var(--w80);margin-top:4px;font-weight:600}
.hero-slide-dots{position:absolute;bottom:22px;right:28px;display:flex;gap:7px;z-index:5}
.hero-slide-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.35);
  border:1px solid rgba(255,255,255,.55);cursor:pointer;transition:all .35s}
.hero-slide-dot.active{background:var(--gold);border-color:var(--gold);width:24px;border-radius:4px}

/* ── Mobile: video background ── */
.hero-vid-wrap{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;background:#000;display:none}
.hero-vid-wrap iframe{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:calc(100vh * 16 / 9);height:100vh;
  min-width:100vw;min-height:calc(100vw * 9 / 16);
  border:0;display:block}

@media(max-width:900px){
  .hero-slider{display:none}
  .hero::before{display:none}
  .hero-vid-wrap{display:block}
}

.hero-vid-overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(to right,rgba(0,0,0,.72) 0%,rgba(0,0,0,.45) 55%,rgba(0,0,0,.2) 100%)}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:80px 0}
.hero-text{position:relative;z-index:2;max-width:600px}
.hero-eyebrow{font-size:.68rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);
  font-weight:600;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.hero-eyebrow::before{content:'';display:inline-block;width:28px;height:1px;background:var(--gold)}
.hero-title{font-family:var(--font-display);font-size:clamp(3.5rem,6vw,6.5rem);line-height:.95;
  letter-spacing:2px;margin-bottom:22px}
.hero-accent{color:transparent;-webkit-text-stroke:1.5px var(--gold)}
.hero-sub{font-size:.88rem;color:var(--w50);line-height:1.8;margin-bottom:32px;max-width:420px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:48px}
.hero-stats{display:flex;gap:36px}
.hst{text-align:left}
.hst .num{font-family:var(--font-display);font-size:1.6rem;color:var(--w);letter-spacing:1px}
.hst .lbl{font-size:.62rem;text-transform:uppercase;letter-spacing:2px;color:var(--w20);margin-top:2px}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center}
.hero-img-wrap{width:440px;height:540px;border-radius:var(--rx);overflow:hidden;border:1px solid var(--b)}
.hero-img-wrap img{width:100%;height:100%;object-fit:cover}
.hfloat1{position:absolute;bottom:40px;left:-20px;background:rgba(17,17,17,.9);border:1px solid var(--b2);
  border-radius:12px;padding:12px 18px;backdrop-filter:blur(8px)}
.hfloat1 .lbl{font-size:.62rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--w20);margin-bottom:3px}
.hfloat1 .val{font-size:.86rem;font-weight:600;color:var(--gold)}
.hfloat2{position:absolute;top:28px;right:-10px;background:rgba(17,17,17,.9);border:1px solid var(--b2);
  border-radius:20px;padding:8px 16px;font-size:.75rem;color:var(--w80);backdrop-filter:blur(8px)}
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:32px}
  .hero-visual{display:none}
  .hero-title{font-size:clamp(3rem,12vw,5rem)}
  .hero-vid-overlay{background:rgba(0,0,0,.7)}
}

/* ── SHOP PAGE ── */
.shop-hero{padding:120px 0 52px;position:relative;overflow:hidden;background:var(--void)}
.shop-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(201,168,76,.07),transparent)}
.shop-hero-inner{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}
.shop-hero-title{font-family:var(--font-display);font-size:clamp(3rem,6vw,5.5rem);letter-spacing:3px;line-height:.9;color:var(--w)}
.shop-hero-title span{color:transparent;-webkit-text-stroke:1.5px var(--gold)}
.shop-hero-meta{font-size:.76rem;color:var(--w50);letter-spacing:1px;margin-top:10px}
.shop-hero-right{text-align:right}
.shop-hero-count{font-family:var(--font-display);font-size:3.5rem;color:var(--gold);line-height:1}
.shop-hero-count-lbl{font-size:.64rem;text-transform:uppercase;letter-spacing:2px;color:var(--w20);margin-top:4px}
.shop-divider{height:1px;background:linear-gradient(to right,transparent,var(--b2),transparent);margin:0}

/* ── TRUST BAR ── */
.trust-bar{border-top:1px solid var(--b);border-bottom:1px solid var(--b);padding:14px 0;background:var(--deep)}
.trust-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.titem{font-size:.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--w50);
  display:flex;align-items:center;gap:8px;font-weight:500}
.titem i{color:var(--gold)}
@media(max-width:768px){.trust-bar{display:none}}

/* ── CATEGORY STRIP ── */
.catstrip{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-top:4px;padding:9px}
@media(max-width:900px){.catstrip{grid-template-columns:repeat(4,1fr)}}
@media(max-width:560px){.catstrip{grid-template-columns:repeat(3,1fr)}}
.cpill{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 10px;
  background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);
  transition:all .3s var(--ease);cursor:pointer}
.cpill:hover,.cpill.on{border-color:rgba(201,168,76,.3);background:var(--golds);transform:translateY(-2px)}
.cpill i{font-size:.96rem;color:var(--gold)}
.cpill .cn{font-size:.72rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--w80)}
.cpill .cc{font-size:.62rem;color:var(--w20)}

/* ── PROMO BANNERS ── */
.promos{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:9px}
@media(max-width:600px){.promos{grid-template-columns:1fr}}
.promo{padding:44px 36px;border-radius:var(--rx);border:1px solid var(--b);position:relative;overflow:hidden}
.promo-1{background:linear-gradient(135deg,rgba(201,168,76,.08),rgba(0,0,0,.4))}
.promo-2{background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(0,0,0,.4))}
.ptag{font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);font-weight:600}
.pdisc{font-family:var(--font-display);font-size:clamp(1.8rem,3.5vw,2.8rem);letter-spacing:2px;margin:10px 0 6px;line-height:1}
.plbl{font-size:.82rem;color:var(--w50);margin-bottom:24px}
.pbtn{padding:10px 22px;border:1px solid var(--gold);color:var(--gold);border-radius:8px;
  font-size:.76rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  background:none;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px}
.pbtn:hover{background:var(--gold);color:#000}

/* ── SHOP FILTERS ── */
.shop-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.cat-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:22px}
.filter-btn{padding:8px 18px;border:1px solid var(--b);border-radius:20px;font-size:.72rem;
  font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--w50);
  background:none;cursor:pointer;transition:all .2s}
.filter-btn.active,.filter-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--golds)}
.cat-btn{padding:6px 14px;border:1px solid var(--b);border-radius:6px;font-size:.72rem;
  font-weight:500;color:var(--w50);background:none;cursor:pointer;transition:all .2s}
.cat-btn.active,.cat-btn:hover{border-color:var(--b2);color:var(--w);background:var(--w08)}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:11px;margin-bottom:22px;flex-wrap:wrap}
.shopcount{font-size:.8rem;color:var(--w50)}.shopcount strong{color:var(--w)}
.sortsel{padding:8px 12px;border-radius:8px;border:1px solid var(--b);background:var(--s3);
  color:var(--w);font-size:.78rem;outline:none;cursor:pointer;font-family:var(--font-body)}
.sortsel:focus{border-color:var(--gold)}

/* ── PAGINATION ── */
.pgn{display:flex;justify-content:center;gap:5px;margin-top:44px;flex-wrap:wrap}
.pgnb{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:600;color:var(--w50);border:1px solid var(--b);background:var(--s2);transition:all .2s;cursor:pointer}
.pgnb:hover{border-color:var(--b2);color:var(--w)}
.pgnb.on{background:var(--gold);border-color:var(--gold);color:#000;font-weight:700}
.pgnb:disabled{opacity:.3;cursor:not-allowed}

/* ── CART & CHECKOUT PAGES ── */
.cart-layout,.checkout-layout{display:grid;grid-template-columns:1fr 360px;gap:28px;align-items:start}
@media(max-width:900px){.cart-layout,.checkout-layout{grid-template-columns:1fr}}
.cart-item{display:grid;grid-template-columns:78px 1fr auto;gap:14px;align-items:center;
  padding:18px;background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);margin-bottom:11px}
.cart-item img{width:78px;height:78px;object-fit:cover;border-radius:9px;background:var(--s3)}
.cart-item-name{font-size:.88rem;font-weight:600;margin-bottom:4px}
.order-card{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:22px}
.order-card h3{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--w50);margin-bottom:18px;font-family:var(--font-body)}
.orow{display:flex;justify-content:space-between;font-size:.82rem;color:var(--w50);margin-bottom:8px}
.orow.tot{font-size:.95rem;font-weight:800;color:var(--w);border-top:1px solid var(--b);padding-top:12px;margin-top:6px}
.sticky-card{position:sticky;top:84px}
.checkout-block{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:24px;margin-bottom:18px}
.checkout-block h3{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--w50);margin-bottom:18px;display:flex;align-items:center;gap:9px;font-family:var(--font-body)}
.checkout-block h3 i{color:var(--gold)}
.checkout-item{display:flex;align-items:center;gap:11px;padding:10px 0;border-bottom:1px solid var(--b)}
.checkout-item:last-of-type{border-bottom:none}
.checkout-item img{width:48px;height:48px;object-fit:cover;border-radius:7px;background:var(--s3);flex-shrink:0}
.pay-methods{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.pmchip{flex:1;min-width:120px;padding:10px 13px;border:1px solid var(--b);border-radius:9px;
  cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;color:var(--w50)}
.pmchip:hover,.pmchip.on{border-color:var(--gold);color:var(--w);background:var(--golds)}
.pmchip i{color:var(--gold)}

/* ── ACCOUNT PAGE ── */
.account-layout{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start}
@media(max-width:768px){.account-layout{grid-template-columns:1fr}}
.account-side{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:22px;position:sticky;top:84px}
.account-avatar{width:68px;height:68px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);
  font-size:1.5rem;color:#000;margin:0 auto 12px}
.account-name{text-align:center;font-weight:700;font-size:.9rem;margin-bottom:3px}
.account-email{text-align:center;font-size:.7rem;color:var(--w50);margin-bottom:16px}
.account-nav{list-style:none}
.account-nav li a{display:flex;align-items:center;gap:10px;padding:10px 12px;
  border-radius:9px;font-size:.78rem;font-weight:500;color:var(--w50);transition:all .2s}
.account-nav li a:hover,.account-nav li a.on{background:var(--w08);color:var(--w)}
.account-nav li a i{width:15px;text-align:center;color:var(--gold);font-size:.78rem}
.account-block{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:24px;margin-bottom:16px}
.account-block h3{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--w50);margin-bottom:16px;font-family:var(--font-body)}

/* ── ADMIN PANEL ── */
.admpanel{position:fixed;inset:0;z-index:800;background:var(--void);display:flex;flex-direction:column;
  overflow:hidden;animation:fadeUp .35s var(--ease)}
.admtop{height:62px;background:var(--deep);border-bottom:1px solid var(--b);
  display:flex;align-items:center;justify-content:space-between;padding:0 28px;flex-shrink:0}
.admtitle{display:flex;align-items:center;gap:11px;font-size:1rem;letter-spacing:1px}
.admbadge{padding:3px 9px;background:rgba(201,168,76,.14);border:1px solid rgba(201,168,76,.28);
  color:var(--gold);font-family:var(--font-body);font-size:.62rem;font-weight:700;
  border-radius:4px;text-transform:uppercase;letter-spacing:.8px}
.admclosebtn{display:flex;align-items:center;gap:7px;padding:7px 14px;border-radius:8px;
  border:1px solid var(--b);color:var(--w50);font-size:.78rem;transition:all .2s;cursor:pointer}
.admclosebtn:hover{background:var(--surface);color:var(--w);border-color:var(--b2)}
.admbody{display:flex;flex:1;overflow:hidden}
.admside{width:210px;flex-shrink:0;background:var(--deep);border-right:1px solid var(--b);padding:20px 0;overflow-y:auto}
.admni{display:flex;align-items:center;gap:11px;padding:11px 18px;font-size:.8rem;font-weight:500;
  color:var(--w50);cursor:pointer;transition:all .2s;border-right:2px solid transparent}
.admni:hover,.admni.on{color:var(--w);background:var(--w08)}
.admni.on{border-right-color:var(--gold)}
.admni i{width:16px;text-align:center;color:var(--w20);font-size:.78rem}
.admni.on i{color:var(--gold)}
.admcont{flex:1;overflow-y:auto;padding:28px}
.admstats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}
@media(max-width:900px){.admstats{grid-template-columns:repeat(2,1fr)}}
.admstat{background:var(--s2);border:1px solid var(--b);border-radius:var(--r);padding:18px}
.admstat .lbl{font-size:.64rem;text-transform:uppercase;letter-spacing:.9px;color:var(--w50);margin-bottom:7px}
.admstat .val{font-family:var(--font-display);font-size:1.9rem;color:var(--w);line-height:1}
.admstat .sub{font-size:.64rem;color:var(--gold);margin-top:3px}
.admtbl{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);overflow:hidden}
.admtblbar{padding:14px 18px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between;gap:11px;flex-wrap:wrap}
.admsearch{padding:7px 12px;border-radius:8px;border:1px solid var(--b);background:var(--s3);
  color:var(--w);font-size:.78rem;outline:none;width:220px;transition:border-color .2s;font-family:var(--font-body)}
.admsearch:focus{border-color:var(--gold)}
.admsearch::placeholder{color:var(--w20)}
.btnadmadd{padding:7px 16px;background:var(--gold);color:#000;border-radius:8px;
  font-size:.78rem;font-weight:700;display:flex;align-items:center;gap:5px;transition:all .2s;cursor:pointer;border:none}
.btnadmadd:hover{background:var(--gold2)}
table.admt{width:100%;border-collapse:collapse}
table.admt th{padding:11px 14px;text-align:left;font-size:.62rem;font-weight:700;
  text-transform:uppercase;letter-spacing:1.3px;color:var(--w20);border-bottom:1px solid var(--b);background:var(--surface)}
table.admt td{padding:11px 14px;font-size:.78rem;border-bottom:1px solid var(--b);vertical-align:middle}
table.admt tr:hover td{background:var(--w08)}
table.admt tr:last-child td{border-bottom:none}
.admimg{width:42px;height:42px;object-fit:cover;border-radius:7px;background:var(--s3)}
.admbg{padding:3px 8px;border-radius:5px;font-size:.62rem;font-weight:700}
.admbg.new{background:rgba(201,168,76,.14);color:var(--gold)}
.admbg.sale{background:rgba(255,71,87,.14);color:var(--re)}
.tbacts{display:flex;gap:5px}
.tbb{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;
  font-size:.7rem;transition:all .2s;border:1px solid var(--b);color:var(--w50);background:var(--s3);cursor:pointer}
.tbb:hover{border-color:var(--gold);color:var(--gold);background:var(--golds)}
.tbb.del:hover{border-color:var(--re);color:var(--re);background:rgba(255,71,87,.1)}
.chart-area{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:22px;margin-bottom:18px}
.chart-area h4{font-size:.78rem;font-weight:700;margin-bottom:18px;color:var(--w80);text-transform:uppercase;letter-spacing:1px}
.barchart{display:flex;align-items:flex-end;gap:5px;height:72px}
.bar{flex:1;border-radius:4px 4px 0 0;background:linear-gradient(to top,var(--gold),rgba(201,168,76,.2));min-width:12px}
.barlabels{display:flex;gap:5px;margin-top:5px}
.barlabels span{flex:1;font-size:.56rem;color:var(--w20);text-align:center}
@media(max-width:768px){.admside{display:none}}
@media(max-width:600px){.admtop{padding:0 14px}.admcont{padding:12px}.admstats{grid-template-columns:1fr 1fr}}

/* ── REVEAL ANIMATION ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal[data-d="2"]{transition-delay:.1s}
.reveal[data-d="3"]{transition-delay:.2s}
.reveal[data-d="4"]{transition-delay:.3s}
.reveal.in{opacity:1;transform:none}

/* ── TOASTS ── */
#toasts{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;align-items:center}
.toast{background:var(--s2);border:1px solid var(--b2);color:var(--w80);font-size:.8rem;font-weight:500;
  padding:11px 20px;border-radius:var(--r);display:flex;align-items:center;gap:8px;
  animation:fadeUp .3s var(--easeback);white-space:nowrap;pointer-events:none;
  box-shadow:0 4px 20px rgba(0,0,0,.4);font-family:var(--font-body)}
.toast i{color:var(--gold)}
.toast.err i{color:var(--re)}
.toast.out{animation:fadeDown .35s var(--ease) forwards}

/* ── FOOTER ── */
footer{background:var(--deep);border-top:1px solid var(--b);padding:64px 0 36px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:44px;margin-bottom:52px}
@media(max-width:1024px){.fgrid{grid-template-columns:1.2fr 1fr 1fr;gap:28px}}
@media(max-width:600px){.fgrid{grid-template-columns:1fr;gap:32px;margin-bottom:32px;text-align:center}}
@media(max-width:600px){.fgrid > div{display:flex;flex-direction:column;align-items:center}}
@media(max-width:600px){.fbot{flex-direction:column;align-items:center;text-align:center;gap:12px}}
.flogo{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.fdesc{font-size:.78rem;color:var(--w50);line-height:1.7;margin-bottom:18px;max-width:280px}
.socials{display:flex;gap:7px;flex-wrap:wrap}
.soc{width:34px;height:34px;border-radius:8px;background:var(--s3);color:var(--w50);
  display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all .2s;border:1px solid var(--b)}
.soc:hover{background:var(--golds);color:var(--gold);border-color:rgba(201,168,76,.3)}
.fcol h4{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--gold);margin-bottom:14px}
.flinks{list-style:none}
.flinks li{margin-bottom:9px}
.flinks a{font-size:.78rem;color:var(--w20);transition:color .2s}
.flinks a:hover{color:var(--w)}
.fbot{border-top:1px solid var(--b);padding-top:26px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.fcopy{font-size:.72rem;color:var(--w20)}
.pays{display:flex;gap:5px}
.pay{padding:3px 9px;background:var(--s3);border:1px solid var(--b);border-radius:5px;font-size:.62rem;font-weight:700;color:var(--w50)}

/* ── SIZE SELECTOR — product modal ── */
.pm-sizes{margin:4px 0 2px}
.pm-sizes-lbl{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--w50);margin-bottom:8px}
.pm-sizes-row{display:flex;gap:6px;flex-wrap:wrap}
.szb{min-width:42px;padding:7px 10px;border:1px solid var(--b2);border-radius:8px;font-size:.75rem;
  font-weight:700;color:var(--w50);background:var(--s3);cursor:pointer;transition:all .2s;letter-spacing:.5px}
.szb:hover{border-color:var(--gold);color:var(--gold);background:var(--golds)}
.szb.on{border-color:var(--gold);background:var(--gold);color:#000}

/* ── SIZE STRIP — on product card ── */
.card-sizes{display:flex;gap:4px;flex-wrap:wrap;margin:7px 0 8px}
.card-szb{padding:4px 8px;border:1px solid var(--b);border-radius:6px;font-size:.62rem;font-weight:700;
  color:var(--w50);background:none;cursor:pointer;transition:all .18s;letter-spacing:.3px}
.card-szb:hover{border-color:rgba(201,168,76,.5);color:var(--gold)}
.card-szb.on{border-color:var(--gold);background:var(--gold);color:#000}
.card-atc{width:100%;padding:9px 0;background:var(--s3);border:1px solid var(--b);border-radius:8px;
  font-size:.75rem;font-weight:700;color:var(--w50);cursor:pointer;transition:all .2s;
  display:flex;align-items:center;justify-content:center;gap:6px;letter-spacing:.3px}
.card-atc:hover,.card-atc.ready{background:var(--gold);border-color:var(--gold);color:#000}

/* ── MAP SECTION ── */
@media(max-width:700px){
  #mapSection .container > div:last-child{grid-template-columns:1fr!important}
  #mapSection .container > div:last-child > div:last-child{border-radius:0 0 var(--rx) var(--rx)}
}
/* ── CONTACT MODAL ── */
.cmodov{display:none;position:fixed;inset:0;z-index:700;background:rgba(0,0,0,.88);
  backdrop-filter:blur(14px);align-items:center;justify-content:center;padding:18px}
.cmodov.on{display:flex}
.cmod{background:var(--deep);border:1px solid var(--b2);border-radius:var(--rx);
  width:100%;max-width:560px;max-height:90vh;overflow-y:auto;
  padding:40px;position:relative;animation:fadeUp .4s var(--easeback)}
.cmod-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:8px;
  background:var(--w08);color:var(--w50);display:flex;align-items:center;justify-content:center;
  font-size:.8rem;cursor:pointer;transition:all .2s;border:none}
.cmod-close:hover{background:var(--s3);color:var(--w)}
@media(max-width:600px){.cmod{padding:24px 18px;border-radius:var(--rl);max-width:96vw}}
@media(max-width:800px){
  #root [style*="grid-template-columns:1fr 400px"]{grid-template-columns:1fr!important}
  #root [style*="position:sticky"]{position:static!important}
  #root [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
}
@keyframes szShake{
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-5px)}
  40%{transform:translateX(5px)}
  60%{transform:translateX(-4px)}
  80%{transform:translateX(4px)}
}

/* ── KEYFRAMES ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes fadeDown{from{opacity:1;transform:none}to{opacity:0;transform:translateY(10px)}}

/* ═══════════════════════════════════════════
   LIGHT THEME TOKENS
═══════════════════════════════════════════ */
[data-theme="light"]{
  /* Backgrounds — warm taupe, not harsh white */
  --void:#e8e0d4;--deep:#d8cfc2;--surface:#cfc5b6;--s2:#c5baaa;--s3:#b8ac9a;
  /* Borders — subtle warm brown */
  --b:rgba(60,42,20,.1);--b2:rgba(60,42,20,.18);--b3:rgba(60,42,20,.32);
  /* Text — rich dark brown, never pure black */
  --w:#2c1f0f;--w80:rgba(44,31,15,.82);--w50:rgba(44,31,15,.52);--w20:rgba(44,31,15,.24);--w08:rgba(44,31,15,.07);
  /* Aliases */
  --text-primary:#2c1f0f;--text-muted:rgba(44,31,15,.52);--bg-primary:#e8e0d4;--bg-secondary:#d8cfc2;--border:rgba(60,42,20,.1);
  /* Gold slightly warmer/richer on light */
  --gold:#b8922a;--golds:rgba(184,146,42,.1);
}
/* Hardcoded dark values overridden for light */
[data-theme="light"] header{background:linear-gradient(to bottom,rgba(232,224,212,.92) 0%,rgba(232,224,212,.32) 75%,transparent 100%)}
[data-theme="light"] header.scrolled{background:rgba(224,216,204,.97);backdrop-filter:blur(20px)}
/* Hero left panel */
[data-theme="light"] .hero::before{background:rgba(216,207,194,.96)}
/* Desktop hero text */
[data-theme="light"] .hero-eyebrow{color:var(--gold)}
[data-theme="light"] .hero-title{color:var(--w)}
[data-theme="light"] .hero-sub{color:var(--w80)}
[data-theme="light"] .hst .num{color:var(--w)}
[data-theme="light"] .hst .lbl{color:var(--w50)}
/* Mobile video overlay */
[data-theme="light"] .hero-vid-overlay{
  background:linear-gradient(to right,rgba(216,207,194,.92) 0%,rgba(216,207,194,.7) 55%,rgba(216,207,194,.25) 100%)}
@media(max-width:900px){
  [data-theme="light"] .hero-vid-overlay{background:rgba(216,207,194,.88)}
  [data-theme="light"] .hero-title{text-shadow:none}
}
[data-theme="light"] .hero-stats .hst .num{font-family:var(--font-display)}
[data-theme="light"] .searchov{background:rgba(224,216,204,.98);backdrop-filter:blur(20px)}
[data-theme="light"] .searchov .shint{color:var(--w20)}
[data-theme="light"] .hfloat1,
[data-theme="light"] .hfloat2{background:rgba(216,207,194,.92);border-color:var(--b2)}
[data-theme="light"] .hfloat1 .lbl,
[data-theme="light"] .hfloat2{color:var(--w50)}
[data-theme="light"] .promo-1{background:linear-gradient(135deg,rgba(184,146,42,.14),rgba(184,146,42,.04))}
[data-theme="light"] .promo-2{background:linear-gradient(135deg,rgba(0,0,0,.07),rgba(0,0,0,.02))}
[data-theme="light"] .toast{background:var(--deep);box-shadow:0 4px 20px rgba(60,42,20,.18)}
[data-theme="light"] ::-webkit-scrollbar-track{background:var(--void)}
[data-theme="light"] ::-webkit-scrollbar-thumb{background:var(--s3)}
/* Modals on light */
[data-theme="light"] .modov-bg{background:rgba(30,20,10,.55)}
[data-theme="light"] .pmwrap,[data-theme="light"] .gmod-box,[data-theme="light"] .sbox{
  background:var(--deep);border-color:var(--b2)}
/* Cart drawer on light */
[data-theme="light"] .cartdrawer{background:var(--deep)}
/* Product cards on light */
[data-theme="light"] .product-card{background:var(--surface);border-color:var(--b)}
[data-theme="light"] .product-card:hover{box-shadow:0 16px 48px rgba(60,42,20,.22),0 0 0 1px rgba(184,146,42,.2)}
/* Buttons on light */
[data-theme="light"] .szb{background:var(--s2);border-color:var(--b2);color:var(--w80)}
[data-theme="light"] .szb:hover{background:var(--s3)}
[data-theme="light"] .szb.on{background:var(--gold);border-color:var(--gold);color:#fff}
/* Input fields on light */
[data-theme="light"] input,[data-theme="light"] textarea,[data-theme="light"] select{
  background:var(--surface);border-color:var(--b2);color:var(--w)}
[data-theme="light"] input:focus,[data-theme="light"] textarea:focus{border-color:var(--gold)}
/* Bot on light */

/* ── THEME TOGGLE BUTTON ── */
#themeToggle{position:relative;overflow:hidden}
#themeToggle .th-icon{transition:transform .4s var(--easeback),opacity .3s}
.theme-sun,
.theme-moon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.92rem;transition:transform .4s var(--easeback),opacity .3s}
[data-theme="dark"]  .theme-sun {opacity:1;transform:translateY(0) rotate(0deg)}
[data-theme="dark"]  .theme-moon{opacity:0;transform:translateY(10px) rotate(-30deg)}
[data-theme="light"] .theme-sun {opacity:0;transform:translateY(-10px) rotate(30deg)}
[data-theme="light"] .theme-moon{opacity:1;transform:translateY(0) rotate(0deg)}

/* ── SMOOTH THEME TRANSITION ── */
.theme-transitioning,
.theme-transitioning *{
  transition:
    background-color .35s ease,
    border-color .35s ease,
    color .2s ease,
    box-shadow .35s ease !important;
}

/* ═══════════════════════════════════════════
   BEBEYS AI CHAT BOT
═══════════════════════════════════════════ */
#bb-bot{position:fixed;bottom:24px;right:24px;z-index:9000;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
@media(max-width:480px){#bb-bot{bottom:14px;right:14px}}

/* FAB button */
.bb-fab{width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;font-size:1.5rem;
  border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.45);transition:transform .25s var(--easeback),box-shadow .25s;
  position:relative;flex-shrink:0}
.bb-fab:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(37,211,102,.6)}
.bb-fab:active{transform:scale(.96)}
.bb-notif{position:absolute;top:-3px;right:-3px;width:18px;height:18px;border-radius:50%;
  background:var(--re);color:#fff;font-size:.6rem;font-weight:800;
  display:none;align-items:center;justify-content:center;border:2px solid var(--void)}

/* Chat window */
.bb-window{position:absolute;bottom:70px;right:0;width:340px;
  background:var(--deep);border:1px solid var(--b2);border-radius:var(--rx);
  box-shadow:0 12px 48px rgba(0,0,0,.45);
  display:flex;flex-direction:column;overflow:hidden;
  opacity:0;pointer-events:none;transform:translateY(16px) scale(.97);
  transition:opacity .25s var(--ease),transform .25s var(--ease)}
.bb-window.on{opacity:1;pointer-events:auto;transform:none}
@media(max-width:480px){
  .bb-window{width:calc(100vw - 28px);right:-14px;bottom:74px}
}

/* Header */
.bb-head{background:#075e54;padding:12px 14px;display:flex;align-items:center;gap:11px}
.bb-head-avatar{width:38px;height:38px;border-radius:50%;background:#25d366;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff;flex-shrink:0}
.bb-head-name{font-size:.88rem;font-weight:700;color:#fff;letter-spacing:.3px}
.bb-head-status{font-size:.68rem;color:rgba(255,255,255,.75);display:flex;align-items:center;gap:5px;margin-top:1px}
.bb-online-dot{width:7px;height:7px;border-radius:50%;background:#25d366}
.bb-close{margin-left:auto;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.12);
  color:rgba(255,255,255,.8);font-size:.76rem;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s;border:none;flex-shrink:0}
.bb-close:hover{background:rgba(255,255,255,.22)}

/* Messages area */
.bb-msgs{flex:1;height:300px;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;
  background:var(--void);
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C9A84C' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.bb-msgs::-webkit-scrollbar{width:3px}
.bb-msgs::-webkit-scrollbar-thumb{background:var(--s3);border-radius:3px}

/* Message bubbles */
.bb-msg{display:flex;flex-direction:column;gap:2px;max-width:85%}
.bb-msg-bot{align-self:flex-start}
.bb-msg-user{align-self:flex-end}
.bb-bubble{padding:9px 13px;border-radius:18px;font-size:.8rem;line-height:1.55;word-break:break-word}
.bb-msg-bot .bb-bubble{background:var(--surface);color:var(--w80);border-radius:4px 18px 18px 18px;border:1px solid var(--b)}
.bb-msg-user .bb-bubble{background:#25d366;color:#fff;border-radius:18px 4px 18px 18px}
.bb-time{font-size:.58rem;color:var(--w20);padding:0 4px;text-align:right}
.bb-msg-bot .bb-time{text-align:left}

/* Typing indicator */
.bb-typing{display:flex;align-items:center;gap:5px;padding:12px 16px}
.bb-typing span{width:7px;height:7px;border-radius:50%;background:var(--gold);opacity:.5;
  animation:bbDot 1.4s infinite ease-in-out}
.bb-typing span:nth-child(1){animation-delay:0s}
.bb-typing span:nth-child(2){animation-delay:.2s}
.bb-typing span:nth-child(3){animation-delay:.4s}
@keyframes bbDot{0%,80%,100%{opacity:.25;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}

/* Input row */
.bb-input-row{display:flex;align-items:center;gap:7px;padding:10px 12px;
  border-top:1px solid var(--b);background:var(--deep)}
#bbInput{flex:1;background:var(--s3);border:1px solid var(--b);border-radius:24px;
  padding:9px 14px;color:var(--w);font-size:.8rem;outline:none;font-family:var(--font-body);
  transition:border-color .2s}
#bbInput:focus{border-color:rgba(37,211,102,.5)}
#bbInput::placeholder{color:var(--w20)}
#bbSend{width:36px;height:36px;border-radius:50%;background:#25d366;color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:.82rem;
  cursor:pointer;border:none;flex-shrink:0;transition:background .2s,transform .2s}
#bbSend:hover{background:#1da851;transform:scale(1.08)}

/* Light theme bot overrides */
[data-theme="light"] .bb-msgs{background:#e5ddd5}
[data-theme="light"] .bb-msg-bot .bb-bubble{background:#fff;color:#1a1108;border-color:rgba(0,0,0,.1)}
[data-theme="light"] .bb-notif{border-color:var(--void)}
/* ═══════════════════════════════════════════
   WISHLIST
═══════════════════════════════════════════ */
.wl-btn{transition:all .25s var(--easeback)}
.wl-btn.on i{color:#e74c3c!important}
.wl-btn:hover{border-color:#e74c3c!important;color:#e74c3c!important;background:rgba(231,76,60,.08)!important}
.wbadge{position:absolute;top:5px;right:5px;width:16px;height:16px;border-radius:50%;
  background:#e74c3c;color:#fff;font-size:.55rem;font-weight:800;
  display:none;align-items:center;justify-content:center;pointer-events:none}

/* ── WISHLIST NAV BUTTON ── */
#wishlistBtn{position:relative}

/* ── CARD WISHLIST HEART (top-right corner) ── */
.product-card .wl-heart{
  position:absolute;top:10px;right:10px;z-index:3;
  width:32px;height:32px;border-radius:50%;
  background:rgba(10,10,10,.65);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.7);
  display:flex;align-items:center;justify-content:center;
  font-size:.76rem;cursor:pointer;transition:all .2s var(--easeback);
  opacity:0;transform:scale(.85)}
.product-card:hover .wl-heart{opacity:1;transform:scale(1)}
.product-card .wl-heart.on{opacity:1;transform:scale(1);border-color:rgba(231,76,60,.5);
  background:rgba(231,76,60,.15);color:#e74c3c}
.product-card .wl-heart:hover{transform:scale(1.12)!important;background:rgba(231,76,60,.25)!important;
  border-color:#e74c3c!important;color:#e74c3c!important}

/* ═══════════════════════════════════════════
   UI / UX IMPROVEMENTS
═══════════════════════════════════════════ */

/* ── Smooth page transitions ── */
#root{animation:fadeUp .28s var(--ease)}

/* ── Improved product card ── */
.product-card{transition:all .32s var(--ease);will-change:transform}
.product-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.55),0 0 0 1px rgba(201,168,76,.15)}

/* ── Price pulsing "sale" badge ── */
.price-save{animation:pricePop .5s var(--easeback)}
@keyframes pricePop{0%{transform:scale(0);opacity:0}70%{transform:scale(1.2)}100%{transform:scale(1);opacity:1}}

/* ── Cart badge entrance ── */
.cbadge{transition:transform .25s var(--easeback)}
.cbadge.bump{animation:badgeBump .35s var(--easeback)}
@keyframes badgeBump{0%{transform:scale(1)}40%{transform:scale(1.6)}100%{transform:scale(1)}}

/* ── Toast improvements ── */
.toast{animation:toastSlideUp .35s var(--easeback)}
@keyframes toastSlideUp{from{opacity:0;transform:translateX(-50%) translateY(18px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ── Skeleton loading shimmer ── */
.skel{background:linear-gradient(90deg,var(--s2) 25%,var(--s3) 50%,var(--s2) 75%);
  background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:6px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Size button improved hover ── */
.szb{transition:all .18s var(--easeback)}
.szb:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(201,168,76,.2)}
.szb.on{transform:translateY(-1px);box-shadow:0 4px 14px rgba(201,168,76,.35)}

/* ── Card ATC button pulse when ready ── */
.card-atc.ready{position:relative;overflow:hidden}
.card-atc.ready::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.12);
  animation:atcPulse 1.8s ease infinite}
@keyframes atcPulse{0%,100%{opacity:0}50%{opacity:1}}

/* ── Improved scrollbar ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-thumb{background:var(--s3);border-radius:4px;transition:background .2s}
::-webkit-scrollbar-thumb:hover{background:var(--b3)}

/* ── Header nav active indicator ── */
.mainnav a.act{position:relative}
.mainnav a.act::after{content:'';position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);
  width:18px;height:2px;background:var(--gold);border-radius:2px}

/* ── Search result highlight ── */
.sitem:hover{transform:translateX(3px)}
.sitem{transition:all .18s var(--ease)}

/* ── Product modal close button ── */
.pmclose{transition:all .2s var(--easeback)}
.pmclose:hover{transform:rotate(90deg) scale(1.15)}

/* ── Improved filter buttons ── */
.filter-btn{transition:all .2s var(--easeback)}
.filter-btn.active{transform:translateY(-1px);box-shadow:0 4px 12px rgba(201,168,76,.2)}

/* ── Cart drawer item hover ── */
.cdi{transition:all .2s}
.cdi:hover{transform:translateX(2px)}

/* ── Better mobile touch targets ── */
@media(max-width:768px){
  .szb{min-width:46px;padding:9px 11px;font-size:.78rem}
  .card-szb{padding:5px 10px;font-size:.65rem}
  .product-card .wl-heart{opacity:1;transform:scale(1)}
}

/* ── Wishlist page empty state ── */
.wl-empty-heart{
  width:80px;height:80px;border-radius:50%;
  background:rgba(231,76,60,.08);border:1px solid rgba(231,76,60,.2);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;font-size:2rem;color:rgba(231,76,60,.4)}

/* ── Back-to-top via scroll progress ── */
.scroll-prog{position:fixed;top:0;left:0;height:2px;background:var(--gold);
  z-index:9999;transition:width .1s linear;pointer-events:none}

/* ── Focus visible outline (accessibility) ── */
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

/* ── Bot quick reply buttons ── */
.bb-quick-btns{display:flex;flex-wrap:wrap;gap:6px;padding:8px 14px 2px;border-top:1px solid var(--b)}
.bb-quick-btns button{font-size:.68rem;padding:5px 11px;border-radius:20px;border:1px solid var(--b2);
  background:var(--s2);color:var(--w80);cursor:pointer;transition:all .18s var(--easeback);font-family:var(--font-body);letter-spacing:.5px}
.bb-quick-btns button:hover{background:var(--gold);color:#000;border-color:var(--gold);transform:translateY(-1px)}

/* ═══════════════════════════════════════════════════
   TRUST BADGES
═══════════════════════════════════════════════════ */
.trust-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;padding:4px 9px}
.tbadge{display:flex;align-items:center;gap:10px;padding:10px 18px;background:var(--s2);border:1px solid var(--b);border-radius:var(--r);min-width:160px}
.tbadge i{font-size:1.2rem;flex-shrink:0}
.tbadge div{display:flex;flex-direction:column}
.tbadge strong{font-size:.74rem;font-weight:700;letter-spacing:.5px;color:var(--w)}
.tbadge span{font-size:.64rem;color:var(--w50);margin-top:1px}
@media(max-width:600px){.tbadge{min-width:calc(50% - 6px);flex:1}}

/* ═══════════════════════════════════════════════════
   CUSTOMER REVIEWS
═══════════════════════════════════════════════════ */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:9px}
.review-card{background:var(--surface);border:1px solid var(--b);border-radius:var(--rx);padding:20px;display:flex;flex-direction:column;gap:10px;transition:all .25s var(--ease)}
.review-card:hover{border-color:rgba(201,168,76,.35);transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.28)}
.review-top{display:flex;align-items:center;gap:10px}
.review-avatar{width:38px;height:38px;border-radius:50%;background:var(--golds);border:1px solid rgba(201,168,76,.4);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--gold);flex-shrink:0}
.review-name{font-size:.8rem;font-weight:700;color:var(--w)}
.review-loc{font-size:.66rem;color:var(--w50);margin-top:1px}
.review-badge{margin-left:auto;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;padding:3px 8px;border-radius:10px;background:var(--golds);color:var(--gold);border:1px solid rgba(201,168,76,.25);white-space:nowrap}
.review-stars{font-size:.85rem;color:var(--gold);letter-spacing:1px}
.review-text{font-size:.78rem;color:var(--w80);line-height:1.7;font-style:italic;flex:1}
.review-date{font-size:.64rem;color:var(--w20);margin-top:2px}

/* ═══════════════════════════════════════════════════
   INSTAGRAM FEED  +  9px padding on all grid/boxes
═══════════════════════════════════════════════════ */
.pgrid{padding:9px 0}
.trust-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;padding:9px}

.insta-feed-wrap{padding:9px 0}
.insta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:600px){.insta-grid{grid-template-columns:repeat(2,1fr);gap:10px}}
@media(max-width:380px){.insta-grid{grid-template-columns:1fr}}

.insta-post{display:block;text-decoration:none;border-radius:var(--r);overflow:hidden;background:var(--surface);border:1px solid var(--b);transition:all .28s var(--ease)}
.insta-post:hover{transform:translateY(-5px);box-shadow:0 14px 40px rgba(0,0,0,.45);border-color:rgba(201,168,76,.35)}
.insta-post-img{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--s2)}
.insta-post-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.insta-post:hover .insta-post-img img{transform:scale(1.07)}
.insta-hover{position:absolute;inset:0;background:rgba(0,0,0,.52);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity .25s var(--ease)}
.insta-post:hover .insta-hover{opacity:1}
.insta-hover i{font-size:1.4rem;margin-bottom:6px}
.insta-hover span{font-size:.72rem;letter-spacing:.8px}
.insta-play{position:absolute;top:10px;right:10px;width:28px;height:28px;background:rgba(0,0,0,.55);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.62rem}
.insta-multi{position:absolute;top:10px;right:10px;color:#fff;font-size:.8rem;filter:drop-shadow(0 1px 3px rgba(0,0,0,.6))}
.insta-cap{font-size:.72rem;color:var(--w80);padding:9px 11px 4px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.insta-date{font-size:.63rem;color:var(--w20);padding:0 11px 9px}
.insta-err{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--w20)}
.insta-skel{aspect-ratio:1/1;border-radius:var(--r)}
.insta-follow-cta{text-align:center;margin-top:18px;padding:9px}

/* CTA fallback when no token yet */
.insta-cta{background:var(--surface);border:1px solid var(--b);border-radius:var(--rx);padding:36px 24px;text-align:center;margin:9px 0}

/* Admin token setup banner (only admin sees this) */
.insta-setup{background:var(--surface);border:1px dashed var(--b2);border-radius:var(--rx);padding:24px;text-align:center;margin:9px 0}
.insta-setup-title{font-size:.82rem;font-weight:700;letter-spacing:.5px;color:var(--w);margin-bottom:6px}
.insta-setup p{font-size:.74rem;color:var(--w50);line-height:1.7;margin-bottom:14px}
.insta-token-row{display:flex;gap:8px;max-width:480px;margin:0 auto;flex-wrap:wrap}
.insta-token-row input{flex:1;min-width:180px;background:var(--deep);border:1px solid var(--b2);color:var(--w);border-radius:var(--r);padding:9px 12px;font-size:.78rem;font-family:var(--font-body);outline:none;transition:border-color .2s}
.insta-token-row input:focus{border-color:var(--gold)}
.insta-token-row button{background:var(--gold);color:#000;border:none;border-radius:var(--r);padding:9px 16px;font-size:.75rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .2s}
.insta-token-row button:hover{background:#b8942e}

/* ═══════════════════════════════════════════════════
   SALE TOP BAR
═══════════════════════════════════════════════════ */
#saleBar{position:fixed;top:0;left:0;right:0;z-index:9998;background:linear-gradient(90deg,#c9a84c,#a07a28,#c9a84c);color:#000;font-size:.78rem;font-weight:600;text-align:center}
.sale-bar-inner{padding:10px 16px;display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap}
/* push page down when bar present */
body:has(#saleBar) header{top:40px}
body:has(#saleBar){padding-top:40px}

/* ═══════════════════════════════════════════════════
   SALE HERO BANNER (homepage)
═══════════════════════════════════════════════════ */
.sale-hero-banner{background:linear-gradient(135deg,#c9a84c 0%,#a07a28 50%,#c9a84c 100%);border-radius:var(--rx);padding:28px 32px;display:flex;align-items:center;justify-content:space-between;gap:20px;cursor:pointer;transition:all .25s var(--ease);flex-wrap:wrap}
.sale-hero-banner:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(201,168,76,.35)}
.shb-left{flex:1}
.shb-badge{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:2.5px;color:rgba(0,0,0,.65);background:rgba(0,0,0,.12);display:inline-block;padding:3px 10px;border-radius:10px;margin-bottom:8px}
.shb-disc{font-family:var(--font-display);font-size:3.2rem;font-weight:600;color:#000;line-height:1;margin-bottom:4px}
.shb-title{font-size:.82rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(0,0,0,.75)}
.shb-dates{font-size:.72rem;color:rgba(0,0,0,.55);margin-top:8px}
.shb-right{text-align:center}
.shb-btn{background:#000;color:var(--gold);border:none;padding:13px 28px;border-radius:var(--r);font-size:.78rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:all .2s var(--ease);display:flex;align-items:center;gap:8px;white-space:nowrap}
.shb-btn:hover{background:#1a1a1a;transform:scale(1.03)}
@media(max-width:600px){.shb-disc{font-size:2.2rem}.sale-hero-banner{padding:22px 20px}.shb-btn{padding:12px 22px}}

/* ═══════════════════════════════════════════════════
   SALE POPUP
═══════════════════════════════════════════════════ */
#salePopup{position:fixed;inset:0;z-index:10000;opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
#salePopup.on{opacity:1;pointer-events:all}
.sp-bg{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(4px)}
.sp-box{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.94);background:var(--deep);border:1px solid var(--b2);border-radius:var(--rx);padding:36px 32px;width:min(92vw,480px);text-align:center;transition:transform .35s var(--easeback);box-shadow:0 24px 80px rgba(0,0,0,.6)}
#salePopup.on .sp-box{transform:translate(-50%,-50%) scale(1)}
.sp-x{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--w50);font-size:.9rem;cursor:pointer;padding:6px;transition:color .2s}
.sp-x:hover{color:var(--re)}
.sp-badge{display:inline-block;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:2px;background:var(--golds);color:var(--gold);border:1px solid rgba(201,168,76,.35);padding:4px 12px;border-radius:10px;margin-bottom:14px}
.sp-hl{font-family:var(--font-display);font-size:2rem;font-weight:600;letter-spacing:2px;color:var(--gold);line-height:1.1;margin-bottom:10px}
.sp-sub{font-size:.78rem;color:var(--w80);line-height:1.7;margin-bottom:10px}
.sp-exp{font-size:.7rem;color:var(--w50);margin-bottom:18px}
.sp-form{display:flex;gap:8px;flex-wrap:wrap}
.sp-form input{flex:1;min-width:160px;background:var(--surface);border:1px solid var(--b2);color:var(--w);border-radius:var(--r);padding:11px 14px;font-size:.82rem;font-family:var(--font-body);outline:none;transition:border-color .2s}
.sp-form input:focus{border-color:var(--gold)}
.sp-btn{background:var(--gold);color:#000;border:none;border-radius:var(--r);padding:11px 18px;font-size:.78rem;font-weight:700;letter-spacing:1px;cursor:pointer;display:flex;align-items:center;gap:7px;white-space:nowrap;transition:background .2s,transform .15s}
.sp-btn:hover{background:#b8942e;transform:scale(1.03)}
.sp-code{background:var(--golds);border:2px dashed var(--gold);border-radius:var(--r);padding:14px 20px;font-family:var(--font-display);font-size:2rem;letter-spacing:4px;color:var(--gold);font-weight:600;cursor:pointer;margin:12px 0;transition:background .2s}
.sp-code:hover{background:rgba(201,168,76,.2)}
.sp-skip{background:none;border:none;color:var(--w20);font-size:.68rem;cursor:pointer;margin-top:14px;padding:4px;transition:color .2s}
.sp-skip:hover{color:var(--w50)}
@media(max-width:480px){.sp-box{padding:26px 20px}.sp-hl{font-size:1.5rem}.sp-form{flex-direction:column}}

/* ═══════════════════════════════════════════════════
   POLICIES PAGE
═══════════════════════════════════════════════════ */
.pol-section{background:var(--surface);border:1px solid var(--b);border-radius:var(--rx);padding:24px 26px;margin-bottom:16px}
.pol-section-head{font-size:.88rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--w);margin-bottom:14px;display:flex;align-items:center;gap:9px}
.pol-body{font-size:.82rem;color:var(--w80);line-height:1.8}
.pol-body p{margin-bottom:10px}
.pol-body p:last-child{margin-bottom:0}
.pol-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:.78rem}
.pol-table th{text-align:left;padding:8px 12px;font-size:.66rem;text-transform:uppercase;letter-spacing:1px;color:var(--gold);border-bottom:1px solid var(--b2);font-weight:700}
.pol-table td{padding:9px 12px;border-bottom:1px solid var(--b)}
.pol-table tr:last-child td{border-bottom:none}
.pol-list{padding-left:18px;margin:8px 0}
.pol-list li{margin-bottom:6px}
.faq-item{border-bottom:1px solid var(--b);padding:12px 0}
.faq-item:last-child{border-bottom:none;padding-bottom:0}
.faq-q{font-weight:700;font-size:.8rem;color:var(--w);margin-bottom:5px}
.faq-a{font-size:.78rem;color:var(--w50);line-height:1.7}
/* ═══════════════════════════════════════════════════
   LEGAL PAGES
═══════════════════════════════════════════════════ */
.legal-nav-bar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:12px 16px;
  background:var(--surface);border:1px solid var(--b);border-radius:var(--r);margin-bottom:1.5rem;font-size:.74rem}
.legal-nav-bar a{color:var(--w80);text-decoration:none;display:flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:20px;border:1px solid var(--b);background:var(--s2);
  transition:all .18s var(--ease);white-space:nowrap}
.legal-nav-bar a:hover{background:var(--golds);border-color:rgba(201,168,76,.4);color:var(--gold)}

/* ═══════════════════════════════════════════════════
   FOOTER LEGAL LINKS
═══════════════════════════════════════════════════ */
.fbot{flex-direction:column;gap:12px;text-align:center}
.flegal{display:flex;flex-wrap:wrap;justify-content:center;gap:6px 16px}
.flegal a{font-size:.68rem;color:var(--w20);text-decoration:none;transition:color .2s;white-space:nowrap}
.flegal a:hover{color:var(--gold)}

/* ═══════════════════════════════════════════════════
   COOKIE / POPIA CONSENT BANNER
═══════════════════════════════════════════════════ */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9997;
  background:var(--void);border-top:1px solid var(--b2);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  padding:16px 24px;animation:cookieSlideUp .4s var(--easeback) both}
@keyframes cookieSlideUp{from{transform:translateY(100%);opacity:0}to{transform:none;opacity:1}}
@keyframes cookieSlideOut{from{transform:none;opacity:1}to{transform:translateY(100%);opacity:0}}
.cookie-inner{display:flex;align-items:center;gap:16px;max-width:1100px;margin:0 auto;flex-wrap:wrap}
.cookie-text{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:260px;
  font-size:.76rem;color:var(--w80);line-height:1.7}
.cookie-actions{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}
.cookie-accept{background:var(--gold);color:#000;border:none;border-radius:var(--r);
  padding:9px 18px;font-size:.74rem;font-weight:700;cursor:pointer;
  transition:background .2s,transform .15s;letter-spacing:.5px;white-space:nowrap}
.cookie-accept:hover{background:#b8942e;transform:scale(1.02)}
.cookie-decline{background:none;border:1px solid var(--b2);color:var(--w50);border-radius:var(--r);
  padding:9px 16px;font-size:.74rem;cursor:pointer;transition:all .2s;white-space:nowrap}
.cookie-decline:hover{border-color:var(--b3);color:var(--w80)}
@media(max-width:600px){
  .cookie-banner{padding:14px 16px}
  .cookie-accept,.cookie-decline{flex:1;text-align:center}
}