/* ═══════════════════════════════════════════
   SCENTWATCH v2 — Deep Slate & Teal
   ═══════════════════════════════════════════ */

/* ── LIGHT ── */
[data-theme="light"] {
  --bg: #f3f4f6;
  --surface: #ffffff;
  --surface2: #f9fafb;
  --surface-hover: #f3f4f6;
  --inset: #e5e7eb;
  --sidebar-bg: #111827;
  --sidebar-text: #9ca3af;
  --sidebar-active: #f9fafb;
  --text1: #111827;
  --text2: #4b5563;
  --text3: #9ca3af;
  --border: #e5e7eb;
  --border2: #d1d5db;
  --accent: #0d9488;
  --accent-h: #0f766e;
  --accent-soft: #ccfbf1;
  --accent-text: #0f766e;
  --green: #059669;
  --green-soft: #d1fae5;
  --red: #dc2626;
  --red-soft: #fee2e2;
  --orange: #d97706;
  --orange-soft: #fef3c7;
  --purple: #7c3aed;
  --purple-soft: #ede9fe;
  --overlay: rgba(17,24,39,0.35);
  --sh1: 0 1px 2px rgba(0,0,0,0.04);
  --sh2: 0 4px 16px rgba(0,0,0,0.06);
  --sh3: 0 20px 60px rgba(0,0,0,0.12);
  --top-note: #fef3c7; --top-note-t: #92400e;
  --heart-note: #fce7f3; --heart-note-t: #9d174d;
  --base-note: #e0e7ff; --base-note-t: #3730a3;
}
/* ── DARK ── */
[data-theme="dark"] {
  --bg: #0b0f19;
  --surface: #111827;
  --surface2: #1a2035;
  --surface-hover: #1e2740;
  --inset: #0d1120;
  --sidebar-bg: #060a14;
  --sidebar-text: #6b7280;
  --sidebar-active: #e5e7eb;
  --text1: #e5e7eb;
  --text2: #9ca3af;
  --text3: #4b5563;
  --border: #1f2937;
  --border2: #374151;
  --accent: #2dd4bf;
  --accent-h: #5eead4;
  --accent-soft: rgba(45,212,191,0.1);
  --accent-text: #5eead4;
  --green: #34d399;
  --green-soft: rgba(52,211,153,0.1);
  --red: #f87171;
  --red-soft: rgba(248,113,113,0.08);
  --orange: #fbbf24;
  --orange-soft: rgba(251,191,36,0.08);
  --purple: #a78bfa;
  --purple-soft: rgba(167,139,250,0.08);
  --overlay: rgba(0,0,0,0.55);
  --sh1: 0 1px 2px rgba(0,0,0,0.3);
  --sh2: 0 4px 16px rgba(0,0,0,0.4);
  --sh3: 0 20px 60px rgba(0,0,0,0.6);
  --top-note: #422006; --top-note-t: #fbbf24;
  --heart-note: #4a0525; --heart-note-t: #f472b6;
  --base-note: #1e1b4b; --base-note-t: #818cf8;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text1);display:flex;min-height:100vh;-webkit-font-smoothing:antialiased;line-height:1.55}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
a{color:inherit;text-decoration:none}
input,select,textarea,button{font-family:inherit}

/* ═══ SIDEBAR ═══ */
.sidebar{width:250px;background:var(--sidebar-bg);position:fixed;top:0;left:0;bottom:0;z-index:100;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,0.04);transition:transform .3s ease}
.sidebar-brand{padding:18px 16px 16px;display:flex;align-items:center;gap:10px}
.brand-mark{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,var(--accent),#06b6d4);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;letter-spacing:1px;flex-shrink:0}
.brand-name{font-family:'DM Serif Display',serif;font-size:17px;color:#f9fafb;letter-spacing:-0.3px;white-space:nowrap}
.brand-name span{color:var(--accent)}
.sidebar-nav{flex:1;padding:4px 10px;display:flex;flex-direction:column;gap:2px}
.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--sidebar-text);font-size:13.5px;font-weight:500;transition:all .15s}
.nav-link svg{width:18px;height:18px;flex-shrink:0}
.nav-link:hover{color:#d1d5db;background:rgba(255,255,255,0.04)}
.nav-link.active{color:var(--sidebar-active);background:rgba(255,255,255,0.06)}
.sidebar-bottom{padding:14px;border-top:1px solid rgba(255,255,255,0.05);display:flex;justify-content:space-between;align-items:center}
.theme-btn{width:36px;height:36px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.03);color:var(--sidebar-text);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.theme-btn:hover{color:#e5e7eb;background:rgba(255,255,255,0.08)}
.theme-btn svg{width:16px;height:16px}
[data-theme="light"] .moon{display:none}[data-theme="dark"] .sun{display:none}
.sidebar-close{display:none;width:36px;height:36px;border:none;background:none;color:var(--sidebar-text);cursor:pointer;border-radius:8px}
.sidebar-close:hover{background:rgba(255,255,255,0.05)}
.sidebar-close svg{width:18px;height:18px}

/* ═══ MAIN ═══ */
.main{flex:1;margin-left:250px;min-height:100vh;display:flex;flex-direction:column}
.header{display:flex;align-items:center;gap:16px;padding:18px 32px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}
.page-title{font-family:'DM Serif Display',serif;font-size:22px;font-weight:400;flex:1}
.menu-btn{display:none;border:none;background:none;color:var(--text1);cursor:pointer;padding:4px}
.menu-btn svg{width:22px;height:22px}
.btn-add{display:flex;align-items:center;gap:7px;padding:9px 18px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s}
.btn-add:hover{background:var(--accent-h);transform:translateY(-1px)}
.btn-add svg{width:16px;height:16px}

.content{padding:28px 32px;flex:1}
.view{display:none;animation:fadeUp .25s ease}
.view.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.subtitle{color:var(--text3);font-size:14px;margin-bottom:24px;max-width:600px}

/* ═══ METRICS ═══ */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}
.metric{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px 22px;box-shadow:var(--sh1);transition:all .2s}
.metric:hover{box-shadow:var(--sh2);transform:translateY(-1px)}
.metric .mv{font-family:'DM Serif Display',serif;font-size:32px;line-height:1}
.metric .ml{font-size:12px;color:var(--text3);font-weight:500;margin-top:4px;letter-spacing:0.3px}
.metric.hl{background:var(--accent-soft);border-color:transparent}
.metric.hl .mv{color:var(--accent-text)}

/* ═══ TOOLBAR ═══ */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:22px;flex-wrap:wrap}
.search-box{display:flex;align-items:center;gap:8px;padding:9px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;flex:1;max-width:360px;transition:border-color .15s}
.search-box:focus-within{border-color:var(--accent)}
.search-box svg{width:16px;height:16px;color:var(--text3);flex-shrink:0}
.search-box input{border:none;background:none;color:var(--text1);font-size:14px;outline:none;width:100%}
.search-box input::placeholder{color:var(--text3)}
.view-toggle{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.vt{border:none;background:var(--surface);color:var(--text3);padding:8px 10px;cursor:pointer;transition:all .15s;display:flex;align-items:center}
.vt:hover{color:var(--text2)}
.vt.active{background:var(--accent);color:#fff}
.vt svg{width:16px;height:16px}

/* ═══ CARDS ═══ */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:16px}
.card-grid.list{grid-template-columns:1fr}
.fcard{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px;box-shadow:var(--sh1);transition:all .2s;position:relative;overflow:hidden}
.fcard:hover{box-shadow:var(--sh2);border-color:var(--border2)}
.fcard-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.fcard-brand{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent-text)}
.fcard-name{font-family:'DM Serif Display',serif;font-size:20px;line-height:1.25;margin-top:3px}
.fcard-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.fbadge{font-size:11px;font-weight:500;padding:3px 10px;border-radius:100px;background:var(--inset);color:var(--text2)}
.fbadge.target{background:var(--accent-soft);color:var(--accent-text)}
.fbadge.conc{background:var(--purple-soft);color:var(--purple)}
.fcard-btns{display:flex;gap:2px}
.fcard-btns button{border:none;background:none;color:var(--text3);cursor:pointer;padding:5px;border-radius:6px;transition:all .12s}
.fcard-btns button:hover{color:var(--text1);background:var(--inset)}
.fcard-btns svg{width:15px;height:15px}
.fcard-retailers{margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}
.fcard-retailers h5{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--text3);margin-bottom:8px}
.ret-chip{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:500;padding:4px 10px;border-radius:100px;background:var(--inset);color:var(--text2);text-decoration:none;margin:2px 3px 2px 0;transition:all .15s}
.ret-chip:hover{background:var(--accent-soft);color:var(--accent-text)}
.ret-chip svg{width:9px;height:9px}
.fcard-notes{margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}
.nrow{display:flex;align-items:center;gap:6px;margin-bottom:5px;flex-wrap:wrap}
.nrow-label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--text3);width:40px;flex-shrink:0}
.ntag{font-size:10.5px;font-weight:500;padding:2px 8px;border-radius:100px}
.nrow.top .ntag{background:var(--top-note);color:var(--top-note-t)}
.nrow.heart .ntag{background:var(--heart-note);color:var(--heart-note-t)}
.nrow.base .ntag{background:var(--base-note);color:var(--base-note-t)}
.fcard-flink{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:500;color:var(--accent-text);margin-top:10px;padding:4px 12px;background:var(--accent-soft);border-radius:100px;transition:all .15s}
.fcard-flink:hover{background:var(--accent);color:#fff}
.fcard-usernote{margin-top:10px;font-size:13px;color:var(--text3);font-style:italic;line-height:1.5}

.empty-state{grid-column:1/-1;text-align:center;padding:80px 24px}
.empty-state h3{font-family:'DM Serif Display',serif;font-size:22px;color:var(--text2);margin-bottom:8px}
.empty-state p{color:var(--text3);margin-bottom:20px}

/* ═══ TABLE ═══ */
.table-container{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--sh1)}
.dtable{width:100%;border-collapse:collapse;font-size:13.5px}
.dtable thead{background:var(--inset)}
.dtable th{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text3);text-align:left;padding:12px 18px;border-bottom:1px solid var(--border)}
.dtable td{padding:12px 18px;border-bottom:1px solid var(--border);vertical-align:middle}
.dtable tr:last-child td{border-bottom:none}
.dtable tr:hover td{background:var(--surface-hover)}
.dtable .td-name{font-weight:600}
.dtable .td-brand{color:var(--text2)}
.dtable .td-link{color:var(--accent-text);font-size:12px}
.dtable .td-link:hover{text-decoration:underline}
.dtable .btn-sm{padding:5px 10px;font-size:12px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text2);cursor:pointer;transition:all .12s}
.dtable .btn-sm:hover{border-color:var(--accent);color:var(--accent-text)}
.dtable .btn-del{border-color:transparent;color:var(--red);background:none}

/* ═══ ALERTS ═══ */
.alerts-grid{display:flex;flex-direction:column;gap:12px}
.alert-row{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px 22px;display:flex;align-items:center;gap:20px;box-shadow:var(--sh1);flex-wrap:wrap}
.alert-info{flex:1;min-width:180px}
.alert-info h4{font-family:'DM Serif Display',serif;font-size:16px}
.alert-info span{font-size:12px;color:var(--text3)}
.alert-field{display:flex;align-items:center;gap:6px}
.alert-field label{font-size:12px;color:var(--text3);white-space:nowrap}
.alert-field input{width:90px;padding:7px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text1);font-size:13px;font-family:inherit}
.alert-field input:focus{outline:none;border-color:var(--accent)}

/* ═══ SETTINGS ═══ */
.settings-panels{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:18px}
.spanel{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;box-shadow:var(--sh1)}
.spanel.full{grid-column:1/-1}
.spanel h3{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:4px}
.spanel>p{color:var(--text3);font-size:13px;margin-bottom:20px}
.fg{margin-bottom:16px}
.fg label{display:block;font-size:12.5px;font-weight:600;color:var(--text2);margin-bottom:5px}
.fi{width:100%;padding:9px 13px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text1);font-size:14px;transition:border-color .15s}
.fi:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.fi::placeholder{color:var(--text3)}
textarea.fi{resize:vertical;min-height:56px;line-height:1.5}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.fi-prefix{display:flex;align-items:center;border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:border-color .15s}
.fi-prefix:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.fi-prefix span{padding:9px 0 9px 13px;color:var(--text3);font-size:14px;user-select:none;background:var(--surface)}
.fi-prefix input{border:none;background:var(--surface);color:var(--text1);padding:9px 13px 9px 4px;font-size:14px;outline:none;width:100%;font-family:inherit}
.hint{font-size:11.5px;color:var(--text3);margin-top:3px;display:block}
.toggle-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;cursor:pointer;user-select:none}
.toggle-row input{display:none}
.tswitch{width:38px;height:20px;background:var(--border2);border-radius:10px;position:relative;flex-shrink:0;transition:background .2s}
.tswitch::after{content:'';width:14px;height:14px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 2px rgba(0,0,0,0.15)}
.toggle-row input:checked~.tswitch{background:var(--accent)}
.toggle-row input:checked~.tswitch::after{transform:translateX(18px)}
.toggle-text{font-size:13.5px;font-weight:450}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}
.btn-outline{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}
.btn-outline:hover{border-color:var(--accent);color:var(--accent-text)}
.btn-outline svg{width:14px;height:14px}
.btn-red{border-color:transparent;background:var(--red-soft);color:var(--red)}
.btn-red:hover{background:var(--red);color:#fff;border-color:transparent}

/* ═══ MODAL ═══ */
.modal-bg{position:fixed;inset:0;background:var(--overlay);backdrop-filter:blur(8px);z-index:200;display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.modal-bg.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:18px;width:100%;max-width:620px;box-shadow:var(--sh3);animation:modIn .3s cubic-bezier(.2,0,0,1);display:flex;flex-direction:column;max-height:calc(100vh - 80px)}
@keyframes modIn{from{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:none}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:22px 26px 12px}
.modal-head h2{font-family:'DM Serif Display',serif;font-size:22px}
.modal-x{border:none;background:none;color:var(--text3);cursor:pointer;padding:4px;border-radius:6px;transition:all .12s}
.modal-x:hover{color:var(--text1);background:var(--inset)}
.modal-x svg{width:20px;height:20px}
.modal-scroll{overflow-y:auto;padding:0 26px 10px;flex:1}
.modal-foot{display:flex;justify-content:flex-start;gap:10px;padding:14px 26px 22px;border-top:1px solid var(--border)}
.btn-cancel{padding:9px 18px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text2);font-size:13.5px;font-weight:500;cursor:pointer;transition:all .12s}
.btn-cancel:hover{background:var(--inset)}
.btn-save{padding:9px 22px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s}
.btn-save:hover{background:var(--accent-h)}

/* ═══ SMART SEARCH ═══ */
.smart-search{padding:0 26px 16px;position:relative}
.ss-label{font-size:12px;color:var(--text3);font-weight:500;margin-bottom:6px;display:block}
.ss-input-wrap{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--border);border-radius:10px;background:var(--inset);transition:all .15s}
.ss-input-wrap:focus-within{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--accent-soft)}
.ss-input-wrap svg{width:18px;height:18px;color:var(--text3);flex-shrink:0}
.ss-input-wrap input{border:none;background:none;color:var(--text1);font-size:15px;font-weight:400;outline:none;width:100%}
.ss-input-wrap input::placeholder{color:var(--text3)}
.ss-clear{border:none;background:none;color:var(--text3);cursor:pointer;font-size:16px;padding:2px 4px;border-radius:4px;display:none;transition:all .12s}
.ss-clear:hover{color:var(--text1);background:var(--inset)}
.ss-dropdown{position:absolute;left:26px;right:26px;top:100%;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--sh3);max-height:320px;overflow-y:auto;z-index:10;display:none}
.ss-dropdown.open{display:block}
.ss-group{padding:4px 0}
.ss-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text3);padding:8px 16px 4px}
.ss-item{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;cursor:pointer;transition:background .1s}
.ss-item:hover,.ss-item.focused{background:var(--accent-soft)}
.ss-item-name{font-size:14px;font-weight:500}
.ss-item-name mark{background:var(--accent-soft);color:var(--accent-text);border-radius:2px;padding:0 1px}
.ss-item-meta{font-size:11px;color:var(--text3)}
.ss-item-conc{font-size:10px;padding:2px 6px;border-radius:4px;background:var(--inset);color:var(--text3);margin-left:4px}
.ss-manual{border:none;background:none;color:var(--accent-text);font-size:12.5px;font-weight:500;cursor:pointer;padding:8px 0 0;display:block;transition:color .12s}
.ss-manual:hover{color:var(--accent)}
.selected-preview{margin:0 26px 14px;padding:16px 18px;background:var(--accent-soft);border:1px solid var(--accent);border-radius:12px;display:flex;align-items:center;gap:14px}
.selected-preview.hidden{display:none}
.sp-icon{width:42px;height:42px;border-radius:10px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.sp-info h4{font-size:15px;font-weight:600}
.sp-info span{font-size:12px;color:var(--text2)}
.sp-change{margin-left:auto;border:none;background:rgba(255,255,255,0.1);color:var(--accent-text);font-size:12px;font-weight:600;padding:5px 12px;border-radius:6px;cursor:pointer;transition:all .12s;white-space:nowrap}
.sp-change:hover{background:var(--accent);color:#fff}

/* TABS */
.mtabs{display:flex;gap:0;padding:0 26px;border-bottom:1px solid var(--border);margin-bottom:18px}
.mtab{padding:9px 16px;border:none;background:none;color:var(--text3);font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all .12s;font-family:inherit}
.mtab:hover{color:var(--text1)}
.mtab.active{color:var(--accent-text);border-bottom-color:var(--accent)}
.mpanel{display:none}.mpanel.active{display:block}
.panel-hint{font-size:13px;color:var(--text3);margin-bottom:16px}
.btn-ghost{display:flex;align-items:center;gap:6px;border:none;background:none;color:var(--accent-text);font-size:13px;font-weight:500;cursor:pointer;padding:8px 0;transition:color .12s;font-family:inherit}
.btn-ghost:hover{color:var(--accent)}
.btn-ghost svg{width:14px;height:14px}

/* RETAILER ROWS */
.ret-row{display:grid;grid-template-columns:140px 1fr auto;gap:10px;align-items:center;padding:12px;background:var(--inset);border-radius:8px;margin-bottom:8px;animation:fadeUp .2s ease}
.ret-row select,.ret-row input{font-size:13px;padding:8px 10px}
.ret-del{border:none;background:none;color:var(--text3);cursor:pointer;padding:4px 6px;border-radius:4px;font-size:16px;transition:all .12s}
.ret-del:hover{color:var(--red);background:var(--red-soft)}

/* NOTE PYRAMID */
.note-pyramid{margin-bottom:20px;text-align:center}
.np-layer{margin:0 auto 4px;padding:10px 16px;border-radius:8px;display:flex;flex-wrap:wrap;gap:4px;justify-content:center}
.np-layer.top{background:var(--top-note);max-width:60%}
.np-layer.heart{background:var(--heart-note);max-width:80%}
.np-layer.base{background:var(--base-note);max-width:100%}
.np-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;width:100%;margin-bottom:2px}
.np-layer.top .np-label{color:var(--top-note-t)}
.np-layer.heart .np-label{color:var(--heart-note-t)}
.np-layer.base .np-label{color:var(--base-note-t)}
.np-tag{font-size:11px;font-weight:500;padding:2px 8px;border-radius:100px;background:rgba(255,255,255,0.4)}
[data-theme="dark"] .np-tag{background:rgba(255,255,255,0.08)}
.np-empty{padding:30px;color:var(--text3);font-size:13px;background:var(--inset);border-radius:10px}

/* ═══ TOASTS ═══ */
.toasts{position:fixed;bottom:20px;right:20px;z-index:300;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 18px;box-shadow:var(--sh3);font-size:13.5px;font-weight:500;display:flex;align-items:center;gap:8px;animation:modIn .3s ease;min-width:260px}
.toast.ok{border-left:3px solid var(--green)}.toast.err{border-left:3px solid var(--red)}.toast.info{border-left:3px solid var(--accent)}

/* ═══ NOTE ICONS (inline) ═══ */
.ni{display:inline-block;margin-right:4px;font-size:0.95em;line-height:1;vertical-align:-1px;filter:saturate(1.1)}
.ntag,.dntag,.np-tag{display:inline-flex;align-items:center}

/* ═══ FRAGRANTICA-STYLE NOTE PYRAMID ═══ */
.np2{padding:8px 0 4px}
.np2-section{margin-bottom:22px}
.np2-section:last-child{margin-bottom:0}
.np2-head{text-align:center;font-size:10.5px;font-weight:700;letter-spacing:2.5px;color:var(--text3);margin-bottom:14px;display:flex;align-items:center;gap:14px;text-transform:uppercase}
.np2-head::before,.np2-head::after{content:'';flex:1;height:1px;background:var(--border)}
.np2-tiles{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;max-width:580px;margin:0 auto}
.note-tile{display:flex;flex-direction:column;align-items:center;gap:8px;width:78px}
.note-tile-img{width:72px;height:72px;border-radius:14px;background:linear-gradient(135deg,#ffffff,#f3f4f6);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px rgba(0,0,0,0.06),inset 0 0 0 1px rgba(0,0,0,0.03);transition:transform .2s,box-shadow .2s;overflow:hidden}
[data-theme="dark"] .note-tile-img{background:linear-gradient(135deg,#1e2740,#111827);box-shadow:0 2px 10px rgba(0,0,0,0.4),inset 0 0 0 1px rgba(255,255,255,0.04)}
.note-tile-img img{width:52px;height:52px;object-fit:contain;display:block}
.note-tile-img-fallback{font-size:36px;line-height:1}
.note-tile:hover .note-tile-img{transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,0.1)}
.note-tile-label{font-size:11.5px;text-align:center;color:var(--text2);line-height:1.25;font-weight:450}

/* ═══ SS ITEM LAYOUT (for conc display) ═══ */
.ss-item-main{display:flex;align-items:center;gap:6px;flex-wrap:wrap}

/* ═══ PERSISTENCE BANNER ═══ */
.persist-banner{display:flex;align-items:center;gap:14px;padding:12px 22px;background:var(--accent-soft);border-bottom:1px solid var(--border);font-size:13px}
.persist-banner.hidden{display:none}
.pb-icon{font-size:18px;flex-shrink:0}
.pb-text{flex:1;color:var(--text2)}
.pb-text strong{color:var(--text1);font-weight:600}
.pb-text a{color:var(--accent-text);font-weight:500;text-decoration:underline;cursor:pointer}
.pb-close{border:none;background:none;color:var(--text3);cursor:pointer;font-size:14px;padding:4px 8px;border-radius:4px}
.pb-close:hover{color:var(--text1);background:var(--inset)}

/* ═══ STATUS FILTERS ═══ */
.status-filter{display:flex;gap:4px;background:var(--inset);padding:3px;border-radius:8px}
.sf{border:none;background:none;color:var(--text3);padding:6px 12px;border-radius:6px;font-size:12.5px;font-weight:500;cursor:pointer;transition:all .12s;font-family:inherit}
.sf:hover{color:var(--text1)}
.sf.active{background:var(--surface);color:var(--text1);box-shadow:var(--sh1)}

/* ═══ STATUS BADGES ON CARDS ═══ */
.status-badge{position:absolute;top:14px;right:14px;padding:3px 10px;border-radius:100px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.6px}
.status-badge.wishlist{background:var(--purple-soft);color:var(--purple)}
.status-badge.owned{background:var(--green-soft);color:var(--green)}
.status-badge.sampled{background:var(--orange-soft);color:var(--orange)}
.status-badge.empty{background:var(--red-soft);color:var(--red)}
.fcard.clickable{cursor:pointer}
.fcard.clickable:hover{transform:translateY(-2px)}

/* ═══ STATUS SELECT IN MODAL ═══ */
.status-select{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.stat-opt{border:1px solid var(--border);background:var(--surface);color:var(--text2);padding:10px 8px;border-radius:8px;font-size:12.5px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit;text-align:center}
.stat-opt:hover{border-color:var(--border2);color:var(--text1)}
.stat-opt.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-text)}

/* ═══ QUICK RETAILERS ═══ */
.quick-retailers{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:14px}
.qr-btn{border:1px solid var(--border);background:var(--surface);color:var(--text2);padding:8px 10px;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:5px}
.qr-btn:hover{border-color:var(--accent);color:var(--accent-text);background:var(--accent-soft)}
.qr-btn.added{border-color:var(--green);background:var(--green-soft);color:var(--green)}
.qr-btn.added::after{content:'✓';margin-left:4px}

/* ═══ DETAIL MODAL ═══ */
.detail-modal{max-width:780px;max-height:calc(100vh - 80px);padding:0}
.detail-x{position:absolute;top:16px;right:16px;z-index:2;background:var(--surface);border:1px solid var(--border);width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.detail-x:hover{background:var(--inset)}
.detail-x svg{width:16px;height:16px}
.detail-body{overflow-y:auto;max-height:calc(100vh - 80px)}
.detail-hero{padding:28px 32px 20px;border-bottom:1px solid var(--border);position:relative}
.detail-brand{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--accent-text);margin-bottom:4px}
.detail-name{font-family:'DM Serif Display',serif;font-size:32px;line-height:1.15;margin-bottom:12px;max-width:calc(100% - 40px)}
.detail-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.detail-meta .fbadge{font-size:11.5px;padding:4px 11px}
.detail-actions{display:flex;gap:8px;flex-wrap:wrap}
.detail-actions button,.detail-actions a{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;border:none;transition:all .15s;font-family:inherit}
.detail-actions .btn-primary{background:var(--accent);color:#fff}
.detail-actions .btn-primary:hover{background:var(--accent-h)}
.detail-actions .btn-outline{background:var(--surface);border:1px solid var(--border);color:var(--text2)}
.detail-actions .btn-outline:hover{border-color:var(--accent);color:var(--accent-text)}
.detail-actions .btn-outline.danger:hover{border-color:var(--red);color:var(--red)}
.detail-actions svg{width:14px;height:14px}

.detail-section{padding:22px 32px;border-bottom:1px solid var(--border)}
.detail-section:last-child{border-bottom:none}
.detail-section h3{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.detail-section h3 .section-count{font-family:'Inter',sans-serif;font-size:12px;font-weight:500;color:var(--text3);background:var(--inset);padding:2px 8px;border-radius:100px}

/* Price chart */
.price-chart{background:var(--inset);border-radius:12px;padding:20px;position:relative}
.pc-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.pc-current{display:flex;align-items:baseline;gap:8px}
.pc-price{font-family:'DM Serif Display',serif;font-size:28px;color:var(--text1)}
.pc-trend{font-size:12px;font-weight:600;padding:3px 8px;border-radius:100px}
.pc-trend.down{background:var(--green-soft);color:var(--green)}
.pc-trend.up{background:var(--red-soft);color:var(--red)}
.pc-range{display:flex;gap:4px}
.pc-range button{border:none;background:none;color:var(--text3);padding:4px 10px;font-size:11px;font-weight:500;border-radius:4px;cursor:pointer;font-family:inherit}
.pc-range button.active{background:var(--surface);color:var(--text1);box-shadow:var(--sh1)}
.pc-chart-svg{width:100%;height:160px;display:block}
.pc-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.pc-stat-v{font-family:'IBM Plex Mono',monospace;font-size:14px;font-weight:500;color:var(--text1)}
.pc-stat-l{font-size:10.5px;color:var(--text3);text-transform:uppercase;letter-spacing:0.6px;margin-top:2px}
.pc-notice{font-size:12px;color:var(--text3);text-align:center;padding:10px;background:var(--surface);border-radius:8px;margin-top:12px}
.pc-notice strong{color:var(--accent-text)}

/* Retailer prices list */
.ret-list{display:flex;flex-direction:column;gap:8px}
.ret-list-item{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--inset);border-radius:10px;text-decoration:none;color:inherit;transition:all .15s}
.ret-list-item:hover{background:var(--surface-hover);transform:translateX(2px)}
.rli-name{font-weight:600;font-size:14px;flex:1}
.rli-price{font-family:'IBM Plex Mono',monospace;font-size:14px;color:var(--text1)}
.rli-status{font-size:11px;padding:3px 8px;border-radius:100px;background:var(--accent-soft);color:var(--accent-text);font-weight:500}
.rli-arrow{color:var(--text3);font-size:16px}

.detail-notes-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.detail-note-col{background:var(--inset);border-radius:10px;padding:14px}
.detail-note-col h4{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.detail-note-col.top h4{color:var(--top-note-t)}
.detail-note-col.heart h4{color:var(--heart-note-t)}
.detail-note-col.base h4{color:var(--base-note-t)}
.detail-note-col .dntag{display:inline-block;font-size:12px;padding:3px 9px;border-radius:100px;margin:2px 3px 2px 0}
.detail-note-col.top .dntag{background:var(--top-note);color:var(--top-note-t)}
.detail-note-col.heart .dntag{background:var(--heart-note);color:var(--heart-note-t)}
.detail-note-col.base .dntag{background:var(--base-note);color:var(--base-note-t)}

.detail-user-note{padding:16px 20px;background:var(--accent-soft);border-left:3px solid var(--accent);border-radius:0 8px 8px 0;color:var(--text2);font-style:italic;font-size:14px;line-height:1.6}

/* ═══ REQUEST FORM ═══ */
.request-section{max-width:600px;margin:0 auto;padding:0 20px 40px}
.req-search-wrap{position:relative}
.req-dropdown{position:absolute;left:0;right:0;top:calc(100% + 6px);background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--sh3);max-height:350px;overflow-y:auto;z-index:10;display:none}
.req-dropdown.open{display:block}
.req-result{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border)}
.req-result:last-child{border-bottom:none}
.req-result:hover{background:var(--accent-soft)}
.req-result-info{flex:1}
.req-result-name{font-weight:600;font-size:14px;color:var(--text1)}
.req-result-brand{font-size:12px;color:var(--text3)}
.req-result-meta{display:flex;gap:6px;margin-top:3px}
.req-result-tag{font-size:10px;padding:2px 7px;border-radius:100px;background:var(--inset);color:var(--text3);font-weight:500}
.req-result-btn{font-size:11px;font-weight:600;color:var(--accent-text);background:var(--accent-soft);border:1px solid var(--accent);padding:5px 12px;border-radius:8px;white-space:nowrap;cursor:pointer;transition:all .15s}
.req-result-btn:hover{background:var(--accent);color:#fff}
.req-loading{padding:20px;text-align:center;color:var(--text3);font-size:13px}
.req-no-key{padding:16px;text-align:center;color:var(--text3);font-size:13px}
.req-success{text-align:center;color:#059669;font-size:14px;font-weight:600;margin-top:12px}
@media(max-width:500px){.req-row{flex-direction:column}}

/* ═══ SVG LOGOS ═══ */
.hero-logo-svg{width:56px;height:56px;flex-shrink:0;border-radius:14px;filter:drop-shadow(0 4px 12px rgba(45,212,191,0.3))}
.sidebar-logo-svg{width:34px;height:34px;flex-shrink:0;border-radius:8px}

/* ═══ ENCYCLOPEDIA ═══ */
.encyclopedia{max-width:900px;margin:0 auto;padding:0 20px 40px}
.enc-title{font-family:'DM Serif Display',serif;font-size:24px;text-align:center;margin-bottom:24px;color:var(--text1)}
.enc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.enc-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px 20px;text-align:center;box-shadow:var(--sh1);transition:all .2s;position:relative;overflow:hidden}
.enc-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}
.enc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0}
.enc-card.c1::before{background:linear-gradient(90deg,#2dd4bf,#06b6d4)}
.enc-card.c2::before{background:linear-gradient(90deg,#a78bfa,#8b5cf6)}
.enc-card.c3::before{background:linear-gradient(90deg,#f472b6,#ec4899)}
.enc-card.c4::before{background:linear-gradient(90deg,#fbbf24,#f59e0b)}
.enc-card.c5::before{background:linear-gradient(90deg,#34d399,#10b981)}
.enc-card.c6::before{background:linear-gradient(90deg,#60a5fa,#3b82f6)}
.enc-icon{font-size:28px;margin-bottom:8px;display:block}
.enc-value{font-family:'DM Serif Display',serif;font-size:32px;color:var(--text1);line-height:1.1}
.enc-label{font-size:12.5px;color:var(--text3);font-weight:500;margin-top:4px;letter-spacing:0.3px}
.enc-card.coming .enc-value{font-size:14px;color:var(--text3);font-family:'Inter',sans-serif;font-weight:500}

/* ═══ HERO / DISCOVER ═══ */
.hero{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 200px);text-align:center;padding:40px 20px}
.hero-mark{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.hero-logo{width:52px;height:52px;font-size:18px;border-radius:14px}
.hero-brand{font-family:'DM Serif Display',serif;font-size:36px;color:var(--text1);letter-spacing:-0.5px}
.hero-brand span{color:var(--accent)}
.hero-tagline{font-family:'DM Serif Display',serif;font-size:30px;color:var(--text1);max-width:640px;line-height:1.2;margin-bottom:14px;font-weight:400;letter-spacing:-0.5px}
.hero-promise{font-size:15.5px;color:var(--text2);max-width:560px;line-height:1.55;margin-bottom:36px;font-weight:400}
.hero-search-wrap{position:relative;width:100%;max-width:560px;margin-bottom:20px}
.hero-search{display:flex;align-items:center;gap:10px;padding:14px 20px;background:var(--surface);border:2px solid var(--border);border-radius:16px;box-shadow:var(--sh2);transition:all .2s}
.hero-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft),var(--sh2)}
.hero-search svg{width:20px;height:20px;color:var(--text3);flex-shrink:0}
.hero-search input{border:none;background:none;color:var(--text1);font-size:17px;outline:none;width:100%;font-family:inherit}
.hero-search input::placeholder{color:var(--text3)}
.hero-kbd{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--text3);background:var(--inset);padding:3px 7px;border-radius:5px;border:1px solid var(--border);white-space:nowrap}
.hero-dropdown{position:absolute;left:0;right:0;top:calc(100% + 6px);background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--sh3);max-height:400px;overflow-y:auto;z-index:10;display:none}
.hero-dropdown.open{display:block}

/* ═══ FRAGRANCE DETAIL PAGE ═══ */
.frag-back{display:inline-flex;align-items:center;gap:6px;color:var(--text3);font-size:13px;font-weight:500;cursor:pointer;padding:6px 12px;border-radius:8px;border:none;background:none;transition:all .15s;font-family:inherit;margin-bottom:20px}
.frag-back:hover{color:var(--text1);background:var(--inset)}
.frag-back svg{width:16px;height:16px}

/* ═══ NEW HEADER: Bottle on left, info on right (above tabs, always visible) ═══ */
.frag-header{display:flex;gap:36px;align-items:flex-start;margin-bottom:28px;flex-wrap:wrap}
.frag-header-img{flex:0 0 240px;max-width:240px}
.frag-header-img .frag-bottle{flex:1 1 auto;max-width:100%;min-height:280px;width:100%;background:transparent;border:none;box-shadow:none}
[data-theme="dark"] .frag-header-img .frag-bottle{background:transparent}
.frag-header-img .frag-bottle img{max-height:300px;filter:drop-shadow(0 12px 24px rgba(0,0,0,0.28))}
.frag-header-info{flex:1;min-width:280px;display:flex;flex-direction:column}
.frag-header-info .frag-actions{margin-top:auto;padding-top:4px}
/* Signature notes inside the info column should play nice with narrower widths */
.frag-header-info .frag-signature-notes{max-width:100%}

@media(max-width:720px){
  .frag-header{flex-direction:column;align-items:center;gap:22px}
  .frag-header-img{flex:0 0 auto;max-width:220px;width:100%}
  .frag-header-img .frag-bottle{min-height:240px}
  .frag-header-img .frag-bottle img{max-height:240px}
  .frag-header-info{width:100%;align-items:flex-start}
  .frag-title{font-size:28px}
}

/* Accord bars — centered standalone block in the About tab, now that the bottle moved up */
.frag-accords-block{max-width:480px;margin:0 auto 28px;padding:8px 0}
.frag-accords-block .accords-section{width:100%}

.frag-hero{display:flex;gap:32px;margin-bottom:32px;flex-wrap:wrap}
.frag-info{flex:1;min-width:280px}
.frag-brand-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;color:var(--accent-text);margin-bottom:6px}
.frag-title{font-family:'DM Serif Display',serif;font-size:38px;line-height:1.15;margin-bottom:10px}
.frag-meta-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.frag-actions{display:flex;gap:10px;flex-wrap:wrap}
.frag-actions button,.frag-actions a{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:10px;font-size:13.5px;font-weight:600;cursor:pointer;text-decoration:none;border:none;transition:all .15s;font-family:inherit}
.frag-actions .btn-primary{background:var(--accent);color:#fff}
.frag-actions .btn-primary:hover{background:var(--accent-h);transform:translateY(-1px)}
.frag-actions .btn-outline{background:var(--surface);border:1px solid var(--border);color:var(--text2)}
.frag-actions .btn-outline:hover{border-color:var(--accent);color:var(--accent-text)}
.frag-actions svg{width:15px;height:15px}

/* ═══ DETAIL PAGE TABS (Prices / About) ═══ */
.detail-tabs{display:inline-flex;background:var(--inset);padding:5px;border-radius:14px;margin-bottom:24px;gap:0;border:1px solid var(--border)}

/* ═══ SIGNATURE NOTES (above tabs) ═══ */
.frag-signature-notes{font-size:14px;color:var(--text2);margin:14px 0 22px;line-height:1.75;max-width:640px}
.sig-tier{white-space:nowrap}
.sig-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-right:7px}
.sig-tier.top .sig-label{color:var(--top-note-t)}
.sig-tier.heart .sig-label{color:var(--heart-note-t)}
.sig-tier.base .sig-label{color:var(--base-note-t)}
.sig-sep{margin:0 12px;color:var(--text3)}
@media(max-width:640px){
  .frag-signature-notes{line-height:2}
  .sig-tier{display:inline-block}
  .sig-sep{display:none}
}
.detail-tab{border:none;background:none;color:var(--text2);padding:11px 24px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .18s;font-family:inherit;display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.detail-tab:hover{color:var(--text1)}
.detail-tab.active{background:var(--surface);color:var(--accent-text);box-shadow:var(--sh1)}
.detail-tab .dt-icon{font-size:15px;line-height:1}
.detail-panel{display:none;animation:fadeUp .25s ease}
.detail-panel.active{display:block}
@media(max-width:500px){
  .detail-tabs{display:flex;width:100%}
  .detail-tab{flex:1;justify-content:center;padding:11px 10px;font-size:13px}
}

/* ═══ ACCORDS ═══ */
.accords-section{width:350px}
.accords-section h3{font-family:'Inter',sans-serif;font-size:14px;font-weight:400;margin-bottom:14px;text-align:center;color:var(--text2)}
.accord-bar-wrap{margin-bottom:5px}
.accord-bar{height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,0.25);transition:width .8s cubic-bezier(.22,1,.36,1);min-width:60px;padding:0 10px;white-space:nowrap}

/* Brand display area */
.brand-logo-area{display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:16px}
.brand-logo-name{font-size:13px;color:var(--text3);letter-spacing:1px}
.brand-logo-text{font-family:'DM Serif Display',serif;font-size:28px;color:var(--text1);letter-spacing:-0.5px}

/* Bottle + accords two-column layout (Fragrantica-style) */
.frag-product{display:flex;gap:40px;align-items:flex-start;margin-bottom:32px;flex-wrap:wrap}
.frag-bottle{flex:0 0 320px;max-width:320px;min-height:380px;background:#fff;border:1px solid var(--border);border-radius:16px;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:var(--sh1)}
[data-theme="dark"] .frag-bottle{background:var(--surface)}
.frag-bottle img{max-width:100%;max-height:400px;object-fit:contain}
.frag-bottle-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px;text-align:center;color:var(--text3)}
.frag-bottle-placeholder .fbp-icon{font-size:64px;opacity:0.3}
.frag-bottle-placeholder .fbp-text{font-size:13px}
.frag-right{flex:1;min-width:280px;display:flex;flex-direction:column;align-items:flex-start;padding-top:10px}

/* ═══ PERFUMER ═══ */
.frag-perfumer{font-size:14px;color:var(--text3);margin-bottom:12px}
.perfumer-link{color:var(--accent-text);cursor:pointer;font-weight:500;text-decoration:none}
.perfumer-link:hover{text-decoration:underline}
.perfumer-section{margin-bottom:20px}
.perfumer-section h3{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:14px}
.perfumer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}
.perfumer-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;cursor:pointer;transition:all .15s}
.perfumer-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--sh2)}
.pc-name{font-weight:600;font-size:14px;color:var(--text1);margin-bottom:2px}
.pc-brand{font-size:12px;color:var(--text3)}
.pc-meta{font-size:11px;color:var(--text3);margin-top:4px}

/* ═══ LIVE PRICING ═══ */
.live-prices{margin-bottom:20px}
.live-prices h3{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:6px}
.live-prices .lp-sub{font-size:13px;color:var(--text3);margin-bottom:16px}
.lp-loading{padding:20px;text-align:center;color:var(--text3);font-size:13px}
.lp-size-tabs{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.lp-size-tab{padding:8px 16px;border:1px solid var(--border);border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;background:var(--surface);color:var(--text2);transition:all .15s;font-family:inherit}
.lp-size-tab:hover{border-color:var(--accent)}
.lp-size-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.lp-grid{display:grid;grid-template-columns:1fr;gap:10px}
.lp-card{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-radius:12px;text-decoration:none;color:inherit;transition:all .15s}
.lp-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--sh2)}
.lp-card.best{border-color:#059669;background:rgba(5,150,105,0.06)}
.lp-card.best .lp-price{color:#059669}
.lp-card.best .lp-best-tag{display:inline-block}
.lp-store{flex:1;min-width:0}
.lp-store-name{font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px}
.lp-store-tag{font-size:11px;color:var(--text3)}
.lp-product-name{font-size:12px;color:var(--text3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lp-price-col{text-align:right;flex-shrink:0}
.lp-price{font-family:'DM Serif Display',serif;font-size:22px;color:var(--text1)}
.lp-compare{font-size:11px;color:var(--text3);text-decoration:line-through}
.lp-savings{font-size:11px;font-weight:600;color:#059669}
.lp-best-tag{display:none;font-size:10px;font-weight:600;color:#fff;background:#059669;padding:2px 8px;border-radius:100px}
.lp-type-tag{font-size:10px;font-weight:600;padding:2px 8px;border-radius:100px}
.lp-type-tag.retail{color:#1e40af;background:#dbeafe}
.lp-type-tag.tester{color:#9333ea;background:#f3e8ff}
.lp-tester-info{font-size:12px;color:var(--text3);background:var(--inset);border-radius:10px;padding:12px 16px;margin-bottom:14px;line-height:1.5}
.lp-tester-info strong{color:var(--text2)}
.lp-unavail{font-size:12px;color:var(--text3);padding:10px 18px;background:var(--surface);border:1px solid var(--border);border-radius:12px;text-align:center}
.lp-arrow{color:var(--accent-text);font-size:16px;font-weight:600;flex-shrink:0}

/* ═══ PRICE INTEL ═══ */
.price-intel{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px 28px;box-shadow:var(--sh1);margin-bottom:20px}
.price-intel h3{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:14px}
.pi-tips{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pi-tip{padding:12px 14px;background:var(--inset);border-radius:10px;font-size:13px;color:var(--text2);line-height:1.5}
.pi-tip strong{color:var(--text1);display:block;margin-bottom:2px;font-size:12px}
.pi-tip.good{border-left:3px solid #059669}
.pi-tip.bad{border-left:3px solid #dc2626}
@media(max-width:600px){.pi-tips{grid-template-columns:1fr}}

/* ═══ FRAGRANCE DESCRIPTION ═══ */
.frag-desc{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px 28px;box-shadow:var(--sh1);margin-bottom:20px;font-size:15px;line-height:1.7;color:var(--text2)}
.frag-desc strong{color:var(--text1)}
.verified-badge{display:inline-block;font-size:11px;font-weight:600;color:#059669;background:#d1fae5;padding:3px 10px;border-radius:100px;margin-bottom:10px;margin-right:6px}
.estimated-badge{display:inline-block;font-size:11px;font-weight:600;color:#d97706;background:#fef3c7;padding:3px 10px;border-radius:100px;margin-bottom:10px;margin-right:6px}

/* ═══ PERFORMANCE (longevity + sillage) ═══ */
.perf-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.perf-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:var(--sh1);text-align:center}
.perf-card h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text3);margin-bottom:16px;display:flex;align-items:center;justify-content:center;gap:8px}
.perf-card h4 span{font-size:20px}
.perf-slider{width:100%;margin:12px 0 16px;-webkit-appearance:none;appearance:none;height:6px;border-radius:3px;background:var(--border);outline:none;cursor:pointer}
.perf-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);border:3px solid var(--surface);box-shadow:var(--sh2);cursor:pointer}
.perf-rows{text-align:left}
.perf-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.perf-row-label{font-size:13px;color:var(--text2);width:90px;flex-shrink:0}
.perf-row-count{font-size:12px;color:var(--text3);width:35px;text-align:right;font-family:'IBM Plex Mono',monospace}
.perf-row-bar{flex:1;height:8px;border-radius:4px;background:var(--border);overflow:hidden}
.perf-row-fill{height:100%;border-radius:4px;transition:width .4s ease}
.perf-row-fill.cyan{background:#22d3ee}
.perf-row-fill.green{background:#34d399}

/* ═══ PROS & CONS ═══ */
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.pc-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:var(--sh1)}
.pc-card h4{font-size:14px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.pc-card h4 .pc-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px}
.pc-card.pros h4 .pc-icon{background:#d1fae5;color:#059669}
.pc-card.cons h4 .pc-icon{background:#fef3c7;color:#d97706}
.pc-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13.5px;color:var(--text2);line-height:1.4}
.pc-item:last-child{border-bottom:none}
.pc-votes{display:flex;flex-direction:column;align-items:center;gap:2px;flex-shrink:0;color:var(--text3)}
.pc-votes button{border:none;background:none;cursor:pointer;padding:2px;color:var(--text3);font-size:14px}
.pc-votes button:hover{color:var(--accent-text)}
.pc-votes span{font-size:11px;font-family:'IBM Plex Mono',monospace}
.pc-placeholder{color:var(--text3);font-size:13px;text-align:center;padding:20px}

/* ═══ REVIEWS ═══ */
.reviews-section{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px 28px;box-shadow:var(--sh1);margin-bottom:20px}
.reviews-section h3{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:6px}

/* Reviews header — title on left, aggregate on right */
.reviews-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.reviews-head h3{margin-bottom:0}
.review-count-badge{font-family:'Inter',sans-serif;font-size:12px;font-weight:600;color:var(--accent-text);background:var(--accent-soft);padding:2px 9px;border-radius:100px;margin-left:4px;vertical-align:middle}
.reviews-avg{display:flex;align-items:center;gap:10px}
.reviews-avg-stars{font-size:15px;letter-spacing:1px}
.reviews-avg-num{font-family:'DM Serif Display',serif;font-size:22px;color:var(--text1);line-height:1}
.reviews-avg-label{font-size:12px;color:var(--text3)}

/* Star rendering */
.rv-star{color:var(--border2);font-size:inherit;letter-spacing:1px}
.rv-star.full{color:var(--orange)}
.rv-star.half{background:linear-gradient(90deg, var(--orange) 50%, var(--border2) 50%);-webkit-background-clip:text;background-clip:text;color:transparent}
.review-stars-display{font-size:14px;white-space:nowrap}
.review-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:16px}
.review-tab{padding:10px 16px;border:none;background:none;color:var(--text3);font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;font-family:inherit}
.review-tab:hover{color:var(--text1)}
.review-tab.active{color:var(--accent-text);border-bottom-color:var(--accent)}
.review-card{padding:16px 0;border-bottom:1px solid var(--border)}
.review-card:last-child{border-bottom:none}
.review-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.review-avatar{width:40px;height:40px;border-radius:50%;background:var(--inset);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text3)}
.review-user{font-weight:600;font-size:13.5px;color:var(--accent-text)}
.review-date{font-size:12px;color:var(--text3)}
.review-badges{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap}
.review-badge{font-size:10px;padding:3px 8px;border-radius:100px;font-weight:500}
.review-badge.rb-love{background:#fce7f3;color:#be185d}
.review-badge.rb-long{background:#ccfbf1;color:#0d9488}
.review-badge.rb-mod{background:#ede9fe;color:#7c3aed}
.review-badge.rb-season{background:var(--inset);color:var(--text2)}
.review-text{font-size:14px;color:var(--text2);line-height:1.6;margin-bottom:10px}
.review-actions{display:flex;gap:12px;align-items:center}
.review-actions button{border:none;background:none;color:var(--text3);cursor:pointer;font-size:13px;display:flex;align-items:center;gap:4px;font-family:inherit}
.review-actions button:hover{color:var(--text1)}
.review-cta{text-align:center;padding:24px;color:var(--text3);font-size:14px}
.review-cta button{margin-top:10px;padding:10px 24px;border:2px solid var(--accent);border-radius:10px;background:none;color:var(--accent-text);font-weight:600;cursor:pointer;font-family:inherit;font-size:14px;transition:all .15s}
.review-cta button:hover{background:var(--accent);color:#fff}

/* Avatar gets a soft accent background so initials aren't invisible */
.reviews-section .review-avatar{background:var(--accent-soft);color:var(--accent-text);font-weight:700;font-size:14px}

/* Review card layout refinements for the hydrated list */
.reviews-section .review-meta{flex:1;min-width:0}
.review-list{display:flex;flex-direction:column;gap:2px}
.review-empty{text-align:center;padding:28px 16px;color:var(--text3);font-size:13.5px}

/* Write-a-Review button (collapsed state) */
.review-write-cta{text-align:center;margin-top:18px;padding-top:18px;border-top:1px solid var(--border)}
.rev-write-btn{padding:11px 28px;border:2px solid var(--accent);border-radius:10px;background:var(--surface);color:var(--accent-text);font-weight:600;cursor:pointer;font-family:inherit;font-size:14px;transition:all .15s}
.rev-write-btn:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}

/* Expanded write-a-review form */
.rev-form{margin-top:20px;padding:22px;background:var(--inset);border:1px solid var(--border);border-radius:12px;animation:fadeUp .25s ease}
.rev-form h4{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:16px;color:var(--text1)}
.rev-form .fg{margin-bottom:14px}
.rev-form .fg:last-of-type{margin-bottom:18px}
.rev-form .fi{background:var(--surface)}
.fg-optional{font-weight:400;color:var(--text3);font-size:11.5px;letter-spacing:0.2px}

/* Star rating input (clickable, hover preview) */
.rev-rating-input{display:inline-flex;gap:3px;font-size:30px;line-height:1;user-select:none;padding:4px 0}
.rev-rating-input .rs{color:var(--border2);cursor:pointer;transition:color .1s,transform .1s}
.rev-rating-input .rs:hover{transform:scale(1.08)}
.rev-rating-input .rs.on{color:var(--orange)}

.rev-char-count{text-align:right;font-size:11px;color:var(--text3);margin-top:4px;font-family:'IBM Plex Mono',monospace}
.rev-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}

@media(max-width:600px){
  .reviews-head{flex-direction:column;align-items:flex-start;gap:8px}
  .reviews-avg{align-self:flex-start}
  .rev-form-actions{justify-content:stretch}
  .rev-form-actions button{flex:1}
}

/* ═══ COMMUNITY VOTING UI ═══ */
.vote-section{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px 28px;box-shadow:var(--sh1);margin-bottom:20px}
.vote-section h3{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:6px}
.vote-section .vote-sub{font-size:13px;color:var(--text3);margin-bottom:16px}
.accord-vote-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.av-btn{border:2px solid var(--border);background:var(--surface);color:var(--text2);padding:8px 16px;border-radius:100px;font-size:12.5px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}
.av-btn:hover{border-color:var(--border2);color:var(--text1)}
.av-btn.selected{border-color:var(--av-color,var(--accent));background:var(--av-color,var(--accent));color:#fff}
.vote-submit{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:10px;background:var(--accent);color:#fff;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}
.vote-submit:hover{background:var(--accent-h);transform:translateY(-1px)}

/* Rating row */
.rating-row{display:flex;gap:6px;flex-wrap:wrap}
.rate-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px;border:2px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text2);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;min-width:64px;font-family:inherit}
.rate-btn .rate-emoji{font-size:24px}
.rate-btn:hover{border-color:var(--border2);color:var(--text1)}
.rate-btn.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-text)}
.rate-count{font-size:10px;color:var(--text3);font-weight:400;margin-top:2px}

/* Ownership row */
.own-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.own-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;border:2px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit;flex:1;justify-content:center}
.own-btn:hover{border-color:var(--border2);color:var(--text1)}
.own-btn.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-text)}
.own-btn svg{width:16px;height:16px}
.own-count{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--text3)}

/* When to wear */
.wear-grid{display:flex;gap:6px;flex-wrap:wrap}
.wear-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 14px;border:2px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text2);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;min-width:60px;font-family:inherit}
.wear-btn .wear-icon{font-size:22px}
.wear-btn:hover{border-color:var(--border2);color:var(--text1)}
.wear-btn.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-text)}
.wear-bar{height:4px;border-radius:2px;background:var(--border);width:100%;margin-top:4px;overflow:hidden}
.wear-bar-fill{height:100%;border-radius:2px;transition:width .4s ease}

/* Accord chart label */
.accord-source{font-size:11px;color:var(--text3);text-align:center;margin-top:10px;display:flex;align-items:center;justify-content:center;gap:6px}
.accord-source .dot{width:6px;height:6px;border-radius:50%;display:inline-block}
.accord-source .dot.algo{background:var(--orange)}
.accord-source .dot.community{background:var(--green)}

/* ═══ CONTENT SECTIONS ═══ */
.frag-sections{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}
.frag-section{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px 28px;box-shadow:var(--sh1)}
.frag-section.full{grid-column:1/-1}
.frag-section h3{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:16px}
.frag-section h3 .badge{font-family:'Inter',sans-serif;font-size:11px;font-weight:600;color:var(--accent-text);background:var(--accent-soft);padding:3px 9px;border-radius:100px;margin-left:8px}

/* ═══ PRICE COMPARISON ═══ */
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.price-link{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--inset);border-radius:10px;text-decoration:none;color:inherit;transition:all .15s;border:1px solid transparent}
.price-link:hover{background:var(--accent-soft);border-color:var(--accent);transform:translateY(-1px)}
.price-link-name{font-weight:600;font-size:13.5px;flex:1}
.price-link-arrow{color:var(--accent-text);font-size:14px;font-weight:600}
.price-link-sub{font-size:11px;color:var(--text3)}

/* ═══ FRAGRANTICA LINK CARD ═══ */
.frag-link-card{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--accent-soft);border:1px solid var(--accent);border-radius:12px;text-decoration:none;color:inherit;transition:all .15s;margin-top:8px}
.frag-link-card:hover{transform:translateY(-2px);box-shadow:var(--sh2)}
.frag-link-card .flc-icon{font-size:24px}
.frag-link-card .flc-text{flex:1}
.frag-link-card .flc-title{font-weight:600;font-size:14px;color:var(--accent-text)}
.frag-link-card .flc-sub{font-size:12px;color:var(--text3)}
.frag-link-card .flc-arrow{font-size:18px;color:var(--accent-text)}

/* ═══ RESPONSIVE ═══ */
@media(max-width:900px){
  .sidebar{transform:translateX(-100%);width:240px}.sidebar.open{transform:none}
  .sidebar-close{display:block}
  .main{margin-left:0}.menu-btn{display:block}
  .header{padding:14px 18px}.content{padding:20px 18px}
  .metrics{grid-template-columns:1fr 1fr}
  .card-grid{grid-template-columns:1fr}
  .fg2,.fg3{grid-template-columns:1fr}
  .settings-panels{grid-template-columns:1fr}
  .status-filter{flex-wrap:wrap}
  .np2-tiles{gap:10px}
  .note-tile{width:66px}.note-tile-img{width:60px;height:60px}
  .note-tile-img img{width:42px;height:42px}
  .note-tile-img-fallback{font-size:30px}.note-tile-label{font-size:10.5px}
  .frag-sections{grid-template-columns:1fr}
  .frag-hero{flex-direction:column;gap:20px}
  .frag-title{font-size:28px}
  .accords-section{max-width:100%}
  .price-grid{grid-template-columns:1fr}
  .hero-tagline{font-size:24px;line-height:1.22;max-width:100%}
  .hero-promise{font-size:14px;max-width:100%}
  .hero-brand{font-size:28px}
  .hero-kbd{display:none}
}
@media(max-width:500px){
  .metrics{grid-template-columns:1fr 1fr;gap:8px}
  .status-filter{order:3;width:100%}
  .hero{min-height:auto;padding:30px 16px}
}
