/* ═══════════════════════════════════════════════
   MODEL COLLECTIVE  ·  styles.css
   ═══════════════════════════════════════════════ */

/* ── Logo Loader (Membership & Contact) ─────── */
@keyframes panel-bg {
    from { background: #111; }
    to   { background: #F5F5F5; }
}
@keyframes model-in {
    from { opacity: 0; transform: scale(1.1); }
    to   { opacity: 1; transform: scale(1); }
}
@keyframes model-out {
    from { opacity: 1; transform: translateY(0); }
    to   { opacity: 0; transform: translateY(-55vh); }
}
@keyframes society-in {
    from { opacity: 0; letter-spacing: 0.18em; }
    to   { opacity: 1; letter-spacing: 0.52em; }
}
@keyframes society-out {
    from { opacity: 1; transform: translateY(0); letter-spacing: 0.52em; }
    to   { opacity: 0; transform: translateY(55vh); letter-spacing: 0.52em; }
}

.logo-loader {
    position: fixed;
    inset: 0;
    z-index: 99999;
    overflow: hidden;
    pointer-events: all;
}
.logo-loader__panel {
    position: absolute;
    left: 0; right: 0;
    background: #111;
    overflow: hidden;
    transition: transform 0.35s cubic-bezier(0.76, 0, 0.24, 1);
}
.logo-loader__panel::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image: url('images/M.svg');
    background-size: 80px 80px;
    background-repeat: repeat;
    opacity: 0.07;
}
.logo-loader__panel--top { top: 0; height: 50.5%; }
.logo-loader__panel--bot { bottom: 0; height: 50.5%; }

.logo-loader--out .logo-loader__panel--top { transform: translateY(-100%); }
.logo-loader--out .logo-loader__panel--bot { transform: translateY(100%); }
.logo-loader--out .logo-loader__model { animation: model-out 0.35s cubic-bezier(0.76, 0, 0.24, 1) forwards; }
.logo-loader--out .logo-loader__society { animation: society-out 0.35s cubic-bezier(0.76, 0, 0.24, 1) forwards; }
.logo-loader--out { pointer-events: none; }

.logo-loader__content {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    pointer-events: none;
}
.logo-loader__model {
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(3.5rem, 10vw, 8rem);
    font-weight: 400;
    letter-spacing: 0.38em;
    background: linear-gradient(160deg, #ffffff 0%, #9B9B9B 50%, #ffffff 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    opacity: 0;
    animation: model-in 0.3s cubic-bezier(0.16,1,0.3,1) 0.15s both;
}
.logo-loader__society {
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(1.6rem, 4vw, 3.2rem);
    font-weight: 400;
    letter-spacing: 0.52em;
    background: linear-gradient(160deg, #cccccc 0%, #777777 50%, #cccccc 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    opacity: 0;
    animation: society-in 0.3s cubic-bezier(0.16,1,0.3,1) 0.25s both;
}

/* ── Logo Loader: Home variant (dark bg, no panels) ── */
@keyframes loader-fade-out {
    from { opacity: 1; }
    to   { opacity: 0; }
}
.logo-loader--home {
    background: #111;
}
.logo-loader--home .logo-loader__panel { display: none; }
.logo-loader--home .logo-loader__model {
    animation: model-in 0.45s cubic-bezier(0.16,1,0.3,1) 0.2s both;
}
.logo-loader--home .logo-loader__society {
    animation: society-in 0.55s cubic-bezier(0.16,1,0.3,1) 0.35s both;
}
.logo-loader--home.logo-loader--out {
    animation: loader-fade-out 0.55s ease forwards;
    pointer-events: none;
}
.logo-loader--home.logo-loader--out .logo-loader__model { animation: model-out 0.55s cubic-bezier(0.76, 0, 0.24, 1) forwards; }
.logo-loader--home.logo-loader--out .logo-loader__society { animation: society-out 0.55s cubic-bezier(0.76, 0, 0.24, 1) forwards; }

/* ── Preloader ──────────────────────────────── */
.preloader {
    position: fixed;
    inset: 0;
    z-index: 999999;
    background: #000;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.5s ease-in, visibility 0.5s, transform 0.5s ease-in;
}
.preloader.preloader--hidden {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: scale(1.04);
}
.preloader__video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.preloader__skip {
    position: absolute;
    bottom: 36px;
    right: 36px;
    background: transparent;
    border: 1px solid rgba(255,255,255,0.35);
    color: rgba(255,255,255,0.7);
    font-family: inherit;
    font-size: 0.72rem;
    letter-spacing: 0.2em;
    padding: 10px 20px;
    cursor: pointer;
    transition: border-color 0.2s, color 0.2s;
    z-index: 1;
    -webkit-tap-highlight-color: transparent;
    min-width: 44px;
    min-height: 44px;
}
.preloader__skip:hover {
    border-color: rgba(255,255,255,0.8);
    color: #fff;
}

/* ── Design Tokens ─────────────────────────── */
:root {
    /* ── Brand Palette ── */
    --black:         #000000;
    --model-black:   #111111;
    --charcoal:      #696969;
    --gray:          #9B9B9B;
    --platinum:      #D9D9D9;
    --off-white:     #F4F4F4;
    --white:         #FFFFFF;
    --gradient:      linear-gradient(135deg, #9B9B9B, #FFFFFF);

    /* ── Mapped tokens ── */
    --cream:         #F4F4F4;
    --cream-border:  #D9D9D9;
    --dark:          #111111;
    --dark-2:        #000000;
    --gold:          #696969;
    --text:          #111111;
    --text-muted:    #555555;
    --text-light:    rgba(255, 255, 255, 0.88);
    --border-light:  rgba(255, 255, 255, 0.12);
    --nav-h:         68px;
    --px:            clamp(24px, 6vw, 90px);
    --ease-out:      cubic-bezier(0.16, 1, 0.3, 1);
    --ease-std:      cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ── Reset ─────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif;
    background: var(--cream);
    color: var(--text);
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    cursor: none;
}
a  { text-decoration: none; color: inherit; }
ul { list-style: none; }
img { display: block; max-width: 100%; }

/* ── Custom Cursor ─────────────────────────── */
.cursor {
    position: fixed;
    top: 0; left: 0;
    width: 10px; height: 10px;
    border-radius: 50%;
    background: #111;
    pointer-events: none;
    z-index: 1000000;
    transform: translate(-50%, -50%);
    transition: background 0.25s ease, width 0.25s var(--ease-out), height 0.25s var(--ease-out), opacity 0.3s;
}
.cursor--dark { background: rgba(255,255,255,0.8); }
.cursor--white { background: #fff; }
.cursor--hover {
    width: 22px; height: 22px;
    opacity: 0.6;
}



/* ── Scroll Reveal Base ────────────────────── */
.reveal {
    opacity: 0;
    transform: translateY(48px);
    transition: opacity 0.85s var(--ease-out),
                transform 0.85s var(--ease-out);
}
.reveal.revealed {
    opacity: 1;
    transform: translateY(0);
}
.delay-1 { transition-delay: 0.12s; }
.delay-2 { transition-delay: 0.22s; }

/* ═══════════════════════════════════════════════
   NAVIGATION
   ═══════════════════════════════════════════════ */
.nav {
    position: fixed;
    inset-block-start: 0;
    inset-inline: 0;
    z-index: 900;
    height: var(--nav-h);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 var(--px);
    background: linear-gradient(to right, rgba(245, 245, 245, 0.60) 0%, rgba(245, 245, 245, 0.25) 47%, rgba(245, 245, 245, 0.05) 100%);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    color: var(--text);
    transition: background 0.4s var(--ease-std),
                box-shadow 0.4s var(--ease-std),
                color 0.3s;
}
.nav--scrolled {
    background: rgba(245, 245, 245, 0.75);
    backdrop-filter: blur(16px) saturate(140%);
    -webkit-backdrop-filter: blur(16px) saturate(140%);
    box-shadow: 0 1px 0 var(--cream-border);
}
.nav--dark {
    background: rgba(10, 10, 10, 0.50);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    color: #fff;
}

.nav__brand {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}
.nav__brand-text {
    display: flex;
    flex-direction: column;
    line-height: 1.15;
    align-items: center;
}
.nav__brand-name {
    font-size: 1.1rem;
    font-weight: 400;
    letter-spacing: 0.38em;
}
.nav__brand-sub {
    font-size: 0.78rem;
    font-weight: 400;
    letter-spacing: 0.50em;
    color: var(--text);
}
/* Logo: dark on cream nav, white on dark sections */
.nav__logo-img {
    height: 52px;
    width: auto;
    filter: invert(1) brightness(0) drop-shadow(0 0 0.4px #000);
    transition: filter 0.3s;
}
.nav--dark .nav__logo-img {
    filter: drop-shadow(0 0 0.4px #fff);
}
.nav--dark .nav__brand-sub { color: #fff; }
.nav--dark .nav__brand-name { color: #fff; }

.nav__links {
    display: flex;
    gap: clamp(18px, 3vw, 56px);
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}
.nav__links a {
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    transition: opacity 0.2s;
    padding-bottom: 3px;
}
.nav__links a:hover { opacity: 0.5; }
.nav__links a.active { opacity: 1; pointer-events: none; cursor: default; border-bottom: 1px solid currentColor; padding-bottom: 2px; }

.nav__indicator {
    position: absolute;
    bottom: -2px;
    height: 1.5px;
    background: currentColor;
    transition: left 0.4s var(--ease-out), width 0.4s var(--ease-out);
    pointer-events: none;
    opacity: 0;
}
.nav__indicator.visible { opacity: 1; }

.nav__actions { display: flex; align-items: center; gap: 14px; }

.nav__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 0 4px;
    background: transparent;
    color: var(--off-white);
    border-bottom: 1px solid var(--off-white);
    font-family: 'Montserrat', sans-serif;
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    transition: color 0.3s, border-color 0.3s, opacity 0.2s;
}
.nav--scrolled .nav__cta { color: var(--text); border-color: var(--text); }
.nav--dark .nav__cta { color: #fff; border-color: #fff; }
.nav__cta:hover { opacity: 0.7; }

.nav__hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: none;
    padding: 6px;
}
.nav__hamburger span {
    display: block;
    width: 22px;
    height: 1.5px;
    background: currentColor;
    transform-origin: center;
    transition: transform 0.28s var(--ease-std), opacity 0.2s;
}
.nav__hamburger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav__hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav__hamburger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
.nav--dark .nav__hamburger span { background: #fff; }

/* Mobile nav menu */
@media (max-width: 768px) {
    .nav:not(.nav--dark):not(.nav--scrolled) { background: rgba(245, 245, 245, 0.08); backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px); }
    .nav__cta { display: none; }
    body { cursor: auto; }
    .cursor { display: none; }
    .nav__links {
        position: fixed;
        top: var(--nav-h);
        left: 0; right: 0;
        flex-direction: column;
        align-items: flex-start;
        gap: 0;
        background: rgba(245, 245, 245, 0.97);
        backdrop-filter: blur(32px) saturate(180%);
        -webkit-backdrop-filter: blur(32px) saturate(180%);
        border-top: 1px solid rgba(255, 255, 255, 0.5);
        padding: 24px var(--px) 32px;
        transform: none;
        clip-path: inset(0 0 100% 0);
        transition: clip-path 0.4s var(--ease-out);
        pointer-events: none;
    }
    .nav__links.open {
        clip-path: inset(0 0 0% 0);
        pointer-events: all;
    }
    .nav__links li { width: 100%; border-bottom: 1px solid var(--cream-border); }
    .nav__links a { display: block; padding: 18px 0; font-size: 0.85rem; color: var(--text); opacity: 1; }
    .nav__links a.active { color: #999 !important; pointer-events: none; }
    .nav__hamburger { display: flex; background: transparent; }
    .nav__hamburger span { background: var(--text); }
    .nav--dark .nav__hamburger span { background: #fff; }
    .nav--dark.nav--scrolled {
        background: rgba(10, 10, 10, 0.85);
        backdrop-filter: blur(16px);
        -webkit-backdrop-filter: blur(16px);
    }
}

/* ═══════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════ */
.hero {
    display: grid;
    grid-template-columns: 47% 1fr;
    height: 100vh;
    background: var(--cream);
}

.hero__left {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(48px, 6vw, 80px) var(--px);
    padding-top: calc(var(--nav-h) + clamp(48px, 6vw, 80px));
}

.hero__label {
    font-size: 0.62rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: var(--text-muted);
    margin-bottom: 20px;
    text-transform: uppercase;
}

/* Hero heading — clip reveal per line */
.hero__heading {
    font-size: clamp(2.6rem, 5.5vw, 6rem);
    font-weight: 400;
    line-height: 0.93;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    margin-bottom: 24px;
}
.hero__heading .line {
    display: block;
    overflow: hidden;
}
.hero__heading .line span {
    display: block;
    transform: translateY(110%);
}
.hero__heading.animate .line:nth-child(1) span { animation: slideUp 0.9s var(--ease-out) 0.05s forwards; }
.hero__heading.animate .line:nth-child(2) span { animation: slideUp 0.9s var(--ease-out) 0.16s forwards; }
.hero__heading.animate .line:nth-child(3) span { animation: slideUp 0.9s var(--ease-out) 0.27s forwards; }

@keyframes slideUp {
    to { transform: translateY(0); }
}

.hero__description {
    font-size: clamp(0.88rem, 1.1vw, 0.95rem);
    font-weight: 400;
    line-height: 1.75;
    color: var(--text-muted);
    max-width: 440px;
    margin-bottom: 32px;
}

.hero__cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 16px;
    padding: 16px 28px;
    background: var(--model-black);
    color: #fff;
    border-radius: 7px;
    font-size: 0.7rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin-bottom: 40px;
    transition: opacity 0.2s;
}
.hero__cta-btn:hover { opacity: 0.85; }
.hero__cta-arrow { font-size: 0.9rem; }

.hero__badges {
    display: flex;
    gap: 28px;
    flex-wrap: wrap;
}
.hero__badge {
    display: flex;
    align-items: center;
    gap: 8px;
}
.hero__badge-icon {
    width: 18px;
    height: 18px;
    color: var(--text-muted);
    flex-shrink: 0;
}
.hero__badge span {
    font-size: 0.55rem;
    font-weight: 400;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    line-height: 1.35;
    text-transform: uppercase;
}

.hero__right {
    position: relative;
    overflow: hidden;
    clip-path: polygon(18% 0, 100% 0, 100% 100%, 0 100%);
    height: 100%;
}
.hero__img {
    position: absolute;
    top: 0;
    left: 0; right: 0; bottom: 0;
    height: 120%;
    background-size: cover;
    background-position: center;
    background-color: #2a2a2a;
    will-change: transform;
}

/* ═══════════════════════════════════════════════
   OFFERING CARDS
   ═══════════════════════════════════════════════ */
.offering {
    background: var(--cream);
    margin-top: clamp(24px, 3vw, 48px);
}
.offering__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2px;
}
.offering__card {
    position: relative;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    cursor: none;
    container-type: inline-size;
}
.offering__card-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transition: transform 0.7s var(--ease-std);
    filter: brightness(0.72);
}
.offering__card:hover .offering__card-bg {
    transform: scale(1.06);
    filter: brightness(0.85);
}
.offering__card::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.08) 50%, transparent 100%);
}
.offering__card-body {
    position: relative;
    z-index: 1;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 24px 20px;
    color: #fff;
}
.offering__icon {
    width: 7cqi;
    height: 7cqi;
    margin-bottom: 4cqi;
    opacity: 0.85;
}
.offering__title {
    font-size: 5cqi;
    font-weight: 400;
    letter-spacing: 0.14em;
    margin-bottom: 10px;
}
.offering__tagline {
    font-size: 4cqi;
    line-height: 1.7;
    color: rgba(255,255,255,0.88);
    font-weight: 400;
}

/* ═══════════════════════════════════════════════
   STATS
   ═══════════════════════════════════════════════ */
.stats {
    background: var(--cream);
    border-top: 1px solid var(--cream-border);
    border-bottom: 1px solid var(--cream-border);
}
.stats__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
}
.stat-item {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: clamp(20px, 3.5vw, 44px) clamp(14px, 2.5vw, 32px);
    position: relative;
    align-items: center;
    text-align: center;
}
.stat-item:not(:last-child)::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 36px;
    background: var(--cream-border);
}
.stat-item__num {
    font-size: clamp(1.5rem, 3.2vw, 2.6rem);
    font-weight: 400;
    letter-spacing: -0.03em;
    line-height: 1;
    color: var(--text);
}
.stat-item__label {
    font-size: clamp(0.5rem, 1vw, 0.6rem);
    font-weight: 400;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    text-transform: uppercase;
    line-height: 1.5;
}

/* ═══════════════════════════════════════════════
   SOCIETY PANEL  (3-column)
   ═══════════════════════════════════════════════ */
.society-panel {
    background: var(--cream);
    border-top: 1px solid var(--cream-border);
    border-bottom: 1px solid var(--cream-border);
}
.society-panel__grid {
    display: grid;
    grid-template-columns: 36% 1fr 1fr;
}
.society-panel__image {
    background-size: cover;
    background-position: center;
    min-height: clamp(340px, 40vh, 540px);
}
.society-panel__text {
    display: flex;
    flex-direction: column;
    padding: clamp(40px, 5vw, 72px) clamp(24px, 3.5vw, 52px);
    border-right: 1px solid var(--cream-border);
}
.society-panel__label {
    display: block;
    font-size: 0.6rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: var(--text-muted);
    margin-bottom: 18px;
    text-transform: uppercase;
}
.society-panel__heading {
    font-size: clamp(1.5rem, 2.4vw, 2.8rem);
    font-weight: 400;
    line-height: 1.08;
    letter-spacing: 0.185em;
    text-transform: uppercase;
    margin-bottom: 20px;
}
.society-panel__body {
    font-size: 0.88rem;
    line-height: 1.8;
    color: var(--text-muted);
    font-weight: 400;
    margin-bottom: 36px;
    flex: 1;
}
.society-panel__link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border-bottom: 1px solid var(--cream-border);
    padding-bottom: 6px;
    align-self: flex-start;
    transition: border-color 0.2s, gap 0.25s var(--ease-std);
}
.society-panel__link:hover { border-color: var(--text); gap: 18px; }
.society-panel__cta {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: clamp(40px, 5vw, 72px) clamp(24px, 3.5vw, 52px);
}
.society-panel__cta-label {
    display: block;
    width: 100%;
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: 0.18em;
    color: var(--text-muted);
    text-transform: uppercase;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--cream-border);
    margin-bottom: 40px;
}
.society-panel__cta-body {
    font-size: 0.9rem;
    line-height: 1.75;
    color: var(--text-muted);
    font-weight: 400;
    margin-bottom: 48px;
}
.society-panel__cta-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 16px 24px;
    background: var(--model-black);
    color: #fff;
    border-radius: 7px;
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    align-self: center;
    transition: opacity 0.2s;
}
.society-panel__cta-btn:hover { opacity: 0.8; }

/* ═══════════════════════════════════════════════
   INTENTIONAL SECTION  (dark)
   ═══════════════════════════════════════════════ */
.intentional {
    background: var(--dark);
    color: #fff;
    padding: clamp(64px, 9vw, 130px) var(--px);
}
.intentional__inner {
    display: grid;
    grid-template-columns: 32% 1fr;
    gap: clamp(48px, 8vw, 110px);
    align-items: start;
}

.intentional__label {
    display: block;
    font-size: 0.62rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: var(--gold);
    margin-bottom: 36px;
    text-transform: uppercase;
}
.intentional__img-wrap {
    width: 100%;
    aspect-ratio: 3 / 4;
    overflow: hidden;
}
.intentional__img {
    width: 100%; height: 100%;
    background-size: cover;
    background-position: center;
    background-color: #2a2a2a;
    transition: transform 0.7s var(--ease-std);
}
.intentional__img-wrap:hover .intentional__img { transform: scale(1.04); }

.intentional__heading {
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(1.05rem, 1.8vw, 1.55rem);
    font-weight: 400;
    line-height: 1.5;
    margin-bottom: 28px;
}
.intentional__sub {
    display: block;
    font-size: clamp(0.78rem, 0.95vw, 0.88rem);
    font-weight: 400;
    line-height: 1.7;
    color: var(--text-light);
}
.intentional__body {
    font-size: 0.88rem;
    line-height: 1.85;
    color: var(--text-light);
    font-weight: 400;
}

/* ═══════════════════════════════════════════════
   SERVICES
   ═══════════════════════════════════════════════ */
.services {
    background: var(--cream);
    padding: clamp(60px, 8vw, 110px) var(--px) clamp(60px, 8vw, 110px);
}
.services__header {
    margin-bottom: clamp(32px, 5vw, 56px);
}
.services__title {
    font-size: clamp(2rem, 5vw, 4rem);
    font-weight: 400;
    letter-spacing: -0.02em;
    line-height: 1;
}
.services__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: clamp(40px, 6vw, 100px);
    border-top: 1px solid var(--cream-border);
}

.service-item {
    display: block;
    position: relative;
    padding: 26px 40px 22px 0; /* right padding reserves space for the arrow */
    border-bottom: 1px solid var(--cream-border);
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text);
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.55s var(--ease-out),
                transform 0.55s var(--ease-out),
                color 0.2s;
}
.service-item.revealed { opacity: 1; transform: translateY(0); }
.service-item:hover { color: var(--text-muted); }

.service-item__name { display: block; }

.service-item__arrow {
    position: absolute;
    bottom: 18px;
    right: 0;
    font-size: 1rem;
    line-height: 1;
    transition: transform 0.22s var(--ease-std);
}
.service-item:hover .service-item__arrow { transform: translate(4px, 4px); }

/* ═══════════════════════════════════════════════
   MEMBERSHIP
   ═══════════════════════════════════════════════ */
.membership {
    background: var(--cream);
    padding: clamp(64px, 9vw, 110px) var(--px);
}
.membership__header { margin-bottom: clamp(40px, 6vw, 64px); }
.membership__title {
    font-size: clamp(2.4rem, 5.2vw, 5.8rem);
    font-weight: 400;
    line-height: 1;
    letter-spacing: -0.02em;
}
.membership__price {
    font-size: clamp(1.4rem, 2.6vw, 2.2rem);
    font-weight: 400;
    color: var(--gold);
    margin-top: 10px;
}
.membership__price span { font-size: 0.62em; font-weight: 400; }

.membership__body {
    display: grid;
    grid-template-columns: 50% 1fr;
    gap: clamp(24px, 4vw, 64px);
    align-items: start;
}
.membership__right {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-left: 12%;
}

.benefit-group { margin-bottom: 34px; }
.benefit-group:last-child { margin-bottom: 0; }
.benefit-group__title {
    font-size: 1.05rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    margin-bottom: 12px;
}
.benefit-list li {
    font-size: 0.86rem;
    line-height: 1.65;
    color: var(--text-muted);
    padding-left: 12px;
    position: relative;
    font-weight: 400;
}
.benefit-list li::before { content: '·'; position: absolute; left: 0; color: var(--text); }

.membership__tagline {
    font-size: 0.95rem;
    line-height: 1.75;
    color: var(--text-muted);
    font-weight: 400;
    margin-bottom: 24px;
    max-width: 480px;
    text-align: justify;
}

.membership__diamond-wrap { position: relative; }
.membership__logo-img {
    width: 100%;
    max-width: 480px;
    height: auto;
    display: block;
    transition: transform 0.5s var(--ease-out);
}
.membership__logo-img:hover {
    transform: scale(1.03);
}

/* ═══════════════════════════════════════════════
   TOUR CTA  (dark)
   ═══════════════════════════════════════════════ */
.tour {
    background: var(--dark);
    color: #fff;
    padding: clamp(64px, 9vw, 120px) var(--px);
}
.tour__inner {
    display: grid;
    grid-template-columns: 38% 1fr;
    gap: clamp(48px, 9vw, 130px);
    align-items: center;
}

.tour__label {
    display: block;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.85rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    width: 225px;
    text-align: center;
    color: var(--gold);
    margin-bottom: 24px;
    text-transform: uppercase;
}
.tour__left {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.tour__mark-wrap { max-width: 220px; }
.tour__logo-img {
    width: 100%;
    height: auto;
    opacity: 0.85;
}

.tour__title {
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(2rem, 3.4vw, 3.5rem);
    font-weight: 400;
    line-height: 1.15;
    letter-spacing: 0.185em;
    text-transform: uppercase;
    margin-bottom: 20px;
}
.tour__body {
    font-size: 0.9rem;
    line-height: 1.8;
    color: var(--text-light);
    font-weight: 400;
    margin-bottom: 44px;
    max-width: 420px;
}

.tour__cta {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border-bottom: 1px solid rgba(255,255,255,0.35);
    padding-bottom: 8px;
    transition: border-color 0.2s, gap 0.25s var(--ease-std);
}
.tour__cta:hover { border-color: #fff; gap: 22px; }
.tour__cta-arrow {
    font-size: 1rem;
    transition: transform 0.22s var(--ease-std);
}
.tour__cta:hover .tour__cta-arrow { transform: translate(5px, -5px); }

/* ═══════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════ */
.footer {
    background: var(--dark);
    color: rgba(255,255,255,0.45);
    border-top: 1px solid rgba(255,255,255,0.08);
    padding: 22px var(--px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
}
.footer__copy { font-size: 0.72rem; }
.footer__links { display: flex; gap: 28px; flex-wrap: wrap; }
.footer__links a {
    font-size: 0.72rem;
    transition: color 0.2s;
}
.footer__links a:hover { color: #fff; }
.footer__links a.active { pointer-events: none; cursor: default; opacity: 0.4; }
.footer__brand {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.22em;
    color: rgba(255,255,255,0.55);
    transition: color 0.2s;
}
.footer__logo-img { height: 22px; width: auto; }
.footer__brand:hover { color: #fff; }

/* ═══════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
   ═══════════════════════════════════════════════ */
@media (max-width: 1100px) {
    .membership__body { grid-template-columns: 1fr; }
    .membership__right { align-items: center; padding-left: 0; }
    .tour__inner { grid-template-columns: 1fr; gap: 56px; }
    .tour__mark-wrap { max-width: 140px; }
    .society-panel__grid { grid-template-columns: 1fr 1fr; }
    .society-panel__image { display: none; }
}

@media (max-width: 900px) {
    .hero { grid-template-columns: 1fr; height: auto; padding-top: var(--nav-h); }
    .hero__left { padding-top: clamp(48px, 6vw, 80px); }
    .hero__right {
        height: 56vw;
        clip-path: none;
    }
    .hero__heading { font-size: clamp(3.2rem, 12vw, 5.5rem); }
    .intentional__inner { grid-template-columns: 1fr; gap: 44px; }
    .intentional__img-wrap { aspect-ratio: 4/3; max-width: 420px; }
}

@media (max-width: 640px) {
    :root { --nav-h: 56px; }
    .hero__right { height: 72vw; }
    .offering { display: none; }
    .offering__grid { grid-template-columns: repeat(2, 1fr); }
    .services__grid { grid-template-columns: 1fr; column-gap: 0; }
    .membership__body { grid-template-columns: 1fr; }
    .society-panel__grid { grid-template-columns: 1fr; }
    .society-panel__text { border-right: none; border-bottom: 1px solid var(--cream-border); }
    .society-panel__cta { align-items: center; text-align: center; }
    .society-panel__cta-label { width: 100%; }
    .society-panel__cta-btn { align-self: center; }
    .footer { flex-direction: column; align-items: flex-start; }
    .footer__logo-img { display: none; }
    .tour__mark-wrap { display: none; }
}

/* ── Reduced motion ────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .reveal, .service-item, .hero__heading .line span {
        transition: none;
        animation: none;
        opacity: 1;
        transform: none;
    }
    body { cursor: auto; }
    .cursor { display: none; }
}

/* ═══════════════════════════════════════════════
   PAGE HERO  (membership & contact pages)
   ═══════════════════════════════════════════════ */
.page-hero {
    background: var(--cream);
    padding: calc(var(--nav-h) + clamp(48px, 7vw, 90px)) var(--px) clamp(48px, 6vw, 80px);
    border-bottom: 1px solid var(--cream-border);
}
.page-hero__label {
    display: block;
    font-size: 0.85rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: var(--gold);
    margin-bottom: 24px;
}
.page-hero__title {
    font-size: clamp(2.8rem, 6vw, 7rem);
    font-weight: 400;
    line-height: 1;
    letter-spacing: -0.025em;
    margin-bottom: 16px;
}
.page-hero__price {
    font-size: clamp(1.6rem, 3vw, 2.6rem);
    font-weight: 400;
    color: var(--gold);
}
.page-hero__price span { font-size: 0.6em; font-weight: 400; }

/* ═══════════════════════════════════════════════
   MEMBERSHIP PAGE
   ═══════════════════════════════════════════════ */
.mem-section {
    background: var(--cream);
    padding: clamp(60px, 8vw, 110px) var(--px);
}
.mem-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 48px 60px;
}
.mem-group__title {
    font-size: 0.65rem;
    font-weight: 400;
    letter-spacing: 0.16em;
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--cream-border);
}
.mem-group__list li {
    font-size: 0.9rem;
    line-height: 1.7;
    color: var(--text-muted);
    font-weight: 400;
    padding-left: 12px;
    position: relative;
}
.mem-group__list li::before { content: '·'; position: absolute; left: 0; color: var(--text); }

.mem-cta {
    background: var(--dark);
    color: #fff;
    padding: clamp(60px, 8vw, 110px) var(--px);
}
.mem-cta__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(40px, 8vw, 100px);
    align-items: center;
}
.mem-cta__heading {
    font-size: clamp(2rem, 4vw, 4rem);
    font-weight: 400;
    line-height: 1.05;
    letter-spacing: 0.185em;
    text-transform: uppercase;
}
.mem-cta__sub {
    font-size: 0.95rem;
    line-height: 1.8;
    color: var(--text-light);
    font-weight: 400;
    margin-top: 20px;
}
.mem-form { display: flex; flex-direction: column; gap: 16px; }
.mem-form input, .mem-form select {
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 7px;
    color: #fff;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.78rem;
    font-weight: 400;
    padding: 13px 16px;
    outline: none;
    transition: border-color 0.2s;
}
.mem-form input::placeholder { color: rgba(255,255,255,0.4); }
.mem-form input:focus, .mem-form select:focus { border-color: var(--gold); }
.mem-form select { color: rgba(255,255,255,0.4); appearance: none; }
.mem-form select option { background: var(--dark); color: #fff; }
.mem-form__btn {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 28px;
    background: var(--gradient);
    color: #111;
    border-radius: 7px;
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border: none;
    cursor: none;
    transition: opacity 0.2s;
    margin-top: 8px;
}
.mem-form__btn:hover { opacity: 0.85; }
.mem-form__btn:disabled { opacity: 0.5; cursor: not-allowed; }

@media (max-width: 1024px) { .mem-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 768px) {
    .mem-grid { grid-template-columns: 1fr; }
    .mem-cta__inner { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════
   CONTACT PAGE
   ═══════════════════════════════════════════════ */
.contact-hero {
    background: var(--cream);
    padding: calc(var(--nav-h) + clamp(60px, 9vw, 120px)) var(--px) clamp(48px, 6vw, 80px);
    border-bottom: 1px solid var(--cream-border);
}
.contact-hero__label {
    display: block;
    font-size: 0.62rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: var(--gold);
    margin-bottom: 24px;
}
.contact-hero__title {
    font-size: clamp(2.8rem, 6vw, 7rem);
    font-weight: 400;
    line-height: 1;
    letter-spacing: -0.025em;
    margin-bottom: 20px;
}
.contact-hero__sub {
    font-size: 1rem;
    line-height: 1.75;
    color: var(--text-muted);
    font-weight: 400;
    max-width: 480px;
}
.contact-body {
    background: var(--cream);
    padding: clamp(60px, 8vw, 110px) var(--px);
}
.contact-body__inner {
    display: grid;
    grid-template-columns: 42% 1fr;
    gap: clamp(48px, 8vw, 120px);
    align-items: start;
}
.contact-info__heading {
    font-size: clamp(1.4rem, 2.4vw, 2rem);
    font-weight: 400;
    margin-bottom: 32px;
    line-height: 1.2;
    letter-spacing: 0.185em;
    text-transform: uppercase;
}
.contact-detail {
    padding: 24px 0;
    border-bottom: 1px solid var(--cream-border);
}
.contact-detail:first-of-type { border-top: 1px solid var(--cream-border); }
.contact-detail__label {
    font-size: 0.62rem;
    font-weight: 400;
    letter-spacing: 0.16em;
    color: var(--gold);
    margin-bottom: 8px;
}
.contact-detail__value {
    font-size: 0.92rem;
    font-weight: 400;
    line-height: 1.6;
    color: var(--text);
}
.contact-detail__value a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 3px;
}
.contact-form { display: flex; flex-direction: column; gap: 14px; }
.contact-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.contact-form input,
.contact-form select,
.contact-form textarea {
    background: transparent;
    border: 1px solid var(--cream-border);
    border-radius: 7px;
    color: var(--text);
    font-family: 'Montserrat', sans-serif;
    font-size: 0.88rem;
    font-weight: 400;
    padding: 13px 16px;
    outline: none;
    transition: border-color 0.2s;
    width: 100%;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder { color: rgba(0,0,0,0.35); }
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus { border-color: var(--text); }
.contact-form select { appearance: none; color: rgba(0,0,0,0.35); }
.contact-form select option { color: var(--text); }
.contact-form textarea { resize: none; height: 100px; }
.contact-form__label {
    font-size: 0.62rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    margin-top: 16px;
    margin-bottom: 4px;
}
.contact-form__btn {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 28px;
    background: rgba(0,0,0,0.35);
    color: #111;
    border-radius: 7px;
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border: none;
    cursor: none;
    margin-top: 20px;
    transition: opacity 0.2s;
}
.contact-form__btn:hover { opacity: 0.8; }
.contact-form__btn:disabled { opacity: 0.5; cursor: not-allowed; }
.contact-img {
    width: 100%;
    height: clamp(280px, 40vw, 520px);
    overflow: hidden;
    background-image: url('images/1.png?v=3');
    background-size: cover;
    background-position: center 40%;
}

@media (max-width: 900px) {
    .contact-body__inner { grid-template-columns: 1fr; }
    .contact-form__row { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════
   FORM STATUS MESSAGES  (shared)
   ═══════════════════════════════════════════════ */
.form-status {
    padding: 12px 16px;
    font-size: 0.82rem;
    font-weight: 400;
    letter-spacing: 0.04em;
    border-radius: 7px;
    display: none;
}
.contact-form .form-status--success,
.ct-form .form-status--success { background: rgba(255,255,255,.06); color: #aaaaaa; border-left: 3px solid #888; display: block; }
.contact-form .form-status--error,
.ct-form .form-status--error   { background: rgba(239,68,68,.1);   color: #b91c1c; border-left: 3px solid #ef4444; display: block; }
.mem-form     .form-status--success { background: rgba(255,255,255,.06); color: #aaaaaa; border-left: 3px solid #888; display: block; }
.mem-form     .form-status--error   { background: rgba(239,68,68,.15);  color: #fca5a5; border-left: 3px solid #ef4444; display: block; }

/* ═══════════════════════════════════════════════
   ABOUT PAGE
   ═══════════════════════════════════════════════ */
.ticker {
    background: var(--gold);
    padding: 14px 0;
    overflow: hidden;
    white-space: nowrap;
}
.ticker__track {
    display: inline-flex;
    animation: ticker 22s linear infinite;
}
.ticker__item {
    font-size: 0.7rem;
    font-weight: 400;
    letter-spacing: 0.18em;
    color: #fff;
    padding: 0 40px;
}
.ticker__dot { opacity: 0.5; }
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(-50%); } }


/* ═══════════════════════════════════════════════
   ABOUT PAGE — REDESIGN
   ═══════════════════════════════════════════════ */

/* About hero tagline */
.a-hero {
    background: #ffffff;
    min-height: 70vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 160px var(--px) 120px;
    text-align: center;
}
.a-hero__inner {
    max-width: 1100px;
}
.a-hero__mark {
    display: block;
    font-size: 6rem;
    line-height: 0.5;
    color: var(--gold);
    opacity: 0.5;
    margin-bottom: 40px;
    font-weight: 400;
}
.a-hero__tagline {
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(2rem, 3.8vw, 3.8rem);
    font-weight: 400;
    color: #0d0d0d;
    line-height: 1.1;
    letter-spacing: -0.03em;
    margin: 0 0 40px;
    font-style: normal;
    text-transform: uppercase;
}
.a-hero__attr {
    display: block;
    font-size: 0.65rem;
    letter-spacing: 0.22em;
    color: rgba(0,0,0,0.35);
    font-weight: 400;
}
.a-hero__body {
    font-size: 0.95rem;
    color: rgba(0,0,0,0.55);
    line-height: 1.85;
    max-width: 620px;
    font-weight: 400;
    margin: 0 auto;
}

/* Story section */
.a-story {
    background: #0d0d0d;
    padding: clamp(80px, 10vw, 140px) var(--px) clamp(80px, 10vw, 120px);
}
.a-story__inner { width: 100%; }
.a-story__label-row {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 48px;
    width: 100%;
}
.a-story__label {
    font-size: 0.62rem;
    letter-spacing: 0.18em;
    color: var(--gold);
    white-space: nowrap;
    font-weight: 400;
    flex-shrink: 0;
}
.a-story__label-line {
    width: 160px;
    flex-shrink: 0;
    height: 1px;
    background: rgba(255,255,255,0.18);
}
.a-story__heading {
    font-size: clamp(2.4rem, 5.2vw, 5.8rem);
    font-weight: 400;
    color: #fff;
    letter-spacing: 0.01em;
    line-height: 1.05;
    margin-bottom: 32px;
    text-transform: uppercase;
}
.a-story__body {
    font-size: 0.95rem;
    color: rgba(255,255,255,0.75);
    line-height: 1.85;
    max-width: 100%;
    margin-bottom: 40px;
    font-weight: 400;
}
.a-story__pillars {
    list-style: none;
    padding: 0;
    margin: 0 0 40px;
    max-width: 100%;
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.a-story__pillars li {
    font-size: 0.95rem;
    color: rgba(255,255,255,0.75);
    line-height: 1.85;
    font-weight: 400;
    padding-left: 0;
}
.a-story__pillars li strong {
    color: #fff;
    font-weight: 400;
    letter-spacing: 0.04em;
}
.a-story__expand {
    display: none;
    height: 0;
    overflow: hidden;
}
.a-story__toggle {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: transparent;
    border: none;
    border-bottom: 1px solid rgba(255,255,255,0.25);
    color: rgba(255,255,255,0.55);
    font-family: 'Montserrat', sans-serif;
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: 0.22em;
    padding: 0 0 4px;
    cursor: pointer;
    margin-top: 8px;
    margin-bottom: 40px;
    transition: color 0.25s, border-color 0.25s;
}
.a-story__toggle:hover { color: #fff; border-color: #fff; }
.a-story__toggle-arrow {
    display: inline-block;
    transition: transform 0.35s ease;
    font-size: 0.8rem;
}
.a-vm-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.a-vm-card {
    background: #161616;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 7px;
    padding: 48px 44px;
}
.a-vm-card__label {
    font-size: 0.62rem;
    letter-spacing: 0.2em;
    color: var(--gold);
    display: block;
    margin-bottom: 24px;
    font-weight: 400;
    text-transform: uppercase;
}
.a-vm-card__text {
    font-size: 0.92rem;
    color: rgba(255,255,255,0.65);
    line-height: 1.9;
    font-weight: 400;
}

/* Founders section */
.a-founders {
    background: #ffffff;
    padding: 100px var(--px) 100px;
}
.a-founders__inner { width: 100%; }
.a-founders__header { margin-bottom: 52px; }
.a-founders__label-row {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 28px;
    width: 100%;
}
.a-founders__label {
    font-size: 0.8rem;
    letter-spacing: 0.2em;
    color: var(--gold);
    white-space: nowrap;
    font-weight: 400;
    flex-shrink: 0;
}
.a-founders__line {
    width: 35%;
    flex-shrink: 0;
    height: 1px;
    background: rgba(0,0,0,0.35);
}
.a-founders__heading {
    font-size: clamp(2rem, 3.8vw, 3.5rem);
    font-weight: 400;
    color: #0d0d0d;
    line-height: 1.1;
    letter-spacing: -0.01em;
}
.a-founders__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.a-founder-card {
    background: #141414;
    overflow: hidden;
    border-radius: 7px;
}
.a-founder-card__photo {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
    object-position: top center;
    display: block;
}
.a-founder-card__body { padding: 28px 28px 36px; }
.a-founder-card__name {
    font-size: 0.9rem;
    font-weight: 400;
    color: #fff;
    letter-spacing: 0.12em;
    margin: 0 0 4px;
}
.a-founder-card__role {
    font-size: 0.58rem;
    letter-spacing: 0.2em;
    color: rgba(255,255,255,0.35);
    display: block;
    margin-bottom: 16px;
}
.a-founder-card__bio {
    font-size: 0.84rem;
    color: rgba(255,255,255,0.55);
    line-height: 1.75;
}

/* About CTA (white) */
.a-about-cta {
    background: #f5f5f0;
    text-align: center;
    padding: 140px var(--px);
}
.a-about-cta__label {
    display: block;
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    color: #0d0d0d;
    font-weight: 400;
    margin-bottom: 28px;
}
.a-about-cta__heading {
    font-size: clamp(2.2rem, 5vw, 5.5rem);
    font-weight: 400;
    color: #0d0d0d;
    line-height: 1.05;
    letter-spacing: -0.02em;
    margin-bottom: 28px;
}
.a-about-cta__note {
    font-size: 0.82rem;
    color: #0d0d0d;
    letter-spacing: 0.06em;
    margin-bottom: 48px;
}
.a-about-cta__btn {
    display: inline-block;
    background: #d4d4d4;
    border: none;
    color: #1a1a1a;
    font-size: 0.7rem;
    letter-spacing: 0.15em;
    font-weight: 400;
    padding: 20px 52px;
    text-decoration: none;
    border-radius: 7px;
    transition: opacity 0.25s;
}
.a-about-cta__btn:hover { opacity: 0.8; }

@media (max-width: 860px) {
    .a-vm-grid { grid-template-columns: 1fr; }
    .a-founders__grid { grid-template-columns: 1fr; gap: 16px; }
    .a-founder-card__photo { aspect-ratio: 4/3; }
    .a-story { padding: 100px var(--px) 80px; }
    .a-founders { padding-top: 60px; }
    .a-hero { min-height: unset; padding: 100px var(--px) 80px; }
    .a-hero__tagline { font-size: clamp(1rem, 5vw, 2rem); white-space: pre-line; }
}
@media (max-width: 560px) {
    .a-vm-card { padding: 28px 24px; }
    .a-about-cta { padding: 100px var(--px); }
}

/* ═══════════════════════════════════════════════
   EVENTS PAGE
   ═══════════════════════════════════════════════ */

.ev-hero {
    background: #0d0d0d;
    padding: 160px var(--px) 80px;
}
.ev-hero__label-row {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 36px;
    width: 100%;
}
.ev-hero__label {
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    color: var(--gold);
    font-weight: 400;
    flex-shrink: 0;
}
.ev-hero__line {
    width: 35%;
    height: 1px;
    background: rgba(255,255,255,0.45);
    flex-shrink: 0;
}
.ev-hero__heading {
    font-size: clamp(3rem, 8vw, 7rem);
    font-weight: 400;
    color: #fff;
    letter-spacing: -0.03em;
    line-height: 1;
    margin-bottom: 28px;
}
.ev-hero__sub {
    font-size: 0.92rem;
    color: rgba(255,255,255,0.45);
    line-height: 1.85;
    max-width: 560px;
    margin-bottom: 48px;
}
.ev-notice {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 7px;
    padding: 24px 28px;
    max-width: 780px;
    margin-bottom: 48px;
}
.ev-notice__icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    color: rgba(255,255,255,0.3);
    margin-top: 2px;
}
.ev-notice p {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.4);
    line-height: 1.75;
}
.ev-notice p a {
    color: var(--gold);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s;
}
.ev-notice p a:hover { border-color: var(--gold); }

.ev-list {
    background: #0d0d0d;
    padding: 20px var(--px) 100px;
    scroll-margin-top: 80px;
}
.ev-list__inner { border-top: 1px solid rgba(255,255,255,0.08); }
.ev-row {
    display: grid;
    grid-template-columns: 120px 1fr auto;
    align-items: center;
    gap: 32px;
    padding: 36px 0;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    transition: background 0.2s;
}
.ev-row:hover { background: rgba(255,255,255,0.02); }
.ev-row__date { text-align: center; }
.ev-row__day {
    display: block;
    font-size: 2.8rem;
    font-weight: 400;
    color: #fff;
    line-height: 1;
    letter-spacing: -0.03em;
}
.ev-row__month {
    display: block;
    font-size: 0.58rem;
    letter-spacing: 0.15em;
    color: var(--gold);
    font-weight: 400;
    margin-top: 4px;
    white-space: nowrap;
}
.ev-row__date--range {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1px;
    text-align: center;
}
.ev-row__range-item {
    display: block;
    font-size: 0.9rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    color: #fff;
    line-height: 1.3;
    text-transform: uppercase;
    white-space: nowrap;
}
.ev-row__range-sep {
    display: block;
    font-size: 0.55rem;
    color: rgba(255,255,255,0.3);
    letter-spacing: 0.1em;
    line-height: 1;
}
.ev-row__title {
    font-size: 1rem;
    font-weight: 400;
    color: #fff;
    letter-spacing: 0.05em;
    margin-bottom: 8px;
}
.ev-row__meta {
    font-size: 0.78rem;
    color: rgba(255,255,255,0.35);
    letter-spacing: 0.02em;
}
.ev-row__badge {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.58rem;
    letter-spacing: 0.18em;
    color: rgba(255,255,255,0.25);
    font-weight: 400;
    white-space: nowrap;
}
.ev-row__badge svg { width: 14px; height: 14px; flex-shrink: 0; }

/* Event categories */
.ev-cats {
    background: #f5f5f0;
    padding: 100px var(--px);
}
.ev-cats__header {
    margin-bottom: 64px;
}
.ev-cats__label {
    display: block;
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    color: var(--gold);
    font-weight: 400;
    margin-bottom: 20px;
}
.ev-cats__heading {
    font-size: clamp(1.8rem, 3.5vw, 3.2rem);
    font-weight: 400;
    color: #0d0d0d;
    line-height: 1.1;
    letter-spacing: -0.02em;
}
.ev-cats__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
}
.ev-cat {
    padding: 36px 32px;
    border-right: 1px solid rgba(0,0,0,0.1);
    border-top: 1px solid rgba(0,0,0,0.1);
    border-bottom: 1px solid rgba(0,0,0,0.1);
}
.ev-cat:first-child {
    border-left: 1px solid rgba(0,0,0,0.1);
    border-radius: 7px 0 0 7px;
}
.ev-cat:last-child {
    border-radius: 0 7px 7px 0;
}
.ev-cat__num {
    display: block;
    font-size: 0.58rem;
    letter-spacing: 0.18em;
    color: var(--gold);
    font-weight: 400;
    margin-bottom: 20px;
}
.ev-cat__title {
    font-size: 0.82rem;
    font-weight: 400;
    color: #0d0d0d;
    letter-spacing: 0.06em;
    margin-bottom: 16px;
    line-height: 1.3;
}
.ev-cat__desc {
    font-size: 0.8rem;
    color: rgba(0,0,0,0.5);
    line-height: 1.75;
}

/* Upcoming events header */
.ev-list__header {
    margin-bottom: 40px;
}
.ev-list__heading {
    font-size: clamp(2rem, 4vw, 3.5rem);
    font-weight: 400;
    color: #fff;
    letter-spacing: -0.02em;
    line-height: 1;
    margin: 20px 0 16px;
}
.ev-list__sub {
    font-size: 0.88rem;
    color: rgba(255,255,255,0.4);
    line-height: 1.75;
    max-width: 520px;
    margin-bottom: 32px;
}

/* Scroll link */
.ev-hero__scroll {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 0.65rem;
    letter-spacing: 0.15em;
    font-weight: 400;
    color: rgba(255,255,255,0.4);
    text-decoration: none;
    margin-top: 48px;
    transition: color 0.2s;
}
.ev-hero__scroll:hover { color: #fff; }

@media (max-width: 1024px) {
    .ev-cats__grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
    .ev-cats__grid { grid-template-columns: 1fr; gap: 12px; }
    .ev-cats { padding: 80px var(--px); }
    .ev-cat,
    .ev-cat:first-child,
    .ev-cat:last-child {
        border: 1px solid rgba(0,0,0,0.1);
        border-radius: 7px;
    }
}

.ev-cta {
    background: #ffffff;
    text-align: center;
    padding: 140px var(--px);
}
.ev-cta__label {
    display: block;
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    color: var(--gold);
    font-weight: 400;
    margin-bottom: 28px;
}
.ev-cta__heading {
    font-size: clamp(2rem, 4.5vw, 4.5rem);
    font-weight: 400;
    color: #0d0d0d;
    line-height: 1.1;
    letter-spacing: -0.01em;
    margin-bottom: 24px;
}
.ev-cta__sub {
    font-size: 0.9rem;
    color: rgba(0,0,0,0.5);
    margin: 0 auto 48px;
    max-width: 480px;
    line-height: 1.75;
}
.ev-cta__btn {
    display: inline-block;
    background: #d4d4d4;
    color: #1a1a1a;
    font-size: 0.7rem;
    font-weight: 400;
    letter-spacing: 0.15em;
    padding: 20px 52px;
    border-radius: 7px;
    border: none;
    text-decoration: none;
    transition: opacity 0.25s;
}
.ev-cta__btn:hover { opacity: 0.8; }

@media (max-width: 700px) {
    .ev-row { grid-template-columns: 80px 1fr; gap: 20px; }
    .ev-row__badge { display: none; }
    .ev-hero { padding: 120px var(--px) 60px; }
    .ev-cta { padding: 100px var(--px); }
}

/* ═══════════════════════════════════════════════
   CONTACT PAGE
   ═══════════════════════════════════════════════ */

/* Hero */
.ct-hero {
    background: #0d0d0d;
    padding: 160px var(--px) 100px;
}
.ct-hero__inner { max-width: 800px; }
.ct-hero__label-row {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 36px;
    width: 100%;
}
.ct-hero__label {
    font-size: 0.62rem;
    letter-spacing: 0.2em;
    color: var(--gold);
    font-weight: 400;
    flex-shrink: 0;
}
.ct-hero__line {
    width: 35%;
    height: 1px;
    background: rgba(255,255,255,0.18);
    flex-shrink: 0;
}
.ct-hero__heading {
    font-size: clamp(3rem, 7vw, 7rem);
    font-weight: 400;
    color: #fff;
    letter-spacing: -0.03em;
    line-height: 1;
    margin-bottom: 24px;
}
.ct-hero__sub {
    font-size: 0.95rem;
    color: rgba(255,255,255,0.45);
    line-height: 1.85;
    max-width: 520px;
}

/* Body: info + form */
.ct-body {
    background: #ffffff;
}

/* Top split: info panel left, map right */
.ct-body__split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 580px;
    align-items: stretch;
}

/* Left: off-white info panel */
.ct-info-panel {
    background: #f5f5f0;
    padding: 72px 60px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.ct-info-panel .ct-detail {
    margin-bottom: 32px;
}
.ct-info-panel .ct-detail:last-child { margin-bottom: 0; }
.ct-info-panel .ct-detail__value {
    color: #2a2a2a;
}
.ct-info-panel .ct-detail__value a {
    color: #2a2a2a;
    border-bottom-color: rgba(0,0,0,0.2);
}
.ct-info-panel .ct-detail__value a:hover { color: #0d0d0d; border-bottom-color: #0d0d0d; }
.ct-info-panel .ct-social { color: #2a2a2a; }
.ct-info-panel .ct-social:hover { color: var(--gold); }

/* Right: map panel */
.ct-map-panel {
    position: relative;
    min-height: 500px;
    background: #F4F4F4;
}
.ct-map-panel iframe,
.ct-map-panel #gmap {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
    border: 0;
    filter: grayscale(25%);
}

/* Right: form panel (inside split) */
.ct-form-section {
    background: #111111;
    padding: clamp(40px, 5vw, 72px) clamp(28px, 4vw, 60px);
}
.ct-form-section__inner {
    max-width: 100%;
    margin: 0;
}

/* Full-width map below split */
.ct-map-full {
    height: 420px;
    position: relative;
    background: #F4F4F4;
}
#gmap-mobile {
    width: 100%;
    height: 100%;
    border-radius: 7px;
}
.ct-map-full #gmap {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

/* Shared detail styles */
.ct-detail {
    margin-bottom: 36px;
}
.ct-detail__label {
    font-size: 0.58rem;
    letter-spacing: 0.2em;
    color: var(--gold);
    font-weight: 400;
    display: block;
    margin-bottom: 10px;
}
.ct-detail__value {
    font-size: 0.9rem;
    color: #2a2a2a;
    line-height: 1.75;
}
.ct-detail__value a {
    color: #2a2a2a;
    text-decoration: none;
    border-bottom: 1px solid rgba(0,0,0,0.2);
    transition: border-color 0.2s, color 0.2s;
}
.ct-detail__value a:hover { color: #0d0d0d; border-color: #0d0d0d; }
.ct-socials {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 4px;
}
.ct-social {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.82rem;
    color: #2a2a2a;
    text-decoration: none;
    font-weight: 400;
    letter-spacing: 0.04em;
    transition: color 0.2s;
}
.ct-social:hover { color: var(--gold); }
.ct-social svg { width: 18px; height: 18px; flex-shrink: 0; }

/* Form column */
.ct-form__heading {
    font-size: 1.4rem;
    font-weight: 400;
    color: #ffffff;
    letter-spacing: -0.01em;
    margin-bottom: 36px;
    text-align: center;
}
.ct-form { display: flex; flex-direction: column; gap: 16px; }
.ct-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ct-form__field { display: flex; flex-direction: column; }
.ct-form input,
.ct-form textarea {
    width: 100%;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 7px;
    padding: 16px 20px;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.72rem;
    letter-spacing: 0.1em;
    color: #ffffff;
    outline: none;
    transition: border-color 0.2s;
    box-sizing: border-box;
}
.ct-form input::placeholder,
.ct-form textarea::placeholder { color: rgba(255,255,255,0.4); }
.ct-form input:focus,
.ct-form textarea:focus { border-color: rgba(255,255,255,0.4); }
.ct-form textarea { resize: vertical; min-height: 140px; }
.ct-form__btn {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    background: transparent;
    color: #ffffff;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.7rem;
    font-weight: 400;
    letter-spacing: 0.15em;
    padding: 18px 40px;
    border: 1px solid rgba(255,255,255,0.6);
    border-radius: 7px;
    cursor: pointer;
    transition: border-color 0.25s, gap 0.25s;
    align-self: flex-start;
    margin-top: 8px;
}
.ct-form__btn:hover { border-color: #fff; gap: 20px; }

/* Mobile inline map (hidden on desktop) */
.ct-map--inline {
    display: none;
    width: 100%;
    height: 200px;
    margin: 16px 0 0;
    filter: grayscale(25%);
    border-radius: 7px;
    overflow: hidden;
}

/* CTA */
.ct-cta {
    background: #0d0d0d;
    padding: 120px var(--px);
    text-align: center;
}
.ct-cta__label {
    display: block;
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    color: var(--gold);
    font-weight: 400;
    margin-bottom: 24px;
}
.ct-cta__heading {
    font-size: clamp(2.5rem, 5vw, 5.5rem);
    font-weight: 400;
    color: #fff;
    line-height: 1.05;
    letter-spacing: -0.02em;
    margin-bottom: 48px;
}
.ct-cta__btn {
    display: inline-block;
    border: 1px solid rgba(255,255,255,0.35);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 400;
    letter-spacing: 0.15em;
    padding: 18px 48px;
    text-decoration: none;
    transition: border-color 0.25s, color 0.25s;
}
.ct-cta__btn:hover { border-color: #fff; }

/* Mobile map under location */
.ct-map-mobile {
    display: none;
    width: 100%;
    height: 220px;
    border-radius: 7px;
    overflow: hidden;
    border-radius: 7px;
    overflow: hidden;
    margin-top: 16px;
}

@media (max-width: 860px) {
    .ct-body__split { grid-template-columns: 1fr; }
    .ct-info-panel { padding: 56px var(--px); }
    .ct-form-section { padding: 60px var(--px); }
    .ct-hero { padding: 120px var(--px) 80px; }
    .ct-map--inline { display: block; }
    .ct-map-mobile { display: block; }
    .ct-map-full { display: none; }
}
@media (max-width: 560px) {
    .ct-form__row { grid-template-columns: 1fr; }
    .ct-cta { padding: 90px var(--px); }
}

/* ═══════════════════════════════════════════════
   PRIVACY POLICY PAGE
   ═══════════════════════════════════════════════ */
.privacy-hero {
    background: var(--cream);
    padding: calc(var(--nav-h) + clamp(48px, 7vw, 90px)) var(--px) clamp(40px, 5vw, 64px);
    border-bottom: 1px solid var(--cream-border);
}
.privacy-hero__label {
    display: block;
    font-size: 0.62rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: var(--gold);
    margin-bottom: 20px;
}
.privacy-hero__title {
    font-size: clamp(2.4rem, 5vw, 5.5rem);
    font-weight: 400;
    line-height: 1;
    letter-spacing: -0.025em;
}
.privacy-body {
    background: var(--cream);
    padding: clamp(48px, 7vw, 90px) var(--px);
    max-width: 780px;
}
.privacy-body h2 {
    font-size: 0.65rem;
    font-weight: 400;
    letter-spacing: 0.16em;
    margin-top: 40px;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--cream-border);
}
.privacy-body h2:first-child { margin-top: 0; }
.privacy-body p {
    font-size: 0.9rem;
    line-height: 1.8;
    color: var(--text-muted);
    font-weight: 400;
    margin-bottom: 12px;
}
.privacy-body a {
    color: var(--text);
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* ═══════════════════════════════════════════════
   NAV CTA — PILL / INQUIRE VARIANT
   ═══════════════════════════════════════════════ */
.nav__cta--pill {
    padding: 10px 26px;
    border-bottom: none;
    border: 1px solid rgba(255,255,255,0.55);
    border-radius: 7px;
    font-size: 0.85rem;
    font-weight: 400;
    letter-spacing: 0.16em;
    color: #1a1a1a;
    background: linear-gradient(180deg, #f0eeeb 0%, #d6d2cc 35%, #b8b4ae 65%, #ccc9c4 100%);
    box-shadow: 0 4px 24px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.6);
    transition: opacity 0.2s, box-shadow 0.2s;
}
.nav__cta--pill:hover {
    opacity: 0.9;
    box-shadow: 0 4px 14px rgba(0,0,0,0.35);
}
.nav--dark .nav__cta--pill,
.nav--scrolled .nav__cta--pill { color: #2a1a0e; }

/* ═══════════════════════════════════════════════
   HERO DARK  (new home hero)
   ═══════════════════════════════════════════════ */
.hero-dark {
    display: grid;
    grid-template-columns: 54% 1fr;
    min-height: 100vh;
    background: #0d0d0d;
    color: #fff;
}
.hero-dark__left {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    overflow: visible;
    padding: clamp(48px, 6vw, 80px) var(--px);
    padding-top: calc(var(--nav-h) + clamp(100px, 10vw, 140px));
    padding-bottom: clamp(60px, 8vw, 110px);
}
.hero-dark__heading {
    font-size: clamp(2.4rem, 5vw, 6rem);
    white-space: nowrap;
    font-weight: 400;
    line-height: 0.95;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    margin-bottom: 32px;
}
.hero-dark__heading .line {
    display: block;
    overflow: hidden;
}
.hero-dark__heading .line span {
    display: block;
    transform: translateY(110%);
}
.hero-dark__heading.animate .line:nth-child(1) span { animation: slideUp 0.9s var(--ease-out) 0.05s forwards; }
.hero-dark__heading.animate .line:nth-child(2) span { animation: slideUp 0.9s var(--ease-out) 0.16s forwards; }
.hero-dark__heading.animate .line:nth-child(3) span { animation: slideUp 0.9s var(--ease-out) 0.27s forwards; }
.hero-dark__heading .line:nth-child(3) { color: rgba(255,255,255,0.35); }

.hero-dark__description {
    font-size: clamp(1rem, 1.4vw, 1.2rem);
    line-height: 1.75;
    color: #fff;
    max-width: 480px;
    margin-bottom: 36px;
}
.hero-dark__cta {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 11px 20px;
    background: linear-gradient(180deg, #f0eeeb 0%, #d6d2cc 35%, #b8b4ae 65%, #ccc9c4 100%);
    border: 1px solid rgba(255,255,255,0.55);
    border-radius: 7px;
    color: #1a1a1a;
    font-size: 0.82rem;
    font-weight: 400;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    align-self: flex-start;
    box-shadow: 0 4px 24px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.6);
    transition: opacity 0.25s, box-shadow 0.25s;
}
.hero-dark__cta:hover {
    opacity: 0.9;
    box-shadow: 0 4px 20px rgba(0,0,0,0.45);
}
.hero-dark__cta-row {
    display: flex;
    align-items: center;
    gap: 28px;
    flex-wrap: wrap;
}
.hero-dark__link {
    color: rgba(255,255,255,0.72);
    font-size: 0.82rem;
    font-weight: 400;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    text-decoration: none;
    transition: color 0.2s;
}
.hero-dark__link:hover {
    color: #fff;
}
.hero-dark__right {
    position: relative;
    overflow: hidden;
    clip-path: polygon(22% 0, 100% 0, 100% 100%, 0 100%);
}
.hero-dark__img {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: brightness(0.75);
}

/* ═══════════════════════════════════════════════
   OVERVIEW  (Everything Under One Roof)
   ═══════════════════════════════════════════════ */
.overview {
    background: var(--cream);
    padding: clamp(80px, 10vw, 130px) var(--px);
}
.overview__header {
    text-align: center;
    margin-bottom: clamp(48px, 6vw, 80px);
}
.overview__title {
    font-size: clamp(2rem, 4.5vw, 4.5rem);
    font-weight: 400;
    line-height: 1.1;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    margin-bottom: 20px;
    color: #111;
}
.overview__title span {
    font-weight: 400;
    color: rgba(0,0,0,0.32);
}
.overview__sub {
    font-size: clamp(0.85rem, 1.1vw, 0.95rem);
    line-height: 1.8;
    color: #111;
    max-width: 680px;
    margin: 0 auto;
}
.overview__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin-bottom: clamp(40px, 5vw, 64px);
}
.overview__card {
    background: #1a1a1a;
    color: #fff;
    padding: clamp(24px, 3vw, 38px);
    display: flex;
    flex-direction: column;
    gap: 14px;
    border-radius: 7px;
    transition: background 0.3s;
}
.overview__card:hover {
    background: #111111;
}
.overview__card-icon {
    width: 42px;
    height: 42px;
    color: rgba(255,255,255,0.55);
    flex-shrink: 0;
}
.overview__card-icon svg { width: 100%; height: 100%; }
.overview__card-icon-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    mix-blend-mode: lighten;
    opacity: 0.75;
}
.overview__card-title {
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
}
.overview__card-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.overview__card-list li {
    font-size: 0.8rem;
    line-height: 1.6;
    color: rgba(255,255,255,0.5);
    padding-left: 12px;
    position: relative;
}
.overview__card-list li::before {
    content: '·';
    position: absolute;
    left: 0;
    color: rgba(255,255,255,0.35);
}
.overview__footer { text-align: center; }
.overview__btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 15px 40px;
    background: var(--model-black);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border-radius: 7px;
    transition: opacity 0.2s;
}
.overview__btn:hover { opacity: 0.8; }

/* ═══════════════════════════════════════════════
   EVENTS SECTION
   ═══════════════════════════════════════════════ */
.photo-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    height: 320px;
    gap: 0;
}
.photo-strip__img {
    background-size: cover;
    background-position: center;
    filter: brightness(0.85);
    transition: filter 0.4s;
}
.photo-strip__img:hover { filter: brightness(1); }
.events-section {
    background: #0d0d0d;
    color: #fff;
    padding: clamp(32px, 5vw, 60px) clamp(32px, 5vw, 72px);
}
.events-section__top {
    display: grid;
    grid-template-columns: 1fr 38%;
    gap: clamp(24px, 4vw, 48px);
    align-items: center;
    margin-bottom: clamp(32px, 5vw, 56px);
}
.events-section__left {
    display: flex;
    flex-direction: column;
}
.events-section__photo {
    width: 100%;
    height: 100%;
    overflow: hidden;
    border-radius: 0;
}
.events-section__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.events-section__heading {
    font-size: clamp(2.4rem, 4.6vw, 5.2rem);
    font-weight: 400;
    line-height: 1.05;
    letter-spacing: 0.01em;
    text-transform: uppercase;
    margin-bottom: 14px;
    order: -1;
}
.events-section__heading-muted {
    color: rgba(255,255,255,0.28);
}
.events-section__label {
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: 0.24em;
    color: rgba(255,255,255,0.4);
    text-transform: uppercase;
    margin-bottom: 14px;
}
.events-section__body {
    font-size: 1.15rem;
    line-height: 1.75;
    color: #fff;
    margin-bottom: 0;
}
.events-section__cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border-top: 1px solid rgba(255,255,255,0.1);
    margin-bottom: clamp(32px, 5vw, 56px);
}
.events-section__card {
    padding: 16px 28px;
    border-right: 1px solid rgba(255,255,255,0.1);
    text-align: center;
}
.events-section__card:last-child {
    border-right: none;
}
.events-section__card-tag {
    display: block;
    font-size: 0.65rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: rgba(255,255,255,0.3);
    text-transform: uppercase;
    margin-bottom: 4px;
}
.events-section__card-name {
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-bottom: 4px;
}
.events-section__card-detail {
    font-size: 0.88rem;
    color: rgba(255,255,255,0.4);
}
.events-section__footer {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}
.events-section__link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 0.85rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border-bottom: 1px solid rgba(255,255,255,0.25);
    padding-bottom: 6px;
    transition: gap 0.25s var(--ease-std), border-color 0.2s;
}
.events-section__link:hover { gap: 18px; border-color: #fff; }
.events-section__members-note {
    font-size: 0.75rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: rgba(255,255,255,0.22);
    text-transform: uppercase;
}

/* ═══════════════════════════════════════════════
   CLINICAL SECTION
   ═══════════════════════════════════════════════ */
.clinical {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: clamp(48px, 8vw, 120px);
    align-items: center;
    padding: clamp(80px, 10vw, 130px) var(--px);
    background: var(--cream);
}
.clinical__label {
    display: block;
    font-size: 0.95rem;
    font-weight: 400;
    letter-spacing: 0.24em;
    color: #111;
    text-transform: uppercase;
    margin-bottom: 20px;
}
.clinical__heading {
    font-size: clamp(2rem, 3.8vw, 4.2rem);
    font-weight: 400;
    line-height: 1.05;
    letter-spacing: 0.01em;
    text-transform: uppercase;
    margin-bottom: 16px;
}
.clinical__body {
    font-size: 1rem;
    line-height: 1.85;
    color: var(--text);
    margin-bottom: 36px;
    max-width: 480px;
}
.clinical__btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 32px;
    background: #d4d4d4;
    border: none;
    color: #1a1a1a;
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border-radius: 7px;
    transition: opacity 0.25s;
}
.clinical__btn:hover { opacity: 0.8; }
.clinical__right {
    display: flex;
    flex-direction: column;
}
.clinical__panel {
    background: #111;
    border-radius: 7px;
    overflow: hidden;
    padding: 8px 0 35px;
}
.clinical__service-card {
    color: #fff;
    padding: 20px 28px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    position: relative;
}
.clinical__service-card::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 28px;
    right: 28px;
    height: 2px;
    background: #fff;
}
.clinical__service-card--last::after {
    display: block;
}
.clinical__service-tag {
    font-size: 0.62rem;
    color: rgba(255,255,255,0.35);
    letter-spacing: 0.12em;
    text-transform: uppercase;
}
.clinical__service-title {
    font-size: 0.92rem;
    font-weight: 400;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

/* ═══════════════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════════════ */
.testimonials {
    background: #0d0d0d;
    color: #fff;
    padding: clamp(80px, 10vw, 130px) var(--px);
}
.testimonials__header { margin-bottom: clamp(40px, 6vw, 72px); }
.testimonials__label {
    display: block;
    font-size: 0.75rem;
    font-weight: 400;
    letter-spacing: 0.24em;
    color: rgba(255,255,255,0.4);
    text-transform: uppercase;
    margin-top: 10px;
}
.testimonials__heading {
    font-size: clamp(2.4rem, 5vw, 5.5rem);
    font-weight: 400;
    letter-spacing: 0.01em;
    line-height: 1;
}
.testimonials__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.testimonials__card {
    background: #161616;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 7px;
    padding: 32px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}
.testimonials__card-top {
    display: flex;
    align-items: center;
    gap: 16px;
}
.testimonials__avatar {
    width: 58px;
    height: 58px;
    border-radius: 50%;
    background: #111111;
    flex-shrink: 0;
    overflow: hidden;
}
.testimonials__avatar--grey {
    background: #555;
    filter: grayscale(100%);
}
.testimonials__info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.testimonials__name {
    font-size: 0.82rem;
    font-weight: 400;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.testimonials__title {
    font-size: 0.72rem;
    color: rgba(255,255,255,0.38);
    letter-spacing: 0.04em;
}
.testimonials__quote {
    font-size: 0.92rem;
    line-height: 1.75;
    color: rgba(255,255,255,0.6);
    font-style: normal;
}

/* ═══════════════════════════════════════════════
   FINAL CTA
   ═══════════════════════════════════════════════ */
.final-cta {
    background: var(--cream);
    padding: clamp(80px, 12vw, 160px) var(--px);
    text-align: center;
}
.final-cta__heading {
    font-size: clamp(1.8rem, 4.5vw, 5rem);
    font-weight: 400;
    line-height: 1.12;
    letter-spacing: 0.01em;
    text-transform: uppercase;
    margin-bottom: 28px;
}
.final-cta__heading em {
    font-style: normal;
    color: var(--charcoal);
}
.final-cta__btn {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 17px 48px;
    background: #d4d4d4;
    border: none;
    color: #1a1a1a;
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    border-radius: 7px;
    transition: opacity 0.25s;
    margin-bottom: 20px;
}
.final-cta__btn:hover { opacity: 0.8; }
.final-cta__note {
    font-size: 1.1rem;
    color: #111;
    letter-spacing: 0.04em;
    margin-bottom: 28px;
}

/* ═══════════════════════════════════════════════
   FOOTER NEW  (home page)
   ═══════════════════════════════════════════════ */
.footer-new {
    background: #0d0d0d;
    color: rgba(255,255,255,0.45);
    border-top: 1px solid rgba(255,255,255,0.07);
}
.footer-new__inner {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr;
    gap: clamp(32px, 4vw, 60px);
    padding: clamp(48px, 7vw, 90px) var(--px);
}
.footer-new__logo-wrap {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
}
.footer-new__logo-img {
    height: 58px;
    width: auto;
}
.footer-new__logo-text {
    display: flex;
    flex-direction: column;
    line-height: 1.15;
}
.footer-new__name {
    font-size: 0.95rem;
    font-weight: 400;
    letter-spacing: 0.38em;
    color: #fff;
}
.footer-new__sub {
    font-size: 0.65rem;
    font-weight: 400;
    letter-spacing: 0.5em;
    color: rgba(255,255,255,0.4);
}
.footer-new__desc {
    font-size: 0.9rem;
    line-height: 1.75;
    color: rgba(255,255,255,0.4);
    margin-bottom: 18px;
    max-width: 280px;
}
.footer-new__address {
    font-size: 0.85rem;
    line-height: 1.75;
    color: rgba(255,255,255,0.3);
    font-style: normal;
}
.footer-new__address a {
    color: rgba(255,255,255,0.3);
    transition: color 0.2s;
}
.footer-new__address a:hover { color: #fff; }
.footer-new__nav-label {
    display: block;
    font-size: 0.65rem;
    font-weight: 400;
    letter-spacing: 0.22em;
    color: rgba(255,255,255,0.28);
    text-transform: uppercase;
    margin-bottom: 14px;
}
.footer-new__nav ul,
.footer-new__member ul,
.footer-new__connect ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 28px;
}
.footer-new__nav a,
.footer-new__member a,
.footer-new__connect a {
    font-size: 0.95rem;
    font-weight: 400;
    color: rgba(255,255,255,0.5);
    transition: color 0.2s;
}
.footer-new__nav a:hover,
.footer-new__member a:hover,
.footer-new__connect a:hover { color: #fff; }
.footer-new__socials {
    display: flex;
    gap: 10px;
    margin-top: 8px;
}
.footer-new__social {
    width: 34px;
    height: 34px;
    border: 1px solid rgba(255,255,255,0.18);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color 0.2s, background 0.2s;
}
.footer-new__social:hover {
    border-color: rgba(255,255,255,0.5);
    background: rgba(255,255,255,0.07);
}
.footer-new__social svg {
    width: 13px;
    height: 13px;
    color: rgba(255,255,255,0.5);
}
.footer-new__phone {
    margin-top: 14px;
    font-size: 0.78rem;
    font-style: normal;
}
.footer-new__phone a {
    color: rgba(255,255,255,0.5);
    transition: color 0.2s;
}
.footer-new__phone a:hover { color: #fff; }
.footer-new__bottom {
    padding: 20px var(--px);
    border-top: 1px solid rgba(255,255,255,0.18);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.65rem;
    color: rgba(255,255,255,0.3);
    letter-spacing: 0.04em;
}

/* ── Home page responsive ──────────────────── */
@media (max-width: 1100px) {
    .hero-dark { grid-template-columns: 1fr; min-height: auto; }
    .hero-dark__right { height: 55vw; clip-path: none; }
    .overview__grid { grid-template-columns: 1fr 1fr; }
    .events-section__top { grid-template-columns: 1fr; }
    .events-section__cards { grid-template-columns: 1fr; }
    .events-section__card { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.1); }
    .events-section__card:last-child { border-bottom: none; }
    .photo-strip { height: 220px; }
    .clinical { grid-template-columns: 1fr; }
    .footer-new__inner { grid-template-columns: 1fr 1fr 1fr; }
}
@media (max-width: 768px) {
    .overview__grid { grid-template-columns: 1fr; }
    .testimonials__grid { grid-template-columns: 1fr 1fr; }
    .footer-new__inner { grid-template-columns: 1fr 1fr; }
    .photo-strip { grid-template-columns: repeat(2, 1fr); height: 300px; }
}
@media (max-width: 640px) {
    .hero-dark__right { height: 70vw; }
    .testimonials__grid { grid-template-columns: 1fr; }
    .footer-new__inner { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════
   MEMBERSHIP PAGE — REDESIGN
   ═══════════════════════════════════════════════ */
.mem-hero {
    background: #0d0d0d;
    padding: calc(var(--nav-h) + clamp(60px, 8vw, 100px)) var(--px) clamp(48px, 6vw, 72px);
}
.mem-hero__label-row {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 28px;
}
.mem-hero__label {
    font-size: 0.82rem;
    font-weight: 400;
    letter-spacing: 0.22em;
    color: rgba(255,255,255,0.35);
    text-transform: uppercase;
    white-space: nowrap;
}
.mem-hero__label-row::after {
    content: '';
    flex: 0 0 80px;
    height: 1px;
    background: rgba(255,255,255,0.15);
}
.mem-hero__heading {
    font-size: clamp(2rem, 3.8vw, 4.2rem);
    font-weight: 400;
    color: #fff;
    text-transform: uppercase;
    line-height: 1.05;
    letter-spacing: -0.01em;
    margin-bottom: 24px;
}
.mem-hero__desc {
    font-size: 0.95rem;
    line-height: 1.75;
    color: rgba(255,255,255,0.45);
    max-width: 520px;
}

/* Tier grid */
.mem-tiers {
    background: #0d0d0d;
    padding: 0 var(--px) clamp(60px, 8vw, 100px);
}
.mem-tiers__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    margin-bottom: 20px;
}
.mem-tier {
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 7px;
    padding: 36px 28px;
    transition: border-color 0.3s, background 0.3s, transform 0.3s;
    display: flex;
    flex-direction: column;
    position: relative;
}
.mem-tier--featured {
    border-color: rgba(255,255,255,0.28);
    margin-top: -14px;
    padding-top: 50px;
}
.mem-tier__badge {
    position: absolute;
    top: -1px;
    left: 50%;
    transform: translateX(-50%);
    background: #0d0d0d;
    border: 1px solid rgba(255,255,255,0.22);
    border-top: none;
    color: rgba(255,255,255,0.55);
    font-size: 0.52rem;
    font-weight: 400;
    letter-spacing: 0.22em;
    padding: 6px 16px;
    text-transform: uppercase;
    white-space: nowrap;
}
.mem-tier__name {
    font-size: 0.85rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: #fff;
    text-transform: uppercase;
    margin-bottom: 8px;
}
.mem-tier__name-gold { color: var(--gold, #B8922A); }
.mem-tier__sub {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.38);
    font-style: italic;
}
.mem-tier__divider {
    height: 1px;
    background: rgba(255,255,255,0.1);
    margin: 22px 0;
}
.mem-tier__features {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 11px;
    flex: 1;
    margin-bottom: 32px;
}
.mem-tier__features li {
    font-size: 0.84rem;
    color: rgba(255,255,255,0.6);
    line-height: 1.55;
    padding-left: 20px;
    position: relative;
    font-weight: 400;
}
.mem-tier__features li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: rgba(255,255,255,0.35);
    font-size: 0.72rem;
    top: 1px;
}
.mem-tier__btn {
    display: block;
    text-align: center;
    padding: 13px 20px;
    border: 1px solid rgba(255,255,255,0.22);
    border-radius: 7px;
    color: rgba(255,255,255,0.6);
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.mem-tier__btn:hover {
    background: transparent;
    color: #fff;
    border-color: rgba(255,255,255,0.85);
}
.mem-tier__btn--white {
    background: #fff;
    color: #0d0d0d;
    border-color: #fff;
    font-weight: 400;
}
.mem-tier__btn--white:hover {
    background: rgba(255,255,255,0.88);
    border-color: rgba(255,255,255,0.88);
}
.mem-tier:hover,
.mem-tier:focus-within {
    border-color: rgba(255,255,255,0.32);
    background: #111111;
    transform: scale(1.03);
    z-index: 2;
}
.mem-tier:hover .mem-tier__btn:not(.mem-tier__btn--white),
.mem-tier:focus-within .mem-tier__btn:not(.mem-tier__btn--white) {
    background: transparent;
    color: #fff;
    border-color: rgba(255,255,255,0.85);
}

/* Corporate banner */
.mem-corporate {
    border: 1px solid rgba(255,255,255,0.1);
    padding: 22px 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    margin-top: 3rem;
}
.mem-corporate__text {
    font-size: 1.05rem;
    color: rgba(255,255,255,0.45);
    font-weight: 400;
}
.mem-corporate__link {
    font-size: 0.85rem;
    font-weight: 400;
    letter-spacing: 0.18em;
    color: rgba(255,255,255,0.65);
    text-transform: uppercase;
    white-space: nowrap;
    transition: color 0.2s;
}
.mem-corporate__link:hover { color: #fff; }

/* FAQ */
.mem-faq {
    background: #f5f5f0;
    padding: clamp(60px, 8vw, 110px) var(--px);
}
.mem-faq__label-row {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 20px;
}
.mem-faq__label {
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.22em;
    color: rgba(0,0,0,0.45);
    text-transform: uppercase;
    white-space: nowrap;
}
.mem-faq__label-row::after {
    content: '';
    flex: 0 0 80px;
    height: 1px;
    background: rgba(0,0,0,0.2);
}
.mem-faq__heading {
    font-size: clamp(2rem, 4vw, 4rem);
    font-weight: 400;
    color: #0d0d0d;
    text-transform: uppercase;
    letter-spacing: -0.01em;
    margin-bottom: 48px;
}
.mem-faq__list { max-width: 860px; }
.mem-faq__item { border-top: 1px solid rgba(0,0,0,0.15); }
.mem-faq__item:last-child { border-bottom: 1px solid rgba(0,0,0,0.15); }
.mem-faq__q {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 22px 0;
    background: none;
    border: none;
    color: rgba(0,0,0,0.7);
    font-size: 1rem;
    font-family: inherit;
    font-weight: 400;
    text-align: left;
    cursor: pointer;
    gap: 24px;
    transition: color 0.2s;
    letter-spacing: 0.02em;
}
.mem-faq__q:hover { color: #0d0d0d; }
.mem-faq__q--open { color: #0d0d0d; font-weight: 400; }
.mem-faq__q span {
    font-size: 1.2rem;
    color: rgba(0,0,0,0.4);
    transition: transform 0.25s;
    flex-shrink: 0;
    line-height: 1;
}
.mem-faq__q--open span { transform: rotate(45deg); color: #0d0d0d; }
.mem-faq__a {
    display: none;
    padding: 0 0 24px;
    font-size: 0.95rem;
    line-height: 1.85;
    color: rgba(0,0,0,0.65);
    max-width: 680px;
    font-weight: 400;
}
.mem-faq__a--open { display: block; }

@media (max-width: 900px) {
    .mem-tiers__grid { grid-template-columns: 1fr; padding-top: 2.5rem; }
    .mem-tier--featured { margin-top: 0; }
    .mem-tier {
        background: #111111;
    }
    .mem-tier .mem-tier__btn {
        background: linear-gradient(180deg, #ffffff 0%, #f0eeeb 20%, #d6d2cc 50%, #b8b4ae 75%, #ccc9c4 100%);
        color: #1a1208;
        border-color: transparent;
        font-weight: 400;
    }
    .mem-tier:hover .mem-tier__btn:not(.mem-tier__btn--white),
    .mem-tier:focus-within .mem-tier__btn:not(.mem-tier__btn--white) {
        background: linear-gradient(180deg, #ffffff 0%, #f0eeeb 20%, #d6d2cc 50%, #b8b4ae 75%, #ccc9c4 100%);
        color: #1a1208;
    }
}
@media (max-width: 640px) {
    .mem-corporate { flex-direction: column; align-items: flex-start; gap: 24px; }
    .mem-corporate__link { align-self: flex-end; }
}

/* ═══════════════════════════════════════════════
   FACILITY PAGE
   ═══════════════════════════════════════════════ */
.fac-hero {
    background: #0d0d0d;
    padding: calc(var(--nav-h) + clamp(80px, 10vw, 130px)) var(--px) clamp(70px, 9vw, 110px);
    text-align: center;
}
.fac-hero__label {
    display: block;
    font-size: 0.62rem;
    font-weight: 400;
    letter-spacing: 0.3em;
    color: rgba(255,255,255,0.3);
    text-transform: uppercase;
    margin-bottom: 28px;
}
.fac-hero__heading {
    font-size: clamp(3rem, 6.5vw, 7.5rem);
    font-weight: 400;
    color: #fff;
    text-transform: uppercase;
    line-height: 1.05;
    margin-bottom: 28px;
}
.fac-hero__desc {
    font-size: clamp(0.9rem, 1.3vw, 1.05rem);
    line-height: 1.85;
    color: rgba(255,255,255,0.45);
    max-width: 600px;
    margin: 0 auto;
}

.fac-pillars { background: #0d0d0d; }
.fac-pillars__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border-top: 1px solid rgba(255,255,255,0.18);
}
.fac-pillar {
    padding: clamp(36px, 5vw, 56px) clamp(28px, 4vw, 48px);
    border-right: 1px solid rgba(255,255,255,0.18);
    border-bottom: 1px solid rgba(255,255,255,0.18);
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    cursor: pointer;
    transition: background 0.3s;
}
.fac-pillar:hover { background: #111111; }
.fac-pillar:hover .fac-pillar__link { color: #fff; border-color: #666; }
.fac-pillar:nth-child(3n) { border-right: none; }
.fac-pillar__num {
    display: block;
    font-size: 0.68rem;
    font-weight: 400;
    color: rgba(255,255,255,0.12);
    letter-spacing: 0.1em;
    margin-bottom: 20px;
}
.fac-pillar__name {
    font-size: 0.88rem;
    font-weight: 400;
    letter-spacing: 0.18em;
    color: #fff;
    text-transform: uppercase;
    margin-bottom: 16px;
}
.fac-pillar__desc {
    font-size: 0.88rem;
    line-height: 1.75;
    color: rgba(255,255,255,0.45);
    margin-bottom: 28px;
}
.fac-pillar__list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 9px;
    margin-bottom: 36px;
    flex: 1;
}
.fac-pillar__list li {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.32);
    padding-left: 14px;
    position: relative;
    font-weight: 400;
}
.fac-pillar__list li::before {
    content: '·';
    position: absolute;
    left: 0;
    color: rgba(255,255,255,0.22);
}
.fac-pillar__link {
    font-size: 0.6rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: rgba(255,255,255,0.35);
    text-transform: uppercase;
    transition: color 0.2s;
    margin-top: auto;
}
.fac-pillar__link:hover { color: #fff; }

/* ── Pillar Detail Sections ── */
.fac-details-wrap {
    display: flex;
    flex-direction: column;
    gap: 0;
    background: #ffffff;
    padding: 1rem 0 0;
}
.fac-detail {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 580px;
    background: #111111;
}
.fac-detail--light { background: #ffffff; }
.fac-detail--flip { direction: rtl; }
.fac-detail--flip > * { direction: ltr; }
.fac-detail__img-wrap {
    overflow: hidden;
    position: relative;
}
.fac-detail__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform 0.7s ease;
}
.fac-detail:hover .fac-detail__img { transform: scale(1.03); }
.fac-detail__content {
    padding: clamp(48px, 7vw, 100px) clamp(32px, 5vw, 80px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}
/* dark bg text */
.fac-detail__num {
    font-size: 0.65rem;
    letter-spacing: 0.3em;
    color: #444;
    font-weight: 400;
    margin-bottom: 1.2rem;
}
.fac-detail__heading {
    font-size: clamp(1.8rem, 3.5vw, 3rem);
    font-weight: 400;
    letter-spacing: 0.08em;
    color: #f5f5f0;
    margin: 0 0 1.2rem;
    line-height: 1.05;
}
.fac-detail__desc {
    font-size: 0.95rem;
    color: #777;
    line-height: 1.85;
    margin: 0 0 2rem;
    font-weight: 400;
    max-width: 480px;
}
.fac-detail__list {
    list-style: none;
    padding: 0;
    margin: 0 0 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}
.fac-detail__list li {
    font-size: 0.82rem;
    color: #555;
    font-weight: 400;
    letter-spacing: 0.04em;
    padding-left: 0;
    position: relative;
}
.fac-detail__list li::before {
    content: '';
    position: absolute;
    left: 0;
}
.fac-detail__btn {
    display: inline-block;
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    color: #f5f5f0;
    border-bottom: 1px solid #333;
    padding-bottom: 4px;
    transition: color 0.2s, border-color 0.2s;
    align-self: flex-start;
}
.fac-detail__btn:hover { color: #fff; border-color: #888; }

/* light bg overrides */
.fac-detail--light .fac-detail__num { color: rgba(0,0,0,0.3); }
.fac-detail--light .fac-detail__heading { color: #0d0d0d; }
.fac-detail--light .fac-detail__desc { color: rgba(0,0,0,0.55); }
.fac-detail--light .fac-detail__list li { color: rgba(0,0,0,0.6); }
.fac-detail--light .fac-detail__list li::before { color: rgba(0,0,0,0.25); }
.fac-detail--light .fac-detail__btn { color: #0d0d0d; border-color: rgba(0,0,0,0.2); }
.fac-detail--light .fac-detail__btn:hover { color: #000; border-color: rgba(0,0,0,0.6); }

@media (max-width: 860px) {
    .fac-details-wrap { gap: 0; padding: 0; }
    .fac-detail {
        grid-template-columns: 1fr;
        direction: ltr;
        min-height: unset;
    }
    .fac-detail--flip { direction: ltr; }
    .fac-detail__img-wrap { height: 300px; }
    .fac-detail__content { padding: 48px 24px; }
}

.fac-tour {
    background: var(--cream, #f5f3f0);
    padding: clamp(80px, 10vw, 130px) var(--px);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
}
.fac-tour__label {
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.28em;
    color: rgba(255,255,255,0.75);
    text-transform: uppercase;
}
.fac-tour__heading {
    font-size: clamp(2.2rem, 5vw, 5.5rem);
    font-weight: 400;
    color: var(--text, #111);
    text-transform: uppercase;
    line-height: 1.1;
    letter-spacing: -0.01em;
}
.fac-tour__desc {
    font-size: 0.95rem;
    color: var(--gold, #B8922A);
    margin-bottom: 4px;
}
.fac-tour__btn {
    display: inline-block;
    padding: 18px 44px;
    background: #d4d4d4;
    border: none;
    color: #1a1a1a;
    border-radius: 7px;
    font-size: 0.7rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    transition: opacity 0.25s;
    margin-top: 8px;
}
.fac-tour__btn:hover { opacity: 0.8; }

@media (max-width: 900px) {
    .fac-pillars__grid { grid-template-columns: repeat(2, 1fr); }
    .fac-pillar:nth-child(3n) { border-right: 1px solid rgba(255,255,255,0.18); }
    .fac-pillar:nth-child(2n) { border-right: none; }
}
@media (max-width: 560px) {
    .fac-pillars__grid { grid-template-columns: 1fr; }
    .fac-pillar { border-right: none; }
    .fac-pillar__list { display: none; }
}

/* ═══════════════════════════════════════════════════════════════════
   EVENTS MODULE — Dynamic Events + Member Auth
   Appended additions only; zero changes to existing rules above.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Loading state ──────────────────────────────────────────────── */
.ev-loading {
    padding: 40px 0;
    color: rgba(255,255,255,0.35);
    font-size: 0.78rem;
    letter-spacing: 0.1em;
    text-align: center;
}

/* ── Member login button (replaces MEMBERS ONLY badge) ─────────── */
.ev-row__login-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 20px;
    background: transparent;
    color: rgba(255,255,255,0.65);
    border: 1px solid rgba(255,255,255,0.22);
    border-radius: 7px;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.62rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    cursor: pointer;
    white-space: nowrap;
    transition: border-color 0.2s, color 0.2s;
}
.ev-row__login-btn:hover {
    border-color: rgba(255,255,255,0.55);
    color: #fff;
}

/* ── Unlocked badge (after auth) ────────────────────────────────── */
.ev-row__badge--unlocked {
    color: var(--charcoal);
    border-color: transparent;
}
.ev-row__badge--unlocked svg {
    stroke: var(--charcoal);
}

/* ── Member detail expand panel ─────────────────────────────────── */
.ev-row__detail {
    grid-column: 1 / -1;
    padding: 16px 0 8px 120px;
    border-top: 1px solid rgba(255,255,255,0.06);
    font-size: 0.82rem;
    color: rgba(255,255,255,0.6);
    line-height: 1.75;
    letter-spacing: 0.02em;
    animation: evDetailIn 0.35s var(--ease-out) forwards;
}
@keyframes evDetailIn {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.ev-row__detail-meta {
    display: flex;
    gap: 0;
    flex-wrap: wrap;
    margin-bottom: 16px;
}
.ev-row__detail-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding-right: 28px;
    margin-bottom: 10px;
    border-right: 1px solid rgba(255,255,255,0.08);
    margin-right: 28px;
}
.ev-row__detail-item:last-child {
    border-right: none;
    margin-right: 0;
}
.ev-row__detail-label {
    font-size: 0.52rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--charcoal);
}
.ev-row__detail-value {
    font-size: 0.8rem;
    color: rgba(255,255,255,0.8);
    letter-spacing: 0.02em;
}
.ev-row__detail-desc {
    margin: 0;
    max-width: 620px;
    padding-top: 14px;
    border-top: 1px solid rgba(255,255,255,0.06);
}

@media (max-width: 600px) {
    .ev-row__detail { padding-left: 0; }
    .ev-row__detail-meta { gap: 12px; }
}

/* ── Email verification modal ───────────────────────────────────── */
.ev-modal {
    position: fixed;
    inset: 0;
    z-index: 9000;
    display: flex;
    align-items: center;
    justify-content: center;
}
.ev-modal[hidden] { display: none; }

.ev-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.78);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.ev-modal__box {
    position: relative;
    z-index: 1;
    background: #111111;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 7px;
    padding: clamp(28px, 5vw, 52px);
    width: min(440px, 92vw);
    animation: evModalIn 0.3s var(--ease-out) forwards;
}
@keyframes evModalIn {
    from { opacity: 0; transform: translateY(12px) scale(0.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
.ev-modal__close {
    position: absolute;
    top: 16px;
    right: 18px;
    background: none;
    border: none;
    cursor: pointer;
    color: rgba(255,255,255,0.35);
    font-size: 1.25rem;
    line-height: 1;
    padding: 4px;
    transition: color 0.2s;
}
.ev-modal__close:hover { color: #fff; }
.ev-modal__label {
    font-size: 0.6rem;
    font-weight: 400;
    letter-spacing: 0.22em;
    color: var(--charcoal);
    text-transform: uppercase;
    margin-bottom: 10px;
    display: block;
}
.ev-modal__title {
    font-size: clamp(1.15rem, 3vw, 1.55rem);
    font-weight: 400;
    letter-spacing: -0.01em;
    color: #fff;
    margin: 0 0 8px;
}
.ev-modal__sub {
    font-size: 0.76rem;
    color: rgba(255,255,255,0.42);
    line-height: 1.65;
    margin: 0 0 24px;
}
.ev-modal__input {
    display: block;
    width: 100%;
    box-sizing: border-box;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 7px;
    color: #fff;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.78rem;
    font-weight: 400;
    padding: 13px 16px;
    margin-bottom: 12px;
    outline: none;
    transition: border-color 0.2s;
}
.ev-modal__input::placeholder { color: rgba(255,255,255,0.35); }
.ev-modal__input:focus { border-color: var(--charcoal); }
.ev-modal__btn {
    display: block;
    width: 100%;
    padding: 16px 28px;
    background: linear-gradient(135deg, #9B9B9B, #FFFFFF);
    color: #111;
    border: none;
    border-radius: 7px;
    cursor: pointer;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    transition: opacity 0.2s;
}
.ev-modal__btn:hover:not(:disabled) { opacity: 0.82; }
.ev-modal__btn:disabled { opacity: 0.5; cursor: not-allowed; }
.ev-modal__btn--danger {
    background: transparent;
    color: #fca5a5;
    border: 1px solid rgba(252,165,165,0.4);
}
.ev-modal__btn--danger:hover:not(:disabled) { border-color: #fca5a5; opacity: 1; }
.ev-modal__btn--ghost {
    background: transparent;
    color: rgba(255,255,255,0.5);
    border: 1px solid rgba(255,255,255,0.15);
}
.ev-modal__btn--ghost:hover:not(:disabled) { color: #fff; border-color: rgba(255,255,255,0.4); opacity: 1; }
.ev-modal__err {
    font-size: 0.72rem;
    color: #fca5a5;
    margin-top: 12px;
    text-align: center;
    line-height: 1.5;
}
.ev-modal__err[hidden] { display: none; }

/* ── Mobile: login button spans full row ────────────────────────── */
@media (max-width: 700px) {
    .ev-row__login-btn {
        grid-column: 1 / -1;
        margin-top: 4px;
    }
    .ev-row__badge--unlocked {
        grid-column: 1 / -1;
        margin-top: 4px;
    }
}

/* ── Member signed-in bar ───────────────────────────────────────── */
.ev-member-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin: 0 var(--px) 32px;
    padding: 14px 20px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 7px;
    font-size: 0.65rem;
    letter-spacing: 0.14em;
    color: rgba(255,255,255,0.5);
}
.ev-member-bar[hidden] { display: none; }
.ev-member-bar__name { color: rgba(255,255,255,0.75); }
.ev-member-bar__signout {
    flex-shrink: 0;
    background: none;
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 7px;
    color: rgba(255,255,255,0.45);
    font-family: 'Montserrat', sans-serif;
    font-size: 0.62rem;
    font-weight: 400;
    letter-spacing: 0.14em;
    padding: 8px 16px;
    cursor: pointer;
    transition: border-color 0.2s, color 0.2s;
}
.ev-member-bar__signout:hover { border-color: rgba(255,255,255,0.4); color: #fff; }
.ev-member-bar__signout:disabled { opacity: 0.45; cursor: default; }

/* ── Remember me checkbox ───────────────────────────────────────── */
.ev-modal__remember {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
    cursor: pointer;
    font-size: 0.72rem;
    color: rgba(255,255,255,0.45);
    letter-spacing: 0.03em;
    user-select: none;
}
.ev-modal__remember input[type="checkbox"] {
    width: 15px; height: 15px;
    accent-color: var(--charcoal);
    cursor: pointer;
    flex-shrink: 0;
}


/* ═══════════════════════════════════════════════
   COWORKER UI ADDITIONS — merged from live version
   ═══════════════════════════════════════════════ */

/* ── Values section (about.html) ─────────────── */
.a-values {
    background: #111111;
    padding: clamp(80px, 10vw, 120px) 0;
}
.a-values__inner {
    max-width: 100%;
}
.a-values__header {
    padding: 0 var(--px);
    margin-bottom: clamp(48px, 6vw, 72px);
}
.a-values__label {
    display: inline-block;
    font-size: 0.65rem;
    letter-spacing: 0.22em;
    color: rgba(255,255,255,0.5);
    text-transform: uppercase;
    margin-bottom: 20px;
}
.a-values__heading {
    font-size: clamp(2rem, 4vw, 3.6rem);
    font-weight: 400;
    color: #fff;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    line-height: 1.1;
    margin: 0;
}
.a-values__grid {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.a-value-card {
    width: 40%;
    background: #111111;
    border: 1px solid rgba(255,255,255,0.1);
    padding: clamp(36px, 4.5vw, 56px) clamp(32px, 4vw, 52px);
    display: flex;
    flex-direction: column;
    gap: 18px;
    border-radius: 7px;
}
.a-value-card:nth-child(1) { margin-left: 0%; }
.a-value-card:nth-child(2) { margin-left: 15%; }
.a-value-card:nth-child(3) { margin-left: 30%; }
.a-value-card:nth-child(4) { margin-left: 45%; }
.a-value-card:nth-child(5) { margin-left: 60%; }
.a-value-card__num { display: none; }
.a-value-card__title {
    font-size: 0.85rem;
    font-weight: 400;
    letter-spacing: 0.18em;
    color: #fff;
    text-transform: uppercase;
    margin: 0;
}
.a-value-card__text {
    font-size: 0.9rem;
    color: rgba(255,255,255,0.55);
    line-height: 1.85;
    font-weight: 400;
    margin: 0;
}
@media (max-width: 860px) {
    .a-value-card { width: 75%; margin-left: auto; margin-right: auto; }
    .a-value-card:nth-child(1),
    .a-value-card:nth-child(2),
    .a-value-card:nth-child(3),
    .a-value-card:nth-child(4),
    .a-value-card:nth-child(5) { margin-left: auto; margin-right: auto; }
}
@media (max-width: 540px) {
    .a-value-card { width: 100%; }
    .a-values__grid { padding: 0 var(--px); }
    .a-value-card:nth-child(1),
    .a-value-card:nth-child(2),
    .a-value-card:nth-child(3),
    .a-value-card:nth-child(4),
    .a-value-card:nth-child(5) { margin-left: 0; }
}

/* ── Service Modal (index.html clinical) ─────── */
.svc-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9000;
    align-items: center;
    justify-content: center;
    padding: 24px;
}
.svc-modal--open { display: flex; }
.svc-modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.72);
}
.svc-modal__card {
    position: relative;
    background: #111;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 7px;
    padding: clamp(36px, 5vw, 60px) clamp(28px, 4vw, 52px);
    max-width: 560px;
    width: 100%;
    z-index: 1;
}
.svc-modal__close {
    position: absolute;
    top: 20px;
    right: 24px;
    background: none;
    border: none;
    color: rgba(255,255,255,0.4);
    font-size: 1rem;
    cursor: pointer;
    line-height: 1;
    transition: color 0.2s;
}
.svc-modal__close:hover { color: #fff; }
.svc-modal__label {
    display: block;
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    color: rgba(255,255,255,0.3);
    text-transform: uppercase;
    margin-bottom: 16px;
}
.svc-modal__title {
    font-size: clamp(1.4rem, 3vw, 2rem);
    font-weight: 400;
    color: #fff;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin: 0 0 24px;
    line-height: 1.15;
}
.svc-modal__body {
    font-size: 0.92rem;
    color: rgba(255,255,255,0.65);
    line-height: 1.85;
    font-weight: 400;
    margin: 0;
}
.clinical__learn-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    text-align: left;
}

/* ── Single membership tier (membership.html) ── */
.mem-single {
    max-width: 560px;
    margin: 0 auto 48px;
    background: transparent;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 7px;
    padding: 36px 28px;
    display: flex;
    flex-direction: column;
}
.mem-single__group { margin-bottom: 28px; }
.mem-single__group-title {
    font-size: 0.85rem;
    letter-spacing: 0.2em;
    font-weight: 400;
    color: #fff;
    text-transform: uppercase;
    margin: 0 0 18px;
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
}
.mem-single__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 11px;
}
.mem-single__list li {
    font-size: 0.84rem;
    color: rgba(255,255,255,0.6);
    font-weight: 400;
    line-height: 1.55;
    padding-left: 20px;
    position: relative;
}
.mem-single__list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: rgba(255,255,255,0.35);
    font-size: 0.72rem;
    top: 1px;
}
.mem-single__btn {
    display: block;
    text-align: center;
    margin-top: 8px;
}

/* ── Facility pillars center row (facility.html) */
.fac-pillars__center-row {
    grid-column: 1 / -1;
    display: flex;
    justify-content: center;
}
.fac-pillars__center-row .fac-pillar {
    width: calc(100% / 3);
    flex-shrink: 0;
    border-right: 1px solid rgba(255,255,255,0.18);
}
.fac-pillars__center-row .fac-pillar:first-child { border-left: 1px solid rgba(255,255,255,0.18); }
.fac-pillars__center-row .fac-pillar:last-child { border-right: 1px solid rgba(255,255,255,0.18); }
@media (max-width: 900px) {
    .fac-pillars__center-row .fac-pillar { width: 50%; }
}
@media (max-width: 560px) {
    .fac-pillars__center-row { flex-direction: column; }
    .fac-pillars__center-row .fac-pillar { width: 100%; border-left: none; border-right: none; }
}

/* ── RSVP — event detail bar ─────────────────── */
.ev-rsvp-bar {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid rgba(255,255,255,0.08);
}
.ev-rsvp-btn {
    display: inline-flex;
    align-items: center;
    padding: 10px 24px;
    background: var(--gradient);
    color: #111;
    border: none;
    border-radius: 7px;
    cursor: pointer;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    transition: opacity 0.2s;
    white-space: nowrap;
}
.ev-rsvp-btn:hover:not(:disabled) { opacity: 0.85; }
.ev-rsvp-btn--confirmed {
    background: transparent;
    color: rgba(255,255,255,0.65);
    border: 1px solid rgba(255,255,255,0.2);
}
.ev-rsvp-btn--confirmed:hover { border-color: rgba(255,255,255,0.5); color: #fff; }
.ev-rsvp-btn--invited {
    background: transparent;
    color: rgba(255,255,255,0.5);
    border: 1px solid rgba(255,255,255,0.15);
    font-size: 0.62rem;
}
.ev-rsvp-btn--invited:hover { border-color: rgba(255,255,255,0.4); color: rgba(255,255,255,0.8); }
.ev-rsvp-btn--full {
    background: transparent;
    color: rgba(255,255,255,0.25);
    border: 1px solid rgba(255,255,255,0.08);
    cursor: not-allowed;
}
.ev-rsvp-spots {
    font-size: 0.65rem;
    letter-spacing: 0.1em;
    color: var(--charcoal);
    text-transform: uppercase;
}

/* ── RSVP modal textarea ─────────────────────── */
.ev-modal__textarea {
    resize: vertical;
    min-height: 72px;
    font-family: 'Montserrat', sans-serif;
    line-height: 1.5;
}
.ev-modal__invite-note {
    font-size: 0.65rem;
    margin-top: -4px;
    margin-bottom: 16px;
    color: rgba(255,255,255,0.3);
}

@media (max-width: 480px) {
    .ev-rsvp-bar { flex-direction: column; align-items: flex-start; gap: 10px; }
    .ev-rsvp-btn { width: 100%; justify-content: center; }
}
