:root,
[data-theme="dark"]{
  --bg:#0a0a09;
  --bg-soft:#141210;
  --card:#1c1916;
  --gold:#d4af37;
  --gold-light:#f0dca0;
  --ink:#f0ead8;
  --ink-dim:#a89a7c;
  --border:#3a3326;
  --card-light:#201c16;
  --card-light-border:#4d4330;
  --ink-strong:#f0ead8;
  --ink-dim-light:#a89a7c;
  --price-accent:#e8c875;
  --on-accent:#1a1610;
  --header-bg:rgba(16,16,15,.92);
  --hero-text:#f0ead8;
  --hero-accent:#f0dca0;
  --hero-accent-dim:#d4af37;
  --hero-overlay-rgb:8,8,7;
  --hero-overlay-a1:.7;
  --hero-overlay-a2:.92;
  --hero-shadow:rgba(0,0,0,.7);
  --banner-bg:#241d13;
  --banner-border:#564a2c;
}

[data-theme="light"]{
  --bg:#f6f2e8;
  --bg-soft:#ece5d3;
  --card:#ffffff;
  --gold:#2f6f62;
  --gold-light:#4f9484;
  --ink:#2c2a25;
  --ink-dim:#6e6757;
  --border:#ded4bd;
  --card-light:#ffffff;
  --card-light-border:#e2d8c2;
  --ink-strong:#221f1a;
  --ink-dim-light:#7d7464;
  --price-accent:#2f6f62;
  --on-accent:#fbf8f1;
  --header-bg:rgba(255,255,255,.92);
  --hero-text:#332f27;
  --hero-accent:#1f5c50;
  --hero-accent-dim:#15463d;
  --hero-overlay-rgb:255,252,244;
  --hero-overlay-a1:.58;
  --hero-overlay-a2:.85;
  --hero-shadow:rgba(255,255,255,.85);
  --banner-bg:#eef6f3;
  --banner-border:#bfe0d6;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:'Work Sans',Arial,sans-serif;
  line-height:1.5;
}
a{color:var(--gold-light);text-decoration:none;}
h1,h2,h3{font-family:'Poppins',Arial,sans-serif; font-weight:600;}
.logo{font-family:'Cinzel','Georgia',serif;}

/* ---------- Header ---------- */
header{
  position:sticky; top:0; z-index:50;
  background:var(--header-bg);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--border);
}
.nav-wrap{
  position:relative;
  max-width:1180px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap;
  padding:14px 24px; gap:10px;
}
.header-actions{
  display:flex; align-items:center; gap:8px;
}
.logo{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px;
  font-size:1.2rem; letter-spacing:.06em; color:var(--gold-light); text-align:center;
}
.logo .mark-wrap{width:150px;}

.mark-wrap{position:relative; display:inline-block; flex:none;}
.mark-wrap .mark{display:block; width:100%; height:auto; fill:currentColor; opacity:.8;}
.mark-shine{
  position:absolute; inset:0;
  background:linear-gradient(115deg, transparent 35%, rgba(255,255,255,.85) 50%, transparent 65%);
  background-size:260% 100%;
  background-position:200% 0;
  -webkit-mask-image:url('../img/logo.svg'); mask-image:url('../img/logo.svg');
  -webkit-mask-size:contain; mask-size:contain;
  -webkit-mask-repeat:no-repeat; mask-repeat:no-repeat;
  -webkit-mask-position:center; mask-position:center;
  animation:logoShine 13s ease-in-out infinite;
  pointer-events:none;
}
@keyframes logoShine{
  0%{background-position:200% 0;}
  50%{background-position:-100% 0;}
  100%{background-position:200% 0;}
}
@media (prefers-reduced-motion:reduce){
  .mark-shine{animation:none; display:none;}
}

.theme-toggle{
  flex:none; width:34px; height:34px; border-radius:50%; cursor:pointer;
  display:flex; align-items:center; justify-content:center; font-size:1rem; line-height:1;
  background:transparent; border:1px solid var(--border); color:var(--gold-light);
  transition:all .2s;
}
.theme-toggle:hover{border-color:var(--gold); background:var(--card-light);}

.lang-select{
  position:relative;
  font-family:'Montserrat',sans-serif; font-size:.7rem; letter-spacing:.04em;
  cursor:pointer; outline:none;
}
.lang-current{
  display:flex; align-items:center; gap:6px;
  padding:6px 10px; border-radius:14px;
  background:transparent; border:1px solid var(--border); color:var(--ink-dim);
  transition:all .2s;
}
.lang-select:hover .lang-current,
.lang-select:focus .lang-current,
.lang-select.open .lang-current{border-color:var(--gold); color:var(--gold-light);}
.lang-current img{width:16px; height:11px; flex:none; border-radius:2px; box-shadow:0 0 0 1px rgba(0,0,0,.25);}
.lang-options{
  position:absolute; top:calc(100% + 6px); right:0; z-index:60;
  list-style:none; margin:0; padding:6px;
  min-width:84px; border-radius:10px;
  background:var(--card); border:1px solid var(--border);
  box-shadow:0 10px 28px rgba(0,0,0,.35);
  display:none; flex-direction:column; gap:2px;
}
.lang-select.open .lang-options{display:flex;}
.lang-options li{
  display:flex; align-items:center; gap:8px;
  padding:6px 8px; border-radius:6px; color:var(--ink-dim); cursor:pointer;
}
.lang-options li img{width:16px; height:11px; flex:none; border-radius:2px; box-shadow:0 0 0 1px rgba(0,0,0,.25);}
.lang-options li:hover{background:var(--bg-soft); color:var(--gold-light);}
.lang-options li.active{color:var(--gold-light); font-weight:600;}

nav ul{
  display:flex; gap:18px; list-style:none; margin:0; padding:0;
  font-family:'Montserrat',sans-serif; font-size:.78rem;
  letter-spacing:.03em; text-transform:uppercase;
}
nav a{color:var(--ink-dim); transition:color .2s;}
nav a:hover{color:var(--gold-light);}
nav a.active-link{color:var(--gold-light);}
nav .nav-sep{margin-left:4px; padding-left:18px; border-left:1px solid var(--border);}
.nav-toggle{display:none;}

.nav-dropdown{position:relative;}
.nav-dropdown-toggle{
  font:inherit; letter-spacing:inherit; text-transform:inherit;
  background:none; border:none; padding:0; margin:0; cursor:pointer;
  color:var(--ink-dim); display:inline-flex; align-items:center; gap:5px;
  transition:color .2s;
}
.nav-dropdown-toggle::after{content:"▾"; font-size:.7em; opacity:.8;}
.nav-dropdown-toggle:hover{color:var(--gold-light);}
.nav-dropdown.open .nav-dropdown-toggle{color:var(--gold-light);}
.nav-dropdown-menu{
  position:absolute; top:calc(100% + 10px); left:0; z-index:60;
  list-style:none; margin:0; padding:6px;
  min-width:200px; border-radius:10px;
  background:var(--card); border:1px solid var(--border);
  box-shadow:0 10px 28px rgba(0,0,0,.35);
  display:none; flex-direction:column; gap:2px;
}
.nav-dropdown.open .nav-dropdown-menu{display:flex;}
.nav-dropdown-menu a{
  display:block; padding:8px 10px; border-radius:6px;
  text-transform:none; letter-spacing:0; font-size:.82rem;
}
.nav-dropdown-menu a:hover{background:var(--bg-soft);}

.store-link{
  flex:none; font-family:'Montserrat',sans-serif; font-size:.72rem;
  letter-spacing:.05em; text-transform:uppercase; white-space:nowrap;
  padding:7px 14px; border-radius:14px;
  border:1px solid var(--gold); color:var(--gold-light);
  transition:all .2s;
}
.store-link:hover{background:var(--gold); color:var(--on-accent);}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:120px 24px 90px;
  text-align:center;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(var(--hero-overlay-rgb),var(--hero-overlay-a1)) 0%, rgba(var(--hero-overlay-rgb),var(--hero-overlay-a2)) 60%, var(--bg) 100%),
    url('../img/hero-room.jpg') center 25% / cover no-repeat;
}
.hero h1{
  font-size:2.7rem; margin:0 0 14px; color:var(--hero-accent);
  letter-spacing:.03em; text-shadow:0 2px 18px var(--hero-shadow);
}
.hero p{
  max-width:620px; margin:0 auto 28px; color:var(--hero-text);
  font-size:1.05rem; text-shadow:0 2px 10px var(--hero-shadow);
}
.hero .tagline{
  font-family:'Montserrat',sans-serif;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--hero-accent-dim); margin-bottom:10px;
}
.btn{
  display:inline-block; padding:12px 30px;
  border:1px solid var(--hero-accent-dim); color:var(--hero-accent);
  font-family:'Montserrat',sans-serif; font-size:.8rem;
  letter-spacing:.12em; text-transform:uppercase;
  border-radius:2px; transition:all .25s; background:rgba(var(--hero-overlay-rgb),.45);
}
.btn:hover{background:var(--hero-accent-dim); color:var(--on-accent);}

/* ---------- Section shell ---------- */
section.category{
  max-width:1180px; margin:0 auto; padding:64px 24px 10px;
}
.section-head{text-align:center; margin-bottom:30px;}
.section-head .kicker{
  font-family:'Montserrat',sans-serif; font-size:.75rem;
  letter-spacing:.2em; text-transform:uppercase; color:var(--gold);
}
.section-head h2{font-size:1.9rem; margin:6px 0 10px; color:var(--ink);}
.section-head p{color:var(--ink-dim); max-width:560px; margin:0 auto; font-size:.95rem;}
.divider{width:60px; height:2px; background:var(--gold); margin:16px auto 0; opacity:.6;}

/* ---------- Banner (category illustrative photo) ---------- */
.banner{
  display:flex; align-items:center; gap:36px;
  background:var(--banner-bg); border:1px solid var(--banner-border); border-radius:8px;
  padding:22px; margin-bottom:36px; overflow:hidden;
}
.banner img{
  width:200px; height:200px; object-fit:contain; flex:none;
  filter:drop-shadow(0 10px 20px rgba(0,0,0,.5));
}
.banner .banner-text{color:var(--ink-dim); font-size:1.15rem; line-height:1.5;}
.banner .banner-text strong{color:var(--gold-light); display:block; font-size:1.4rem; margin-bottom:8px;}
@media (max-width:640px){
  .banner{flex-direction:column; text-align:center;}
}

/* ---------- Grid / Cards ---------- */
.grid{
  display:grid; gap:22px;
  grid-template-columns:repeat(auto-fill,minmax(max(210px,(100% - 44px)/3),1fr));
  margin-bottom:18px;
}
.card{
  position:relative;
  background:var(--card-light);
  border:1px solid var(--card-light-border);
  border-radius:6px;
  padding:18px 16px 18px;
  text-align:center;
  transition:transform .25s, border-color .25s, box-shadow .25s, z-index .25s;
}
.card:hover{
  transform:translateY(-4px);
  border-color:var(--gold);
  box-shadow:0 10px 28px rgba(0,0,0,.35);
  z-index:5;
}
.card .thumb{
  position:relative;
  width:100%; height:148px; display:flex; align-items:center; justify-content:center;
  margin-bottom:12px; overflow:visible;
}
.card .thumb img{
  max-width:100%; max-height:100%; object-fit:contain;
  filter:drop-shadow(0 6px 10px rgba(60,50,30,.22));
  transition:transform .25s ease;
  cursor:zoom-in;
}
.card .thumb:hover img{
  transform:scale(1.7);
  position:relative;
  z-index:10;
}
.card h3{font-size:1rem; margin:0 0 6px; color:var(--ink-strong); font-weight:600;}
.card .codes{
  font-family:'Consolas',monospace; font-size:.68rem; color:var(--ink-dim-light);
  margin-bottom:8px; word-break:break-word;
}
.card .sizes{font-size:.78rem; color:var(--ink-dim-light); margin-bottom:10px;}
.card .price{font-family:'Montserrat',sans-serif; font-size:.95rem; color:var(--price-accent);}
.card .price span{
  font-size:.66rem; color:var(--ink-dim-light); display:block; letter-spacing:.08em;
  text-transform:uppercase; margin-top:2px;
}

.cat-note{text-align:center; font-size:.82rem; color:var(--ink-dim); margin-bottom:30px;}

/* ---------- Option blocks (type / colour / style / size) ---------- */
.option-block{
  position:relative; margin-top:16px; padding-top:14px;
}
.option-block::before{
  content:""; position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:36px; height:2px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity:.7;
}
.option-row{
  display:flex; flex-wrap:wrap; gap:8px; justify-content:center;
}
.opt-btn{
  font-family:'Montserrat',sans-serif; font-size:.68rem; letter-spacing:.03em;
  padding:6px 12px; border-radius:14px; cursor:pointer;
  background:transparent; border:1px solid var(--card-light-border); color:var(--ink-dim-light);
  transition:all .2s;
}
.opt-btn:hover{border-color:var(--gold); color:var(--ink-strong);}
.opt-btn.active{background:var(--gold); border-color:var(--gold); color:var(--on-accent); font-weight:600;}
.type-switch .opt-btn{border-radius:4px;}
.size-switch .opt-btn{border-radius:4px;}

.item-note{font-size:.78rem; color:var(--ink-dim-light); margin-bottom:6px;}

/* ---------- Article / price detail block ---------- */
.product-details{
  display:none; margin-top:14px; padding-top:10px; border-top:1px solid var(--card-light-border);
}
.product-details.visible{display:block;}
.detail-row{
  display:flex; justify-content:space-between; align-items:baseline;
  font-size:.78rem; padding:3px 0;
}
.detail-row .detail-label{
  font-family:'Montserrat',sans-serif; font-size:.64rem; letter-spacing:.08em;
  text-transform:uppercase; color:var(--ink-dim-light);
}
.detail-row .detail-value{
  font-family:'Consolas',monospace; font-size:.74rem; color:var(--ink-strong); font-weight:600;
}
.detail-row.detail-price{justify-content:center; margin-top:6px;}
.detail-price .detail-value{width:100%;}

.amazon-link{
  display:inline-block;
  font-family:'Montserrat',sans-serif; font-size:.7rem; letter-spacing:.05em;
  text-transform:uppercase; padding:6px 14px; border-radius:14px;
  border:1px solid var(--gold); color:var(--gold-light);
  transition:all .2s;
}
.amazon-link:hover{background:var(--gold); color:var(--on-accent);}

/* ---------- Footer ---------- */
footer{
  margin-top:80px; border-top:1px solid var(--border);
  padding:40px 24px 30px; text-align:center; color:var(--ink-dim); font-size:.85rem;
}
footer .mark-wrap{width:140px; margin:0 auto 14px; color:var(--gold);}
footer a{color:var(--gold-light);}
footer .legal{font-size:.72rem; margin-top:16px; opacity:.6;}
.footer-nav{display:flex; justify-content:center; gap:18px; margin-top:14px; font-size:.85rem;}

@media (max-width:760px){
  nav ul{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; gap:0;
    background:var(--bg-soft); border-top:1px solid var(--border);
    display:none;
  }
  nav ul.open{display:flex;}
  nav li{border-bottom:1px solid var(--border);}
  nav a{display:block; padding:14px 24px;}
  nav .nav-sep{margin-left:0; padding-left:0; border-left:none;}
  .nav-toggle{
    display:flex; align-items:center; justify-content:center;
    position:absolute; top:14px; right:24px;
    width:34px; height:34px; padding:0; line-height:1;
    background:none; border:none; color:var(--gold-light); font-size:1.4rem; cursor:pointer;
  }
  .nav-dropdown-toggle{display:block; width:100%; padding:14px 24px; text-align:left;}
  .nav-dropdown-menu{
    position:static; box-shadow:none; border:none; border-radius:0;
    background:var(--card-light); padding:0; min-width:0;
  }
  .nav-dropdown-menu a{padding:12px 36px; border-radius:0;}
  .header-actions{order:1; flex-wrap:wrap; justify-content:flex-end; gap:8px 10px; margin-left:auto;}
  .hero h1{font-size:1.9rem;}
}

/* ---------- Contacts page ---------- */
.contact-grid{
  display:grid; gap:18px; margin-bottom:36px;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
}
.contact-card{
  background:var(--card-light); border:1px solid var(--card-light-border); border-radius:8px;
  padding:18px; text-align:center;
}
.contact-card strong{display:block; color:var(--ink-strong); margin-bottom:8px; font-size:.95rem;}
.contact-card .placeholder{color:var(--ink-dim-light); font-size:.85rem; font-style:italic;}

/* ---------- Feedback form ---------- */
.feedback-form{
  max-width:520px; margin:0 auto 60px;
  display:flex; flex-direction:column; gap:18px;
}
.feedback-form label{
  display:flex; flex-direction:column; gap:6px;
  font-size:.85rem; color:var(--ink-dim);
}
.feedback-form input,
.feedback-form textarea{
  font-family:'Montserrat',sans-serif; font-size:.9rem;
  background:var(--card-light); border:1px solid var(--card-light-border); border-radius:6px;
  padding:10px 12px; color:var(--ink-strong); resize:vertical;
}
.feedback-form input:focus,
.feedback-form textarea:focus{outline:none; border-color:var(--gold);}
.btn-solid{
  align-self:flex-start;
  font-family:'Montserrat',sans-serif; font-size:.8rem; letter-spacing:.08em;
  text-transform:uppercase; padding:11px 28px; border-radius:4px; cursor:pointer;
  background:var(--gold); border:1px solid var(--gold); color:var(--on-accent);
  transition:opacity .2s;
}
.btn-solid:hover{opacity:.85;}
.form-status{font-size:.85rem; color:var(--price-accent); min-height:1.2em;}
