/* ═══════════════════════════════════════════════════
   iCookMagic — Shop CSS
   Design: white dominant · black contrast · pink+neon
   ═══════════════════════════════════════════════════ */
:root {
  --m:#FF3D7F; --md:#D9266A; --ml:#fff5f8; --mb:#ffd0e0;
  --n:#39FF14; --nd:#2BC510; --nl:#f0ffe8;
  --ink:#1A1A1A; --s2:#3A3A3A; --mt:#6B6B6B;
  --bg:#f6f6f4; --wh:#fff; --ln:#E4E4E4; --ln2:#f2f2f0;
  --fh:'Cormorant Garamond',Georgia,serif;
  --fb:'DM Sans',system-ui,sans-serif;
}

/* ── PAGE ── */
.shop-page { background:var(--bg); min-height:100vh; }

/* ── STRIP ── */
.strip {
  background:#000; color:#fff;
  display:flex; align-items:center; gap:0;
  border-bottom:1px solid #222;
  overflow:hidden;
}
.strip-brand {
  flex-shrink:0; padding:10px 18px;
  font-family:var(--fh); font-style:italic; font-size:14px; font-weight:500;
  color:rgba(255,255,255,.8); border-right:1px solid #222; white-space:nowrap;
}
.strip-brand em { color:var(--m); }
.strip-brand .sp { color:var(--n); margin-right:5px; }
.strip-divider { width:1px; background:#222; align-self:stretch; }
.strip-ticker { flex:1; overflow:hidden; position:relative; }
.ticker-track {
  display:flex; gap:0; white-space:nowrap;
  animation:ticker-scroll 36s linear infinite;
  width:max-content;
}
.ticker-track:hover { animation-play-state:paused; }
@keyframes ticker-scroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.tk { display:inline-block; padding:10px 20px; font-size:12px; color:rgba(255,255,255,.7); }
.tk em { color:var(--m); font-style:italic; font-family:var(--fh); }
.tk b { color:#fff; }
.tk-new { background:var(--n); color:#000; font-size:9px; font-weight:800; padding:2px 7px; border-radius:100px; margin-right:4px; letter-spacing:.06em; }
.tk-dot { color:#333; padding:0 4px; }
.strip-cd {
  flex-shrink:0; padding:10px 18px; border-left:1px solid #222;
  font-size:11px; font-weight:600; color:rgba(255,255,255,.7);
  text-decoration:none; white-space:nowrap; transition:.15s;
}
.strip-cd:hover { color:var(--n); }
.strip-cd b { color:var(--n); }
.strip-cd-arr { color:var(--m); margin-left:4px; }

/* ── WELCOME BAR ── */
.welcome-bar {
  background:var(--wh); border-bottom:1px solid var(--ln);
  padding:12px 24px;
}
.welcome-bar-inner {
  max-width:1300px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap;
}
.wb-left { display:flex; align-items:center; gap:10px; }
.wb-eye {
  display:inline-flex; align-items:center; gap:5px;
  font-size:9px; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  color:var(--m); background:var(--ml); border:1px solid var(--mb);
  padding:3px 10px; border-radius:100px; white-space:nowrap;
}
.wb-msg { font-size:12.5px; color:var(--s2); }
.wb-msg em { font-family:var(--fh); font-style:italic; color:var(--ink); }
.wb-msg b { color:var(--ink); }
.wb-actions { display:flex; gap:8px; }
.wb-btn {
  padding:8px 16px; border-radius:100px; font-size:12px; font-weight:600;
  cursor:pointer; font-family:var(--fb); transition:.15s; border:1.5px solid;
}
.wb-btn.ghost { background:var(--wh); color:var(--ink); border-color:var(--ln); }
.wb-btn.ghost:hover { border-color:var(--ink); }
.wb-btn.primary { background:var(--ink); color:var(--wh); border-color:var(--ink); }
.wb-btn.primary:hover { background:var(--m); border-color:var(--m); }

/* ── LAYOUT ── */
.layout {
  max-width:1300px; margin:0 auto; padding:20px 20px 48px;
  display:grid; grid-template-columns:240px 1fr; gap:20px;
}
@media(max-width:900px) { .layout { grid-template-columns:1fr; } }

/* ── SIDEBAR ── */
.sidebar {
  align-self:start; position:sticky; top:16px;
  max-height:calc(100vh - 32px); overflow-y:auto;
  scrollbar-width:thin; scrollbar-color:var(--ln) transparent;
}
.sidebar::-webkit-scrollbar { width:3px; }
.sidebar::-webkit-scrollbar-thumb { background:var(--ln); border-radius:3px; }

.sidebar-hd {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 14px; background:#000; border-radius:10px 10px 0 0;
  border:1px solid #000;
}
.sidebar-hd h3 {
  font-family:var(--fh); font-style:italic; font-size:16px;
  font-weight:600; color:#fff; margin:0;
}
.sidebar-hd h3 em { color:var(--m); }
.sidebar-clear {
  font-size:10px; font-weight:700; color:rgba(255,255,255,.5);
  background:none; border:none; cursor:pointer; font-family:var(--fb);
  transition:.15s;
}
.sidebar-clear:hover { color:var(--m); }

.sb-sec {
  background:var(--wh); border:1px solid var(--ln); border-top:none;
  padding:10px 14px;
}
.sb-sec:last-of-type { border-radius:0 0 10px 10px; }

.sb-sec-lbl {
  font-size:8.5px; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--mt); margin-bottom:7px;
  display:flex; align-items:center; gap:5px;
}
.sb-sec-lbl::before { content:''; width:10px; height:2px; background:var(--m); flex-shrink:0; }

.sb-row { display:flex; flex-wrap:wrap; gap:4px; }
.sb-c {
  display:inline-flex; align-items:center; gap:3px;
  padding:4px 10px; border-radius:100px;
  border:1px solid var(--ln); background:var(--wh);
  font-size:10.5px; color:var(--s2); font-weight:500;
  cursor:pointer; transition:.15s; user-select:none;
  font-family:var(--fb);
}
.sb-c:hover { border-color:var(--m); color:var(--m); background:var(--ml); }
.sb-c.on { background:#000; border-color:#000; color:#fff; font-weight:600; }
.sb-c.m.on { background:var(--m); border-color:var(--m); color:#fff; }
.sb-c.n.on { background:var(--n); border-color:var(--nd); color:#000; }
.sb-c-n {
  background:rgba(0,0,0,.08); color:inherit; border-radius:100px;
  padding:0 5px; font-size:8.5px; font-weight:700; margin-left:1px;
}
.sb-c.on .sb-c-n { background:rgba(255,255,255,.2); }

/* ── MAIN COLUMN ── */
.main-col { min-width:0; }

/* ── TOOLBAR ── */
.toolbar {
  background:var(--wh); border:1px solid var(--ln); border-radius:10px;
  padding:10px 14px; display:flex; align-items:center; gap:10px;
  flex-wrap:wrap; margin-bottom:12px;
}
.filter-btn-mobile {
  display:none; align-items:center; gap:6px;
  padding:8px 14px; background:#000; color:#fff;
  border:none; border-radius:100px; font-size:12px; font-weight:700;
  cursor:pointer; font-family:var(--fb); position:relative;
}
@media(max-width:900px) { .filter-btn-mobile { display:inline-flex; } }
.filter-badge {
  background:var(--n); color:#000; font-size:9px; font-weight:800;
  padding:1px 6px; border-radius:100px; min-width:16px; text-align:center;
}

.cat-tabs { display:flex; gap:0; border:1px solid var(--ln); border-radius:8px; overflow:hidden; }
.cat-tab {
  padding:8px 14px; font-size:11.5px; font-weight:600; cursor:pointer;
  border:none; background:var(--wh); color:var(--mt);
  border-right:1px solid var(--ln); transition:.15s;
  font-family:var(--fb); white-space:nowrap;
}
.cat-tab:last-child { border-right:none; }
.cat-tab:hover { color:var(--ink); background:var(--bg); }
.cat-tab.on { background:#000; color:#fff; }
.ct-n {
  display:inline-block; background:rgba(0,0,0,.1); color:inherit;
  font-size:9px; font-weight:700; padding:0 5px; border-radius:100px; margin-left:3px;
}
.cat-tab.on .ct-n { background:rgba(255,255,255,.2); }

.smart-strip {
  flex:1; font-size:11.5px; color:var(--mt);
  display:flex; align-items:center; min-width:0;
}
.ss-icon { color:var(--m); margin-right:5px; }
.ss-text em { font-family:var(--fh); font-style:italic; color:var(--ink); }
.ss-text a { color:var(--m); font-weight:600; text-decoration:none; }
.ss-text a:hover { text-decoration:underline; }

.sort-sel {
  padding:8px 28px 8px 12px; border:1px solid var(--ln); border-radius:8px;
  font-size:11.5px; font-family:var(--fb); background:var(--wh) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1L5 5L9 1' stroke='%231A1A1A' stroke-width='1.5' fill='none'/></svg>") no-repeat right 10px center;
  color:var(--ink); outline:none; cursor:pointer; appearance:none;
  -webkit-appearance:none; font-weight:500;
}
.sort-sel:focus { border-color:var(--m); }

/* ── ACTIVE FILTER CHIPS ── */
.active-chips { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:10px; }
.act-chip {
  display:inline-flex; align-items:center; gap:4px;
  padding:4px 10px; background:var(--ml); border:1px solid var(--mb);
  border-radius:100px; font-size:10px; font-weight:600; color:var(--md);
}
.act-chip button {
  background:none; border:none; color:var(--mb); cursor:pointer;
  font-size:11px; line-height:1; padding:0; font-family:inherit;
}
.act-chip button:hover { color:var(--m); }

/* ── GRID ── */
.grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
  margin-bottom:16px;
}
@media(max-width:1100px) { .grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px)  { .grid { grid-template-columns:1fr; } }

/* ── PRODUCT CARD ── */
.card {
  background:var(--wh); border:1px solid var(--ln); border-radius:12px;
  overflow:hidden; display:flex; flex-direction:column;
  transition:transform .18s, box-shadow .18s, border-color .18s;
  cursor:pointer;
}
.card:hover {
  transform:translateY(-3px);
  box-shadow:0 10px 28px rgba(0,0,0,.08);
  border-color:#ccc;
}
.card.bestseller { border-color:var(--n); }
.card.feat { border-color:var(--m); }

/* Card image */
.card-img {
  height:180px; position:relative; background:#f5f5f3; overflow:hidden;
}
.card-img img {
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .3s;
}
.card:hover .card-img img { transform:scale(1.04); }
.ph {
  position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  background:linear-gradient(135deg,#fdf6f0,#fef0f5);
}
.ph-cuisine {
  font-size:10px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--mt); margin-bottom:4px;
}
.ph-name {
  font-family:var(--fh); font-size:18px; font-style:italic;
  font-weight:600; color:var(--ink); text-align:center; padding:0 10px;
}

/* Badges on image */
.badges { position:absolute; top:8px; left:8px; display:flex; gap:4px; flex-wrap:wrap; z-index:1; }
.b {
  font-size:9px; font-weight:800; letter-spacing:.06em; text-transform:uppercase;
  padding:3px 8px; border-radius:100px;
}
.b-best { background:#000; color:var(--n); }
.b-new  { background:var(--m); color:#fff; }
.b-trend{ background:var(--n); color:#000; }

/* Wishlist button */
.wish {
  position:absolute; top:8px; right:8px; z-index:1;
  width:28px; height:28px; border-radius:50%; border:1px solid var(--ln);
  background:rgba(255,255,255,.9); font-size:13px; color:var(--mt);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:.15s; box-shadow:0 2px 6px rgba(0,0,0,.1);
}
.wish:hover,.wish.on { color:var(--m); border-color:var(--mb); }

/* Diet ribbon */
.diet-ribbon {
  position:absolute; bottom:0; left:0; right:0;
  background:rgba(0,0,0,.75); backdrop-filter:blur(4px);
  padding:4px 8px; display:flex; gap:4px; flex-wrap:wrap;
}
.dl {
  font-size:8.5px; font-weight:700; padding:1px 7px; border-radius:100px;
  text-transform:uppercase; letter-spacing:.04em;
  background:rgba(255,255,255,.15); color:#fff;
}
.dl.m { background:rgba(255,61,127,.3); color:#fff; }

/* Card body */
.card-body {
  padding:12px 13px; flex:1; display:flex; flex-direction:column; gap:5px;
}
.cat-tag {
  font-size:9px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--mt); display:flex; align-items:center; gap:4px;
}
.ctd {
  width:5px; height:5px; border-radius:50%; background:var(--m);
  flex-shrink:0; display:inline-block;
}
.p-name {
  font-family:var(--fh); font-size:17px; font-weight:600;
  font-style:italic; color:var(--ink); margin:0; line-height:1.2;
}
.p-meta {
  font-size:11px; color:var(--mt); display:flex; align-items:center; gap:4px;
  flex-wrap:wrap;
}
.p-meta b { color:var(--ink); font-weight:700; }
.p-meta em { font-family:var(--fh); font-style:italic; color:var(--m); }
.dot { color:var(--ln); }
.p-rate {
  display:inline-flex; align-items:center; gap:3px;
  font-size:11px; font-weight:700; color:var(--ink);
}
.stars { color:var(--m); font-size:12px; }
.rv { color:var(--mt); font-weight:400; font-size:10px; }
.p-nutri { font-size:10.5px; color:var(--mt); font-weight:500; }
.p-nutri b { color:var(--s2); }

/* Health tags */
.p-tags { display:flex; flex-wrap:wrap; gap:3px; }
.htag {
  padding:2px 7px; background:var(--nl); border:1px solid var(--nd);
  border-radius:100px; font-size:9px; font-weight:600;
  color:#1a5c00; text-transform:capitalize;
}

/* Trust tags */
.p-trust { display:flex; flex-wrap:wrap; gap:3px; }
.ttag {
  padding:2px 7px; background:var(--bg); border:1px solid var(--ln);
  border-radius:100px; font-size:9px; font-weight:600; color:var(--s2);
}

/* Footer */
.p-foot { margin-top:auto; padding-top:8px; border-top:1px solid var(--ln2); }
.p-price-row { display:flex; align-items:baseline; gap:6px; margin-bottom:3px; }
.p-price {
  font-family:var(--fh); font-size:20px; font-style:italic;
  font-weight:700; color:var(--ink); line-height:1;
}
.p-per { font-size:10.5px; color:var(--mt); }
.p-coins {
  font-size:10px; font-weight:600; color:#B07A12;
  display:flex; align-items:center; gap:3px; margin-bottom:6px;
}
.ci { color:var(--n); font-size:12px; }
.p-actions { display:flex; gap:6px; align-items:center; }
.act-prebook {
  flex:1; padding:8px 10px; background:#000; color:#fff; border:none;
  border-radius:8px; font-size:11px; font-weight:700;
  cursor:pointer; font-family:var(--fb); transition:.15s;
  display:flex; align-items:center; justify-content:center; gap:4px;
}
.act-prebook:hover { background:var(--m); }
.act-prebook.done { background:var(--n); color:#000; }
.pba { font-size:13px; }
.act-notify,.act-wish-sm {
  width:32px; height:32px; border-radius:8px; border:1px solid var(--ln);
  background:var(--wh); font-size:13px; cursor:pointer; transition:.15s;
  display:flex; align-items:center; justify-content:center;
}
.act-notify:hover { border-color:var(--ink); background:var(--bg); }
.act-wish-sm:hover,.act-wish-sm.on { color:var(--m); border-color:var(--mb); }
.p-prelaunch {
  font-size:9px; color:var(--mt); text-align:center; margin-top:5px;
}

/* ── CATEGORY HEADERS ── */
.cat-hd {
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:10px; margin:20px 0 12px; padding-bottom:10px;
  border-bottom:2px solid #000;
}
.cat-hd:first-child { margin-top:0; }
.cat-hd-l {}
.cat-hd h2 {
  font-family:var(--fh); font-size:26px; font-weight:600;
  font-style:italic; line-height:1.05; margin:0 0 3px; color:var(--ink);
}
.cat-hd h2 em { color:var(--m); }
.ch-sub { font-size:12px; color:var(--mt); }
.ct-cnt {
  font-size:11px; color:var(--mt); font-weight:600;
  white-space:nowrap; padding-bottom:2px;
}
.ct-cnt b { color:var(--ink); font-weight:800; }

/* ── EDITORIAL BLOCKS ── */
.eb {
  border-radius:12px; padding:20px 24px; margin:16px 0;
  display:flex; flex-direction:column; gap:8px;
}
.eb-soft { background:var(--wh); border:1px solid var(--ln); }
.eb-dark { background:#000; color:#fff; }
.eb-mood { background:var(--ml); border:1px dashed var(--mb); }
.eb-eye {
  font-size:9px; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  color:var(--m); display:inline-flex; align-items:center; gap:5px;
  align-self:flex-start;
}
.eb-dark .eb-eye { color:var(--n); }
.eb h3 {
  font-family:var(--fh); font-size:20px; font-weight:600;
  font-style:italic; margin:0; line-height:1.1; color:var(--ink);
}
.eb-dark h3 { color:#fff; }
.eb h3 em { color:var(--m); }
.eb-dark h3 em { color:var(--n); }
.eb p { font-size:12.5px; color:var(--mt); line-height:1.6; margin:0; }
.eb-dark p { color:rgba(255,255,255,.7); }
.eb p b { color:var(--ink); }
.eb-dark p b { color:#fff; }
.eb-bigger { font-size:13.5px !important; color:var(--s2) !important; }
.eb-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 18px; background:#000; color:#fff; border:none;
  border-radius:100px; font-size:12px; font-weight:700;
  cursor:pointer; font-family:var(--fb); text-decoration:none;
  transition:.15s; align-self:flex-start; margin-top:4px;
}
.eb-btn:hover { background:var(--m); }
.eb-dark .eb-btn { background:var(--m); }
.eb-dark .eb-btn:hover { background:var(--md); }
.mood-tags { display:flex; flex-wrap:wrap; gap:5px; }
.mood-tag {
  padding:4px 11px; background:var(--wh); border:1px solid var(--mb);
  border-radius:100px; font-size:11px; color:var(--m); font-weight:600;
}

/* ── SUGGEST SECTION ── */
.suggest-section {
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
  background:var(--wh); border:1px solid var(--ln); border-radius:12px;
  padding:24px; margin-top:20px;
}
@media(max-width:700px) { .suggest-section { grid-template-columns:1fr; } }
.ss-l { display:flex; flex-direction:column; gap:8px; }
.ss-eye {
  font-size:9px; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  color:var(--m); display:inline-flex; align-items:center; gap:5px; align-self:flex-start;
}
.ss-l h2 {
  font-family:var(--fh); font-size:22px; font-weight:600;
  font-style:italic; margin:0; color:var(--ink);
}
.ss-l h2 em { color:var(--m); }
.ss-l p { font-size:12.5px; color:var(--mt); line-height:1.6; margin:0; }
.ss-l p b { color:var(--ink); }
.ss-tiny { font-family:var(--fh); font-style:italic; color:var(--m) !important; font-size:13px !important; }
.ss-form { display:flex; flex-direction:column; gap:10px; }
.ss-label { font-size:9px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--mt); }
.ss-input,.ss-textarea {
  padding:10px 12px; border:1.5px solid var(--ln); border-radius:8px;
  font-size:12.5px; font-family:var(--fb); background:var(--bg);
  outline:none; transition:.15s; width:100%;
}
.ss-input:focus,.ss-textarea:focus { border-color:var(--m); background:var(--wh); }
.ss-textarea { resize:vertical; min-height:72px; line-height:1.5; }
.ss-chips { display:flex; flex-wrap:wrap; gap:5px; }
.ss-chip {
  padding:5px 12px; border:1.5px solid var(--ln); border-radius:100px;
  font-size:11px; font-weight:500; cursor:pointer;
  background:var(--wh); color:var(--s2); font-family:var(--fb); transition:.15s;
}
.ss-chip:hover,.ss-chip.on { border-color:var(--m); color:var(--m); background:var(--ml); }
.ss-submit {
  padding:11px 20px; background:var(--m); color:#fff; border:none;
  border-radius:8px; font-size:13px; font-weight:700;
  cursor:pointer; font-family:var(--fb); transition:.15s;
}
.ss-submit:hover { background:var(--md); }
.ss-note { font-size:10.5px; color:var(--mt); }
.ss-note em { font-family:var(--fh); font-style:italic; color:var(--ink); }

/* ── FLOAT BUTTON ── */
.float-suggest {
  position:fixed; bottom:24px; right:24px; z-index:100;
  background:#000; color:#fff; border:none; border-radius:100px;
  padding:12px 18px; font-size:12px; font-weight:700;
  cursor:pointer; font-family:var(--fb); transition:.2s;
  display:flex; align-items:center; gap:6px;
  box-shadow:0 4px 16px rgba(0,0,0,.2);
}
.float-suggest:hover { background:var(--m); transform:translateY(-2px); }
.fs-ico { font-size:16px; }

/* ── FILTER DRAWER (mobile) ── */
.fd-overlay {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.5);
  z-index:300; opacity:0; transition:opacity .25s;
}
.fd-overlay.on { display:block; opacity:1; }
.fd {
  position:fixed; bottom:0; left:0; right:0; max-height:85vh;
  background:var(--wh); z-index:301;
  border-radius:16px 16px 0 0;
  transform:translateY(100%); transition:transform .3s cubic-bezier(.16,1,.3,1);
  overflow-y:auto; box-shadow:0 -8px 32px rgba(0,0,0,.15);
}
.fd.open { transform:translateY(0); }
.fd-handle {
  width:36px; height:4px; background:var(--ln); border-radius:2px;
  margin:10px auto 0;
}
.fd-hd {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 18px; border-bottom:1px solid var(--ln);
}
.fd-hd h3 { font-family:var(--fh); font-size:18px; font-weight:600; font-style:italic; margin:0; }
.fd-hd h3 em { color:var(--m); }
.fd-close {
  width:28px; height:28px; border-radius:50%; border:1px solid var(--ln);
  background:var(--wh); font-size:16px; cursor:pointer; display:flex;
  align-items:center; justify-content:center; color:var(--mt);
  transition:.15s;
}
.fd-close:hover { background:var(--m); color:#fff; border-color:var(--m); }
.fd-body { padding:14px 18px; }
.fd-sec { margin-bottom:14px; }
.fd-sec-lbl {
  font-size:9px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:var(--mt); margin-bottom:7px;
}
.fc-row { display:flex; flex-wrap:wrap; gap:5px; }
.fc {
  padding:5px 11px; border-radius:100px; border:1px solid var(--ln);
  font-size:11px; color:var(--s2); font-weight:500; cursor:pointer;
  background:var(--wh); transition:.15s; font-family:var(--fb);
}
.fc:hover,.fc.on { border-color:var(--m); color:var(--m); background:var(--ml); }
.fc.m.on { background:var(--m); color:#fff; border-color:var(--m); }
.fc.n.on { background:var(--n); color:#000; border-color:var(--nd); }
.fc-n { font-size:9px; opacity:.7; margin-left:2px; }
.fd-foot {
  display:flex; gap:10px; padding:14px 18px; border-top:1px solid var(--ln);
  background:var(--wh); position:sticky; bottom:0;
}
.fd-clear {
  flex:1; padding:11px; background:var(--bg); color:var(--ink); border:1px solid var(--ln);
  border-radius:8px; font-size:12px; font-weight:600; cursor:pointer; font-family:var(--fb);
}
.fd-apply {
  flex:2; padding:11px; background:#000; color:#fff; border:none;
  border-radius:8px; font-size:12px; font-weight:700; cursor:pointer; font-family:var(--fb);
  transition:.15s;
}
.fd-apply:hover { background:var(--m); }

/* ── SUGGEST MODAL ── */
.sug-modal {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.6);
  z-index:400; align-items:center; justify-content:center; padding:20px;
}
.sug-modal.on { display:flex; }
.sug-box {
  background:var(--wh); border-radius:14px; padding:24px;
  max-width:480px; width:100%; max-height:90vh; overflow-y:auto;
  position:relative; box-shadow:0 24px 60px rgba(0,0,0,.2);
}
.sug-close {
  position:absolute; top:14px; right:14px; width:28px; height:28px;
  border-radius:50%; border:1px solid var(--ln); background:var(--wh);
  font-size:16px; cursor:pointer; display:flex; align-items:center;
  justify-content:center; color:var(--mt); transition:.15s;
}
.sug-close:hover { background:var(--m); color:#fff; border-color:var(--m); transform:rotate(90deg); }
.sug-eye {
  font-size:9px; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  color:var(--m); display:block; margin-bottom:6px;
}
.sug-h2 {
  font-family:var(--fh); font-size:22px; font-weight:600;
  font-style:italic; margin:0 0 6px; color:var(--ink);
}
.sug-h2 em { color:var(--m); }
.sug-p { font-size:12.5px; color:var(--mt); margin-bottom:14px; }
.sug-field { margin-bottom:12px; }
.sug-label { font-size:9px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--mt); display:block; margin-bottom:5px; }
.sug-input,.sug-textarea {
  width:100%; padding:10px 12px; border:1.5px solid var(--ln); border-radius:8px;
  font-size:12.5px; font-family:var(--fb); background:var(--bg); outline:none; transition:.15s;
}
.sug-input:focus,.sug-textarea:focus { border-color:var(--m); background:var(--wh); }
.sug-textarea { resize:vertical; min-height:70px; }
.sug-chips { display:flex; flex-wrap:wrap; gap:5px; }
.form-chip {
  padding:5px 12px; border:1.5px solid var(--ln); border-radius:100px;
  font-size:11px; font-weight:500; cursor:pointer;
  background:var(--wh); color:var(--s2); font-family:var(--fb); transition:.15s;
}
.form-chip:hover,.form-chip.on { border-color:var(--m); color:var(--m); background:var(--ml); }
.sug-submit {
  width:100%; padding:12px; background:var(--m); color:#fff; border:none;
  border-radius:8px; font-size:13px; font-weight:700; cursor:pointer;
  font-family:var(--fb); transition:.15s; margin-top:4px;
}
.sug-submit:hover { background:var(--md); }
.sug-note { font-size:10.5px; color:var(--mt); margin-top:8px; text-align:center; }
.sug-note em { font-family:var(--fh); font-style:italic; color:var(--ink); }
.sug-thanks { display:none; text-align:center; padding:24px 0; }
.sug-thanks.on { display:block; }
.sug-thanks-h { font-family:var(--fh); font-size:24px; font-weight:600; font-style:italic; margin:0 0 8px; }
.sug-thanks-p { font-size:13px; color:var(--mt); margin-bottom:18px; line-height:1.6; }
.sug-thanks-p em { font-family:var(--fh); font-style:italic; color:var(--ink); }

/* ── TOAST ── */
.toast {
  position:fixed; bottom:80px; left:50%; transform:translateX(-50%) translateY(20px);
  background:#000; color:#fff; padding:10px 18px; border-radius:100px;
  font-size:12px; font-weight:600; z-index:500; opacity:0;
  transition:opacity .25s, transform .25s; pointer-events:none;
  display:flex; align-items:center; gap:7px; white-space:nowrap;
  box-shadow:0 4px 16px rgba(0,0,0,.2);
}
.toast.on { opacity:1; transform:translateX(-50%) translateY(0); }
.toast .ti { color:var(--n); font-size:14px; }
.toast em { font-family:var(--fh); font-style:italic; color:var(--m); }

/* ── EMPTY STATE ── */
.empty {
  text-align:center; padding:56px 24px;
  background:var(--wh); border:1px solid var(--ln); border-radius:12px;
}
.ee { font-size:44px; margin-bottom:12px; opacity:.4; }
.empty h4 { font-family:var(--fh); font-size:22px; font-style:italic; margin:0 0 8px; }
.empty p { font-size:13px; color:var(--mt); margin:0 0 16px; }
.empty button {
  padding:10px 20px; background:var(--m); color:#fff; border:none;
  border-radius:8px; font-size:13px; font-weight:700;
  cursor:pointer; font-family:var(--fb);
}

/* ── RESPONSIVE ── */
@media(max-width:900px) {
  .layout { padding:14px 14px 40px; }
  .welcome-bar { padding:10px 14px; }
  .strip-brand { display:none; }
}
@media(max-width:600px) {
  .toolbar { gap:8px; }
  .smart-strip { display:none; }
  .suggest-section { padding:16px; }
}
