/* ══════════════════════════════════════════
   KOKOON — style.css
   Core design tokens, layout, components
══════════════════════════════════════════ */

:root {
  /* Silk Color Palette */
  --silk-cream:   #f9f5ef;
  --silk-warm:    #fdf9f4;
  --silk-gold:    #b8935a;
  --silk-gold-lt: #dfc49a;
  --silk-gold-pl: #f0e3cc;
  --silk-deep:    #1c1209;
  --silk-char:    #2d1f10;
  --silk-muted:   #8a7260;
  --silk-border:  rgba(184,147,90,.22);
  --silk-blush:   #e9d5c3;
  --silk-rouge:   #b86b6b;
  --silk-sage:    #8fa88e;
  --silk-pearl:   #ede7de;
  --silk-sheen:   rgba(255,248,235,.14);

  --font-display: 'Cormorant Garamond', serif;
  --font-body:    'Nunito Sans', sans-serif;

  --text-xs:   11px;
  --text-sm:   13px;
  --text-base: 15px;
  --text-md:   17px;
  --text-lg:   20px;
  --text-xl:   24px;
  --text-2xl:  32px;
  --text-3xl:  clamp(28px, 4vw, 48px);
  --text-4xl:  clamp(40px, 6vw, 72px);
  --text-hero: clamp(48px, 8vw, 100px);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:var(--font-body); background:var(--silk-warm); color:var(--silk-deep); overflow-x:hidden; -webkit-font-smoothing:antialiased; }

/* ─── ANNOUNCEMENT BAR ─── */
.ann { background:var(--silk-deep); color:var(--silk-gold-lt); text-align:center; padding:11px 16px; font-size:var(--text-xs); letter-spacing:2.5px; text-transform:uppercase; font-weight:300; }

/* ─── HEADER ─── */
header { position:sticky; top:0; z-index:1000; background:rgba(253,249,244,.96); backdrop-filter:blur(16px); border-bottom:1px solid var(--silk-border); }
.hdr { max-width:1440px; margin:0 auto; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; padding:0 48px; height:68px; }
.nav-links { display:flex; gap:32px; }
.nav-links button { background:none; border:none; font-family:var(--font-body); font-size:var(--text-xs); letter-spacing:2.5px; text-transform:uppercase; color:var(--silk-char); cursor:pointer; font-weight:500; position:relative; transition:color .25s; padding:0; }
.nav-links button::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:1px; background:var(--silk-gold); transition:width .3s; }
.nav-links button:hover, .nav-links button.active { color:var(--silk-gold); }
.nav-links button:hover::after, .nav-links button.active::after { width:100%; }
.logo-wrap { text-align:center; cursor:pointer; }
.logo-wrap h1 { font-family:var(--font-display); font-size:var(--text-2xl); font-weight:300; letter-spacing:10px; text-transform:uppercase; line-height:1; }
.logo-wrap span { display:block; font-size:9px; letter-spacing:5px; color:var(--silk-gold); font-weight:300; text-transform:uppercase; margin-top:2px; }
.hdr-actions { display:flex; justify-content:flex-end; align-items:center; gap:14px; }
.hdr-actions button { background:none; border:none; font-family:var(--font-body); font-size:var(--text-xs); letter-spacing:1.5px; text-transform:uppercase; cursor:pointer; color:var(--silk-char); transition:color .25s; font-weight:500; }
.hdr-actions button:hover { color:var(--silk-gold); }
.cart-btn-hdr { background:var(--silk-deep)!important; color:var(--silk-gold-lt)!important; padding:9px 20px!important; border-radius:1px; }
.cart-btn-hdr:hover { background:var(--silk-gold)!important; color:var(--silk-deep)!important; }
.cart-count { background:var(--silk-gold); color:var(--silk-deep); border-radius:50%; width:17px; height:17px; font-size:9px; display:inline-flex; align-items:center; justify-content:center; font-weight:700; margin-left:5px; }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:4px; }
.hamburger span { display:block; width:22px; height:1.5px; background:var(--silk-char); transition:all .3s; }
.mobile-menu { display:none; position:fixed; inset:0; background:var(--silk-deep); z-index:2000; flex-direction:column; align-items:center; justify-content:center; gap:32px; }
.mobile-menu.open { display:flex; }
.mobile-menu button { background:none; border:none; font-family:var(--font-display); font-size:32px; color:var(--silk-cream); cursor:pointer; letter-spacing:4px; font-weight:300; transition:color .2s; }
.mobile-menu button:hover { color:var(--silk-gold); }
.mobile-menu-close { position:absolute; top:24px; right:24px; background:none; border:none; color:var(--silk-gold); font-size:28px; cursor:pointer; }
.mobile-cart-row { display:flex; align-items:center; gap:10px; margin-top:16px; }

/* ─── PAGE SYSTEM ─── */
.page { display:none; animation:fadeIn .35s ease; }
.page.active { display:block; }
@keyframes fadeIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
#page-admin-login { display:none; }
#page-admin-login.active { display:flex!important; }
#page-admin { display:none; }
#page-admin.active { display:block; }

/* ─── TOAST ─── */
.toast { position:fixed; bottom:28px; right:28px; background:var(--silk-deep); color:var(--silk-cream); padding:16px 24px; z-index:9999; font-size:var(--text-sm); border-left:3px solid var(--silk-gold); transform:translateX(140%); transition:transform .4s cubic-bezier(.25,.46,.45,.94); max-width:320px; font-weight:300; line-height:1.5; }
.toast.show { transform:translateX(0); }
.toast strong { color:var(--silk-gold); font-weight:600; }

/* ─── UTILITIES ─── */
.container { max-width:1440px; margin:0 auto; padding:0 60px; }
.sec-label { font-size:10px; letter-spacing:5px; text-transform:uppercase; color:var(--silk-gold); font-weight:500; margin-bottom:14px; display:flex; align-items:center; gap:14px; }
.sec-label::before { content:''; width:32px; height:1px; background:var(--silk-gold); }
.sec-title { font-family:var(--font-display); font-size:var(--text-3xl); font-weight:300; color:var(--silk-deep); line-height:1.1; margin-bottom:16px; }
.sec-sub { font-size:var(--text-base); color:var(--silk-muted); font-weight:300; line-height:1.8; letter-spacing:.2px; }

/* ─── BUTTONS ─── */
.btn-primary { background:var(--silk-gold); color:var(--silk-deep); border:none; padding:15px 42px; font-size:10px; letter-spacing:3px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); font-weight:600; transition:all .3s; display:inline-block; text-decoration:none; }
.btn-primary:hover { background:var(--silk-deep); color:var(--silk-gold); }
.btn-outline { background:transparent; border:1px solid var(--silk-border); color:var(--silk-muted); padding:14px 42px; font-size:10px; letter-spacing:3px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); font-weight:400; transition:all .3s; }
.btn-outline:hover { border-color:var(--silk-gold); color:var(--silk-gold); }
.btn-dark { background:var(--silk-deep); color:var(--silk-gold-lt); border:none; padding:15px 42px; font-size:10px; letter-spacing:3px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); font-weight:500; transition:background .3s; }
.btn-dark:hover { background:var(--silk-char); }

/* ─── SILK COLOR CLASSES ─── */
.c-champagne { background:linear-gradient(145deg,#edd5b0,#c9a96e,#b8935a); }
.c-noir       { background:linear-gradient(145deg,#2a1e14,#1c1209,#382510); }
.c-rose       { background:linear-gradient(145deg,#e8c0c4,#c48090,#d4909a); }
.c-silver     { background:linear-gradient(145deg,#d8d8e0,#b8b8c8,#c8c8d8); }
.c-lake       { background:linear-gradient(145deg,#b8d0e0,#7090b8,#90b0d0); }
.c-sage       { background:linear-gradient(145deg,#c0d4b8,#8aa880,#a0c098); }
.c-mauve      { background:linear-gradient(145deg,#d8c0d0,#b090a8,#c8a8c0); }
.c-ruby       { background:linear-gradient(145deg,#e0a0a0,#b85050,#d07070); }
.c-midnight   { background:linear-gradient(145deg,#303060,#1a1a40,#282858); }
.c-ivory      { background:linear-gradient(145deg,#f5eed8,#e8d8a8,#f0e4c0); }
.c-charcoal   { background:linear-gradient(145deg,#707070,#454545,#585858); }
.c-blush      { background:linear-gradient(145deg,#f0d8d0,#d8b0a8,#e8c8c0); }
.c-custom     { background:linear-gradient(145deg,#d4c8b8,#b8a888,#c8b898); }
.silk-sheen::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.22) 0%,transparent 45%,rgba(255,255,255,.1) 100%); pointer-events:none; }

/* ─── HERO ─── */
.hero { position:relative; height:94vh; min-height:580px; overflow:hidden; }
.hero-slides { position:absolute; inset:0; display:flex; transition:transform .75s cubic-bezier(.77,0,.18,1); will-change:transform; }
.hero-slide { position:relative; min-width:100%; height:100%; flex-shrink:0; display:flex; align-items:center; overflow:hidden; }
.hero-slide-bg { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform 8s ease; }
.hero-slide.active .hero-slide-bg { transform:scale(1.06); }
.hero-slide-overlay { position:absolute; inset:0; background:linear-gradient(100deg,rgba(18,10,4,.82) 0%,rgba(18,10,4,.45) 55%,rgba(18,10,4,.15) 100%); }
.hero-content { position:relative; z-index:2; max-width:1440px; margin:0 auto; padding:0 80px; width:100%; }
.hero-eyebrow { font-size:10px; letter-spacing:5px; text-transform:uppercase; color:var(--silk-gold); font-weight:400; margin-bottom:26px; display:flex; align-items:center; gap:18px; }
.hero-eyebrow::before { content:''; width:44px; height:1px; background:var(--silk-gold); }
.hero h2 { font-family:var(--font-display); font-size:var(--text-hero); font-weight:300; color:var(--silk-cream); line-height:1.04; max-width:700px; margin-bottom:28px; }
.hero h2 em { font-style:italic; color:var(--silk-gold); }
.hero-desc { font-size:var(--text-base); color:rgba(249,245,239,.72); line-height:1.85; max-width:420px; margin-bottom:48px; font-weight:300; }
.hero-ctas { display:flex; gap:16px; flex-wrap:wrap; }
.hero-ghost { border:1px solid rgba(249,245,239,.32); color:var(--silk-cream); padding:14px 40px; font-size:10px; letter-spacing:3px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); transition:all .3s; background:transparent; font-weight:400; }
.hero-ghost:hover { border-color:var(--silk-gold); color:var(--silk-gold); }
.hero-dots { position:absolute; bottom:32px; left:50%; transform:translateX(-50%); display:flex; gap:10px; z-index:10; }
.hero-dot { width:28px; height:2px; background:rgba(249,245,239,.3); cursor:pointer; transition:all .35s; border:none; padding:0; }
.hero-dot.active { background:var(--silk-gold); width:44px; }
.hero-arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:10; background:rgba(249,245,239,.1); border:1px solid rgba(249,245,239,.22); color:var(--silk-cream); width:48px; height:48px; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:18px; transition:all .3s; backdrop-filter:blur(4px); }
.hero-arrow:hover { background:var(--silk-gold); border-color:var(--silk-gold); color:var(--silk-deep); }
.hero-arrow-prev { left:32px; }
.hero-arrow-next { right:32px; }
.hero-slide-text { opacity:0; transform:translateY(24px); transition:opacity .6s .3s, transform .6s .3s; }
.hero-slide.active .hero-slide-text { opacity:1; transform:translateY(0); }

/* ─── MARQUEE ─── */
.marquee { background:var(--silk-gold); padding:13px 0; overflow:hidden; white-space:nowrap; }
.marquee-track { display:inline-flex; animation:marquee 22s linear infinite; }
.marquee-item { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--silk-deep); font-weight:600; padding:0 40px; display:flex; align-items:center; gap:14px; }
.marquee-item::after { content:'◆'; font-size:6px; opacity:.6; }
@keyframes marquee { from { transform:translateX(0); } to { transform:translateX(-50%); } }

/* ─── CATEGORIES ─── */
.categories-section { padding:80px 0 40px; }
.cat-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:0; margin-top:40px; height:500px; }
.cat-card { position:relative; overflow:hidden; cursor:pointer; }
.cat-bg-el { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .6s ease; }
.cat-card:hover .cat-bg-el { transform:scale(1.06); }
.cat-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(18,10,4,.8) 0%,rgba(18,10,4,.2) 60%,transparent 100%); display:flex; flex-direction:column; justify-content:flex-end; padding:24px 20px; }
.cat-tag { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--silk-gold); font-weight:500; margin-bottom:6px; }
.cat-name { font-family:var(--font-display); font-size:22px; color:var(--silk-cream); font-weight:300; margin-bottom:10px; }
.cat-link-el { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:rgba(249,245,239,.6); font-weight:400; transition:color .3s; }
.cat-card:hover .cat-link-el { color:var(--silk-gold); }

/* ─── FEATURED PRODUCTS ─── */
.feat-section { padding:80px 0; }
.prod-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:40px; }

/* ─── PRODUCT CARD ─── */
.prod-card { position:relative; cursor:pointer; }
.prod-card-img { aspect-ratio:3/4; position:relative; overflow:hidden; margin-bottom:16px; }
.prod-card-img-inner { width:100%; height:100%; transition:transform .5s ease; }
.prod-card:hover .prod-card-img-inner { transform:scale(1.04); }
.prod-badge { position:absolute; top:12px; left:12px; background:var(--silk-deep); color:var(--silk-gold-lt); font-size:9px; letter-spacing:2px; text-transform:uppercase; padding:5px 10px; font-weight:600; z-index:2; }
.prod-badge.feat { background:var(--silk-gold); color:var(--silk-deep); }
.prod-badge.new { background:var(--silk-sage); color:white; }
.prod-quick { position:absolute; bottom:0; left:0; right:0; background:var(--silk-deep); color:var(--silk-gold-lt); border:none; padding:12px; font-size:10px; letter-spacing:2.5px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); font-weight:600; transform:translateY(100%); transition:transform .3s; }
.prod-card:hover .prod-quick { transform:translateY(0); }
.prod-info .prod-cat { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--silk-gold); margin-bottom:5px; font-weight:500; }
.prod-info .prod-name { font-family:var(--font-display); font-size:var(--text-md); font-weight:400; color:var(--silk-deep); margin-bottom:6px; line-height:1.2; }
.prod-info .prod-stars { color:var(--silk-gold); font-size:11px; letter-spacing:1px; margin-bottom:6px; }
.prod-price-row { display:flex; align-items:baseline; gap:8px; }
.prod-pnow { font-family:var(--font-display); font-size:var(--text-lg); font-weight:400; }
.prod-pwas { font-size:var(--text-sm); color:var(--silk-muted); text-decoration:line-through; font-weight:300; }
.prod-disc { font-size:var(--text-xs); color:var(--silk-rouge); font-weight:600; letter-spacing:1px; }
.prod-swatches { display:flex; gap:5px; margin-top:10px; flex-wrap:wrap; }
.prod-swatch { width:14px; height:14px; border-radius:50%; border:1.5px solid transparent; }
.prod-swatch.more { background:var(--silk-pearl); border-color:var(--silk-border); font-size:8px; display:flex; align-items:center; justify-content:center; color:var(--silk-muted); font-weight:600; font-family:var(--font-body); }

/* ─── ABOUT SPLIT ─── */
.about-split { display:grid; grid-template-columns:1fr 1fr; min-height:640px; }
.about-visual { background:var(--silk-deep); display:flex; align-items:flex-end; padding:48px; }
.about-quote { max-width:480px; }
.qmark { font-family:var(--font-display); font-size:80px; color:var(--silk-gold); line-height:.8; display:block; margin-bottom:16px; opacity:.6; }
.about-quote p { font-family:var(--font-display); font-size:var(--text-xl); color:var(--silk-cream); line-height:1.5; font-weight:300; font-style:italic; margin-bottom:16px; }
.about-quote cite { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--silk-gold); font-weight:400; font-style:normal; }
.about-content { padding:80px 72px; display:flex; flex-direction:column; justify-content:center; }
.about-content p { font-size:var(--text-base); color:var(--silk-muted); line-height:1.85; font-weight:300; margin-bottom:20px; }
.cert-row { display:flex; gap:24px; margin-top:32px; }
.cert-badge { border:1px solid var(--silk-border); padding:20px 24px; text-align:center; flex:1; }
.cert-badge h4 { font-family:var(--font-display); font-size:var(--text-xl); font-weight:400; color:var(--silk-gold); margin-bottom:4px; }
.cert-badge p { font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--silk-muted); font-weight:500; }

/* ─── TESTIMONIALS ─── */
.testi-section { padding:80px 0; background:var(--silk-pearl); }
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.testi-card { background:white; padding:40px 36px; border:1px solid var(--silk-border); }
.testi-stars { color:var(--silk-gold); font-size:14px; letter-spacing:3px; margin-bottom:16px; }
.testi-title { font-family:var(--font-display); font-size:var(--text-lg); font-weight:400; margin-bottom:14px; }
.testi-text { font-size:var(--text-sm); color:var(--silk-muted); line-height:1.85; font-weight:300; margin-bottom:20px; font-style:italic; }
.testi-author { font-size:10px; letter-spacing:2.5px; text-transform:uppercase; color:var(--silk-gold); font-weight:500; }

/* ─── NEWSLETTER ─── */
.newsletter { background:var(--silk-deep); padding:72px 0; }
.newsletter-inner { text-align:center; }
.newsletter h2 { font-family:var(--font-display); font-size:var(--text-3xl); color:var(--silk-cream); font-weight:300; margin-bottom:12px; }
.newsletter p { font-size:var(--text-base); color:rgba(249,245,239,.55); font-weight:300; margin-bottom:36px; }
.nl-form { display:flex; gap:0; max-width:480px; margin:0 auto; }
.nl-form input { flex:1; border:none; background:rgba(255,255,255,.08); color:var(--silk-cream); padding:15px 20px; font-family:var(--font-body); font-size:var(--text-sm); outline:none; }
.nl-form input::placeholder { color:rgba(249,245,239,.35); }
.nl-form button { background:var(--silk-gold); color:var(--silk-deep); border:none; padding:15px 32px; font-size:10px; letter-spacing:2.5px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); font-weight:700; transition:background .3s; }
.nl-form button:hover { background:var(--silk-gold-lt); }

/* ─── FOOTER ─── */
footer { background:var(--silk-deep); padding:72px 0 0; }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(184,147,90,.16); }
.footer-brand .footer-logo { font-family:var(--font-display); font-size:var(--text-2xl); letter-spacing:8px; color:var(--silk-cream); font-weight:300; text-transform:uppercase; display:block; margin-bottom:4px; }
.footer-brand .footer-tagline { font-size:9px; letter-spacing:4px; color:var(--silk-gold); text-transform:uppercase; font-weight:400; display:block; margin-bottom:20px; }
.footer-brand p { font-size:var(--text-sm); color:rgba(249,245,239,.45); line-height:1.8; font-weight:300; }
.footer-col h4 { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--silk-gold); font-weight:600; margin-bottom:20px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer-col li button { background:none; border:none; font-family:var(--font-body); font-size:var(--text-sm); color:rgba(249,245,239,.45); cursor:pointer; transition:color .2s; font-weight:300; text-align:left; padding:0; }
.footer-col li button:hover { color:var(--silk-gold-lt); }
.footer-bottom { padding:24px 0; text-align:center; }
.footer-bottom p { font-size:var(--text-xs); color:rgba(249,245,239,.25); letter-spacing:1.5px; font-weight:300; }

/* ─── SHOP PAGE ─── */
.shop-hero { background:var(--silk-deep); padding:64px 60px; text-align:center; }
.shop-hero h1 { font-family:var(--font-display); font-size:var(--text-4xl); font-weight:300; color:var(--silk-cream); margin-bottom:12px; letter-spacing:2px; }
.shop-hero p { font-size:var(--text-sm); color:rgba(249,245,239,.5); letter-spacing:1.5px; font-weight:300; }
.shop-layout { display:grid; grid-template-columns:260px 1fr; max-width:1440px; margin:0 auto; padding:48px 60px; gap:48px; }
.sidebar { position:sticky; top:88px; height:fit-content; }
.sb-title { font-size:10px; letter-spacing:4px; text-transform:uppercase; color:var(--silk-char); font-weight:600; margin-bottom:28px; }
.filter-group { margin-bottom:24px; }
.fl-label { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--silk-muted); font-weight:500; margin-bottom:14px; display:block; }
.fl-opt { display:flex; align-items:center; gap:10px; font-size:var(--text-sm); color:var(--silk-char); cursor:pointer; margin-bottom:10px; font-weight:300; }
.fl-opt input { display:none; }
.fl-check { width:15px; height:15px; border:1px solid var(--silk-border); flex-shrink:0; position:relative; transition:all .2s; }
.fl-opt input:checked ~ .fl-check { background:var(--silk-gold); border-color:var(--silk-gold); }
.fl-opt input:checked ~ .fl-check::after { content:'✓'; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:9px; color:white; font-weight:700; }
.fl-div { height:1px; background:var(--silk-border); margin:20px 0; }
.col-sw { width:24px; height:24px; border-radius:50%; cursor:pointer; border:2px solid transparent; transition:all .2s; flex-shrink:0; }
.col-sw.active { border-color:var(--silk-gold); transform:scale(1.15); }
.sz-chip { border:1px solid var(--silk-border); padding:8px 14px; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; font-family:var(--font-body); background:none; cursor:pointer; margin:0 6px 6px 0; color:var(--silk-muted); transition:all .2s; font-weight:400; }
.sz-chip.active { border-color:var(--silk-gold); color:var(--silk-gold); }
.clear-btn { background:none; border:1px solid var(--silk-border); padding:10px 20px; font-size:10px; letter-spacing:2.5px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); color:var(--silk-muted); margin-top:20px; width:100%; transition:all .2s; font-weight:400; }
.clear-btn:hover { border-color:var(--silk-rouge); color:var(--silk-rouge); }
.toolbar { display:flex; justify-content:space-between; align-items:center; margin-bottom:28px; }
.prod-count { font-size:var(--text-sm); color:var(--silk-muted); font-weight:300; }
.sort-sel { border:1px solid var(--silk-border); padding:9px 14px; font-family:var(--font-body); font-size:var(--text-sm); background:white; color:var(--silk-char); outline:none; cursor:pointer; }
.main-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.products-main { min-height:400px; }

/* ─── PRODUCT DETAIL ─── */
.breadcrumb { max-width:1440px; margin:0 auto; padding:24px 60px; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--silk-muted); }
.breadcrumb button { background:none; border:none; font-family:var(--font-body); font-size:inherit; letter-spacing:inherit; text-transform:inherit; color:var(--silk-gold); cursor:pointer; font-weight:400; }
.detail-wrap { max-width:1440px; margin:0 auto; padding:0 60px 80px; display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:start; }
.gallery { position:sticky; top:88px; }
.gallery-main { position:relative; aspect-ratio:4/5; overflow:hidden; margin-bottom:12px; }
.gal-main-img { width:100%; height:100%; transition:all .3s; }
.gal-badge { position:absolute; top:16px; left:16px; background:var(--silk-deep); color:var(--silk-gold-lt); font-size:9px; letter-spacing:2px; text-transform:uppercase; padding:6px 12px; font-weight:600; }
.gal-thumbs { display:grid; grid-template-columns:repeat(5,1fr); gap:8px; }
.gal-thumb { aspect-ratio:3/4; cursor:pointer; overflow:hidden; opacity:.6; transition:opacity .2s; border:2px solid transparent; }
.gal-thumb.active, .gal-thumb:hover { opacity:1; border-color:var(--silk-gold); }
.product-info { padding-top:8px; }
.pi-cat { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--silk-gold); font-weight:500; margin-bottom:10px; }
.pi-title { font-family:var(--font-display); font-size:var(--text-3xl); font-weight:300; line-height:1.1; margin-bottom:16px; }
.pi-rat-row { display:flex; align-items:center; gap:12px; margin-bottom:20px; }
.pi-stars { color:var(--silk-gold); font-size:14px; letter-spacing:2px; }
.pi-rcount { font-size:var(--text-sm); color:var(--silk-muted); font-weight:300; }
.pi-price-row { display:flex; align-items:baseline; gap:10px; margin-bottom:24px; }
.pi-pnow { font-family:var(--font-display); font-size:var(--text-2xl); font-weight:400; }
.pi-pwas { font-size:var(--text-base); color:var(--silk-muted); text-decoration:line-through; font-weight:300; }
.pi-pbadge { font-size:11px; color:var(--silk-rouge); background:rgba(184,107,107,.1); padding:3px 8px; letter-spacing:1px; font-weight:600; }
.opt-label { font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--silk-char); font-weight:600; margin-bottom:12px; margin-top:20px; }
.opt-label em { color:var(--silk-gold); font-style:normal; margin-left:8px; font-weight:400; }
.color-opts { display:flex; gap:10px; flex-wrap:wrap; }
.color-opt { width:28px; height:28px; border-radius:50%; cursor:pointer; border:2px solid transparent; transition:all .2s; position:relative; }
.color-opt.selected, .color-opt:hover { border-color:var(--silk-gold); transform:scale(1.15); }
.size-opts { display:flex; gap:8px; flex-wrap:wrap; }
.size-opt { border:1px solid var(--silk-border); padding:10px 18px; cursor:pointer; font-size:12px; letter-spacing:1.5px; font-family:var(--font-body); background:none; transition:all .2s; color:var(--silk-char); font-weight:400; }
.size-opt.selected, .size-opt:hover { border-color:var(--silk-gold); color:var(--silk-gold); }
.qty-row { display:flex; align-items:center; gap:0; border:1px solid var(--silk-border); width:fit-content; margin-top:8px; }
.qty-btn { background:none; border:none; padding:10px 18px; font-size:var(--text-xl); cursor:pointer; color:var(--silk-char); transition:color .2s; font-weight:300; }
.qty-btn:hover { color:var(--silk-gold); }
.qty-disp { padding:10px 20px; font-size:var(--text-base); font-weight:500; min-width:50px; text-align:center; border-left:1px solid var(--silk-border); border-right:1px solid var(--silk-border); }
.cta-row { display:flex; gap:12px; margin-top:28px; }
.btn-bag { flex:2; background:var(--silk-deep); color:var(--silk-gold-lt); border:none; padding:16px 28px; font-size:10px; letter-spacing:3px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); font-weight:600; transition:background .3s; }
.btn-bag:hover { background:var(--silk-char); }
.btn-buy { flex:1; background:var(--silk-gold); color:var(--silk-deep); border:none; padding:16px 20px; font-size:10px; letter-spacing:3px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); font-weight:600; transition:all .3s; }
.btn-buy:hover { background:var(--silk-deep); color:var(--silk-gold); }
.trust-badges { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:28px; border-top:1px solid var(--silk-border); padding-top:24px; }
.trust-item { text-align:center; }
.trust-icon { display:block; font-size:20px; margin-bottom:6px; }
.trust-txt { font-size:11px; color:var(--silk-muted); font-weight:300; line-height:1.4; }
.accordion { margin-top:28px; border-top:1px solid var(--silk-border); }
.acc-item { border-bottom:1px solid var(--silk-border); }
.acc-hdr { display:flex; justify-content:space-between; align-items:center; padding:16px 0; cursor:pointer; font-size:11px; letter-spacing:2.5px; text-transform:uppercase; color:var(--silk-char); font-weight:500; transition:color .2s; }
.acc-hdr:hover { color:var(--silk-gold); }
.acc-icon { font-size:18px; font-weight:300; transition:transform .3s; }
.acc-hdr.open .acc-icon { transform:rotate(45deg); }
.acc-body { max-height:0; overflow:hidden; transition:max-height .4s ease; }
.acc-body.open { max-height:300px; }
.acc-inner { padding:0 0 16px; font-size:var(--text-sm); color:var(--silk-muted); line-height:1.85; font-weight:300; }
.acc-inner ul { padding-left:16px; }
.acc-inner li { margin-bottom:6px; }
.related-sec { background:var(--silk-pearl); padding:80px 0; }
.related-sec h2 { font-family:var(--font-display); font-size:var(--text-3xl); font-weight:300; text-align:center; margin-bottom:48px; }
.related-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; max-width:1440px; margin:0 auto; padding:0 60px; }

/* ─── CART ─── */
.cart-wrap { max-width:1440px; margin:0 auto; padding:0 60px 80px; display:grid; grid-template-columns:1fr 380px; gap:60px; }
.cart-title { font-family:var(--font-display); font-size:var(--text-3xl); font-weight:300; margin-bottom:8px; }
.cart-sub-txt { font-size:var(--text-sm); color:var(--silk-muted); font-weight:300; margin-bottom:36px; }
.cart-item { display:grid; grid-template-columns:100px 1fr auto; gap:20px; padding:24px 0; border-bottom:1px solid var(--silk-border); align-items:start; }
.ci-img { width:100px; height:130px; position:relative; overflow:hidden; }
.ci-cat { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--silk-gold); margin-bottom:5px; font-weight:500; }
.ci-name { font-family:var(--font-display); font-size:var(--text-md); font-weight:400; margin-bottom:5px; line-height:1.2; }
.ci-var { font-size:var(--text-sm); color:var(--silk-muted); font-weight:300; margin-bottom:14px; }
.ci-qty { display:flex; align-items:center; gap:0; border:1px solid var(--silk-border); width:fit-content; }
.ci-qbtn { background:none; border:none; padding:6px 12px; font-size:16px; cursor:pointer; color:var(--silk-char); }
.ci-qnum { padding:6px 14px; border-left:1px solid var(--silk-border); border-right:1px solid var(--silk-border); font-size:var(--text-sm); font-weight:500; }
.ci-price-col { text-align:right; }
.ci-price { font-family:var(--font-display); font-size:var(--text-xl); font-weight:400; display:block; margin-bottom:8px; }
.ci-remove { background:none; border:none; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--silk-muted); cursor:pointer; font-family:var(--font-body); transition:color .2s; font-weight:400; }
.ci-remove:hover { color:var(--silk-rouge); }
.cart-empty-state { text-align:center; padding:80px 40px; }
.cart-empty-state h3 { font-family:var(--font-display); font-size:var(--text-2xl); font-weight:300; margin-bottom:12px; }
.cart-empty-state p { font-size:var(--text-sm); color:var(--silk-muted); margin-bottom:28px; font-weight:300; }
.order-summary { background:var(--silk-cream); padding:32px; border:1px solid var(--silk-border); position:sticky; top:88px; }
.os-title { font-size:10px; letter-spacing:3.5px; text-transform:uppercase; color:var(--silk-char); font-weight:600; margin-bottom:24px; }
.os-row { display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px solid var(--silk-border); font-size:var(--text-sm); font-weight:300; }
.os-row.total { border-bottom:none; padding-top:20px; font-weight:600; }
.os-total-val { font-family:var(--font-display); font-size:var(--text-xl); font-weight:400; }
.promo-row { display:flex; gap:0; margin:16px 0 8px; }
.promo-row input { flex:1; border:1px solid var(--silk-border); padding:11px 14px; font-size:var(--text-sm); font-family:var(--font-body); outline:none; background:white; }
.promo-row button { background:var(--silk-deep); color:var(--silk-gold); border:none; padding:11px 18px; font-size:10px; letter-spacing:2px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); font-weight:600; }
.promo-msg { font-size:12px; color:var(--silk-sage); margin-bottom:8px; min-height:18px; font-weight:300; }
.btn-checkout { width:100%; background:var(--silk-gold); color:var(--silk-deep); border:none; padding:16px; font-size:10px; letter-spacing:3px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); font-weight:700; margin-top:20px; transition:all .3s; }
.btn-checkout:hover { background:var(--silk-deep); color:var(--silk-gold); }
.btn-cont { width:100%; background:none; border:1px solid var(--silk-border); color:var(--silk-muted); padding:14px; font-size:10px; letter-spacing:2.5px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); margin-top:10px; transition:all .3s; font-weight:400; }
.btn-cont:hover { border-color:var(--silk-gold); color:var(--silk-gold); }
.secure-row { display:flex; justify-content:center; gap:16px; margin-top:20px; }
.sec-badge { font-size:10px; color:var(--silk-muted); letter-spacing:1.5px; font-weight:300; }

/* ─── CHECKOUT ─── */
.checkout-wrap { max-width:1440px; margin:0 auto; padding:0 60px 80px; display:grid; grid-template-columns:1fr 380px; gap:60px; margin-top:40px; }
.co-title { font-family:var(--font-display); font-size:var(--text-2xl); font-weight:300; margin-bottom:32px; }
.co-steps { display:flex; gap:0; margin-bottom:40px; border:1px solid var(--silk-border); }
.co-step { flex:1; padding:16px 20px; display:flex; align-items:center; gap:12px; font-size:10px; letter-spacing:2.5px; text-transform:uppercase; color:var(--silk-muted); border-right:1px solid var(--silk-border); font-weight:400; }
.co-step:last-child { border-right:none; }
.co-step.active { color:var(--silk-deep); background:var(--silk-pearl); }
.co-step.done { color:var(--silk-sage); }
.step-num { width:24px; height:24px; border-radius:50%; border:1px solid currentColor; display:flex; align-items:center; justify-content:center; font-size:10px; flex-shrink:0; font-weight:700; }
.co-section { display:none; }
.co-section.active { display:block; }
.sec-hd { font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--silk-char); font-weight:600; margin-bottom:20px; margin-top:32px; }
.sec-hd:first-child { margin-top:0; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group.form-full { grid-column:1/-1; }
.fl-lbl { font-size:10px; letter-spacing:2.5px; text-transform:uppercase; color:var(--silk-muted); font-weight:500; }
.fl-input { border:1px solid var(--silk-border); padding:12px 14px; font-size:var(--text-sm); font-family:var(--font-body); outline:none; background:white; transition:border-color .2s; font-weight:300; width:100%; }
.fl-input:focus { border-color:var(--silk-gold); }
.fl-sel { border:1px solid var(--silk-border); padding:12px 14px; font-size:var(--text-sm); font-family:var(--font-body); outline:none; background:white; color:var(--silk-char); }
.pay-opt { display:flex; align-items:center; gap:16px; border:1px solid var(--silk-border); padding:16px 20px; cursor:pointer; margin-bottom:10px; transition:border-color .2s; }
.pay-opt.selected { border-color:var(--silk-gold); }
.pay-radio { width:16px; height:16px; border:1.5px solid var(--silk-border); border-radius:50%; flex-shrink:0; position:relative; transition:border-color .2s; }
.pay-opt.selected .pay-radio { border-color:var(--silk-gold); }
.pay-opt.selected .pay-radio::after { content:''; position:absolute; inset:3px; border-radius:50%; background:var(--silk-gold); }
.pay-name { font-size:var(--text-sm); color:var(--silk-char); font-weight:400; }
.pay-icons { margin-left:auto; display:flex; gap:8px; }
.pay-icon { font-size:10px; letter-spacing:1.5px; color:var(--silk-muted); border:1px solid var(--silk-border); padding:3px 8px; font-weight:500; }
.card-fields { display:none; grid-template-columns:1fr 1fr; gap:12px; margin-top:-4px; padding:20px; background:var(--silk-pearl); }
.card-fields.show { display:grid; }
.co-nav { display:flex; justify-content:space-between; margin-top:32px; }
.btn-back { background:none; border:1px solid var(--silk-border); padding:14px 28px; font-size:10px; letter-spacing:2.5px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); color:var(--silk-muted); transition:all .3s; font-weight:400; }
.btn-back:hover { border-color:var(--silk-gold); color:var(--silk-gold); }
.btn-next { background:var(--silk-deep); color:var(--silk-gold-lt); border:none; padding:14px 32px; font-size:10px; letter-spacing:2.5px; text-transform:uppercase; cursor:pointer; font-family:var(--font-body); font-weight:600; transition:background .3s; }
.btn-next:hover { background:var(--silk-char); }
.cs-sidebar { background:var(--silk-cream); padding:32px; border:1px solid var(--silk-border); position:sticky; top:88px; height:fit-content; }
.cs-title { font-size:10px; letter-spacing:3.5px; text-transform:uppercase; color:var(--silk-char); font-weight:600; margin-bottom:24px; }
.cs-item { display:flex; gap:14px; margin-bottom:16px; }
.cs-img { width:52px; height:68px; flex-shrink:0; }
.cs-name { font-family:var(--font-display); font-size:var(--text-base); font-weight:400; margin-bottom:3px; }
.cs-var { font-size:11px; color:var(--silk-muted); font-weight:300; }
.cs-price { font-size:var(--text-sm); font-weight:500; }
.cs-row { display:flex; justify-content:space-between; font-size:var(--text-sm); padding:8px 0; font-weight:300; }
.cs-total-row { font-weight:600; margin-top:8px; border-top:1px solid var(--silk-border); padding-top:16px; }
.cs-total-val { font-family:var(--font-display); font-size:var(--text-xl); font-weight:400; }

/* ─── CONFIRM ─── */
.confirm-wrap { max-width:680px; margin:0 auto; padding:100px 40px; text-align:center; }
.confirm-icon { font-size:56px; margin-bottom:24px; display:block; }
.confirm-title { font-family:var(--font-display); font-size:var(--text-3xl); font-weight:300; margin-bottom:12px; }
.confirm-num { font-size:var(--text-sm); color:var(--silk-gold); letter-spacing:2px; text-transform:uppercase; margin-bottom:16px; font-weight:500; }
.confirm-msg { font-size:var(--text-base); color:var(--silk-muted); font-weight:300; line-height:1.8; margin-bottom:40px; }
.confirm-items { background:var(--silk-cream); padding:32px; margin-bottom:40px; border:1px solid var(--silk-border); text-align:left; }

/* ── Hide site chrome when admin panel is active ─────────────────────────── */
body.admin-active .ann,
body.admin-active header {
  display: none !important;
}
body.admin-active #page-admin {
  position: fixed;
  inset: 0;
  z-index: 500;
  overflow: hidden;
}