/* Flavour Friend — 16-bit / Chrono-Trigger skin.
   Ported verbatim from demo/mockup-nes.html (approved design). */

/* Pixel type (falls back to monospace offline). */
@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=VT323&display=swap');

:root{
  /* burgundy/gold brand in Chrono-Trigger menu-box shape */
  --burg-2:#7a2e43; --burg-1:#5a1f33; --burg-0:#3a1220; --burg-hi:#8f3a52;
  --gold:#e8c66a; --gold-2:#c8a24a; --cream:#f5ead2; --cream-mut:#cbb48c;
  --shadow:#1a0810; --line:#2a0c16;
  --screen-0:#2a1420; --screen-1:#120609;
  /* data marks — dark-surface categorical steps (Epicure culinary modes) */
  --m-choc:#3987e5; --m-citrus:#eb6834; --m-spice:#eda100; --m-savoury:#1baf7a;
  --m-other:#9c7f9a;
  --friend:#3987e5; --wild:#e8c66a;
  --pixel:'Press Start 2P', monospace;
  --pixel-read:'VT323', 'Courier New', monospace;
  --sans:system-ui,-apple-system,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
body{margin:0;line-height:1.5;color:var(--cream);
  background:
    radial-gradient(120% 90% at 50% 0%, #4a1a2c 0%, #2a0e18 55%, #1c0912 100%) fixed;
  font-family:var(--pixel-read);
  image-rendering:pixelated;
}

/* ---- Chrono-Trigger style window ---- */
.win{position:relative;padding:16px 18px;border-radius:8px;
  background:linear-gradient(180deg,#6f2740 0%,#4a1526 60%,#3a1220 100%);
  border:3px solid var(--cream);
  box-shadow:0 0 0 2px var(--line), 0 6px 0 var(--shadow),
             inset 0 0 0 2px rgba(232,198,106,.25);
}
.win-title{font-family:var(--pixel);font-size:.6rem;letter-spacing:1px;
  color:var(--gold);text-shadow:2px 2px 0 var(--shadow);
  text-transform:uppercase;margin:0 0 14px}
.win-sub{font-size:1rem;color:var(--cream-mut);margin:-8px 0 12px;
  text-shadow:1px 1px 0 var(--shadow)}
.placeholder{font-family:var(--sans);font-size:.82rem;color:var(--cream-mut);
  border:2px dashed rgba(245,234,210,.25);border-radius:6px;padding:16px;text-align:center}

/* ---- header ---- */
header{display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  padding:14px 20px;border-bottom:3px solid var(--gold-2);
  background:linear-gradient(180deg,#5a1f33,#2a0e18)}
header h1{font-family:var(--pixel);font-size:.95rem;margin:0;color:var(--gold);
  text-shadow:3px 3px 0 var(--shadow);letter-spacing:1px}
header .plate{flex:1;min-width:160px;font-size:1.5rem;color:var(--cream);
  text-shadow:2px 2px 0 var(--shadow)}
header .plate b{color:var(--gold)}
.cmds{display:flex;gap:10px}
.cmd{font-family:var(--pixel);font-size:.5rem;color:var(--cream);cursor:pointer;
  padding:9px 11px;border-radius:5px;border:2px solid var(--cream);
  background:linear-gradient(180deg,#7a2e43,#4a1526);
  text-shadow:1px 1px 0 var(--shadow);box-shadow:0 3px 0 var(--shadow)}
.cmd:hover{background:linear-gradient(180deg,#8f3a52,#5a1f33)}
.cmd[disabled]{opacity:.5;cursor:not-allowed}

/* ---- layout ---- */
.stage{max-width:1200px;margin:0 auto;padding:18px;
  display:flex;flex-direction:column;gap:18px}
.main{display:grid;grid-template-columns:1.55fr 1fr;gap:18px;position:relative}
.menus{display:grid;grid-template-columns:1fr 1fr 1.25fr;gap:18px}
@media(max-width:900px){.main{grid-template-columns:1fr}.menus{grid-template-columns:1fr}}

/* ---- map "screen" ---- */
.screen{background:radial-gradient(circle at 50% 40%,var(--screen-0),var(--screen-1));
  border:3px solid var(--line);border-radius:4px;padding:6px}
svg{width:100%;height:auto;display:block}
/* flavour-family regions (background blobs; never intercept node interaction) */
.region{pointer-events:none}
.region.filtered{display:none}
.region ellipse{transition:all .1s ease}
.region.hl ellipse{fill-opacity:.22;stroke-opacity:.95;stroke-width:2.5}
/* region key above the map — coloured circle symbols, hover to find on the map */
.regionkey{display:flex;flex-wrap:wrap;align-items:center;gap:5px 12px;
  margin:2px 0 10px;font-family:var(--sans);font-size:.8rem}
.rk-label{font-family:var(--pixel);font-size:.42rem;color:var(--cream-mut);
  text-transform:uppercase;letter-spacing:1px}
.rk-item{display:inline-flex;align-items:center;gap:7px;color:var(--cream);cursor:pointer;
  padding:2px 6px;border-radius:4px;text-shadow:1px 1px 0 var(--shadow)}
.rk-item:hover,.rk-item:focus{background:rgba(232,198,106,.16);color:var(--gold);outline:none}
.rk-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--shadow);flex:none}
.maptext{fill:var(--cream);stroke:var(--screen-1);stroke-width:3;
  paint-order:stroke;font-family:var(--pixel-read);font-size:15px}
.maptext.wc{fill:var(--wild);font-style:italic}
.maptext.basket{fill:#fff;font-weight:700;font-size:16px}
/* your-recipe items are diamonds, linked by a thin line on the map */
.recipe-link{stroke:#fff;stroke-width:1;opacity:.5;fill:none;pointer-events:none}
/* interactive nodes: hover (desktop) or tap/focus (touch) highlights the pair */
.mapnode{cursor:pointer}
.mapnode:focus{outline:none}
.leader{stroke:var(--gold-2);stroke-width:2;opacity:.75}
.mapnode :is(circle,polygon),.mapnode .maptext,.mapnode .leader{transition:all .1s ease}
.mapnode:hover .leader,.mapnode:focus .leader,.mapnode.hl .leader{stroke:var(--gold);
  stroke-width:2.5;opacity:1}
.mapnode:hover .maptext,.mapnode:focus .maptext,.mapnode.hl .maptext{fill:var(--gold);
  stroke-width:4}
.mapnode:hover :is(circle,polygon),.mapnode:focus :is(circle,polygon),
.mapnode.hl :is(circle,polygon){stroke:#fff;stroke-width:3;
  filter:brightness(1.4) drop-shadow(0 0 4px var(--gold))}
/* toggling a family: friends vanish, your-recipe dims, wildcards go dashed */
.mapnode.friend.filtered{display:none}
/* your-recipe never vanishes (the link line would point at nothing) — just fade */
.mapnode.basket.filtered{opacity:.4}
.mapnode.wild.filtered circle{stroke-dasharray:4 3}

/* collapsible map ledger — hovering a row highlights that node (JS in base.html) */
.ledger{margin-top:14px;font-family:var(--sans)}
.ledger>summary{font-family:var(--pixel);font-size:.5rem;color:var(--gold);cursor:pointer;
  text-transform:uppercase;letter-spacing:1px;padding:6px 0;list-style:none;
  text-shadow:1px 1px 0 var(--shadow)}
.ledger>summary::-webkit-details-marker{display:none}
.ledger>summary::before{content:"\25B8  ";color:var(--gold-2)}
.ledger[open]>summary::before{content:"\25BE  "}
.ledger-body{display:flex;flex-direction:column;gap:9px;padding:8px 0 2px}
.ledger-grp{display:flex;flex-wrap:wrap;gap:5px 10px;align-items:center}
.ledger-h{font-family:var(--pixel);font-size:.42rem;color:var(--cream-mut);width:100%;
  text-transform:uppercase;letter-spacing:1px}
.ledger-item{display:inline-flex;align-items:center;gap:6px;font-size:.98rem;color:var(--cream);
  cursor:pointer;padding:2px 7px;border-radius:4px;text-shadow:1px 1px 0 var(--shadow)}
.ledger-item:hover,.ledger-item:focus{background:rgba(232,198,106,.16);color:var(--gold);outline:none}
.ledger-item .dot{width:11px;height:11px;border:2px solid var(--shadow);flex:none}
/* symbol shapes: diamond = your recipe, circle = friends/wildcards */
.dia{clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);border:0 !important}
.circ{border-radius:50%}
.fam-dia{display:inline-block;width:11px;height:11px;flex:none;
  clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%)}
.legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px;font-size:1rem;
  color:var(--cream-mut)}
.legend span{display:inline-flex;align-items:center;gap:6px}
.legfilter{cursor:pointer;user-select:none;padding:2px 5px;border-radius:4px}
.legfilter:hover,.legfilter:focus{background:rgba(232,198,106,.14);color:var(--gold);outline:none}
.legfilter.off{opacity:.4;text-decoration:line-through}
.sw{width:12px;height:12px;border:2px solid var(--shadow)}

/* ---- ingredient detail popover ---- */
.popover{position:absolute;top:10px;right:10px;width:210px;z-index:5;padding:12px 13px}
.popover .win-title{margin-bottom:8px;font-size:.5rem}
.popover .x{position:absolute;top:8px;right:10px;color:var(--cream);cursor:pointer;
  font-size:1.2rem}
.popover .kv{font-size:1.05rem;color:var(--cream);text-shadow:1px 1px 0 var(--shadow)}
.popover .kv b{color:var(--gold)}

/* ---- what to expect ---- */
.prose{font-family:var(--sans);font-size:.92rem;line-height:1.6;color:var(--cream)}
.prose b{color:var(--gold)}
.lean{font-family:var(--sans);margin-top:.6rem;font-size:.82rem;color:var(--cream-mut)}
.lean b{color:var(--gold)}
.bars{margin-top:14px;display:flex;flex-direction:column;gap:8px}
.brow{display:grid;grid-template-columns:96px 1fr;align-items:center;gap:10px;
  font-size:1.15rem;text-shadow:1px 1px 0 var(--shadow)}
.btrack{height:14px;background:#2a0c16;border:2px solid var(--shadow)}
.bfill{display:block;height:100%;background:var(--gold);
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.25)}
.bfill.aroma{background:var(--m-citrus)}
/* nudge control: Less <  ..pips..  > More (MAX_STEPS each way, driven by app.py) */
.bias{display:flex;align-items:center;gap:5px}
.bb{display:grid;place-items:center;width:18px;height:16px;cursor:pointer;font-size:.5rem;
  color:var(--gold);border:2px solid var(--cream);border-radius:3px;padding:0;
  font-family:var(--pixel-read);
  background:linear-gradient(180deg,#7a2e43,#4a1526);box-shadow:0 2px 0 var(--shadow)}
.bb:hover{background:linear-gradient(180deg,#8f3a52,#5a1f33)}
.bb[disabled]{opacity:.35;cursor:not-allowed}
.bb[disabled]:hover{background:linear-gradient(180deg,#7a2e43,#4a1526)}
.pips{display:flex;gap:2px;align-items:center}
.pips i{width:7px;height:12px;background:#2a0c16;border:1px solid var(--shadow);display:block}
.pips .mid{width:2px;height:15px;background:var(--cream);border:0}
.pips i.mo{background:var(--gold)}
.pips i.le{background:#e08a3a}
.rec-weighted{font-family:var(--sans);font-size:.8rem;color:var(--gold);margin:-4px 0 10px}
/* left column stacks LENS over PREFERENCE SHAPER */
.col{display:flex;flex-direction:column;gap:18px}
.shaper-hint{font-family:var(--sans);font-size:.78rem;color:var(--cream-mut);margin:-6px 0 14px}
.pref{margin-bottom:14px}
.pref-h{display:flex;align-items:center;gap:8px;font-size:1.25rem;color:var(--cream);
  text-shadow:1px 1px 0 var(--shadow);margin-bottom:7px}
.pref-h .cur{color:var(--gold)}
.pref-h .rm{margin-left:auto;color:var(--wild);cursor:pointer}
.pref .bias{margin-left:22px}
.add-taste{font-family:var(--pixel);font-size:.5rem;color:var(--gold);cursor:pointer;
  border:2px dashed rgba(245,234,210,.5);border-radius:5px;padding:11px;text-align:center;
  text-transform:uppercase;letter-spacing:1px}
.add-taste:hover{border-color:var(--cream);background:rgba(232,198,106,.08)}
.add-taste .left{color:var(--cream-mut);font-size:.42rem;display:block;margin-top:5px}
.pref-h .rm{background:none;border:0;font-family:var(--pixel-read);font-size:1.25rem}
.slots-left{font-family:var(--sans);font-size:.72rem;color:var(--cream-mut);
  margin-top:8px;font-style:italic}
.cohesion{margin-top:16px;font-size:1.15rem;color:var(--cream);
  text-shadow:1px 1px 0 var(--shadow)}
.cohesion b{color:var(--gold)}
.meter{height:14px;background:#2a0c16;border:2px solid var(--shadow);margin-top:6px}
.meter i{display:block;height:100%;width:78%;background:var(--m-savoury);
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.25)}

/* ---- menu rows (navigable) ---- */
.mrow{display:flex;align-items:center;gap:8px;padding:3px 0;cursor:pointer;
  font-size:1.25rem;color:var(--cream);text-shadow:1px 1px 0 var(--shadow);
  background:none;border:0;width:100%;text-align:left;font-family:var(--pixel-read)}
.mrow .cur{width:14px;color:var(--gold);opacity:0}
.mrow.sel,.mrow:hover{color:var(--gold)}
.mrow.sel .cur,.mrow:hover .cur{opacity:1}
.mrow .exp{font-size:.98rem;color:var(--cream-mut);margin-left:22px;
  font-style:italic}
.lensrow{display:block;padding:6px 0;border-bottom:2px solid rgba(232,198,106,.15)}
.lensrow:last-child{border-bottom:0}

.rname-box{margin:0 0 14px}
.rname-input{width:100%;background:#2a0c16;border:2px solid var(--cream);border-radius:4px;
  padding:7px 9px;color:var(--gold);font-family:var(--pixel-read);font-size:1.2rem;
  outline:0}
.rname-input::placeholder{color:var(--cream-mut);font-style:italic}
.rname-input:focus{border-color:var(--gold)}
.basket{list-style:none;margin:0 0 12px;padding:0}
.basket li{display:flex;align-items:center;gap:8px;font-size:1.25rem;
  color:var(--cream);padding:2px 0;text-shadow:1px 1px 0 var(--shadow)}
.basket .rm{margin-left:auto;color:var(--wild);cursor:pointer;
  background:none;border:0;font-family:var(--pixel-read);font-size:1.25rem}
.basket-empty{font-family:var(--sans);font-size:.82rem;color:var(--cream-mut);margin:0 0 12px}
.recipe-item{cursor:pointer;border-radius:4px;outline:none}
.recipe-item:hover,.recipe-item:focus{color:var(--gold)}
.field{display:flex;align-items:center;gap:8px;margin-top:6px;
  border:2px solid var(--cream);background:#2a0c16;padding:6px 8px;border-radius:4px}
.field input{flex:1;background:transparent;border:0;outline:0;color:var(--cream);
  font-family:var(--pixel-read);font-size:1.25rem}
.field input::placeholder{color:var(--cream-mut)}
.field button{background:none;border:0;color:var(--gold);cursor:pointer;
  font-family:var(--pixel);font-size:.5rem}
.caret{width:9px;height:18px;background:var(--gold);animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
/* ---- type-ahead dropdown (shared: add field + shaper category) ---- */
.suggest{list-style:none;margin:6px 0 0;padding:4px;border:2px solid var(--cream);
  border-radius:4px;background:#2a0c16;box-shadow:0 4px 0 var(--shadow);
  max-height:240px;overflow-y:auto}
.suggest li{display:block}
.sg{display:flex;align-items:baseline;gap:8px;width:100%;text-align:left;cursor:pointer;
  background:none;border:0;padding:5px 7px;border-radius:3px;color:var(--cream);
  font-family:var(--pixel-read);font-size:1.2rem;text-shadow:1px 1px 0 var(--shadow)}
.sg:hover{background:linear-gradient(180deg,#7a2e43,#4a1526);color:var(--gold)}
.sg-sub{font-family:var(--sans);font-size:.72rem;color:var(--cream-mut)}
.chem-tag{font-family:var(--sans);font-size:.7rem;color:var(--cream-mut);font-style:italic}

/* shared info card (hover / press-hold on map nodes + recommendation rows) */
#infocard{display:none;position:fixed;z-index:50;max-width:250px;pointer-events:none;
  padding:10px 12px;border:2px solid var(--cream);border-radius:6px;
  background:linear-gradient(180deg,#4a1526,#2a0e18);box-shadow:0 5px 0 var(--shadow);
  font-family:var(--sans);color:var(--cream)}
.ic-name{display:flex;align-items:center;gap:7px;font-family:var(--pixel-read);
  font-size:1.25rem;color:var(--gold);text-shadow:1px 1px 0 var(--shadow);margin-bottom:5px}
.ic-dot{width:11px;height:11px;flex:none;border:2px solid var(--shadow)}
.ic-desc{font-size:.82rem;line-height:1.5;color:var(--cream);margin-bottom:7px}
.ic-row{font-size:.78rem;line-height:1.45;color:var(--cream-mut)}
.ic-row b{color:var(--cream)}
.ic-ai{font-size:.66rem;font-style:italic;color:var(--cream-mut);opacity:.7;margin-top:7px}

/* ---- info icon + tooltip (hover on desktop, tap/focus on touch) ---- */
.info{position:relative;display:inline-grid;place-items:center;width:16px;height:16px;
  margin-left:5px;border:2px solid var(--gold-2);border-radius:50%;color:var(--gold);
  font-family:var(--pixel);font-size:.45rem;cursor:help;vertical-align:middle;
  text-shadow:1px 1px 0 var(--shadow)}
.info:hover,.info:focus{background:rgba(232,198,106,.18);outline:0}
.info .tip{display:none;position:absolute;right:0;top:150%;z-index:20;width:270px;
  padding:11px 13px;font-family:var(--sans);font-size:.76rem;line-height:1.5;
  font-style:normal;color:var(--cream);text-align:left;text-shadow:none;
  background:linear-gradient(180deg,#4a1526,#2a0e18);
  border:2px solid var(--cream);border-radius:6px;box-shadow:0 5px 0 var(--shadow)}
.info:hover .tip,.info:focus .tip{display:block}
.info .tip b{color:var(--gold)}

.notice{font-family:var(--sans);font-size:.82rem;color:var(--cream-mut);margin:10px 0 0}
.notice .chip{display:inline-block;margin:4px 4px 0 0;padding:5px 8px;cursor:pointer;
  font-family:var(--pixel-read);font-size:1.05rem;color:var(--cream);
  border:2px solid var(--cream);border-radius:4px;background:linear-gradient(180deg,#7a2e43,#4a1526)}
.notice .chip:hover{color:var(--gold)}

.rec-h{font-family:var(--pixel);font-size:.5rem;color:var(--gold);
  text-shadow:1px 1px 0 var(--shadow);margin:2px 0 6px;text-transform:uppercase}
.rec-h.wild{color:var(--wild)}
.fam-sq{width:10px;height:10px;flex:none;display:inline-block;
  border:1px solid var(--shadow)}
.minibar{margin-left:auto;width:70px;height:8px;background:#2a0c16;
  border:2px solid var(--shadow)}
.minibar i{display:block;height:100%}
.add-plus{color:var(--gold);opacity:0;text-align:center;
  background:none;border:0;font-family:var(--pixel-read);font-size:1.25rem;cursor:pointer}
.step{display:inline-flex;gap:3px}
.step button{display:grid;place-items:center;width:19px;height:18px;cursor:pointer;
  font-size:.62rem;color:var(--gold);border:2px solid var(--cream);border-radius:3px;
  background:linear-gradient(180deg,#7a2e43,#4a1526);box-shadow:0 2px 0 var(--shadow);
  font-family:var(--pixel-read)}
.step button:hover{background:linear-gradient(180deg,#8f3a52,#5a1f33)}
.step button[disabled]{opacity:.35;cursor:not-allowed}
/* recommendation sub-groups: header pager + labelled bar column */
.grp-h{display:flex;align-items:center;justify-content:space-between;margin:2px 0 6px}
.grp-h.wtop{margin-top:16px}
.grp-h .rec-h{margin:0}
.pager{display:inline-flex;align-items:center;gap:7px;font-size:.98rem;color:var(--cream-mut)}
.rec-cols{display:grid;grid-template-columns:1fr 72px 22px;gap:8px;align-items:end;
  font-family:var(--pixel);font-size:.42rem;letter-spacing:1px;text-transform:uppercase;
  color:var(--cream-mut);margin-bottom:6px}
.rec-cols .lbl{text-align:center}
.recrow{display:grid;grid-template-columns:1fr 72px 22px;align-items:center;gap:8px;
  padding:3px 0;cursor:pointer;font-size:1.25rem;color:var(--cream);
  text-shadow:1px 1px 0 var(--shadow)}
.recrow:hover{color:var(--gold)}
.recrow .nm{display:flex;align-items:center;gap:8px;background:none;border:0;
  color:inherit;font-family:var(--pixel-read);font-size:1.25rem;cursor:pointer;text-align:left}
.recrow .nm .cur{color:var(--gold);opacity:0}
.recrow:hover .nm .cur,.recrow:hover .add-plus{opacity:1}

footer{font-family:var(--sans);text-align:center;color:var(--cream-mut);
  font-size:.75rem;padding:18px;border-top:2px solid var(--line)}
footer b{color:var(--gold-2)}

/* ---- About story modal ---- */
.modal{display:none;position:fixed;inset:0;z-index:100;align-items:center;
  justify-content:center;padding:20px}
.modal.show{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(12,4,8,.72)}
.modal-box{position:relative;z-index:1;max-width:560px;width:100%;
  max-height:88vh;overflow-y:auto}
.modal-x{position:absolute;top:10px;right:14px;background:none;border:0;
  color:var(--wild);cursor:pointer;font-family:var(--pixel-read);font-size:1.6rem;
  line-height:1}
.about-body{font-family:var(--sans);font-size:.92rem;line-height:1.65;color:var(--cream)}
.about-body p{margin:0 0 12px}
.about-body b{color:var(--gold)}
.about-sign{font-family:var(--pixel-read);font-size:1.2rem;color:var(--gold);
  text-align:right;margin-top:4px}
