/* ── 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: hidden;
    touch-action: pan-y;
}
body {
    margin: 0;
    padding: 0;
    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;
}
.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 {
    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__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;
}
.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__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; grid-template-columns: 1.1fr 1fr; gap: 1.125rem; }
.soflo-featured__panel.is-active { display: grid; }

.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.875rem;
}
.soflo-feat-small {
    background: white; border: 1px solid var(--line);
    border-radius: 1rem; padding: 1rem;
    display: flex; flex-direction: column; gap: 0.625rem;
}
.soflo-feat-small__top { display: flex; gap: 0.75rem; align-items: center; }
.soflo-feat-small__thumb {
    width: 3.5rem; height: 3.5rem; border-radius: 0.75rem;
    overflow: hidden; flex: none; background: var(--paper-2);
}
.soflo-feat-small__thumb img { width: 100%; height: 100%; object-fit: cover; }
.soflo-feat-small__name { font-size: 1.0625rem; letter-spacing: -.01em; }
.soflo-feat-small__meta { font-size: 0.75rem; color: var(--ink-3); }
.soflo-feat-small__btns { display: flex; gap: 0.5rem; margin-top: auto; }
.soflo-feat-small__btn {
    flex: 1; padding: 0.5rem 0.75rem; border-radius: 999px;
    font-size: 0.75rem; font-weight: 600;
}
.soflo-feat-small__btn--primary { background: var(--blue-50); color: var(--blue-500); border: none; }
.soflo-feat-small__btn--outline { background: transparent; color: var(--ink-2); border: 1px solid var(--line); }
.soflo-feat-small__btn:hover { opacity: .85; }

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

/* ── 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__panel.is-active { grid-template-columns: 1fr; }
    .soflo-feat-small-grid { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
    .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 { aspect-ratio: 3/4; }
    .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-feat-small-grid { grid-template-columns: 1fr; }
    .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%; }
    .soflo-gig-guide__meta { flex-wrap: wrap; gap: 0.5rem; }
    .soflo-feed { padding-top: 0; }
}
