
: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}
}
