/* ═══════════════════════════════════════════════════════════
   LAUXURIA — features.css  (additive, never overrides base)
   All new feature styles scoped to avoid conflicts
═══════════════════════════════════════════════════════════ */

/* ── LOGIN MODAL ──────────────────────────────────────────── */
.login-overlay{position:fixed;inset:0;background:rgba(14,12,11,.55);backdrop-filter:blur(4px);z-index:998;opacity:0;pointer-events:none;transition:opacity .3s ease}
.login-overlay.open{opacity:1;pointer-events:all}
.login-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-46%);z-index:999;background:#faf7f2;width:min(460px,94vw);max-height:90vh;overflow-y:auto;padding:40px 40px 36px;opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease;border:1px solid #e8e0d4;box-shadow:0 24px 80px rgba(14,12,11,.18)}
.login-modal.open{opacity:1;pointer-events:all;transform:translate(-50%,-50%)}
.login-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.login-header h2{font-family:var(--font-display);font-size:26px;font-weight:400;letter-spacing:.02em}
.login-close{background:none;border:none;font-size:24px;color:var(--muted);line-height:1;padding:4px 8px;transition:color var(--tr)}
.login-close:hover{color:var(--ink)}
.login-form .login-group{margin-bottom:20px;position:relative}
.login-form label{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-weight:500}
.login-form input[type=email],.login-form input[type=password],.login-form input[type=text]{width:100%;border:1px solid var(--border);background:#fff;padding:12px 16px;font-family:var(--font-body);font-size:14px;color:var(--ink);outline:none;transition:border-color var(--tr)}
.login-form input:focus{border-color:var(--gold)}
.login-form input.input-error{border-color:#c0392b}
.login-form input.input-ok{border-color:#27ae60}
.login-pw-group{position:relative}
.login-pw-toggle{position:absolute;right:14px;top:36px;background:none;border:none;font-size:14px;cursor:pointer;color:var(--muted);padding:2px}
.login-forgot{display:block;font-size:12px;color:var(--gold);margin-top:8px;text-align:right;letter-spacing:.04em}
.login-forgot:hover{text-decoration:underline}
.login-remember{display:flex;align-items:center;gap:8px;margin-bottom:24px}
.login-remember input{accent-color:var(--gold)}
.login-remember label{font-size:13px;color:var(--muted);cursor:pointer}
.login-error-msg{background:#fdf2f2;border:1px solid #f5c6c6;color:#c0392b;padding:10px 14px;font-size:13px;margin-bottom:16px;border-radius:2px}
.login-field-error{display:block;font-size:11px;color:#c0392b;margin-top:5px;min-height:16px}
.login-btn{width:100%;background:var(--ink);color:var(--cream);border:none;padding:14px;font-size:12px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;transition:background var(--tr);display:block;text-align:center;cursor:pointer}
.login-btn:hover{background:#2a2520}
.login-btn-ghost{width:100%;background:none;border:1px solid var(--border);color:var(--muted);padding:12px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;transition:all var(--tr);display:block;text-align:center;cursor:pointer;margin-top:8px}
.login-btn-ghost:hover{border-color:var(--ink);color:var(--ink)}
.login-divider{text-align:center;margin:20px 0;position:relative;color:var(--muted);font-size:12px}
.login-divider:before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border)}
.login-divider span{background:#faf7f2;padding:0 12px;position:relative}
.login-social{width:100%;background:#fff;border:1px solid var(--border);padding:12px 16px;font-size:13px;display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:10px;transition:border-color var(--tr),box-shadow var(--tr);cursor:pointer;font-family:var(--font-body);color:var(--ink)}
.login-social:hover{border-color:var(--gold);box-shadow:0 2px 8px rgba(184,150,62,.12)}
.login-signup{text-align:center;font-size:13px;color:var(--muted);margin-top:16px}
.login-signup-link{color:var(--gold);font-weight:500}
.login-logged-in{text-align:center;padding:20px 0}
.login-avatar{width:64px;height:64px;background:var(--gold);color:var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:28px;margin:0 auto 16px}

/* ── ANNOUNCEMENT BAR CLOSE ───────────────────────────────── */
.ann{position:relative}
.ann-close{background:none;border:none;color:rgba(255,255,255,.5);font-size:18px;cursor:pointer;padding:0 0 0 16px;line-height:1;transition:color var(--tr)}
.ann-close:hover{color:var(--gold2)}

/* ── NOTIFICATION BELL & PANEL ────────────────────────────── */
.notif-trigger{position:relative}
.notif-badge{position:absolute;top:-6px;right:-6px;background:#c0392b;color:#fff;width:18px;height:18px;border-radius:50%;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;pointer-events:none}
.notif-overlay{position:fixed;inset:0;z-index:996;display:none}
.notif-overlay.open{display:block}
.notif-panel{position:fixed;top:78px;right:24px;width:360px;max-height:480px;background:#fff;border:1px solid var(--border);box-shadow:0 16px 48px rgba(14,12,11,.14);z-index:997;display:flex;flex-direction:column;transform:translateY(-8px) scale(.97);opacity:0;pointer-events:none;transition:transform .25s ease,opacity .25s ease}
.notif-panel.open{transform:translateY(0) scale(1);opacity:1;pointer-events:all}
.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.notif-panel-header h3{font-family:var(--font-display);font-size:18px;font-weight:400}
.notif-mark-all{background:none;border:none;color:var(--gold);font-size:12px;letter-spacing:.06em;cursor:pointer;padding:0}
.notif-mark-all:hover{text-decoration:underline}
.notif-close{background:none;border:none;font-size:22px;color:var(--muted);cursor:pointer;padding:0 4px;line-height:1}
.notif-panel-body{overflow-y:auto;flex:1;padding:8px 0}
.notif-loading{padding:32px;text-align:center;color:var(--muted);font-size:13px}
.notif-item{display:flex;align-items:flex-start;gap:12px;padding:14px 20px;border-bottom:1px solid rgba(232,224,212,.5);transition:background var(--tr);cursor:default}
.notif-item:hover{background:#faf7f2}
.notif-item.unread{background:rgba(184,150,62,.05)}
.notif-item.unread .notif-item-title{font-weight:600}
.notif-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.notif-icon.order{background:rgba(184,150,62,.12);color:var(--gold)}
.notif-icon.promo{background:rgba(39,174,96,.1);color:#27ae60}
.notif-icon.system{background:rgba(14,12,11,.06);color:var(--muted)}
.notif-item-body{flex:1;min-width:0}
.notif-item-title{font-size:13px;color:var(--ink);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-item-msg{font-size:12px;color:var(--muted);line-height:1.5}
.notif-item-time{font-size:11px;color:var(--muted);margin-top:4px;opacity:.7}
.notif-unread-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:5px}
.notif-empty{padding:48px 20px;text-align:center;color:var(--muted);font-size:13px}
.notif-empty svg{margin:0 auto 12px;opacity:.3}

/* ── CART DRAWER ENHANCEMENTS ─────────────────────────────── */
.cd-coupon-wrap{border-bottom:1px solid var(--border);padding:0}
.cd-coupon-toggle{width:100%;background:none;border:none;padding:14px 20px;display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;letter-spacing:.08em;color:var(--gold);cursor:pointer;text-align:left;transition:background var(--tr)}
.cd-coupon-toggle:hover{background:rgba(184,150,62,.06)}
.cd-coupon-toggle svg{flex-shrink:0}
.cd-coupon-body{background:#fdf9f3;overflow:hidden;max-height:0;transition:max-height .3s ease}
.cd-coupon-body.open{max-height:200px}
.cd-coupon-row{display:flex;gap:8px;padding:14px 16px 8px}
.cd-coupon-input{flex:1;border:1px solid var(--border);background:#fff;padding:10px 12px;font-family:var(--font-body);font-size:13px;color:var(--ink);outline:none;transition:border-color var(--tr)}
.cd-coupon-input:focus{border-color:var(--gold)}
.btn-gold-sm{background:var(--gold);color:var(--ink);border:none;padding:10px 16px;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:background var(--tr);white-space:nowrap}
.btn-gold-sm:hover{background:var(--gold2)}
.cd-coupon-msg{padding:0 16px 10px;font-size:12px;min-height:20px}
.cd-coupon-msg.success{color:#27ae60}
.cd-coupon-msg.error{color:#c0392b}
.cd-applied-coupons{padding:0 16px 12px;display:flex;flex-wrap:wrap;gap:6px}
.cd-applied-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(39,174,96,.1);border:1px solid rgba(39,174,96,.25);color:#27ae60;padding:5px 10px;font-size:11px;font-weight:600;letter-spacing:.06em}
.cd-remove-coupon{background:none;border:none;color:#27ae60;font-size:14px;cursor:pointer;padding:0;line-height:1;margin-left:2px}
.cd-cart-link{display:block;text-align:center;font-size:12px;color:var(--muted);letter-spacing:.06em;padding:8px;transition:color var(--tr)}
.cd-cart-link:hover{color:var(--ink)}

/* ── SHOP PAGE LAYOUT ─────────────────────────────────────── */
.shop-layout{display:grid;grid-template-columns:260px 1fr;gap:0;max-width:1360px;margin:0 auto;padding:48px 32px;align-items:start}
.shop-sidebar{background:#fff;border:1px solid var(--border);padding:28px 24px;position:sticky;top:90px}
.sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.sidebar-header h3{font-family:var(--font-display);font-size:20px;font-weight:400}
.sidebar-close-btn{display:none;background:none;border:none;font-size:22px;color:var(--muted);cursor:pointer}
.sidebar-section{border-top:1px solid var(--border);padding:20px 0}
.sidebar-section-title{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-weight:600}
.sidebar-cat-list{list-style:none;display:flex;flex-direction:column;gap:6px}
.sidebar-cat-link{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--muted);padding:6px 0;transition:color var(--tr)}
.sidebar-cat-link:hover,.sidebar-cat-link.active{color:var(--ink)}
.sidebar-cat-link.active{font-weight:600;border-left:2px solid var(--gold);padding-left:8px}
.sidebar-cat-count{font-size:11px;background:var(--warm);padding:2px 7px;border-radius:100px}
.price-range-inputs{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.price-input-group{display:flex;flex-direction:column;gap:4px;flex:1}
.price-input-group label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.price-input{width:100%;border:1px solid var(--border);padding:8px 10px;font-size:13px;font-family:var(--font-body);outline:none;transition:border-color var(--tr)}
.price-input:focus{border-color:var(--gold)}
.price-sep{color:var(--muted);font-size:14px;margin-top:18px}
.sidebar-check-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);cursor:pointer;padding:5px 0;transition:color var(--tr)}
.sidebar-check-label:hover{color:var(--ink)}
.sidebar-check{accent-color:var(--gold)}
.sidebar-reset-btn{width:100%;background:none;border:1px solid var(--border);color:var(--muted);padding:10px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;margin-top:8px;transition:all var(--tr)}
.sidebar-reset-btn:hover{border-color:var(--ink);color:var(--ink)}
.shop-sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(14,12,11,.5);z-index:299}
.shop-main{padding-left:32px}
.shop-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.shop-toolbar-left{display:flex;align-items:center;gap:16px}
.filter-toggle-btn{display:none;background:none;border:1px solid var(--border);padding:9px 16px;font-size:12px;font-weight:500;letter-spacing:.08em;color:var(--ink);cursor:pointer;align-items:center;gap:6px;transition:all var(--tr)}
.filter-toggle-btn:hover{border-color:var(--gold);color:var(--gold)}
.shop-results-count{font-size:13px;color:var(--muted)}
.active-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.active-filter-chip{display:inline-flex;align-items:center;background:rgba(184,150,62,.1);border:1px solid rgba(184,150,62,.3);color:var(--gold);padding:5px 12px;font-size:11px;font-weight:600;letter-spacing:.06em;transition:all var(--tr)}
.active-filter-chip:hover{background:rgba(184,150,62,.2)}
.active-filter-clear{font-size:12px;color:var(--muted);padding:5px 8px;text-decoration:underline}
.shop-coupon-banner{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:#fdf9f3;border:1px solid rgba(184,150,62,.25);padding:12px 16px;margin-bottom:20px;font-size:12px;color:var(--muted)}
.shop-coupon-banner>span:first-of-type{font-weight:600;color:var(--gold);letter-spacing:.06em}
.shop-coupon-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px dashed rgba(184,150,62,.4);padding:5px 10px}
.shop-coupon-chip code{font-family:monospace;font-size:12px;font-weight:700;color:var(--ink);letter-spacing:.08em;background:rgba(184,150,62,.1);padding:2px 6px}
.shop-coupon-chip span{font-size:11px;color:var(--muted)}
.copy-code-btn{background:var(--gold);color:var(--ink);border:none;padding:4px 8px;font-size:10px;font-weight:600;letter-spacing:.08em;cursor:pointer;transition:background var(--tr)}
.copy-code-btn:hover{background:var(--gold2)}
.copy-code-btn.copied{background:#27ae60;color:#fff}
.pcard-offer-tag{position:absolute;top:12px;right:12px;z-index:3;background:rgba(184,150,62,.9);color:var(--ink);font-size:9px;font-weight:600;letter-spacing:.1em;padding:3px 8px;display:flex;align-items:center;gap:4px}
.shop-empty-state{grid-column:1/-1;text-align:center;padding:80px 24px}
.shop-empty-icon{font-size:48px;margin-bottom:16px}
.shop-empty-state h3{font-family:var(--font-display);font-size:24px;font-weight:400;margin-bottom:8px}
.shop-empty-state p{color:var(--muted);font-size:14px;margin-bottom:24px}
.shop-pagination{margin-top:48px;display:flex;justify-content:center}
.shop-pagination .woocommerce-pagination ul{display:flex;gap:4px;list-style:none}
.shop-pagination .woocommerce-pagination a,.shop-pagination .woocommerce-pagination span{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);font-size:13px;color:var(--muted);transition:all var(--tr)}
.shop-pagination .woocommerce-pagination a:hover{border-color:var(--gold);color:var(--gold)}
.shop-pagination .woocommerce-pagination .current{background:var(--ink);color:var(--cream);border-color:var(--ink)}

/* ── SINGLE PRODUCT — OFFERS SECTION ─────────────────────── */
.pdp-offers{border:1px solid var(--border);margin:20px 0}
.pdp-offers-toggle{width:100%;background:#fdf9f3;border:none;padding:14px 16px;display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);cursor:pointer;text-align:left}
.pdp-offers-toggle:hover{background:rgba(184,150,62,.1)}
.offers-chevron{margin-left:auto;transition:transform .3s ease}
.pdp-offers-toggle.open .offers-chevron{transform:rotate(180deg)}
.pdp-offers-loading{padding:16px}
.offers-skeleton{height:38px;background:linear-gradient(90deg,var(--warm) 25%,#f9f5ee 50%,var(--warm) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;margin-bottom:8px}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.pdp-offers-list{padding:8px 12px 12px;display:flex;flex-direction:column;gap:8px}
.offer-item{display:flex;align-items:center;gap:10px;background:#fff;border:1px dashed rgba(184,150,62,.35);padding:10px 12px}
.offer-code{font-family:monospace;font-size:13px;font-weight:700;letter-spacing:.1em;background:rgba(184,150,62,.1);padding:4px 10px;color:var(--ink)}
.offer-label{flex:1;font-size:13px;color:var(--muted)}
.offer-expiry{font-size:11px;color:var(--muted);opacity:.7}
.offer-copy-btn{background:var(--gold);color:var(--ink);border:none;padding:6px 12px;font-size:10px;font-weight:700;letter-spacing:.1em;cursor:pointer;transition:background var(--tr);white-space:nowrap}
.offer-copy-btn:hover{background:var(--gold2)}
.offer-copy-btn.copied{background:#27ae60;color:#fff}
.pdp-offers-empty{padding:16px;font-size:13px;color:var(--muted);text-align:center}

/* ── TOAST ENHANCEMENTS ───────────────────────────────────── */
.toast{position:fixed;bottom:28px;right:28px;background:var(--ink);color:var(--cream);padding:13px 20px;font-size:13px;letter-spacing:.04em;z-index:9999;max-width:320px;opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .3s ease,transform .3s ease;border-left:3px solid var(--gold)}
.toast.show{opacity:1;transform:translateY(0)}
.toast.toast-success{border-left-color:#27ae60}
.toast.toast-error{border-left-color:#c0392b}
.toast.toast-warning{border-left-color:#f39c12}

/* ── SEARCH CLOSE BUTTON ─────────────────────────────────── */
.search-close-btn{background:none;border:none;color:rgba(255,255,255,.5);font-size:28px;cursor:pointer;padding:0 8px;line-height:1;transition:color var(--tr)}
.search-close-btn:hover{color:#fff}

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media(max-width:900px){
  .shop-layout{grid-template-columns:1fr;padding:24px 16px}
  .shop-main{padding-left:0;margin-top:16px}
  .shop-sidebar{position:fixed;top:0;left:-280px;width:280px;height:100vh;overflow-y:auto;z-index:400;transition:left .3s ease;border:none;box-shadow:4px 0 24px rgba(14,12,11,.15)}
  .shop-sidebar.open{left:0}
  .shop-sidebar-overlay.open{display:block}
  .sidebar-close-btn{display:block}
  .filter-toggle-btn{display:inline-flex}
  .testimonials-grid{grid-template-columns:1fr!important}
  .shop-layout .pgrid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:540px){
  .login-modal{padding:28px 20px 24px}
  .notif-panel{right:8px;left:8px;width:auto}
  .toast{left:16px;right:16px;bottom:16px;max-width:none}
  .shop-layout .pgrid{grid-template-columns:1fr}
  .cd-coupon-row{flex-direction:column}
  .cd-coupon-apply{width:100%}
}
