/* CT Concert Center — live events hub styles (extends the cream/black theme) */

.hub-head{padding:48px 0 6px}
.hub-head .eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:13px;font-weight:700;color:var(--ink)}
.hub-head h1{font-size:clamp(30px,4.6vw,48px);letter-spacing:-.02em;line-height:1.08;margin:8px 0 12px}
.hub-head p.lede{color:var(--muted);font-size:18px;max-width:64ch;margin:0}
.hub-head .updated{margin-top:14px;font-size:13px;color:var(--muted)}
.hub-head .updated .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#1f9d57;margin-right:7px;vertical-align:middle}

/* Controls */
.hub-controls{position:sticky;top:66px;z-index:10;background:rgba(246,241,225,.92);backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--ring);padding:14px 0}
.hub-controls .wrap{display:flex;flex-direction:column;gap:10px}
.seg{display:inline-flex;background:var(--paper);border:1px solid var(--ring);border-radius:999px;padding:4px;gap:2px;align-self:flex-start;max-width:100%;overflow-x:auto}
.seg button{border:none;background:transparent;color:var(--muted);font:inherit;font-size:14px;font-weight:600;padding:8px 16px;border-radius:999px;cursor:pointer;white-space:nowrap}
.seg button[aria-pressed="true"]{background:var(--ink);color:var(--cream)}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chips button{border:1px solid var(--ring);background:var(--paper);color:var(--muted);font:inherit;font-size:13px;font-weight:600;padding:6px 13px;border-radius:999px;cursor:pointer}
.chips button[aria-pressed="true"]{background:var(--ink);color:var(--cream);border-color:var(--ink)}

/* Results */
.hub-results{padding:26px 0 70px;min-height:40vh}
.day-group{margin:0 0 30px}
.day-head{font-size:15px;font-weight:700;letter-spacing:.02em;color:var(--ink);text-transform:uppercase;margin:0 0 12px;padding-bottom:7px;border-bottom:1px solid var(--ring)}
.ev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.ev{display:flex;gap:14px;background:var(--paper);border:1px solid var(--ring);border-radius:16px;padding:15px 16px;text-decoration:none;color:inherit;transition:transform .14s ease,box-shadow .14s ease}
.ev:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(27,24,19,.10)}
.ev .date{flex:none;width:54px;text-align:center;border-right:1px solid var(--ring);padding-right:12px;display:flex;flex-direction:column;justify-content:center}
.ev .date .dow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.ev .date .dnum{font-size:24px;font-weight:800;line-height:1.05;letter-spacing:-.02em}
.ev .date .mon{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--muted)}
.ev .body{min-width:0;flex:1}
.ev .title{font-size:16px;font-weight:700;line-height:1.25;margin:0 0 3px;letter-spacing:-.01em}
.ev .sub{font-size:13px;color:var(--muted);margin:0 0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ev .meta-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.ev .pill{font-size:11px;font-weight:600;color:var(--muted);background:var(--cream);border:1px solid var(--ring);border-radius:999px;padding:2px 9px}
.ev .time{font-size:12px;font-weight:600;color:var(--ink)}
.ev .go{flex:none;align-self:center;color:var(--muted);font-size:18px}

/* States */
.hub-state{text-align:center;padding:56px 20px;color:var(--muted)}
.hub-state .spin{width:30px;height:30px;border:3px solid var(--ring);border-top-color:var(--ink);border-radius:50%;margin:0 auto 16px;animation:hubspin .8s linear infinite}
@keyframes hubspin{to{transform:rotate(360deg)}}
.hub-state.error{color:#9a3b2f}
.hub-count{font-size:13px;color:var(--muted);margin:0 0 18px}

/* In-page app CTA band reused from theme via .cta-band/.appstore */
.hub-cta{margin:34px 0 0;padding:30px;background:var(--cream2);border:1px solid var(--ring);border-radius:22px;text-align:center}
.hub-cta h2{margin:0 0 8px;font-size:22px}
.hub-cta p{margin:0 0 18px;color:var(--muted)}

@media(max-width:520px){
  .ev .sub{white-space:normal}
  .hub-controls{top:0}
}
