:root {
    --ink: #0b0f2b;
    --ink-2: #121845;
    --panel: rgba(23, 30, 71, 0.55);
    --panel-solid: #161d49;
    --gold: #d9b46a;
    --gold-bright: #f3d89b;
    --parchment: #f4ecd8;
    --text: #e8e6f2;
    --muted: #a9a8c8;
    --line: rgba(217, 180, 106, 0.28);
    --display: "Cormorant Garamond", Georgia, serif;
    --body: "Jost", system-ui, sans-serif;
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body {
    font-family: var(--body);
    color: var(--text);
    background:
        radial-gradient(1200px 700px at 80% -10%, rgba(217,180,106,0.10), transparent 60%),
        radial-gradient(900px 600px at 0% 110%, rgba(120,90,200,0.18), transparent 55%),
        linear-gradient(160deg, var(--ink), var(--ink-2));
    min-height: 100vh;
    line-height: 1.6;
    font-weight: 300;
    letter-spacing: 0.2px;
    position: relative;
    overflow-x: hidden;
}

/* drifting star texture */
.starfield {
    position: fixed; inset: 0; z-index: 0; pointer-events: none;
    background-image:
        radial-gradient(1.4px 1.4px at 20% 30%, #fff, transparent),
        radial-gradient(1.2px 1.2px at 70% 70%, #fff, transparent),
        radial-gradient(1px 1px at 40% 80%, #fff, transparent),
        radial-gradient(1.6px 1.6px at 85% 25%, #fff, transparent),
        radial-gradient(1px 1px at 55% 15%, #fff, transparent),
        radial-gradient(1.2px 1.2px at 10% 65%, #fff, transparent);
    opacity: 0.5;
    animation: drift 60s linear infinite;
}
@keyframes drift { from { transform: translateY(0); } to { transform: translateY(-40px); } }

.site-header, .container, .site-footer { position: relative; z-index: 1; }

/* header */
.site-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 22px 6vw; border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: center; gap: 12px; text-decoration: none; color: var(--parchment); }
.brand-mark { font-size: 1.6rem; color: var(--gold-bright); }
.brand-text { font-family: var(--display); font-size: 1.5rem; letter-spacing: 1px; }
.brand-text sup { color: var(--gold); font-size: 0.6rem; }
.nav { display: flex; align-items: center; gap: 26px; }
.nav a { color: var(--muted); text-decoration: none; font-size: 0.92rem; letter-spacing: 0.5px; transition: color .2s; }
.nav a:hover { color: var(--gold-bright); }
.nav a.cta {
    color: var(--ink); background: linear-gradient(120deg, var(--gold), var(--gold-bright));
    padding: 9px 18px; border-radius: 999px; font-weight: 500;
}
.nav a.cta:hover { color: var(--ink); filter: brightness(1.06); }

/* layout */
.container { max-width: 980px; margin: 0 auto; padding: 56px 6vw 90px; }

h1, h2, h3 { font-family: var(--display); font-weight: 500; letter-spacing: 0.5px; line-height: 1.15; }
h1 { font-size: clamp(2.6rem, 6vw, 4.4rem); margin: 0 0 12px; }
h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); color: var(--parchment); }
a { color: var(--gold-bright); }

/* hero */
.hero { text-align: center; padding: 30px 0 10px; }
.hero .eyebrow { letter-spacing: 5px; text-transform: uppercase; font-size: 0.72rem; color: var(--gold); }
.hero h1 { color: #fff; }
.hero .lede { max-width: 620px; margin: 0 auto 28px; color: var(--muted); font-size: 1.1rem; }
.hero .moon-emblem { font-size: 3rem; color: var(--gold-bright); margin-bottom: 10px;
    text-shadow: 0 0 36px rgba(243,216,155,0.55); }

.btn {
    display: inline-block; text-decoration: none; cursor: pointer; border: none;
    font-family: var(--body); font-size: 1rem; letter-spacing: 0.5px;
    padding: 14px 30px; border-radius: 999px;
    background: linear-gradient(120deg, var(--gold), var(--gold-bright)); color: var(--ink);
    font-weight: 500; transition: transform .15s, filter .2s;
}
.btn:hover { transform: translateY(-2px); filter: brightness(1.05); }
.btn.secondary { background: transparent; color: var(--gold-bright); border: 1px solid var(--line); }

/* three pillars */
.pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin: 64px 0; }
.pillar {
    background: var(--panel); border: 1px solid var(--line); border-radius: 16px;
    padding: 28px 24px; backdrop-filter: blur(6px);
}
.pillar .sym { font-size: 1.8rem; color: var(--gold-bright); }
.pillar h3 { font-size: 1.4rem; margin: 10px 0 8px; color: var(--parchment); }
.pillar p { color: var(--muted); font-size: 0.95rem; margin: 0; }

/* cards / panels */
.card {
    background: var(--panel); border: 1px solid var(--line); border-radius: 18px;
    padding: 34px; backdrop-filter: blur(6px); margin-bottom: 26px;
}
.card.solid { background: var(--panel-solid); }

/* forms */
.form { max-width: 460px; margin: 0 auto; }
.form label { display: block; margin: 16px 0 6px; font-size: 0.85rem; letter-spacing: 0.6px; color: var(--muted); text-transform: uppercase; }
.form input {
    width: 100%; padding: 12px 14px; border-radius: 10px;
    border: 1px solid var(--line); background: rgba(8,11,33,0.6); color: var(--text);
    font-family: var(--body); font-size: 1rem;
}
.form input:focus { outline: none; border-color: var(--gold); }
.form .row { display: flex; gap: 14px; }
.form .row > div { flex: 1; }
.form .btn { width: 100%; margin-top: 24px; }
.form .hint { font-size: 0.8rem; color: var(--muted); margin-top: 6px; }
.form .switch { text-align: center; margin-top: 18px; color: var(--muted); }

.alert { padding: 12px 16px; border-radius: 10px; margin-bottom: 18px; font-size: 0.92rem;
    background: rgba(193, 84, 84, 0.15); border: 1px solid rgba(193,84,84,0.4); color: #f4c9c9; }

/* the reading */
.archetype-banner { text-align: center; padding: 18px 0 30px; }
.archetype-banner .eyebrow { letter-spacing: 5px; text-transform: uppercase; font-size: 0.7rem; color: var(--gold); }
.archetype-banner h1 { color: #fff; margin: 6px 0; font-style: italic;
    text-shadow: 0 0 40px rgba(243,216,155,0.35); }

.key-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 14px; margin: 8px 0 30px; }
.key-chip {
    text-align: center; padding: 18px 12px; border-radius: 14px;
    background: rgba(8,11,33,0.45); border: 1px solid var(--line);
}
.key-chip .label { font-size: 0.7rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gold); }
.key-chip .value { font-family: var(--display); font-size: 1.7rem; color: var(--parchment); margin-top: 4px; }

.four-keys .card h2 { display: flex; align-items: baseline; gap: 12px; margin-top: 0; }
.four-keys .card h2 .num { font-size: 0.8rem; color: var(--gold); letter-spacing: 2px; }
.four-keys .card p { color: #d7d5ea; margin-bottom: 0; }

.moon-now { display: flex; align-items: center; gap: 18px; }
.moon-now .glyph { font-size: 2.6rem; color: var(--gold-bright); text-shadow: 0 0 30px rgba(243,216,155,0.5); }
.moon-now .meta .label { font-size: 0.72rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gold); }
.moon-now .meta .name { font-family: var(--display); font-size: 1.5rem; color: var(--parchment); }

.matrix-quote {
    font-family: var(--display); font-style: italic; font-size: 1.3rem; line-height: 1.5;
    color: var(--parchment); border-left: 2px solid var(--gold); padding-left: 22px; margin: 0;
}

/* footer */
.site-footer { text-align: center; padding: 40px 6vw 60px; border-top: 1px solid var(--line); color: var(--muted); }
.footer-keys { font-size: 1.3rem; color: var(--gold-bright); letter-spacing: 6px; }
.site-footer .fine { font-size: 0.78rem; color: #7d7ca0; max-width: 560px; margin: 8px auto; }

/* entrance animation */
.fade-up { opacity: 0; transform: translateY(16px); animation: fadeUp .7s ease forwards; }
.fade-up:nth-child(2) { animation-delay: .08s; }
.fade-up:nth-child(3) { animation-delay: .16s; }
.fade-up:nth-child(4) { animation-delay: .24s; }
@keyframes fadeUp { to { opacity: 1; transform: none; } }

@media (max-width: 720px) {
    .pillars { grid-template-columns: 1fr; }
    .form .row { flex-direction: column; }
    .nav { gap: 16px; }
}
