/* ── Design Tokens ─────────────────────────────────────────────────────────── */
:root {
    --navy-950: #0b1f6b;
    --navy-900: #112a8a;
    --navy-800: #1b3aa6;
    --navy-700: #234bc4;
    --navy-600: #2f5cdb;
    --blue-500: #3b6cf2;
    --blue-400: #6a8df5;
    --blue-300: #9db4f7;
    --blue-100: #dde6fb;
    --blue-50:  #eef2fc;
    --sky:   #4fc3f7;
    --teal:  #2bd4c8;
    --aqua:  #38e0c5;
    --ink:   #0b1f6b;
    --ink-2: #4b5ea3;
    --ink-3: #8b97c5;
    --paper:   #ffffff;
    --paper-2: #f3f5fb;
    --line:    #e2e7f3;
}

/* ── Base ───────────────────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing: border-box; }
html {
    margin: 0;
    padding: 0;
    font-size: clamp(1rem, 1vw, 100rem);
    overflow-x: clip;
    touch-action: pan-y;
}
body {
    margin: 0;
    padding: 0;
    overflow-x: clip;
    font-family: 'Inter', system-ui, sans-serif;
    color: var(--ink);
    background: var(--paper);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
a { text-decoration: none; }
button { cursor: pointer; font: inherit; }
img { display: block; max-width: 100%; }
::selection { background: var(--sky); color: white; }

.soflo-display {
    font-family: 'Bricolage Grotesque','Inter',sans-serif;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 0.95;
    font-variation-settings: "opsz" 96;
}
.soflo-mono { font-family: 'JetBrains Mono', ui-monospace, monospace; }

@keyframes soflo-pulse { 0%,100%{opacity:1} 50%{opacity:.4} }

/* ── Nav ────────────────────────────────────────────────────────────────────── */
.soflo-nav {
    position: sticky;
    top: 0;
    z-index: 50;
    background: transparent;
    border-bottom: 1px solid transparent;
    transition: background .25s ease, border-color .25s ease, backdrop-filter .25s ease;
}
.admin-bar .soflo-nav { top: 32px; }
.soflo-nav.is-scrolled {
    background: rgba(255,255,255,0.94);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom-color: var(--line);
}
.soflo-nav__inner {
    max-width: 80rem;
    margin: 0 auto;
    padding: 0.875rem 2rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
}
.soflo-nav__logo-img {
    height: 3.5rem;
    width: auto;
    transition: opacity .25s ease;
}
.soflo-nav__logo-img--default { opacity: 1; filter: brightness(0) invert(1); }
.soflo-nav__logo-img--sticky  { display: none; }
.soflo-nav.is-scrolled .soflo-nav__logo-img--default { display: none; }
.soflo-nav.is-scrolled .soflo-nav__logo-img--sticky  { display: block; }

.soflo-nav__links { display: flex; align-items: center; gap: 0.25rem; }
.soflo-nav__link {
    position: relative;
    padding: 0.5rem 0.875rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: rgba(255,255,255,.95);
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    transition: background .15s ease, color .25s ease;
}
.soflo-nav__link:hover { background: rgba(255,255,255,.12); }
.soflo-nav.is-scrolled .soflo-nav__link { color: var(--ink); }
.soflo-nav.is-scrolled .soflo-nav__link:hover { background: rgba(11,31,107,.06); }
.soflo-nav__badge {
    font-size: 0.5625rem; font-weight: 700; letter-spacing: .08em;
    background: var(--blue-500); color: white;
    padding: 0.125rem 0.375rem; border-radius: 0.25rem;
}
.soflo-nav__actions { display: flex; align-items: center; gap: 0.625rem; }
.soflo-nav__login {
    font-size: 0.875rem; font-weight: 500;
    color: white; padding: 0.5rem 0.875rem;
    transition: color .25s ease;
}
.soflo-nav.is-scrolled .soflo-nav__login { color: var(--ink); }
.soflo-nav__join {
    font-size: 0.875rem; font-weight: 600; color: white;
    background: var(--blue-500); padding: 0.625rem 1.25rem;
    border-radius: 999px;
    box-shadow: 0 0.25rem 0.875rem rgba(59,108,242,.35);
    transition: background .15s ease;
}
.soflo-nav__join:hover { background: var(--navy-700); }

/* ── Burger ─────────────────────────────────────────────────────────────────── */
.soflo-nav__burger {
    display: none;
    flex-direction: column; justify-content: center; align-items: center;
    gap: 0.3125rem;
    width: 2.5rem; height: 2.5rem;
    background: transparent; border: none; padding: 0;
    cursor: pointer;
}
.soflo-nav__burger span {
    display: block; width: 1.375rem; height: 2px;
    background: white; border-radius: 2px;
    transition: transform .25s ease, opacity .25s ease;
}
.soflo-nav.is-scrolled .soflo-nav__burger span { background: var(--ink); }
.soflo-nav__burger.is-open span:nth-child(1) { transform: translateY(0.4375rem) rotate(45deg); }
.soflo-nav__burger.is-open span:nth-child(2) { opacity: 0; }
.soflo-nav__burger.is-open span:nth-child(3) { transform: translateY(-0.4375rem) rotate(-45deg); }

/* ── Mobile menu ────────────────────────────────────────────────────────────── */
.soflo-mobile-menu {
    display: none;
    position: fixed; top: 5.375rem; left: 0; right: 0; bottom: 0;
    z-index: 99;
    background: var(--navy-950);
    flex-direction: column;
    overflow-y: auto;
    padding: 2rem 1.5rem 3rem;
    transform: translateY(-1rem);
    opacity: 0;
    transition: transform .25s ease, opacity .25s ease;
}
.soflo-mobile-menu.is-open {
    opacity: 1;
    transform: translateY(0);
}
.soflo-mobile-menu__links {
    display: flex; flex-direction: column;
    border-top: 1px solid rgba(255,255,255,.1);
}
.soflo-mobile-menu__links .soflo-nav__link {
    display: flex; align-items: center; gap: 0.625rem;
    padding: 1rem 0;
    border-bottom: 1px solid rgba(255,255,255,.1);
    color: rgba(255,255,255,.85);
    font-size: 1.125rem; font-weight: 500;
    transition: color .15s;
}
.soflo-mobile-menu__links .soflo-nav__link:hover { color: white; }
.soflo-mobile-menu__links .soflo-nav__link--new { color: var(--sky); }
.soflo-mobile-menu__links .soflo-nav__badge {
    font-size: 0.6rem; font-weight: 700; letter-spacing: .12em;
    background: var(--blue-500); color: white;
    padding: 0.1875rem 0.4375rem; border-radius: 0.25rem;
    font-family: 'JetBrains Mono', monospace;
}
.soflo-mobile-menu__actions {
    display: flex; flex-direction: column; gap: 0.75rem;
    margin-top: 2rem;
}
.soflo-mobile-menu__login {
    text-align: center; padding: 0.875rem;
    border: 1px solid rgba(255,255,255,.25); border-radius: 999px;
    color: white; font-weight: 500; font-size: 0.9375rem;
}
.soflo-mobile-menu__join {
    text-align: center; padding: 0.875rem;
    background: var(--blue-500); border-radius: 999px;
    color: white; font-weight: 600; font-size: 0.9375rem;
    box-shadow: 0 0.25rem 0.875rem rgba(59,108,242,.45);
}

/* ── Hero ───────────────────────────────────────────────────────────────────── */
.soflo-hero {
    position: relative;
    overflow: hidden;
    isolation: isolate;
    margin-top: -5.375rem;
    padding-top: 5.375rem;
}
.soflo-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -3;
    background-image: var(--hero-bg);
    background-size: cover;
    background-position: center;
}
.soflo-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -2;
    background: linear-gradient(180deg, rgba(11,31,107,.88) 0%, rgba(17,42,138,.85) 50%, rgba(11,31,107,.95) 100%);
}
.soflo-hero__palm {
    position: absolute;
    bottom: -1.25rem;
    z-index: -1;
    opacity: .85;
    color: rgba(11,31,107,.7);
}
.soflo-hero__palm--left  { left: -2.5rem; width: 13.75rem; }
.soflo-hero__palm--right { right: -1.875rem; width: 11.25rem; }

.soflo-hero__inner {
    max-width: 80rem;
    margin: 0 auto;
    padding: 3.75rem 2rem 8.125rem;
    position: relative;
}

/* live badge */
.soflo-hero__live-badge {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.375rem 0.875rem;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.25);
    border-radius: 999px;
    color: rgba(255,255,255,.95);
    font-size: 0.75rem; font-weight: 500;
    backdrop-filter: blur(6px);
    margin: 1.75rem auto 1.5rem;
    justify-content: center;
    width: fit-content;
}
.soflo-hero__live-dot {
    width: 0.375rem; height: 0.375rem; border-radius: 50%;
    background: var(--aqua);
    box-shadow: 0 0 0.625rem var(--aqua);
    animation: soflo-pulse 2s infinite;
    flex-shrink: 0;
}
.soflo-hero__live-label { letter-spacing: .1em; font-size: 0.6875rem; }
.soflo-hero__live-sep { color: rgba(255,255,255,.6); }

/* headline */
.soflo-hero__h1 {
    color: white;
    font-size: clamp(2.75rem, 7vw, 6rem);
    text-align: center;
    margin: 0 auto;
    max-width: 68.75rem;
}
.soflo-hero__em {
    font-style: italic;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 600;
    color: var(--aqua);
}
.soflo-hero__underline {
    display: inline-block;
    position: relative;
    margin-left: 1rem;
}
.soflo-hero__underline svg {
    position: absolute;
    bottom: -0.5rem; left: 0;
    width: 100%; height: 0.875rem;
    color: var(--sky);
}

.soflo-hero__desc {
    color: rgba(255,255,255,.85);
    text-align: center;
    font-size: 1.0625rem; line-height: 1.55;
    max-width: 38.75rem;
    margin: 2rem auto 2.75rem;
}

/* search bar */
.soflo-hero__search-wrap { max-width: 57.5rem; margin: 0 auto; }
.soflo-hero__searchbar {
    background: white;
    border-radius: 1.25rem; padding: 0.5rem;
    display: grid;
    grid-template-columns: 1.2fr 1.2fr 1fr auto;
    gap: 0.375rem;
    box-shadow: 0 1.875rem 5rem -1.25rem rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.5);
}
.soflo-searchbar__dropdown { position: relative; }
.soflo-searchbar__btn {
    width: 100%;
    display: flex; align-items: center; gap: 0.625rem;
    padding: 1rem;
    background: white; border: none; border-radius: 0.75rem;
    color: var(--ink); text-align: left;
}
.soflo-searchbar__btn:focus { box-shadow: 0 0 0 2px var(--blue-500); outline: none; }
.soflo-searchbar__icon { color: var(--blue-500); display: flex; flex: none; }
.soflo-searchbar__val { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 0.875rem; font-weight: 600; }
.soflo-searchbar__chev { color: var(--ink-3); display: flex; flex: none; transition: transform .15s ease; }
.soflo-searchbar__dropdown.is-open .soflo-searchbar__chev { transform: rotate(180deg); }
.soflo-searchbar__dropdown-list {
    display: none;
    position: absolute; top: calc(100% + 0.375rem); left: 0; right: 0;
    background: white; border-radius: 0.75rem;
    box-shadow: 0 1.25rem 3.125rem rgba(11,31,107,.25), 0 0 0 1px rgba(11,31,107,.06);
    padding: 0.375rem; z-index: 30; max-height: 20rem; overflow-y: auto;
}
.soflo-searchbar__dropdown.is-open .soflo-searchbar__dropdown-list { display: block; }
.soflo-searchbar__opt {
    width: 100%; text-align: left;
    padding: 0.625rem 0.75rem; border-radius: 0.5rem;
    background: transparent; border: none;
    font-size: 0.875rem; font-weight: 400; color: var(--ink);
}
.soflo-searchbar__opt:hover { background: var(--paper-2); }
.soflo-searchbar__opt.is-selected { background: var(--blue-50); color: var(--blue-500); font-weight: 600; }
.soflo-searchbar__submit {
    background: var(--blue-500); color: white;
    border: none; border-radius: 0.75rem;
    padding: 0 1.75rem;
    font-weight: 700; font-size: 0.875rem;
    display: flex; align-items: center; gap: 0.5rem;
    white-space: nowrap;
    transition: background .15s ease;
}
.soflo-searchbar__submit:hover { background: var(--navy-700); }

/* OR row */
.soflo-hero__or-row {
    display: flex; align-items: center; gap: 0.875rem;
    color: white; font-size: 0.6875rem; font-weight: 700; letter-spacing: .18em;
    margin: 2rem auto 1rem;
    max-width: 45rem;
}
.soflo-hero__or-line { flex: 1; height: 1px; background: rgba(255,255,255,.3); }
.soflo-hero__or-text { font-family: 'JetBrains Mono', monospace; }

/* name search */
.soflo-hero__name-search { max-width: 45rem; margin: 0 auto; }
.soflo-name-search {
    display: flex; align-items: center; gap: 0.875rem;
    background: white; border-radius: 999px;
    padding: 0.875rem 1.375rem 0.875rem 1.25rem;
    box-shadow: 0 0.875rem 1.875rem -0.5rem rgba(0,0,0,.35);
    transition: box-shadow .2s ease;
}
.soflo-name-search:focus-within {
    box-shadow: 0 0 0 3px var(--sky), 0 1.25rem 2.5rem -0.625rem rgba(0,0,0,.4);
}
.soflo-name-search__icon { color: var(--blue-500); display: flex; }
.soflo-name-search__input {
    flex: 1; background: transparent; border: none; outline: none;
    color: var(--ink); font-size: 1rem; font-family: inherit; font-weight: 500;
}
.soflo-name-search__input::placeholder { color: var(--ink-3); }
.soflo-name-search__kbd {
    font-size: 0.6875rem; color: var(--ink-3); letter-spacing: .1em;
    padding: 0.25rem 0.5rem; background: var(--paper-2); border-radius: 0.375rem;
}

/* trending */
.soflo-hero__trending {
    margin-top: 2.5rem;
    display: flex; align-items: center; gap: 0.875rem;
    justify-content: center; flex-wrap: wrap;
    color: rgba(255,255,255,.85); font-size: 0.8125rem;
}
.soflo-hero__trending-label {
    font-size: 0.6875rem; letter-spacing: .12em; color: rgba(255,255,255,.65);
}
.soflo-hero__trending-pill {
    color: white; font-weight: 500;
    padding: 0.3125rem 0.75rem; border-radius: 999px;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.2);
    font-size: 0.75rem;
    transition: background .15s ease;
}
.soflo-hero__trending-pill:hover { background: rgba(255,255,255,.22); }

/* wave */
.soflo-hero__wave {
    position: absolute; bottom: -1px; left: 0; right: 0;
    color: var(--paper); line-height: 0;
}
.soflo-hero__wave svg { width: 100%; height: 4.375rem; display: block; }

/* ── Genre Rail ────────────────────────────────────────────────────────────── */
.soflo-genre-rail {
    background: var(--paper);
    padding: 2.25rem 2rem 1.75rem;
    border-bottom: 1px solid var(--line);
}
.soflo-genre-rail__inner { max-width: 80rem; margin: 0 auto; }
.soflo-genre-rail__head {
    display: flex; align-items: baseline; justify-content: space-between;
    margin-bottom: 1.125rem;
}
.soflo-genre-rail__eyebrow { font-size: 0.6875rem; color: var(--ink-3); letter-spacing: .14em; margin-bottom: 0.375rem; }
.soflo-genre-rail__title { font-size: 1.5rem; margin: 0; }
.soflo-genre-rail__all { font-size: 0.8125rem; font-weight: 600; color: var(--blue-500); }
.soflo-genre-rail__all:hover { text-decoration: underline; }
.soflo-genre-rail__grid {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 0.75rem;
}
.soflo-genre-card {
    position: relative;
    padding: 1.25rem 0.875rem 1rem;
    background: white;
    border: 1px solid var(--line);
    border-radius: 1rem;
    text-align: center;
    color: var(--ink);
    display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    overflow: hidden;
}
.soflo-genre-card:hover {
    transform: translateY(-0.1875rem);
    box-shadow: 0 0.75rem 1.5rem -0.5rem rgba(59,108,242,.25);
    border-color: var(--blue-500);
}
.soflo-genre-card__badge {
    position: absolute; top: 0.5rem; right: 0.5rem;
    font-size: 0.5625rem; font-weight: 700; letter-spacing: .08em;
    background: var(--blue-500); color: white;
    padding: 0.125rem 0.3125rem; border-radius: 0.25rem;
}
.soflo-genre-card__icon {
    color: var(--blue-500);
    display: flex; align-items: center; justify-content: center;
    width: 2.5rem; height: 2.5rem;
}
.soflo-genre-card__label { font-size: 0.8125rem; font-weight: 600; line-height: 1.2; }
.soflo-genre-card__sub { font-size: 0.6875rem; color: var(--ink-3); }

/* ── What's On ──────────────────────────────────────────────────────────────── */
.soflo-whats-on { background: var(--paper); padding: 3.75rem 2rem 5rem; }
.soflo-whats-on__inner { max-width: 80rem; margin: 0 auto; }
.soflo-whats-on__head {
    display: flex; justify-content: space-between; align-items: flex-end;
    margin-bottom: 1.75rem; gap: 1.5rem; flex-wrap: wrap;
}
.soflo-whats-on__live-row { display: flex; align-items: center; gap: 0.625rem; margin-bottom: 0.625rem; }
.soflo-whats-on__dot {
    width: 0.5rem; height: 0.5rem; border-radius: 50%;
    background: var(--blue-500);
    box-shadow: 0 0 0.75rem var(--blue-500);
    animation: soflo-pulse 2s infinite;
    flex-shrink: 0;
}
.soflo-whats-on__updated { font-size: 0.6875rem; color: var(--ink-3); letter-spacing: .14em; }
.soflo-whats-on__title { font-size: clamp(2.25rem, 4.5vw, 3.5rem); margin: 0; }
.soflo-whats-on__title em { font-style: italic; font-weight: 500; color: var(--blue-500); }
.soflo-whats-on__sub { font-size: 0.9375rem; color: var(--ink-2); margin-top: 0.625rem; max-width: 33.75rem; }
.soflo-whats-on__cal-link {
    font-size: 0.8125rem; font-weight: 600; color: var(--ink);
    padding: 0.625rem 1.125rem;
    border: 1px solid var(--ink); border-radius: 999px;
    display: inline-flex; align-items: center; gap: 0.5rem;
    white-space: nowrap;
}
.soflo-whats-on__cal-link:hover { background: var(--paper-2); }
.soflo-whats-on__tabs {
    display: flex; gap: 0.375rem; margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--line);
}
.soflo-whats-on__tab {
    padding: 0.625rem 1rem; background: transparent;
    border: none; border-bottom: 2px solid transparent;
    font-size: 0.875rem; font-weight: 500; color: var(--ink-3);
    margin-bottom: -1px;
    transition: color .15s, border-color .15s;
}
.soflo-whats-on__tab.is-active { border-bottom-color: var(--blue-500); font-weight: 600; color: var(--blue-500); }
.soflo-whats-on__tab:hover:not(.is-active) { color: var(--ink); }

.soflo-shows-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.125rem; }

.soflo-show-card {
    position: relative; display: block; color: inherit;
    border-radius: 1.125rem; overflow: hidden;
    background: white; border: 1px solid var(--line);
    transition: transform .25s ease, box-shadow .25s ease;
}
.soflo-show-card:hover {
    transform: translateY(-0.25rem);
    box-shadow: 0 1.5rem 2.5rem -0.75rem rgba(11,31,107,.25);
}
.soflo-show-card__link { display: block; color: inherit; text-decoration: none; }
.soflo-show-card__img-wrap {
    position: relative; aspect-ratio: 4/2.6; overflow: hidden; background: var(--paper-2);
}
.soflo-show-card__img { width: 100%; height: 100%; object-fit: cover; }
.soflo-show-card__heart {
    position: absolute; top: 0.625rem; right: 0.625rem;
    width: 2.125rem; height: 2.125rem; border-radius: 50%;
    background: rgba(11,31,107,.55); backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.25);
    display: flex; align-items: center; justify-content: center;
    color: white; transition: background .15s, transform .15s;
}
.soflo-show-card__heart:hover { background: var(--blue-500); transform: scale(1.1); }
.soflo-show-card__heart.is-saved { background: var(--blue-500); }
.soflo-show-card__heart.is-saved svg { fill: white; stroke: none; }
.soflo-show-card__time {
    position: absolute; bottom: 0.75rem; left: 0.75rem;
    background: rgba(11,31,107,.85); backdrop-filter: blur(8px);
    color: white; padding: 0.3125rem 0.6875rem; border-radius: 0.375rem;
    font-size: 0.6875rem; font-weight: 600;
}
.soflo-show-card__body { padding: 1.125rem; }
.soflo-show-card__genre { font-size: 0.625rem; color: var(--ink-3); letter-spacing: .1em; margin-bottom: 0.375rem; }
.soflo-show-card__artist { font-size: 1.375rem; margin: 0 0 0.5rem; letter-spacing: -.01em; }
.soflo-show-card__venue {
    display: flex; align-items: center; gap: 0.375rem;
    color: var(--ink-2); font-size: 0.8125rem; margin-bottom: 0.25rem;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.soflo-show-card__about {
    font-size: 0.78rem; color: var(--ink-2); line-height: 1.4; margin: 0.25rem 0 0.5rem;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.soflo-show-card__meta-row {
    display: flex; align-items: center; gap: 0.4rem; margin: 0.35rem 0 0.5rem;
}
.soflo-show-card__badge {
    font-size: 0.68rem; font-weight: 700; letter-spacing: .04em;
    background: var(--blue-500); border: none;
    color: #fff; padding: 0.15rem 0.5rem; border-radius: 999px;
}
.soflo-show-card__badge--free {
    background: var(--blue-500);
}
.soflo-show-card__age {
    font-size: 0.68rem; font-weight: 700;
    background: var(--blue-500); color: #fff;
    padding: 0.15rem 0.5rem; border-radius: 999px;
}
.soflo-show-card__details {
    display: flex; justify-content: flex-end; align-items: center;
    gap: 0.375rem; margin-top: 0.625rem;
    font-size: 0.75rem; font-weight: 600; color: var(--blue-500);
}

/* ── Drive Scene ────────────────────────────────────────────────────────────── */
.soflo-drive {
    position: relative; overflow: hidden;
    padding: 4.5rem 2rem 5rem;
    background: linear-gradient(135deg, var(--navy-950) 0%, var(--navy-800) 60%, var(--navy-700) 100%);
    color: white;
}
.soflo-drive__wave {
    position: absolute; left: 0; right: 0; bottom: 0;
    color: rgba(79,195,247,.18); opacity: .6;
}
.soflo-drive__wave svg { width: 100%; height: 3.75rem; }
.soflo-drive__inner {
    max-width: 80rem; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1.2fr;
    gap: 3.75rem; align-items: center; position: relative;
}
.soflo-drive__eyebrow { font-size: 0.6875rem; letter-spacing: .14em; color: var(--sky); }
.soflo-drive__title { font-size: clamp(3rem, 6vw, 5rem); margin: 0.875rem 0 1.25rem; }
.soflo-drive__em { display: inline-block; margin-left: 0.875rem; color: var(--sky); font-style: italic; font-weight: 500; }
.soflo-drive__desc { font-size: 1rem; line-height: 1.6; color: rgba(255,255,255,.85); max-width: 28.75rem; margin-bottom: 1.875rem; }
.soflo-drive__ctas { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.soflo-drive__cta-primary {
    padding: 0.875rem 1.5rem; background: white; color: var(--navy-900);
    border-radius: 999px; font-weight: 600; font-size: 0.875rem;
    display: inline-flex; align-items: center; gap: 0.5rem;
    transition: opacity .15s ease;
}
.soflo-drive__cta-primary:hover { opacity: .9; }
.soflo-drive__cta-outline {
    padding: 0.875rem 1.5rem; background: transparent; color: white;
    border: 1px solid rgba(255,255,255,.4); border-radius: 999px;
    font-weight: 600; font-size: 0.875rem;
    transition: background .15s ease;
}
.soflo-drive__cta-outline:hover { background: rgba(255,255,255,.1); }
.soflo-drive__stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.soflo-stat-card {
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 1rem; padding: 1.5rem;
}
.soflo-stat-card__value { font-size: 3rem; color: white; line-height: 1; }
.soflo-stat-card__label {
    font-size: 0.75rem; color: rgba(255,255,255,.75);
    margin-top: 0.5rem; text-transform: uppercase; letter-spacing: .1em; font-weight: 500;
}

/* ── Featured ───────────────────────────────────────────────────────────────── */
.soflo-featured { background: var(--paper); padding: 4.5rem 2rem 5rem; }
.soflo-featured__inner { max-width: 80rem; margin: 0 auto; }
.soflo-featured__head {
    display: flex; align-items: flex-end; justify-content: space-between;
    margin-bottom: 1.75rem; flex-wrap: wrap; gap: 1.25rem;
}
.soflo-featured__eyebrow { font-size: 0.6875rem; color: var(--ink-3); letter-spacing: .14em; margin-bottom: 0.5rem; }
.soflo-featured__title { font-size: clamp(2.25rem, 4.5vw, 3.5rem); margin: 0; }
.soflo-featured__title em { font-style: italic; font-weight: 500; color: var(--blue-500); }
.soflo-featured__tabs {
    background: white; border: 1px solid var(--line);
    border-radius: 999px; padding: 0.25rem; display: flex;
}
.soflo-featured__tab {
    padding: 0.5rem 1.125rem; border-radius: 999px;
    background: transparent; color: var(--ink-2);
    border: none; font-size: 0.8125rem; font-weight: 600;
    transition: background .15s, color .15s;
}
.soflo-featured__tab.is-active { background: var(--blue-500); color: white; }
.soflo-featured__grid { position: relative; }
.soflo-featured__panel { display: none; }
.soflo-featured__panel.is-active { display: flex; gap: 1.125rem; align-items: stretch; aspect-ratio: 12 / 5; }
.soflo-featured__panel.is-active > .soflo-feat-big { flex: 1.1 1 0; min-width: 0; min-height: 0; height: 100%; aspect-ratio: auto; }
.soflo-featured__panel.is-active > .soflo-feat-small-grid { flex: 1 1 0; min-width: 0; min-height: 0; height: 100%; overflow: hidden; }

.soflo-feat-big {
    position: relative; display: block; border-radius: 1.25rem; overflow: hidden;
    aspect-ratio: 5/4; color: inherit;
}
.soflo-feat-big__img {
    position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
}
.soflo-feat-big__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 35%, rgba(11,31,107,.92) 100%);
}
.soflo-feat-big__badge {
    position: absolute; top: 1.125rem; left: 1.125rem;
    background: var(--blue-500); color: white;
    padding: 0.3125rem 0.6875rem; border-radius: 0.375rem;
    font-size: 0.625rem; font-weight: 700; letter-spacing: .12em;
    font-family: 'JetBrains Mono', monospace;
    display: inline-flex; align-items: center; gap: 0.375rem;
}
.soflo-feat-big__dot { width: 0.375rem; height: 0.375rem; border-radius: 50%; background: white; }
.soflo-feat-big__body { position: absolute; left: 1.5rem; right: 1.5rem; bottom: 1.5rem; color: white; }
.soflo-feat-big__name { font-size: 2.75rem; margin: 0; letter-spacing: -.02em; }
.soflo-feat-big__desc { font-size: 0.875rem; color: rgba(255,255,255,.9); margin: 0.375rem 0 1rem; }
.soflo-feat-big__cta {
    display: inline-flex; align-items: center; gap: 0.5rem;
    padding: 0.625rem 1.125rem; background: white; color: var(--navy-900);
    border-radius: 999px; font-size: 0.8125rem; font-weight: 600;
}

.soflo-feat-small-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr; gap: 0.75rem; height: 100%;
}
.soflo-feat-small {
    border-radius: 0.875rem; overflow: hidden;
    border: 1px solid var(--line);
    background: #fff;
    text-decoration: none; color: inherit;
    display: flex; flex-direction: column; min-height: 0;
    transition: box-shadow .15s, transform .15s;
}
.soflo-feat-small:hover { box-shadow: 0 6px 20px rgba(59,85,230,.1); transform: translateY(-2px); }
.soflo-feat-small__avatar {
    flex: 1; min-height: 0; overflow: hidden;
}
.soflo-feat-small__avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.soflo-feat-small__info {
    padding: 0.6rem 0.75rem 0.7rem;
}
.soflo-feat-small__name {
    font-size: 0.875rem; font-weight: 700; color: #1a1d2e;
    letter-spacing: -.01em; line-height: 1.2;
}
.soflo-feat-small__meta {
    font-size: 0.68rem; color: #8b97c5; margin-top: 0.18rem; line-height: 1.3;
}
.soflo-feat-small__name-row {
    display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap;
}
.soflo-feat-small__genre {
    font-size: 0.6rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
    color: var(--blue-500); background: rgba(59,85,230,.08);
    border: 1px solid rgba(59,85,230,.18);
    padding: 0.1rem 0.45rem; border-radius: 999px; white-space: nowrap; flex-shrink: 0;
}
.soflo-feat-small__pick {
    font-size: 0.7rem; color: var(--ink-2); margin-top: 0.3rem; line-height: 1.35;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.soflo-feat-big__genre-pill {
    display: inline-block; font-size: 0.7rem; font-weight: 700; letter-spacing: .07em;
    text-transform: uppercase; color: white;
    background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.35);
    padding: 0.2rem 0.6rem; border-radius: 999px; margin-bottom: 0.4rem;
    backdrop-filter: blur(4px);
}
.soflo-feat-big__pick {
    font-size: 0.875rem; color: rgba(255,255,255,.9); margin: 0.375rem 0 1rem; line-height: 1.45;
}

/* ── Gig Guide ──────────────────────────────────────────────────────────────── */
.soflo-gig-guide { background: var(--paper); padding: 0 2rem 5rem; }
.soflo-gig-guide__inner {
    max-width: 80rem; margin: 0 auto;
    background: var(--paper-2); border-radius: 1.5rem; overflow: hidden;
    display: grid; grid-template-columns: 1fr 1fr;
    border: 1px solid var(--line);
}
.soflo-gig-guide__copy { padding: 3.25rem 3.5rem; }
.soflo-gig-guide__eyebrow {
    font-size: 0.6875rem; color: var(--ink-3); letter-spacing: .14em;
    margin-bottom: 0.875rem; display: inline-flex; align-items: center; gap: 0.5rem;
}
.soflo-gig-guide__title { font-size: clamp(2.25rem, 4vw, 3.25rem); margin: 0 0 0.875rem; letter-spacing: -.02em; }
.soflo-gig-guide__em { display: block; font-style: italic; font-weight: 500; color: var(--blue-500); }
.soflo-gig-guide__desc { font-size: 0.9375rem; color: var(--ink-2); line-height: 1.6; margin-bottom: 1.5rem; max-width: 23.75rem; }
.soflo-gig-guide__form { display: flex; gap: 0.5rem; max-width: 26.25rem; }
.soflo-gig-guide__input {
    flex: 1; padding: 0.875rem 1.125rem;
    background: white; border: 1px solid var(--line);
    border-radius: 0.75rem; font: inherit; font-size: 0.875rem; outline: none;
}
.soflo-gig-guide__input:focus { border-color: var(--blue-500); }
.soflo-gig-guide__submit {
    padding: 0.875rem 1.375rem;
    background: var(--blue-500); color: white;
    border: none; border-radius: 0.75rem;
    font-weight: 600; font-size: 0.875rem; white-space: nowrap;
    transition: background .15s ease;
}
.soflo-gig-guide__submit:hover { background: var(--navy-700); }
.soflo-gig-guide__success {
    margin-top: 1rem;
    padding: 0.875rem 1.125rem; background: white;
    border: 1px solid var(--blue-500); border-radius: 0.75rem;
    color: var(--ink); font-size: 0.875rem; font-weight: 500;
    display: flex; align-items: center; gap: 0.625rem;
}
.soflo-gig-guide__check { color: var(--blue-500); font-size: 1.125rem; }
.soflo-gig-guide__meta {
    display: flex; gap: 1.125rem; margin-top: 1.375rem;
    font-size: 0.75rem; color: var(--ink-3);
}
.soflo-gig-guide__photo {
    position: relative; overflow: hidden; min-height: 26.25rem;
    background-image: var(--gg-bg);
    background-size: cover; background-position: center;
}
.soflo-gig-guide__photo::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(11,31,107,.55) 0%, rgba(59,108,242,.35) 100%);
}

/* ── Social Feed ────────────────────────────────────────────────────────────── */
.soflo-feed { background: var(--paper); padding: 3.75rem 2rem 5.625rem; }
.soflo-feed__head { max-width: 80rem; margin: 0 auto 2.25rem; text-align: center; }
.soflo-feed__hashtag {
    font-size: clamp(2.5rem, 5vw, 4rem); letter-spacing: -.02em;
    color: var(--blue-500); font-style: italic; font-weight: 500;
}
.soflo-feed__sub { color: var(--ink-2); font-size: 0.9375rem; margin-top: 0.5rem; }
.soflo-feed__grid {
    max-width: 80rem; margin: 0 auto;
    display: grid; grid-template-columns: repeat(6,1fr); gap: 0.5rem;
}
.soflo-feed__item {
    position: relative; aspect-ratio: 1; border-radius: 0.75rem;
    overflow: hidden; display: block; background: var(--paper-2);
}
.soflo-feed__img { width: 100%; height: 100%; object-fit: cover; }
.soflo-feed__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(0deg, rgba(11,31,107,.9), transparent 60%);
    padding: 0.75rem; display: flex; flex-direction: column; justify-content: flex-end;
    color: white; opacity: 0; transition: opacity .2s ease;
}
.soflo-feed__item:hover .soflo-feed__overlay { opacity: 1; }
.soflo-feed__user { font-size: 0.75rem; font-weight: 600; }
.soflo-feed__spot { font-size: 0.6875rem; color: rgba(255,255,255,.85); }

/* ── Footer ─────────────────────────────────────────────────────────────────── */
.soflo-footer {
    position: relative; overflow: hidden;
    background: var(--navy-950); color: rgba(255,255,255,.85);
    padding: 4.5rem 2rem 2rem;
}
.soflo-footer__glow {
    position: absolute; border-radius: 50%; filter: blur(40px); pointer-events: none;
}
.soflo-footer__glow--top {
    top: -12.5rem; left: -9.375rem; width: 31.25rem; height: 31.25rem;
    background: radial-gradient(circle, rgba(79,195,247,.18) 0%, transparent 70%);
}
.soflo-footer__glow--bottom {
    bottom: -15rem; right: -11.25rem; width: 33.75rem; height: 33.75rem;
    background: radial-gradient(circle, rgba(59,108,242,.22) 0%, transparent 70%);
}
.soflo-footer__wave {
    position: absolute; left: 0; right: 0; bottom: 0.75rem;
    color: rgba(79,195,247,.18); pointer-events: none;
}
.soflo-footer__wave svg { width: 100%; height: 2.5rem; }
.soflo-footer__inner { max-width: 80rem; margin: 0 auto; position: relative; }
.soflo-footer__grid {
    display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 3.75rem; margin-bottom: 3.75rem;
}
.soflo-footer__logo { height: 5rem; width: auto; filter: brightness(0) invert(1); }
.soflo-footer__desc { margin-top: 1.125rem; font-size: 0.8125rem; line-height: 1.6; color: rgba(255,255,255,.7); max-width: 20rem; }
.soflo-footer__social { display: flex; gap: 0.625rem; margin-top: 1.125rem; }
.soflo-footer__social-link {
    width: 2.25rem; height: 2.25rem; border-radius: 50%;
    background: rgba(255,255,255,.1);
    display: flex; align-items: center; justify-content: center;
    color: white;
    flex: 0 0 2.25rem;
    transition: background .15s ease;
}
.soflo-footer__social-link:hover { background: rgba(255,255,255,.2); }
.soflo-footer__col-heading {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.6875rem; color: rgba(255,255,255,.55);
    letter-spacing: .14em; text-transform: uppercase;
    margin: 0 0 1rem;
}
.soflo-footer__col-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.625rem; }
.soflo-footer__col-link { color: rgba(255,255,255,.85); font-size: 0.8125rem; }
.soflo-footer__col-link:hover { color: white; text-decoration: underline; }
.soflo-footer__bottom {
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255,255,255,.12);
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 0.875rem;
    font-size: 0.75rem; color: rgba(255,255,255,.55);
}
.soflo-footer__legal { display: flex; gap: 1.125rem; }
.soflo-footer__legal a { color: inherit; }
.soflo-footer__legal a:hover { color: white; }


/* ── Going button (stat band) ───────────────────────────────────────────────── */
.soflo-gig-stat-band__going {
    display: inline-flex; align-items: center; gap: 0.4rem;
    background: rgba(255,255,255,.12); border: 1.5px solid rgba(255,255,255,.55);
    color: white; border-radius: 999px; padding: 0.5625rem 1.125rem;
    font-size: 0.75rem; letter-spacing: .06em; font-weight: 600; cursor: pointer;
    transition: background .15s, border-color .15s, color .15s;
}
.soflo-gig-stat-band__going:hover {
    background: rgba(255,255,255,.22); border-color: white;
}
.soflo-gig-stat-band__going.is-going {
    background: white; color: var(--blue-500); border-color: white;
}
.soflo-gig-stat-band__going svg { transition: fill .15s; }
.soflo-gig-stat-band__going.is-going svg { fill: var(--blue-500); stroke: var(--blue-500); }
.soflo-gig-stat-band__going-count { opacity: .75; font-size: 0.6875rem; }

/* ── Gig stat band ───────────────────────────────────────────────────────────── */
.soflo-gig-stat-band {
    background: var(--blue-500); color: white; padding: 1.25rem 0;
}
.soflo-gig-stat-band__inner {
    max-width: 80rem; margin: 0 auto; padding: 0 2rem;
    display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap;
}
.soflo-gig-stat-band__type {
    font-size: 0.75rem; letter-spacing: .14em; font-weight: 700; white-space: nowrap;
    background: white; color: var(--blue-500); border-radius: 999px;
    padding: 0.3125rem 0.875rem;
}
.soflo-gig-stat-band__stats {
    display: flex; align-items: flex-start; gap: 0; flex: 1;
}
.soflo-gig-stat-band__stat {
    display: flex; flex-direction: column; gap: 0.125rem; padding: 0 1.25rem;
}
.soflo-gig-stat-band__stat:first-child { padding-left: 0; }
.soflo-gig-stat-band__stat-label {
    font-size: 0.625rem; letter-spacing: .12em; opacity: .75; margin-bottom: 0.1rem;
}
.soflo-gig-stat-band__stat-val {
    font-size: 1.0625rem; font-weight: 700; line-height: 1.15; color: white;
}
.soflo-gig-stat-band__stat-sub {
    font-size: 0.5625rem; opacity: .7; margin-top: 0.1rem;
}
.soflo-gig-stat-band__divider {
    width: 1px; background: rgba(255,255,255,.25); align-self: stretch; margin: 0;
}
.soflo-gig-stat-band__ctas {
    display: flex; gap: 0.625rem; align-items: center; flex-shrink: 0;
}
.soflo-gig-stat-band__save {
    display: inline-flex; align-items: center; gap: 0.4rem;
    background: rgba(255,255,255,.15); border: 1.5px solid rgba(255,255,255,.5);
    color: white; border-radius: 999px; padding: 0.5625rem 1.25rem;
    font-size: 0.75rem; letter-spacing: .06em; cursor: pointer;
    transition: background .15s;
}
.soflo-gig-stat-band__save:hover { background: rgba(255,255,255,.25); }
.soflo-gig-stat-band__tickets {
    background: white; color: var(--blue-500); border-radius: 999px;
    padding: 0.5625rem 1.25rem; font-size: 0.75rem; letter-spacing: .04em;
    text-decoration: none; font-weight: 700; transition: opacity .15s;
}
.soflo-gig-stat-band__tickets:hover { opacity: .85; }
@media (max-width: 640px) {
    .soflo-gig-stat-band__inner { flex-direction: column; gap: 1rem; align-items: flex-start; }
    .soflo-gig-stat-band__stats { flex-wrap: wrap; gap: 0.75rem; }
    .soflo-gig-stat-band__stat { padding: 0; }
    .soflo-gig-stat-band__divider { display: none; }
    .soflo-gig-stat-band__ctas { flex-direction: column; width: 100%; }
    .soflo-gig-stat-band__going,
    .soflo-gig-stat-band__save,
    .soflo-gig-stat-band__tickets { width: 100%; justify-content: center; display: flex; align-items: center; }
}


/* ── Add to Calendar dropdown ────────────────────────────────────────────────── */
.soflo-cal-dropdown { position: relative; display: inline-block; }
.soflo-cal-dropdown__menu {
    display: none; position: absolute; top: calc(100% + 0.375rem); left: 0;
    background: white; border: 1px solid var(--line); border-radius: 0.75rem;
    box-shadow: 0 8px 24px rgba(0,0,0,.12); min-width: 13rem; z-index: 200;
    overflow: hidden; padding: 0.375rem 0;
}
.soflo-cal-dropdown.is-open .soflo-cal-dropdown__menu { display: block; }
.soflo-cal-dropdown__item {
    display: flex; align-items: center; gap: 0.625rem;
    padding: 0.625rem 1rem; font-size: 0.8125rem; color: var(--ink);
    text-decoration: none; transition: background .12s;
}
.soflo-cal-dropdown__item:hover { background: var(--paper-2); }


/* ── Leaflet map: keep panes below sticky nav (z-index 50) ─────────────────── */
.soflo-gig-detail__where-map .leaflet-pane,
.soflo-gig-detail__where-map .leaflet-top,
.soflo-gig-detail__where-map .leaflet-bottom { z-index: 10 !important; }
.soflo-gig-detail__where-map .leaflet-tile-pane    { z-index: 10 !important; }
.soflo-gig-detail__where-map .leaflet-overlay-pane { z-index: 11 !important; }
.soflo-gig-detail__where-map .leaflet-shadow-pane  { z-index: 12 !important; }
.soflo-gig-detail__where-map .leaflet-marker-pane  { z-index: 13 !important; }
.soflo-gig-detail__where-map .leaflet-tooltip-pane { z-index: 14 !important; }
.soflo-gig-detail__where-map .leaflet-popup-pane   { z-index: 15 !important; }

/* ── Responsive ─────────────────────────────────────────────────────────────── */
@media (max-width: 980px) {
    .soflo-hero__searchbar { grid-template-columns: 1fr 1fr; }
    .soflo-genre-rail__grid { grid-template-columns: repeat(4,1fr); }
    .soflo-shows-grid { grid-template-columns: repeat(2,1fr); }
    .soflo-drive__inner { grid-template-columns: 1fr; gap: 2.5rem; }
    .soflo-featured { padding-bottom: 0; }
    .soflo-featured__panel.is-active { flex-direction: column; aspect-ratio: auto; }
    .soflo-featured__panel.is-active > .soflo-feat-big { flex: none; height: auto; aspect-ratio: 5/4; }
    .soflo-featured__panel.is-active > .soflo-feat-small-grid { flex: none; height: auto; overflow: visible; }
    .soflo-feat-small__avatar { flex: none; height: 11rem; }
    .soflo-feat-small-grid { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
    .soflo-gig-guide { padding-bottom: 0; }
    .soflo-gig-guide__inner { grid-template-columns: 1fr; }
    .soflo-gig-guide__photo { min-height: 16.25rem; }
    .soflo-feed__grid { grid-template-columns: repeat(3,1fr); }
    .soflo-footer__grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}

@media (max-width: 768px) {
    .soflo-hero__searchbar { grid-template-columns: 1fr; }
    .soflo-feed { padding-top: 0; }
    .soflo-searchbar__submit { height: 3rem; justify-content: center; }
}

@media (max-width: 640px) {
    .soflo-nav__links { display: none; }
    .soflo-nav__burger { display: flex; }
    .soflo-mobile-menu { display: flex; }
    .soflo-hero__inner { padding-top: 0; }
    .soflo-searchbar__submit { height: 3rem; justify-content: center; }
    .soflo-name-search { min-width: 0; }
    .soflo-name-search__input { min-width: 0; }
    .soflo-name-search__kbd { display: none; }
    .soflo-hero__trending { flex-direction: column; align-items: center; gap: 0.5rem; }
    .soflo-hero__trending-pill { align-self: center; }
    .soflo-hero__underline svg { bottom: -1.5rem; }
    .soflo-hero__live-badge { flex-direction: column; align-items: center; gap: 0.125rem; border-radius: 0.75rem; text-align: center; }
    .soflo-hero__live-sep { display: none; }
    .soflo-hero__live-dot { margin-bottom: 0.5rem; margin-top: 0.5rem; }
    .soflo-hero__searchbar { grid-template-columns: 1fr; }
    .soflo-genre-rail__grid { grid-template-columns: repeat(2,1fr); }
    .soflo-shows-grid { grid-template-columns: 1fr; }
    .soflo-whats-on { padding: 3rem 1.25rem 4rem; }
    .soflo-whats-on__head { flex-direction: column; align-items: flex-start; }
    .soflo-whats-on__tabs {
        flex-direction: column;
        border-bottom: none;
        gap: 0;
        margin-bottom: 1.5rem;
    }
    .soflo-whats-on__tab {
        border-bottom: 1px solid var(--line);
        border-left: none;
        margin-bottom: 0;
        text-align: center;
        padding: 0.75rem 1rem;
        width: 100%;
    }
    .soflo-whats-on__tab.is-active {
        border-bottom-color: var(--line);
        border-left: none;
    }

    .soflo-feat-big__body { left: 1.25rem; right: 1.25rem; bottom: 1.25rem; }
    .soflo-feat-big__name { font-size: 1.75rem; }
    .soflo-feat-big__desc { margin: 0.5rem 0 1.25rem; }
    .soflo-drive { padding: 3rem 1.25rem 4rem; overflow-x: hidden; }
    .soflo-drive__inner { width: 100%; min-width: 0; }
    .soflo-drive__title { font-size: clamp(2rem, 10vw, 3rem); }
    .soflo-drive__desc { max-width: 100%; }
    .soflo-drive__stats { grid-template-columns: 1fr 1fr; gap: 0.625rem; }
    .soflo-stat-card { padding: 1rem; }
    .soflo-stat-card__value { font-size: 2.25rem; }
    .soflo-featured { padding: 3rem 1.25rem 0; }
    .soflo-feat-small-grid { grid-template-columns: 1fr; }
    .soflo-feat-small__avatar { height: 14rem; }
    .soflo-feed__grid { grid-template-columns: repeat(2,1fr); }
    .soflo-footer__grid { grid-template-columns: 1fr; gap: 1.5rem; }
    .soflo-footer__brand { align-items: center; text-align: center; display: flex; flex-direction: column; }
    .soflo-footer__logo { margin: 0 auto; }
    .soflo-footer__social { justify-content: center; }
    .soflo-footer__col { text-align: center; }
    .soflo-footer__col-list { padding: 0; list-style: none; }
    .soflo-footer__bottom { flex-direction: column; align-items: center; text-align: center; }
    .soflo-footer__legal { justify-content: center; }
    .soflo-genre-rail__head { flex-direction: column; gap: 0.5rem; }
    .soflo-gig-guide { padding: 0 1rem 3.5rem; }
    .soflo-gig-guide__copy { padding: 1.75rem 1.25rem; }
    .soflo-gig-guide__title { font-size: clamp(1.75rem, 8vw, 2.5rem); }
    .soflo-gig-guide__desc { max-width: 100%; }
    .soflo-gig-guide__form { flex-direction: column; max-width: 100%; }
    .soflo-gig-guide__submit { width: 100%; padding: 1rem; }
    .soflo-gig-guide__input { width: 100%; }


} /* close @media (max-width: 640px) from base CSS */

/* ══════════════════════════════════════════════════════════════════════════════
   DISCOVER PAGE
   ══════════════════════════════════════════════════════════════════════════════ */

/* ── Discover Header ─────────────────────────────────────────────────────────── */
.soflo-discover-header {
    background: linear-gradient(160deg, var(--navy-950) 0%, var(--navy-800) 100%);
    margin-top: -5.375rem;
    padding: calc(5.375rem + 3.25rem) 2rem 3.5rem;
    position: relative; overflow: hidden;
}
.soflo-discover-header::after {
    content: ''; position: absolute;
    bottom: -1px; left: 0; right: 0; height: 1px;
    background: rgba(255,255,255,.08);
}
.soflo-discover-header__inner { max-width: 80rem; margin: 0 auto; }
.soflo-discover-header__kicker {
    display: flex; align-items: center; gap: 0.5rem; margin-bottom: 1rem;
}
.soflo-discover-header__dot {
    width: 0.4375rem; height: 0.4375rem; border-radius: 50%;
    background: var(--aqua); box-shadow: 0 0 0.625rem var(--aqua);
    animation: soflo-pulse 2s infinite; flex-shrink: 0;
}
.soflo-discover-header__eyebrow { font-size: 0.6875rem; color: rgba(255,255,255,.55); letter-spacing: .14em; }
.soflo-discover-header__h1 {
    font-size: clamp(2.75rem, 5.5vw, 4.5rem); color: white;
    margin: 0 0 0.75rem; line-height: 0.95;
}
.soflo-discover-header__em { font-style: italic; font-weight: 500; color: var(--aqua); }
.soflo-discover-header__sub { font-size: 1rem; color: rgba(255,255,255,.75); margin: 0; }
.soflo-discover-header__count { font-weight: 700; color: var(--sky); }

/* ── Pill Filter Bar ─────────────────────────────────────────────────────────── */
.soflo-filterbar {
    background: white;
    border-bottom: 1px solid var(--line);
    position: sticky; top: 5.3rem; z-index: 40;
    box-shadow: 0 0.25rem 1.25rem rgba(11,31,107,.07);
}
.soflo-filterbar__inner {
    max-width: 80rem; margin: 0 auto;
    padding: 0.625rem 2rem;
    display: flex; align-items: center; gap: 0.75rem;
}
.soflo-filterbar__label {
    font-size: 0.625rem; letter-spacing: .16em; color: var(--ink-3);
    flex-shrink: 0; white-space: nowrap;
}
.soflo-filterbar__pills-row {
    display: flex; align-items: center; flex-wrap: wrap; gap: 0.375rem; flex: 1;
}
.soflo-filterbar__dd { position: relative; }
.soflo-filterbar__dd .soflo-searchbar__btn {
    display: inline-flex; align-items: center; gap: 0.3125rem;
    padding: 0.4375rem 0.75rem;
    background: white; color: var(--ink);
    border: 1.5px solid var(--line); border-radius: 999px;
    font-size: 0.8125rem; font-weight: 600; white-space: nowrap;
    min-height: unset;
    transition: border-color .15s, background .15s, color .15s;
}
.soflo-filterbar__dd .soflo-searchbar__btn:hover,
.soflo-filterbar__dd.is-open .soflo-searchbar__btn {
    border-color: var(--blue-300); background: var(--blue-50); color: var(--blue-500);
}
.soflo-filterbar__dd .soflo-searchbar__icon { color: var(--ink-3); flex-shrink: 0; }
.soflo-filterbar__dd .soflo-searchbar__chev { color: var(--ink-3); flex-shrink: 0; }
.soflo-filterbar__dd .soflo-searchbar__dropdown-list { min-width: 13rem; top: calc(100% + 0.375rem); }
.soflo-filterbar__divider {
    width: 1px; height: 1.125rem; background: var(--line); flex-shrink: 0; margin: 0 0.125rem;
}
.soflo-filterbar__toggle {
    display: inline-flex; align-items: center;
    padding: 0.4375rem 0.75rem;
    background: transparent; color: var(--ink-2);
    border: 1.5px solid var(--line); border-radius: 999px;
    font-size: 0.625rem; letter-spacing: .1em; white-space: nowrap;
    transition: border-color .15s, background .15s, color .15s;
}
.soflo-filterbar__toggle:hover { border-color: var(--blue-300); color: var(--blue-500); }
.soflo-filterbar__toggle.is-active {
    background: var(--blue-500); color: white; border-color: var(--blue-500);
}
.soflo-filterbar__right {
    display: flex; align-items: center; gap: 0.75rem;
    flex-shrink: 0; margin-left: auto; padding-left: 0.875rem;
    border-left: 1px solid var(--line);
}
.soflo-filterbar__count { font-size: 0.625rem; letter-spacing: .12em; color: var(--ink-3); white-space: nowrap; }
.soflo-filterbar__view-btns {
    display: flex; gap: 0.125rem;
    background: var(--paper-2); border-radius: 0.5rem; padding: 0.1875rem;
}
.soflo-filterbar__view-btn {
    width: 2rem; height: 2rem;
    display: flex; align-items: center; justify-content: center;
    background: transparent; border: none; border-radius: 0.3125rem;
    color: var(--ink-3); transition: background .15s, color .15s;
}
.soflo-filterbar__view-btn:hover { background: white; color: var(--ink); }
.soflo-filterbar__view-btn.is-active {
    background: white; color: var(--blue-500);
    box-shadow: 0 1px 4px rgba(0,0,0,.1);
}

/* ── Starting Soon Band ──────────────────────────────────────────────────────── */
.soflo-soon-band {
    background: var(--paper-2);
    padding: 3rem 2rem 0.5rem;
}
.soflo-soon-band__inner {
    max-width: 80rem; margin: 0 auto;
    background: var(--navy-950);
    border-radius: 1.25rem;
    padding: 1.125rem 1.75rem;
    display: flex; align-items: center; gap: 2rem;
    overflow: hidden;
}
.soflo-soon-band__heading {
    display: flex; align-items: center; gap: 0.625rem; flex-shrink: 0;
}
.soflo-soon-band__dot {
    width: 0.5rem; height: 0.5rem; border-radius: 50%;
    background: var(--aqua); box-shadow: 0 0 0.625rem var(--aqua);
    animation: soflo-pulse 1.8s infinite; flex-shrink: 0;
}
.soflo-soon-band__label { font-size: 0.625rem; color: rgba(255,255,255,.55); letter-spacing: .16em; }
.soflo-soon-band__track {
    display: flex; gap: 0.875rem;
    overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none;
    flex: 1;
}
.soflo-soon-band__track::-webkit-scrollbar { display: none; }
.soflo-soon-card {
    display: flex; align-items: center; gap: 0.875rem; flex-shrink: 0;
    background: rgba(255,255,255,.08); border-radius: 0.875rem;
    padding: 0.625rem 1rem 0.625rem 0.625rem;
    border: 1px solid rgba(255,255,255,.1);
    cursor: pointer; transition: background .15s;
}
.soflo-soon-card:hover { background: rgba(255,255,255,.13); }
.soflo-soon-card__img-wrap {
    width: 3rem; height: 3rem; border-radius: 0.5rem;
    overflow: hidden; flex-shrink: 0;
}
.soflo-soon-card__img { width: 100%; height: 100%; object-fit: cover; }
.soflo-soon-card__info { display: flex; flex-direction: column; gap: 0.1875rem; }
.soflo-soon-card__name { font-size: 0.9375rem; font-weight: 600; color: white; white-space: nowrap; }
.soflo-soon-card__venue { font-size: 0.625rem; color: rgba(255,255,255,.45); letter-spacing: .06em; white-space: nowrap; }
.soflo-soon-card__pill {
    display: inline-block; padding: 0.25rem 0.6875rem;
    background: rgba(255,255,255,.1); color: rgba(255,255,255,.8);
    border-radius: 999px; font-size: 0.625rem; letter-spacing: .08em;
    white-space: nowrap; flex-shrink: 0; margin-left: 0.5rem;
}
.soflo-soon-card__pill.is-soon { background: rgba(239,68,68,.3); color: #fca5a5; }
.soflo-soon-card__pill.is-live { background: rgba(16,185,129,.3); color: #6ee7b7; }

/* ── Discover Feed ───────────────────────────────────────────────────────────── */
.soflo-discover { background: var(--paper-2); padding-top: 0.7rem; padding-bottom: 5rem; }
.soflo-discover__inner { max-width: 80rem; margin: 0 auto; padding: 0 2rem 0; }
.soflo-discover__meta {
    min-height: 1.5rem;
    display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
    margin-bottom: 1.25rem;
}
.soflo-discover__active-chips { display: flex; gap: 0.4375rem; flex-wrap: wrap; }
.soflo-discover__chip {
    display: inline-flex; align-items: center; gap: 0.375rem;
    padding: 0.25rem 0.6875rem;
    background: var(--blue-50); color: var(--blue-500);
    border: 1px solid var(--blue-300); border-radius: 999px;
    font-size: 0.75rem; font-weight: 600;
}
.soflo-discover__chip-remove {
    background: transparent; border: none; padding: 0; margin-left: 0.125rem;
    color: var(--blue-400); font-size: 1rem; line-height: 1;
    display: flex; align-items: center; cursor: pointer;
}
.soflo-discover__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}

/* ── Genre Color Chips ───────────────────────────────────────────────────────── */
.soflo-gig-card__genre-chip {
    position: absolute; top: 0.625rem; left: 0.625rem;
    padding: 0.25rem 0.625rem; border-radius: 999px;
    font-size: 0.5rem; letter-spacing: .1em; font-weight: 700;
    color: white; backdrop-filter: blur(4px);
    white-space: nowrap; max-width: calc(100% - 3.5rem);
    overflow: hidden; text-overflow: ellipsis;
}
.genre-latin      { background: linear-gradient(135deg, #f97316, #ef4444); }
.genre-reggae     { background: linear-gradient(135deg, #10b981, #059669); }
.genre-hiphop     { background: linear-gradient(135deg, #8b5cf6, #7c3aed); }
.genre-jazz       { background: linear-gradient(135deg, #3b6cf2, #1e40af); }
.genre-indie      { background: linear-gradient(135deg, #f59e0b, #d97706); }
.genre-funk       { background: linear-gradient(135deg, #f97316, #ea580c); }
.genre-electronic { background: linear-gradient(135deg, #06b6d4, #0891b2); }
.genre-karaoke    { background: linear-gradient(135deg, #ec4899, #db2777); }
.genre-acoustic   { background: linear-gradient(135deg, #a16207, #78350f); }
.genre-default    { background: rgba(11,31,107,.78); }

/* ── Gig Card ────────────────────────────────────────────────────────────────── */
.soflo-gig-card {
    display: flex; flex-direction: column;
    background: white;
    border: 1px solid var(--line);
    border-radius: 1.125rem;
    transition: transform .22s ease, box-shadow .22s ease;
    will-change: transform;
    color: inherit;
    cursor: pointer;
}
.soflo-gig-card:hover {
    transform: translateY(-0.3125rem);
    box-shadow: 0 1.5rem 3rem -0.75rem rgba(11,31,107,.2);
}
.soflo-gig-card__img-wrap {
    position: relative; aspect-ratio: 4/2.8;
    overflow: hidden; background: var(--paper-2);
    flex-shrink: 0; border-radius: 1.125rem 1.125rem 0 0;
}
.soflo-gig-card__img { width: 100%; height: 100%; object-fit: cover; }

/* save button */
.soflo-gig-card__save {
    position: absolute; top: 0.625rem; right: 0.625rem;
    width: 2.125rem; height: 2.125rem; border-radius: 50%;
    background: rgba(11,31,107,.55); backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.25);
    display: flex; align-items: center; justify-content: center;
    color: white; transition: background .15s, transform .15s;
}
.soflo-gig-card__save:hover  { background: var(--blue-500); transform: scale(1.1); }
.soflo-gig-card__save.is-saved { background: var(--blue-500); }
.soflo-gig-card__save.is-saved svg { fill: white; }

/* countdown badge */
.soflo-gig-card__status {
    position: absolute; bottom: 0.625rem; right: 0.625rem;
    background: rgba(11,31,107,.85); backdrop-filter: blur(8px);
    color: white; padding: 0.3125rem 0.625rem; border-radius: 999px;
    font-size: 0.5rem; font-weight: 700; letter-spacing: .08em;
    display: flex; align-items: center; gap: 0.3125rem; white-space: nowrap;
}
.soflo-gig-card__status.is-soon {
    background: rgba(239,68,68,.9);
    animation: soflo-pulse 1.8s infinite;
}
.soflo-gig-card__status.is-live {
    background: rgba(16,185,129,.9);
    animation: soflo-pulse 1.5s infinite;
}
.soflo-gig-card__status-dot {
    width: 0.375rem; height: 0.375rem; border-radius: 50%;
    background: white; flex-shrink: 0;
}

/* card body */
.soflo-gig-card__body {
    padding: 0.875rem 1rem 1rem;
    display: flex; flex-direction: column; flex: 1;
}
.soflo-gig-card__name {
    font-size: 1.25rem; margin: 0 0 0.375rem;
    letter-spacing: -.015em; line-height: 1.05;
}
.soflo-gig-card__venue {
    display: flex; align-items: center; gap: 0.3125rem;
    color: var(--ink-2); font-size: 0.75rem; font-weight: 500;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    margin-bottom: 0.25rem;
}
.soflo-gig-card__time {
    display: flex; align-items: center; gap: 0.3125rem;
    font-size: 0.75rem; color: var(--ink-2); font-weight: 500;
    margin-bottom: 0.75rem;
}
.soflo-gig-card__about {
    font-size: 0.8125rem;
    color: var(--ink-2);
    line-height: 1.45;
    margin: 0 0 0.625rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.soflo-gig-card__pills {
    display: flex; flex-wrap: wrap; gap: 0.3125rem;
    padding-top: 0.625rem; border-top: 1px solid var(--line);
    margin-top: auto;
}
.soflo-gig-card__pill {
    display: inline-flex; align-items: center;
    padding: 0.3125rem 0.75rem;
    border: 1px solid var(--line); border-radius: 999px;
    font-size: 0.75rem; font-weight: 700; letter-spacing: .08em;
    color: var(--ink-2); background: transparent;
    font-family: 'JetBrains Mono', monospace; white-space: nowrap;
}
.soflo-gig-card__pill.is-free    { background: var(--blue-500, #3b6cf2); color: white; border-color: var(--blue-500, #3b6cf2); }
.soflo-gig-card__pill--age       { border-color: #bfdbfe; color: var(--blue-500); }
.soflo-gig-card__pill--parking   { border-color: var(--line); color: var(--ink-3); }

/* ── Map View ────────────────────────────────────────────────────────────────── */
.soflo-discover__map { width: 100%; }
.soflo-map-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 0.875rem;
}
.soflo-map-header__count { font-size: 0.625rem; color: var(--ink-3); letter-spacing: .12em; }
.soflo-map-header__back {
    display: inline-flex; align-items: center; gap: 0.3125rem;
    font-size: 0.8125rem; font-weight: 600; color: var(--blue-500);
    background: transparent; border: none; cursor: pointer;
    transition: gap .15s;
}
.soflo-map-header__back:hover { gap: 0.5rem; }
.soflo-map-container {
    width: 100%; height: 72vh; min-height: 480px;
    border-radius: 1.125rem; overflow: hidden;
    border: 1px solid var(--line);
}

/* Keep all map panes below sticky nav (z-index 50) */
.soflo-map-container .leaflet-pane,
.soflo-map-container .leaflet-top,
.soflo-map-container .leaflet-bottom    { z-index: 10 !important; }
.soflo-map-container .leaflet-tile-pane    { z-index: 10 !important; }
.soflo-map-container .leaflet-overlay-pane { z-index: 11 !important; }
.soflo-map-container .leaflet-shadow-pane  { z-index: 12 !important; }
.soflo-map-container .leaflet-marker-pane  { z-index: 13 !important; }
.soflo-map-container .leaflet-tooltip-pane { z-index: 14 !important; }
.soflo-map-container .leaflet-popup-pane   { z-index: 15 !important; }

/* Leaflet popup overrides */
.leaflet-popup-content-wrapper {
    border-radius: 0.875rem !important;
    box-shadow: 0 0.5rem 2rem rgba(11,31,107,.2) !important;
    padding: 0 !important;
}
.leaflet-popup-content { margin: 0 !important; }
.soflo-map-popup { padding: 0.75rem 1rem 0.875rem; min-width: 180px; }
.soflo-map-popup__genre {
    display: inline-block; padding: 0.1875rem 0.5rem; border-radius: 999px;
    font-size: 0.5rem; font-weight: 700; letter-spacing: .1em;
    color: white; font-family: 'JetBrains Mono', monospace;
    margin-bottom: 0.5rem;
}
.soflo-map-popup__name  { font-size: 0.9375rem; font-weight: 700; color: #0b1f6b; margin-bottom: 0.1875rem; font-family: 'Bricolage Grotesque', sans-serif; }
.soflo-map-popup__venue { font-size: 0.75rem; color: #6b7280; margin-bottom: 0.25rem; }
.soflo-map-popup__meta  { font-size: 0.75rem; color: #374151; font-weight: 500; }

/* ── No Results ──────────────────────────────────────────────────────────────── */
.soflo-no-results {
    text-align: center; padding: 4rem 2rem;
    background: white; border-radius: 1.125rem;
    border: 1.5px dashed var(--line);
}
.soflo-no-results__label { font-size: 0.625rem; letter-spacing: .16em; color: var(--ink-3); margin-bottom: 0.875rem; }
.soflo-no-results__title { font-size: clamp(1.375rem, 2.5vw, 1.875rem); margin: 0 0 0.625rem; }
.soflo-no-results__desc  { font-size: 0.9375rem; color: var(--ink-2); margin-bottom: 1.5rem; }
.soflo-no-results__reset {
    padding: 0.75rem 1.75rem;
    background: var(--blue-500); color: white;
    border: none; border-radius: 999px;
    font-size: 0.875rem; font-weight: 600;
    transition: background .15s; cursor: pointer;
}
.soflo-no-results__reset:hover { background: var(--navy-700); }

/* ── Load More ───────────────────────────────────────────────────────────────── */
.soflo-discover__more {
    margin-top: 2.5rem;
    display: flex; flex-direction: column; align-items: center; gap: 0.75rem;
}
.soflo-discover__load-more {
    padding: 0.875rem 2.75rem;
    background: white; color: var(--ink);
    border: 1.5px solid var(--line); border-radius: 999px;
    font-size: 0.875rem; font-weight: 600;
    transition: border-color .15s, box-shadow .15s;
}
.soflo-discover__load-more:hover {
    border-color: var(--blue-300);
    box-shadow: 0 0.25rem 1rem rgba(59,108,242,.15);
}
.soflo-discover__more-meta { font-size: 0.6875rem; color: var(--ink-3); letter-spacing: .1em; }

/* ── Save Toast ──────────────────────────────────────────────────────────────── */
.soflo-save-toast {
    position: fixed; bottom: 1.75rem; left: 50%;
    transform: translateX(-50%) translateY(0.75rem);
    background: var(--navy-950); color: white;
    padding: 0.875rem 1.625rem; border-radius: 999px;
    font-size: 0.875rem; font-weight: 500;
    box-shadow: 0 0.5rem 2rem rgba(0,0,0,.28);
    pointer-events: none; opacity: 0;
    transition: opacity .25s ease, transform .25s ease;
    z-index: 9999; white-space: nowrap;
    display: flex; align-items: center; gap: 0.625rem;
}
.soflo-save-toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }
.soflo-save-toast__action {
    pointer-events: all; cursor: pointer;
    color: var(--sky); font-weight: 700; font-size: 0.8125rem;
    background: transparent; border: none; padding: 0;
}

/* ── Map popup link ──────────────────────────────────────────────────────────── */
.soflo-map-popup__actions {
    display: flex; flex-direction: column; gap: 0.375rem;
    margin-top: 0.5rem; padding-top: 0.4375rem;
    border-top: 1px solid #f3f4f6;
}
.soflo-map-popup__link {
    font-size: 0.8125rem; font-weight: 700; color: var(--blue-500, #3b6cf2);
    text-decoration: none; display: inline-block; margin-top: 0.25rem;
}
.soflo-map-popup__link:hover { text-decoration: underline; }
.soflo-map-popup__link--dir { }

/* ── Weekend Gig Guide – top padding ────────────────────────────────────────── */
.soflo-gig-guide { padding-top: 5rem; }

/* ══════════════════════════════════════════════════════════════════════════════
   GIG DETAIL PAGE
   ══════════════════════════════════════════════════════════════════════════════ */

.soflo-gig-detail { background: var(--paper-2); }
.soflo-gig-detail-empty {
    max-width: 40rem; margin: 6rem auto; padding: 0 2rem;
    font-size: 1rem; color: var(--ink-2);
}
.soflo-gig-detail-empty a { color: var(--blue-500); }

/* ── Hero ────────────────────────────────────────────────────────────────────── */
.soflo-gig-detail__hero {
    position: relative;
    background-size: cover; background-position: center 30%;
    margin-top: -5.375rem;
    min-height: 22rem;
}
.soflo-gig-detail__hero-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to bottom,
        rgba(5,10,40,.65) 0%,
        rgba(5,10,40,.18) 35%,
        rgba(5,10,40,.72) 68%,
        rgba(5,10,40,.95) 100%
    );
}
.soflo-gig-detail__hero-inner {
    position: relative; z-index: 1;
    max-width: 80rem; margin: 0 auto;
    padding: calc(5.375rem + 1.25rem) 2rem 2.5rem;
    min-height: 22rem;
    display: flex; flex-direction: column; justify-content: space-between;
}
.soflo-gig-detail__back {
    align-self: flex-start;
    display: inline-flex; align-items: center; gap: 0.3125rem;
    color: rgba(255,255,255,.65); font-size: 0.625rem; letter-spacing: .14em;
    text-decoration: none; transition: color .15s;
}
.soflo-gig-detail__back:hover { color: white; }
.soflo-gig-detail__hero-content {
    display: flex; flex-direction: column; gap: 0.625rem;
}
.soflo-gig-detail__genre-chip {
    align-self: flex-start;
    padding: 0.3125rem 0.875rem; border-radius: 999px;
    font-size: 0.5625rem; letter-spacing: .1em; font-weight: 700; color: white;
}
.soflo-gig-detail__artist {
    font-size: clamp(2.25rem, 5.5vw, 4.25rem); color: white;
    margin: 0; line-height: 0.93; letter-spacing: -.025em;
}
.soflo-gig-detail__hero-meta {
    display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap;
    color: rgba(255,255,255,.78); font-size: 0.9375rem;
}
.soflo-gig-detail__hero-meta svg { flex-shrink: 0; opacity: .7; }
.soflo-gig-detail__hero-sep { color: rgba(255,255,255,.35); }

/* ── Body ────────────────────────────────────────────────────────────────────── */
.soflo-gig-detail__body-wrap {
    background: white; border-bottom: 1px solid var(--line);
}
.soflo-gig-detail__body {
    max-width: 80rem; margin: 0 auto;
    padding: 2.75rem 2.75rem 3rem;
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 3.5rem; align-items: start;
}
.soflo-gig-detail__about {
    font-size: 1.0625rem; line-height: 1.7; color: var(--ink-2);
    margin: 0 0 2.25rem;
}
.soflo-gig-detail__info-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 1.625rem 2.5rem; margin-bottom: 2.25rem;
}
.soflo-gig-detail__info-item {
    display: flex; flex-direction: column; gap: 0.3125rem;
}
.soflo-gig-detail__info-label {
    font-size: 0.6875rem; letter-spacing: .1em; color: var(--ink-3);
}
.soflo-gig-detail__info-val {
    font-size: 1.0625rem; font-weight: 700; color: var(--ink); line-height: 1.2;
}
.soflo-gig-detail__info-val.is-free { color: var(--blue-500, #3b6cf2); font-weight: 700; }
.soflo-gig-detail__info-sub {
    font-size: 0.75rem; color: var(--ink-3); margin-top: 0.0625rem;
}
.soflo-gig-detail__ticket-btn {
    display: inline-flex; align-items: center; gap: 0.5rem;
    padding: 0.9375rem 2.5rem;
    background: var(--blue-500); color: white;
    border: none; border-radius: 999px; font-size: 0.9375rem; font-weight: 700;
    text-decoration: none; cursor: pointer;
    transition: background .15s, transform .15s;
}
.soflo-gig-detail__ticket-btn:hover {
    background: var(--navy-700); transform: translateY(-2px);
}
.soflo-gig-detail__no-ticket {
    font-size: 0.625rem; letter-spacing: .12em; color: var(--ink-3); padding: 0.875rem 0;
}
.soflo-gig-detail__map-col { position: relative; }
.soflo-gig-detail__map-address {
    display: flex; align-items: flex-start; gap: 0.5rem; margin-bottom: 0.875rem;
}
.soflo-gig-detail__map-address svg { margin-top: 0.125rem; flex-shrink: 0; color: var(--blue-500); }
.soflo-gig-detail__map-venue-name { font-size: 0.875rem; font-weight: 700; color: var(--ink); }
.soflo-gig-detail__map-venue-addr { font-size: 0.75rem; color: var(--ink-3); margin-top: 0.125rem; }
.soflo-gig-detail__map {
    width: 100%; height: 20rem;
    border-radius: 1.125rem; overflow: hidden;
    border: 1px solid var(--line); background: var(--paper-2);
}
.soflo-gig-detail__directions-btn {
    display: flex; align-items: center; justify-content: center; gap: 0.4375rem;
    margin-top: 0.75rem; padding: 0.8125rem 1.5rem;
    background: var(--blue-500); color: white;
    border: none; border-radius: 0.875rem; font-size: 0.875rem; font-weight: 600;
    text-decoration: none; width: 100%; cursor: pointer;
    transition: background .15s, transform .15s;
}
.soflo-gig-detail__directions-btn:hover { background: var(--navy-700); transform: translateY(-1px); }

/* ── Related gigs ────────────────────────────────────────────────────────────── */
.soflo-gig-detail__related { background: var(--paper-2); padding: 3.5rem 0 5rem; }
.soflo-gig-detail__related-inner {
    max-width: 80rem; margin: 0 auto; padding: 0 2rem;
}
.soflo-gig-detail__related-h2 {
    font-size: clamp(1.5rem, 2.5vw, 2.25rem);
    margin: 0 0 1.875rem; letter-spacing: -.02em;
}
.soflo-gig-detail__related-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem;
}

/* ── Gig detail responsive ───────────────────────────────────────────────────── */
@media (max-width: 860px) {
    .soflo-gig-detail__body { grid-template-columns: 1fr; gap: 2rem; }
    .soflo-gig-detail__map  { height: 18rem; }
    .soflo-gig-detail__related-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
    .soflo-gig-detail__hero-inner { padding: calc(5.375rem + 1rem) 1.25rem 2rem; min-height: 20rem; }
    .soflo-gig-detail__body { padding: 1.75rem 1.25rem 2.25rem; }
    .soflo-gig-detail__related-inner { padding: 0 1.25rem; }
    .soflo-gig-detail__related-grid { grid-template-columns: 1fr; }
}

/* ── Gig detail: hero chips + share ─────────────────────────────────────────── */
.soflo-gig-detail__hero-chips {
    display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem;
    margin-bottom: 0.25rem;
}
.soflo-gig-detail__hero-badge {
    padding: 0.3rem 0.75rem; border-radius: 999px;
    background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.3);
    color: white; font-size: 0.5625rem; letter-spacing: .1em; font-weight: 700;
}
.soflo-gig-detail__hero-badge--recurring { background: rgba(251,191,36,.25); border-color: rgba(251,191,36,.5); }
.soflo-gig-detail__hero-share {
    display: inline-flex; align-items: center; gap: 0.4rem;
    margin-top: 1rem; padding: 0.5rem 1.125rem;
    background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.25);
    border-radius: 999px; color: rgba(255,255,255,.85);
    font-size: 0.625rem; letter-spacing: .1em;
    transition: background .15s, color .15s; cursor: pointer;
}
.soflo-gig-detail__hero-share:hover { background: rgba(255,255,255,.22); color: white; }

/* ── Artist strip ────────────────────────────────────────────────────────────── */
.soflo-gig-detail__artist-strip {
    background: var(--navy-950); border-bottom: 1px solid rgba(255,255,255,.07);
}
.soflo-gig-detail__artist-strip-inner {
    max-width: 80rem; margin: 0 auto; padding: 2.25rem 2.75rem;
    display: flex; align-items: center; gap: 1.75rem; flex-wrap: wrap;
}
.soflo-gig-detail__artist-avatar {
    width: 6rem; height: 6rem; border-radius: 50%;
    object-fit: cover; flex-shrink: 0;
    border: 3px solid rgba(255,255,255,.12);
}
.soflo-gig-detail__artist-info { flex: 1; min-width: 0; }
.soflo-gig-detail__artist-eyebrow {
    display: block; font-size: 0.5rem; letter-spacing: .16em;
    color: var(--blue-400); margin-bottom: 0.25rem;
}
.soflo-gig-detail__artist-name {
    font-size: clamp(1.25rem, 2.5vw, 2rem); color: white;
    margin: 0 0 0.25rem; line-height: 1;
}
.soflo-gig-detail__artist-genre {
    display: inline-block; font-size: 0.5625rem; letter-spacing: .1em;
    color: var(--ink-3); margin-bottom: 0.5rem;
}
.soflo-gig-detail__artist-bio {
    font-size: 0.875rem; line-height: 1.6; color: rgba(255,255,255,.6);
    margin: 0.375rem 0 0.75rem; max-width: 38rem;
}
.soflo-gig-detail__artist-socials {
    display: flex; flex-wrap: wrap; gap: 0.625rem;
}
.soflo-gig-detail__artist-social {
    display: inline-flex; align-items: center; gap: 0.35rem;
    padding: 0.375rem 0.875rem; border-radius: 999px;
    border: 1px solid rgba(255,255,255,.18); color: rgba(255,255,255,.75);
    font-size: 0.5625rem; letter-spacing: .1em;
    transition: border-color .15s, color .15s;
}
.soflo-gig-detail__artist-social:hover { border-color: rgba(255,255,255,.5); color: white; }
.soflo-gig-detail__artist-profile-btn {
    align-self: flex-start; flex-shrink: 0;
    display: inline-flex; align-items: center; gap: 0.4rem;
    padding: 0.625rem 1.25rem; border-radius: 999px;
    border: 1px solid rgba(255,255,255,.25); color: white;
    font-size: 0.5625rem; letter-spacing: .12em;
    transition: background .15s, border-color .15s;
    white-space: nowrap;
}
.soflo-gig-detail__artist-profile-btn:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.4); }

/* ── Action row ──────────────────────────────────────────────────────────────── */
.soflo-gig-detail__actions {
    display: flex; flex-wrap: wrap; gap: 0.625rem; margin-bottom: 1.5rem;
}
.soflo-gig-detail__action-btn {
    display: inline-flex; align-items: center; gap: 0.4rem;
    padding: 0.625rem 1.125rem; border-radius: 999px;
    border: 1.5px solid var(--blue-500); background: white; color: var(--blue-500);
    font-size: 0.75rem; letter-spacing: .06em; text-decoration: none;
    transition: border-color .15s, color .15s, background .15s; cursor: pointer;
}
.soflo-gig-detail__action-btn:hover { background: var(--blue-500); color: white; }

/* ── Media (YouTube) ─────────────────────────────────────────────────────────── */
.soflo-gig-detail__media { margin-top: 2rem; }
.soflo-gig-detail__media-label {
    display: block; font-size: 0.5rem; letter-spacing: .16em;
    color: var(--ink-3); margin-bottom: 0.625rem;
}
.soflo-gig-detail__media-wrap {
    position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden;
    border-radius: 0.875rem;
}
.soflo-gig-detail__media-frame {
    position: absolute; inset: 0; width: 100%; height: 100%;
    border-radius: 0.875rem;
}


/* ── Gig page identity badge (hero) ─────────────────────────────────────────── */
.soflo-gig-detail__type-badge {
    display: inline-flex; align-items: center; gap: 0.5rem;
    background: rgba(239,68,68,.92); color: white;
    border-radius: 999px; padding: 0.4375rem 1.125rem;
    font-size: 0.75rem; letter-spacing: .16em; font-weight: 700;
    margin-bottom: 1.125rem; position: relative; overflow: visible;
}
.soflo-gig-detail__type-badge::before {
    content: '';
    display: inline-block; width: 7px; height: 7px; border-radius: 50%;
    background: white; flex-shrink: 0;
    animation: soflo-live-pulse 1.6s ease-in-out infinite;
}
@keyframes soflo-live-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: 0.35; transform: scale(0.8); }
}

/* ── WHERE card venue photo ──────────────────────────────────────────────────── */
.soflo-gig-detail__where-header {
    display: flex; align-items: baseline; justify-content: space-between;
    padding: 0.875rem 1.125rem 0.5rem; gap: 0.5rem;
}
.soflo-gig-detail__where-venue-name-small {
    font-size: 0.75rem; letter-spacing: .04em; color: var(--ink-2);
    font-weight: 700; text-align: right; flex-shrink: 0;
}
.soflo-gig-detail__where-venue-img-wrap {
    position: relative; height: 8.5rem; overflow: hidden;
    border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.soflo-gig-detail__where-venue-img {
    width: 100%; height: 100%; object-fit: cover;
}
.soflo-gig-detail__where-venue-img-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to bottom, transparent 50%, rgba(11,31,107,.35));
}
.soflo-gig-detail__where-venue-btn {
    display: flex; align-items: center; justify-content: center; gap: 0.4rem;
    width: 100%; padding: 0.6875rem 1rem;
    background: var(--blue-500); border: 1.5px solid var(--blue-500); border-radius: 0.875rem;
    color: white; text-decoration: none;
    font-size: 0.75rem; letter-spacing: .06em; font-weight: 700;
    transition: background .15s, opacity .15s;
}
.soflo-gig-detail__where-venue-btn:hover { opacity: .88; }
.soflo-gig-detail__where-directions-link {
    display: flex; align-items: center; justify-content: center; gap: 0.3rem;
    font-size: 0.6875rem; letter-spacing: .06em; font-weight: 600;
    color: var(--ink-3); text-decoration: none; padding: 0.375rem 0;
    transition: color .15s;
}
.soflo-gig-detail__where-directions-link:hover { color: var(--ink); }

/* ── WHERE card (map + venue info integrated) ───────────────────────────────── */
.soflo-gig-detail__where-card {
    border: 1px solid var(--line); border-radius: 1.125rem;
    overflow: hidden; background: white;
}
.soflo-gig-detail__where-label {
    display: block; font-size: 0.5625rem; letter-spacing: .16em; color: var(--ink-3);
}
.soflo-gig-detail__where-map {
    width: 100%; height: 13rem;
    background: var(--paper-2);
    border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.soflo-gig-detail__where-body {
    padding: 1.125rem;
}
.soflo-gig-detail__where-name {
    font-size: 1.375rem; color: var(--ink); line-height: 1.1; margin-bottom: 0.375rem;
}
.soflo-gig-detail__where-addr {
    font-size: 0.75rem; letter-spacing: .04em; color: var(--ink-3); margin-bottom: 0.875rem;
    line-height: 1.4;
}
.soflo-gig-detail__where-tags {
    display: flex; gap: 0.375rem; flex-wrap: wrap; margin-bottom: 1rem;
}
.soflo-gig-detail__where-tag {
    font-size: 0.5625rem; letter-spacing: .1em; color: var(--ink-3);
    background: var(--paper-2); border: 1px solid var(--line);
    border-radius: 999px; padding: 0.25rem 0.625rem;
    display: inline-flex; align-items: center; gap: 0.25rem;
}
.soflo-gig-detail__where-actions {
    display: flex; flex-direction: column; gap: 0.625rem;
}
.soflo-gig-detail__where-actions .soflo-gig-detail__directions-btn { margin-top: 0; }
.soflo-gig-detail__where-venue-link {
    display: flex; align-items: center; justify-content: center; gap: 0.3rem;
    font-size: 0.6875rem; letter-spacing: .06em;
    color: var(--blue-500); text-decoration: none; padding: 0.375rem 0;
}
.soflo-gig-detail__where-venue-link:hover { text-decoration: underline; }

/* ── Reviews login CTA ───────────────────────────────────────────────────────── */
.soflo-dir-reviews__login-cta {
    display: flex; flex-direction: column; align-items: center;
    text-align: center; padding: 2rem 1.5rem;
    background: var(--paper-2); border-radius: 1rem;
    border: 1.5px dashed var(--line);
}
.soflo-dir-reviews__login-star {
    font-size: 2rem; color: #f59e0b; margin-bottom: 0.625rem; line-height: 1;
}
.soflo-dir-reviews__login-title {
    font-size: 1.125rem; font-weight: 700; color: var(--ink); margin-bottom: 0.5rem;
}
.soflo-dir-reviews__login-text {
    font-size: 0.875rem; color: var(--ink-3); line-height: 1.6;
    max-width: 28rem; margin: 0 0 1.25rem;
}
.soflo-dir-reviews__login-btn {
    display: inline-flex; align-items: center;
    background: var(--blue-500); color: white;
    padding: 0.6875rem 1.75rem; border-radius: 999px;
    font-size: 0.75rem; letter-spacing: .08em; font-weight: 700;
    text-decoration: none; transition: background .15s;
}
.soflo-dir-reviews__login-btn:hover { background: var(--navy-950); }

/* ── Venue preview card ──────────────────────────────────────────────────────── */
.soflo-gig-detail__venue-card {
    border: 1px solid var(--line); border-radius: 1.125rem;
    overflow: hidden; background: white; margin-bottom: 1.5rem;
}
.soflo-gig-detail__venue-card-img-wrap { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.soflo-gig-detail__venue-card-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.soflo-gig-detail__venue-card-age {
    position: absolute; top: 0.625rem; right: 0.625rem;
    padding: 0.25rem 0.625rem; border-radius: 999px;
    background: rgba(11,31,107,.7); color: white;
    font-size: 0.5rem; letter-spacing: .12em;
}
.soflo-gig-detail__venue-card-body { padding: 1rem 1.125rem 1.125rem; }
.soflo-gig-detail__venue-card-top {
    display: flex; align-items: flex-start; justify-content: space-between; gap: 0.75rem;
    margin-bottom: 0.5rem;
}
.soflo-gig-detail__venue-card-name { font-size: 1.0625rem; color: var(--ink); line-height: 1.1; }
.soflo-gig-detail__venue-card-hood {
    font-size: 0.5625rem; letter-spacing: .1em; color: var(--ink-3); margin-top: 0.2rem;
}
.soflo-gig-detail__venue-card-rating {
    display: flex; align-items: center; gap: 0.25rem; flex-shrink: 0;
    font-size: 0.875rem; font-weight: 700; color: var(--ink);
}
.soflo-gig-detail__venue-card-vibe {
    font-size: 0.8125rem; color: var(--ink-2); margin: 0 0 0.25rem;
}
.soflo-gig-detail__venue-card-cap {
    font-size: 0.5rem; letter-spacing: .12em; color: var(--ink-3);
    margin: 0 0 0.75rem;
}
.soflo-gig-detail__venue-card-link {
    display: inline-flex; align-items: center; gap: 0.3rem;
    font-size: 0.5625rem; letter-spacing: .1em; color: var(--blue-500);
    font-weight: 700;
}
.soflo-gig-detail__venue-card-link:hover { text-decoration: underline; }

/* ── More by artist / More at venue ─────────────────────────────────────────── */
.soflo-gig-detail__more {
    border-top: 1px solid var(--line);
}
.soflo-gig-detail__more-inner {
    max-width: 80rem; margin: 0 auto; padding: 2.5rem 2.75rem;
}
.soflo-gig-detail__more-h2 {
    font-size: 0.625rem; letter-spacing: .16em; color: var(--ink-3);
    margin: 0 0 1.5rem;
}

/* ── Responsive: new components ─────────────────────────────────────────────── */
@media (max-width: 860px) {
    .soflo-gig-detail__artist-strip-inner { padding: 1.75rem 1.25rem; gap: 1.25rem; }
    .soflo-gig-detail__artist-avatar { width: 4.5rem; height: 4.5rem; }
    .soflo-gig-detail__artist-profile-btn { display: none; }
    .soflo-gig-detail__more-inner { padding: 2rem 1.25rem; }
}
@media (max-width: 560px) {
    .soflo-gig-detail__artist-strip-inner { flex-direction: column; align-items: flex-start; gap: 1rem; }
    .soflo-gig-detail__actions { gap: 0.5rem; flex-direction: column; }
    .soflo-gig-detail__action-btn { padding: 0.625rem 1rem; width: 100%; justify-content: center; }
}

/* ── Responsive ──────────────────────────────────────────────────────────────── */
@media (max-width: 1100px) {
    .soflo-discover__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 820px) {
    .soflo-discover__grid { grid-template-columns: repeat(2, 1fr); }
    .soflo-filterbar { position: static; box-shadow: none; }
    .soflo-filterbar__inner { flex-wrap: wrap; padding: 0.5rem 1.25rem; gap: 0.5rem; }
    .soflo-filterbar__right { margin-left: 0; padding-left: 0; border-left: none; }
    .soflo-soon-band { padding: 3rem 1.25rem 0.5rem; }
}
@media (max-width: 640px) {
    .soflo-discover-header { padding: calc(5.375rem + 2rem) 1.25rem 2.5rem; }
    .soflo-discover__inner { padding: 1.25rem 1.25rem 0; }
    .soflo-discover__grid { grid-template-columns: 1fr; }
    .soflo-soon-band { padding: 2.5rem 1rem 0.5rem; }
}

/* ── Starting Soon endless marquee ──────────────────────────────────────────── */
/*
 * One strip holds originals + clones back-to-back.
 * padding-right equals the inter-card gap so the loop point is gapless.
 * translateX(-50%) = exactly one content-width, guaranteed seamless.
 */
.soflo-soon-band__track {
    overflow: hidden;
    gap: 0;
    flex-wrap: nowrap;
}
.soflo-soon-strip {
    display: flex; flex-shrink: 0; align-items: center;
    gap: 0.875rem;
    padding-right: 0.875rem; /* trailing gap: makes -50% == 1× content cycle */
    will-change: transform;
}
@keyframes soflo-soon-marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}
.soflo-soon-strip.is-playing {
    animation: soflo-soon-marquee linear infinite;
}
.soflo-soon-band__track:hover .soflo-soon-strip.is-playing { animation-play-state: paused; }
@media (prefers-reduced-motion: reduce) {
    .soflo-soon-strip.is-playing { animation: none; }
}

/* ── Nav: mobile menu from 320 to 1023px ────────────────────────────────────── */
/* Invisible menu must never block clicks when closed */
.soflo-mobile-menu          { pointer-events: none; }
.soflo-mobile-menu.is-open  { pointer-events: auto; }

@media (max-width: 1023px) {
    .soflo-nav__links  { display: none; }
    .soflo-nav__login  { display: none; }
    .soflo-nav__join   { display: none; }
    .soflo-nav__burger { display: flex; }
    .soflo-mobile-menu { display: flex; }
}
@media (min-width: 1024px) {
    .soflo-nav__burger { display: none !important; }
    .soflo-mobile-menu { display: none !important; }
    .soflo-nav__links  { display: flex; }
    .soflo-nav__login  { display: block; }
    .soflo-nav__join   { display: block; }
}

/* ── Filter bar: full-width stacked on mobile ──────────────────────────────── */
@media (max-width: 640px) {
    .soflo-filterbar__inner {
        flex-direction: column;
        align-items: stretch;
        padding: 0.75rem 1rem 0.875rem;
        gap: 0.4375rem;
    }
    .soflo-filterbar__pills-row {
        flex: unset; width: 100%;
        flex-direction: column; gap: 0.4375rem;
    }
    .soflo-filterbar__dd { width: 100%; }
    .soflo-filterbar__dd .soflo-searchbar__btn {
        width: 100%; justify-content: space-between; border-radius: 0.75rem;
    }
    .soflo-filterbar__dd .soflo-searchbar__dropdown-list { width: 100%; min-width: 0; left: 0; right: 0; }
    .soflo-filterbar__divider { display: none; }
    .soflo-filterbar__toggle {
        flex: none; width: 100%; justify-content: center;
        border-radius: 0.75rem; padding: 0.625rem 1rem;
    }
    .soflo-filterbar__right {
        flex: unset; width: 100%;
        margin-left: 0; padding-left: 0; border-left: none;
        border-top: 1px solid var(--line); padding-top: 0.5rem;
    }
    .soflo-filterbar__view-btn { width: 2.75rem; height: 2.75rem; }
    .soflo-filterbar__view-btns { margin-left: auto; }
}

/* ── Starting Soon: label above + horizontal scroll on mobile ──────────────── */
@media (max-width: 640px) {
    .soflo-soon-band__inner {
        flex-direction: column;
        align-items: center;
        gap: 0.75rem;
        padding: 0.875rem 1.25rem 0.875rem;
    }
    .soflo-soon-band__heading { padding: 0; width: 100%; }
    .soflo-soon-band__track {
        width: 100%;
        padding: 0 0 0.25rem;
        scroll-behavior: smooth;
    }
    .soflo-soon-card { min-width: 12.5rem; }
}

/* ── Newsletter / Gig Guide ──────────────────────────────────────────────── */
.soflo-newsletter {
    background: var(--navy, #0b1f6b);
    padding: 5rem 1.5rem;
    text-align: center;
}
.soflo-newsletter__inner {
    max-width: 42rem;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.25rem;
}
.soflo-newsletter__kicker {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: rgba(255,255,255,.5);
    font-size: 0.6875rem;
    letter-spacing: 0.1em;
}
.soflo-newsletter__dot {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: var(--blue, #3b6cf2);
    flex-shrink: 0;
    animation: soflo-pulse 2s ease-in-out infinite;
}
.soflo-newsletter__h2 {
    font-size: clamp(2rem, 5vw, 3.25rem);
    color: #fff;
    line-height: 1.1;
    margin: 0;
}
.soflo-newsletter__body {
    font-size: 1.0625rem;
    color: rgba(255,255,255,.7);
    margin: 0;
    max-width: 34rem;
}
.soflo-newsletter__form {
    display: flex;
    width: 100%;
    max-width: 28rem;
    gap: 0.625rem;
}
.soflo-newsletter__input {
    flex: 1;
    padding: 0.75rem 1rem;
    border-radius: 0.75rem;
    border: 1px solid rgba(255,255,255,.15);
    background: rgba(255,255,255,.07);
    color: #fff;
    font-size: 0.9375rem;
    outline: none;
    transition: border-color .15s;
}
.soflo-newsletter__input::placeholder { color: rgba(255,255,255,.3); }
.soflo-newsletter__input:focus        { border-color: var(--blue, #3b6cf2); }
.soflo-newsletter__btn {
    padding: 0.75rem 1.375rem;
    border-radius: 0.75rem;
    background: var(--blue, #3b6cf2);
    color: #fff;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    border: none;
    cursor: pointer;
    white-space: nowrap;
    transition: background .15s;
}
.soflo-newsletter__btn:hover { background: #2a5ae0; }
.soflo-newsletter__fine {
    font-size: 0.6875rem;
    color: rgba(255,255,255,.3);
    margin: 0;
    letter-spacing: 0.07em;
}
@media (max-width: 480px) {
    .soflo-newsletter          { padding: 3.5rem 1.25rem; }
    .soflo-newsletter__form    { flex-direction: column; }
    .soflo-newsletter__btn     { width: 100%; text-align: center; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   Page Fold — shared hero used by Venues, Artists, Karaoke, City Guide
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-page-fold {
    background: linear-gradient(160deg, var(--navy-950) 0%, var(--navy-800) 100%);
    margin-top: -5.375rem;
    padding: calc(5.375rem + 3.25rem) 2rem 3.5rem;
    position: relative;
    overflow: hidden;
}
.soflo-page-fold::after {
    content: '';
    position: absolute;
    bottom: -1px; left: 0; right: 0; height: 1px;
    background: rgba(255,255,255,.08);
}
.soflo-page-fold--karaoke {
    background: linear-gradient(160deg, #3b0764 0%, #7c3aed 100%);
}
.soflo-page-fold--cityguide {
    background: linear-gradient(160deg, #022c22 0%, #065f46 100%);
}
.soflo-page-fold__inner {
    max-width: 80rem;
    margin: 0 auto;
}
.soflo-page-fold__kicker {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
}
.soflo-page-fold__dot {
    width: 0.4375rem;
    height: 0.4375rem;
    border-radius: 50%;
    background: var(--aqua);
    box-shadow: 0 0 0.625rem var(--aqua);
    animation: soflo-pulse 2s infinite;
    flex-shrink: 0;
}
.soflo-page-fold--karaoke .soflo-page-fold__dot {
    background: #e879f9;
    box-shadow: 0 0 0.625rem #e879f9;
}
.soflo-page-fold--cityguide .soflo-page-fold__dot {
    background: var(--aqua);
    box-shadow: 0 0 0.625rem var(--aqua);
}
.soflo-page-fold__eyebrow {
    font-size: 0.6875rem;
    color: rgba(255,255,255,.55);
    letter-spacing: .14em;
}
.soflo-page-fold__h1 {
    font-size: clamp(2.75rem, 5.5vw, 4.5rem);
    color: white;
    margin: 0 0 0.75rem;
    line-height: 0.95;
}
.soflo-page-fold__em {
    font-style: italic;
    font-weight: 500;
    color: var(--aqua);
}
.soflo-page-fold--karaoke .soflo-page-fold__em { color: #e879f9; }
.soflo-page-fold--cityguide .soflo-page-fold__em { color: var(--teal); }
.soflo-page-fold__desc {
    font-size: 1rem;
    color: rgba(255,255,255,.75);
    margin: 0;
    max-width: 42rem;
}

/* ══════════════════════════════════════════════════════════════════════════════
   Directory Section — shared wrapper for all page grids
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-dir-section { padding-bottom: 5rem; }
.soflo-dir-section__inner {
    max-width: 80rem;
    margin: 0 auto;
    padding: 2.5rem 2rem 0;
}
.soflo-dir-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}
.soflo-dir-grid--artists {
    grid-template-columns: repeat(4, 1fr);
}

/* ══════════════════════════════════════════════════════════════════════════════
   Venue Card
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-venue-card {
    background: white;
    border-radius: 1rem;
    overflow: hidden;
    border: 1px solid var(--line);
    transition: box-shadow .2s, transform .2s;
    display: flex;
    flex-direction: column;
    cursor: pointer;
}
.soflo-venue-card:hover {
    box-shadow: 0 0.5rem 2rem rgba(11,31,107,.1);
    transform: translateY(-2px);
}
.soflo-venue-card__img-wrap {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
}
.soflo-venue-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .35s ease;
}
.soflo-venue-card:hover .soflo-venue-card__img {
    transform: scale(1.04);
}
.soflo-venue-card__genre-chip {
    position: absolute;
    top: 0.625rem;
    left: 0.625rem;
    padding: 0.25rem 0.6875rem;
    border-radius: 999px;
    font-size: 0.5625rem;
    letter-spacing: .1em;
    color: white;
    font-weight: 600;
    text-transform: uppercase;
}
.soflo-venue-card__live-badge {
    position: absolute;
    top: 0.625rem;
    right: 0.625rem;
    background: rgba(11,31,107,.85);
    backdrop-filter: blur(6px);
    color: white;
    font-size: 0.75rem;
    letter-spacing: .08em;
    padding: 0.3rem 0.75rem;
    border-radius: 999px;
    display: flex;
    align-items: center;
    gap: 0.375rem;
}
.soflo-venue-card__live-dot {
    width: 0.375rem;
    height: 0.375rem;
    border-radius: 50%;
    background: var(--aqua);
    box-shadow: 0 0 0.375rem var(--aqua);
    animation: soflo-pulse 2s infinite;
    flex-shrink: 0;
}
.soflo-venue-card__body {
    padding: 1rem 1.125rem 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    flex: 1;
}
.soflo-venue-card__name {
    font-size: 1.0625rem;
    color: var(--ink);
    margin: 0;
    line-height: 1.15;
}
.soflo-venue-card__hood {
    display: flex;
    align-items: center;
    gap: 0.3125rem;
    font-size: 0.8125rem;
    color: var(--ink-2);
}
.soflo-venue-card__hood svg {
    flex-shrink: 0;
    color: var(--ink-3);
}
.soflo-venue-card__tonight {
    display: flex; flex-direction: column; gap: 0.05rem;
    margin-top: 0.25rem; letter-spacing: .06em;
}
.soflo-venue-card__tonight-lbl {
    font-size: 0.625rem; letter-spacing: .12em; color: var(--ink-3, #8b97c5);
    text-transform: uppercase;
}
.soflo-venue-card__tonight-gig {
    font-size: 0.8125rem; color: var(--blue-500, #3b6cf2);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.soflo-venue-card__pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
    margin-top: 0.5rem;
}
.soflo-venue-card__pick {
    font-size: 0.8125rem;
    color: var(--ink-2);
    margin: 0.25rem 0 0;
    line-height: 1.45;
}

/* ══════════════════════════════════════════════════════════════════════════════
   Artist Card
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-artist-card {
    cursor: pointer;
    background: white;
    border-radius: 1rem;
    overflow: hidden;
    border: 1px solid var(--line);
    transition: box-shadow .2s, transform .2s;
    display: flex;
    flex-direction: column;
}
.soflo-artist-card:hover {
    box-shadow: 0 0.5rem 2rem rgba(11,31,107,.1);
    transform: translateY(-2px);
}
.soflo-artist-card__img-wrap {
    position: relative;
    aspect-ratio: 1 / 1;
    overflow: hidden;
}
.soflo-artist-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .35s ease;
}
.soflo-artist-card:hover .soflo-artist-card__img {
    transform: scale(1.04);
}
.soflo-artist-card__genre-chip {
    position: absolute;
    top: 0.625rem;
    left: 0.625rem;
    padding: 0.25rem 0.6875rem;
    border-radius: 999px;
    font-size: 0.5625rem;
    letter-spacing: .1em;
    color: white;
    font-weight: 600;
    text-transform: uppercase;
}
.soflo-artist-card__body {
    padding: 1rem 1.125rem 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    flex: 1;
}
.soflo-artist-card__name {
    font-size: 1.0625rem;
    color: var(--ink);
    margin: 0;
    line-height: 1.15;
}
.soflo-artist-card__hood {
    display: flex;
    align-items: center;
    gap: 0.3125rem;
    font-size: 0.8125rem;
    color: var(--ink-2);
}
.soflo-artist-card__hood svg {
    flex-shrink: 0;
    color: var(--ink-3);
}
.soflo-artist-card__bio {
    font-size: 0.8125rem;
    color: var(--ink-2);
    margin: 0.25rem 0 0;
    line-height: 1.55;
}
.soflo-artist-card__next-gig {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    color: var(--navy-700);
    font-weight: 500;
    margin-top: 0.375rem;
}
.soflo-artist-card__next-gig svg {
    flex-shrink: 0;
    opacity: .75;
}
.soflo-artist-card__next-gig--none {
    color: var(--ink-3);
    font-style: italic;
    font-weight: 400;
    font-size: 0.75rem;
    margin-top: 0.375rem;
}
.soflo-artist-card__follow {
    align-self: flex-start;
    margin-top: auto;
    padding-top: 0.75rem;
    padding: 0.4375rem 1rem;
    border-radius: 999px;
    border: 1.5px solid var(--navy-700);
    background: transparent;
    color: var(--navy-700);
    font-size: 0.625rem;
    letter-spacing: .1em;
    font-weight: 600;
    transition: background .15s, color .15s;
}
.soflo-artist-card__follow:hover,
.soflo-artist-card__follow.is-following {
    background: var(--navy-700);
    color: white;
}

/* ── Artist detail — hero social icons ───────────────────────────────────────*/
.soflo-artist-detail__hero-socials {
    display: flex;
    gap: 0.625rem;
    margin-top: 0.875rem;
}
.soflo-artist-detail__hero-social {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    background: rgba(255,255,255,.15);
    color: white;
    border: 1.5px solid rgba(255,255,255,.35);
    transition: background .15s, border-color .15s;
    text-decoration: none;
}
.soflo-artist-detail__hero-social:hover {
    background: rgba(255,255,255,.28);
    border-color: rgba(255,255,255,.6);
}

/* ── Artist detail — sidebar value text ──────────────────────────────────────*/
.soflo-dir-detail__sidebar-val {
    font-size: 0.9375rem;
    color: var(--ink);
    margin: 0.375rem 0 0;
    line-height: 1.45;
}

/* ── Events list — venue link style ──────────────────────────────────────────*/
.soflo-dir-events__artist--link {
    color: var(--navy-700);
    text-decoration: none;
    font-weight: 600;
}
.soflo-dir-events__artist--link:hover {
    text-decoration: underline;
}

/* ── Artist detail — show row gig link ───────────────────────────────────────*/
.soflo-dir-events__gig-link {
    font-size: 0.8125rem;
    color: var(--navy-700);
    text-decoration: none;
    font-weight: 600;
    letter-spacing: 0.02em;
    margin-top: 0.4rem;
    display: inline-block;
}
.soflo-dir-events__gig-link:hover {
    text-decoration: underline;
}

/* ── Artist detail — "AT" venue label in show rows ──────────────────────────*/
.soflo-dir-events__at-label {
    font-size: 0.625rem;
    letter-spacing: 0.1em;
    color: var(--ink-muted, #9ca3af);
    margin-bottom: 0.1rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

/* ── Artist detail — sidebar venues list ────────────────────────────────────*/
.soflo-dir-detail__venue-list { display: flex; flex-direction: column; gap: 0.5rem; }
.soflo-dir-detail__sidebar-venue {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8125rem;
    color: var(--ink);
    text-decoration: none;
    letter-spacing: 0;
}
a.soflo-dir-detail__sidebar-venue { color: var(--navy-700, #3b55e6); }
a.soflo-dir-detail__sidebar-venue:hover { text-decoration: underline; }

/* ══════════════════════════════════════════════════════════════════════════════
   Karaoke — "What to expect" intro callout
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-karaoke-intro {
    background: var(--blue-50);
    border-bottom: 1px solid var(--line);
    padding: 2.25rem 2rem;
}
.soflo-karaoke-intro__inner {
    max-width: 80rem;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
}
.soflo-karaoke-intro__icon {
    font-size: 2rem;
    line-height: 1;
    flex-shrink: 0;
    margin-top: 0.125rem;
}
.soflo-karaoke-intro__h2 {
    font-size: 1.25rem;
    color: var(--ink);
    margin: 0 0 0.5rem;
}
.soflo-karaoke-intro__body {
    font-size: 0.9375rem;
    color: var(--ink-2);
    margin: 0;
    line-height: 1.65;
    max-width: 56rem;
}

/* ══════════════════════════════════════════════════════════════════════════════
   Karaoke — Weekly picks
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-karaoke-picks {
    background: var(--paper-2);
    border-bottom: 1px solid var(--line);
    padding: 2rem 2rem;
}
.soflo-karaoke-picks__inner {
    max-width: 80rem;
    margin: 0 auto;
}
.soflo-karaoke-picks__heading {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}
.soflo-karaoke-picks__dot {
    width: 0.4375rem;
    height: 0.4375rem;
    border-radius: 50%;
    background: var(--blue-500);
    flex-shrink: 0;
}
.soflo-karaoke-picks__label {
    font-size: 0.6875rem;
    color: var(--ink-3);
    letter-spacing: .14em;
}
.soflo-karaoke-picks__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}
.soflo-karaoke-picks__item {
    background: white;
    border: 1px solid var(--line);
    border-radius: 0.875rem;
    padding: 1.125rem 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.3125rem;
}
.soflo-karaoke-picks__tag {
    display: inline-block;
    font-size: 0.5625rem;
    letter-spacing: .1em;
    color: var(--blue-500);
    border: 1px solid var(--blue-100);
    border-radius: 999px;
    padding: 0.1875rem 0.625rem;
    margin-bottom: 0.125rem;
    align-self: flex-start;
}
.soflo-karaoke-picks__name {
    font-family: 'Bricolage Grotesque', 'Inter', sans-serif;
    font-weight: 700;
    font-size: 1.0625rem;
    color: var(--ink);
    letter-spacing: -0.01em;
}
.soflo-karaoke-picks__note {
    font-size: 0.8125rem;
    color: var(--ink-3);
}
.soflo-karaoke-picks__item--media {
    flex-direction: row;
    align-items: center;
    gap: 0.75rem;
    padding: 0.875rem 1rem;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
}
.soflo-karaoke-picks__item--media:hover { border-color: var(--blue-500); }
.soflo-karaoke-picks__img-wrap {
    width: 3.25rem;
    height: 3.25rem;
    flex-shrink: 0;
    border-radius: 0.5rem;
    overflow: hidden;
    background: var(--paper-2);
}
.soflo-karaoke-picks__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s ease;
}
.soflo-karaoke-picks__item--media:hover .soflo-karaoke-picks__img { transform: scale(1.04); }
.soflo-karaoke-picks__chip {
    font-size: 0.5625rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    background: var(--blue-50, #eff6ff);
    color: var(--blue-500);
    padding: 0.1875rem 0.5rem;
    border-radius: 999px;
    display: inline-block;
    align-self: flex-start;
}
.soflo-karaoke-picks__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

/* ══════════════════════════════════════════════════════════════════════════════
   City Guide — Neighborhood grid
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-cityguide-section {
    background: var(--paper-2);
    padding-bottom: 5rem;
}
.soflo-cityguide-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
}
.soflo-neighborhood-card {
    background: white;
    border-radius: 1rem;
    overflow: hidden;
    border: 1px solid var(--line);
    transition: box-shadow .2s, transform .2s;
}
.soflo-neighborhood-card:hover {
    box-shadow: 0 0.5rem 2.5rem rgba(11,31,107,.12);
    transform: translateY(-3px);
}
.soflo-neighborhood-card__img-wrap {
    position: relative;
    aspect-ratio: 16/7;
    overflow: hidden;
}
.soflo-neighborhood-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .4s ease;
}
.soflo-neighborhood-card:hover .soflo-neighborhood-card__img {
    transform: scale(1.05);
}
.soflo-neighborhood-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(11,31,107,.7) 0%, transparent 55%);
    display: flex;
    align-items: flex-end;
    padding: 1.25rem 1.375rem;
}
.soflo-neighborhood-card__name {
    color: white;
    font-size: clamp(1.25rem, 2.5vw, 1.75rem);
    margin: 0;
    text-shadow: 0 1px 4px rgba(0,0,0,.35);
}
.soflo-neighborhood-card__body {
    padding: 1.125rem 1.375rem 1.375rem;
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
}
.soflo-neighborhood-card__vibe {
    font-size: 0.9375rem;
    color: var(--ink-2);
    margin: 0;
    line-height: 1.5;
}
.soflo-neighborhood-card__meta {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
}
.soflo-neighborhood-card__meta-item {
    display: flex;
    flex-direction: column;
    gap: 0.1875rem;
}
.soflo-neighborhood-card__meta-label {
    font-size: 0.5625rem;
    letter-spacing: .12em;
    color: var(--ink-3);
}
.soflo-neighborhood-card__meta-item > span:last-child {
    font-size: 0.875rem;
    color: var(--ink);
    font-weight: 500;
}
.soflo-neighborhood-card__genres {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
}
.soflo-neighborhood-card__genre-tag {
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    font-size: 0.5625rem;
    letter-spacing: .1em;
    color: white;
    font-weight: 600;
    text-transform: uppercase;
}

/* ══════════════════════════════════════════════════════════════════════════════
   Responsive
   ══════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1200px) {
    .soflo-dir-grid--artists { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
    .soflo-dir-grid              { grid-template-columns: repeat(2, 1fr); }
    .soflo-dir-grid--artists     { grid-template-columns: repeat(2, 1fr); }
    .soflo-cityguide-grid        { grid-template-columns: 1fr; }
    .soflo-karaoke-picks__grid   { grid-template-columns: 1fr; gap: 0.75rem; }
    .soflo-neighborhood-card__meta { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
    .soflo-page-fold             { padding: calc(5.375rem + 2rem) 1.25rem 2.5rem; }
    .soflo-dir-section__inner    { padding: 1.25rem 1.25rem 0; }
    .soflo-dir-grid              { grid-template-columns: 1fr; }
    .soflo-dir-grid--artists     { grid-template-columns: 1fr; }
    .soflo-karaoke-intro         { padding: 1.5rem 1.25rem; }
    .soflo-karaoke-intro__inner  { flex-direction: column; gap: 0.75rem; }
    .soflo-karaoke-picks         { padding: 1.5rem 1.25rem; }
    .soflo-neighborhood-card__meta { grid-template-columns: 1fr; }
    .soflo-neighborhood-card__img-wrap { aspect-ratio: 16/8; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   Interior / utility pages (About, Contact, List a venue, Advertise)
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-interior {
    background: var(--paper);
    padding: 4rem 0 6rem;
}
.soflo-interior__inner {
    max-width: 60rem;
    margin: 0 auto;
    padding: 0 2rem;
}
.soflo-interior__inner--contact {
    max-width: 72rem;
}
.soflo-interior__section {
    margin-bottom: 3rem;
}
.soflo-interior__section--lead {
    padding: 0 0 2rem;
    border-bottom: 1px solid var(--line);
    margin-bottom: 3rem;
}
.soflo-interior__lead {
    font-size: clamp(1.125rem, 2vw, 1.375rem);
    color: var(--ink);
    line-height: 1.6;
    margin: 0;
}
.soflo-interior__h2 {
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    color: var(--ink);
    margin: 0 0 0.875rem;
}
.soflo-interior__inner p {
    font-size: 1.0625rem;
    color: var(--ink-2);
    line-height: 1.7;
    margin: 0 0 1rem;
}

/* Stat row */
.soflo-interior__stat-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--line);
    border: 1px solid var(--line);
    border-radius: 1rem;
    overflow: hidden;
    margin: 0 0 3.5rem;
}
.soflo-interior__stat {
    background: var(--paper-2);
    padding: 1.75rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
}
.soflo-interior__stat-num {
    font-size: clamp(2rem, 4vw, 3rem);
    color: var(--navy-700);
    line-height: 1;
}
.soflo-interior__stat-label {
    font-size: 0.625rem;
    letter-spacing: .12em;
    color: var(--ink-3);
}

/* Cards row */
.soflo-interior__cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-top: 1.5rem;
}
.soflo-interior__card {
    background: var(--paper-2);
    border: 1px solid var(--line);
    border-radius: 1rem;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.soflo-interior__card--featured {
    background: var(--blue-50);
    border-color: var(--blue-100);
}
.soflo-interior__card-tag {
    font-size: 0.5625rem;
    letter-spacing: .1em;
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 0.2rem 0.625rem;
    align-self: flex-start;
    color: var(--ink-3);
}
.soflo-interior__card h3 {
    font-family: 'Bricolage Grotesque', 'Inter', sans-serif;
    font-weight: 700;
    font-size: 1.125rem;
    color: var(--ink);
    margin: 0;
    letter-spacing: -0.01em;
}
.soflo-interior__card p {
    font-size: 0.9rem !important;
    flex: 1;
}
.soflo-interior__card-link {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--blue-500);
    margin-top: 0.25rem;
}
.soflo-interior__card-link:hover { text-decoration: underline; }

/* ══════════════════════════════════════════════════════════════════════════════
   Auth pages (Login / Join)
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-auth-fold {
    min-height: calc(100vh - 5.375rem);
    background: var(--paper-2);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4rem 1.5rem;
}
.soflo-auth-fold__inner {
    width: 100%;
    max-width: 26rem;
}
.soflo-auth-card {
    background: white;
    border: 1px solid var(--line);
    border-radius: 1.25rem;
    padding: 2.5rem 2.25rem;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.soflo-auth-card--join {
    max-width: 100%;
}
.soflo-auth-fold__inner .soflo-auth-card--join {
    max-width: 28rem;
}
.soflo-auth-card__logo-link { display: block; margin-bottom: 1.75rem; }
.soflo-auth-card__logo {
    height: 2.5rem;
    width: auto;
    filter: brightness(0) saturate(1) hue-rotate(0deg);
}
.soflo-auth-card__h1 {
    font-size: clamp(1.5rem, 4vw, 2rem);
    color: var(--ink);
    margin: 0 0 0.5rem;
}
.soflo-auth-card__sub {
    font-size: 0.9375rem;
    color: var(--ink-2);
    margin: 0 0 1.75rem;
    line-height: 1.5;
}
.soflo-auth-card__switch {
    font-size: 0.875rem;
    color: var(--ink-3);
    margin-top: 1.25rem;
    text-align: center;
}
.soflo-auth-card__switch a { color: var(--blue-500); font-weight: 600; }

/* WP native login form overrides */
#soflo-login-user, #soflo-login-pass {
    display: block; width: 100%; box-sizing: border-box;
    padding: 0.75rem 1rem;
    border: 1.5px solid var(--line);
    border-radius: 0.75rem;
    font-size: 0.9375rem;
    font-family: inherit;
    color: var(--ink);
    background: white;
    transition: border-color .15s;
    margin-top: 0.375rem;
    margin-bottom: 1rem;
}
#soflo-login-user:focus, #soflo-login-pass:focus {
    outline: none;
    border-color: var(--blue-500);
}
.login-username label, .login-password label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ink);
    letter-spacing: .01em;
}
#soflo-login-submit {
    width: 100%;
    padding: 0.75rem 1.5rem;
    border-radius: 0.75rem;
    background: var(--navy-950);
    color: white;
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: .05em;
    border: none;
    cursor: pointer;
    transition: background .15s;
    font-family: 'JetBrains Mono', monospace;
    margin-top: 0.5rem;
}
#soflo-login-submit:hover { background: var(--navy-800); }
.login-remember { font-size: 0.8125rem; color: var(--ink-2); display: flex; align-items: center; gap: 0.5rem; margin: 0.75rem 0; }
.login-remember label { cursor: pointer; }
.login-remember input { accent-color: var(--blue-500); }
.login-links { font-size: 0.8125rem; color: var(--ink-3); margin-top: 0.75rem; display: flex; justify-content: center; gap: 1rem; }
.login-links a { color: var(--blue-500); }

/* Perks list (join page) */
.soflo-auth-perks {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    margin: 0 0 1.5rem;
    padding: 1.125rem 1.25rem;
    background: var(--paper-2);
    border-radius: 0.875rem;
    border: 1px solid var(--line);
}
.soflo-auth-perk {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.9375rem;
    color: var(--ink);
}
.soflo-auth-perk__icon { font-size: 1.125rem; flex-shrink: 0; }

/* Auth form (register) */
.soflo-auth-form { display: flex; flex-direction: column; gap: 0.875rem; }
.soflo-auth-form__row { display: flex; flex-direction: column; gap: 0.375rem; }
.soflo-auth-form__row label { font-size: 0.8125rem; font-weight: 600; color: var(--ink); }
.soflo-auth-form__input {
    width: 100%; box-sizing: border-box;
    padding: 0.75rem 1rem;
    border: 1.5px solid var(--line);
    border-radius: 0.75rem;
    font-size: 0.9375rem;
    font-family: inherit;
    color: var(--ink);
    background: white;
    transition: border-color .15s;
}
.soflo-auth-form__input:focus { outline: none; border-color: var(--blue-500); }
.soflo-auth-form__fine { font-size: 0.8125rem; color: var(--ink-3); margin: 0; }
.soflo-auth-form__submit {
    padding: 0.75rem 1.5rem;
    border-radius: 0.75rem;
    background: var(--navy-950);
    color: white;
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: .05em;
    border: none;
    cursor: pointer;
    transition: background .15s;
    align-self: flex-start;
}
.soflo-auth-form__submit:hover { background: var(--navy-800); }
.soflo-auth-form__inline { display: flex; gap: 0.625rem; }
.soflo-auth-form__inline .soflo-auth-form__input { flex: 1; }
.soflo-auth-form__inline .soflo-auth-form__submit { align-self: auto; white-space: nowrap; }

/* ══════════════════════════════════════════════════════════════════════════════
   Contact page
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-contact-grid {
    display: grid;
    grid-template-columns: 1fr 22rem;
    gap: 3.5rem;
    align-items: start;
}
.soflo-contact-form { display: flex; flex-direction: column; gap: 1.125rem; }
.soflo-contact-form__row { display: flex; gap: 1rem; }
.soflo-contact-form__row--two > * { flex: 1; }
.soflo-contact-form__field { display: flex; flex-direction: column; gap: 0.375rem; flex: 1; }
.soflo-contact-form__field label { font-size: 0.8125rem; font-weight: 600; color: var(--ink); }
.soflo-contact-form__input {
    width: 100%; box-sizing: border-box;
    padding: 0.75rem 1rem;
    border: 1.5px solid var(--line);
    border-radius: 0.75rem;
    font-size: 0.9375rem;
    font-family: inherit;
    color: var(--ink);
    background: white;
    transition: border-color .15s;
    -webkit-appearance: none;
}
.soflo-contact-form__input:focus { outline: none; border-color: var(--blue-500); }
.soflo-contact-form__select { cursor: pointer; }
.soflo-contact-form__textarea { resize: vertical; min-height: 8rem; line-height: 1.55; }
.soflo-contact-form__submit {
    align-self: flex-start;
    padding: 0.75rem 1.75rem;
    border-radius: 0.75rem;
    background: var(--navy-950);
    color: white;
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: .05em;
    border: none;
    cursor: pointer;
    transition: background .15s;
}
.soflo-contact-form__submit:hover { background: var(--navy-800); }
.soflo-contact-form__success {
    padding: 1.5rem;
    background: #ecfdf5;
    border: 1px solid #a7f3d0;
    border-radius: 0.875rem;
    color: #065f46;
    font-size: 1rem;
    line-height: 1.5;
}
.soflo-contact-form__success .soflo-mono { font-size: 0.875rem; letter-spacing: .08em; }

.soflo-contact-info { display: flex; flex-direction: column; gap: 2rem; padding-top: 0.5rem; }
.soflo-contact-info__items { display: flex; flex-direction: column; gap: 1.25rem; }
.soflo-contact-info__item { display: flex; flex-direction: column; gap: 0.25rem; }
.soflo-contact-info__label { font-size: 0.5625rem; letter-spacing: .12em; color: var(--ink-3); }
.soflo-contact-info__val { font-size: 1rem; color: var(--ink); font-weight: 500; }
.soflo-contact-info__val:is(a) { color: var(--blue-500); }
.soflo-contact-info__val:is(a):hover { text-decoration: underline; }
.soflo-contact-info__social { display: flex; flex-direction: column; gap: 0.75rem; }
.soflo-contact-info__social-links { display: flex; flex-direction: column; gap: 0.5rem; }
.soflo-contact-info__social-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.625rem 1rem;
    border: 1.5px solid var(--line);
    border-radius: 0.75rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--ink);
    transition: border-color .15s, background .15s;
}
.soflo-contact-info__social-btn:hover { background: var(--paper-2); border-color: var(--blue-300); }

/* ══════════════════════════════════════════════════════════════════════════════
   List a venue page
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-lav-features {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 3.5rem;
    padding-bottom: 3.5rem;
    border-bottom: 1px solid var(--line);
}
.soflo-lav-feature { display: flex; flex-direction: column; gap: 0.75rem; }
.soflo-lav-feature__icon { font-size: 2rem; line-height: 1; }
.soflo-lav-feature__h3 { font-family: 'Bricolage Grotesque','Inter',sans-serif; font-weight: 700; font-size: 1.125rem; color: var(--ink); margin: 0; letter-spacing: -.01em; }
.soflo-lav-feature p { font-size: 0.9375rem; color: var(--ink-2); margin: 0; line-height: 1.65; }
.soflo-lav-cta { margin-top: 2rem; }
.soflo-lav-cta__content { margin-bottom: 2rem; }
.soflo-lav-cta__h2 { font-size: clamp(1.5rem, 3vw, 2.25rem); color: var(--ink); margin: 0 0 0.5rem; }
.soflo-lav-cta__content p { color: var(--ink-2); margin: 0; }

/* ══════════════════════════════════════════════════════════════════════════════
   Responsive
   ══════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
    .soflo-contact-grid        { grid-template-columns: 1fr; gap: 2.5rem; }
    .soflo-interior__cards     { grid-template-columns: 1fr; }
    .soflo-interior__stat-row  { grid-template-columns: repeat(2, 1fr); }
    .soflo-lav-features        { grid-template-columns: 1fr; gap: 2rem; }
}
@media (max-width: 600px) {
    .soflo-interior            { padding: 2.5rem 0 4rem; }
    .soflo-interior__inner     { padding: 0 1.25rem; }
    .soflo-interior__stat-row  { grid-template-columns: repeat(2, 1fr); }
    .soflo-auth-card           { padding: 2rem 1.5rem; }
    .soflo-contact-form__row   { flex-direction: column; }
    .soflo-auth-form__inline   { flex-direction: column; }
    .soflo-contact-form__submit { width: 100%; text-align: center; }
}


/* ══════════════════════════════════════════════════════════════════════════════
   Stories — blog listing
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-stories-fold {
    background: linear-gradient(160deg, #0f1f5c 0%, var(--navy-800) 60%, #1e3a8a 100%);
}
.soflo-stories {
    background: var(--paper-2);
    padding: 2.5rem 0 5rem;
}
.soflo-stories__inner {
    max-width: 80rem;
    margin: 0 auto;
    padding: 0 2rem;
}

/* Category filter pills */
.soflo-stories__cats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 2rem;
}
.soflo-stories__cat-pill {
    padding: 0.375rem 1rem;
    border-radius: 999px;
    border: 1.5px solid var(--line);
    font-size: 0.625rem;
    letter-spacing: .1em;
    color: var(--ink-3);
    background: white;
    transition: border-color .15s, color .15s, background .15s;
}
.soflo-stories__cat-pill:hover,
.soflo-stories__cat-pill.is-active {
    border-color: var(--navy-700);
    color: var(--navy-700);
    background: var(--blue-50);
}

/* Post grid */
.soflo-stories__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

/* Featured first card — spans 2 cols on large screens */
.soflo-stories__grid .soflo-story-card--featured {
    grid-column: span 2;
}
.soflo-stories__grid .soflo-story-card--featured .soflo-story-card__img-link {
    aspect-ratio: 16/7;
}
.soflo-stories__grid .soflo-story-card--featured .soflo-story-card__title {
    font-size: clamp(1.25rem, 2.5vw, 1.75rem);
}
.soflo-stories__grid .soflo-story-card--featured .soflo-story-card__excerpt {
    -webkit-line-clamp: 3;
}

/* Story card */
.soflo-story-card {
    background: white;
    border-radius: 1rem;
    overflow: hidden;
    border: 1px solid var(--line);
    display: flex;
    flex-direction: column;
    transition: box-shadow .2s, transform .2s;
}
.soflo-story-card:hover {
    box-shadow: 0 0.5rem 2rem rgba(11,31,107,.1);
    transform: translateY(-2px);
}
.soflo-story-card__img-link {
    display: block;
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
}
.soflo-story-card__img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .4s ease;
}
.soflo-story-card:hover .soflo-story-card__img { transform: scale(1.04); }
.soflo-story-card__img-placeholder {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--navy-950) 0%, var(--navy-700) 100%);
}
.soflo-story-card__cat-badge {
    position: absolute;
    bottom: 0.75rem;
    left: 0.75rem;
    background: rgba(11,31,107,.85);
    backdrop-filter: blur(6px);
    color: white;
    font-size: 0.5rem;
    letter-spacing: .12em;
    padding: 0.25rem 0.625rem;
    border-radius: 999px;
}
.soflo-story-card__body {
    padding: 1.125rem 1.25rem 1.375rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    flex: 1;
}
.soflo-story-card__title {
    font-size: 1.0625rem;
    color: var(--ink);
    margin: 0;
    line-height: 1.2;
}
.soflo-story-card__title a { color: inherit; }
.soflo-story-card__title a:hover { color: var(--navy-700); }
.soflo-story-card__title--sm { font-size: 0.9375rem; }
.soflo-story-card__excerpt {
    font-size: 0.875rem;
    color: var(--ink-2);
    margin: 0;
    line-height: 1.55;
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.soflo-story-card__meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.625rem;
    letter-spacing: .08em;
    color: var(--ink-3);
    margin-top: 0.25rem;
}
.soflo-story-card__dot {
    width: 3px; height: 3px; border-radius: 50%;
    background: var(--ink-3); flex-shrink: 0;
}
.soflo-story-card--small .soflo-story-card__img-link { aspect-ratio: 16/8; }

/* Pagination */
.soflo-stories__pagination {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    margin-top: 3rem;
}
.soflo-stories__pagination .page-numbers {
    padding: 0.5rem 0.875rem;
    border-radius: 0.75rem;
    border: 1.5px solid var(--line);
    font-size: 0.875rem;
    color: var(--ink-2);
    background: white;
    transition: border-color .15s, color .15s;
}
.soflo-stories__pagination .page-numbers:hover,
.soflo-stories__pagination .page-numbers.current {
    border-color: var(--navy-700);
    color: var(--navy-700);
    background: var(--blue-50);
}
.soflo-stories__empty {
    text-align: center;
    padding: 4rem 0;
    color: var(--ink-3);
    font-size: 0.875rem;
    letter-spacing: .1em;
}

/* ══════════════════════════════════════════════════════════════════════════════
   Single post
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-post-fold {
    background: linear-gradient(160deg, var(--navy-950) 0%, var(--navy-800) 100%);
    margin-top: -5.375rem;
    padding: calc(5.375rem + 3rem) 2rem 3rem;
    position: relative;
    overflow: hidden;
}
.soflo-post-fold--has-image { padding-bottom: 4rem; }
.soflo-post-fold__bg {
    position: absolute; inset: 0;
}
.soflo-post-fold__bg-img {
    width: 100%; height: 100%; object-fit: cover; opacity: .18;
}
.soflo-post-fold__bg-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, var(--navy-950) 0%, transparent 60%);
}
.soflo-post-fold__inner {
    max-width: 52rem;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}
.soflo-post-fold__back {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.625rem;
    letter-spacing: .1em;
    color: rgba(255,255,255,.55);
    margin-bottom: 1.5rem;
    transition: color .15s;
}
.soflo-post-fold__back:hover { color: rgba(255,255,255,.9); }
.soflo-post-fold__kicker {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
}
.soflo-post-fold__cat {
    font-size: 0.6875rem;
    letter-spacing: .12em;
    color: var(--aqua);
    text-transform: uppercase;
}
.soflo-post-fold__cat:hover { text-decoration: underline; }
.soflo-post-fold__sep { color: rgba(255,255,255,.3); font-size: 0.75rem; }
.soflo-post-fold__readtime { font-size: 0.6875rem; letter-spacing: .1em; color: rgba(255,255,255,.45); }
.soflo-post-fold__title {
    font-size: clamp(1.75rem, 4.5vw, 3.25rem);
    color: white;
    margin: 0 0 1rem;
    line-height: 1.05;
}
.soflo-post-fold__meta {
    font-size: 0.6875rem;
    letter-spacing: .08em;
    color: rgba(255,255,255,.45);
}

/* Post body */
.soflo-post-body {
    background: var(--paper);
    padding: 3.5rem 0 5rem;
}
.soflo-post-body__inner {
    max-width: 52rem;
    margin: 0 auto;
    padding: 0 2rem;
}

/* Article content typography */
.soflo-post-content {
    font-size: 1.0625rem;
    color: var(--ink);
    line-height: 1.75;
}
.soflo-post-content h2 {
    font-family: 'Bricolage Grotesque', 'Inter', sans-serif;
    font-weight: 700;
    font-size: clamp(1.25rem, 2.5vw, 1.75rem);
    color: var(--ink);
    margin: 2.5rem 0 0.875rem;
    letter-spacing: -0.02em;
    line-height: 1.15;
}
.soflo-post-content h3 {
    font-family: 'Bricolage Grotesque', 'Inter', sans-serif;
    font-weight: 700;
    font-size: 1.125rem;
    margin: 2rem 0 0.625rem;
    color: var(--ink);
}
.soflo-post-content p  { margin: 0 0 1.25rem; }
.soflo-post-content ul,
.soflo-post-content ol { margin: 0 0 1.25rem; padding-left: 1.5rem; }
.soflo-post-content li { margin-bottom: 0.4375rem; }
.soflo-post-content strong { font-weight: 600; color: var(--ink); }
.soflo-post-content a  { color: var(--blue-500); text-decoration: underline; }
.soflo-post-content a:hover { color: var(--navy-700); }
.soflo-post-content img {
    width: 100%; border-radius: 0.75rem; margin: 1.5rem 0;
}
.soflo-post-content blockquote {
    margin: 2rem 0;
    padding: 1.25rem 1.5rem;
    border-left: 3px solid var(--navy-700);
    background: var(--blue-50);
    border-radius: 0 0.75rem 0.75rem 0;
    font-size: 1.125rem;
    font-style: italic;
    color: var(--navy-800);
}

/* Post footer */
.soflo-post-footer {
    margin-top: 3rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--line);
}
.soflo-post-footer__back {
    font-size: 0.625rem;
    letter-spacing: .1em;
    color: var(--ink-3);
    transition: color .15s;
}
.soflo-post-footer__back:hover { color: var(--blue-500); }

/* Related posts */
.soflo-post-related { margin-top: 3.5rem; }
.soflo-post-related__heading {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
}
.soflo-post-related__dot {
    width: 0.4375rem; height: 0.4375rem; border-radius: 50%;
    background: var(--blue-500); flex-shrink: 0;
}
.soflo-post-related__label { font-size: 0.6875rem; letter-spacing: .14em; color: var(--ink-3); }
.soflo-post-related__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }

/* Responsive */
@media (max-width: 900px) {
    .soflo-stories__grid { grid-template-columns: repeat(2, 1fr); }
    .soflo-stories__grid .soflo-story-card--featured { grid-column: span 2; }
    .soflo-post-related__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
    .soflo-stories { padding: 1.5rem 0 3rem; }
    .soflo-stories__inner { padding: 0 1.25rem; }
    .soflo-stories__grid { grid-template-columns: 1fr; }
    .soflo-stories__grid .soflo-story-card--featured { grid-column: 1; }
    .soflo-post-fold { padding: calc(5.375rem + 2rem) 1.25rem 2.5rem; }
    .soflo-post-body__inner { padding: 0 1.25rem; }
    .soflo-post-related__grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   Detail modal (artist / karaoke)
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-detail-modal {
    position: fixed; inset: 0; z-index: 500;
    display: flex; align-items: flex-end; justify-content: center;
    pointer-events: none; opacity: 0;
    transition: opacity .22s ease;
}
.soflo-detail-modal.is-open {
    pointer-events: all; opacity: 1;
}
.soflo-detail-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(10,20,60,.55);
    backdrop-filter: blur(3px);
}
.soflo-detail-modal__panel {
    position: relative; z-index: 1;
    width: 100%; max-width: 480px;
    background: white; border-radius: 1.25rem 1.25rem 0 0;
    overflow: hidden; max-height: 92vh;
    display: flex; flex-direction: column;
    transform: translateY(2rem);
    transition: transform .28s cubic-bezier(.22,1,.36,1);
    box-shadow: 0 -0.5rem 3rem rgba(0,0,0,.18);
}
.soflo-detail-modal.is-open .soflo-detail-modal__panel {
    transform: translateY(0);
}
.soflo-detail-modal__close {
    position: absolute; top: 0.875rem; right: 0.875rem; z-index: 2;
    width: 2rem; height: 2rem; border-radius: 50%;
    background: rgba(0,0,0,.45); border: none; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    color: white; transition: background .15s;
}
.soflo-detail-modal__close:hover { background: rgba(0,0,0,.65); }
.soflo-detail-modal__img-wrap {
    position: relative; aspect-ratio: 16/7; flex-shrink: 0;
    background: var(--navy-950);
}
.soflo-detail-modal__img {
    width: 100%; height: 100%; object-fit: cover;
}
.soflo-detail-modal__img-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(5,12,40,.7) 0%, transparent 55%);
}
.soflo-detail-modal__chip {
    position: absolute; bottom: 0.875rem; left: 1rem;
    font-size: 0.5625rem; letter-spacing: .1em;
    background: rgba(11,31,107,.85); backdrop-filter: blur(6px);
    color: white; padding: 0.25rem 0.625rem; border-radius: 999px;
}
.soflo-detail-modal__body {
    padding: 1.375rem 1.5rem 1.75rem;
    overflow-y: auto; flex: 1;
    display: flex; flex-direction: column; gap: 0.5rem;
}
.soflo-detail-modal__title {
    font-size: clamp(1.375rem, 4vw, 1.75rem);
    color: var(--ink); margin: 0; line-height: 1.1;
}
.soflo-detail-modal__hood {
    display: flex; align-items: center;
    font-size: 0.8125rem; color: var(--ink-3); gap: 2px;
}
.soflo-detail-modal__bio {
    font-size: 1rem; color: var(--ink-2); line-height: 1.65; margin: 0.5rem 0 0;
}
.soflo-detail-modal__pick {
    font-size: 1rem; color: var(--ink-2); line-height: 1.65; margin: 0.5rem 0 0;
}
.soflo-detail-modal__tonight {
    font-size: 0.8125rem; color: var(--blue-500);
    letter-spacing: .04em; margin-top: 0.625rem;
    padding: 0.5rem 0.75rem; background: var(--blue-50);
    border-radius: 0.625rem; display: inline-block;
}
.soflo-detail-modal__pills-row {
    display: flex; gap: 0.5rem; flex-wrap: wrap; margin-top: 0.75rem;
}
.soflo-detail-modal__pill {
    font-size: 0.6875rem; letter-spacing: .06em;
    padding: 0.3rem 0.75rem; border-radius: 999px;
    border: 1.5px solid var(--line); color: var(--ink-3);
}
.soflo-detail-modal__pill--free {
    border-color: #a7f3d0; color: #065f46; background: #ecfdf5;
}
.soflo-detail-modal__shows {
    margin-top: 1.25rem; padding-top: 1.125rem;
    border-top: 1px solid var(--line);
}
.soflo-detail-modal__shows-label {
    font-size: 0.5625rem; letter-spacing: .12em; color: var(--ink-3); display: block; margin-bottom: 0.5rem;
}
.soflo-detail-modal__shows-empty {
    font-size: 0.875rem; color: var(--ink-3); margin: 0;
}
.soflo-detail-modal__actions {
    display: flex; gap: 0.75rem; margin-top: 1.25rem; flex-wrap: wrap;
}
.soflo-detail-modal__follow,
.soflo-detail-modal__save {
    flex: 1; padding: 0.75rem 1.25rem; border-radius: 0.75rem;
    background: var(--navy-950); color: white; border: none; cursor: pointer;
    font-size: 0.8125rem; font-weight: 700; letter-spacing: .06em;
    transition: background .15s;
}
.soflo-detail-modal__follow:hover,
.soflo-detail-modal__save:hover { background: var(--navy-800); }
.soflo-detail-modal__directions {
    flex: 1; padding: 0.75rem 1.25rem; border-radius: 0.75rem;
    background: white; color: var(--navy-950);
    border: 1.5px solid var(--line); cursor: pointer;
    font-size: 0.8125rem; font-weight: 700; letter-spacing: .06em;
    text-align: center; text-decoration: none;
    transition: border-color .15s, background .15s;
}
.soflo-detail-modal__directions:hover {
    border-color: var(--blue-500); background: var(--blue-50);
}

/* prevent page scroll when modal open */
body.soflo-modal-open { overflow: hidden; }

/* Leaflet popup custom padding */
.soflo-leaflet-popup .leaflet-popup-content-wrapper {
    border-radius: 0.875rem;
    box-shadow: 0 4px 20px rgba(0,0,0,.15);
    padding: 0;
}
.soflo-leaflet-popup .leaflet-popup-content {
    margin: 0;
}
.soflo-leaflet-popup .leaflet-popup-tip-container {
    margin-top: -1px;
}

@media (min-width: 600px) {
    .soflo-detail-modal { align-items: center; }
    .soflo-detail-modal__panel { border-radius: 1.25rem; max-height: 85vh; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   Auth page — standard layout (replaces full-screen auth-fold)
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-auth-page {
    padding: 4rem 1rem 5rem;
    min-height: 55vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--paper-2, #f8f9ff);
}
.soflo-auth-page__inner {
    width: 100%;
    max-width: 420px;
}

/* ══════════════════════════════════════════════════════════════════════════════
   Directory detail related-cards (venues / artists / karaoke)
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-dir-related-card {
    display: flex;
    flex-direction: column;
    border-radius: 0.875rem;
    overflow: hidden;
    background: white;
    text-decoration: none;
    border: 1.5px solid var(--line, #e9ebf5);
    transition: box-shadow .2s, transform .2s;
}
.soflo-dir-related-card:hover {
    box-shadow: 0 6px 24px rgba(11,31,107,.1);
    transform: translateY(-2px);
}
.soflo-dir-related-card__img-wrap {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
}
.soflo-dir-related-card__img-wrap img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .35s ease;
}
.soflo-dir-related-card:hover .soflo-dir-related-card__img-wrap img {
    transform: scale(1.04);
}
.soflo-dir-related-card__chip {
    position: absolute; bottom: 0.5rem; left: 0.625rem;
    font-size: 0.5rem; letter-spacing: .1em;
    padding: 0.2rem 0.5rem; border-radius: 999px;
    color: white;
}
.soflo-dir-related-card__body {
    padding: 0.75rem 0.875rem 0.875rem;
}
.soflo-dir-related-card__name {
    font-size: 0.9375rem; font-weight: 700;
    color: var(--ink, #0d1b3e); line-height: 1.2;
    font-family: 'Bricolage Grotesque', sans-serif;
}
.soflo-dir-related-card__hood {
    display: flex; align-items: center; gap: 3px;
    font-size: 0.75rem; color: var(--ink-3, #8b97c5); margin-top: 0.25rem;
}

/* ══════════════════════════════════════════════════════════════════════════════
   Detail page extras (tonight strip, shows placeholder, genres row)
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-dir-detail__tonight {
    display: inline-flex; align-items: center; gap: 0.5rem;
    font-size: 0.8125rem; color: var(--blue-500, #3b6cf2);
    letter-spacing: .04em; margin-bottom: 1rem;
    padding: 0.5rem 0.75rem; background: var(--blue-50, #eff3ff);
    border-radius: 0.625rem;
}
.soflo-dir-detail__tonight-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: #3b6cf2;
    animation: soflo-pulse 1.6s ease-in-out infinite;
}
.soflo-dir-detail__genres {
    display: flex; flex-wrap: wrap; gap: 0.375rem; margin-top: 1rem;
}
.soflo-dir-detail__shows {
    margin-top: 1.5rem; padding-top: 1.25rem;
    border-top: 1px solid var(--line, #e9ebf5);
}
.soflo-dir-detail__shows-label {
    display: block; font-size: 0.5625rem; letter-spacing: .12em;
    color: var(--ink-3, #8b97c5); margin-bottom: 0.5rem;
}
.soflo-dir-detail__shows-empty {
    font-size: 0.875rem; color: var(--ink-3, #8b97c5); margin: 0;
}
.soflo-dir-detail__save-btn,
.soflo-dir-detail__follow-btn {
    display: inline-flex; align-items: center; gap: 0.5rem;
    margin-top: 1.5rem;
}
.soflo-gig-detail__body--single-col {
    grid-template-columns: 1fr !important;
    max-width: 640px;
}

/* ══════════════════════════════════════════════════════════════════════════════
   Member dashboard
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-dashboard {
    padding: 3rem 1rem 5rem;
    background: var(--paper-2, #f8f9ff);
    min-height: 70vh;
}
.soflo-dashboard__inner {
    max-width: 880px; margin: 0 auto;
    display: flex; flex-direction: column; gap: 2.5rem;
}
.soflo-dashboard__welcome {
    display: flex; align-items: flex-start; justify-content: space-between;
    gap: 1.5rem; flex-wrap: wrap;
}
.soflo-dashboard__h1 {
    font-size: clamp(1.5rem, 4vw, 2.25rem); margin: 0 0 0.375rem;
    color: var(--ink, #0d1b3e);
}
.soflo-dashboard__sub {
    font-size: 1rem; color: var(--ink-2, #3d4f7c); margin: 0;
}
.soflo-dashboard__discover-btn {
    flex-shrink: 0; padding: 0.75rem 1.375rem;
    background: var(--navy-950, #0b1f6b); color: white;
    border-radius: 0.75rem; text-decoration: none;
    font-size: 0.8125rem; font-weight: 700; letter-spacing: .06em;
    transition: background .15s;
}
.soflo-dashboard__discover-btn:hover { background: var(--navy-800, #1b3aa6); }
.soflo-dashboard__nav {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.75rem;
}
.soflo-dashboard__nav-item {
    display: flex; flex-direction: column; align-items: center; gap: 0.375rem;
    padding: 1.25rem 0.75rem;
    background: white; border-radius: 0.875rem;
    text-decoration: none; color: var(--ink-2, #3d4f7c);
    font-size: 0.8125rem; font-weight: 600;
    border: 1.5px solid var(--line, #e9ebf5);
    transition: border-color .15s, box-shadow .15s;
}
.soflo-dashboard__nav-item:hover {
    border-color: var(--blue-500, #3b6cf2);
    box-shadow: 0 4px 16px rgba(59,108,242,.12);
    color: var(--ink, #0d1b3e);
}
.soflo-dashboard__nav-icon { font-size: 1.5rem; }
.soflo-dashboard__section {
    background: white; border-radius: 1rem;
    border: 1.5px solid var(--line, #e9ebf5);
    overflow: hidden;
}
.soflo-dashboard__section-head {
    padding: 1.125rem 1.5rem;
    border-bottom: 1px solid var(--line, #e9ebf5);
}
.soflo-dashboard__section-label {
    font-size: 0.5625rem; letter-spacing: .12em;
    color: var(--ink-3, #8b97c5); margin: 0;
}
.soflo-dashboard__empty-state {
    padding: 3rem 1.5rem;
    text-align: center;
    color: var(--ink-2, #3d4f7c);
}
.soflo-dashboard__empty-icon {
    font-size: 2rem; margin-bottom: 0.5rem;
    opacity: .4;
}
.soflo-dashboard__empty-state p { margin: 0 0 1rem; font-size: 0.9375rem; }
.soflo-dashboard__cta {
    font-size: 0.8125rem; font-weight: 700; letter-spacing: .06em;
    color: var(--blue-500, #3b6cf2); text-decoration: none;
}
.soflo-dashboard__cta:hover { text-decoration: underline; }
.soflo-dashboard__account-row {
    padding: 1.25rem 1.5rem;
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.soflo-dashboard__account-name {
    font-size: 0.9375rem; font-weight: 700; color: var(--ink, #0d1b3e);
}
.soflo-dashboard__account-email {
    font-size: 0.8125rem; color: var(--ink-3, #8b97c5); margin-top: 0.1875rem;
}
.soflo-dashboard__logout {
    font-size: 0.75rem; font-weight: 700; letter-spacing: .06em;
    color: var(--ink-3, #8b97c5); text-decoration: none; padding: 0.5rem 0.875rem;
    border: 1.5px solid var(--line, #e9ebf5); border-radius: 0.5rem;
    transition: border-color .15s, color .15s;
}
.soflo-dashboard__logout:hover { border-color: #ef4444; color: #ef4444; }

@media (max-width: 600px) {
    .soflo-dashboard__nav { grid-template-columns: repeat(2, 1fr); }
    .soflo-detail-modal__actions { flex-direction: column; }
    .soflo-detail-modal__follow,
    .soflo-detail-modal__save,
    .soflo-detail-modal__directions { flex: none; width: 100%; }
}

/* ── Venue card: cover pill + hours ─────────────────────────────────────────── */

.soflo-venue-card__hours {
    display: flex; align-items: center; gap: 4px;
    font-size: 0.75rem; color: var(--ink-3, #8b97c5); margin-top: 0.375rem;
}

/* ── Detail info value: free highlight ──────────────────────────────────────── */


/* ── Venue events calendar ───────────────────────────────────────────────────── */
.soflo-dir-events-wrap { padding-top: 0; background: var(--paper-2, #f8f9ff); }
.soflo-dir-events { margin-top: 1.75rem; }
.soflo-dir-events__header {
    display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem;
}
.soflo-dir-events__title { font-size: 0.5625rem; letter-spacing: .12em; color: var(--ink-3, #8b97c5); }
.soflo-dir-events__reserve {
    font-size: 0.75rem; font-weight: 700; letter-spacing: .04em;
    color: var(--blue-500, #3b6cf2); text-decoration: none;
}
.soflo-dir-events__reserve:hover { text-decoration: underline; }
.soflo-dir-events__list {
    display: flex; flex-direction: column;
    border: 1.5px solid var(--line, #e9ebf5); border-radius: 0.875rem;
    overflow-x: hidden; overflow-y: auto; background: white;
    max-height: 300px;
}
.soflo-dir-events__row {
    display: flex; align-items: center; gap: 1rem;
    padding: 0.875rem 1.125rem;
    border-bottom: 1px solid var(--line, #e9ebf5);
}
.soflo-dir-events__row:last-child { border-bottom: none; }
.soflo-dir-events__row.is-tonight { background: var(--blue-50, #eff3ff); }
.soflo-dir-events__date-col { min-width: 72px; display: flex; flex-direction: column; gap: 0.125rem; }
.soflo-dir-events__day {
    font-size: 0.6875rem; font-weight: 700; letter-spacing: .08em;
    color: var(--ink-3, #8b97c5); text-transform: uppercase;
}
.soflo-dir-events__num { font-size: 0.8125rem; color: var(--ink-2, #3d4f7c); }
.soflo-dir-events__tonight-pill {
    display: inline-flex; align-items: center; margin-top: 0;
    padding: 0.125rem 0.4375rem; background: var(--blue-500, #3b6cf2);
    color: white; border-radius: 999px; font-size: 0.5rem; letter-spacing: .1em;
}
.soflo-dir-events__info-col { flex: 1; display: flex; flex-direction: column; gap: 0.2rem; min-width: 0; }
.soflo-dir-events__artist {
    font-size: 0.9375rem; font-weight: 700; color: var(--ink, #0d1b3e);
    font-family: 'Bricolage Grotesque', sans-serif;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.soflo-dir-events__meta {
    display: flex; align-items: center; gap: 0.3rem;
    font-size: 0.75rem; color: var(--ink-3, #8b97c5); letter-spacing: .03em;
    flex-wrap: wrap;
}
.soflo-dir-events__time { color: var(--ink-3, #8b97c5); }
.soflo-dir-events__sep { color: var(--ink-3, #8b97c5); opacity: .5; }
.soflo-dir-events__cover { color: var(--ink-2, #3d4f7c); font-weight: 600; }
.soflo-dir-events__cover.is-free { color: var(--blue-500, #3b6cf2); font-weight: 700; }
.soflo-dir-events__gate {
    position: relative; overflow: hidden;
    border: 1.5px solid var(--line, #e9ebf5); border-top: none;
    border-radius: 0 0 0.875rem 0.875rem;
}
.soflo-dir-events__gate-rows { filter: blur(4px); user-select: none; pointer-events: none; padding-bottom: 1.25rem; }
.soflo-dir-events__gate-cta {
    position: absolute; inset: 0;
    display: flex; flex-direction: column; align-items: center; justify-content: flex-end; gap: 0.75rem; padding-bottom: 0.9rem;
    background: rgba(255,255,255,0.75); backdrop-filter: blur(2px);
}
.soflo-dir-events__gate-msg {
    font-size: 0.875rem; font-weight: 600; color: var(--ink, #0d1b3e); margin: 0; text-align: center;
}
.soflo-dir-events__gate-btn {
    display: inline-flex; align-items: center;
    padding: 0.75rem 1.75rem; background: var(--blue-500, #3b6cf2);
    color: white; border-radius: 999px; border: none;
    font-size: 0.8125rem; font-weight: 700; letter-spacing: .05em;
    text-decoration: none; transition: background .15s, transform .15s;
}
.soflo-dir-events__gate-btn:hover { background: var(--navy-700, #1a3a7c); transform: translateY(-1px); }
.soflo-dir-events__footer { margin-top: 1rem; }
.soflo-dir-events__footer--social {
    display: flex; align-items: center; flex-wrap: wrap; gap: 0.5rem 1rem; margin-top: 1rem;
}
.soflo-dir-events__social {
    display: inline-flex; align-items: center; gap: 0.4375rem;
    font-size: 0.75rem; font-weight: 700; letter-spacing: .04em;
    color: var(--ink-2, #3d4f7c); text-decoration: none;
}
.soflo-dir-events__social:hover { color: var(--ink, #0d1b3e); }
/* ── Venue cover chip (brand blue) ──────────────────────────────────────────── */
.soflo-venue-card__cover-chip {
    display: inline-flex; align-items: center;
    padding: 0.375rem 0.875rem;
    background: var(--blue-500, #3b6cf2); color: white;
    border-radius: 999px;
    font-size: 0.75rem; font-weight: 700; letter-spacing: .08em;
    white-space: nowrap; font-family: 'JetBrains Mono', monospace;
}

/* ── Event row remind bell button ────────────────────────────────────────────── */
.soflo-dir-events__remind {
    width: 34px; height: 34px; border-radius: 50%;
    border: 1.5px solid var(--line, #e9ebf5); background: none; cursor: pointer;
    color: var(--ink-3, #8b97c5); display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; transition: border-color .15s, color .15s, background .15s;
}
.soflo-dir-events__remind:hover {
    border-color: var(--blue-500, #3b6cf2); color: var(--blue-500, #3b6cf2);
    background: var(--blue-50, #eff3ff);
}

/* ── Venue detail genre tags (larger, colored) ──────────────────────────────── */
.soflo-dir-detail__genre-tag {
    display: inline-flex; align-items: center;
    padding: 0.4375rem 1rem;
    border-radius: 999px;
    font-size: 0.75rem; font-weight: 700; letter-spacing: .07em;
    color: white; white-space: nowrap;
}

/* ── Photo strip ─────────────────────────────────────────────────────────────── */
.soflo-venue-photos {
    background: #0d1b3e; padding: 0.75rem 0;
    display: flex; align-items: center;
}
.soflo-venue-photos__track {
    display: flex; gap: 0.5rem; padding: 0;
    overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none;
    scroll-behavior: smooth; flex: 1; min-width: 0;
}
.soflo-venue-photos__track::-webkit-scrollbar { display: none; }
.soflo-venue-photos__item {
    flex-shrink: 0; width: 220px; height: 140px;
    border-radius: 0.5rem; overflow: hidden;
    cursor: pointer; transition: opacity .2s;
}
.soflo-venue-photos__item:hover { opacity: .88; }
.soflo-venue-photos__item img { width: 100%; height: 100%; object-fit: cover; }
.soflo-venue-photos__arrow {
    flex-shrink: 0; width: 36px; height: 36px; border-radius: 50%;
    background: rgba(255,255,255,.25); border: 1.5px solid rgba(255,255,255,.55);
    color: white; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background .15s, opacity .15s;
    margin: 0 0.75rem;
}
.soflo-venue-photos__arrow:hover { background: rgba(255,255,255,.42); }
.soflo-venue-photos__arrow--prev { }
.soflo-venue-photos__arrow--next { }
.soflo-venue-photos__arrow[disabled] { opacity: 0.25; pointer-events: none; }

/* ── Rating badge ────────────────────────────────────────────────────────────── */
.soflo-dir-detail__rating {
    display: flex; align-items: center; gap: 0.625rem; margin-bottom: 0.875rem;
}
.soflo-dir-detail__rating-score {
    font-size: 2.25rem; font-weight: 800; color: var(--ink, #0d1b3e);
    line-height: 1; font-family: 'Bricolage Grotesque', sans-serif;
}
.soflo-dir-detail__rating-stars { display: flex; gap: 2px; }
.soflo-dir-detail__rating-count { font-size: 0.8125rem; color: var(--ink-3, #8b97c5); }

/* ── Vibe bar ────────────────────────────────────────────────────────────────── */
.soflo-dir-detail__vibes {
    display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1.25rem; margin-bottom: 0.25rem;
}
.soflo-dir-detail__vibe-tag {
    display: inline-flex; align-items: center; gap: 0.375rem;
    padding: 0.5rem 1rem;
    background: var(--paper-2, #f8f9ff); border: 1px solid var(--line, #e9ebf5);
    border-radius: 999px; font-size: 0.8125rem; font-weight: 600;
    color: var(--ink-2, #3d4f7c);
}
.soflo-dir-detail__vibe-tag svg { flex-shrink: 0; color: var(--blue-500, #3b6cf2); }

/* ── Best for / pick block ──────────────────────────────────────────────────── */
.soflo-venue-pick-block {
    background: var(--paper-2, #f8f9ff); border: 1px solid var(--line, #e9ebf5);
    border-radius: 10px; padding: 0.875rem 1.125rem; margin: 1.5rem 0 1rem;
}
.soflo-venue-pick-block__label {
    font-size: 0.625rem; letter-spacing: .12em; color: var(--blue-500, #3b6cf2); display: block; margin-bottom: 0.25rem;
}
.soflo-venue-pick-block__text { margin: 0; font-size: 0.9375rem; color: var(--ink-2, #3d4f7c); font-style: italic; }

/* ── Venue address line ─────────────────────────────────────────────────────── */
.soflo-venue-address {
    display: flex; align-items: center; gap: 0.375rem; margin: 0.75rem 0;
    font-size: 0.8rem; letter-spacing: .03em; color: var(--ink-3, #8b97c5);
}
.soflo-venue-address a { color: var(--ink-3, #8b97c5); text-decoration: none; }
.soflo-venue-address a:hover { color: var(--blue-500, #3b6cf2); text-decoration: underline; }
.soflo-venue-address svg { flex-shrink: 0; }

/* ── Featured video ──────────────────────────────────────────────────────────── */
.soflo-dir-video { padding: 2.5rem 1.5rem; border-top: 1px solid var(--line, #e9ebf5); }
.soflo-dir-video__col { margin-top: 1.25rem; }
.soflo-dir-video__inner { max-width: 820px; margin: 0 auto; }
.soflo-dir-video__label {
    font-size: 0.625rem; letter-spacing: .14em; color: var(--ink-3, #8b97c5); margin: 0 0 1rem;
}
.soflo-dir-video__embed {
    position: relative; aspect-ratio: 16/9;
    border-radius: 0.875rem; overflow: hidden; background: #0d1b3e;
}
.soflo-dir-video__embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }

/* ── Community reviews ───────────────────────────────────────────────────────── */
.soflo-dir-reviews { padding: 2.5rem 1.5rem; border-top: 1px solid var(--line, #e9ebf5); }
.soflo-dir-reviews__inner { max-width: 820px; margin: 0 auto; width: 100%; }
.soflo-dir-reviews__head {
    display: flex; flex-wrap: wrap; gap: 1rem;
    align-items: flex-start; margin-bottom: 2rem;
}
.soflo-dir-reviews__title {
    font-size: 0.625rem; letter-spacing: .14em;
    color: var(--ink-3, #8b97c5); margin: 0 0 0.75rem;
}
.soflo-dir-reviews__summary { display: flex; align-items: center; gap: 0.875rem; }
.soflo-dir-reviews__avg {
    font-size: 3.5rem; font-weight: 800; color: var(--ink, #0d1b3e);
    line-height: 1; font-family: 'Bricolage Grotesque', sans-serif;
}
.soflo-dir-reviews__stars { display: flex; gap: 2px; margin-bottom: 0.25rem; }
.soflo-dir-reviews__count { font-size: 0.8125rem; color: var(--ink-3, #8b97c5); }
.soflo-dir-reviews__list { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 2rem; }
.soflo-dir-reviews__card {
    background: white; border: 1.5px solid var(--line, #e9ebf5);
    border-radius: 0.875rem; padding: 1.125rem 1.25rem;
}
.soflo-dir-reviews__card-head {
    display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0.75rem;
}
.soflo-dir-reviews__avatar {
    width: 2.25rem; height: 2.25rem; border-radius: 50%;
    background: var(--blue-500, #3b6cf2); color: white;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 0.9375rem; flex-shrink: 0;
    font-family: 'Bricolage Grotesque', sans-serif;
}
.soflo-dir-reviews__name { font-size: 0.9375rem; font-weight: 700; color: var(--ink, #0d1b3e); }
.soflo-dir-reviews__card-stars { display: flex; gap: 1px; margin-top: 0.1875rem; }
.soflo-dir-reviews__date {
    font-size: 0.625rem; color: var(--ink-3, #8b97c5);
    margin-left: auto; letter-spacing: .05em; flex-shrink: 0;
}
.soflo-dir-reviews__text {
    font-size: 0.9375rem; color: var(--ink-2, #3d4f7c); line-height: 1.65; margin: 0;
}
.soflo-dir-reviews__form {
    background: var(--paper-2, #f8f9ff); border: 1.5px solid var(--line, #e9ebf5);
    border-radius: 1rem; padding: 1.5rem;
}
.soflo-dir-reviews__form-title {
    font-size: 1.0625rem; font-weight: 700; color: var(--ink, #0d1b3e);
    margin: 0 0 1rem; font-family: 'Bricolage Grotesque', sans-serif;
}
.soflo-dir-reviews__star-pick { display: flex; gap: 0.25rem; margin-bottom: 1rem; }
.soflo-dir-reviews__star {
    background: none; border: none; cursor: pointer; padding: 0;
    color: #d1d5db; transition: color .15s, transform .1s;
    line-height: 0;
}
.soflo-dir-reviews__star:hover,
.soflo-dir-reviews__star.is-hover,
.soflo-dir-reviews__star.is-active { color: #f59e0b; transform: scale(1.1); }
.soflo-dir-reviews__textarea {
    width: 100%; padding: 0.75rem 1rem; box-sizing: border-box;
    border: 1.5px solid var(--line, #e9ebf5); border-radius: 0.625rem;
    font-size: 0.9375rem; font-family: inherit; color: var(--ink, #0d1b3e);
    resize: vertical; margin-bottom: 1rem; background: white; transition: border-color .15s;
}
.soflo-dir-reviews__textarea:focus { outline: none; border-color: var(--blue-500, #3b6cf2); }
.soflo-dir-reviews__submit {
    background: var(--navy-950, #0b1f6b); color: white; border: none;
    padding: 0.75rem 1.5rem; border-radius: 0.625rem;
    font-size: 0.625rem; font-weight: 700; letter-spacing: .1em;
    cursor: pointer; transition: background .15s;
}
.soflo-dir-reviews__submit:hover { background: var(--blue-500, #3b6cf2); }
.soflo-dir-reviews__submit:disabled { opacity: .5; cursor: not-allowed; }
.soflo-dir-reviews__login-cta {
    text-align: center; padding: 2rem 1.5rem;
    background: var(--paper-2, #f8f9ff); border-radius: 0.875rem;
    font-size: 0.9375rem; color: var(--ink-2, #3d4f7c);
}
.soflo-dir-reviews__login-link {
    color: var(--blue-500, #3b6cf2); font-weight: 700; text-decoration: none;
}
.soflo-dir-reviews__login-link:hover { text-decoration: underline; }
.soflo-dir-reviews__success {
    text-align: center; padding: 2rem; color: var(--blue-500, #3b6cf2);
    font-weight: 600; font-size: 1rem;
}

/* ── Photo lightbox ──────────────────────────────────────────────────────────── */
.soflo-lightbox {
    position: fixed; inset: 0; z-index: 9000;
    background: rgba(0,0,0,.93);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none; transition: opacity .2s;
}
.soflo-lightbox.is-open { opacity: 1; pointer-events: all; }
.soflo-lightbox__img {
    max-width: 90vw; max-height: 85vh;
    object-fit: contain; border-radius: 0.5rem; display: block;
    user-select: none;
}
.soflo-lightbox__close {
    position: absolute; top: 1rem; right: 1rem;
    background: rgba(255,255,255,.14); border: none; cursor: pointer;
    color: white; width: 2.5rem; height: 2.5rem;
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    font-size: 1.375rem; line-height: 1; transition: background .15s; z-index: 2;
}
.soflo-lightbox__close:hover { background: rgba(255,255,255,.26); }
.soflo-lightbox__prev,
.soflo-lightbox__next {
    position: absolute; top: 50%; transform: translateY(-50%);
    background: rgba(255,255,255,.14); border: none; cursor: pointer;
    color: white; width: 3rem; height: 3rem;
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    transition: background .15s; z-index: 2;
}
.soflo-lightbox__prev { left: 1.25rem; }
.soflo-lightbox__next { right: 1.25rem; }
.soflo-lightbox__prev:hover,
.soflo-lightbox__next:hover { background: rgba(255,255,255,.28); }
.soflo-lightbox__counter {
    position: absolute; bottom: 1.25rem; left: 50%; transform: translateX(-50%);
    color: rgba(255,255,255,.65); font-size: 0.6875rem;
    font-family: 'JetBrains Mono', monospace; letter-spacing: .1em;
    background: rgba(0,0,0,.35); padding: 0.25rem 0.75rem; border-radius: 999px;
}

/* ── Events remind label ─────────────────────────────────────────────────────── */
.soflo-dir-events__remind-label {
    font-size: 0.5625rem; letter-spacing: .08em; margin-left: 0.25rem;
    font-family: 'JetBrains Mono', monospace;
}

/* ── Local Tips review card (simplified, no stars) ───────────────────────────── */
.soflo-dir-reviews__card-head--simple {
    display: flex; align-items: center; gap: 0.625rem;
}
.soflo-dir-reviews__card-head--simple .soflo-dir-reviews__name {
    flex: 1; font-size: 0.875rem; font-weight: 700; color: var(--ink);
}

/* ── Google rating link ──────────────────────────────────────────────────────── */
.soflo-dir-detail__rating-link {
    display: inline-flex; align-items: center; gap: 0.375rem;
    text-decoration: none; color: inherit;
}
.soflo-dir-detail__rating-link:hover .soflo-dir-detail__rating-count { text-decoration: underline; }
.soflo-dir-detail__rating-google {
    display: inline-flex; align-items: center; gap: 0.25rem;
    font-size: 0.6875rem; color: var(--ink-3, #8b97c5);
    font-family: 'JetBrains Mono', monospace; letter-spacing: .04em;
    padding-left: 0.375rem;
    border-left: 1px solid var(--line, #e9ebf5);
}

.soflo-dir-detail__tonight-lbl {
    color: var(--ink-3, #8b97c5); margin-right: 0.1em;
}
.soflo-venue-card__cover-lbl {
    opacity: 0.72;
}

.soflo-dir-events__list + .soflo-dir-events__gate ~ * { }
.soflo-dir-events__list:has(+ .soflo-dir-events__gate) {
    border-bottom: none; border-radius: 0.875rem 0.875rem 0 0;
}

/* ── 320-420px venue detail fixes ──────────────────────────────────────────── */
@media (max-width: 420px) {
    .soflo-gig-detail__info-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
    .soflo-dir-reviews { padding: 2rem 1.125rem; }
    .soflo-venue-photos { overflow-x: hidden; }
}
@media (max-width: 360px) {
    .soflo-gig-detail__body { padding: 1.5rem 1rem 2rem; }
    .soflo-dir-events__row { padding: 0.75rem 0.875rem; gap: 0.625rem; }
    .soflo-dir-events__date-col { min-width: 60px; }
    .soflo-dir-detail__tonight { font-size: 0.75rem; }
    .soflo-dir-reviews { padding: 1.75rem 1rem; }
    .soflo-gig-detail__hero-inner { padding: calc(5.375rem + 1rem) 1rem 2rem; }
}


/* ══════════════════════════════════════════════════════════════════════════════
   Full-width auth pages (.soflo-auth-full)
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-auth-full {
    display: flex;
    min-height: 100vh;
}
.soflo-auth-full__left {
    flex: 0 0 42%;
    background: var(--navy-950);
    padding: 4rem 3.5rem;
    display: flex;
    flex-direction: column;
    gap: 0;
    position: relative;
}
.soflo-auth-full__logo-link { display: block; margin-bottom: 3rem; }
.soflo-auth-full__logo { height: 3.5rem; width: auto; filter: brightness(0) invert(1); }
.soflo-auth-full__tagline {
    font-family: 'Bricolage Grotesque', 'Inter', sans-serif;
    font-size: clamp(1.375rem, 2.5vw, 1.875rem);
    font-weight: 700;
    color: white;
    line-height: 1.3;
    margin: 0 0 2.5rem;
    letter-spacing: -.02em;
}
.soflo-auth-full__perks {
    list-style: none;
    padding: 0; margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
    margin-top: 2.5rem;
}
.soflo-auth-full__perks li {
    font-size: 0.9375rem;
    color: rgba(255,255,255,.7);
    display: flex;
    align-items: center;
    gap: 0.625rem;
}
.soflo-auth-full__perks li::before { content: '\2713'; color: #38bdf8; font-weight: 700; }
.soflo-auth-full__right {
    flex: 1;
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4rem 3rem;
    overflow-y: auto;
}
.soflo-auth-full__form-wrap { width: 100%; max-width: 26rem; }
.soflo-auth-full__logo-mobile-wrap { display: none; margin-bottom: 2rem; text-align: center; }
.soflo-auth-full__logo-mobile { height: 2.75rem; width: auto; }
.soflo-auth-full__h1 {
    font-size: clamp(1.625rem, 3vw, 2.125rem);
    margin: 0 0 0.5rem;
    color: var(--ink);
}
.soflo-auth-full__sub { font-size: 0.9375rem; color: var(--ink-2); margin: 0 0 1.75rem; }
.soflo-auth-full__switch {
    font-size: 0.875rem;
    color: var(--ink-3);
    margin-top: 1.25rem;
    text-align: center;
}
.soflo-auth-full__switch a { color: var(--blue-500); font-weight: 600; }

/* Nav in "scrolled" state on full-width auth pages */
body:has(.soflo-auth-full) .soflo-nav {
    background: rgba(255,255,255,0.96);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom-color: var(--line);
}
body:has(.soflo-auth-full) .soflo-nav__link { color: var(--ink); }
body:has(.soflo-auth-full) .soflo-nav__link:hover { background: rgba(11,31,107,.06); }
body:has(.soflo-auth-full) .soflo-nav__login { color: var(--ink); }
body:has(.soflo-auth-full) .soflo-nav__logo-img--default { display: none; }
body:has(.soflo-auth-full) .soflo-nav__logo-img--sticky  { display: block; }

/* Nav in scrolled state on light-background pages (dashboard, interior, calendar) */
body:has(.soflo-dash) .soflo-nav,
body:has(.soflo-interior) .soflo-nav,
body:has(.soflo-calendar-page) .soflo-nav {
    background: rgba(255,255,255,0.96);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom-color: var(--line);
    box-shadow: 0 1px 0 var(--line);
}
body:has(.soflo-dash) .soflo-nav__link,
body:has(.soflo-interior) .soflo-nav__link,
body:has(.soflo-calendar-page) .soflo-nav__link { color: var(--ink); }
body:has(.soflo-dash) .soflo-nav__link:hover,
body:has(.soflo-interior) .soflo-nav__link:hover,
body:has(.soflo-calendar-page) .soflo-nav__link:hover { background: rgba(11,31,107,.06); }
body:has(.soflo-dash) .soflo-nav__login,
body:has(.soflo-interior) .soflo-nav__login,
body:has(.soflo-calendar-page) .soflo-nav__login { color: var(--ink); }
body:has(.soflo-dash) .soflo-nav__logo-img--default,
body:has(.soflo-interior) .soflo-nav__logo-img--default,
body:has(.soflo-calendar-page) .soflo-nav__logo-img--default { display: none; }
body:has(.soflo-dash) .soflo-nav__logo-img--sticky,
body:has(.soflo-interior) .soflo-nav__logo-img--sticky,
body:has(.soflo-calendar-page) .soflo-nav__logo-img--sticky  { display: block; }
.soflo-auth-consent {
    display: flex;
    align-items: flex-start;
    gap: 0.625rem;
    font-size: 0.8125rem;
    color: var(--ink-2);
    line-height: 1.5;
    cursor: pointer;
}
.soflo-auth-consent input[type="checkbox"] {
    margin-top: 0.15em;
    accent-color: var(--blue-500);
    flex-shrink: 0;
    width: 1rem; height: 1rem;
}
.soflo-auth-form__divider { border: none; border-top: 1px solid var(--line); margin: 0.25rem 0; }
.soflo-auth-required { color: #e11d48; font-size: 0.8125rem; }
.soflo-auth-hint     { color: var(--ink-3); font-weight: 400; font-size: 0.75rem; }
@media (max-width: 820px) {
    .soflo-auth-full            { flex-direction: column; min-height: auto; }
    .soflo-auth-full__left      { display: none; }
    .soflo-auth-full__right     { padding: 3rem 1.5rem 4rem; align-items: flex-start; }
    .soflo-auth-full__form-wrap { max-width: 100%; }
    .soflo-auth-full__logo-mobile-wrap { display: block; }
}

/* ── Legal pages ──────────────────────────────────────────────────────────── */
.soflo-legal-page { max-width: 48rem; }
.soflo-legal-page h2 { font-size: 1.125rem; font-weight: 700; color: var(--ink); margin: 2rem 0 .5rem; }
.soflo-legal-page p, .soflo-legal-page li { font-size: .9375rem; color: var(--ink-2); line-height: 1.7; }
.soflo-legal-page ul { padding-left: 1.375rem; margin: .5rem 0 1rem; }
.soflo-legal-page ul li { margin-bottom: .25rem; }
.soflo-legal-page a { color: var(--blue-500); }
.soflo-legal-page__date { font-size: .8125rem; color: var(--ink-3); margin: -.5rem 0 2rem; }
.soflo-legal-page__table { width: 100%; border-collapse: collapse; margin: 1rem 0 1.5rem; font-size: .875rem; }
.soflo-legal-page__table th { background: var(--paper-2); padding: .625rem .875rem; text-align: left; font-weight: 600; border: 1px solid var(--line); }
.soflo-legal-page__table td { padding: .625rem .875rem; border: 1px solid var(--line); color: var(--ink-2); vertical-align: top; }
/* Sitemap grid */
.soflo-sitemap-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 2rem 2.5rem; margin-top: 1.5rem; }
.soflo-sitemap-grid h2 { font-size: 1rem; font-weight: 700; color: var(--ink); margin: 0 0 .625rem; }
.soflo-sitemap-grid ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .4rem; }
.soflo-sitemap-grid li a { font-size: .9rem; color: var(--blue-500); }
.soflo-sitemap-grid li a:hover { text-decoration: underline; }

/* ══════════════════════════════════════════════════════════════════════════════
   Dashboard v2 (.soflo-dash)
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-dash { background: var(--paper-2, #f4f5f9); min-height: calc(100vh - 5.5rem); padding: 2.5rem 0 5rem; }
.soflo-dash__inner { max-width: 860px; margin: 0 auto; padding: 0 1.5rem; }

/* Header */
.soflo-dash__header { display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; flex-wrap: wrap; }
.soflo-dash__avatar {
    width: 3.25rem; height: 3.25rem; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.375rem; font-weight: 700; color: white; flex-shrink: 0;
}
.soflo-dash__avatar--fan    { background: var(--blue-500, #3b82f6); }
.soflo-dash__avatar--venue  { background: #7c3aed; }
.soflo-dash__avatar--artist { background: #db2777; }
.soflo-dash__header-text { flex: 1; min-width: 0; }
.soflo-dash__name { font-size: clamp(1.375rem, 3vw, 1.875rem); margin: 0 0 .25rem; color: var(--ink); }
.soflo-dash__role-pill {
    display: inline-block; font-size: .625rem; letter-spacing: .1em; padding: .2em .7em;
    border-radius: 999px; font-weight: 700;
}
.soflo-dash__role-pill--fan    { background: #dbeafe; color: #1d4ed8; }
.soflo-dash__role-pill--venue  { background: #ede9fe; color: #6d28d9; }
.soflo-dash__role-pill--artist { background: #fce7f3; color: #be185d; }
.soflo-dash__explore {
    padding: .625rem 1.125rem; border-radius: .75rem; background: var(--navy-950);
    color: white; font-size: .75rem; letter-spacing: .05em; white-space: nowrap; margin-left: auto;
}
.soflo-dash__explore:hover { background: var(--navy-800); }

/* Pending banner */
.soflo-dash__pending-banner {
    display: flex; align-items: flex-start; gap: 1rem;
    background: #fffbeb; border: 1px solid #fcd34d; border-radius: 1rem;
    padding: 1.125rem 1.375rem; margin-bottom: 1.75rem;
}
.soflo-dash__pending-icon { font-size: 1.5rem; flex-shrink: 0; margin-top: .125rem; }
.soflo-dash__pending-banner p { margin: .25rem 0 0; font-size: .875rem; color: var(--ink-2); }

/* Tab nav */
.soflo-dash__tabs {
    display: flex; gap: .375rem; margin-bottom: 1.5rem;
    border-bottom: 2px solid var(--line); padding-bottom: 0;
    overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.soflo-dash__tabs::-webkit-scrollbar { display: none; }
.soflo-dash__tab {
    display: flex; align-items: center; gap: .4rem;
    padding: .625rem 1rem; border-radius: .625rem .625rem 0 0;
    font-size: .875rem; font-weight: 500; color: var(--ink-2);
    white-space: nowrap; border-bottom: 2px solid transparent; margin-bottom: -2px;
    transition: color .15s, border-color .15s;
}
.soflo-dash__tab:hover { color: var(--ink); }
.soflo-dash__tab.is-active { color: var(--navy-950); border-bottom-color: var(--navy-950); font-weight: 600; }
.soflo-dash__tab-icon { font-size: 1rem; }

/* Panels */
.soflo-dash__panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.125rem; }
.soflo-dash__panel-title { font-size: 1.125rem; font-weight: 700; color: var(--ink); margin: 0 0 1.125rem; }
.soflo-dash__panel-head .soflo-dash__panel-title { margin: 0; }

/* Cards */
.soflo-dash__card {
    background: white; border: 1px solid var(--line); border-radius: 1rem; padding: 1.5rem;
}
.soflo-dash__card--profile { display: flex; align-items: center; gap: 1.25rem; }
.soflo-dash__card-h3 { font-size: .9375rem; font-weight: 700; color: var(--ink); margin: 0 0 1rem; }
.soflo-dash__card-desc { font-size: .9375rem; color: var(--ink-2); margin: 0 0 1rem; line-height: 1.6; }
.soflo-dash__card-fine { font-size: .8125rem; color: var(--ink-2); margin: .25rem 0; line-height: 1.5; }

/* Profile block */
.soflo-dash__profile-avatar {
    width: 4rem; height: 4rem; border-radius: 50%;
    background: #db2777; color: white; font-size: 1.75rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.soflo-dash__profile-name  { font-size: 1.125rem; font-weight: 700; color: var(--ink); }
.soflo-dash__profile-genre { font-size: .6875rem; letter-spacing: .1em; color: var(--ink-3); margin-top: .25rem; }
.soflo-dash__profile-ig    { font-size: .875rem; color: var(--blue-500); margin-top: .375rem; }
.soflo-dash__profile-ig a  { color: inherit; }

/* Info rows in account tab */
.soflo-dash__info-row { display: flex; gap: 1rem; padding: .625rem 0; border-bottom: 1px solid var(--line); font-size: .9375rem; }
.soflo-dash__info-row:last-child { border: none; }
.soflo-dash__info-label { color: var(--ink-3); min-width: 7.5rem; font-size: .8125rem; font-weight: 600; letter-spacing: .02em; }

/* List rows */
.soflo-dash__list { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: 1rem; overflow: hidden; background: white; }
.soflo-dash__list-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: .875rem 1.25rem; border-bottom: 1px solid var(--line); }
.soflo-dash__list-row:last-child { border: none; }
.soflo-dash__list-left { display: flex; flex-direction: column; gap: .1875rem; min-width: 0; flex: 1; }
.soflo-dash__list-name { font-size: .9375rem; font-weight: 500; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.soflo-dash__list-meta { font-size: .75rem; color: var(--ink-3); }
.soflo-dash__list-right { display: flex; align-items: center; gap: .625rem; flex-shrink: 0; }
.soflo-dash__status { font-size: .625rem; letter-spacing: .1em; padding: .25em .7em; border-radius: 999px; }
.soflo-dash__status--live  { background: #dcfce7; color: #166534; }
.soflo-dash__status--draft { background: #f3f4f6; color: #6b7280; }
.soflo-dash__link { font-size: .8125rem; color: var(--blue-500); font-weight: 500; letter-spacing: .02em; }
.soflo-dash__link:hover { text-decoration: underline; }

/* Empty state */
.soflo-dash__empty { display: flex; flex-direction: column; align-items: center; padding: 3rem 1.5rem; text-align: center; background: white; border: 1px solid var(--line); border-radius: 1rem; }
.soflo-dash__empty-icon { font-size: 2.5rem; margin-bottom: .75rem; }
.soflo-dash__empty p { font-size: .9375rem; color: var(--ink-2); margin: 0 0 1.25rem; max-width: 24rem; line-height: 1.6; }
.soflo-dash__cta { font-size: .8125rem; color: var(--blue-500); font-weight: 600; letter-spacing: .04em; }
.soflo-dash__cta:hover { text-decoration: underline; }

/* Buttons */
.soflo-dash__btn {
    display: inline-flex; align-items: center; gap: .375rem;
    padding: .625rem 1.25rem; border-radius: .75rem;
    background: var(--navy-950); color: white; border: none; cursor: pointer;
    font-size: .75rem; letter-spacing: .05em; font-weight: 700; transition: background .15s;
}
.soflo-dash__btn:hover { background: var(--navy-800); }
.soflo-dash__btn--ghost {
    background: transparent; color: var(--ink-2);
    border: 1.5px solid var(--line);
}
.soflo-dash__btn--ghost:hover { border-color: #ef4444; color: #ef4444; background: transparent; }

/* Consent */
.soflo-dash__consent-row { margin: .75rem 0 1.25rem; }
.soflo-dash__badge { display: inline-block; font-size: .6875rem; letter-spacing: .08em; padding: .25em .875em; border-radius: 999px; }
.soflo-dash__badge--green { background: #dcfce7; color: #166534; }
.soflo-dash__badge--gray  { background: #f3f4f6; color: #6b7280; }

/* Password form */
.soflo-dash__form { display: flex; flex-direction: column; gap: .875rem; margin-top: .5rem; }
.soflo-dash__form-row { display: flex; flex-direction: column; gap: .3rem; }
.soflo-dash__form-row label { font-size: .8125rem; font-weight: 600; color: var(--ink); }
.soflo-dash__input {
    padding: .6875rem .9375rem; border: 1.5px solid var(--line); border-radius: .75rem;
    font-size: .9375rem; font-family: inherit; color: var(--ink); background: white;
    transition: border-color .15s; width: 100%; max-width: 22rem; box-sizing: border-box;
}
.soflo-dash__input:focus { outline: none; border-color: var(--blue-500); }

/* Alerts */
.soflo-dash__alert { padding: .75rem 1rem; border-radius: .625rem; font-size: .875rem; margin-bottom: .875rem; }
.soflo-dash__alert--ok  { background: #dcfce7; color: #166534; }
.soflo-dash__alert--err { background: #fee2e2; color: #991b1b; }

/* Hint text */
.soflo-dash__hint { font-size: .8125rem; color: var(--ink-3); margin-top: .75rem; }
.soflo-dash__hint a { color: var(--blue-500); }

/* Responsive */
@media (max-width: 600px) {
    .soflo-dash__inner  { padding: 0 1rem; }
    .soflo-dash__explore { display: none; }
    .soflo-dash__list-name { font-size: .875rem; }
    .soflo-dash__card--profile { flex-direction: column; align-items: flex-start; }
}
/* ── Mobile stacking (≤480px → 320px) ───────────────────────────────────────── */
@media (max-width: 480px) {

    /* Tonight detail pill: badge on row 1, gig text on row 2 */
    .soflo-dir-detail__tonight {
        flex-wrap: wrap;
        max-width: 100%;
        box-sizing: border-box;
    }
    .soflo-dir-detail__tonight-gig {
        flex: 0 0 100%;
        white-space: normal;
        word-break: break-word;
        font-size: 0.875rem;
        line-height: 1.4;
        margin-top: 0.125rem;
    }

    /* Rating: score+stars on row 1, reviews+Google on row 2 */
    .soflo-dir-detail__rating { flex-wrap: wrap; row-gap: 0.375rem; }
    .soflo-dir-detail__rating-link { flex: 0 0 100%; }

    /* Events row: column stack — date → tonight pill → artist → meta → bell */
    .soflo-dir-events__row {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.25rem;
        padding: 0.875rem 1rem;
    }
    .soflo-dir-events__date-col {
        flex-direction: row;
        align-items: center;
        flex-wrap: wrap;
        gap: 0.375rem;
        min-width: 0;
        width: 100%;
    }
    .soflo-dir-events__info-col { width: 100%; }
    .soflo-dir-events__artist {
        white-space: normal;
        overflow: visible;
        text-overflow: clip;
    }
    .soflo-dir-events__meta { flex-wrap: wrap; gap: 0.2rem 0.3rem; }
    .soflo-dir-events__remind {
        align-self: flex-end;
        margin-top: 0.375rem;
    }

    /* Map col + video: prevent horizontal overflow */
    .soflo-gig-detail__map-col { max-width: 100%; overflow: hidden; }
    .soflo-gig-detail__map { max-width: 100%; }
    .soflo-dir-video { padding: 2rem 1rem; overflow: hidden; }
    .soflo-dir-video__inner { max-width: 100%; }
    .soflo-gig-detail__body-wrap { overflow-x: hidden; }
}

/* ── Structured hours schedule ───────────────────────────────────────────────── */
.soflo-hours-schedule { display: flex; flex-direction: column; gap: 0.25rem; }
.soflo-hours-row { display: flex; align-items: baseline; gap: 0.5rem; }
.soflo-hours-day {
    font-size: 0.6875rem; font-weight: 700; letter-spacing: .06em;
    color: var(--ink-3, #8b97c5); text-transform: uppercase;
    min-width: 2.75rem; flex-shrink: 0;
}
.soflo-hours-val { font-size: 0.9375rem; font-weight: 700; color: var(--ink, #0d1b3e); }
.soflo-hours-closed { color: var(--ink-3, #8b97c5); font-weight: 400; font-style: italic; font-size: 0.875rem; }

/* ── Secondary info (capacity / parking — muted) ─────────────────────────────── */
.soflo-gig-detail__secondary-info {
    font-size: 0.6875rem; letter-spacing: .06em; color: var(--ink-3, #8b97c5);
    margin: -1.5rem 0 2.25rem; text-transform: uppercase;
}

/* ── Mobile social stacking + tonight centering + bell left (≤480px) ─────────── */
@media (max-width: 480px) {
    /* Tonight detail pill: center dot+badge and gig line */
    .soflo-dir-detail__tonight { justify-content: center; }
    .soflo-dir-detail__tonight-gig { text-align: center; }

    /* Bell: left-aligned (not pushed to far right) */
    .soflo-dir-events__remind { align-self: flex-start; }

    /* Social links: stack vertically */
    .soflo-dir-events__footer--social { flex-direction: column; align-items: flex-start; gap: 0.5rem; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   Join page: type-selection cards + confirmation
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-join-types { display: flex; flex-direction: column; gap: 0.75rem; margin-top: 1.5rem; }
.soflo-join-type {
    display: flex; flex-direction: column; gap: 0.25rem;
    padding: 1rem 1.125rem;
    border: 1.5px solid var(--line, #e9ebf5); border-radius: 0.75rem;
    text-decoration: none; color: var(--ink, #0d1b3e); background: #fff;
    transition: border-color .15s, box-shadow .15s; position: relative; cursor: pointer;
}
.soflo-join-type:hover { border-color: var(--blue-500, #3b55e6); box-shadow: 0 2px 12px rgba(59,85,230,.09); }
.soflo-join-type__icon  { font-size: 1.5rem; margin-bottom: 0.125rem; }
.soflo-join-type__title { font-size: 1.0625rem; font-weight: 700; }
.soflo-join-type__desc  { font-size: 0.8125rem; color: var(--ink-2, #4a5380); line-height: 1.45; }
.soflo-join-type__tag {
    position: absolute; top: 1rem; right: 1rem;
    font-size: 0.625rem; letter-spacing: .10em;
    color: var(--blue-500, #3b55e6); background: var(--blue-50, #edf0fd);
    padding: 0.2rem 0.5rem; border-radius: 100px;
}

.soflo-join-back { margin-bottom: 0.75rem; }
.soflo-join-back__link { font-size: 0.8125rem; color: var(--ink-3, #8b97c5); text-decoration: none; font-weight: 600; }
.soflo-join-back__link:hover { color: var(--ink, #0d1b3e); }
.soflo-auth-required, .soflo-auth-hint { color: var(--ink-3, #8b97c5); font-weight: 400; font-size: 0.75rem; }
.soflo-auth-form__divider { border: none; border-top: 1px solid var(--line, #e9ebf5); margin: 0.25rem 0; }

.soflo-auth-errors { display: flex; flex-direction: column; gap: 0.375rem; margin-bottom: 0.25rem; }
.soflo-auth-error {
    font-size: 0.8125rem; color: #c0392b;
    background: #fdf0ef; border: 1px solid #f5c6c2;
    border-radius: 0.5rem; padding: 0.5rem 0.75rem; margin: 0;
}

.soflo-join-confirm { text-align: center; padding: 0.5rem 0 0.75rem; }
.soflo-join-confirm__icon { font-size: 2.5rem; margin-bottom: 0.375rem; }
.soflo-join-confirm__steps {
    display: flex; margin-top: 1.5rem;
    border: 1.5px solid var(--line, #e9ebf5); border-radius: 0.625rem; overflow: hidden;
}
.soflo-join-confirm__step {
    flex: 1; padding: 0.5rem 0.25rem;
    font-size: 0.625rem; font-weight: 600; letter-spacing: .05em; text-align: center;
    color: var(--ink-3, #8b97c5); background: var(--paper-2, #f8f9ff);
    border-right: 1.5px solid var(--line, #e9ebf5);
}
.soflo-join-confirm__step:last-child { border-right: none; }
.soflo-join-confirm__step--done   { background: var(--blue-50, #edf0fd); color: var(--blue-500, #3b55e6); }
.soflo-join-confirm__step--active { background: var(--blue-500, #3b55e6); color: #fff; }

/* ══════════════════════════════════════════════════════════════════════════════
   Dashboard: pending notice + venue/gig list rows
   ══════════════════════════════════════════════════════════════════════════════ */
.soflo-dashboard__pending {
    display: flex; align-items: flex-start; gap: 0.875rem;
    padding: 1rem 1.25rem; background: #fffbec;
    border: 1.5px solid #f5e28a; border-radius: 0.75rem;
    margin-bottom: 2rem; font-size: 0.875rem;
}
.soflo-dashboard__pending p { margin: 0.25rem 0 0; color: var(--ink-2, #4a5380); font-size: 0.8125rem; }
.soflo-dashboard__pending-icon { font-size: 1.5rem; flex-shrink: 0; }
.soflo-dashboard__section-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.75rem; }
.soflo-dashboard__section-action { font-size: 0.75rem; letter-spacing: .06em; color: var(--blue-500, #3b55e6); text-decoration: none; font-weight: 700; }
.soflo-dashboard__venue-list { display: flex; flex-direction: column; gap: 0.5rem; }
.soflo-dashboard__venue-row {
    display: flex; align-items: center; gap: 0.75rem;
    padding: 0.75rem 1rem; background: #fff;
    border: 1.5px solid var(--line, #e9ebf5); border-radius: 0.625rem;
}
.soflo-dashboard__venue-name   { flex: 1; font-weight: 600; font-size: 0.9375rem; }
.soflo-dashboard__venue-status {
    font-size: 0.625rem; letter-spacing: .08em;
    color: var(--ink-3, #8b97c5); padding: 0.2rem 0.5rem;
    background: var(--paper-2, #f8f9ff); border-radius: 100px;
}
.soflo-dashboard__venue-status--live { background: #e6f9ee; color: #1a7f45; }
.soflo-dashboard__venue-edit { font-size: 0.75rem; letter-spacing: .06em; color: var(--blue-500, #3b55e6); text-decoration: none; font-weight: 700; }


/* ── Editor's Picks strip ────────────────────────────────────────────────── */
.soflo-picks-strip { padding: 2.5rem 0 0; }
.soflo-picks-strip__inner { max-width: 1280px; margin: 0 auto; padding: 0 1.5rem; }
.soflo-picks-strip__head { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.25rem; }
.soflo-picks-strip__badge {
    font-size: .65rem; letter-spacing: .12em; background: #fff3cd; color: #92600a;
    padding: .25rem .6rem; border-radius: 100px; white-space: nowrap;
}
.soflo-picks-strip__title { font-size: clamp(1.1rem, 2vw, 1.4rem); margin: 0; }
.soflo-picks-strip__row {
    display: flex; gap: 1rem; overflow-x: auto; padding-bottom: .5rem;
    scrollbar-width: none;
}
.soflo-picks-strip__row::-webkit-scrollbar { display: none; }

.soflo-picks-card {
    flex: 0 0 200px; text-decoration: none; color: inherit; border-radius: 10px;
    overflow: hidden; border: 1px solid #e8eaf0; transition: box-shadow .2s;
}
.soflo-picks-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.1); }
.soflo-picks-card__img-wrap { position: relative; aspect-ratio: 4/3; overflow: hidden; }
.soflo-picks-card__img { width: 100%; height: 100%; object-fit: cover; }
.soflo-picks-card__genre {
    position: absolute; top: .5rem; left: .5rem; font-size: .6rem; letter-spacing: .1em;
    padding: .2rem .55rem; border-radius: 100px; background: rgba(255,255,255,.9);
}
.soflo-picks-card__body { padding: .6rem .75rem .75rem; }
.soflo-picks-card__name { font-size: .9rem; margin: 0 0 .35rem; }
.soflo-picks-card__city { font-size: .65rem; letter-spacing: .08em; color: #777; }
.soflo-picks-card__follow {
    display: block; margin-top: .5rem; width: 100%; padding: .3rem 0;
    font-size: .65rem; letter-spacing: .1em; border: 1.5px solid currentColor;
    border-radius: 100px; background: none; cursor: pointer; color: #3b55e6;
    transition: background .15s, color .15s;
}
.soflo-picks-card__follow.is-following,
.soflo-picks-card__follow:hover { background: #3b55e6; color: #fff; }




/* ── Artist detail: two-column body ─────────────────────────────────────── */
.soflo-gig-detail__aside {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.soflo-gig-detail__body--two-col {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 2.5rem;
    align-items: start;
}
@media (max-width: 768px) {
    .soflo-gig-detail__body--two-col { grid-template-columns: 1fr; }
    .soflo-gig-detail__aside { order: -1; }
}

/* ── Upcoming shows list ─────────────────────────────────────────────────── */
.soflo-dir-detail__shows-list { margin-top: .75rem; display: flex; flex-direction: column; gap: .5rem; }
.soflo-dir-detail__show-row {
    display: flex; gap: 1rem; align-items: baseline;
    padding: .6rem 0; border-bottom: 1px solid #f0f1f8;
}
.soflo-dir-detail__show-row:last-child { border-bottom: none; }
.soflo-dir-detail__show-date {
    font-size: .7rem; letter-spacing: .07em; color: #8b97c5;
    min-width: 120px; flex-shrink: 0;
}
.soflo-dir-detail__show-info { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; }
.soflo-dir-detail__show-venue {
    font-size: .9rem; font-weight: 600; color: #1a1d2e;
    text-decoration: none;
}
a.soflo-dir-detail__show-venue:hover { color: #3b55e6; }
.soflo-dir-detail__show-price {
    font-size: .65rem; letter-spacing: .08em; background: #f0f1f8;
    padding: .15rem .5rem; border-radius: 100px; color: #5a6490;
}

/* ── Sidebar card ────────────────────────────────────────────────────────── */
.soflo-dir-detail__sidebar-card {
    border: 1px solid #dde2f5; border-radius: 12px;
    padding: 1.25rem 1.5rem;
    background: #f4f6ff;
}
.soflo-dir-detail__sidebar-label {
    display: block; font-size: .7rem; letter-spacing: .1em;
    color: #6b7fbb; margin-bottom: .75rem;
}

/* ── Social links ────────────────────────────────────────────────────────── */
.soflo-dir-detail__social-links { display: flex; flex-direction: column; gap: .5rem; }
.soflo-dir-detail__social-link {
    display: flex; align-items: center; gap: .5rem; font-size: .75rem;
    letter-spacing: .06em; color: #3b55e6; text-decoration: none;
    padding: .4rem .6rem; border-radius: 8px; transition: background .15s;
}
.soflo-dir-detail__social-link:hover { background: #f0f3ff; }
.soflo-dir-detail__social-link svg { flex-shrink: 0; }


/* ── Calendar page ───────────────────────────────────────────────────────── */
.soflo-page-fold--calendar { background: linear-gradient(135deg, #0d0f1e 0%, #1a1d3a 100%); }

.soflo-calendar-body { padding: 3rem 0 5rem; }
.soflo-calendar-body__inner { max-width: 820px; margin: 0 auto; padding: 0 1.5rem; }

.soflo-cal-nav {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 2.5rem; gap: 1rem;
}
.soflo-cal-nav__btn {
    font-size: .75rem; letter-spacing: .08em; color: #3b55e6;
    text-decoration: none; display: flex; align-items: center; gap: .3rem;
    padding: .4rem .75rem; border: 1.5px solid #e0e3f5; border-radius: 100px;
    transition: background .15s;
}
.soflo-cal-nav__btn:hover { background: #f0f3ff; }
.soflo-cal-nav__label { font-size: clamp(1.1rem, 2.5vw, 1.5rem); }

/* Empty state */
.soflo-calendar-empty { text-align: center; padding: 4rem 1rem; }
.soflo-calendar-empty__icon { color: #c0c8e8; margin-bottom: 1.25rem; }
.soflo-calendar-empty__h2 { font-size: 1.4rem; margin: 0 0 .75rem; }
.soflo-calendar-empty__p { color: #6b75a0; max-width: 360px; margin: 0 auto 1.5rem; }
.soflo-calendar-empty__cta {
    font-size: .75rem; letter-spacing: .1em; color: #3b55e6;
    text-decoration: none; border: 1.5px solid #3b55e6; border-radius: 100px;
    padding: .5rem 1.25rem; display: inline-block; transition: background .15s, color .15s;
}
.soflo-calendar-empty__cta:hover { background: #3b55e6; color: #fff; }

/* Date sections */
.soflo-calendar-sections { display: flex; flex-direction: column; gap: 2.5rem; }

.soflo-cal-section__head {
    display: flex; align-items: baseline; gap: .75rem; margin-bottom: .75rem;
    padding-bottom: .5rem; border-bottom: 2px solid #1a1d2e;
}
.soflo-cal-section__date { font-size: clamp(1rem, 2.5vw, 1.3rem); margin: 0; }
.soflo-cal-section__sub  { font-size: .65rem; letter-spacing: .1em; color: #8b97c5; }
.soflo-cal-section__count{ font-size: .65rem; letter-spacing: .1em; color: #8b97c5; margin-left: auto; }

/* Gig rows */
.soflo-cal-section__rows { display: flex; flex-direction: column; gap: 0; }
.soflo-cal-row {
    display: grid; grid-template-columns: 70px 1fr auto;
    gap: .5rem 1rem; align-items: start;
    padding: .75rem 0; border-bottom: 1px solid #f0f1f8;
}
.soflo-cal-row:last-child { border-bottom: none; }
.soflo-cal-row__time { font-size: .7rem; letter-spacing: .06em; color: #8b97c5; padding-top: .15rem; }
.soflo-cal-row__artist { font-weight: 700; font-size: .95rem; margin-bottom: .2rem; }
.soflo-cal-row__venue {
    display: flex; align-items: center; gap: .3rem;
    font-size: .8rem; color: #5a6490; margin-bottom: .3rem;
}
.soflo-cal-row__venue a { color: inherit; text-decoration: none; }
.soflo-cal-row__venue a:hover { color: #3b55e6; }
.soflo-cal-row__genre {
    font-size: .6rem; letter-spacing: .1em; padding: .1rem .4rem;
    border-radius: 100px; background: #f0f1f8; display: inline-block;
}
.soflo-cal-row__right { display: flex; flex-direction: column; align-items: flex-end; gap: .35rem; }
.soflo-cal-row__price { font-size: .7rem; letter-spacing: .08em; color: #5a6490; }
.soflo-cal-row__ticket {
    font-size: .7rem; letter-spacing: .08em; color: #3b55e6;
    text-decoration: none; white-space: nowrap;
}
.soflo-cal-row__ticket:hover { text-decoration: underline; }

@media (max-width: 540px) {
    .soflo-cal-row { grid-template-columns: 60px 1fr; }
    .soflo-cal-row__right { grid-column: 2; flex-direction: row; }
}


/* -- Discover: Calendar view -- */
.soflo-discover__cal { padding: 0; }

.soflo-cal-section { margin-bottom: 2.5rem; }

.soflo-cal-section__label {
    font-size: .7rem; letter-spacing: .13em; color: #8b97c5; font-weight: 600;
    text-transform: uppercase;
    padding: .65rem 1.25rem;
    background: #f7f8ff;
    border: 1px solid #e8eaf0;
    border-radius: 8px 8px 0 0;
    margin-bottom: 0;
    display: block;
}
.soflo-cal-section__rows {
    border: 1px solid #e8eaf0;
    border-top: none;
    border-radius: 0 0 12px 12px;
    overflow: hidden;
    background: #fff;
}

.soflo-cal-row {
    display: grid;
    grid-template-columns: 90px 1fr auto auto auto;
    align-items: center;
    gap: 1rem 1.5rem;
    padding: 1.15rem 1.25rem;
    border-bottom: 1px solid #f0f1f8;
    text-decoration: none;
    color: inherit;
    transition: background .15s;
}
.soflo-cal-row:hover { background: #f7f8ff; }
.soflo-cal-row:last-child { border-bottom: none; }

.soflo-cal-row__time {
    font-size: .78rem; letter-spacing: .05em; color: #8b97c5; font-weight: 500;
    white-space: nowrap;
}
.soflo-cal-row__main {
    display: flex; flex-direction: column; gap: .22rem; min-width: 0;
}
.soflo-cal-row__artist {
    font-size: 1.05rem; font-weight: 700; color: #1a1d2e; line-height: 1.2;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.soflo-cal-row__venue {
    font-size: .82rem; color: #8b97c5; line-height: 1.3;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.soflo-cal-row__genre {
    font-size: .63rem; letter-spacing: .09em; font-weight: 600;
    padding: .3rem .7rem; border-radius: 100px;
    white-space: nowrap; flex-shrink: 0;
}
.soflo-cal-row__price {
    font-size: .88rem; font-weight: 700; color: #3b4a6b;
    white-space: nowrap; flex-shrink: 0; min-width: 62px; text-align: right;
}
.soflo-cal-row__price.is-free { color: #3b4a6b; }
.soflo-cal-row__tix {
    font-size: .65rem; letter-spacing: .08em; font-weight: 600;
    color: #3b55e6; padding: .4rem .9rem;
    border: 1.5px solid #c7d0f5; border-radius: 100px;
    white-space: nowrap; flex-shrink: 0;
    transition: background .15s, color .15s;
}
.soflo-cal-row:hover .soflo-cal-row__tix { background: #3b55e6; color: #fff; border-color: #3b55e6; }

.soflo-cal-empty { padding: 3rem 0; text-align: center; color: #8b97c5; }
.soflo-cal-empty a { color: #3b55e6; }

@media (max-width: 768px) {
    .soflo-cal-row { grid-template-columns: 80px 1fr auto auto; gap: .75rem 1rem; padding: 1rem; }
    .soflo-cal-row__genre { display: none; }
}
@media (max-width: 600px) {
    .soflo-cal-row {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 0;
        padding: 1rem .75rem;
        min-width: 0;
    }
    .soflo-cal-row__time {
        font-size: .7rem;
        margin-bottom: .3rem;
    }
    .soflo-cal-row__main {
        width: 100%;
        min-width: 0;
        margin-bottom: .3rem;
    }
    .soflo-cal-row__artist {
        font-size: 1rem;
        white-space: normal;
        overflow: visible;
        text-overflow: unset;
    }
    .soflo-cal-row__venue {
        white-space: normal;
        overflow: visible;
        text-overflow: unset;
    }
    .soflo-cal-row__genre {
        display: inline-block;
        margin-bottom: .45rem;
    }
    .soflo-cal-row__price {
        font-size: .82rem;
        font-weight: 600;
        text-align: left;
        min-width: 0;
        margin-bottom: .6rem;
    }
    .soflo-cal-row__tix {
        width: 100%;
        text-align: center;
        padding: .55rem 0;
        border-radius: 8px;
    }
}

/* -- Calendar gate (login wall) -- */
.soflo-cal-gate {
    margin-top: 1.5rem;
    border: 2px dashed #dde1f5;
    border-radius: 14px;
    padding: 2.5rem 1.5rem;
    text-align: center;
    background: linear-gradient(180deg, #f7f8ff 0%, #fff 100%);
}
.soflo-cal-gate__icon { font-size: 2rem; margin: 0 0 .75rem; }
.soflo-cal-gate__title {
    font-size: 1.25rem; font-weight: 700; color: #1a1d2e;
    margin: 0 0 .5rem;
}
.soflo-cal-gate__desc {
    font-size: .9rem; color: #8b97c5; margin: 0 0 1.5rem;
    max-width: 340px; margin-left: auto; margin-right: auto;
}
.soflo-cal-gate__btns { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; }
.soflo-cal-gate__btn {
    font-size: .75rem; letter-spacing: .08em; font-weight: 700;
    padding: .6rem 1.4rem; border-radius: 100px; text-decoration: none;
    transition: opacity .15s;
}
.soflo-cal-gate__btn:hover { opacity: .85; }
.soflo-cal-gate__btn--primary { background: #3b55e6; color: #fff; }
.soflo-cal-gate__btn--outline { border: 2px solid #3b55e6; color: #3b55e6; }

.soflo-gig-stat-band .soflo-dir-detail__follow-btn { margin-top: 0; }

.soflo-dir-events__remind { margin-top: 0; }
.soflo-dir-events__remind.is-reminded svg { fill: var(--blue-500); stroke: var(--blue-500); }
.soflo-gig-stat-band__going.is-going svg,
.soflo-gig-detail__action-btn.is-saved svg { fill: currentColor; }


/* ── Blog grid (city guide) ──────────────────────────────────────────────── */
.soflo-blog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 1.5rem;
}
.soflo-blog-card {
    background: var(--white, #fff);
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--gray-100, #f3f4f6);
    display: flex;
    flex-direction: column;
    transition: box-shadow .2s ease;
}
.soflo-blog-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,.08); }
.soflo-blog-card__img-link { display: block; }
.soflo-blog-card__img-wrap {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: var(--gray-100, #f3f4f6);
}
.soflo-blog-card__img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .35s ease;
}
.soflo-blog-card:hover .soflo-blog-card__img { transform: scale(1.04); }
.soflo-blog-card__img-placeholder { width: 100%; height: 100%; background: var(--gray-100, #f3f4f6); }
.soflo-blog-card__cat {
    position: absolute; top: .75rem; left: .75rem;
    background: var(--blue-500, #3b6cf2); color: #fff;
    padding: .2rem .55rem; border-radius: 4px;
    font-size: .68rem; letter-spacing: .06em;
}
.soflo-blog-card__body {
    padding: 1.25rem 1.5rem 1.5rem;
    display: flex; flex-direction: column; gap: .5rem;
    flex: 1;
}
.soflo-blog-card__title {
    font-size: 1.05rem; line-height: 1.35; margin: 0;
}
.soflo-blog-card__title a { color: inherit; text-decoration: none; }
.soflo-blog-card__title a:hover { color: var(--blue-500, #3b6cf2); }
.soflo-blog-card__excerpt {
    font-size: .875rem; color: var(--gray-500, #6b7280);
    line-height: 1.55; margin: 0;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
    overflow: hidden;
}
.soflo-blog-card__meta {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: auto; padding-top: .75rem;
}
.soflo-blog-card__date { font-size: .75rem; color: var(--gray-400, #9ca3af); }
.soflo-blog-card__read {
    font-size: .75rem; color: var(--blue-500, #3b6cf2);
    text-decoration: none; letter-spacing: .03em;
}
.soflo-blog-card__read:hover { text-decoration: underline; }


/* ── Venue karaoke highlight banner ── */
.soflo-venue-karaoke-banner {
    display: flex; align-items: center; justify-content: space-between; gap: 0.75rem;
    background: linear-gradient(135deg, #f5f3ff, #ede9fe);
    border: 1px solid #ddd6fe;
    border-left: 3px solid #7c3aed;
    border-radius: 0.75rem;
    padding: 0.75rem 1rem;
    margin-bottom: 1.25rem;
}
.soflo-venue-karaoke-banner__left {
    display: flex; align-items: center; gap: 0.625rem;
}
.soflo-venue-karaoke-banner__icon {
    font-size: 1.25rem; flex-shrink: 0; line-height: 1;
}
.soflo-venue-karaoke-banner__text {
    display: flex; flex-direction: column; gap: 0.125rem;
}
.soflo-venue-karaoke-banner__label {
    font-size: 0.625rem; letter-spacing: .1em; color: #6d28d9; font-weight: 700;
}
.soflo-venue-karaoke-banner__detail {
    font-size: 0.875rem; color: #3b0764; font-weight: 500;
}
.soflo-venue-karaoke-banner__link {
    font-size: 0.6875rem; letter-spacing: .06em; color: #7c3aed;
    text-decoration: none; white-space: nowrap; flex-shrink: 0;
}
.soflo-venue-karaoke-banner__link:hover { color: #6d28d9; text-decoration: underline; }

/* ── Karaoke card schedule + host rows ── */
.soflo-karaoke-card__schedule {
    display: flex; align-items: center; gap: 0.35rem;
    font-size: 0.75rem; color: #7c3aed; letter-spacing: .03em;
    margin: 0.25rem 0 0.1rem;
}
.soflo-karaoke-card__host {
    display: flex; align-items: center; gap: 0.35rem;
    font-size: 0.7rem; color: #8b97c5; letter-spacing: .03em;
    margin-bottom: 0.2rem;
}
.soflo-karaoke-card__style-pill {
    background: #ede9fe; color: #6d28d9; border-color: #ddd6fe;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   FAN DASHBOARD v2 — new components
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ── Dashboard shell ─────────────────────────────────────────────────────────── */
.soflo-dash { background: #f7f8ff; min-height: 100vh; padding-bottom: 4rem; }
.soflo-dash__inner { max-width: 780px; margin: 0 auto; padding: 0 1.25rem; }

/* ── Hero header ─────────────────────────────────────────────────────────────── */
.soflo-dash__header {
    display: flex; align-items: center; gap: 1rem;
    padding: 2.5rem 0 0;
}
.soflo-dash__avatar {
    width: 3rem; height: 3rem; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.25rem; font-weight: 800; flex-shrink: 0;
    background: #e8ecff; color: #3b55e6;
}
.soflo-dash__avatar--venue  { background: #fef3c7; color: #d97706; }
.soflo-dash__avatar--artist { background: #fce7f3; color: #be185d; }
.soflo-dash__header-text { flex: 1 1 auto; }
.soflo-dash__name { font-size: 1.375rem; font-weight: 800; color: #0d1b3e; margin: 0 0 .2rem; letter-spacing: -.03em; }
.soflo-dash__role-pill {
    display: inline-block; padding: .15rem .55rem; border-radius: 999px;
    font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
    background: #e8ecff; color: #3b55e6;
}
.soflo-dash__role-pill--venue  { background: #fef3c7; color: #d97706; }
.soflo-dash__role-pill--artist { background: #fce7f3; color: #be185d; }
.soflo-dash__explore-link {
    font-size: .8125rem; font-weight: 700; letter-spacing: .04em; color: #3b55e6;
    text-decoration: none; white-space: nowrap; flex-shrink: 0;
}
.soflo-dash__explore-link:hover { text-decoration: underline; }

/* ── Pending banner ──────────────────────────────────────────────────────────── */
.soflo-dash__pending-banner {
    display: flex; align-items: flex-start; gap: 1rem;
    background: #fffbeb; border: 1px solid #fde68a; border-radius: .875rem;
    padding: 1rem 1.25rem; margin-top: 1.5rem;
    font-size: .9375rem; color: #92400e;
}
.soflo-dash__pending-banner p { margin: .25rem 0 0; }

/* ── Tab nav ─────────────────────────────────────────────────────────────────── */
.soflo-dash__tabs {
    display: flex; gap: .25rem; margin-top: 1.75rem;
    border-bottom: 2px solid #e4e8f7; overflow-x: auto;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.soflo-dash__tabs::-webkit-scrollbar { display: none; }
.soflo-dash__tab {
    display: flex; align-items: center; gap: .4rem; flex-shrink: 0;
    padding: .65rem 1rem .7rem; border-radius: .5rem .5rem 0 0;
    font-size: .8125rem; font-weight: 600; color: #5a6a9a;
    text-decoration: none; border: none; background: none; cursor: pointer;
    transition: color .15s, background .15s;
}
.soflo-dash__tab:hover { color: #0d1b3e; background: #eef1fd; }
.soflo-dash__tab.is-active {
    color: #0d1b3e; background: #eef1fd;
    box-shadow: 0 2px 0 0 #3b55e6; font-weight: 700;
}
.soflo-dash__tab-icon { font-size: 1rem; line-height: 1; }

/* ── Panel container ─────────────────────────────────────────────────────────── */
.soflo-dash__panels { padding-top: 1.5rem; }
.soflo-dash__panel  { display: block; }

/* ── Feed header ─────────────────────────────────────────────────────────────── */
.soflo-dash__feed-header { margin-bottom: 1.25rem; }
.soflo-dash__feed-title { font-size: 1.25rem; font-weight: 800; color: #0d1b3e; margin: 0 0 .2rem; letter-spacing: -.025em; }
.soflo-dash__feed-sub   { font-size: .8125rem; color: #8b97c5; }

/* ── Empty state ─────────────────────────────────────────────────────────────── */
.soflo-dash__empty-state {
    display: flex; flex-direction: column; align-items: center; text-align: center;
    background: #fff; border: 1px solid #e4e8f7; border-radius: 1.25rem;
    padding: 3rem 1.5rem 2.5rem;
}
.soflo-dash__empty-state h2 { font-size: 1.125rem; font-weight: 800; color: #0d1b3e; margin: .75rem 0 .5rem; }
.soflo-dash__empty-state p  { font-size: .9375rem; color: #5a6a9a; max-width: 22rem; line-height: 1.6; margin: 0 0 1.5rem; }
.soflo-dash__empty-icon     { font-size: 2.75rem; }
.soflo-dash__empty-actions  { display: flex; gap: .75rem; flex-wrap: wrap; justify-content: center; }

/* ── Gig row card (.soflo-drow) ──────────────────────────────────────────────── */
.soflo-drow-list { display: flex; flex-direction: column; gap: .5rem; }
.soflo-drow {
    display: grid; grid-template-columns: 3.5rem 1fr auto;
    gap: .875rem; align-items: center;
    background: #fff; border: 1px solid #e4e8f7; border-radius: .875rem;
    padding: .875rem 1rem;
    transition: box-shadow .15s;
}
.soflo-drow:hover { box-shadow: 0 2px 12px rgba(59,85,230,.08); }
.soflo-drow__thumb { flex-shrink: 0; display: block; }
.soflo-drow__thumb-img { width: 3.5rem; height: 3.5rem; border-radius: .5rem; object-fit: cover; display: block; }
.soflo-drow__thumb-placeholder {
    width: 3.5rem; height: 3.5rem; border-radius: .5rem; display: block;
    background: linear-gradient(135deg, #e8ecff 0%, #d0d8f8 100%);
}
.soflo-drow__body { min-width: 0; }
.soflo-drow__badges { display: flex; gap: .35rem; margin-bottom: .3rem; flex-wrap: wrap; }
.soflo-drow__badge {
    display: inline-block; padding: .1rem .5rem; border-radius: 999px;
    font-size: .65rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
}
.soflo-drow__badge--tonight  { background: #dcfce7; color: #166534; }
.soflo-drow__badge--tomorrow { background: #fef9c3; color: #854d0e; }
.soflo-drow__badge--source   { background: #e8ecff; color: #3b55e6; }
.soflo-drow__title { font-size: .9375rem; font-weight: 700; color: #0d1b3e; margin: 0 0 .2rem; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.soflo-drow__title a { color: inherit; text-decoration: none; }
.soflo-drow__title a:hover { color: #3b55e6; }
.soflo-drow__meta { font-size: .75rem; color: #8b97c5; margin: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.soflo-drow__actions { display: flex; flex-direction: column; align-items: flex-end; gap: .5rem; flex-shrink: 0; }
.soflo-drow__view {
    font-size: .75rem; font-weight: 700; letter-spacing: .04em; color: #3b55e6;
    text-decoration: none; white-space: nowrap;
}
.soflo-drow__view:hover { text-decoration: underline; }
.soflo-drow__unsave {
    background: none; border: none; cursor: pointer; padding: .25rem;
    color: #c4cce0; line-height: 1; display: flex; align-items: center;
    border-radius: .25rem; transition: color .15s;
}
.soflo-drow__unsave:hover { color: #e53e3e; }

/* ── Following card grid (.soflo-fcard) ──────────────────────────────────────── */
.soflo-fcard-grid { display: flex; flex-direction: column; gap: .5rem; }
.soflo-fcard {
    display: grid; grid-template-columns: 4rem 1fr auto;
    gap: .875rem; align-items: center;
    background: #fff; border: 1px solid #e4e8f7; border-radius: .875rem;
    padding: .875rem 1rem;
}
.soflo-fcard__thumb { display: block; flex-shrink: 0; }
.soflo-fcard__img { width: 4rem; height: 4rem; border-radius: .625rem; object-fit: cover; display: block; }
.soflo-fcard__thumb-placeholder {
    width: 4rem; height: 4rem; border-radius: .625rem; display: flex;
    align-items: center; justify-content: center; font-size: 1.75rem;
    background: linear-gradient(135deg, #e8ecff 0%, #d0d8f8 100%);
}
.soflo-fcard__body    { min-width: 0; }
.soflo-fcard__name    { font-size: .9375rem; font-weight: 700; color: #0d1b3e; margin: 0 0 .15rem; }
.soflo-fcard__name a  { color: inherit; text-decoration: none; }
.soflo-fcard__name a:hover { color: #3b55e6; }
.soflo-fcard__genre   { font-size: .75rem; color: #8b97c5; margin: 0 0 .35rem; text-transform: uppercase; letter-spacing: .05em; }
.soflo-fcard__next    { font-size: .75rem; color: #5a6a9a; margin: 0; display: flex; align-items: center; gap: .3rem; }
.soflo-fcard__next a  { color: #3b55e6; text-decoration: none; }
.soflo-fcard__next a:hover { text-decoration: underline; }
.soflo-fcard__next--none { color: #b0b9d9; font-style: italic; }
.soflo-fcard__next-dot { width: .45rem; height: .45rem; border-radius: 50%; flex-shrink: 0; background: #c4cce0; }
.soflo-fcard__next-dot--live { background: #22c55e; box-shadow: 0 0 0 2px #dcfce7; }
.soflo-fcard__actions { flex-shrink: 0; }
.soflo-fcard__unfollow {
    font-size: .75rem; font-weight: 600; letter-spacing: .04em; color: #c4cce0;
    background: none; border: 1px solid #e4e8f7; border-radius: 999px;
    padding: .3rem .75rem; cursor: pointer; transition: color .15s, border-color .15s;
}
.soflo-fcard__unfollow:hover { color: #e53e3e; border-color: #fca5a5; }

/* ── Section headings inside panels ─────────────────────────────────────────── */
.soflo-dash__section-head { display: flex; align-items: center; gap: .5rem; margin-bottom: .875rem; }
.soflo-dash__section-title { font-size: 1rem; font-weight: 800; color: #0d1b3e; margin: 0; letter-spacing: -.02em; }
.soflo-dash__count {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 1.375rem; height: 1.375rem; border-radius: 999px;
    background: #e8ecff; color: #3b55e6; font-size: .7rem; font-weight: 700; padding: 0 .3rem;
}

/* ── Picks: section label ────────────────────────────────────────────────────── */
.soflo-dash__picks-section-label {
    font-size: .6875rem; font-weight: 700; letter-spacing: .12em; color: #3b55e6;
    text-transform: uppercase; margin: 0 0 .75rem;
}

/* ── City guide list ─────────────────────────────────────────────────────────── */
.soflo-guide-list { display: flex; flex-direction: column; gap: .5rem; }
.soflo-guide-item {
    display: flex; align-items: center; gap: .875rem;
    background: #fff; border: 1px solid #e4e8f7; border-radius: .875rem;
    padding: .875rem 1rem; text-decoration: none; color: inherit;
    transition: box-shadow .15s;
}
.soflo-guide-item:hover { box-shadow: 0 2px 12px rgba(59,85,230,.08); }
.soflo-guide-item__thumb { flex-shrink: 0; }
.soflo-guide-item__img { width: 3.5rem; height: 3.5rem; border-radius: .5rem; object-fit: cover; display: block; }
.soflo-guide-item__body { flex: 1 1 auto; display: flex; align-items: center; justify-content: space-between; gap: .5rem; }
.soflo-guide-item__title { font-size: .9375rem; font-weight: 700; color: #0d1b3e; margin: 0; }
.soflo-guide-item__arrow { font-size: 1rem; color: #c4cce0; flex-shrink: 0; }
.soflo-guide-item:hover .soflo-guide-item__arrow { color: #3b55e6; }

/* ── Email subscription strip ────────────────────────────────────────────────── */
.soflo-dash__email-strip {
    display: flex; align-items: center; gap: 1rem; justify-content: space-between;
    background: linear-gradient(135deg, #0d1b3e 0%, #1e3a8a 100%);
    border-radius: 1rem; padding: 1.125rem 1.25rem; margin-top: 2rem;
    flex-wrap: wrap; gap: 1rem;
}
.soflo-dash__email-strip-left { display: flex; align-items: center; gap: .75rem; flex: 1 1 auto; }
.soflo-dash__email-strip-icon { font-size: 1.5rem; flex-shrink: 0; }
.soflo-dash__email-strip-title { font-size: .9375rem; font-weight: 700; color: #fff; display: block; }
.soflo-dash__email-strip-sub   { font-size: .8125rem; color: #93c5fd; margin: .1rem 0 0; }
.soflo-dash__email-strip-form  { display: flex; align-items: center; gap: .75rem; flex-shrink: 0; }
.soflo-dash__subscribed-badge  { font-size: .8125rem; font-weight: 600; color: #86efac; white-space: nowrap; }

/* ── Panel title / head (list views) ─────────────────────────────────────────── */
.soflo-dash__panel-title { font-size: 1.25rem; font-weight: 800; color: #0d1b3e; margin: 0 0 1.25rem; letter-spacing: -.025em; }
.soflo-dash__panel-head  { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.25rem; }
.soflo-dash__panel-head .soflo-dash__panel-title { margin: 0; }

/* ── List rows (venue/artist/gig management) ─────────────────────────────────── */
.soflo-dash__list { display: flex; flex-direction: column; gap: .375rem; }
.soflo-dash__list-row {
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
    background: #fff; border: 1px solid #e4e8f7; border-radius: .75rem; padding: .875rem 1rem;
}
.soflo-dash__list-left  { flex: 1 1 auto; min-width: 0; }
.soflo-dash__list-right { display: flex; align-items: center; gap: .625rem; flex-shrink: 0; }
.soflo-dash__list-name  { display: block; font-size: .9375rem; font-weight: 700; color: #0d1b3e; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.soflo-dash__list-meta  { display: block; font-size: .75rem; color: #8b97c5; margin-top: .1rem; }
.soflo-dash__status {
    font-size: .65rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
    padding: .2rem .6rem; border-radius: 999px;
}
.soflo-dash__status--live  { background: #dcfce7; color: #166534; }
.soflo-dash__status--draft { background: #f3f4f6; color: #6b7280; }
.soflo-dash__link { font-size: .8125rem; font-weight: 600; color: #3b55e6; text-decoration: none; }
.soflo-dash__link:hover { text-decoration: underline; }

/* ── Shared card ─────────────────────────────────────────────────────────────── */
.soflo-dash__card {
    background: #fff; border: 1px solid #e4e8f7; border-radius: 1rem; padding: 1.25rem 1.25rem 1.375rem;
}
.soflo-dash__card-h3   { font-size: .9375rem; font-weight: 800; color: #0d1b3e; margin: 0 0 .875rem; }
.soflo-dash__card-desc { font-size: .875rem; color: #5a6a9a; margin: -.25rem 0 .875rem; line-height: 1.55; }
.soflo-dash__card-fine { font-size: .8125rem; color: #8b97c5; margin: 0; }
.soflo-dash__info-row  { display: flex; justify-content: space-between; gap: 1rem; padding: .5rem 0; border-bottom: 1px solid #f0f2fa; font-size: .875rem; color: #0d1b3e; }
.soflo-dash__info-row:last-child { border-bottom: none; }
.soflo-dash__info-label { color: #8b97c5; flex-shrink: 0; }

/* ── Notification toggles ────────────────────────────────────────────────────── */
.soflo-dash__notif-list { display: flex; flex-direction: column; gap: 0; }
.soflo-dash__notif-row {
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
    padding: .875rem 0; border-bottom: 1px solid #f0f2fa; cursor: pointer;
}
.soflo-dash__notif-row:last-child { border-bottom: none; }
.soflo-dash__notif-text  { flex: 1 1 auto; }
.soflo-dash__notif-label { display: block; font-size: .875rem; font-weight: 600; color: #0d1b3e; }
.soflo-dash__notif-desc  { display: block; font-size: .75rem; color: #8b97c5; margin-top: .15rem; }
.soflo-dash__toggle-wrap { flex-shrink: 0; position: relative; }
.soflo-dash__toggle-input { position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none; }
.soflo-dash__toggle {
    display: block; width: 2.75rem; height: 1.5rem; border-radius: 999px;
    background: #d1d9ef; transition: background .2s; position: relative;
}
.soflo-dash__toggle::after {
    content: ''; position: absolute; top: .2rem; left: .2rem;
    width: 1.1rem; height: 1.1rem; border-radius: 50%;
    background: #fff; transition: transform .2s; box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.soflo-dash__toggle-input:checked ~ .soflo-dash__toggle { background: #3b55e6; }
.soflo-dash__toggle-input:checked ~ .soflo-dash__toggle::after { transform: translateX(1.25rem); }

/* ── Form elements ───────────────────────────────────────────────────────────── */
.soflo-dash__form     { display: flex; flex-direction: column; gap: .875rem; }
.soflo-dash__form-row { display: flex; flex-direction: column; gap: .3rem; }
.soflo-dash__form-row label { font-size: .8125rem; font-weight: 600; color: #3d4f7c; }
.soflo-dash__input {
    width: 100%; padding: .625rem .875rem; font-size: .9375rem; color: #0d1b3e;
    background: #f8f9ff; border: 1.5px solid #dde1f5; border-radius: .625rem;
    outline: none; transition: border-color .15s;
    box-sizing: border-box;
}
.soflo-dash__input:focus { border-color: #3b55e6; background: #fff; }

/* ── Buttons ─────────────────────────────────────────────────────────────────── */
.soflo-dash__btn {
    display: inline-flex; align-items: center; justify-content: center;
    padding: .65rem 1.375rem; border-radius: 999px;
    font-size: .875rem; font-weight: 700; letter-spacing: .03em;
    background: #3b55e6; color: #fff; border: none; cursor: pointer;
    text-decoration: none; transition: background .15s;
}
.soflo-dash__btn:hover { background: #2d44c7; color: #fff; }
.soflo-dash__btn--ghost {
    background: transparent; color: #3b55e6; border: 1.5px solid #c8cef5;
}
.soflo-dash__btn--ghost:hover { background: #eef1fd; color: #2d44c7; }
.soflo-dash__btn--sm { padding: .5rem 1.1rem; font-size: .8125rem; }

/* ── Alerts ──────────────────────────────────────────────────────────────────── */
.soflo-dash__alert       { font-size: .875rem; padding: .75rem 1rem; border-radius: .625rem; margin-bottom: .75rem; }
.soflo-dash__alert--ok   { background: #dcfce7; color: #166534; }
.soflo-dash__alert--err  { background: #fee2e2; color: #991b1b; }

/* ── Artist profile card ─────────────────────────────────────────────────────── */
.soflo-dash__card--profile { display: flex; align-items: center; gap: 1.25rem; }
.soflo-dash__profile-avatar {
    width: 4rem; height: 4rem; border-radius: 50%; flex-shrink: 0;
    background: #fce7f3; color: #be185d; font-size: 1.5rem; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
}
.soflo-dash__profile-name  { font-size: 1.125rem; font-weight: 800; color: #0d1b3e; }
.soflo-dash__profile-genre { font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: #8b97c5; margin-top: .2rem; }
.soflo-dash__profile-ig    { font-size: .8125rem; color: #3b55e6; margin-top: .3rem; }
.soflo-dash__profile-ig a  { color: inherit; text-decoration: none; }
.soflo-dash__profile-ig a:hover { text-decoration: underline; }
.soflo-dash__hint { font-size: .8125rem; color: #8b97c5; }
.soflo-dash__hint a { color: #3b55e6; }

/* ── Mobile responsive ───────────────────────────────────────────────────────── */
@media (max-width: 600px) {
    .soflo-dash__header { padding-top: 1.75rem; }
    .soflo-dash__name   { font-size: 1.175rem; }
    .soflo-dash__explore-link { display: none; }
    .soflo-dash__tab-label  { font-size: .75rem; }
    .soflo-dash__tab        { padding: .6rem .75rem .65rem; }
    .soflo-drow { grid-template-columns: 2.75rem 1fr auto; gap: .625rem; padding: .75rem .875rem; }
    .soflo-drow__thumb-img, .soflo-drow__thumb-placeholder { width: 2.75rem; height: 2.75rem; }
    .soflo-fcard { grid-template-columns: 3rem 1fr auto; gap: .625rem; padding: .75rem .875rem; }
    .soflo-fcard__img, .soflo-fcard__thumb-placeholder { width: 3rem; height: 3rem; }
    .soflo-dash__email-strip { flex-direction: column; align-items: flex-start; gap: .875rem; }
    .soflo-dash__email-strip-form { width: 100%; }
    .soflo-dash__email-strip-form .soflo-dash__btn { flex: 1 1 auto; }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   FAN DASHBOARD v3 — thumbnail placeholders + clickable cards + Remove button
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ── Colorful initial-letter thumbnail (gig rows) ───────────────────────────── */
.soflo-drow__initial {
    display: flex; align-items: center; justify-content: center;
    width: 3.5rem; height: 3.5rem; border-radius: .625rem; flex-shrink: 0;
    font-size: 1.25rem; font-weight: 800; letter-spacing: -.03em;
}
.soflo-drow__img { width: 3.5rem; height: 3.5rem; border-radius: .625rem; object-fit: cover; display: block; }

/* ── Clickable card overlay (full card = link) ───────────────────────────────── */
.soflo-drow { position: relative; cursor: pointer; }
.soflo-drow__overlay {
    position: absolute; inset: 0; border-radius: inherit; z-index: 1;
}
.soflo-drow__body    { position: relative; z-index: 2; pointer-events: none; }
.soflo-drow__thumb   { position: relative; z-index: 2; pointer-events: none; }
.soflo-drow__remove  { position: relative; z-index: 2; }
.soflo-drow__arrow   { position: relative; z-index: 2; pointer-events: none;
    font-size: 1rem; color: #c4cce0; flex-shrink: 0; transition: color .15s; }
.soflo-drow:hover .soflo-drow__arrow { color: #3b55e6; }

/* ── Gig row layout ──────────────────────────────────────────────────────────── */
.soflo-drow {
    display: grid; grid-template-columns: 3.5rem 1fr auto;
    gap: .875rem; align-items: center;
    background: #fff; border: 1px solid #e4e8f7; border-radius: .875rem;
    padding: .875rem 1rem; transition: box-shadow .15s, border-color .15s;
}
.soflo-drow:hover { box-shadow: 0 4px 16px rgba(59,85,230,.1); border-color: #c8d0f0; }

/* ── Remove button (replaces X icon) ────────────────────────────────────────── */
.soflo-drow__remove {
    background: none; border: 1px solid #e4e8f7; border-radius: 999px;
    font-size: .75rem; font-weight: 600; color: #8b97c5; padding: .3rem .75rem;
    cursor: pointer; transition: color .15s, border-color .15s; white-space: nowrap;
}
.soflo-drow__remove:hover { color: #dc2626; border-color: #fca5a5; }

/* ── Following card: colorful thumbnail ──────────────────────────────────────── */
.soflo-fcard__img {
    width: 4rem; height: 4rem; border-radius: .625rem; object-fit: cover; display: block;
}
.soflo-fcard__initial {
    display: flex; align-items: center; justify-content: center;
    width: 4rem; height: 4rem; border-radius: .625rem; flex-shrink: 0;
    font-size: 1.5rem; font-weight: 800; letter-spacing: -.03em;
}

/* ── Following card: clickable overlay ───────────────────────────────────────── */
.soflo-fcard { position: relative; cursor: pointer; }
.soflo-fcard__overlay {
    position: absolute; inset: 0; border-radius: inherit; z-index: 1;
}
.soflo-fcard__body     { position: relative; z-index: 2; pointer-events: none; }
.soflo-fcard__thumb    { position: relative; z-index: 2; pointer-events: none; }
.soflo-fcard__unfollow { position: relative; z-index: 2; }

/* ── Following card layout ───────────────────────────────────────────────────── */
.soflo-fcard {
    display: grid; grid-template-columns: 4rem 1fr auto;
    gap: .875rem; align-items: center;
    background: #fff; border: 1px solid #e4e8f7; border-radius: .875rem;
    padding: .875rem 1rem; transition: box-shadow .15s, border-color .15s;
}
.soflo-fcard:hover { box-shadow: 0 4px 16px rgba(59,85,230,.1); border-color: #c8d0f0; }
.soflo-fcard__name   { font-size: .9375rem; font-weight: 700; color: #0d1b3e; margin: 0 0 .15rem; }
.soflo-fcard__name a { color: inherit; text-decoration: none; }
.soflo-fcard__sub    { font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: #8b97c5; margin: 0 0 .35rem; }
.soflo-fcard__next   { font-size: .75rem; color: #5a6a9a; margin: 0; display: flex; align-items: center; gap: .3rem; }
.soflo-fcard__next a { color: #3b55e6; text-decoration: none; font-weight: 600; }
.soflo-fcard__next a:hover { text-decoration: underline; }
.soflo-fcard__next--none { color: #b0b9d9; font-style: italic; }
.soflo-fcard__dot    { width: .45rem; height: .45rem; border-radius: 50%; flex-shrink: 0;
    background: #22c55e; box-shadow: 0 0 0 2.5px #dcfce7; }
.soflo-fcard__unfollow {
    font-size: .75rem; font-weight: 600; color: #8b97c5;
    background: none; border: 1px solid #e4e8f7; border-radius: 999px;
    padding: .3rem .75rem; cursor: pointer; white-space: nowrap;
    transition: color .15s, border-color .15s;
}
.soflo-fcard__unfollow:hover { color: #dc2626; border-color: #fca5a5; }

/* ── Section label above following groups ────────────────────────────────────── */
.soflo-dash__fol-label {
    font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
    color: #3b55e6; margin: 0 0 .75rem; display: flex; align-items: center; gap: .5rem;
}

/* ── City guide items: colorful thumbnail ────────────────────────────────────── */
.soflo-guide-item__img     { width: 3.5rem; height: 3.5rem; border-radius: .5rem; object-fit: cover; display: block; }
.soflo-guide-item__initial {
    display: flex; align-items: center; justify-content: center;
    width: 3.5rem; height: 3.5rem; border-radius: .5rem; flex-shrink: 0;
    font-size: 1.25rem; font-weight: 800;
}

/* ── Mobile ──────────────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
    .soflo-drow { grid-template-columns: 2.75rem 1fr auto; gap: .625rem; padding: .75rem; }
    .soflo-drow__initial, .soflo-drow__img { width: 2.75rem; height: 2.75rem; font-size: 1rem; }
    .soflo-fcard { grid-template-columns: 3rem 1fr auto; gap: .625rem; padding: .75rem; }
    .soflo-fcard__initial, .soflo-fcard__img { width: 3rem; height: 3rem; font-size: 1.25rem; }
    .soflo-guide-item__initial, .soflo-guide-item__img { width: 2.75rem; height: 2.75rem; font-size: 1rem; }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   FAN DASHBOARD — mobile-first overrides  (320 px +)
   Appended to assets/style.css after soflo_dash_v3_patch.css
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ── 1. Force sticky nav into "scrolled" (dark) state on the dashboard page ──── */
/*     Without this the hamburger is white-on-white and invisible.               */
.page-template-page-dashboard-php .soflo-nav,
.page-template-page-dashboard-php .soflo-nav.is-scrolled {
    background: rgba(255,255,255,0.96);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom-color: var(--line, #e4e8f7);
}
.page-template-page-dashboard-php .soflo-nav__logo-img--default { display: none !important; }
.page-template-page-dashboard-php .soflo-nav__logo-img--sticky  { display: block !important; }
.page-template-page-dashboard-php .soflo-nav .soflo-nav__link   { color: var(--ink, #0d1b3e); }
.page-template-page-dashboard-php .soflo-nav .soflo-nav__login  { color: var(--ink, #0d1b3e); }
.page-template-page-dashboard-php .soflo-nav .soflo-nav__burger span { background: var(--ink, #0d1b3e); }

/* ── 2. Reduce inner gutter on narrow screens ────────────────────────────────── */
@media (max-width: 480px) {
    .soflo-dash__inner { padding-left: .875rem; padding-right: .875rem; }
    .soflo-nav__inner  { padding-left: 1rem; padding-right: 1rem; }
}
@media (max-width: 360px) {
    .soflo-dash__inner { padding-left: .625rem; padding-right: .625rem; }
    .soflo-nav__inner  { padding-left: .75rem; padding-right: .75rem; }
}

/* ── 3. Tabs: wrap into 3-column pill grid instead of horizontal scroll ─────── */
@media (max-width: 640px) {
    .soflo-dash__tabs {
        flex-wrap: wrap;
        overflow: visible;
        border-bottom: none;
        gap: .3rem;
        margin-top: 1.25rem;
        margin-bottom: .75rem;
    }
    /* Each tab: at least 1/3 width so 3 fit per row; last row stretches evenly  */
    .soflo-dash__tab {
        flex: 1 1 calc(33.33% - .3rem);
        justify-content: center;
        background: #fff;
        border: 1.5px solid #e4e8f7;
        border-radius: .75rem;
        padding: .6rem .4rem .65rem;
        font-size: .75rem;
        font-weight: 600;
        color: #5a6a9a;
        /* remove the underline-bottom indicator */
        box-shadow: none;
    }
    .soflo-dash__tab:hover {
        background: #f4f6ff;
        border-color: #c8d0f0;
        color: #0d1b3e;
    }
    .soflo-dash__tab.is-active {
        background: #3b55e6;
        border-color: #3b55e6;
        color: #fff;
        box-shadow: 0 2px 8px rgba(59,85,230,.35);
    }
    .soflo-dash__tab-icon { font-size: .9rem; }
}

/* 320-360 px: switch to 2 columns so labels don't get squeezed */
@media (max-width: 400px) {
    .soflo-dash__tab {
        flex: 1 1 calc(50% - .3rem);
        font-size: .7rem;
        padding: .55rem .3rem .6rem;
    }
    .soflo-dash__tab-icon { font-size: .85rem; }
}

/* ── 4. Full-width primary buttons on mobile ─────────────────────────────────── */
@media (max-width: 640px) {
    /* Main action buttons inside panels & cards */
    .soflo-dash__panel .soflo-dash__btn:not(.soflo-dash__btn--sm),
    .soflo-dash__card  .soflo-dash__btn:not(.soflo-dash__btn--sm) {
        width: 100%;
    }

    /* Empty-state paired buttons: stack vertically */
    .soflo-dash__empty-actions {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
        gap: .625rem;
    }
    .soflo-dash__empty-actions .soflo-dash__btn { width: 100%; }

    /* Email strip subscribe button */
    .soflo-dash__email-strip-form { width: 100%; }
    .soflo-dash__email-strip-form .soflo-dash__btn { flex: 1 1 auto; width: auto; }
}

/* ── 5. Compact header at 480 px ────────────────────────────────────────────── */
@media (max-width: 480px) {
    .soflo-dash__header { padding-top: 1.25rem; }
    .soflo-dash__name   { font-size: 1.1rem; }
}

/* ── 6. Feed section header stacks neatly ────────────────────────────────────── */
@media (max-width: 480px) {
    .soflo-dash__feed-header { margin-bottom: 1rem; }
    .soflo-dash__feed-title  { font-size: 1.125rem; }
}

/* ── 7. Panels top padding tighter on mobile ─────────────────────────────────── */
@media (max-width: 640px) {
    .soflo-dash__panels { padding-top: 1rem; }
}

/* ── 8. Tightest overrides at 360 px and below ───────────────────────────────── */
@media (max-width: 360px) {
    /* Gig rows */
    .soflo-drow {
        grid-template-columns: 2.25rem 1fr auto;
        gap: .45rem;
        padding: .625rem .625rem;
    }
    .soflo-drow__initial,
    .soflo-drow__img {
        width: 2.25rem !important;
        height: 2.25rem !important;
        font-size: .8125rem !important;
    }

    /* Following cards */
    .soflo-fcard {
        grid-template-columns: 2.5rem 1fr auto;
        gap: .45rem;
        padding: .625rem .625rem;
    }
    .soflo-fcard__initial,
    .soflo-fcard__img {
        width: 2.5rem !important;
        height: 2.5rem !important;
        font-size: .9375rem !important;
    }

    /* Unfollow / Remove buttons: smaller on tiny screens */
    .soflo-fcard__unfollow,
    .soflo-drow__remove {
        font-size: .6875rem;
        padding: .25rem .55rem;
    }

    /* Card padding */
    .soflo-dash__card { padding: .875rem .875rem 1rem; }
    .soflo-dash__feed-title { font-size: 1rem; }

    /* Notification rows: allow label to wrap */
    .soflo-dash__notif-row { gap: .625rem; }

    /* Guide items */
    .soflo-guide-item__initial,
    .soflo-guide-item__img {
        width: 2.25rem !important;
        height: 2.25rem !important;
        font-size: .8125rem !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   FAN DASHBOARD — full mobile redesign v2
   Overrides previous mobile patch. 320 px → 640 px.
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════════════
   TABS — full-width stacked list (all breakpoints ≤ 640 px)
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
    .soflo-dash__tabs {
        display: flex !important;
        flex-direction: column !important;
        flex-wrap: nowrap !important;
        overflow: visible !important;
        border-bottom: none !important;
        gap: .3rem !important;
        margin-top: 1.25rem !important;
        margin-bottom: 1.25rem !important;
    }
    .soflo-dash__tab {
        flex: none !important;
        width: 100% !important;
        justify-content: flex-start !important;
        gap: .75rem !important;
        background: #fff !important;
        border: 1.5px solid #e4e8f7 !important;
        border-radius: .875rem !important;
        padding: .875rem 1rem !important;
        font-size: .9375rem !important;
        font-weight: 600 !important;
        color: #0d1b3e !important;
        box-shadow: none !important;
        text-align: left !important;
    }
    .soflo-dash__tab:hover {
        background: #f4f6ff !important;
        border-color: #c8d0f0 !important;
        color: #0d1b3e !important;
    }
    .soflo-dash__tab.is-active {
        background: #3b55e6 !important;
        border-color: #3b55e6 !important;
        color: #fff !important;
        box-shadow: 0 3px 10px rgba(59,85,230,.28) !important;
    }
    .soflo-dash__tab-icon { font-size: 1.1rem !important; line-height: 1 !important; }
    .soflo-dash__tab-label { font-size: .9375rem !important; }
}

/* ════════════════════════════════════════════════════════════════════════
   INNER PADDING — tighten gutters on small screens
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {
    .soflo-dash__inner  { padding-left: .875rem; padding-right: .875rem; }
    .soflo-nav__inner   { padding-left: 1rem; padding-right: 1rem; }
}
@media (max-width: 360px) {
    .soflo-dash__inner { padding-left: .625rem; padding-right: .625rem; }
    .soflo-nav__inner  { padding-left: .75rem; padding-right: .75rem; }
}

/* ════════════════════════════════════════════════════════════════════════
   HEADER — compact avatar + name at small sizes
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {
    .soflo-dash__header { padding-top: 1.25rem; gap: .75rem; }
    .soflo-dash__avatar { width: 2.625rem; height: 2.625rem; font-size: 1rem; }
    .soflo-dash__name   { font-size: 1.125rem; letter-spacing: -.025em; }
}

/* ════════════════════════════════════════════════════════════════════════
   PANELS — less top padding on mobile
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
    .soflo-dash__panels { padding-top: .25rem; }
    .soflo-dash__feed-header { margin-bottom: 1rem; }
    .soflo-dash__feed-title  { font-size: 1.125rem; }
}

/* ════════════════════════════════════════════════════════════════════════
   BUTTONS — full-width primary buttons on mobile
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
    /* Main CTA buttons inside panels & cards */
    .soflo-dash__panel .soflo-dash__btn:not(.soflo-dash__btn--sm),
    .soflo-dash__card  .soflo-dash__btn:not(.soflo-dash__btn--sm) {
        width: 100%;
    }
    /* Empty state paired buttons: stack vertically */
    .soflo-dash__empty-actions {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
        gap: .625rem;
    }
    .soflo-dash__empty-actions .soflo-dash__btn { width: 100%; }
    /* Email strip: expand subscribe button */
    .soflo-dash__email-strip-form { width: 100%; }
    .soflo-dash__email-strip-form .soflo-dash__btn { flex: 1 1 auto; width: auto; }
}

/* ════════════════════════════════════════════════════════════════════════
   GIG ROWS — scale down thumbnails at 480 px
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {
    .soflo-drow {
        grid-template-columns: 2.75rem 1fr auto;
        gap: .625rem;
        padding: .75rem .875rem;
    }
    .soflo-drow__initial,
    .soflo-drow__img { width: 2.75rem !important; height: 2.75rem !important; border-radius: .5rem !important; }
    .soflo-drow__title { font-size: .875rem; }
    .soflo-drow__meta  { font-size: .6875rem; }
}

/* ════════════════════════════════════════════════════════════════════════
   FOLLOWING CARDS — scale down at 480 px
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {
    .soflo-fcard {
        grid-template-columns: 3rem 1fr auto;
        gap: .625rem;
        padding: .75rem .875rem;
    }
    .soflo-fcard__initial,
    .soflo-fcard__img { width: 3rem !important; height: 3rem !important; }
    .soflo-fcard__name { font-size: .875rem; }
    .soflo-fcard__next { font-size: .6875rem; }
}

/* ════════════════════════════════════════════════════════════════════════
   ACCOUNT / CARDS
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {
    .soflo-dash__card { padding: 1rem 1rem 1.125rem; border-radius: .875rem; }
    .soflo-dash__card-h3 { font-size: .875rem; }
    .soflo-dash__notif-label { font-size: .8125rem; }
    .soflo-dash__notif-desc  { font-size: .6875rem; }
    /* Info rows: allow value to wrap */
    .soflo-dash__info-row { flex-wrap: wrap; gap: .25rem; }
    /* Management list rows */
    .soflo-dash__list-row { flex-wrap: wrap; gap: .5rem .75rem; padding: .75rem .875rem; }
    .soflo-dash__list-left { flex: 1 1 100%; min-width: 0; }
    .soflo-dash__list-right { flex: 0 0 auto; }
}

/* ════════════════════════════════════════════════════════════════════════
   EMAIL STRIP — stack at 560 px
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 560px) {
    .soflo-dash__email-strip { flex-direction: column; align-items: flex-start; gap: .875rem; }
}

/* ════════════════════════════════════════════════════════════════════════
   320 px — absolute tightest overrides
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 360px) {
    /* Tabs: keep full-width, just smaller text */
    .soflo-dash__tab {
        padding: .75rem .875rem !important;
        font-size: .875rem !important;
    }
    .soflo-dash__tab-icon { font-size: 1rem !important; }

    /* Gig rows */
    .soflo-drow {
        grid-template-columns: 2.25rem 1fr auto;
        gap: .4rem;
        padding: .625rem .625rem;
    }
    .soflo-drow__initial,
    .soflo-drow__img { width: 2.25rem !important; height: 2.25rem !important; font-size: .75rem !important; }
    .soflo-drow__remove,
    .soflo-drow__arrow { font-size: .6875rem; }

    /* Following cards */
    .soflo-fcard {
        grid-template-columns: 2.5rem 1fr auto;
        gap: .4rem;
        padding: .625rem .625rem;
    }
    .soflo-fcard__initial,
    .soflo-fcard__img { width: 2.5rem !important; height: 2.5rem !important; font-size: .875rem !important; }
    .soflo-fcard__unfollow { font-size: .6875rem; padding: .2rem .5rem; }
    .soflo-fcard__name { font-size: .8125rem; }

    /* Pending banner */
    .soflo-dash__pending-banner { padding: .875rem; font-size: .875rem; }

    /* Account card */
    .soflo-dash__card { padding: .875rem .75rem 1rem; }

    /* Feed title */
    .soflo-dash__feed-title { font-size: 1rem; }

    /* Section label */
    .soflo-dash__fol-label { font-size: .6875rem; }

    /* Guide items */
    .soflo-guide-item { padding: .75rem .75rem; gap: .625rem; }
    .soflo-guide-item__initial,
    .soflo-guide-item__img { width: 2.25rem !important; height: 2.25rem !important; font-size: .75rem !important; border-radius: .375rem !important; }
    .soflo-guide-item__title { font-size: .8125rem; }

    /* Form inputs */
    .soflo-dash__input { font-size: .875rem; padding: .5rem .75rem; }

    /* Empty state */
    .soflo-dash__empty-state { padding: 2rem 1rem 1.75rem; }
    .soflo-dash__empty-icon  { font-size: 2.25rem; }
    .soflo-dash__empty-state h2 { font-size: 1rem; }
    .soflo-dash__empty-state p  { font-size: .875rem; }

    /* Name and header */
    .soflo-dash__name { font-size: 1rem; }
    .soflo-dash__avatar { width: 2.25rem; height: 2.25rem; font-size: .875rem; }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   FAN DASHBOARD — card text + layout overrides for mobile (v3)
   Let titles wrap; bigger, airier cards. 320 px → 640 px.
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════════════
   GIG ROWS  (.soflo-drow)
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {

    /* Lift the card a little */
    .soflo-drow {
        grid-template-columns: 3rem 1fr auto;
        gap: .75rem;
        align-items: flex-start;           /* top-align so tall titles don't center */
        padding: .9375rem 1rem;
        border-radius: 1rem;
    }

    /* Thumbnail: align with first line of title */
    .soflo-drow__thumb { padding-top: .125rem; }

    /* Let title wrap — kill the nowrap + ellipsis */
    .soflo-drow__title {
        white-space: normal !important;
        overflow: visible !important;
        text-overflow: clip !important;
        font-size: 1rem;
        font-weight: 700;
        line-height: 1.35;
        margin-bottom: .25rem;
    }

    /* Meta line: wrap too, slightly larger */
    .soflo-drow__meta {
        white-space: normal !important;
        overflow: visible !important;
        text-overflow: clip !important;
        font-size: .8125rem;
        line-height: 1.4;
    }

    /* Arrow: align to top so it doesn't float center on tall cards */
    .soflo-drow__arrow { align-self: flex-start; padding-top: .25rem; }

    /* Remove button: align to top */
    .soflo-drow__remove { align-self: flex-start; margin-top: .125rem; }

    /* Thumbnail sizes */
    .soflo-drow__initial,
    .soflo-drow__img {
        width: 3rem !important;
        height: 3rem !important;
        font-size: .9375rem !important;
        border-radius: .625rem !important;
    }
}

/* ════════════════════════════════════════════════════════════════════════
   FOLLOWING CARDS  (.soflo-fcard)
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {

    .soflo-fcard {
        grid-template-columns: 3.25rem 1fr auto;
        gap: .75rem;
        align-items: flex-start;
        padding: .9375rem 1rem;
        border-radius: 1rem;
    }

    .soflo-fcard__thumb { padding-top: .125rem; }

    /* Name: allow wrap, bigger */
    .soflo-fcard__name {
        white-space: normal !important;
        font-size: 1rem;
        font-weight: 700;
        line-height: 1.3;
        margin-bottom: .25rem;
    }

    /* Genre sub-label */
    .soflo-fcard__sub {
        font-size: .6875rem;
        margin-bottom: .3rem;
    }

    /* "Next:" row: allow the link to wrap onto the next line */
    .soflo-fcard__next {
        font-size: .8125rem;
        flex-wrap: wrap;
        gap: .2rem .3rem;
        line-height: 1.4;
    }
    .soflo-fcard__next a { white-space: normal; }

    /* Unfollow button: top-aligned */
    .soflo-fcard__unfollow { align-self: flex-start; margin-top: .125rem; }

    /* Thumbnail */
    .soflo-fcard__initial,
    .soflo-fcard__img {
        width: 3.25rem !important;
        height: 3.25rem !important;
        font-size: 1rem !important;
        border-radius: .625rem !important;
    }
}

/* ════════════════════════════════════════════════════════════════════════
   CITY GUIDE ITEMS  (.soflo-guide-item)
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
    .soflo-guide-item { padding: .9375rem 1rem; gap: .75rem; border-radius: 1rem; }
    .soflo-guide-item__title { font-size: 1rem; white-space: normal; }
    .soflo-guide-item__initial,
    .soflo-guide-item__img {
        width: 3rem !important;
        height: 3rem !important;
        font-size: .875rem !important;
        border-radius: .625rem !important;
    }
}

/* ════════════════════════════════════════════════════════════════════════
   BADGES — slightly larger pill text on mobile
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
    .soflo-drow__badge { font-size: .6875rem; padding: .15rem .55rem; }
}

/* ════════════════════════════════════════════════════════════════════════
   320 px — keep the same proportions, just tighter gutters
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 360px) {

    .soflo-drow {
        grid-template-columns: 2.75rem 1fr auto;
        gap: .55rem;
        padding: .75rem .75rem;
    }
    .soflo-drow__initial,
    .soflo-drow__img {
        width: 2.75rem !important;
        height: 2.75rem !important;
        font-size: .875rem !important;
        border-radius: .5rem !important;
    }
    .soflo-drow__title { font-size: .9375rem; }
    .soflo-drow__meta  { font-size: .75rem; }

    .soflo-fcard {
        grid-template-columns: 2.75rem 1fr auto;
        gap: .55rem;
        padding: .75rem .75rem;
    }
    .soflo-fcard__initial,
    .soflo-fcard__img {
        width: 2.75rem !important;
        height: 2.75rem !important;
        font-size: .875rem !important;
        border-radius: .5rem !important;
    }
    .soflo-fcard__name  { font-size: .9375rem; }
    .soflo-fcard__next  { font-size: .75rem; }

    .soflo-guide-item { padding: .75rem .75rem; }
    .soflo-guide-item__initial,
    .soflo-guide-item__img {
        width: 2.75rem !important;
        height: 2.75rem !important;
        font-size: .875rem !important;
    }
    .soflo-guide-item__title { font-size: .9375rem; }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   VENUE MANAGER DASHBOARD — forms, gig management rows, stat cards
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════════════
   PANEL HEAD  (shared heading + button row)
   ════════════════════════════════════════════════════════════════════════ */
.soflo-dash__panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
}
.soflo-dash__panel-head .soflo-dash__feed-sub {
    display: block;
    font-size: .8125rem;
    color: #64748b;
    margin-top: .2rem;
}

/* ════════════════════════════════════════════════════════════════════════
   ALERT  (success / error banners inside panels)
   ════════════════════════════════════════════════════════════════════════ */
.soflo-dash__alert {
    padding: .75rem 1rem;
    border-radius: .75rem;
    font-size: .875rem;
    font-weight: 600;
    margin-bottom: 1.25rem;
}
.soflo-dash__alert--ok  { background: #f0fdf4; color: #15803d; border: 1px solid #bbf7d0; }
.soflo-dash__alert--err { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }

/* ════════════════════════════════════════════════════════════════════════
   STATUS PILL  (Live / Draft on venue/gig rows)
   ════════════════════════════════════════════════════════════════════════ */
.soflo-dash__status {
    display: inline-block;
    font-size: .6875rem;
    font-weight: 700;
    letter-spacing: .04em;
    padding: .2rem .55rem;
    border-radius: 99px;
    vertical-align: middle;
    text-transform: uppercase;
}
.soflo-dash__status--live  { background: #dcfce7; color: #15803d; }
.soflo-dash__status--draft { background: #f1f5f9; color: #64748b; }

/* ════════════════════════════════════════════════════════════════════════
   MGIG ROWS  (.soflo-mgig-row) — management list for gigs and venues
   ════════════════════════════════════════════════════════════════════════ */
.soflo-mgig-list {
    display: flex;
    flex-direction: column;
    gap: .625rem;
}

.soflo-mgig-row {
    display: grid;
    grid-template-columns: 3rem 1fr auto;
    gap: .875rem;
    align-items: center;
    background: #fff;
    border: 1.5px solid #e4e8f7;
    border-radius: .875rem;
    padding: .875rem 1rem;
    transition: border-color .15s;
}
.soflo-mgig-row:hover { border-color: #c8d0f0; }
.soflo-mgig-row--past { opacity: .75; }

/* Thumbnail */
.soflo-mgig-row__thumb { flex-shrink: 0; }
.soflo-mgig-row__img {
    width: 3rem; height: 3rem;
    object-fit: cover;
    border-radius: .625rem;
    display: block;
}
.soflo-mgig-row__initial {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3rem; height: 3rem;
    border-radius: .625rem;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -.01em;
}

/* Body */
.soflo-mgig-row__body { min-width: 0; }
.soflo-mgig-row__name {
    font-size: .9375rem;
    font-weight: 600;
    color: #0d1b3e;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.soflo-mgig-row__meta {
    font-size: .8125rem;
    color: #64748b;
    margin-top: .2rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.soflo-mgig-row__stats {
    font-size: .75rem;
    color: #94a3b8;
    margin-top: .2rem;
}

/* Actions */
.soflo-mgig-row__actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: .3rem;
    flex-shrink: 0;
}
.soflo-dash__link {
    font-size: .8125rem;
    font-weight: 600;
    color: #3b55e6;
    text-decoration: none;
    white-space: nowrap;
}
.soflo-dash__link:hover { text-decoration: underline; }

.soflo-mgig-row__delete {
    font-size: .75rem;
    font-weight: 600;
    color: #ef4444;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    white-space: nowrap;
}
.soflo-mgig-row__delete:hover { color: #b91c1c; }

/* ════════════════════════════════════════════════════════════════════════
   PAST SHOWS DETAILS TOGGLE
   ════════════════════════════════════════════════════════════════════════ */
.soflo-mgig-past summary { list-style: none; display: flex; align-items: center; gap: .5rem; }
.soflo-mgig-past summary::-webkit-details-marker { display: none; }
.soflo-mgig-past summary::before {
    content: '▶';
    font-size: .6875rem;
    color: #94a3b8;
    transition: transform .18s;
}
.soflo-mgig-past[open] summary::before { transform: rotate(90deg); }

/* ════════════════════════════════════════════════════════════════════════
   VFORM  — venue / gig add-edit form
   ════════════════════════════════════════════════════════════════════════ */
.soflo-vform__back {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .875rem;
    font-weight: 600;
    color: #3b55e6;
    text-decoration: none;
}
.soflo-vform__back:hover { text-decoration: underline; }

.soflo-vform {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

/* Two-column grid that collapses to 1 column on mobile */
.soflo-vform__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .875rem;
}

.soflo-vform__field { display: flex; flex-direction: column; gap: .35rem; }
.soflo-vform__field--full { grid-column: 1 / -1; }

.soflo-vform__label {
    font-size: .8125rem;
    font-weight: 600;
    color: #0d1b3e;
}
.soflo-vform__req { color: #ef4444; }
.soflo-vform__opt { font-weight: 400; color: #94a3b8; }
.soflo-vform__section-head { border-top: 1px solid #e9ebf5; padding-top: 1.25rem; margin-top: .5rem; }
.soflo-vform__section-label { font-size: .75rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: #8b97c5; }
.soflo-vform__multiselect { width: 100%; max-width: 400px; overflow-y: auto; font-size: .875rem; }

.soflo-vform__textarea {
    resize: vertical;
    min-height: 6rem;
}

/* Inline checkbox + label (e.g. "Free entry") */
.soflo-vform__check-inline {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    font-size: .875rem;
    color: #374151;
    cursor: pointer;
    margin-top: .3rem;
}
.soflo-vform__check-inline input[type="checkbox"] { accent-color: #3b55e6; width: 1rem; height: 1rem; }

/* Current photo preview */
.soflo-vform__photo-thumb {
    display: block;
    width: 5rem; height: 5rem;
    object-fit: cover;
    border-radius: .625rem;
    border: 1.5px solid #e4e8f7;
    margin-bottom: .35rem;
}

/* File input */
.soflo-vform__file {
    font-size: .8125rem;
    color: #374151;
}

.soflo-vform__hint {
    font-size: .75rem;
    color: #94a3b8;
    margin: 0;
}

/* Actions row */
.soflo-vform__actions {
    display: flex;
    gap: .75rem;
    align-items: center;
    flex-wrap: wrap;
    margin-top: .25rem;
}

/* ════════════════════════════════════════════════════════════════════════
   STAT GRID  (Audience tab)
   ════════════════════════════════════════════════════════════════════════ */
.soflo-stat-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .875rem;
    margin-top: .5rem;
    margin-bottom: .25rem;
}

.soflo-stat-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1.5px solid #e4e8f7;
    border-radius: .875rem;
    padding: 1.25rem 1.25rem 1rem;
}
.soflo-stat-card__num {
    font-size: 2rem;
    font-weight: 800;
    color: #0d1b3e;
    letter-spacing: -.03em;
    line-height: 1;
}
.soflo-stat-card__label {
    font-size: .875rem;
    font-weight: 700;
    color: #0d1b3e;
    margin-top: .3rem;
}
.soflo-stat-card__hint {
    font-size: .75rem;
    color: #94a3b8;
    margin-top: .2rem;
}

/* ════════════════════════════════════════════════════════════════════════
   LIST  (.soflo-dash__list + rows) — per-venue breakdown in audience tab
   ════════════════════════════════════════════════════════════════════════ */
.soflo-dash__list {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    margin-top: .5rem;
}
.soflo-dash__list-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: #fff;
    border: 1.5px solid #e4e8f7;
    border-radius: .75rem;
    padding: .75rem 1rem;
}
.soflo-dash__list-left { min-width: 0; display: flex; flex-direction: column; gap: .15rem; }
.soflo-dash__list-name { font-size: .9375rem; font-weight: 600; color: #0d1b3e; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.soflo-dash__list-meta { font-size: .8125rem; color: #64748b; }
.soflo-dash__list-right { display: flex; align-items: center; gap: .75rem; flex-shrink: 0; }

/* ════════════════════════════════════════════════════════════════════════
   MOBILE — venue forms and management rows
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
    /* Collapse 2-col vform grid to 1 col */
    .soflo-vform__grid { grid-template-columns: 1fr; }

    /* Full-width form submit button */
    .soflo-vform__actions .soflo-dash__btn:first-child { width: 100%; justify-content: center; }

    /* Panel head: stack heading and button */
    .soflo-dash__panel-head { flex-direction: row; flex-wrap: wrap; }

    /* Stat grid: 2 cols, but smaller padding */
    .soflo-stat-card { padding: 1rem .875rem .875rem; }
    .soflo-stat-card__num { font-size: 1.625rem; }
}

@media (max-width: 480px) {
    /* Management rows: tighter */
    .soflo-mgig-row {
        grid-template-columns: 2.75rem 1fr auto;
        gap: .625rem;
        padding: .75rem .875rem;
    }
    .soflo-mgig-row__img,
    .soflo-mgig-row__initial { width: 2.75rem !important; height: 2.75rem !important; font-size: .875rem !important; }
    .soflo-mgig-row__name { font-size: .875rem; }
    .soflo-mgig-row__meta { font-size: .75rem; }

    /* Stat grid: full-width 1 col on tiny screens */
    .soflo-stat-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 360px) {
    .soflo-mgig-row {
        grid-template-columns: 2.5rem 1fr auto;
        gap: .5rem;
        padding: .625rem .75rem;
    }
    .soflo-mgig-row__img,
    .soflo-mgig-row__initial { width: 2.5rem !important; height: 2.5rem !important; font-size: .8125rem !important; }
    .soflo-stat-grid { grid-template-columns: 1fr; }
}

/* ── Mobile menu: restore white link text on interior/dash pages ─────────── */
.soflo-mobile-menu .soflo-mobile-menu__links .soflo-nav__link {
    color: rgba(255,255,255,.85) !important;
}
.soflo-mobile-menu .soflo-mobile-menu__links .soflo-nav__link:hover {
    color: #fff !important;
    background: rgba(255,255,255,.07) !important;
}
.soflo-mobile-menu .soflo-mobile-menu__links .soflo-nav__link--new {
    color: var(--sky) !important;
}

/* ── Drive scene stat cards — restore frosted-glass look (overrides dashboard card conflict) ── */
.soflo-drive__stats .soflo-stat-card {
    background: rgba(255,255,255,.1) !important;
    border: 1px solid rgba(255,255,255,.2) !important;
    border-radius: 1rem !important;
    padding: 1.5rem !important;
}
.soflo-drive__stats .soflo-stat-card__value {
    font-size: 3rem !important;
    color: #fff !important;
    line-height: 1 !important;
}
.soflo-drive__stats .soflo-stat-card__label {
    font-size: .75rem !important;
    color: rgba(255,255,255,.75) !important;
    margin-top: .5rem !important;
    text-transform: uppercase !important;
    letter-spacing: .1em !important;
    font-weight: 500 !important;
}
@media (max-width: 640px) {
    .soflo-drive__stats .soflo-stat-card { padding: 1rem !important; }
    .soflo-drive__stats .soflo-stat-card__value { font-size: 2.25rem !important; }
}

/* ── Dropdown typeahead search input ── */
.soflo-dd-search {
    display: block;
    width: 100%;
    padding: .45rem .75rem;
    margin: 0;
    font-size: .8125rem;
    font-family: inherit;
    background: #f8fafc;
    border: none;
    border-bottom: 1px solid rgba(0,0,0,.08);
    outline: none;
    color: #0f172a;
    box-sizing: border-box;
    border-radius: 0;
    line-height: 1.4;
}
.soflo-dd-search:focus {
    background: #fff;
    border-bottom-color: #3b6cf2;
    box-shadow: none;
}
.soflo-dd-search::placeholder { color: #9ca3af; font-style: italic; }

/* ── Dropdown overflow unlock ─────────────────────────────────────────────── */
.soflo-hero.soflo-dd-open,
.soflo-page-fold.soflo-dd-open { overflow: visible; }

