/* ============================================================
   CHOWDOWN OUTTA TOWN, interactive map component
   Framework-free rebuild of the Claude Design map spec.
   Country -> State -> Metro, breadcrumb, search, Featured toggle.
   ============================================================ */
.cot-map-wrap{position:relative;z-index:1}

/* legend + disclosure + featured toggle row */
.cot-legend{display:flex;flex-wrap:wrap;gap:12px 18px;align-items:center;justify-content:center;margin:0 0 10px}
.cot-legend .item{display:inline-flex;align-items:center;gap:8px;font-family:"Supreme",sans-serif;font-size:13px;font-weight:700;background:var(--cream);border:2px solid var(--ink);border-radius:999px;padding:6px 13px}
.cot-legend .d-fav{width:14px;height:14px;border-radius:50%;background:var(--ink);border:2px solid var(--saffron);display:inline-block}
.cot-legend .d-leg{font-size:15px;line-height:1}
.cot-legend .d-feat{width:15px;height:15px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ffd877,#f29b1d);border:2px solid var(--ink);display:inline-block}
.cot-disclosure{text-align:center;font-family:"Supreme",sans-serif;font-size:12.5px;font-weight:600;color:#9a8f6f;max-width:64ch;margin:0 auto 14px}

.cot-feat-toggle{display:inline-flex;align-items:center;gap:9px;font-family:"Supreme",sans-serif;font-weight:800;text-transform:uppercase;font-size:11px;letter-spacing:.06em;color:var(--ink);background:var(--cream);border:2px solid var(--ink);border-radius:999px;padding:7px 14px;cursor:pointer}
.cot-feat-toggle .sw{position:relative;width:34px;height:18px;border-radius:999px;background:#cdbf95;border:2px solid var(--ink);transition:background .18s;flex:none}
.cot-feat-toggle .sw::after{content:"";position:absolute;top:1px;left:1px;width:12px;height:12px;border-radius:50%;background:var(--cream);border:1.5px solid var(--ink);transition:transform .18s}
.cot-feat-toggle[aria-pressed="true"] .sw{background:var(--saffron)}
.cot-feat-toggle[aria-pressed="true"] .sw::after{transform:translateX(16px)}

/* stage: map + list */
.cot-stage{display:grid;grid-template-columns:1fr 360px;gap:22px;align-items:stretch;height:clamp(460px,54vw,640px)}
@media(max-width:900px){.cot-stage{grid-template-columns:1fr;height:auto}}

.cot-map{position:relative;width:100%;height:100%;border:3px solid var(--ink);border-radius:22px;overflow:hidden;box-shadow:8px 8px 0 var(--ink);background:#fdf6da}
@media(max-width:900px){.cot-map{height:clamp(360px,72vw,460px)}}
.cot-frame{position:absolute;inset:0;margin:auto;width:100%;aspect-ratio:5/3;max-height:100%}
.cot-layer{position:absolute;inset:0;transition:opacity .4s ease}
.cot-layer svg{position:absolute;inset:0;width:100%;height:100%;display:block}
.cot-layer[hidden]{display:none}
/* the marker overlay must not swallow clicks meant for the SVG below
   (e.g. the clickable Ohio shape); only its buttons are interactive */
.cot-markers{position:absolute;inset:0;pointer-events:none}
.cot-markers > *{pointer-events:auto}
/* country level: branded US states map */
.cot-state{fill:#fab52b;stroke:#fdf6da;stroke-width:1.6;stroke-linejoin:round}
.cot-ohio{stroke:#363636;stroke-width:3;cursor:pointer;transition:fill .16s}
.cot-ohio:hover,.cot-ohio:focus-visible{fill:#ff2273;outline:none}
.cot-lbl{fill:rgba(54,54,51,.6);font-family:"Supreme",sans-serif;font-weight:800;font-size:20px;text-anchor:middle;dominant-baseline:middle;letter-spacing:.4px;pointer-events:none}
.cot-lbl-oh{fill:#ff2273;font-size:23px}
@keyframes cotZoomIn{from{transform:scale(1.06)}to{transform:scale(1)}}
.cot-layer.in{animation:cotZoomIn .5s cubic-bezier(.4,0,.2,1) both}
@media(prefers-reduced-motion:reduce){.cot-layer.in{animation:none}}

/* hotspots (country/state) */
.cot-hot{position:absolute;transform:translate(-50%,-50%);background:none;border:none;padding:0;display:flex;flex-direction:column;align-items:center;gap:5px;animation:cotBloom .45s cubic-bezier(.34,1.56,.64,1) backwards}
@keyframes cotBloom{from{transform:translate(-50%,-50%) scale(.5);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}
.cot-hot.live{cursor:pointer;z-index:9}
.cot-hot.soon{cursor:default;z-index:5}
.cot-hot .h-live{width:17px;height:17px;border-radius:50%;background:var(--pink);border:3px solid var(--cream);box-shadow:0 2px 7px rgba(42,38,34,.45),0 0 0 2px var(--ink)}
.cot-hot .h-soon{width:13px;height:13px;border-radius:50%;background:#d8c89a;border:2px solid #9a8f6f}
.cot-hot .h-label{font-family:"Supreme",sans-serif;font-weight:800;text-transform:uppercase;font-size:9px;letter-spacing:.05em;color:var(--ink);background:rgba(253,246,218,.85);padding:1px 6px;border-radius:6px;white-space:nowrap}
.cot-hot .h-badge{font-family:"Supreme",sans-serif;font-weight:800;font-size:8px;letter-spacing:.05em;color:var(--cream);background:var(--pink);border:1.5px solid var(--ink);border-radius:5px;padding:1px 5px}

/* clusters (metro, neighborhood bubbles) */
.cot-cluster{position:absolute;transform:translate(-50%,-50%);background:none;border:none;padding:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;z-index:6;animation:cotBloom .4s cubic-bezier(.34,1.56,.64,1) backwards}
.cot-cluster .bub{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:var(--cream);border:2.5px solid var(--ink);box-shadow:0 4px 0 var(--ink),0 6px 10px rgba(42,38,34,.25);font-family:"Supreme",sans-serif;font-weight:900;font-size:15px;color:var(--ink)}
.cot-cluster.has-feat .bub{outline:2px solid #f29b1d;outline-offset:2px}
.cot-cluster .lab{font-family:"Supreme",sans-serif;font-weight:800;text-transform:uppercase;font-size:9px;letter-spacing:.04em;color:var(--ink);background:rgba(253,246,218,.85);padding:1px 6px;border-radius:6px;white-space:nowrap}

/* pins (metro, individual) */
.cot-pin{position:absolute;transform:translate(-50%,-100%);background:none;border:none;padding:0;cursor:pointer;z-index:10;animation:cotDrop .4s cubic-bezier(.34,1.56,.64,1) backwards}
.cot-pin.featured{z-index:20}
.cot-pin.hover{z-index:30}
.cot-pin.active{z-index:40}
@keyframes cotDrop{from{transform:translate(-50%,-100%) scale(.4);opacity:0}to{transform:translate(-50%,-100%) scale(1);opacity:1}}
@media(prefers-reduced-motion:reduce){.cot-pin{animation:none}}
.cot-pin .head{display:grid;place-items:center;transition:transform .16s cubic-bezier(.34,1.56,.64,1)}
.cot-pin .glyph{line-height:1}
.cot-pin.fav .head{width:26px;height:26px;border-radius:50% 50% 50% 0;background:var(--ink);border:2.5px solid var(--saffron);box-shadow:0 4px 9px rgba(42,38,34,.4);transform:rotate(-45deg)}
.cot-pin.fav .glyph{transform:rotate(45deg);font-size:7px;color:var(--saffron)}
.cot-pin.legend .head{width:31px;height:31px;border-radius:50% 50% 50% 0;background:var(--saffron);border:2.5px solid var(--ink);box-shadow:0 5px 10px rgba(42,38,34,.42);transform:rotate(-45deg)}
.cot-pin.legend .glyph{transform:rotate(45deg);font-size:12px;color:var(--ink)}
.cot-pin.featured .head{width:30px;height:30px;border-radius:50%;background:radial-gradient(circle at 35% 28%,#ffe39a,#f29b1d);border:2.5px solid var(--ink);box-shadow:0 0 0 3px rgba(250,181,43,.35),0 5px 11px rgba(42,38,34,.45)}
.cot-pin.featured .glyph{font-size:15px;color:var(--ink);font-weight:900}
.cot-pin.hover.fav .head,.cot-pin.hover.legend .head{transform:rotate(-45deg) scale(1.16)}
.cot-pin.active.fav .head,.cot-pin.active.legend .head{transform:rotate(-45deg) scale(1.28)}
.cot-pin.hover.featured .head{transform:scale(1.16)}
.cot-pin.active.featured .head{transform:scale(1.28)}
.cot-pin .crown{position:absolute;top:-13px;left:50%;transform:translateX(-50%);font-size:13px;z-index:1}
.cot-pin .ribbon{display:none;position:absolute;bottom:100%;left:50%;transform:translate(-50%,-4px);font-family:"Supreme",sans-serif;font-weight:800;font-size:8px;letter-spacing:.08em;color:var(--ink);background:var(--saffron);border:1.5px solid var(--ink);border-radius:4px;padding:2px 5px;white-space:nowrap;box-shadow:0 2px 0 var(--ink)}
.cot-pin.hover .ribbon,.cot-pin.active .ribbon{display:block}
.cot-pin .ping{position:absolute;top:15px;left:50%;width:30px;height:30px;border-radius:50%;transform:translate(-50%,-50%);background:rgba(242,155,29,.45);animation:cotPing 2.1s ease-out infinite;z-index:-1}
@keyframes cotPing{0%{transform:translate(-50%,-50%) scale(.5);opacity:.6}100%{transform:translate(-50%,-50%) scale(2.7);opacity:0}}
@media(prefers-reduced-motion:reduce){.cot-pin .ping{animation:none;opacity:0}}

/* breadcrumb / back / hint */
.cot-crumb{position:absolute;top:14px;left:14px;display:flex;align-items:center;gap:7px;font-family:"Supreme",sans-serif;font-weight:800;text-transform:uppercase;font-size:10.5px;letter-spacing:.08em;background:rgba(251,241,205,.92);border:2px solid var(--ink);border-radius:999px;padding:6px 13px;box-shadow:2px 2px 0 var(--ink);z-index:20}
.cot-crumb button{font:inherit;background:none;border:none;padding:0;cursor:pointer;text-transform:uppercase}
.cot-crumb .sep{opacity:.4}
.cot-crumb .here{color:var(--pink)}
.cot-crumb .dim{color:var(--ink);opacity:.5}
.cot-back{position:absolute;top:14px;right:14px;font-family:"Supreme",sans-serif;font-weight:800;text-transform:uppercase;font-size:11px;letter-spacing:.06em;background:var(--ink);color:var(--saffron);border:2px solid var(--ink);border-radius:999px;padding:8px 15px;cursor:pointer;box-shadow:2px 2px 0 rgba(0,0,0,.25);z-index:20}
.cot-hint{position:absolute;bottom:14px;left:14px;right:14px;text-align:center;font-family:"Supreme",sans-serif;font-size:12px;font-weight:700;color:var(--ink);background:rgba(251,241,205,.9);border:2px solid var(--ink);border-radius:12px;padding:8px 12px;pointer-events:none;z-index:15}

/* active spot card */
.cot-active{position:absolute;left:16px;bottom:16px;width:300px;max-width:calc(100% - 32px);max-height:calc(100% - 32px);display:flex;flex-direction:column;background:var(--cream);border:3px solid var(--ink);border-radius:18px;box-shadow:6px 6px 0 var(--ink);overflow:hidden;z-index:50;animation:cotPopCard .26s cubic-bezier(.34,1.4,.64,1)}
.cot-active .photo{flex:none}
@keyframes cotPopCard{from{transform:translateY(10px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
@media(prefers-reduced-motion:reduce){.cot-active{animation:none}}
/* mobile: the card is too tall for the short map box, so float it as a
   bottom sheet anchored to the viewport — the Get Directions button and
   the rest stay fully visible / scrollable instead of being clipped */
@media(max-width:900px){
  .cot-active{position:fixed;left:0;right:0;bottom:0;top:auto;width:auto;max-width:none;max-height:82vh;border-radius:22px 22px 0 0;box-shadow:0 -10px 30px rgba(54,54,51,.34);z-index:300;animation:cotSheetUp .28s cubic-bezier(.34,1.4,.64,1)}
  .cot-active .body{padding-bottom:24px}
}
@keyframes cotSheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){.cot-active{animation:none}}
.cot-active .x{position:absolute;top:9px;right:9px;width:24px;height:24px;border-radius:50%;border:2px solid var(--ink);background:var(--cream);cursor:pointer;font-weight:800;line-height:1;z-index:2}
.cot-active .photo{position:relative;height:118px;display:grid;place-items:center;overflow:hidden;background:repeating-linear-gradient(135deg,#f4e7b8 0 11px,#efe0a8 11px 22px)}
.cot-active .photo .hero{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.cot-active .photo.has-photo .em{display:none}
.cot-active .photo .tier{z-index:2}
.cot-active .photo .em{font-size:48px;filter:drop-shadow(0 4px 7px rgba(0,0,0,.28))}
.cot-active .tier{position:absolute;top:10px;left:10px;font-family:"Supreme",sans-serif;text-transform:uppercase;font-weight:800;font-size:10px;letter-spacing:.05em;padding:5px 10px;border-radius:999px;border:2px solid var(--ink)}
.cot-active .tier.fav{background:var(--ink);color:var(--saffron)}
.cot-active .tier.legend{background:var(--saffron);color:var(--ink)}
.cot-active .tier.featured{background:#f29b1d;color:var(--ink)}
.cot-active .body{padding:15px 17px 17px;overflow-y:auto}
.cot-active .body .nap{margin-top:11px;display:flex;flex-direction:column;gap:6px;border-top:1.5px solid rgba(54,54,51,.14);padding-top:11px}
.cot-active .body .nap-row{display:flex;align-items:flex-start;gap:7px;font-family:"Supreme",sans-serif;font-size:12px;font-weight:600;color:var(--ink);text-decoration:none;line-height:1.32}
.cot-active .body .nap-row svg{flex:none;margin-top:1px;color:var(--orange)}
.cot-active .body a.nap-row:hover span{color:var(--pink)}
.cot-active .body .nap-row.web span{font-weight:800;color:var(--pink);text-decoration:underline;text-underline-offset:2px;word-break:break-all}
.cot-active .body .cot-dir{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:13px;padding:10px 16px;border:2px solid var(--ink);border-radius:999px;background:var(--saffron);color:var(--ink);font-family:"Supreme",sans-serif;font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:.05em;text-decoration:none;transition:background .15s,transform .15s}
.cot-active .body .cot-dir:hover{background:var(--orange);color:var(--cream);transform:translateY(-1px)}
.cot-active .body .cot-dir svg{flex:none}
.cot-active .body h3{font-family:"Supreme",sans-serif;text-transform:uppercase;font-size:18px;line-height:1.05}
.cot-active .body .meta{font-family:"Supreme",sans-serif;font-size:12px;font-weight:600;opacity:.7;margin-top:5px}
.cot-active .body .dish{margin-top:11px;font-size:13.5px}
.cot-active .body .dish b{font-family:"Supreme",sans-serif;text-transform:uppercase;font-size:10px;letter-spacing:.1em;color:var(--orange);display:block;margin-bottom:2px;font-weight:800}
.cot-active .body .vouch{margin-top:11px;background:rgba(250,181,43,.3);border-radius:12px;padding:9px 12px;font-size:13px;font-style:italic}
.cot-active .body .paidnote{margin-top:10px;font-family:"Supreme",sans-serif;font-size:11px;font-weight:700;color:#9a8f6f;display:flex;gap:6px;align-items:center}
.cot-active .body .paidnote .d{width:11px;height:11px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ffd877,#f29b1d);border:1.5px solid var(--ink);display:inline-block;flex:none}
.cot-active .body .called{font-family:"Supreme",sans-serif;font-size:11.5px;font-weight:700;margin-top:10px}
.cot-active .body .called span{opacity:.55;font-weight:600}

/* list panel */
.cot-list{display:flex;flex-direction:column;border:3px solid var(--ink);border-radius:22px;overflow:hidden;box-shadow:8px 8px 0 var(--ink);background:var(--cream);min-height:0}
@media(max-width:900px){.cot-list{height:420px}}
.cot-list-head{padding:16px 16px 12px;border-bottom:2px solid rgba(54,54,54,.18)}
.cot-list-head .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cot-list-head .title{font-family:"Supreme",sans-serif;text-transform:uppercase;font-size:14px}
.cot-list-head .count{font-family:"Supreme",sans-serif;font-weight:800;font-size:11px;color:#9a8f6f}
.cot-search{display:flex;align-items:center;gap:8px;background:#fff;border:2px solid var(--ink);border-radius:999px;padding:9px 14px}
.cot-search span{opacity:.45;font-size:14px}
.cot-search input{border:none;outline:none;background:none;font-family:"Supreme",sans-serif;font-size:13.5px;font-weight:600;width:100%;color:var(--ink)}
.cot-rows{overflow-y:auto;flex:1;min-height:0;padding:8px}
.cot-rows::-webkit-scrollbar{width:9px}
.cot-rows::-webkit-scrollbar-thumb{background:#d8c98f;border-radius:9px;border:2px solid var(--cream)}
.cot-row{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:2px solid transparent;background:transparent;border-radius:13px;padding:9px 10px;cursor:pointer;transition:background .12s}
.cot-row.on,.cot-row:hover{background:#fdf0c4;border-color:var(--ink)}
.cot-row.region{cursor:default}
.cot-row.region.live{cursor:pointer}
.cot-row .mk{flex:none;display:grid;place-items:center;width:24px;height:24px}
.cot-row .mk.fav{border-radius:50%;background:var(--ink);border:2px solid var(--saffron);font-size:7px;color:var(--saffron)}
.cot-row .mk.legend{font-size:15px}
.cot-row .mk.featured{border-radius:50%;background:radial-gradient(circle at 35% 30%,#ffd877,#f29b1d);border:2px solid var(--ink);font-size:12px;color:var(--ink)}
.cot-row .mk.dot{border-radius:50%;border:2px solid var(--ink)}
.cot-row .mk.dot.live{background:var(--pink);animation:cotBlink .9s steps(1,end) infinite}
.cot-row .mk.dot.soon{background:#d8c89a}
@keyframes cotBlink{0%,55%{opacity:1}62%,100%{opacity:.25}}
.cot-row .info{flex:1;min-width:0}
.cot-row .info .nm{display:block;font-family:"Supreme",sans-serif;font-weight:800;font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cot-row .info .sub{display:block;font-family:"Supreme",sans-serif;font-weight:600;font-size:11px;color:#9a8f6f;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cot-row .tag{flex:none;font-family:"Supreme",sans-serif;font-weight:800;text-transform:uppercase;font-size:8.5px;letter-spacing:.05em;border-radius:5px;padding:2px 6px}
.cot-row .tag.feat{color:var(--ink);background:var(--saffron);border:1.5px solid var(--ink)}
.cot-row .tag.live{color:var(--cream);background:var(--pink);border:1.5px solid var(--ink)}
.cot-row .tag.soon{color:#9a8f6f;border:1.5px solid #cdbf95}
.cot-noresult{text-align:center;font-family:"Supreme",sans-serif;font-size:13px;font-weight:600;color:#9a8f6f;padding:30px 16px}
