/* ============ RESET / BASE ============ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',Arial,sans-serif;
  background:#160f08;color:#f3ead7;line-height:1.5;overflow-x:hidden;
}
img{max-width:100%;display:block}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}
ul{list-style:none}

:root{
  --bg:#160f08; --bg-soft:#1f1710; --bg-card:#241a10;
  --line:#38291a; --text:#f3ead7; --text-muted:#b3a181;
  --accent:#8a5410; --accent-hot:#a4631a;
  --rose-gold:#d8a657; --champagne:#e8cf9f;
  --burgundy:#5a3618; --success:#4caf50; --danger:#e53935;
}

/* ============ AGE GATE ============ */
#ageGate{position:fixed;inset:0;z-index:9999;background:radial-gradient(ellipse at center,#1f1710 0%,#0a0509 100%);display:flex;align-items:center;justify-content:center;padding:20px}
.age-box{max-width:480px;text-align:center;background:linear-gradient(180deg,#241a10 0%,#150b13 100%);border:1px solid var(--line);border-radius:16px;padding:48px 32px;box-shadow:0 20px 60px rgba(160,100,24,.15)}
.age-box .logo-mark{font-family:'Georgia',serif;font-size:42px;letter-spacing:.05em;background:linear-gradient(135deg,var(--rose-gold),var(--accent-hot));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px}
.age-box .tag{color:var(--text-muted);font-size:12px;letter-spacing:.3em;text-transform:uppercase;margin-bottom:32px}
.age-box h2{font-family:'Georgia',serif;font-weight:400;font-size:24px;margin-bottom:16px;color:var(--champagne)}
.age-box p{color:var(--text-muted);font-size:14px;margin-bottom:28px;line-height:1.7}
.age-buttons{display:flex;gap:12px;flex-direction:column}
.age-btn{padding:14px 24px;border-radius:8px;font-size:15px;font-weight:600;letter-spacing:.05em;transition:all .25s ease}
.age-btn-yes{background:linear-gradient(135deg,var(--accent),var(--accent-hot));color:#fff}
.age-btn-yes:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(160,100,24,.4)}
.age-btn-no{background:transparent;border:1px solid var(--line);color:var(--text-muted)}
.age-btn-no:hover{border-color:var(--text-muted)}
.age-disclaimer{font-size:11px;color:#6b5560;margin-top:20px;line-height:1.6}

/* ============ PROMO BAR ============ */
.promo-bar{background:linear-gradient(90deg,var(--burgundy),var(--accent),var(--burgundy));color:#fff;text-align:center;padding:10px 16px;font-size:13px;font-weight:500;letter-spacing:.04em;overflow:hidden;position:relative}
.promo-track{display:inline-block;animation:slide 30s linear infinite;white-space:nowrap}
.promo-track span{margin:0 32px}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ HEADER ============ */
header{background:rgba(14,8,16,.92);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:100}
.header-inner{max-width:1400px;margin:0 auto;padding:18px 32px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px}
.header-left{display:flex;gap:24px;align-items:center}
.icon-btn{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s;position:relative}
.icon-btn:hover{background:var(--bg-soft)}
.icon-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8}
.auth-dot{position:absolute;bottom:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--success);border:2px solid var(--bg)}
.cart-count{position:absolute;top:2px;right:2px;background:#8a5410;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.brand{font-family:'Georgia',serif;font-size:28px;letter-spacing:.08em;text-align:center;cursor:pointer;background:linear-gradient(135deg,var(--champagne) 0%,var(--rose-gold) 50%,var(--accent-hot) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.brand-tag{display:block;font-size:9px;letter-spacing:.35em;color:var(--text-muted);-webkit-text-fill-color:var(--text-muted);text-align:center;margin-top:2px}
.header-right{display:flex;gap:8px;justify-content:flex-end;align-items:center}

.search-bar{display:flex;align-items:center;gap:8px;background:var(--bg-soft);border:1px solid var(--line);border-radius:24px;padding:8px 16px;min-width:280px;transition:border-color .2s}
.search-bar:focus-within{border-color:var(--accent)}
.search-bar input{background:transparent;border:none;outline:none;color:var(--text);flex:1;font-size:14px}
.search-bar input::placeholder{color:var(--text-muted)}
.search-bar svg{width:16px;height:16px;stroke:var(--text-muted);fill:none;stroke-width:2}

/* ============ NAV ============ */
nav.categories{background:var(--bg);border-bottom:1px solid var(--line);position:sticky;top:79px;z-index:99}
.nav-inner{max-width:1400px;margin:0 auto;padding:0 32px;display:flex;justify-content:center;gap:36px;overflow-x:auto;scrollbar-width:none}
.nav-inner::-webkit-scrollbar{display:none}
.nav-inner a{padding:16px 0;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap;position:relative;font-weight:500;transition:color .2s}
.nav-inner a:hover, .nav-inner a.active{color:var(--text)}
.nav-inner a.active::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-hot))}
.nav-sale{color:#e0a23a !important;font-weight:700 !important}

/* ============ HERO ============ */
.hero{height:560px;position:relative;overflow:hidden;background:radial-gradient(ellipse at 20% 50%,rgba(160,100,24,.18) 0%,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(90,54,24,.3) 0%,transparent 60%),linear-gradient(180deg,#1f1710 0%,#160f08 100%)}
.hero-content{max-width:1400px;margin:0 auto;height:100%;padding:0 32px;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:48px}
.hero-text .eyebrow{font-size:12px;letter-spacing:.35em;text-transform:uppercase;color:var(--rose-gold);margin-bottom:24px}
.hero-text h1{font-family:'Georgia',serif;font-weight:300;font-size:64px;line-height:1.05;margin-bottom:24px;letter-spacing:-.02em}
.hero-text h1 em{font-style:italic;background:linear-gradient(135deg,var(--rose-gold),var(--accent-hot));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-text p{color:var(--text-muted);font-size:17px;max-width:480px;margin-bottom:36px;line-height:1.7}
/* Button gradient is a touch deeper than the decorative --accent so white text
   clears WCAG AA (4.5:1). #a4631a→#8a5410 ≈ 4.95–5.9:1 with #fff. */
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#a4631a,#8a5410);color:#fff;padding:16px 32px;border-radius:32px;font-weight:600;font-size:15px;letter-spacing:.05em;transition:all .3s ease}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(160,100,24,.4)}
.btn-secondary{display:inline-block;padding:16px 28px;border-radius:32px;border:1px solid var(--line);color:var(--text);font-weight:500;font-size:14px;letter-spacing:.05em;transition:all .2s;margin-left:12px}
.btn-secondary:hover{border-color:var(--rose-gold);color:var(--rose-gold)}

.hero-visual{position:relative;height:100%;display:flex;align-items:center;justify-content:center}
.hero-shape{width:420px;height:520px;border-radius:24px;position:relative;overflow:hidden;box-shadow:0 30px 100px rgba(160,100,24,.35);background:linear-gradient(135deg,#5a3618,#8a5410,#d8a657);animation:float 8s ease-in-out infinite}
.hero-shape img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .6s ease}
.hero-shape img.loaded{opacity:1}
.banner-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .6s ease}
.banner-visual img.loaded{opacity:1}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
.hero-badge{position:absolute;background:rgba(31,19,32,.9);border:1px solid var(--line);border-radius:20px;padding:10px 16px;font-size:12px;color:var(--champagne);backdrop-filter:blur(20px);letter-spacing:.05em}
.hero-badge-1{top:30%;left:5%;animation:bob 4s ease-in-out infinite}
.hero-badge-2{bottom:25%;right:5%;animation:bob 5s ease-in-out infinite -2s}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ============ SECTIONS ============ */
section{padding:80px 32px}
.container{max-width:1400px;margin:0 auto}
.section-head{text-align:center;margin-bottom:56px}
.section-head .eyebrow{font-size:11px;letter-spacing:.35em;text-transform:uppercase;color:var(--rose-gold);margin-bottom:12px}
.section-head h2{font-family:'Georgia',serif;font-weight:300;font-size:42px;letter-spacing:-.01em;margin-bottom:12px}
.section-head p{color:var(--text-muted);font-size:15px;max-width:560px;margin:0 auto}

/* ============ CATEGORY GRID ============ */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cat-card{aspect-ratio:1;border-radius:16px;position:relative;overflow:hidden;cursor:pointer;transition:transform .35s ease}
.cat-card:hover{transform:translateY(-6px)}
.cat-card .cat-bg{position:absolute;inset:0;transition:transform .8s ease}
.cat-card:hover .cat-bg{transform:scale(1.1)}
.cat-card .cat-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(14,8,16,.92) 100%)}
.cat-card .cat-content{position:absolute;bottom:0;left:0;right:0;padding:24px}
.cat-card h3{font-family:'Georgia',serif;font-weight:400;font-size:24px;margin-bottom:4px;overflow-wrap:break-word;word-break:break-word}
.cat-card .cat-count{font-size:12px;color:var(--text-muted);letter-spacing:.05em}
.cat-card .cat-arrow{position:absolute;top:20px;right:20px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;transition:all .3s}
.cat-card:hover .cat-arrow{background:var(--accent-hot);transform:rotate(45deg)}
.cat-arrow svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:2}

/* ============ PRODUCT GRID ============ */
.filters{display:flex;gap:12px;align-items:center;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap}
.filter-pills{display:flex;gap:8px;flex-wrap:wrap}
.pill{padding:8px 18px;border-radius:20px;border:1px solid var(--line);font-size:13px;color:var(--text-muted);transition:all .2s;letter-spacing:.03em}
.pill:hover{color:var(--text);border-color:var(--text-muted)}
.pill.active{background:linear-gradient(135deg,var(--accent),var(--accent-hot));color:#fff;border-color:transparent}
.sort-select{background:var(--bg-soft);border:1px solid var(--line);border-radius:20px;padding:8px 16px;color:var(--text);font-size:13px;outline:none;cursor:pointer}

.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.product{background:var(--bg-card);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:all .35s ease;position:relative;cursor:pointer;display:block}
.product:hover{transform:translateY(-6px);border-color:rgba(160,100,24,.4);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.product-image{aspect-ratio:1;position:relative;overflow:hidden}
.product-image .img-bg{position:absolute;inset:0;transition:transform .6s ease}
.product:hover .img-bg{transform:scale(1.08)}
.product-badge{position:absolute;top:12px;left:12px;padding:5px 10px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;z-index:2}
.badge-new{background:var(--champagne);color:#3a1f14}
.badge-sale{background:var(--accent-hot);color:#fff}
.badge-best{background:#222;color:var(--rose-gold);border:1px solid var(--rose-gold)}
.product-wishlist{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:rgba(14,8,16,.7);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2}
.product-wishlist:hover{background:var(--accent-hot)}
.product-wishlist svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:1.8}
.product-wishlist.active svg{fill:var(--accent-hot);stroke:var(--accent-hot)}

.product-quickview{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(0deg,rgba(14,8,16,.95),transparent);padding:16px;text-align:center;transform:translateY(100%);transition:transform .3s ease}
.product:hover .product-quickview{transform:translateY(0)}
.product-quickview button{background:#fff;color:#160f08;padding:10px 20px;border-radius:20px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}

.product-info{padding:20px}
.product-cat{font-size:11px;color:var(--text-muted);letter-spacing:.15em;text-transform:uppercase;margin-bottom:8px}
.product-name{font-family:'Georgia',serif;font-size:17px;font-weight:400;margin-bottom:10px;line-height:1.3}
.product-rating{display:flex;align-items:center;gap:6px;margin-bottom:12px;font-size:12px;color:var(--text-muted)}
.stars{color:var(--rose-gold);letter-spacing:1px;font-size:13px}
.product-price{display:flex;align-items:center;gap:10px}
.price-now{font-size:18px;font-weight:600;color:var(--text)}
.price-was{font-size:14px;color:var(--text-muted);text-decoration:line-through}
.price-save{font-size:11px;color:var(--accent-hot);font-weight:700;margin-left:auto;letter-spacing:.05em}

/* ============ BANNER ============ */
.banner{margin:0 32px;border-radius:24px;overflow:hidden;background:radial-gradient(ellipse at 30% 50%,rgba(176,116,25,.3) 0%,transparent 50%),linear-gradient(135deg,#2a1d10 0%,#1f1710 100%);padding:64px 48px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;border:1px solid var(--line)}
.banner-content .eyebrow{font-size:12px;letter-spacing:.3em;color:var(--rose-gold);text-transform:uppercase;margin-bottom:16px}
.banner-content h2{font-family:'Georgia',serif;font-size:48px;font-weight:300;margin-bottom:16px;line-height:1.1}
.banner-content p{color:var(--text-muted);margin-bottom:28px;max-width:480px}
.banner-visual{height:280px;border-radius:16px;position:relative;overflow:hidden;background:radial-gradient(circle at 50% 50%,rgba(160,100,24,.5) 0%,transparent 70%),conic-gradient(from 0deg,#5a3618,#8a5410,#a4631a,#d8a657,#5a3618)}
.banner-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 30%,rgba(14,8,16,.7) 100%)}

/* ============ TRUST ROW ============ */
.trust-row{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:48px 32px}
.trust-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.trust-item{text-align:center}
.trust-icon{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,rgba(160,100,24,.15),rgba(212,165,116,.1));display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.trust-icon svg{width:22px;height:22px;stroke:var(--rose-gold);fill:none;stroke-width:1.8}
.trust-item h4{font-size:14px;letter-spacing:.05em;margin-bottom:4px}
.trust-item p{font-size:12px;color:var(--text-muted)}

/* ============ NEWSLETTER ============ */
.newsletter{text-align:center;padding:80px 32px;background:radial-gradient(ellipse at center,rgba(160,100,24,.1) 0%,transparent 60%),var(--bg)}
.newsletter h2{font-family:'Georgia',serif;font-size:42px;font-weight:300;margin-bottom:12px}
.newsletter p{color:var(--text-muted);margin-bottom:28px;max-width:520px;margin-left:auto;margin-right:auto}
.nl-form{display:flex;max-width:480px;margin:0 auto;gap:8px}
.nl-form input{flex:1;background:var(--bg-soft);border:1px solid var(--line);border-radius:28px;padding:14px 22px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s}
.nl-form input:focus{border-color:var(--accent)}
.nl-perks{margin-top:24px;display:flex;justify-content:center;gap:32px;font-size:12px;color:var(--text-muted)}
.nl-perks span::before{content:'✦ ';color:var(--rose-gold);margin-right:4px}

/* ============ FOOTER ============ */
footer{background:#070407;border-top:1px solid var(--line);padding:64px 32px 24px}
.footer-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand .brand{text-align:left;margin-bottom:16px}
.footer-brand p{color:var(--text-muted);font-size:13px;line-height:1.7;max-width:280px}
.footer-col h5{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--champagne);margin-bottom:18px}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{font-size:13px;color:var(--text-muted);transition:color .2s}
.footer-col ul li a:hover{color:var(--text)}
.footer-bottom{max-width:1400px;margin:0 auto;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-muted)}
.pay-icons{display:flex;gap:10px}
.pay-icon{background:var(--bg-soft);border:1px solid var(--line);border-radius:6px;padding:6px 12px;font-size:11px;font-weight:700;letter-spacing:.05em}

/* ============ CART DRAWER ============ */
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(4px)}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:100vw;background:var(--bg-soft);border-left:1px solid var(--line);z-index:201;transform:translateX(100%);transition:transform .35s ease;display:flex;flex-direction:column}
.cart-drawer.open{transform:translateX(0)}
.cart-head{padding:24px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.cart-head h3{font-family:'Georgia',serif;font-size:22px;font-weight:400}
.cart-close{width:36px;height:36px;border-radius:50%;background:var(--bg-card);display:flex;align-items:center;justify-content:center}
.cart-body{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:16px 24px}
.cart-item{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
.cart-item-img{width:80px;height:80px;border-radius:8px;flex-shrink:0;position:relative;overflow:hidden}
.img-bg img, .cat-bg img, .cart-item-img img, .modal-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .5s ease}
.img-bg img.loaded, .cat-bg img.loaded, .cart-item-img img.loaded, .modal-img img.loaded{opacity:1}
.cart-item-info{flex:1;display:flex;flex-direction:column}
.cart-item-name{font-size:14px;font-weight:500;margin-bottom:4px}
.cart-item-meta{font-size:12px;color:var(--text-muted);margin-bottom:auto}
.cart-item-bot{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.qty-controls{display:flex;align-items:center;border:1px solid var(--line);border-radius:18px;overflow:hidden}
.qty-controls button{width:28px;height:28px;color:var(--text-muted)}
.qty-controls button:hover{color:var(--text)}
.qty-controls span{padding:0 10px;font-size:13px}
.cart-item-price{font-weight:600;font-size:15px}
.cart-empty{text-align:center;padding:48px 0;color:var(--text-muted)}
.cart-foot{padding:24px;border-top:1px solid var(--line);background:var(--bg)}
.cart-totals{margin-bottom:16px}
.cart-totals div{display:flex;justify-content:space-between;margin-bottom:8px;font-size:14px}
.cart-total-row{font-size:18px !important;font-weight:600;color:var(--text);padding-top:12px;border-top:1px solid var(--line)}
.checkout-btn{width:100%;padding:16px;border-radius:28px;background:linear-gradient(135deg,var(--accent),var(--accent-hot));color:#fff;font-weight:600;letter-spacing:.05em;font-size:14px;transition:transform .2s}
.checkout-btn:hover{transform:translateY(-2px)}
.free-ship-bar{margin-bottom:16px;font-size:12px;color:var(--text-muted)}
.free-ship-progress{height:4px;background:var(--bg-card);border-radius:2px;margin-top:8px;overflow:hidden}
.free-ship-fill{height:100%;background:linear-gradient(90deg,var(--rose-gold),var(--accent-hot));transition:width .3s}

/* ============ QUICK VIEW MODAL ============ */
.modal-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{max-width:960px;width:100%;max-height:90vh;background:var(--bg-soft);border:1px solid var(--line);border-radius:20px;overflow:hidden auto;overscroll-behavior:contain;display:grid;grid-template-columns:1fr 1fr}
/* Let grid columns shrink to the modal width instead of overflowing it */
.modal > *{min-width:0}
.modal-info h2{overflow-wrap:break-word;word-break:break-word}
.modal-img{aspect-ratio:1;position:sticky;top:0;align-self:start;z-index:1}
.modal-info{padding:40px;position:relative}
.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:var(--bg-card);display:flex;align-items:center;justify-content:center}
.modal-cat{font-size:11px;letter-spacing:.2em;color:var(--rose-gold);text-transform:uppercase;margin-bottom:12px}
.modal-info h2{font-family:'Georgia',serif;font-weight:300;font-size:32px;margin-bottom:16px;line-height:1.2}
.modal-rating{display:flex;align-items:center;gap:8px;margin-bottom:20px;color:var(--text-muted);font-size:13px}
.modal-price{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.modal-price .price-now{font-size:28px}
.modal-desc{color:var(--text-muted);font-size:14px;line-height:1.7;margin-bottom:28px}
.modal-features{margin-bottom:28px}
.modal-features li{padding:8px 0;font-size:13px;color:var(--text);display:flex;align-items:center;gap:10px}
.modal-features li::before{content:'✦';color:var(--rose-gold);font-size:14px}
.modal-actions{display:flex;gap:12px;margin-bottom:20px}
.modal-actions .btn-primary{flex:1;justify-content:center}
.modal-actions .icon-btn{border:1px solid var(--line);border-radius:50%}
.modal-actions .icon-btn svg{stroke:var(--text)}

/* ============ TOAST ============ */
.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(20px);opacity:0;pointer-events:none;background:var(--bg-soft);border:1px solid var(--accent);padding:14px 24px;border-radius:32px;font-size:14px;z-index:400;transition:opacity .3s ease, transform .3s ease;box-shadow:0 10px 40px rgba(0,0,0,.4);display:flex;align-items:center;gap:10px}
.toast.show{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.toast svg{width:18px;height:18px;stroke:var(--accent-hot);fill:none;stroke-width:2}

/* ============ PRODUCT DETAIL PAGE ============ */
.pd-wrap{max-width:1400px;margin:0 auto;padding:40px 32px}
.pd-breadcrumb{font-size:12px;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:24px}
.pd-breadcrumb a:hover{color:var(--rose-gold)}
.pd-breadcrumb .sep{margin:0 8px}
.pd-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:start}
.pd-image{aspect-ratio:1;border-radius:20px;position:relative;overflow:hidden;background:var(--bg-card);box-shadow:0 30px 80px rgba(0,0,0,.4)}
.pd-info{position:sticky;top:140px}
.pd-cat{font-size:12px;color:var(--rose-gold);letter-spacing:.25em;text-transform:uppercase;margin-bottom:12px}
.pd-info h1{font-family:'Georgia',serif;font-weight:300;font-size:42px;line-height:1.1;margin-bottom:16px}
.pd-rating{display:flex;align-items:center;gap:10px;margin-bottom:24px;color:var(--text-muted);font-size:13px}
.pd-price{display:flex;align-items:baseline;gap:14px;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.pd-price .price-now{font-size:36px}
.pd-price .price-was{font-size:18px}
.pd-desc{color:var(--text-muted);font-size:15px;line-height:1.8;margin-bottom:28px}
.pd-features{margin-bottom:36px}
.pd-features h4{font-size:11px;letter-spacing:.25em;color:var(--rose-gold);text-transform:uppercase;margin-bottom:14px}
.pd-features li{padding:8px 0;font-size:14px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line)}
.pd-features li:last-child{border-bottom:none}
.pd-features li::before{content:'✦';color:var(--rose-gold)}
.pd-actions{display:flex;gap:12px;align-items:stretch;margin-bottom:28px}
.pd-qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:32px;overflow:hidden}
.pd-qty button{width:44px;height:48px;color:var(--text-muted);font-size:18px}
.pd-qty button:hover{color:var(--text)}
.pd-qty span{padding:0 14px;font-size:16px;min-width:48px;text-align:center}
.pd-add{flex:1}
.pd-wish{width:48px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}
.pd-wish:hover{border-color:var(--accent-hot)}
.pd-wish svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:1.8}
.pd-wish.active svg{fill:var(--accent-hot);stroke:var(--accent-hot)}
.pd-perks{padding:20px 0;border-top:1px solid var(--line);font-size:13px;color:var(--text-muted);line-height:2}
.pd-perks span::before{content:'✦ ';color:var(--rose-gold)}

/* ============ FORM PAGES (login/register/admin) ============ */
.form-page{min-height:calc(100vh - 79px - 51px);display:flex;align-items:center;justify-content:center;padding:60px 20px;background:radial-gradient(ellipse at center,rgba(160,100,24,.1) 0%,transparent 60%)}
.form-card{max-width:440px;width:100%;background:var(--bg-soft);border:1px solid var(--line);border-radius:16px;padding:48px 40px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.form-card h1{font-family:'Georgia',serif;font-weight:300;font-size:32px;margin-bottom:8px}
.form-card .sub{color:var(--text-muted);font-size:14px;margin-bottom:32px}
.form-tabs{display:flex;gap:4px;margin-bottom:28px;background:var(--bg);border:1px solid var(--line);border-radius:24px;padding:4px}
.form-tab{flex:1;padding:10px 16px;text-align:center;border-radius:20px;font-size:13px;color:var(--text-muted);letter-spacing:.05em;cursor:pointer;transition:all .2s}
.form-tab.active{background:linear-gradient(135deg,var(--accent),var(--accent-hot));color:#fff}
.field{margin-bottom:18px}
.field label{display:block;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px}
.field input, .field select, .field textarea{
  width:100%;background:var(--bg);border:1px solid var(--line);border-radius:10px;
  padding:12px 16px;color:var(--text);font-size:15px;outline:none;
  transition:border-color .2s; font-family: inherit;
}
.field input:focus, .field select:focus, .field textarea:focus{border-color:var(--accent)}
.field textarea{min-height:96px;resize:vertical;line-height:1.5}
.field .hint{font-size:12px;color:var(--text-muted);margin-top:6px}
.form-error{
  background:rgba(229,57,53,.1);border:1px solid rgba(229,57,53,.5);
  color:#ff7b7b;padding:12px 16px;border-radius:10px;
  font-size:13px;margin-bottom:18px;
}
.form-success{
  background:rgba(76,175,80,.1);border:1px solid rgba(76,175,80,.5);
  color:#7be08b;padding:12px 16px;border-radius:10px;
  font-size:13px;margin-bottom:18px;
}
.form-submit{
  width:100%;padding:14px;border-radius:28px;
  background:linear-gradient(135deg,var(--accent),var(--accent-hot));
  color:#fff;font-weight:600;letter-spacing:.05em;font-size:14px;
  transition:transform .2s; margin-top: 6px;
}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(160,100,24,.4)}
.form-submit:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}
.form-foot{text-align:center;margin-top:24px;font-size:13px;color:var(--text-muted)}
.form-foot a{color:var(--rose-gold)}
.form-foot a:hover{color:var(--accent-hot)}

/* ============ ACCOUNT PAGE ============ */
.account-wrap{max-width:1100px;margin:0 auto;padding:40px 32px}
.account-head{margin-bottom:32px}
.account-head h1{font-family:'Georgia',serif;font-weight:300;font-size:36px;margin-bottom:8px}
.account-head p{color:var(--text-muted);font-size:14px}
.account-grid{display:grid;grid-template-columns:240px 1fr;gap:48px}
.account-nav{position:sticky;top:140px;align-self:start}
.account-nav a{display:block;padding:12px 16px;border-radius:8px;font-size:14px;color:var(--text-muted);margin-bottom:4px;transition:all .15s}
.account-nav a:hover, .account-nav a.active{background:var(--bg-soft);color:var(--text)}
.account-nav a.logout{margin-top:24px;color:var(--danger)}
.account-section h2{font-family:'Georgia',serif;font-weight:300;font-size:24px;margin-bottom:20px}
.account-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:24px;margin-bottom:16px}

/* ============ ADMIN PAGE ============ */
.admin-wrap{max-width:1400px;margin:0 auto;padding:32px}
.admin-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}
.admin-head h1{font-family:'Georgia',serif;font-weight:300;font-size:32px}
.admin-tabs{display:inline-flex;gap:4px;margin-bottom:24px;background:var(--bg);border:1px solid var(--line);border-radius:24px;padding:4px}
.admin-tab{padding:10px 22px;border-radius:20px;font-size:13px;color:var(--text-muted);letter-spacing:.05em;cursor:pointer;transition:all .2s;border:none;background:transparent}
.admin-tab.active{background:linear-gradient(135deg,var(--accent),var(--accent-hot));color:#fff}
.admin-tab:hover:not(.active){color:var(--text)}
.badge-preview{display:inline-block;padding:5px 10px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.color-swatch{display:inline-block;width:20px;height:20px;border-radius:4px;vertical-align:middle;margin-right:6px;border:1px solid var(--line)}
.gradient-preview{display:inline-block;width:48px;height:32px;border-radius:6px;border:1px solid var(--line);background-size:cover}
.admin-table{width:100%;border-collapse:collapse;background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.admin-table th, .admin-table td{padding:14px 16px;text-align:left;font-size:14px;border-bottom:1px solid var(--line);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:none}
.admin-table th{background:var(--bg);color:var(--text-muted);font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:600}
.admin-table .thumb{width:56px;height:56px;border-radius:8px;background:var(--bg-card);position:relative;overflow:hidden}
.admin-table .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.admin-table tr:hover td{background:rgba(160,100,24,.04)}
/* Keep this a normal table-cell (NOT display:flex) so vertical-align:middle
   centers the buttons in the row, matching the other cells. */
.admin-table .row-actions{text-align:right;white-space:nowrap}
.admin-table .row-actions button, .admin-table .row-actions select{vertical-align:middle}
.admin-table .row-actions > * + *{margin-left:8px}
.admin-table .row-actions button{
  font-size:12px;padding:6px 12px;border-radius:8px;
  background:var(--bg);border:1px solid var(--line);color:var(--text);
}
.admin-table .row-actions button:hover{border-color:var(--accent-hot)}
.admin-table .row-actions .danger:hover{border-color:var(--danger);color:var(--danger)}
.admin-section-divider{
  margin:32px 0 16px;padding:14px 18px;
  background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;
  display:flex;align-items:center;justify-content:space-between;
  font-size:13px;color:var(--text-muted);letter-spacing:.05em;
}
.admin-section-divider strong{color:var(--text);font-size:14px;letter-spacing:0;text-transform:none}
.admin-table .row-inactive td{opacity:.5}
.admin-table .row-inactive .name-cell{text-decoration:line-through;text-decoration-color:rgba(243,233,237,.6);text-decoration-thickness:1px}
.admin-table .row-inactive:hover td{opacity:.75;background:rgba(76,175,80,.04)}
.admin-table .row-actions .restore{color:var(--success)}
.admin-table .row-actions .restore:hover{border-color:var(--success);color:var(--success)}

.admin-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:300;display:none;align-items:flex-start;justify-content:center;padding:48px 16px;overflow-y:auto;overscroll-behavior:contain}
.admin-modal-overlay.open{display:flex}
.admin-modal{max-width:640px;width:100%;background:var(--bg-soft);border:1px solid var(--line);border-radius:16px;padding:32px;position:relative}
.admin-modal h2{font-family:'Georgia',serif;font-weight:300;font-size:24px;margin-bottom:24px}
.admin-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.image-preview{
  width:100%;aspect-ratio:1;border-radius:12px;
  background:var(--bg-card);position:relative;overflow:hidden;margin-bottom:8px;
  border:1px dashed var(--line);
}
.image-preview img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.image-preview .placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:12px;text-align:center;padding:16px}
.btn-ghost{padding:12px 22px;border-radius:24px;border:1px solid var(--line);color:var(--text);font-size:14px;background:transparent;transition:border-color .2s}
.btn-ghost:hover{border-color:var(--text-muted)}

/* AI generate buttons inside admin product editor */
.ai-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.ai-btn{
  padding:7px 14px;border-radius:18px;font-size:12px;letter-spacing:.04em;
  background:linear-gradient(135deg,rgba(212,165,116,.18),rgba(160,100,24,.18));
  border:1px solid rgba(212,165,116,.4);color:var(--champagne);
  transition:all .2s; cursor:pointer; display:inline-flex; align-items:center; gap:6px;
}
.ai-btn:hover:not(:disabled){border-color:var(--rose-gold);color:#fff;background:linear-gradient(135deg,rgba(212,165,116,.3),rgba(160,100,24,.3))}
.ai-btn:disabled{opacity:.45;cursor:not-allowed}
.ai-btn.busy{opacity:.7;cursor:wait}
.ai-panel{
  display:none; margin-top:10px; padding:14px;
  background:rgba(212,165,116,.07); border:1px solid rgba(212,165,116,.25);
  border-radius:10px;
}
.ai-panel.open{display:block}
.ai-panel textarea{
  width:100%; min-height:60px; resize:vertical; padding:10px 12px;
  background:var(--bg); border:1px solid var(--line); border-radius:8px;
  color:var(--text); font-size:13px; font-family:inherit; line-height:1.5; outline:none;
}
.ai-panel textarea:focus{border-color:var(--accent)}
.ai-panel .ai-hint{font-size:11px;color:var(--text-muted);margin-bottom:8px;line-height:1.5}
.ai-panel .ai-row{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}
.ai-panel .ai-row button{
  font-size:12px;padding:7px 16px;border-radius:18px;
}
.ai-panel .ai-go{
  background:linear-gradient(135deg,var(--rose-gold),var(--accent));
  color:#fff;border:none;font-weight:600;
}
.ai-panel .ai-go:hover:not(:disabled){box-shadow:0 4px 14px rgba(212,165,116,.4)}
.ai-panel .ai-go:disabled{opacity:.6;cursor:not-allowed}
.ai-panel .ai-cancel{background:transparent;border:1px solid var(--line);color:var(--text-muted)}
.ai-panel .ai-cancel:hover{color:var(--text);border-color:var(--text-muted)}
.ai-panel .ai-error{
  margin-top:8px; padding:8px 12px; border-radius:6px;
  background:rgba(229,57,53,.12); border:1px solid rgba(229,57,53,.4);
  color:#ff7b7b; font-size:12px;
}

/* ============ RELATED PRODUCTS (smaller grid on detail page) ============ */
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
  .header-inner{grid-template-columns:auto 1fr auto}
  .search-bar{display:none}
  /* left-align the category strip so its first items are reachable when it
     overflows (justify-content:center makes the left overflow unscrollable) */
  .nav-inner{justify-content:flex-start}
  nav.categories{top:77px}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .hero-content{grid-template-columns:1fr}
  .hero-visual{display:none}
  .hero-text h1{font-size:44px}
  .banner{grid-template-columns:1fr;padding:40px 28px;margin:0 16px}
  .banner-content h2{font-size:32px}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .modal{grid-template-columns:1fr;max-height:95vh;overflow-y:auto}
  .modal-img{aspect-ratio:1.5}
  .pd-grid{grid-template-columns:1fr;gap:32px}
  .pd-info{position:static}
  .pd-info h1{font-size:32px}
  .account-grid{grid-template-columns:1fr;gap:24px}
  .account-nav{position:static;display:flex;flex-wrap:wrap;gap:4px}
  .account-nav a{margin-bottom:0}
  .admin-row{grid-template-columns:1fr}
  section{padding:56px 16px}
  .section-head h2{font-size:32px}
}
@media (max-width:600px){
  .header-inner{padding:14px 16px}
  .brand{font-size:22px}
  /* On phones, let the category strip scroll away with the page instead of
     pinning at a hardcoded offset — kills the gap that showed through below
     the header. */
  nav.categories{position:static}
  .nav-inner{padding:0 16px}
  /* Category tiles: smaller padding + type so long placeholder names fit/wrap */
  .cat-card .cat-content{padding:16px}
  .cat-card h3{font-size:18px}
  .hero{height:auto;padding:60px 0}
  .hero-text h1{font-size:34px}
  .cat-grid,.product-grid,.related-grid{grid-template-columns:1fr 1fr;gap:12px}
  .product-info{padding:14px}
  .product-name{font-size:14px}
  .price-now{font-size:15px}
  .nl-form{flex-direction:column}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .form-card{padding:32px 24px}
}

/* ── Phase 5: cross-device polish ───────────────────────────────────────── */
/* Wide admin tables scroll horizontally on small screens instead of
   overflowing the viewport or crushing their columns. */
@media (max-width:820px){
  #tabContent{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .admin-table{min-width:620px}
}
/* Finger-friendly touch targets (≥40–44px) and no iOS auto-zoom on focus. */
@media (max-width:600px){
  .icon-btn{width:44px;height:44px}
  .product-wishlist{width:40px;height:40px}
  .qty-controls button{width:40px;height:40px}
  .qty-controls span{padding:0 14px;font-size:15px}
  .pill{padding:10px 18px}
  /* 16px stops iOS Safari zooming in when a field gains focus */
  .field input, .field select, .field textarea,
  .nl-form input, .sort-select, .search-bar input{font-size:16px}
}

/* ============ ACCESSIBILITY ============ */
/* Visible keyboard focus on every interactive element (mouse clicks are
   unaffected — :focus-visible only fires for keyboard/AT navigation). */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible,
textarea:focus-visible, [tabindex]:focus-visible, .product:focus-visible{
  outline:3px solid var(--accent,#d98aa0);
  outline-offset:2px;
  border-radius:4px;
}
/* Skip-to-content link: off-screen until focused, then visible at top-left. */
.skip-link{
  position:fixed;top:8px;left:8px;z-index:2000;
  padding:10px 16px;border-radius:8px;
  background:var(--accent,#d98aa0);color:#1a1014;font-weight:700;
  transform:translateY(-150%);transition:transform .15s ease;
}
.skip-link:focus{transform:translateY(0)}
/* Honour the OS "reduce motion" setting — kill animations/large transitions. */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
}
