*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    --rose: #E87A8D;
    --teal: #4AAEC0;
    --rose-lt: #F5D5DC;
    --teal-lt: #C8EAF0;
    --ivory: #FDFAF7;
    --cream: #F5F0EA;
    --parch: #EDE6D6;
    --sand: #C8B89A;
    --dune: #A08878;
    --ink: #1E1614;
    --gold: #C8A84B;
    --charcoal: #2A2A2A;
    --white: #fff;
}

html {
    scroll-behavior: smooth;
}

body {
    background: var(--ivory);
    color: var(--ink);
    font-family: 'Jost', sans-serif;
    font-weight: 300;
    overflow-x: hidden;
    cursor: none;
}

/* ── Cursor ── */
#cur {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--teal);
    position: fixed;
    top: 0;
    left: 0;
    pointer-events: none;
    z-index: 9999;
    transform: translate(-50%, -50%);
}

#cur-ring {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid var(--rose);
    position: fixed;
    top: 0;
    left: 0;
    pointer-events: none;
    z-index: 9998;
    transform: translate(-50%, -50%);
    transition: width .3s, height .3s, opacity .3s, border-color .3s;
}

/* ── Pages ── */
.page {
    display: none;
    min-height: 100vh;
    animation: fadeUp .6s ease both;
}

.page.active {
    display: block;
}

@keyframes fadeUp {
    from {
        opacity: 0;
        transform: translateY(14px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

/* ── NAV ── */
nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 200;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 52px;
    background: rgba(253, 250, 247, .92);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(200, 184, 154, .2);
}

.nav-logo {
    cursor: none;
    display: flex;
    align-items: center;
    gap: 0;
}

.nav-logo img {
    height: 25px;
    display: block;
}

.nav-logo .logo-tag {
    font-family: 'Jost', sans-serif;
    font-size: .55rem;
    letter-spacing: .3em;
    text-transform: uppercase;
    color: var(--dune);
    margin-left: 12px;
    margin-top: 2px;
}

.hamburger {
    display: flex;
    flex-direction: column;
    gap: 5px;
    cursor: none;
    padding: 6px;
    background: none;
    border: none;
}

.hamburger span {
    display: block;
    width: 24px;
    height: 1px;
    background: var(--ink);
    transition: all .35s ease;
}

.hamburger.open span:nth-child(1) {
    transform: rotate(45deg) translate(4px, 4px);
}

.hamburger.open span:nth-child(2) {
    opacity: 0;
    transform: translateX(-8px);
}

.hamburger.open span:nth-child(3) {
    transform: rotate(-45deg) translate(4px, -4px);
}

/* ── Overlay Nav ── */
.nav-overlay {
    position: fixed;
    inset: 0;
    z-index: 150;
    background: var(--ink);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .45s ease;
}

.nav-overlay.open {
    opacity: 1;
    pointer-events: all;
}

.overlay-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 80px;
    padding: 20px;
}

.nav-item {
    display: block;
    text-decoration: none;
    cursor: none;
    padding: 12px 0;
    border-bottom: 1px solid rgba(255, 255, 255, .08);
    transition: border-color .3s;
}

.nav-item:hover {
    border-bottom-color: var(--rose);
}

.nav-item .ni-num {
    font-size: .6rem;
    letter-spacing: .28em;
    color: var(--teal);
    margin-bottom: 6px;
    text-transform: uppercase;
}

.nav-item .ni-label {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.4rem, 3vw, 2.2rem);
    font-weight: 300;
    color: var(--white);
    line-height: 1.1;
    transition: color .3s;
}

.nav-item .ni-sub {
    font-size: .62rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .35);
    margin-top: 4px;
}

.nav-item:hover .ni-label {
    color: var(--rose);
}

.overlay-close-hint {
    position: absolute;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    font-size: .6rem;
    letter-spacing: .28em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .25);
}

/* ── Common section helpers ── */
.sect {
    padding: 88px 52px;
}

.sect-sm {
    padding: 56px 52px;
}

.label-rose {
    font-size: .62rem;
    letter-spacing: .35em;
    text-transform: uppercase;
    color: var(--rose);
    margin-bottom: 14px;
}

.label-teal {
    font-size: .62rem;
    letter-spacing: .35em;
    text-transform: uppercase;
    color: var(--teal);
    margin-bottom: 14px;
}

.label-gold {
    font-size: .62rem;
    letter-spacing: .35em;
    text-transform: uppercase;
    color: var(--gold);
    margin-bottom: 14px;
}

.disp-head {
    font-family: 'Cormorant Garamond', serif;
    font-weight: 300;
    line-height: 1.05;
}

.rule-rose {
    width: 40px;
    height: 1px;
    background: var(--rose);
    margin: 16px 0 20px;
}

.rule-teal {
    width: 40px;
    height: 1px;
    background: var(--teal);
    margin: 16px 0 20px;
}

.rule-gold {
    width: 40px;
    height: 1px;
    background: var(--gold);
    margin: 16px 0 20px;
}

/* ── HERO (shared) ── */
.hero {
    position: relative;
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 0 52px 64px;
    overflow: hidden;
}

.hero-bg {
    position: absolute;
    inset: 0;
}

.blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(90px);
    pointer-events: none;
}

.hero-scroll {
    position: absolute;
    bottom: 36px;
    right: 52px;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 9px;
    opacity: 0;
    animation: fadeIn .8s 1.2s ease forwards;
}

.hero-scroll span {
    font-size: .56rem;
    letter-spacing: .3em;
    text-transform: uppercase;
    color: var(--dune);
    writing-mode: vertical-rl;
}

.scroll-ln {
    width: 1px;
    height: 52px;
    background: linear-gradient(to bottom, var(--teal), transparent);
    animation: spulse 2s ease-in-out infinite;
}

@keyframes spulse {

    0%,
    100% {
        opacity: .35
    }

    50% {
        opacity: 1
    }
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

/* ── Marquee ── */
.marquee-bar {
    overflow: hidden;
    padding: 14px 0;
    border-top: 1px solid rgba(74, 174, 192, .2);
    border-bottom: 1px solid rgba(232, 122, 141, .2);
    background: var(--cream);
}

.marquee-track {
    display: flex;
    white-space: nowrap;
    animation: mq 24s linear infinite;
}

.mq-item {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: .9rem;
    padding: 0 32px;
    letter-spacing: .06em;
}

.mq-r {
    color: var(--rose)
}

.mq-t {
    color: var(--teal)
}

.mq-g {
    color: var(--gold)
}

.mq-sep {
    color: var(--sand);
    padding: 0 4px;
}

@keyframes mq {
    from {
        transform: translateX(0)
    }

    to {
        transform: translateX(-50%)
    }
}

/* ── Buttons ── */
.btn-rose {
    font-family: 'Jost';
    font-size: .66rem;
    font-weight: 400;
    letter-spacing: .24em;
    text-transform: uppercase;
    color: #fff;
    background: var(--rose);
    border: none;
    padding: 15px 38px;
    cursor: none;
    transition: background .3s, transform .2s;
}

.btn-disabled {
    position: relative;
    filter: grayscale(1);
    pointer-events: none;
    cursor: not-allowed;
}

.btn-disabled::after {
    content: 'Coming Soon';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: .62rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .8);
}

.btn-rose:hover {
    background: #d45e72;
    transform: translateY(-1px);
}

.btn-teal {
    font-family: 'Jost';
    font-size: .66rem;
    font-weight: 300;
    letter-spacing: .24em;
    text-transform: uppercase;
    color: var(--teal);
    background: transparent;
    border: 1px solid var(--teal);
    padding: 15px 38px;
    cursor: none;
    transition: background .3s, color .3s, transform .2s;
}

.btn-teal:hover {
    background: var(--teal);
    color: #fff;
    transform: translateY(-1px);
}

.btn-gold {
    font-family: 'Jost';
    font-size: .66rem;
    font-weight: 400;
    letter-spacing: .24em;
    text-transform: uppercase;
    color: var(--ink);
    background: var(--gold);
    border: none;
    padding: 15px 38px;
    cursor: none;
    transition: filter .3s, transform .2s;
}

.btn-gold:hover {
    filter: brightness(1.1);
    transform: translateY(-1px);
}

.btn-outline-w {
    font-family: 'Jost';
    font-size: .66rem;
    letter-spacing: .24em;
    text-transform: uppercase;
    color: #fff;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, .35);
    padding: 15px 38px;
    cursor: none;
    transition: border-color .3s, background .3s;
}

.btn-outline-w:hover {
    border-color: #fff;
    background: rgba(255, 255, 255, .08);
}



/* ── Footer ── */
footer {
    border-top: 1px solid var(--parch);
    padding: 40px 52px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

footer.dark {
    background: var(--charcoal);
    border-top: 1px solid rgba(255, 255, 255, .08);
}

.foot-logo img {
    height: 24px;
}

.foot-copy {
    font-size: .62rem;
    letter-spacing: .1em;
    color: var(--dune);
}

.foot-copy.w {
    color: rgba(255, 255, 255, .35);
}

.foot-nav {
    display: flex;
    gap: 24px;
    list-style: none;
    flex-wrap: wrap;
}

.foot-nav a {
    font-size: .62rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--dune);
    text-decoration: none;
    cursor: none;
    transition: color .3s;
}

.foot-nav a:hover {
    color: var(--teal);
}

.foot-nav.w a {
    color: rgba(255, 255, 255, .35);
}

.foot-nav.w a:hover {
    color: var(--rose);
}

/* ── Responsive ── */
@media(max-width:960px) {
    nav {
        padding: 14px 20px;
    }

    .hero,
    .sect,
    .sect-sm {
        padding-left: 20px;
        padding-right: 20px;
    }

    .cat-grid,
    .poems-grid,
    .prog-cards,
    .roster-grid,
    .feat-grid,
    .philo-inner,
    .bigemm-about-inner,
    .bsrh-about-inner,
    .prose-inner,
    .partner-why-grid,
    .partner-form-grid,
    .contact-layout,
    .verticals-grid,
    .overlay-inner {
        grid-template-columns: 1fr;
    }

    .cat-card,
    .cat-card:first-child {
        height: 280px;
    }

    footer {
        flex-direction: column;
        gap: 14px;
        text-align: center;
        padding: 32px 20px;
    }

    .bigemm-title,
    .bsrh-title {
        font-size: clamp(42px, 12vw, 80px);
    }

    .philo-band,
    .bigemm-about,
    .bsrh-about,
    .roster-sect,
    .discog-sect,
    .programs-sect,
    .partner-why,
    .partner-form-sect,
    .poems-sect,
    .prose-band {
        padding: 60px 20px;
    }

    .prog-cta-band {
        padding: 52px 20px;
    }
}