/* =========================================================================
   ApresMeet — SXSW London 2026 festival page
   Ported verbatim from prototype (devops/design/festival/index.html).
   Global resets / color vars omitted — already in APM base CSS.
   Page-level overrides scoped to body.page-festival.
   ========================================================================= */

/* One fixed header height drives every sticky offset — change only here */
:root{
  --am-header-h:56px;
  --am-slate-400:#94A3B8;
  --am-shadow:0 1px 2px rgba(13,27,42,.04),0 8px 24px rgba(13,27,42,.06);
  --am-shadow-lg:0 8px 30px rgba(13,27,42,.12);
}

/* Hide shared APM chrome — festival.css is only loaded on this page */
#div_menu_outer,
#page_menu,
#div_pre_body_main,
.am-footer{display:none!important}

/* Scoped body / typography / link styles */
body.page-festival{font-family:'DM Sans',system-ui,sans-serif;color:var(--am-navy);background:var(--am-slate-100);-webkit-font-smoothing:antialiased}
.page-festival h1,.page-festival h2,.page-festival h3,.page-festival .serif,.page-festival .am-display{font-family:'DM Serif Display',Georgia,serif;font-weight:400;letter-spacing:-.01em}
.page-festival a:not(.btn){color:var(--am-teal-mid);text-decoration:none}
.page-festival a:not(.btn):hover{text-decoration:underline}
/* Logo overrides the general link colour — must match specificity (0,2,1) */
.page-festival a.am-brand,.page-festival a.am-brand:hover{color:var(--am-navy);text-decoration:none}

/* ---------- Focus states ---------- */
.page-festival a:focus-visible,.page-festival button:focus-visible,.page-festival input:focus-visible,.page-festival select:focus-visible,
.page-festival textarea:focus-visible,.page-festival .nav-link:focus-visible,.page-festival [tabindex]:focus-visible{
  outline:3px solid rgba(0,196,154,.45);outline-offset:2px;border-radius:8px;
}

/* ---------- Buttons ---------- */
.page-festival .btn{font-family:'DM Sans';font-size:13px;font-weight:500;border-radius:10px;letter-spacing:.01em;transition:transform .12s ease,box-shadow .2s ease,background .2s ease}
.page-festival .btn:active{transform:translateY(1px)}
.page-festival .btn-sm{border-radius:8px;font-size:12px;padding:.34rem .7rem}
.btn-am-primary,.btn-am-teal,.btn-am-teal-deep,.btn-am-outline,.btn-am-ghost{display:inline-flex;align-items:center;justify-content:center}
.btn-am-teal-deep{background:var(--am-teal-deep,#007E60);color:#fff;border:1px solid var(--am-teal-deep,#007E60)}
.btn-am-teal-deep:hover{background:#006650;color:#fff;box-shadow:0 6px 16px rgba(0,126,96,.28)}
.btn-am-primary{background:var(--am-navy);color:#fff;border:1px solid var(--am-navy)}
.btn-am-primary:hover{background:var(--am-navy-800,#1A2E42);color:#fff;box-shadow:var(--am-shadow)}
.btn-am-teal{background:var(--am-teal);color:#fff;border:1px solid var(--am-teal)}
.btn-am-teal:hover{background:var(--am-teal-mid);color:#fff;box-shadow:0 6px 16px rgba(0,168,128,.28)}
.btn-am-outline{background:#fff;color:var(--am-navy);border:1px solid var(--am-navy)}
.btn-am-outline:hover{background:var(--am-navy);color:#fff}
.btn-am-ghost{background:transparent;color:var(--am-navy);border:1px solid transparent}
.btn-am-ghost:hover{background:var(--am-slate-100);color:var(--am-navy)}
.btn-am-danger{background:var(--am-red,#EF4444);color:#fff;border:1px solid var(--am-red,#EF4444)}
.btn-am-danger:hover{background:#dc2626;color:#fff}

/* ---------- Cards ---------- */
.am-card{background:#fff;border:.5px solid var(--am-slate-200);border-radius:14px;box-shadow:var(--am-shadow)}

/* ---------- Pills / badges ---------- */
.am-pill{font-family:'DM Sans';font-size:.7rem;font-weight:600;border-radius:999px;padding:.2rem .6rem;display:inline-flex;align-items:center;gap:.3rem;white-space:nowrap;line-height:1.2}
.pill-house{background:var(--am-navy);color:#fff}
.pill-cat{background:var(--am-slate-100);color:var(--am-slate)}
.pill-free{background:var(--am-teal-light);color:var(--am-teal-mid)}
.pill-ticketed{background:var(--am-amber-light);color:var(--am-amber)}
.pill-invite{background:var(--am-slate-100);color:var(--am-slate)}
.pill-amenity{background:var(--am-slate-100);color:var(--am-slate)}

/* ---------- Nav / daybar (mobile/tablet — hidden on desktop by DESKTOP REDESIGN block) ---------- */
.am-nav{background:#fff;border-bottom:.5px solid var(--am-slate-200);position:sticky;top:0;z-index:1030}
.am-breadcrumb{background:#fff;border-bottom:.5px solid var(--am-slate-200);font-size:.82rem;color:var(--am-slate)}
.am-breadcrumb a{color:var(--am-slate)}
.am-breadcrumb .active{color:var(--am-navy);font-weight:600}

/* ---------- Brand marks ---------- */
.am-wordmark{font-family:'DM Serif Display';font-size:1.4rem;color:var(--am-navy);letter-spacing:-.02em}
.am-wordmark .dot{color:var(--am-teal-deep,var(--am-teal))}
/* Prototype brand class (used in fixed header + daybar) */
.am-brand{font-family:'DM Serif Display';font-size:1.4rem;color:var(--am-navy);letter-spacing:-.02em;text-decoration:none;white-space:nowrap;flex:0 0 auto;line-height:1}
.am-brand:hover{text-decoration:none;color:var(--am-navy)}
.am-brand-meet{color:var(--am-teal)}

/* ---------- Hero ---------- */
.am-hero{background:
  radial-gradient(1200px 400px at 85% -10%,rgba(0,196,154,.10),transparent 60%),
  radial-gradient(900px 500px at -10% 120%,rgba(245,166,35,.08),transparent 55%),
  #fff;
  border-bottom:.5px solid var(--am-slate-200)}
@media(min-width:992px){
  .am-hero{min-height:calc(100vh - var(--am-header-h));display:flex;flex-direction:column;justify-content:center}
}
.am-hero h1{font-size:clamp(2.2rem,4.5vw,3.8rem);line-height:1.02}
.chip-teal{display:inline-flex;align-items:center;gap:.4rem;background:var(--am-teal-light);color:var(--am-teal-mid);font-weight:600;font-size:.78rem;border-radius:999px;padding:.32rem .8rem}
.chip-teal .dot{width:7px;height:7px;border-radius:50%;background:var(--am-teal)}
.am-stat-card{position:relative;overflow:hidden}
.am-stat-card::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,196,154,.04),transparent 40%);pointer-events:none}
.am-stat-row{display:flex;align-items:center;gap:.7rem;padding:.7rem 0}
.am-stat-row .dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.am-stat-num{font-family:'DM Serif Display';font-size:1.5rem;color:var(--am-navy);line-height:1}
.am-stat-label{font-size:.8rem;color:var(--am-slate)}
.am-live{display:inline-flex;align-items:center;gap:.35rem;font-size:.7rem;color:var(--am-teal-mid);font-weight:600}
.am-live .pulse{width:8px;height:8px;border-radius:50%;background:var(--am-teal);box-shadow:0 0 0 0 rgba(0,196,154,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(0,196,154,.5)}70%{box-shadow:0 0 0 9px rgba(0,196,154,0)}100%{box-shadow:0 0 0 0 rgba(0,196,154,0)}}

/* ---------- Day rail ---------- */
.am-section-h{font-family:'DM Serif Display';font-size:1.5rem;color:var(--am-navy)}
.day-rail{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.4rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.day-rail::-webkit-scrollbar{height:5px}
.day-rail::-webkit-scrollbar-thumb{background:var(--am-slate-200);border-radius:999px}
.day-pill{flex:0 0 auto;background:#fff;border:1px solid var(--am-slate-200);color:var(--am-navy);border-radius:14px;padding:.5rem .9rem;text-align:center;cursor:pointer;transition:all .15s ease;min-width:74px;font-weight:600;font-size:.85rem}
.day-pill .cnt{display:block;font-size:.68rem;font-weight:600;margin-top:.2rem;background:var(--am-slate-100);color:var(--am-slate);border-radius:999px;padding:.05rem 0}
.day-pill:hover{border-color:var(--am-teal)}
.day-pill.active{background:var(--am-navy);border-color:var(--am-navy);color:#fff}
.day-pill.active .cnt{background:rgba(255,255,255,.22);color:#fff}

/* ---------- House cards ---------- */
.house-strip{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.6rem;-webkit-overflow-scrolling:touch}
.house-strip::-webkit-scrollbar{height:6px}
.house-strip::-webkit-scrollbar-thumb{background:var(--am-slate-200);border-radius:999px}
.house-card{flex:0 0 240px;padding:1rem;display:flex;flex-direction:column;gap:.5rem;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease}
.house-card:hover{transform:translateY(-3px);box-shadow:var(--am-shadow-lg)}
.house-card h3{font-size:1.15rem;margin:0}
.house-meta{font-size:.78rem;color:var(--am-slate)}
.house-next{font-size:.74rem;color:var(--am-teal-mid);font-weight:600}
@media(min-width:992px){
  .house-strip{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:.6rem;overflow:visible}
  .house-card{flex:auto;padding:.65rem .7rem;gap:.2rem;border-radius:12px}
  .house-card h3{font-size:.9rem;line-height:1.1}
  .house-card .house-meta{font-size:.7rem}
  .house-card .house-next{font-size:.68rem}
  .house-card .house-cats,.house-card .house-view{display:none}
}

/* ---------- Filter panel ---------- */
.filter-panel{position:sticky;top:96px}
.filter-group{border-bottom:.5px solid var(--am-slate-200);padding:.9rem 0}
.filter-group:last-child{border-bottom:0}
.filter-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--am-slate);margin-bottom:.55rem;display:block}
.chk-pill{position:relative;display:inline-block;margin:0 .3rem .4rem 0}
.chk-pill input{position:absolute;opacity:0;width:0;height:0}
.chk-pill span{display:inline-block;border:1px solid var(--am-slate-200);background:#fff;color:var(--am-navy);border-radius:999px;padding:.3rem .7rem;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .12s ease}
.chk-pill input:checked+span{background:var(--am-navy);border-color:var(--am-navy);color:#fff;font-weight:600}
.chk-pill input:focus-visible+span{outline:3px solid rgba(0,196,154,.45);outline-offset:2px}
.filter-search-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.75rem}
.filter-search-row .search-wrap{flex:4;min-width:0}
.filter-search-row #fReset{flex:1;white-space:nowrap}
.search-wrap{position:relative}
.search-wrap .ic{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);color:var(--am-slate-400)}
.search-wrap input{padding-left:2.1rem;border-radius:10px;border:1px solid var(--am-slate-200)}

/* ---------- Toolbar ---------- */
.list-toolbar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.result-count{font-weight:700;color:var(--am-navy)}

/* ---------- Event card ---------- */
.event-card{
  display:flex;gap:0;padding:0;margin-bottom:.65rem;
  cursor:pointer;position:relative;
  --am-rib:var(--am-teal);
  border-radius:14px;border-left:4px solid var(--am-rib)!important;
  border:.5px solid var(--am-slate-200);
  background:#fff;box-shadow:var(--am-shadow);
  transition:box-shadow .18s ease,border-color .18s ease,transform .1s ease;
  overflow:hidden;
}
.event-card:hover{box-shadow:var(--am-shadow-lg)}
.event-card:active{transform:scale(.985)}
/* Active highlight uses the card's own ribbon colour (rank-based) */
.event-card.am-active{box-shadow:0 0 0 2px var(--am-rib),var(--am-shadow-lg)!important}
.event-card.rb-5{--am-rib:var(--am-navy)}
.event-card.rb-4{--am-rib:var(--am-teal-mid)}
.event-card.rb-3{--am-rib:#3B82F6}
.event-card.rb-2{--am-rib:var(--am-amber)}
.event-card.rb-1{--am-rib:var(--am-slate-200)}
.date-col{
  flex:0 0 62px;width:62px;
  background:transparent;
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  padding:.9rem .3rem .9rem .1rem;text-align:center;
}
.date-col .mon{font-size:10px;text-transform:uppercase;color:var(--am-teal-mid);font-weight:700;letter-spacing:.06em}
.date-col .num{font-family:'DM Serif Display';font-size:26px;color:var(--am-navy);line-height:1.05}
.date-col .dow{font-size:10px;color:var(--am-slate-400);font-weight:500}
.event-main{flex:1;min-width:0;padding:.75rem .75rem .75rem 0;padding-right:2.8rem}
.event-title{font-weight:700;font-size:15px;color:var(--am-navy);margin:0 0 .2rem;line-height:1.25}
.event-meta{font-size:12px;color:var(--am-slate);line-height:1.5}
.event-host{font-size:11px;color:var(--am-slate-400);margin-top:.1rem}
.event-desc{font-size:12.5px;color:var(--am-slate);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:.4rem 0 .45rem}
.badge-row{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:.45rem}
.event-foot{font-size:12px;color:var(--am-slate);display:flex;align-items:center;gap:.5rem;margin-top:.15rem}
.event-foot .ef-dot{width:3px;height:3px;border-radius:50%;background:var(--am-slate-400);flex:0 0 3px}
.event-actions{
  position:absolute;top:.6rem;right:.6rem;
  display:flex;flex-direction:column;align-items:flex-end;gap:.3rem;
}
.ev-icon-btn{
  width:28px;height:28px;border-radius:8px;
  border:.5px solid var(--am-slate-200);background:#fff;
  color:var(--am-slate);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;line-height:1;
  transition:background .12s ease,color .12s ease,border-color .12s ease;
}
.ev-icon-btn:hover,.ev-icon-btn:focus-visible{background:var(--am-teal-light);border-color:var(--am-teal);color:var(--am-teal-mid)}
.ev-icon-btn.in-plan{background:var(--am-teal-light);border-color:var(--am-teal);color:var(--am-teal-mid)}
/* RSVP button: plain icon by default; label + green styling appear only on the clicked (active) card */
.ev-rsvp-label{display:none;line-height:1}
.event-card.am-active .ev-rsvp-btn{
  width:auto;padding:0 .5rem;gap:.28rem;
  background:var(--am-teal-deep);border-color:var(--am-teal-deep);color:#fff;
  font-size:11px;font-weight:700;letter-spacing:.01em;
  box-shadow:0 1px 2px rgba(11,31,59,.12);
}
.event-card.am-active .ev-rsvp-btn:hover,.event-card.am-active .ev-rsvp-btn:focus-visible{background:var(--am-teal-forest)!important;border-color:var(--am-teal-forest)!important;color:#fff!important}
.event-card.am-active .ev-rsvp-label{display:inline}
/* Widen the content gutter only while active, so the label has room without reflowing every card on load */
.event-card.am-active .event-main{padding-right:4.6rem}
.action-row{display:none}
.ext-link{color:var(--am-slate-400);display:inline-flex;align-items:center}
.ext-link:hover{color:var(--am-teal-mid)}

/* Compact mode (default) */
.card-mode-compact .event-card{margin-bottom:.4rem;border-radius:12px}
.card-mode-compact .date-col{padding:.65rem .2rem .65rem .1rem}
.card-mode-compact .date-col .num{font-size:22px}
.card-mode-compact .event-main{padding:.55rem .55rem .55rem 0;padding-right:2.8rem}
.card-mode-compact .event-title{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-mode-compact .event-desc{display:none}
.card-mode-compact .badge-row{display:none}
.card-mode-compact .event-host{display:none}
.card-mode-compact .event-foot{margin-top:.1rem}

/* View toggle */
.view-toggle{display:flex;border:.5px solid var(--am-slate-200);border-radius:8px;overflow:hidden;background:#fff}
.view-toggle button{border:0;background:transparent;padding:.3rem .55rem;font-size:.75rem;font-weight:600;color:var(--am-slate);cursor:pointer;line-height:1;white-space:nowrap}
.view-toggle button.active{background:var(--am-navy);color:#fff}
.view-toggle button:focus-visible{outline:2px solid var(--am-teal);outline-offset:-2px}

/* ---------- Map ---------- */
.map-col{position:sticky;top:96px}
#map{height:440px;border-radius:14px;border:.5px solid var(--am-slate-200);z-index:1}
.map-note{font-size:.76rem;color:var(--am-slate);margin-top:.5rem}
.leaflet-popup-content-wrapper{border-radius:12px}
.leaflet-popup-content{font-family:'DM Sans';margin:.8rem}
.popup-title{font-family:'DM Serif Display';font-size:1rem;color:var(--am-navy);margin-bottom:.2rem}
.popup-meta{font-size:.78rem;color:var(--am-slate);margin-bottom:.5rem}


/* ---------- Skeleton ---------- */
.skeleton{position:relative;overflow:hidden;background:var(--am-slate-100)}
.skeleton::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:shimmer 1.4s infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}
.sk-line{height:12px;border-radius:6px;background:var(--am-slate-200);margin-bottom:.5rem}
.sk-box{border-radius:10px;background:var(--am-slate-200)}

/* ---------- Empty states ---------- */
.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--am-slate)}
.empty-state .ic{width:56px;height:56px;border-radius:16px;background:var(--am-teal-light);color:var(--am-teal-mid);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}
.empty-state h4{font-family:'DM Serif Display';color:var(--am-navy);font-size:1.15rem}

/* ---------- Festival island nav ---------- */
/* JS adds .is-active (not .active) — alias so festival-events.js needs no changes */
.am-island-item.is-active                 { background:var(--am-navy); padding:8px 14px; gap:5px; }
.am-island-item.is-active .am-island-icon { color:var(--am-teal); }
.am-island-item.is-active .am-island-label{ display:block; color:#ffffff; }
/* Badge: superscript on icon when inactive; inline in pill when active */
.am-island-item .am-island-badge          { position:absolute; top:1px; right:-4px; }
.am-island-item.active .am-island-badge,
.am-island-item.is-active .am-island-badge{ position:static; margin:0 1px; border-color:var(--am-navy); }
@media(max-width:991.98px){
  .page-festival #eventList{padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}
}

/* ---------- AI planner ---------- */
.interest-grid{display:flex;flex-wrap:wrap;gap:.4rem}
.ai-reason{font-size:.76rem;color:var(--am-slate);font-style:italic;margin-top:.25rem}
.ai-summary{font-family:'DM Serif Display';font-style:italic;font-size:1.05rem;color:var(--am-navy)}
.ai-soft-notice{background:var(--am-amber-light);color:#9a6a12;border-radius:10px;padding:.7rem .8rem;font-size:.85rem;margin-bottom:.8rem}

/* ---------- Detail modal ---------- */
.detail-pitch{font-size:15px;font-weight:600;color:var(--am-navy)}
.detail-desc{font-size:14px;color:var(--am-slate);line-height:1.6}
.house-rules{background:var(--am-amber-light);border-radius:10px;padding:.7rem .8rem;font-size:.84rem;color:#7a560f}

.toast-container{z-index:1090}
.form-label{font-weight:600;font-size:.85rem}
.modal-title.serif{font-family:'DM Serif Display'}
.section-fill{background:var(--am-slate-100)}
.text-slate{color:var(--am-slate)!important}
.text-slate-400{color:var(--am-slate-400)!important}

/* Offcanvas bottom sheet */
.offcanvas-bottom.am-sheet{height:78vh;border-radius:18px 18px 0 0}
@media(min-width:992px){.d-lg-none-strict{display:none!important}}

/* ---------- Ask Coco button ---------- */
.btn-coco{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--am-teal),var(--am-navy));color:#fff;border:0;font-weight:700;font-size:.95rem;padding:.7rem 1rem;border-radius:12px;box-shadow:0 8px 22px rgba(0,168,128,.28)}
.btn-coco:hover{color:#fff;box-shadow:0 10px 28px rgba(13,27,42,.28);transform:translateY(-1px)}
.btn-coco .coco-spark{display:inline-block;margin-right:.25rem;animation:cocoTwinkle 2.4s ease-in-out infinite}
.btn-coco:after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-20deg);animation:cocoShine 3.4s ease-in-out infinite}
@keyframes cocoShine{0%,60%{left:-60%}100%{left:130%}}
@keyframes cocoTwinkle{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(1.15)}}
.coco-sub{font-size:.72rem;color:var(--am-slate-400);text-align:center;margin:.35rem 0 0}

/* Coco modal */
.coco-orb{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:linear-gradient(135deg,var(--am-teal),var(--am-navy));color:#fff;margin:0 auto .7rem}
.coco-orb.sm{width:34px;height:34px;font-size:1rem;border-radius:10px;margin:0}
.coco-verify-card{border:.5px solid var(--am-slate-200);border-radius:14px;padding:1rem;margin-top:1rem;background:var(--am-slate-100)}
.coco-fineprint{font-size:.7rem;color:var(--am-slate-400);margin:.6rem 0 0}
.coco-resulthead{display:flex;gap:.6rem;align-items:center;margin-bottom:.4rem}
.coco-upsell-hint{margin-top:.9rem;font-size:.8rem;color:var(--am-slate);background:var(--am-teal-light);border-radius:10px;padding:.55rem .7rem}
.coco-paywall{text-align:center}
.coco-pro-pill{background:var(--am-amber-light);color:var(--am-amber);font-weight:700;letter-spacing:.07em;font-size:.68rem}
.coco-perks{list-style:none;padding:0;margin:.9rem 0;text-align:left;display:inline-block}
.coco-perks li{font-size:.86rem;color:var(--am-navy);padding:.28rem 0 .28rem 1.5rem;position:relative}
.coco-perks li:before{content:"✓";position:absolute;left:0;color:var(--am-teal-mid);font-weight:700}
.coco-price{margin:.6rem 0 .9rem}
.coco-price-num{font-family:'DM Serif Display';font-size:2.2rem;color:var(--am-navy)}
.coco-price-per{font-size:.85rem;color:var(--am-slate)}
.btn-coco-pro{background:var(--am-amber);color:#3d2c06;border:1px solid var(--am-amber);font-weight:700}
.btn-coco-pro:hover{background:#e0950f;color:#3d2c06}

/* ---------- Featured cards ---------- */
.featured-card{display:flex;flex-direction:column;height:100%;padding:1rem 1.1rem;position:relative;overflow:hidden}
.featured-tag{align-self:flex-start;font-size:.66rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;border-radius:999px;padding:.22rem .6rem;margin-bottom:.6rem}
.tag-daily{background:var(--am-teal-light);color:var(--am-teal-mid)}
.tag-weekly{background:var(--am-navy);color:#fff}
.tag-houses{background:var(--am-amber-light);color:var(--am-amber)}
.featured-card .fc-time{font-size:.78rem;color:var(--am-teal-mid);font-weight:600}
.featured-card h3{font-family:'DM Serif Display';font-size:1.18rem;color:var(--am-navy);margin:.15rem 0 .25rem;line-height:1.12}
.featured-card .fc-venue{font-size:.8rem;color:var(--am-slate)}
.featured-card .fc-actions{margin-top:auto;padding-top:.7rem;display:flex;gap:.4rem;flex-wrap:wrap}
.fhouse{display:flex;align-items:center;justify-content:space-between;gap:.6rem;border:.5px solid var(--am-slate-200);border-radius:10px;padding:.55rem .7rem;cursor:pointer;transition:border-color .15s ease,background .15s ease}
.fhouse:hover{border-color:var(--am-teal);background:var(--am-teal-light)}
.fhouse .fh-name{font-family:'DM Serif Display';font-size:1rem;color:var(--am-navy);line-height:1}
.fhouse .fh-meta{font-size:.72rem;color:var(--am-slate)}
.fhouse .fh-arrow{color:var(--am-teal-mid);font-weight:700}

/* ---------- Desktop filter bar (search + dropdown panes) ---------- */
.filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;position:relative;z-index:6}
.filter-bar-sep{display:inline-block;width:1px;height:1.2rem;background:var(--am-slate-200);align-self:center;flex-shrink:0}
.filter-pane{position:relative}
.filter-pane>summary{list-style:none;cursor:pointer;border:1px solid var(--am-slate-200);background:#fff;border-radius:100px;padding:6px 13px;font-size:12px;font-weight:400;color:var(--am-navy);display:inline-flex;gap:.4rem;align-items:center;white-space:nowrap;-webkit-user-select:none;user-select:none}
.filter-pane>summary::-webkit-details-marker{display:none}
.filter-pane>summary:after{content:"▾";font-size:.7rem;color:var(--am-slate-400)}
.filter-pane[open]>summary{border-color:var(--am-teal);background:var(--am-teal-light);color:var(--am-teal-mid)}
.filter-pane>summary .fp-count{background:var(--am-teal);color:#fff;border-radius:999px;font-size:.66rem;padding:.02rem .42rem;font-weight:700}
.filter-pane .fp-body{position:absolute;top:calc(100% + 7px);left:0;min-width:230px;max-width:300px;background:#fff;border:.5px solid var(--am-slate-200);border-radius:12px;box-shadow:var(--am-shadow-lg);padding:.85rem;z-index:30}
.fp-body .tag-search{margin-bottom:.55rem}
.fp-list{max-height:210px;overflow:auto}
.fp-list::-webkit-scrollbar{width:6px}
.fp-list::-webkit-scrollbar-thumb{background:var(--am-slate-200);border-radius:999px}
.tag-opt.hide{display:none}
.fp-hint{font-size:.7rem;color:var(--am-slate-400);margin:.35rem 0 0}

/* Combined filter card toolbar (active filters + view toggle + sort) */
.combined-toolbar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;border-top:.5px solid var(--am-slate-200);margin-top:.85rem;padding-top:.8rem}
.active-filters{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;flex:1;min-width:0}
.combined-toolbar .ct-right{display:flex;align-items:center;gap:.5rem;margin-left:auto}
.af-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--am-slate-400)}
.af-empty{font-size:.85rem;color:var(--am-slate)}
.filter-chip{border:1px solid var(--am-teal);background:var(--am-teal-light);color:var(--am-teal-mid);border-radius:100px;font-size:12px;font-weight:400;padding:6px 13px;display:inline-flex;align-items:center;gap:.32rem;cursor:pointer;line-height:1.3}
.filter-chip:hover{background:#fff}
.filter-chip .x{font-size:.68rem;opacity:.85}
.filter-chip.catered-toggle{background:#fff;border-color:var(--am-slate-200);color:var(--am-navy)}
.filter-chip.catered-toggle:hover{background:var(--am-slate-100)}
.filter-chip.catered-toggle.active{background:var(--am-navy);border-color:var(--am-navy);color:#fff}
.af-clear{border-color:var(--am-slate-200);background:#fff;color:var(--am-slate)}
.af-clear:hover{border-color:var(--am-slate-400);background:var(--am-slate-100)}
.tod-pills{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.35rem}
.tod-pill,.access-pill{border-color:var(--am-slate-200);background:#fff;color:var(--am-slate);font-size:12px;font-weight:400;padding:6px 13px;border-radius:100px}
.tod-pill.active,.access-pill.active{border-color:var(--am-navy);background:var(--am-navy);color:#fff}
.tod-pill:hover,.access-pill:hover{border-color:var(--am-navy);background:var(--am-navy);color:#fff}

/* ===================== DESKTOP REDESIGN =====================
   One fixed header is the only pinned chrome on desktop.
   Every sticky offset references --am-header-h.
   ============================================================ */
.am-fh-inner{display:flex;align-items:center;gap:1rem;height:var(--am-header-h)}
.am-fh-days{flex:1 1 auto;min-width:0;margin:0}
.am-fh-actions{flex:0 0 auto;display:flex;align-items:center;gap:.5rem}

/* Fixed desktop header — hidden on mobile */
.am-fixed-header{display:none;background:var(--am-navy);border-bottom:none}
.am-fixed-header .am-brand,.page-festival .am-fixed-header .am-brand{color:#fff}
.am-fixed-header .am-brand:hover,.page-festival .am-fixed-header .am-brand:hover{color:#fff}
.am-fixed-header .btn-am-primary{background:#fff;color:var(--am-navy);border-color:#fff}
.am-fixed-header .btn-am-primary:hover{background:rgba(255,255,255,.9);color:var(--am-navy)}
.am-fixed-header .btn-am-ghost{color:rgba(255,255,255,.75);border-color:transparent}
.am-fixed-header .btn-am-ghost:hover{background:rgba(255,255,255,.1);color:#fff;border-color:transparent}
.am-fixed-header .day-pill{min-width:auto;padding:.32rem .72rem;font-size:.8rem;background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:#fff}
.am-fixed-header .day-pill.active{background:#fff;border-color:#fff;color:var(--am-navy)}
.am-fixed-header .day-pill:hover{border-color:rgba(255,255,255,.5)}
.am-fixed-header .day-pill .cnt{display:none}

@media(max-width:991px){
  .day-pill .cnt{display:none}
}

@media(min-width:992px){
  .container-xl{max-width:none;padding-left:1.75rem;padding-right:1.75rem}
  body.page-festival{padding-top:var(--am-header-h)}
  .page-festival .am-nav,.page-festival .am-daybar{display:none!important}
  .am-fixed-header{display:block;position:fixed;top:0;left:0;right:0;z-index:1040;box-shadow:0 1px 0 rgba(13,27,42,.05)}
  /* Right column sticky offset */
  .map-col{top:calc(var(--am-header-h) + 1rem)}
  .filter-panel{top:calc(var(--am-header-h) + 1rem)}
}

/* Mobile/tablet day bar */
.am-daybar{background:#fff;border-bottom:.5px solid var(--am-slate-200)}
.am-daybar .am-wordmark{font-size:1.25rem;white-space:nowrap}
.am-daybar .am-brand{font-size:1.25rem}
.am-daybar-actions .btn{white-space:nowrap}

/* ===================== DISCOVERY LAYOUT =====================
   Mobile: normal block flow — MUST come BEFORE the desktop media query.
   Desktop: #discovery locks to viewport height; only #eventList scrolls.
   ============================================================ */

/* Mobile base — before the desktop query */
.am-discovery-grid{display:block;padding-top:1rem}
.am-discovery-left{margin-bottom:2rem}
.am-discovery-right{margin-top:1.5rem}

@media(min-width:992px){

  /* 1. Lock section to remaining viewport height */
  #discovery{
    height:calc(100vh - var(--am-header-h));
    display:flex;
    flex-direction:column;
    overflow:hidden;
    padding:0!important;
  }

  /* 2. Container fills section */
  #discovery>.container-xl{
    flex:1;
    min-height:0;
    display:flex;
    flex-direction:column;
    padding-top:1rem;
    padding-bottom:0;
  }

  /* 3. Grid fills container */
  .am-discovery-grid{
    flex:1;
    min-height:0;
    display:grid;
    grid-template-columns:1fr 360px;
    gap:1.5rem;
    align-items:stretch;
    padding-top:0;
    padding-bottom:1rem;
    margin-top:0;
  }

  /* 4. LEFT column: filter fixed, card list scrolls */
  .am-discovery-left{
    margin-bottom:0;
    display:flex;
    flex-direction:column;
    min-height:0;
    min-width:0;
    overflow:hidden;
    gap:.75rem;
  }
  #filterDesktop{flex:0 0 auto;z-index:20;min-width:0}
  #eventList{
    flex:1;
    min-height:0;
    min-width:0;
    overflow-y:auto;
    padding-right:.25rem;
    scrollbar-width:thin;
    scrollbar-color:var(--am-slate-200) transparent;
  }
  #eventList::-webkit-scrollbar{width:5px}
  #eventList::-webkit-scrollbar-thumb{background:var(--am-slate-200);border-radius:999px}
  .tod-pill-group,.tod-pill-group+.filter-bar-sep{display:none}
  #eventList.ev-list-cols{overflow:hidden;padding-right:0;display:flex;flex-direction:column}
  .ev-cols{flex:1;min-height:0;min-width:0;width:100%;display:flex;gap:0;border-radius:12px;overflow:hidden;border:.5px solid var(--am-slate-200);background:#fff}
  .ev-col{flex:1;min-width:0;display:flex;flex-direction:column;border-right:.5px solid var(--am-slate-200)}
  .ev-col:last-child{border-right:none}
  .ev-col-head{flex:0 0 auto;display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--am-slate);border-bottom:.5px solid var(--am-slate-200);background:#fff;position:sticky;top:0;z-index:1}
  .ev-col-cnt{font-weight:500;color:var(--am-slate-400);text-transform:none;letter-spacing:0;margin-left:auto}
  .ev-col-body{flex:1;min-height:0;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--am-slate-200) transparent}
  .ev-col-body::-webkit-scrollbar{width:4px}
  .ev-col-body::-webkit-scrollbar-thumb{background:var(--am-slate-200);border-radius:999px}
  .ev-col-empty{padding:2rem 1rem;text-align:center;color:var(--am-slate-400);font-size:.82rem}
  .ev-cols .am-card.event-card{border-radius:0;border:none;border-bottom:.5px solid var(--am-slate-200);box-shadow:none}
  .ev-cols .am-card.event-card:last-child{border-bottom:none}
  /* Outer shadow is clipped by .ev-cols overflow:hidden — use an inset ring + tint (both in the card's ribbon colour) so a clicked card reads as selected in column view */
  .ev-cols .am-card.event-card.am-active{box-shadow:inset 0 0 0 2px var(--am-rib)!important;background:color-mix(in srgb, var(--am-rib) 9%, #fff)}

  /* 5. RIGHT column: flex column, Coco+map fixed, planner scrolls */
  .am-discovery-right{margin-top:0;min-width:0;display:flex;flex-direction:column;min-height:0}
  .am-right-sticky{
    flex:1;
    min-height:0;
    display:flex;
    flex-direction:column;
    gap:.75rem;
  }
  .btn-coco{flex:0 0 auto}
  .coco-sub{flex:0 0 auto;margin:0}

  #plannerDesktop{
    flex:0 0 auto;
    display:flex;
    flex-direction:column;
  }

  #mapWrap{
    flex:1;
    min-height:160px;
    display:flex;
    flex-direction:column;
    border-radius:14px;
    overflow:hidden;
  }
  #houseWrap{
    flex:1;
    overflow-y:auto;
    border-radius:14px;
    min-height:0;
  }
  #map{
    flex:1;
    min-height:0;
    height:auto!important;
    border-radius:14px;
    border:.5px solid var(--am-slate-200);
  }
}


/* ── Contribute page ──────────────────────────────────────────────────────── */
.contrib-helper{font-size:.78rem;color:var(--am-slate)}
.req{color:var(--am-red)}

.nav-pills .nav-link{color:var(--am-navy);font-weight:600;border:1px solid var(--am-slate-200);background:#fff;border-radius:999px;padding:.45rem 1.1rem}
.nav-pills .nav-link.active{background:var(--am-teal);border-color:var(--am-teal);color:#fff}

.tag-input-wrap{display:flex;flex-wrap:wrap;gap:.35rem;border:1px solid var(--am-slate-200);border-radius:10px;padding:.4rem;align-items:center}
.tag-pill{background:var(--am-teal-light);color:var(--am-teal-mid);border-radius:999px;font-size:.78rem;font-weight:600;padding:.2rem .6rem;display:inline-flex;gap:.35rem;align-items:center}
.tag-pill button{border:0;background:transparent;color:var(--am-teal-mid);cursor:pointer;line-height:1}
.tag-input-wrap input{border:0;outline:0;flex:1;min-width:120px;font-size:.9rem}

.contrib-success{text-align:center;padding:2.5rem 1rem}
.contrib-success-ic{width:64px;height:64px;border-radius:50%;background:var(--am-teal-light);color:var(--am-teal-mid);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 1rem}

.grid-wrap{overflow:auto;border:.5px solid var(--am-slate-200);border-radius:12px;max-height:60vh}
table.entry-grid{border-collapse:separate;border-spacing:0;width:100%;min-width:1100px;font-size:.84rem}
table.entry-grid thead th{position:sticky;top:0;background:#fff;border-bottom:2px solid var(--am-teal-mid);font-weight:700;padding:.5rem .4rem;white-space:nowrap;z-index:2}
table.entry-grid td{border-bottom:.5px solid var(--am-slate-200);border-right:.5px solid var(--am-slate-100);padding:0}
table.entry-grid td input{border:0;width:100%;padding:.4rem .45rem;font-size:.84rem;background:transparent}
table.entry-grid td input:focus{background:var(--am-teal-light);outline:2px solid var(--am-teal)}
.row-num{color:var(--am-slate-400);font-size:.72rem;text-align:center;width:34px}
.row-del{border:0;background:transparent;color:var(--am-slate-400);cursor:pointer;opacity:0;transition:opacity .12s}
tr:hover .row-del{opacity:1}
.row-del:hover{color:var(--am-red)}
.status-cell{white-space:nowrap;font-size:.74rem;font-weight:600;padding:0 .5rem!important}
.sdot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:.35rem;vertical-align:middle}
.s-ready{color:#15803d}.s-ready .sdot{background:#22c55e}
.s-missing{color:#b45309}.s-missing .sdot{background:var(--am-amber)}
.s-invalid{color:#b91c1c}.s-invalid .sdot{background:var(--am-red)}

.summary-bar{position:sticky;bottom:0;background:#fff;border-top:.5px solid var(--am-slate-200);padding:.8rem 1rem;border-radius:0 0 14px 14px;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;z-index:3}

.drop-zone{border:2px dashed var(--am-slate-200);border-radius:14px;background:var(--am-slate-100);text-align:center;padding:2.5rem 1rem;cursor:pointer;transition:all .15s}
.drop-zone:hover,.drop-zone.dragover{border-color:var(--am-teal);background:var(--am-teal-light)}
.drop-ic{width:52px;height:52px;border-radius:14px;background:#fff;color:var(--am-teal-mid);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto 1rem;box-shadow:var(--am-shadow)}
.conf-high{color:var(--am-teal-mid);font-weight:600}
.conf-low{color:var(--am-amber);font-weight:600}

/* ── Highlight cards (calendar-style) in festival right column ─────────── */
.am-right-sticky .cal-hl-block { display: flex; flex-direction: column; gap: .5rem; margin-top: .75rem; }
.am-right-sticky .cal-hl-label { font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--am-slate); display: flex; align-items: center; gap: 5px; }
.am-right-sticky .cal-hl-label i { font-size: 9px; }
.am-right-sticky .hl-card { box-sizing: border-box; background: #fff; border-radius: 10px; overflow: hidden; display: flex; flex-direction: column; cursor: pointer; transition: box-shadow .15s ease; }
.am-right-sticky .hl-card:hover { box-shadow: 0 3px 12px rgba(13,27,42,.08); }
.am-right-sticky .hl-stripe { height: 3px; width: 100%; flex-shrink: 0; }
.am-right-sticky .hl-body { flex: 1; min-height: 0; display: flex; gap: .625rem; padding: .625rem .75rem; overflow: hidden; }
.am-right-sticky .hl-date { text-align: center; flex-shrink: 0; width: 30px; }
.am-right-sticky .hl-mon { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.am-right-sticky .hl-day { font-size: 22px; color: var(--am-navy,#0D1B2A); line-height: 1; margin: 2px 0; }
.am-right-sticky .hl-dow { font-size: 9px; color: var(--am-slate); }
.am-right-sticky .hl-content { flex: 1; min-width: 0; overflow: hidden; }
.am-right-sticky .hl-title { font-size: 12px; font-weight: 500; color: var(--am-navy,#0D1B2A); line-height: 1.35; margin-bottom: 3px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.am-right-sticky .hl-venue { font-size: 10px; color: var(--am-slate); margin-bottom: 4px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.am-right-sticky .hl-tags { display: flex; gap: 3px; overflow: hidden; }
.am-right-sticky .hl-tag { padding: 2px 6px; border-radius: 100px; font-size: 9px; background: var(--am-slate-100); color: var(--am-slate); flex-shrink: 0; }
.am-right-sticky .hl-footer { flex-shrink: 0; box-sizing: border-box; border-top: .5px solid var(--am-slate-200); padding: 0 .75rem; height: 30px; display: flex; align-items: center; justify-content: space-between; }
.am-right-sticky .hl-meta { font-size: 10px; color: var(--am-slate); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.am-right-sticky .hl-footer-link { font-size: 10px; font-weight: 500; text-decoration: none; display: inline-flex; align-items: center; gap: 3px; white-space: nowrap; flex-shrink: 0; }
.am-right-sticky .hl-footer-link i { font-size: 8px; }
.am-right-sticky .hl-card--today { border: 1.5px solid var(--am-navy,#0D1B2A); }
.am-right-sticky .hl-card--today .hl-stripe { background: var(--am-navy,#0D1B2A); }
.am-right-sticky .hl-card--today .hl-mon { color: var(--am-teal-mid); }
.am-right-sticky .hl-card--today .hl-footer-link { color: var(--am-teal-mid); }
.am-right-sticky .hl-card--week { border: .5px solid var(--am-slate-200); }
.am-right-sticky .hl-card--week .hl-stripe { background: var(--am-teal-mid); }
.am-right-sticky .hl-card--week .hl-mon { color: var(--am-teal-mid); }
.am-right-sticky .hl-card--week .hl-footer-link { color: var(--am-teal-mid); }
.am-right-sticky .hl-card--trending { border: .5px solid rgba(245,166,35,.45); }
.am-right-sticky .hl-card--trending .hl-stripe { background: #F5A623; }
.am-right-sticky .hl-card--trending .hl-mon { color: #F5A623; }
.am-right-sticky .hl-card--trending .hl-footer { background: #FFFBF0; border-top-color: rgba(245,166,35,.25); }
.am-right-sticky .hl-card--trending .hl-footer-link { color: #8B5E00; }
.am-right-sticky .hl-empty { box-sizing: border-box; background: #fff; border: .5px solid var(--am-slate-200); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 11px; color: var(--am-slate); padding: 1.25rem; min-height: 80px; }
