
:root{
  --bg:#070707;
  --bg-soft:#0f0f0f;
  --panel:#111111;
  --panel-2:#171717;
  --text:#f5f1eb;
  --muted:#b9afa1;
  --line:rgba(255,255,255,.08);
  --gold:#d8c08a;
  --gold-2:#ebd7a7;
  --shadow:rgba(0,0,0,.26);
  --radius:28px;
  --max:1280px;
}
body.theme-light{
  --bg:#f6efe6;
  --bg-soft:#fffaf4;
  --panel:#fffaf4;
  --panel-2:#f0e5d6;
  --text:#1f1915;
  --muted:#6f6559;
  --line:rgba(50,38,23,.11);
  --gold:#b89554;
  --gold-2:#d8bc84;
  --shadow:rgba(94,72,39,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  background:
    radial-gradient(circle at top right, rgba(216,192,138,.08), transparent 28%),
    radial-gradient(circle at left 20%, rgba(255,255,255,.03), transparent 22%),
    var(--bg);
  color:var(--text);
  line-height:1.5;
  transition:background-color .35s ease,color .35s ease;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button,input,select,textarea{font:inherit}
.container{width:min(var(--max), calc(100% - 40px));margin:0 auto}

.promo-bar{
  position:relative; overflow:hidden; min-height:52px; display:flex; align-items:center; justify-content:center;
  padding:0 16px; background:linear-gradient(90deg,#ead091,#d5b46f); color:#15110d; border-bottom:1px solid rgba(0,0,0,.05)
}
.promo-stack{position:relative;width:100%;max-width:1200px;min-height:24px}
.promo-item{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center; gap:8px; text-align:center;
  opacity:0; transform:translateY(10px); transition:opacity .65s ease, transform .65s ease;
  font-size:14px; font-weight:800; letter-spacing:.02em; line-height:1.35;
}
.promo-item strong{background:rgba(255,255,255,.25); padding:3px 8px; border-radius:999px}
.promo-item.is-active{opacity:1; transform:none}

.site-header{
  position:sticky; top:0; z-index:40; backdrop-filter:blur(14px);
  background:rgba(7,7,7,.84); border-bottom:1px solid var(--line); transition:background .28s ease, box-shadow .28s ease
}
body.theme-light .site-header{background:rgba(246,239,230,.88)}
.site-header.is-scrolled{box-shadow:0 12px 30px rgba(0,0,0,.18)}
.nav-wrap{min-height:88px; display:flex; align-items:center; justify-content:space-between; gap:20px}
.brand{display:inline-flex; align-items:center}
.logo{height:38px; width:auto}
.logo-lightmode{display:none}
body.theme-light .logo-darkmode{display:none}
body.theme-light .logo-lightmode{display:block}

.main-nav{display:flex; gap:28px; align-items:center}
.main-nav a{color:var(--muted); font-size:17px; position:relative; transition:color .25s ease}
.main-nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:-10px; height:2px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent); transform:scaleX(0); transition:transform .25s ease
}
.main-nav a:hover,.main-nav a.active{color:var(--text)}
.main-nav a:hover::after,.main-nav a.active::after{transform:scaleX(1)}

.nav-actions{display:flex; align-items:center; gap:12px}
.icon-btn,.menu-btn,.theme-toggle{
  border:1px solid var(--line); background:rgba(255,255,255,.03); color:var(--text); border-radius:999px; height:48px;
  display:inline-flex; align-items:center; justify-content:center; transition:transform .25s ease, box-shadow .25s ease, background-color .25s ease
}
.icon-btn,.menu-btn{padding:0 18px; min-width:48px}
.theme-toggle{padding:0 12px 0 10px; gap:10px}
.icon-btn:hover,.menu-btn:hover,.theme-toggle:hover,.btn:hover{transform:translateY(-2px); box-shadow:0 10px 24px var(--shadow)}
.menu-btn{display:none}
.switch-track{
  position:relative; width:50px; height:26px; border-radius:999px; background:rgba(216,192,138,.16); border:1px solid rgba(216,192,138,.22)
}
.switch-thumb{
  position:absolute; top:2px; left:2px; width:20px; height:20px; border-radius:50%; background:linear-gradient(135deg,var(--gold),var(--gold-2));
  box-shadow:0 6px 16px rgba(0,0,0,.18); transition:left .28s ease
}
body.theme-light .switch-thumb{left:26px}
.switch-label{font-size:14px; font-weight:700}

.section{padding:34px 0}
.hero{padding:54px 0 24px; position:relative; overflow:hidden}
.hero-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:24px; align-items:stretch}
.hero-card,.feature-card,.content-card,.product-card,.lookbook-card{
  position:relative; background:radial-gradient(circle at top left, rgba(255,255,255,.03), transparent 42%), var(--panel);
  border:1px solid var(--line); border-radius:var(--radius); box-shadow:0 18px 46px var(--shadow)
}
.hero-card,.feature-card,.content-card,.product-card,.lookbook-card,.newsletter-card{
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease, background-color .35s ease
}
.hero-card:hover,.feature-card:hover,.content-card:hover,.product-card:hover,.lookbook-card:hover{
  transform:translateY(-4px); box-shadow:0 24px 58px var(--shadow); border-color:rgba(216,192,138,.16)
}
.hero-card{padding:38px; min-height:620px; display:flex; flex-direction:column; justify-content:space-between}
.feature-grid{display:grid; gap:20px}
.feature-card{padding:26px; min-height:193px}
.eyebrow{
  display:inline-flex; width:max-content; padding:10px 16px; border-radius:999px; border:1px solid rgba(216,192,138,.22);
  background:rgba(216,192,138,.09); color:var(--gold); font-weight:700; font-size:14px
}
h1{font-size:clamp(48px,8vw,104px); line-height:.95; letter-spacing:-.05em; margin:18px 0; max-width:10ch}
h2{font-size:clamp(30px,4vw,48px); line-height:1.02; letter-spacing:-.04em; margin:0 0 14px}
h3{font-size:clamp(24px,3vw,34px); line-height:1.05; letter-spacing:-.03em; margin:0 0 10px}
.lead{font-size:clamp(18px,2vw,24px); color:var(--muted); max-width:34ch; margin:0 0 26px}
p{margin:0 0 14px}
.muted,.small{color:var(--muted)}
.actions{display:flex; gap:14px; flex-wrap:wrap}
.btn{
  height:56px; padding:0 28px; border-radius:999px; border:1px solid transparent; cursor:pointer; display:inline-flex; align-items:center;
  justify-content:center; font-weight:700
}
.btn-gold,.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-2)); color:#15110d}
.btn-outline{border-color:var(--line); background:transparent; color:var(--text)}
.btn-block{width:100%}

.stats-grid,.grid-3,.product-grid,.lookbook-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.stat-num{font-size:44px; font-weight:800}
.trust-card{text-align:center}
.trust-icon{
  width:58px; height:58px; border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 16px;
  color:var(--gold); background:rgba(216,192,138,.10); border:1px solid rgba(216,192,138,.18)
}

.product-card{padding:22px; min-height:470px; display:flex; flex-direction:column; justify-content:space-between; overflow:hidden}
.product-image{border-radius:22px; overflow:hidden; margin-bottom:18px; aspect-ratio:3/4; background:var(--panel-2)}
.product-image img{width:100%; height:100%; object-fit:cover; transition:transform .35s ease}
.product-card:hover .product-image img,.lookbook-card:hover img,.gallery-main:hover img{transform:scale(1.05)}
.product-tag,.badge{
  display:inline-flex; width:max-content; padding:8px 14px; border-radius:999px; background:rgba(216,192,138,.08);
  border:1px solid rgba(216,192,138,.16); color:var(--gold); font-weight:700; font-size:13px
}
.price-row{display:flex; align-items:end; gap:10px; flex-wrap:wrap; margin:12px 0 16px}
.price-now,.price{font-size:36px; font-weight:800}
.price-old,.old{text-decoration:line-through; color:var(--muted)}
.product-actions{display:flex; gap:12px; flex-wrap:wrap}
.product-actions .btn{flex:1}
.filter-bar{padding:16px 18px; margin-bottom:20px; border:1px solid var(--line); border-radius:20px; background:var(--panel)}

.page-hero{padding:48px 0 8px}
.content-card{padding:26px}
.checkout-grid,.product-layout,.contact-grid,.footer-grid{display:grid; grid-template-columns:1fr 1fr; gap:20px}
.field{display:grid; gap:8px; margin-bottom:14px}
input,select,textarea{
  width:100%; background:var(--panel-2); color:var(--text); border:1px solid var(--line); border-radius:18px; padding:15px 16px;
  transition:border-color .25s ease, background-color .35s ease
}
input:focus,select:focus,textarea:focus{outline:none; border-color:rgba(216,192,138,.28)}
textarea{min-height:140px; resize:vertical}

.gallery-main{background:var(--panel); border:1px solid var(--line); border-radius:26px; overflow:hidden; aspect-ratio:4/5}
.gallery-main img{width:100%; height:100%; object-fit:cover; transition:transform .35s ease}
.thumbs{display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:12px}
.thumbs img{width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:16px; border:1px solid var(--line); cursor:pointer; transition:transform .25s ease,border-color .25s ease}
.thumbs img:hover{transform:translateY(-2px); border-color:rgba(216,192,138,.24)}

.table-wrap{overflow:auto; border:1px solid var(--line); border-radius:20px}
.table{width:100%; border-collapse:collapse; min-width:620px}
.table th,.table td{padding:14px 16px; border-bottom:1px solid var(--line); text-align:left}
.table tbody tr:hover{background:rgba(216,192,138,.04)}

.drawer{
  position:fixed; top:0; right:-430px; width:min(420px,100vw); height:100vh; z-index:60; background:var(--panel); border-left:1px solid var(--line);
  box-shadow:-18px 0 40px var(--shadow); transition:right .35s ease
}
.drawer.open{right:0}
.drawer-head,.drawer-foot{padding:18px; border-bottom:1px solid var(--line)}
.drawer-foot{border-top:1px solid var(--line); border-bottom:none}
.drawer-body{padding:18px; overflow:auto; height:calc(100vh - 150px)}
.drawer-head{display:flex; justify-content:space-between; align-items:center}
.drawer-head button{background:none; border:none; color:var(--text); font-size:22px; cursor:pointer}
.cart-item{display:grid; grid-template-columns:84px 1fr auto; gap:12px; padding:12px 0; border-bottom:1px solid var(--line)}
.cart-item img{width:84px; height:108px; object-fit:cover; border-radius:14px}
.qty-mini{width:74px; padding:8px 10px; border-radius:12px; margin-top:8px}

.cookie-banner{
  position:fixed; left:20px; bottom:20px; z-index:70; max-width:440px; background:var(--panel); border:1px solid var(--line);
  border-radius:24px; padding:18px; box-shadow:0 16px 34px var(--shadow); display:flex; gap:16px; align-items:end
}
.hidden{display:none !important}
.newsletter-modal{position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:80; display:flex; align-items:center; justify-content:center; padding:20px}
.newsletter-card{
  width:min(480px,100%); background:var(--panel); border:1px solid var(--line); border-radius:28px; padding:28px; position:relative;
  box-shadow:0 24px 56px var(--shadow)
}
.newsletter-close{position:absolute; right:16px; top:16px; border:none; background:none; color:var(--text); font-size:22px; cursor:pointer}
.newsletter-form{display:grid; gap:12px}

.site-footer{border-top:1px solid var(--line); padding:30px 0 38px; margin-top:30px}
.footer-logo{height:36px; width:auto; margin-bottom:14px}
.footer-bottom{display:flex; justify-content:space-between; gap:16px; padding-top:16px; margin-top:16px; border-top:1px solid var(--line); color:var(--muted)}

.reveal-on-scroll{opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease}
.reveal-on-scroll.is-visible{opacity:1; transform:none}
.stagger-children > *{opacity:0; transform:translateY(18px); transition:opacity .55s ease, transform .55s ease}
.stagger-children.is-visible > *{opacity:1; transform:none}
.stagger-children.is-visible > *:nth-child(1){transition-delay:.05s}
.stagger-children.is-visible > *:nth-child(2){transition-delay:.11s}
.stagger-children.is-visible > *:nth-child(3){transition-delay:.17s}
.stagger-children.is-visible > *:nth-child(4){transition-delay:.23s}

.hero-card::before,.feature-card::before,.content-card::before,.product-card::before,.lookbook-card::before{
  content:""; position:absolute; inset:0; pointer-events:none; border-radius:inherit;
  background:linear-gradient(135deg, rgba(255,255,255,.04), transparent 28%, transparent 72%, rgba(216,192,138,.04))
}
.hero::before,.page-hero::before{
  content:""; position:absolute; width:30rem; height:30rem; right:-5rem; top:-6rem; border-radius:50%;
  background:radial-gradient(circle, rgba(216,192,138,.10), transparent 62%); filter:blur(10px); animation:orbFloat 12s ease-in-out infinite; pointer-events:none
}
.hero::after,.page-hero::after{
  content:""; position:absolute; width:24rem; height:24rem; left:-7rem; bottom:-8rem; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.05), transparent 60%); filter:blur(10px); animation:orbFloatTwo 14s ease-in-out infinite; pointer-events:none
}
@keyframes orbFloat{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(-18px,14px,0)}}
@keyframes orbFloatTwo{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(18px,-14px,0)}}

@media (max-width:1024px){
  .hero-grid,.checkout-grid,.product-layout,.contact-grid,.footer-grid,.grid-2{grid-template-columns:1fr}
  .stats-grid,.grid-3,.product-grid,.lookbook-grid{grid-template-columns:repeat(2,1fr)}
  .hero-card{min-height:auto}
}
@media (max-width:820px){
  .container{width:calc(100% - 28px)}
  .menu-btn{display:inline-flex}
  .main-nav{
    position:fixed; top:92px; left:14px; right:14px; display:none; flex-direction:column; gap:10px; padding:14px; background:var(--panel);
    border:1px solid var(--line); border-radius:22px; box-shadow:0 22px 46px var(--shadow)
  }
  body.menu-open .main-nav{display:flex}
  .main-nav a{padding:12px; border-radius:14px; background:rgba(255,255,255,.02)}
  .hero{padding-top:30px}
  .hero-card,.feature-card,.content-card,.product-card{padding:20px}
  h1{font-size:clamp(34px,10vw,56px); max-width:12ch}
  .promo-bar{min-height:58px}
  .promo-item{font-size:13px; padding:0 10px}
  .switch-label{display:none}
  .stats-grid,.grid-3,.product-grid,.lookbook-grid{grid-template-columns:1fr}
  .product-actions,.actions{flex-direction:column}
  .btn,.product-actions .btn{width:100%}
  .thumbs{grid-template-columns:repeat(3,1fr)}
  .footer-bottom{flex-direction:column; align-items:flex-start}
}
@media (max-width:560px){
  .cookie-banner{left:10px; right:10px; bottom:10px; max-width:none; flex-direction:column; align-items:flex-start}
  .nav-wrap{min-height:76px}
  .logo{height:30px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important; transition:none !important}
  .reveal-on-scroll,.stagger-children > *{opacity:1 !important; transform:none !important}
}


/* --- refined layout and visuals --- */
.page-hero .container,
.hero .container{
  position:relative;
  z-index:2;
}
.page-hero .container{
  max-width:1180px;
}
.page-hero h1,
.hero h1{
  max-width:8.5ch;
}
.page-hero .lead,
.hero .lead{
  max-width:22ch;
}
.page-hero{
  padding:56px 0 14px;
}
.page-hero .eyebrow{
  margin-bottom:10px;
}
.page-hero.reveal-on-scroll .container,
.hero .container{
  padding-left:8px;
}
@media (min-width: 1200px){
  .page-hero .container,
  .hero .container{
    width:min(1240px, calc(100% - 72px));
  }
  .page-hero.reveal-on-scroll .container,
  .hero .container{
    padding-left:28px;
  }
}
@media (max-width: 900px){
  .page-hero h1,
  .hero h1{
    max-width:10ch;
  }
  .page-hero .lead,
  .hero .lead{
    max-width:28ch;
  }
}

/* subtle fashion backdrop */
.page-hero.has-fashion-bg,
.hero.has-fashion-bg{
  overflow:hidden;
}
.page-hero.has-fashion-bg::before,
.hero.has-fashion-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(7,7,7,.92) 0%, rgba(7,7,7,.78) 38%, rgba(7,7,7,.88) 100%),
    url('https://images.unsplash.com/photo-1496747611176-843222e1e57c?auto=format&fit=crop&w=1400&q=70') right center / cover no-repeat;
  opacity:.18;
  pointer-events:none;
}
body.theme-light .page-hero.has-fashion-bg::before,
body.theme-light .hero.has-fashion-bg::before{
  background:
    linear-gradient(90deg, rgba(246,239,230,.94) 0%, rgba(246,239,230,.78) 38%, rgba(246,239,230,.88) 100%),
    url('https://images.unsplash.com/photo-1496747611176-843222e1e57c?auto=format&fit=crop&w=1400&q=70') right center / cover no-repeat;
  opacity:.22;
}

/* FAQ animation */
.faq-item{
  border-bottom:1px solid var(--line);
  padding:18px 0;
}
.faq-question{
  width:100%;
  text-align:left;
  background:none;
  border:none;
  color:var(--text);
  padding:0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  cursor:pointer;
  font-weight:700;
  font-size:22px;
}
.faq-question span:last-child{
  font-size:26px;
  color:var(--gold);
  transition:transform .28s ease;
}
.faq-answer{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .32s ease, opacity .32s ease;
  opacity:.7;
}
.faq-answer > div{
  overflow:hidden;
}
.faq-item.open .faq-answer{
  grid-template-rows:1fr;
  opacity:1;
}
.faq-item.open .faq-question span:last-child{
  transform:rotate(45deg);
}

/* better about/trust text rhythm */
.long-copy{
  max-width:78ch;
}
.long-copy p{
  margin-bottom:16px;
}
.copy-highlight{
  color:var(--gold);
  font-weight:700;
}

/* admin size chooser */
.size-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:10px;
  margin-top:8px;
}
.size-check{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  min-height:44px;
  border:1px solid var(--line);
  border-radius:14px;
  background:var(--panel-2);
  cursor:pointer;
  padding:8px;
}
.size-check input{
  display:none;
}
.size-check.active{
  border-color:rgba(216,192,138,.45);
  background:rgba(216,192,138,.08);
}
.size-check span{
  color:var(--text);
  font-weight:700;
}
@media (max-width:900px){
  .size-grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
}


/* --- final polish --- */
h1,h2,h3{
  text-wrap:balance;
}
.hero-card h1,
.page-hero h1{
  letter-spacing:-0.055em;
}
.page-hero{
  padding-top:64px;
  padding-bottom:22px;
}
.page-hero .lead{
  margin-top:8px;
}
.section{
  padding:42px 0;
}
.hero + .section{
  padding-top:24px;
}
.content-card,
.feature-card,
.product-card,
.lookbook-card{
  backdrop-filter: blur(10px);
}
.site-footer{
  position:relative;
  overflow:hidden;
}
.site-footer::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 85% 20%, rgba(216,192,138,.08), transparent 22%),
    radial-gradient(circle at 10% 80%, rgba(255,255,255,.04), transparent 18%);
  pointer-events:none;
}
.footer-grid{
  position:relative;
  z-index:1;
}
.footer-grid h4{
  font-size:18px;
  margin:0 0 12px;
  letter-spacing:-.02em;
}
.footer-grid p{
  margin-bottom:10px;
}
.footer-grid a{
  transition:opacity .22s ease, color .22s ease;
}
.footer-grid a:hover{
  opacity:1;
  color:var(--text);
}
.footer-bottom{
  position:relative;
  z-index:1;
}
.promo-bar{
  min-height:48px;
}
.promo-item{
  font-size:13px;
  letter-spacing:.03em;
}
.hero-card .actions,
.page-hero + .section .actions{
  margin-top:6px;
}
.content-card p:last-child,
.feature-card p:last-child,
.product-card p:last-child{
  margin-bottom:0;
}
.lookbook-card .btn,
.product-card .btn{
  min-height:52px;
}
@media (max-width: 1024px){
  .section{
    padding:34px 0;
  }
  .page-hero{
    padding-top:48px;
  }
}
@media (max-width: 820px){
  .section{
    padding:28px 0;
  }
  .page-hero{
    padding-top:40px;
    padding-bottom:8px;
  }
  .promo-bar{
    min-height:52px;
  }
  .promo-item{
    font-size:12px;
  }
}


/* --- model image + maps --- */
.page-hero.model-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(7,7,7,.92) 0%, rgba(7,7,7,.78) 42%, rgba(7,7,7,.88) 100%),
    url('https://images.unsplash.com/photo-1515886657613-9f3515b0c78f?auto=format&fit=crop&w=1600&q=80') right center / cover no-repeat;
  opacity:.22;
  pointer-events:none;
}
body.theme-light .page-hero.model-bg::before{
  background:
    linear-gradient(90deg, rgba(246,239,230,.94) 0%, rgba(246,239,230,.80) 42%, rgba(246,239,230,.88) 100%),
    url('https://images.unsplash.com/photo-1515886657613-9f3515b0c78f?auto=format&fit=crop&w=1600&q=80') right center / cover no-repeat;
  opacity:.26;
}
.map-card{
  overflow:hidden;
}
.map-embed{
  width:100%;
  min-height:420px;
  border:0;
  border-radius:22px;
}
.contact-grid{
  align-items:start;
}
.contact-info p{
  margin-bottom:12px;
}

/* --- stable patch additions --- */
.hero.model-bg::before,
.page-hero.model-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background-position:right center;
  background-size:cover;
  background-repeat:no-repeat;
  opacity:.22;
  pointer-events:none;
}
.hero.model-bg::after,
.page-hero.model-bg::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(7,7,7,.95) 0%, rgba(7,7,7,.84) 40%, rgba(7,7,7,.80) 100%);
  pointer-events:none;
}
body.theme-light .hero.model-bg::after,
body.theme-light .page-hero.model-bg::after{
  background:linear-gradient(90deg, rgba(246,239,230,.95) 0%, rgba(246,239,230,.88) 40%, rgba(246,239,230,.78) 100%);
}
.hero-home::before{background-image:url('assets/img/hero-home.jpg')}
.hero-about::before{background-image:url('assets/img/hero-about.jpg')}
.hero-contact::before{background-image:url('assets/img/hero-contact.jpg')}
.hero-faq::before{background-image:url('assets/img/hero-faq.jpg')}
.hero-lookbook::before{background-image:url('assets/img/hero-lookbook.jpg')}
.hero-shop::before{background-image:url('assets/img/hero-shop.jpg')}
.hero-product::before{background-image:url('assets/img/hero-product.jpg')}
.hero-checkout::before{background-image:url('assets/img/hero-checkout.jpg')}
.filter-panel{padding:18px 20px}
.shop-filters{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:14px;
  align-items:end;
}
.filter-actions{
  display:flex;
  gap:12px;
  align-items:end;
  flex-wrap:wrap;
}
.product-meta-row{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom:8px;
}
.status-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  padding:8px 14px;
  border-radius:999px;
  font-weight:700;
  font-size:13px;
  border:1px solid var(--line);
}
.status-tag.in-stock{
  background:rgba(216,192,138,.08);
  color:var(--gold);
  border-color:rgba(216,192,138,.18);
}
.status-tag.sold-out{
  background:rgba(255,255,255,.04);
  color:var(--muted);
}
button[disabled]{
  opacity:.7;
  cursor:not-allowed;
}
@media (max-width:1024px){
  .shop-filters{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }
}
@media (max-width:720px){
  .shop-filters{
    grid-template-columns:1fr;
  }
}

/* --- feature pack extras --- */
.whatsapp-float{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:85;
  height:58px;
  padding:0 20px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));
  color:#17120d;
  box-shadow:0 16px 36px rgba(0,0,0,.24);
}
.review-card strong{display:block;margin-top:10px}
@media (max-width:720px){
  .whatsapp-float{right:12px;bottom:12px;height:54px;padding:0 18px}
}

/* hero upload admin */
.hero-upload-card{
  padding:14px;
  border:1px solid var(--line);
  border-radius:18px;
  background:var(--panel-2);
}
.hero-thumb{
  margin-top:10px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--line);
  max-width:100%;
}
.hero-thumb img{
  width:100%;
  height:180px;
  object-fit:cover;
  display:block;
}

/* robust hero inline background fix */
.hero.model-bg[style]::before,
.page-hero.model-bg[style]::before{
  background-image:none !important;
}
