: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;
}
*{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)}
.person input{flex:1;min-width:0;background:#fff;border:1px solid var(--line);border-radius:10px;
  color:var(--ink);padding:10px 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}
.person input:focus{outline:none;border-color:var(--sky-deep);box-shadow:0 0 0 3px rgba(159,233,242,.4)}
.person input::placeholder{color:#a9c2c8}
.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(--line);border-radius:99px;color:var(--muted);
  padding:7px 14px;font-size:13px;font-weight:500;transition:.12s}
.chip:hover{border-color:var(--sky-deep)}
.chip.on{background:var(--sky);border-color:var(--sky-deep);color:var(--ink);font-weight:600}

.seg{display:flex;background:#eef9fb;border-radius:10px;padding:3px;gap:3px}
.seg button{flex:1;border:none;background:none;color:var(--muted);padding:8px;border-radius:8px;
  font-size:13px;font-weight:500}
.seg button.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}

.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}

.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)}

/* 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}
}
