/* ═══════════════════════════════════════════════════════════
   SELFISM — TEMPLE THEME (shared across all pages)
   ═══════════════════════════════════════════════════════════ */

:root {
    --void: #0C0E0B;
    --void-warm: #14120E;
    --leather: #1A1710;
    --gold: #EDBA30;
    --gold-deep: #C49610;
    --gold-warm: #FFF0B0;
    --gold-muted: rgba(237, 186, 48, 0.6);
    --cream: #F6F5EF;
    --brown: #6B4817;
    --muted: rgba(246, 245, 239, 0.55);
    --hairline: rgba(237, 186, 48, 0.15);

    --font-masthead: 'Cinzel', serif;
    --font-scripture: 'Playfair Display', serif;
    --font-ui: 'Inter', sans-serif;

    --chamber-max: 720px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
    background: var(--void);
    color: var(--cream);
    font-family: var(--font-scripture);
    font-size: 18px;
    line-height: 1.75;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

::selection { background: var(--gold); color: var(--void); }

/* ─── Texture + vignette ─────────────────────────────── */
.texture {
    position: fixed; inset: 0; pointer-events: none; z-index: 1;
    background: url('data:image/svg+xml;utf8,%3Csvg viewBox="0 0 256 256" xmlns="http://www.w3.org/2000/svg"%3E%3Cfilter id="n"%3E%3CfeTurbulence type="fractalNoise" baseFrequency="0.85" numOctaves="4"/%3E%3C/filter%3E%3Crect width="100%25" height="100%25" filter="url(%23n)" opacity="0.5"/%3E%3C/svg%3E');
    opacity: 0.07; mix-blend-mode: overlay;
}
.vignette {
    position: fixed; inset: 0; pointer-events: none; z-index: 2;
    background: radial-gradient(ellipse at center, transparent 40%, rgba(10,12,8,0.55) 100%);
}

/* ─── Atmospheric blobs ──────────────────────────────── */
.aurora { position: fixed; pointer-events: none; border-radius: 50%; filter: blur(90px); z-index: 0; }
.aurora-gold { top: -14vw; right: -18vw; width: 55vw; height: 55vw; background: radial-gradient(circle, rgba(237,186,48,0.14), transparent 70%); }
.aurora-warm { top: 50vh; left: -22vw; width: 55vw; height: 55vw; background: radial-gradient(circle, rgba(196,150,16,0.07), transparent 70%); }

/* ─── Navigation ─────────────────────────────────────── */
.topnav {
    position: fixed; top: 0; left: 0; right: 0; z-index: 100;
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 32px;
    background: rgba(12,14,11,0.7);
    backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--hairline);
    transition: transform 0.35s;
}
.topnav.hidden { transform: translateY(-100%); }
.topnav-logo { font-family: var(--font-masthead); font-weight: 900; font-size: 16px; letter-spacing: 4px; color: var(--cream); text-decoration: none; }
.topnav-links { display: flex; gap: 28px; align-items: center; }
.topnav-links a {
    font-family: var(--font-ui); font-size: 11px; font-weight: 500;
    letter-spacing: 2px; text-transform: uppercase; color: var(--muted);
    text-decoration: none; transition: color 0.3s;
}
.topnav-links a:hover { color: var(--gold); }
.topnav-cta {
    font-family: var(--font-ui); font-size: 10px; font-weight: 700;
    letter-spacing: 2px; text-transform: uppercase; color: var(--void) !important;
    background: var(--gold); padding: 8px 18px; text-decoration: none; transition: all 0.3s;
}
.topnav-cta:hover { background: var(--gold-warm); }
.hamburger { display: none; background: none; border: none; cursor: pointer; padding: 8px; }
.hamburger span { display: block; width: 22px; height: 2px; background: var(--cream); margin: 5px 0; transition: all 0.3s; }

@media (max-width: 768px) {
    .hamburger { display: block; }
    .topnav-links {
        display: none; position: absolute; top: 100%; left: 0; right: 0;
        flex-direction: column; padding: 20px 32px; gap: 16px;
        background: rgba(12,14,11,0.95); backdrop-filter: blur(16px);
        border-bottom: 1px solid var(--hairline);
    }
    .topnav-links.open { display: flex; }
}

/* ─── Page content ───────────────────────────────────── */
.page-main {
    position: relative; z-index: 5;
    max-width: var(--chamber-max);
    margin: 0 auto;
    padding: 140px 32px 80px;
}

.page-hero {
    text-align: center;
    margin-bottom: 60px;
    padding-top: 40px;
}

.page-kicker {
    font-family: var(--font-ui); font-size: 11px; letter-spacing: 4px;
    text-transform: uppercase; color: var(--gold); margin-bottom: 16px;
}

.page-title {
    font-family: var(--font-masthead); font-weight: 900;
    font-size: clamp(2rem, 5vw, 3.2rem); letter-spacing: 0.08em;
    margin-bottom: 16px;
}

.page-sub {
    font-family: var(--font-scripture); font-style: italic;
    font-size: 17px; color: var(--muted); max-width: 560px; margin: 0 auto;
}

.page-rule {
    width: 60px; height: 1px; background: var(--gold);
    margin: 40px auto;
}

/* ─── Legal / long-form body ─────────────────────────── */
.legal-body h2 {
    font-family: var(--font-masthead); font-weight: 700;
    font-size: 18px; letter-spacing: 3px; color: var(--gold);
    margin: 48px 0 16px; text-transform: uppercase;
}

.legal-body h3 {
    font-family: var(--font-scripture); font-weight: 700;
    font-size: 20px; color: var(--cream); margin: 28px 0 12px;
}

.legal-body p {
    font-family: var(--font-scripture); font-size: 16px;
    line-height: 1.8; color: rgba(246,245,239,0.78); margin-bottom: 16px;
}

.legal-body ul, .legal-body ol {
    padding-left: 24px; margin-bottom: 16px;
}

.legal-body li {
    font-family: var(--font-scripture); font-size: 16px;
    line-height: 1.8; color: rgba(246,245,239,0.78);
    margin-bottom: 8px;
}

.legal-body a {
    color: var(--gold); text-decoration: none;
    border-bottom: 1px solid transparent; transition: border-color 0.3s;
}
.legal-body a:hover { border-color: var(--gold); }

.legal-body strong { color: var(--cream); }

.legal-body .important {
    border-left: 3px solid var(--gold);
    padding: 16px 20px;
    margin: 24px 0;
    background: rgba(237,186,48,0.04);
}

.legal-effective {
    font-family: var(--font-ui); font-size: 12px; letter-spacing: 1px;
    color: var(--muted); text-align: center; margin-bottom: 40px;
}

/* ─── Footer ─────────────────────────────────────────── */
footer {
    border-top: 1px solid var(--hairline);
    padding: 48px 32px 36px; text-align: center;
    position: relative; z-index: 5;
}
.foot-links {
    display: flex; justify-content: center; gap: 24px;
    flex-wrap: wrap; margin-bottom: 20px;
}
.foot-links a {
    font-family: var(--font-ui); font-size: 10px; letter-spacing: 2px;
    text-transform: uppercase; color: var(--muted);
    text-decoration: none; transition: color 0.3s;
}
.foot-links a:hover { color: var(--gold); }
.foot-copy {
    font-family: var(--font-ui); font-size: 10px; letter-spacing: 2px;
    text-transform: uppercase; color: rgba(246,245,239,0.3);
}

/* ─── Buttons ────────────────────────────────────────── */
.btn-gold {
    display: inline-flex; align-items: center; gap: 10px;
    background: var(--gold); color: var(--void);
    border: 1.5px solid var(--gold);
    font-family: var(--font-ui); font-size: 12px; font-weight: 700;
    letter-spacing: 2px; text-transform: uppercase; padding: 15px 28px;
    text-decoration: none; transition: all 0.3s;
}
.btn-gold:hover { background: transparent; color: var(--gold); }

.btn-ghost {
    display: inline-flex; align-items: center; gap: 10px;
    background: transparent; color: var(--cream);
    border: 1.5px solid rgba(246,245,239,0.2);
    font-family: var(--font-ui); font-size: 12px; font-weight: 600;
    letter-spacing: 2px; text-transform: uppercase; padding: 15px 28px;
    text-decoration: none; transition: all 0.3s;
}
.btn-ghost:hover { border-color: var(--cream); }

/* ─── Responsive ─────────────────────────────────────── */
@media (max-width: 640px) {
    .page-main { padding: 110px 16px 48px; }
    .page-hero { padding-top: 20px; margin-bottom: 40px; }
    .page-sub { font-size: 15px; }
    .topnav { padding: 14px 20px; }
    footer { padding: 36px 20px 28px; }
    .foot-links { gap: 16px; }
    .btn-gold, .btn-ghost { padding: 14px 24px; font-size: 11px; }
    .legal-body h2 { font-size: 15px; margin: 36px 0 12px; }
    .legal-body p, .legal-body li { font-size: 15px; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}
