:root{
  --sky:#d1fbff;            /* core brand */
  --sky-deep:#9fe9f2;
  --teal:#1f9fb5;           /* accent / links */
  --teal-deep:#0f7488;      /* primary button */
  --ink:#0b2a33;            /* headings, body */
  --muted:#5a7a82;          /* secondary text */
  --bg:#f5feff;
  --card:#ffffff;
  --line:#e1f3f6;
  --gold:#e7b53c; --silver:#9fb0b8; --bronze:#cf8a52;
  --shadow-sm:0 1px 2px rgba(11,42,51,.06),0 4px 12px rgba(11,42,51,.08);
  --shadow-md:0 2px 6px rgba(11,42,51,.08),0 12px 32px rgba(11,42,51,.12);
  --shadow-lg:0 8px 24px rgba(11,42,51,.12),0 24px 56px rgba(11,42,51,.16);
  --r:16px;
  /* Form-control tokens (modern, component-library feel) */
  --field-border:#d3e9ee;
  --field-border-hover:#b4dde6;
  --field-shadow:0 1px 2px rgba(11,42,51,.05);
  --ring:0 0 0 3.5px rgba(31,159,181,.16);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:var(--bg);color:var(--ink);
  font:15px/1.5 'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  -webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:600;letter-spacing:-.01em}
button{font-family:inherit;cursor:pointer}
a{color:var(--teal-deep)}

#map{position:fixed;inset:0;background:linear-gradient(160deg,var(--sky),#eafdff)}

/* Brand ───────────────────────────────────────────── */
.brand{position:fixed;top:18px;left:20px;z-index:5;display:flex;align-items:center;gap:9px;
  pointer-events:none}
.brand-mark{width:22px;height:22px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#fff,var(--sky) 55%,var(--teal) 130%);
  box-shadow:var(--shadow-sm),0 0 0 4px rgba(255,255,255,.6)}
.brand-name{font-family:'Fraunces',serif;font-weight:600;font-size:16px;color:var(--ink);
  background:rgba(255,255,255,.7);padding:3px 10px;border-radius:99px;backdrop-filter:blur(6px)}

/* Input panel ─────────────────────────────────────── */
.panel{position:fixed;top:62px;left:20px;z-index:4;width:360px;max-width:calc(100vw - 40px);
  background:rgba(255,255,255,.82);backdrop-filter:blur(16px) saturate(1.3);
  border:1px solid rgba(255,255,255,.9);border-radius:var(--r);box-shadow:var(--shadow-lg);
  padding:20px}
.panel-title{margin:0 0 4px;font-size:21px}
.panel-sub{margin:0 0 16px;font-size:13px;color:var(--muted);line-height:1.4}

.people{display:flex;flex-direction:column;gap:8px}
.person{position:relative}
.person-row{display:flex;align-items:center;gap:8px}
.dot{flex:none;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:12px;font-weight:600;box-shadow:var(--shadow-sm)}
/* Unified modern form controls ───────────────────── */
.person input,.vibe,.select{width:100%;background:#fff;color:var(--ink);font-family:inherit;font-size:14px;
  border:1px solid var(--field-border);border-radius:11px;padding:11px 13px;box-shadow:var(--field-shadow);
  transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}
.person input:hover,.vibe:hover,.select:hover{border-color:var(--field-border-hover)}
.person input:focus,.vibe:focus,.select:focus{outline:none;border-color:var(--teal);
  box-shadow:var(--ring),var(--field-shadow)}
.person input::placeholder,.vibe::placeholder{color:#9fbcc6}

.person input{flex:1;min-width:0}
.person .remove{flex:none;width:24px;height:24px;border:none;background:none;color:#b6cdd2;font-size:18px;
  line-height:1;border-radius:6px}
.person .remove:hover{color:var(--teal-deep);background:var(--sky)}

/* geocode suggestions */
.suggest{position:absolute;left:32px;right:0;top:38px;z-index:9;background:#fff;border:1px solid var(--line);
  border-radius:10px;box-shadow:var(--shadow-md);overflow:hidden;display:none}
.suggest.show{display:block}
.suggest button{display:block;width:100%;text-align:left;border:none;background:none;padding:9px 12px;
  font-size:13px;color:var(--ink);border-bottom:1px solid var(--line)}
.suggest button:last-child{border-bottom:none}
.suggest button:hover{background:var(--sky)}
.suggest .s-main{font-weight:500}
.suggest .s-sub{font-size:11.5px;color:var(--muted)}

.add-person{margin:10px 0 0;width:100%;background:none;border:1px dashed var(--sky-deep);
  color:var(--teal-deep);border-radius:10px;padding:9px;font-size:13px;font-weight:500}
.add-person:hover{background:var(--sky)}
.add-person:disabled{opacity:.4;cursor:not-allowed}

.field{margin-top:16px}
.field>label{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);margin-bottom:7px;font-weight:600}

.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{background:#fff;border:1px solid var(--field-border);border-radius:99px;color:var(--muted);
  padding:7px 14px;font-size:13px;font-weight:500;box-shadow:var(--field-shadow);
  transition:border-color .14s,background .14s,color .14s,box-shadow .14s}
.chip:hover{border-color:var(--field-border-hover);color:var(--ink)}
.chip.on{background:var(--teal-deep);border-color:var(--teal-deep);color:#fff;font-weight:600;
  box-shadow:0 1px 2px rgba(15,116,136,.25),0 4px 10px rgba(15,116,136,.18)}

/* Multiline AI vibe input */
.vibe-wrap{position:relative;margin-top:9px}
.vibe{display:block;resize:vertical;min-height:72px;line-height:1.45;padding-right:54px}
.vibe::placeholder{line-height:1.45}
.vibe-spark{position:absolute;top:9px;right:10px;pointer-events:none;font-size:10.5px;font-weight:700;
  letter-spacing:.04em;color:var(--teal-deep);background:var(--sky);border:1px solid var(--sky-deep);
  border-radius:99px;padding:2px 8px}

.select{font-weight:500;cursor:pointer;padding-right:34px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%230f7488' stroke-width='1.7' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 13px center;-webkit-appearance:none;appearance:none}

.find{margin-top:18px;width:100%;background:var(--teal-deep);color:#fff;border:none;border-radius:12px;
  padding:13px;font-size:15px;font-weight:600;box-shadow:var(--shadow-md);transition:.15s}
.find:hover:not(:disabled){background:var(--teal);transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.find:disabled{background:#bcd9de;color:#fff;cursor:not-allowed;box-shadow:none}
.find.loading{pointer-events:none;opacity:.85}

.hint{margin:9px 0 0;font-size:12px;color:var(--muted);text-align:center;min-height:16px}

/* Featured results ────────────────────────────────── */
.featured{position:fixed;left:0;right:0;bottom:0;z-index:4;padding:0 20px 18px;pointer-events:none}
.featured-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;
  max-width:1080px;margin:0 auto 10px;pointer-events:none}
.ai-summary{margin:0;flex:1;font-size:14px;line-height:1.45;color:var(--ink);
  background:rgba(255,255,255,.85);backdrop-filter:blur(12px);border-radius:12px;padding:11px 15px;
  box-shadow:var(--shadow-md);pointer-events:auto;min-height:0}
.ai-summary:empty{display:none}
.ai-summary .seasonal{color:var(--teal-deep);font-weight:600}
.share{flex:none;background:rgba(255,255,255,.85);backdrop-filter:blur(12px);border:1px solid var(--line);
  color:var(--teal-deep);border-radius:99px;padding:10px 18px;font-size:13px;font-weight:600;
  box-shadow:var(--shadow-md);pointer-events:auto}
.share:hover{background:#fff}

/* Result controls: rank-model pills + dynamic facet chips */
.result-controls{max-width:1080px;margin:0 auto 10px;display:flex;flex-direction:column;gap:8px;
  pointer-events:none}
.rank-pills{display:flex;flex-wrap:wrap;gap:6px;pointer-events:auto}
.rank-pill{background:rgba(255,255,255,.85);backdrop-filter:blur(12px);border:1px solid var(--line);
  color:var(--muted);border-radius:99px;padding:7px 13px;font-size:12.5px;font-weight:600;
  box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:6px}
.rank-pill .ico{font-size:13px}
.rank-pill:hover{color:var(--ink)}
.rank-pill.on{background:var(--teal-deep);border-color:var(--teal-deep);color:#fff}
.rank-pill .sub{font-weight:400;opacity:.75;font-size:11px}
.facets{display:flex;flex-wrap:wrap;gap:6px;pointer-events:auto}
.facet{background:rgba(255,255,255,.8);backdrop-filter:blur(12px);border:1px solid var(--line);
  color:var(--muted);border-radius:99px;padding:5px 11px;font-size:12px;font-weight:500;
  box-shadow:var(--shadow-sm)}
.facet:hover{border-color:var(--sky-deep);color:var(--ink)}
.facet.on{background:var(--sky);border-color:var(--sky-deep);color:var(--ink);font-weight:600}
.facet .n{opacity:.6;margin-left:3px}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:1080px;margin:0 auto;
  pointer-events:none}
.card{background:var(--card);border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;
  pointer-events:auto;cursor:pointer;border:2px solid transparent;transition:.15s;display:flex;flex-direction:column}
.card:hover,.card.hi{transform:translateY(-3px);border-color:var(--sky-deep)}
.card-photo{height:96px;background:var(--sky) center/cover;position:relative}
.card-photo.empty{background:linear-gradient(135deg,var(--sky),#eafdff)}
.medal{position:absolute;top:8px;left:8px;width:26px;height:26px;border-radius:50%;color:#fff;
  font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-sm);font-family:'Fraunces',serif}
.medal.g{background:var(--gold)} .medal.s{background:var(--silver)} .medal.b{background:var(--bronze)}
.card-body{padding:11px 13px 13px;display:flex;flex-direction:column;gap:6px;flex:1}
.card-name{font-family:'Fraunces',serif;font-weight:600;font-size:15.5px;line-height:1.2}
.card-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:12px;color:var(--muted)}
.rating{background:var(--sky);color:var(--teal-deep);font-weight:600;border-radius:6px;padding:1px 6px}
.price{color:var(--teal-deep);font-weight:600}
.open{color:#1c9d63;font-weight:600} .closed{color:#c2584f;font-weight:600}
.card-fair{font-size:12px;color:var(--ink)}
.card-fair b{font-weight:600}
.legs{font-size:11.5px;color:var(--muted);margin-top:1px}
.card-cta{margin-top:auto;display:flex;gap:8px;padding-top:4px}
.card-cta a{flex:1;text-align:center;text-decoration:none;border-radius:9px;padding:8px;font-size:12.5px;
  font-weight:600;transition:.12s}
.cta-primary{background:var(--teal-deep);color:#fff}
.cta-primary:hover{background:var(--teal)}
.cta-ghost{background:var(--sky);color:var(--teal-deep)}
.cta-ghost:hover{background:var(--sky-deep)}

.more-toggle{display:block;margin:10px auto 0;background:rgba(255,255,255,.85);backdrop-filter:blur(12px);
  border:1px solid var(--line);color:var(--teal-deep);border-radius:99px;padding:8px 18px;font-size:13px;
  font-weight:600;box-shadow:var(--shadow-md);pointer-events:auto}

/* Map markers ─────────────────────────────────────── */
.person-pin{width:28px;height:28px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);
  border:2px solid #fff;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center}
.person-pin span{transform:rotate(45deg);color:#fff;font-size:12px;font-weight:700}
.mid-pin{width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--teal-deep);
  box-shadow:var(--shadow-md)}
.venue-pin{width:14px;height:14px;border-radius:50%;background:var(--teal);border:2px solid #fff;
  box-shadow:var(--shadow-sm);cursor:pointer}
.venue-pin.top{width:30px;height:30px;font-size:14px;font-weight:700;color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif}
.venue-pin.top.g{background:var(--gold)} .venue-pin.top.s{background:var(--silver)} .venue-pin.top.b{background:var(--bronze)}

/* Detail overlay ──────────────────────────────────── */
.detail-scrim{position:fixed;inset:0;z-index:9;background:rgba(11,42,51,.28);backdrop-filter:blur(2px)}
.detail{position:fixed;top:0;right:0;bottom:0;z-index:10;width:420px;max-width:100vw;
  background:var(--card);box-shadow:var(--shadow-lg);overflow-y:auto;
  animation:slideIn .22s cubic-bezier(.2,.8,.2,1)}
@keyframes slideIn{from{transform:translateX(30px);opacity:0}to{transform:translateX(0);opacity:1}}
.detail-close{position:absolute;top:14px;right:14px;z-index:2;width:34px;height:34px;border:none;
  background:rgba(255,255,255,.9);border-radius:50%;font-size:22px;line-height:1;color:var(--ink);
  box-shadow:var(--shadow-sm)}
.detail-close:hover{background:#fff}
.detail-hero{height:200px;background:var(--sky) center/cover;position:relative}
.detail-body{padding:18px 20px 28px}
.detail-body h2{margin:0 0 3px;font-size:22px}
.detail-cat{color:var(--muted);font-size:13px;margin:0 0 12px}
.detail-meta{display:flex;flex-wrap:wrap;gap:7px;align-items:center;margin-bottom:14px}
.detail-legs{background:#f3fbfc;border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:14px}
.detail-legs h3{margin:0 0 8px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.detail-leg{display:flex;align-items:center;gap:9px;font-size:13px;padding:3px 0}
.detail-leg .dot{width:20px;height:20px;font-size:11px}
.detail-leg .who{flex:1;color:var(--ink)}
.detail-leg .t{font-weight:600;color:var(--teal-deep)}
.detail-addr{font-size:13px;color:var(--muted);margin:0 0 16px;line-height:1.5}
.detail-actions{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:14px}
.detail-actions a{text-align:center;text-decoration:none;border-radius:10px;padding:11px;font-size:13.5px;
  font-weight:600;transition:.12s}
.act-primary{background:var(--teal-deep);color:#fff}.act-primary:hover{background:var(--teal)}
.act-ghost{background:var(--sky);color:var(--teal-deep)}.act-ghost:hover{background:var(--sky-deep)}
.detail-links{display:flex;gap:14px;flex-wrap:wrap;font-size:12.5px}
.detail-note{font-size:11.5px;color:var(--muted);opacity:.8;margin-top:14px;line-height:1.5}
@media (max-width:720px){.detail{width:100%}}

/* Notice ──────────────────────────────────────────── */
.notice{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:8;
  background:var(--ink);color:#fff;padding:11px 18px;border-radius:12px;font-size:13px;
  box-shadow:var(--shadow-lg);max-width:90vw;text-align:center}
.notice a{color:var(--sky)}

/* Mobile ──────────────────────────────────────────── */
@media (max-width:720px){
  #map{bottom:auto;height:42vh;position:fixed;top:0}
  .panel{position:relative;top:0;left:0;width:100%;max-width:100%;margin:calc(42vh - 40px) 0 0;
    border-radius:20px 20px 0 0;box-shadow:var(--shadow-lg)}
  body{overflow-y:auto}
  .brand{top:12px;left:14px}
  .featured{position:relative;bottom:auto;padding:14px;background:var(--bg)}
  .featured-head{flex-direction:column;align-items:stretch}
  .cards{grid-template-columns:1fr}
  .card{flex-direction:row}
  .card-photo{width:96px;height:auto;flex:none}
  .card-body{flex:1}
}
