/* =========================================================================
   UTOPIA VR — design system
   Futuristic teal/cyber theme rebuilt from the original mockups.
   ========================================================================= */

:root {
    --teal-900: #0c2330;
    --teal-800: #123445;
    --teal-700: #1b4b60;
    --teal-600: #235f78;
    --teal-500: #307b9b;   /* dominant background from the mockups */
    --teal-400: #4a93b0;
    --teal-300: #6fb2c9;

    --cyan:      #5fd4e6;
    --cyan-soft: #8be6f2;
    --ink:       #eaf7fb;
    --ink-dim:   #b9d6e0;

    --kofi:   #ff5e5b;
    --ks:     #66c05a;

    --panel:        rgba(10, 38, 51, 0.55);
    --panel-strong: rgba(8, 30, 42, 0.78);
    --panel-border: rgba(120, 220, 240, 0.22);
    --glow:         0 0 24px rgba(95, 212, 230, 0.25);

    --radius: 16px;
    --maxw: 1180px;
    --header-h: 70px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: "Exo 2", system-ui, sans-serif;
    color: var(--ink);
    line-height: 1.6;
    background:
        radial-gradient(1100px 760px at 80% -12%, rgba(64,150,180,.55) 0%, transparent 60%),
        radial-gradient(900px 620px at 8% 6%, rgba(120,86,210,.20) 0%, transparent 55%),
        radial-gradient(1000px 900px at 50% 116%, rgba(8,34,48,.95) 0%, transparent 60%),
        linear-gradient(180deg, #0b2c3f 0%, #0a2030 42%, #050d16 100%);
    background-attachment: fixed;
    min-height: 100vh;
    overflow-x: hidden;
}

h1, h2, h3, h4 { font-family: "Orbitron", sans-serif; letter-spacing: 2px; line-height: 1.15; }

a { color: var(--cyan-soft); text-decoration: none; transition: color .2s ease; }
a:hover { color: #fff; }

img { max-width: 100%; display: block; }

/* ----------------------------------------------------- dynamic space bg --- */
.space-bg { position: fixed; inset: 0; z-index: -1; pointer-events: none; overflow: hidden; }
.spacefield { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }

/* drifting nebula clouds */
.nebula { position: absolute; border-radius: 50%; filter: blur(70px); opacity: .55; mix-blend-mode: screen; will-change: transform; }
.nebula-1 { width: 62vw; height: 62vw; left: -12vw; top: -16vw;
    background: radial-gradient(circle at 50% 50%, rgba(95,212,230,.55), rgba(95,212,230,0) 66%);
    animation: neb1 42s ease-in-out infinite alternate; }
.nebula-2 { width: 56vw; height: 56vw; right: -14vw; top: 18vh;
    background: radial-gradient(circle at 50% 50%, rgba(124,94,224,.42), rgba(124,94,224,0) 66%);
    animation: neb2 54s ease-in-out infinite alternate; }
.nebula-3 { width: 74vw; height: 74vw; left: 8vw; bottom: -34vw;
    background: radial-gradient(circle at 50% 50%, rgba(40,150,180,.5), rgba(40,150,180,0) 66%);
    animation: neb3 64s ease-in-out infinite alternate; }
@keyframes neb1 { from { transform: translate(0,0) scale(1); }      to { transform: translate(7vw,5vh) scale(1.18); } }
@keyframes neb2 { from { transform: translate(0,0) scale(1.1); }    to { transform: translate(-6vw,7vh) scale(.92); } }
@keyframes neb3 { from { transform: translate(0,0) scale(.95); }    to { transform: translate(5vw,-6vh) scale(1.15); } }

/* faint aurora shimmer band */
.aurora { position: absolute; inset: -20% -10% auto -10%; height: 60vh;
    background: linear-gradient(115deg, transparent 0%, rgba(95,212,230,.10) 35%, rgba(124,94,224,.10) 55%, transparent 80%);
    filter: blur(40px); mix-blend-mode: screen; opacity: .7;
    animation: aurora 26s ease-in-out infinite alternate; }
@keyframes aurora { from { transform: translateY(-6%) skewX(-6deg); opacity: .45; } to { transform: translateY(10%) skewX(6deg); opacity: .8; } }

/* CSS star layers (static density beneath the animated canvas) */
.starfield { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.stars { position: absolute; inset: -200px; background-repeat: repeat; opacity: .5; }
.stars-1 { background-image: radial-gradient(1px 1px at 20px 30px, #fff, transparent),
                              radial-gradient(1px 1px at 120px 80px, #cfeff7, transparent),
                              radial-gradient(1px 1px at 200px 160px, #fff, transparent);
           background-size: 240px 240px; animation: drift 140s linear infinite; }
.stars-2 { background-image: radial-gradient(1.4px 1.4px at 60px 120px, #fff, transparent),
                              radial-gradient(1.4px 1.4px at 180px 40px, #aee6f2, transparent);
           background-size: 320px 320px; opacity: .35; animation: drift 90s linear infinite reverse, twinkle 6s ease-in-out infinite; }
.stars-3 { background-image: radial-gradient(2px 2px at 100px 200px, #fff, transparent);
           background-size: 420px 420px; opacity: .25; animation: drift 200s linear infinite; }
@keyframes drift   { from { transform: translateY(0); } to { transform: translateY(240px); } }
@keyframes twinkle { 0%,100% { opacity: .35; } 50% { opacity: .12; } }

/* -------------------------------------------------------------- header --- */
.site-header {
    position: sticky; top: 0; z-index: 50;
    backdrop-filter: blur(10px);
    background: linear-gradient(180deg, rgba(7,28,39,.85), rgba(7,28,39,.45));
    border-bottom: 1px solid var(--panel-border);
    transition: background .3s ease, box-shadow .3s ease;
}
.site-header.scrolled { background: rgba(7,28,39,.95); box-shadow: 0 6px 24px rgba(0,0,0,.35); }
.header-inner {
    max-width: var(--maxw); margin: 0 auto; padding: 10px 22px;
    min-height: var(--header-h);
    display: flex; align-items: center; gap: 24px;
}
.brand { display: flex; flex-direction: column; line-height: 1; }
.brand-name { font-family: "Orbitron", sans-serif; font-weight: 900; font-size: 1.6rem; letter-spacing: 3px; color: #fff; }
.brand-vr { color: var(--cyan); text-shadow: 0 0 14px rgba(95,212,230,.7); }
.brand-tag { font-size: .62rem; letter-spacing: 3px; color: var(--cyan-soft); margin-top: 4px; text-transform: uppercase; }

.main-nav { margin-left: auto; display: flex; align-items: center; gap: 22px; }
.nav-link { font-family: "Orbitron", sans-serif; font-size: .8rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ink); position: relative; padding: 6px 0; }
.nav-link::after { content: ""; position: absolute; left: 0; bottom: 0; height: 2px; width: 0; background: var(--cyan); box-shadow: var(--glow); transition: width .25s ease; }
.nav-link:hover::after, .nav-link.is-active::after { width: 100%; }
.nav-link.is-active { color: #fff; }
.nav-cta {
    font-family: "Orbitron", sans-serif; font-size: .72rem; letter-spacing: 1px; text-transform: uppercase;
    padding: 9px 16px; border-radius: 999px; color: #042029; font-weight: 700;
    background: linear-gradient(135deg, var(--cyan), #9bf0ff);
    box-shadow: var(--glow); transition: transform .2s ease, box-shadow .2s ease;
}
.nav-cta:hover { transform: translateY(-2px); box-shadow: 0 0 28px rgba(95,212,230,.6); color: #042029; }

.nav-toggle { margin-left: auto; display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav-toggle span { width: 26px; height: 2px; background: var(--cyan-soft); transition: .3s; border-radius: 2px; }
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* --------------------------------------------------------------- layout -- */
.site-main { display: block; }
.section { max-width: var(--maxw); margin: 0 auto; padding: 64px 22px; }
.section.narrow { max-width: 920px; }

.panel {
    background: var(--panel); backdrop-filter: blur(8px);
    border: 1px solid var(--panel-border); border-radius: var(--radius);
    box-shadow: var(--glow);
}

.eyebrow { font-family: "Orbitron", sans-serif; color: var(--cyan); letter-spacing: 4px; text-transform: uppercase; font-size: .75rem; margin: 0 0 10px; }
.section-title { font-size: clamp(1.6rem, 3vw, 2.6rem); margin: 0 0 18px; color: #fff; text-transform: uppercase; }
.section-title .vr-accent { color: var(--cyan); }
.lede { font-size: 1.08rem; color: var(--ink-dim); max-width: 70ch; }

/* reveal-on-scroll */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }

/* -------------------------------------------------------------- buttons -- */
.btn {
    display: inline-flex; align-items: center; gap: 10px; cursor: pointer;
    font-family: "Orbitron", sans-serif; font-size: .82rem; letter-spacing: 1.5px; text-transform: uppercase;
    padding: 13px 26px; border-radius: 999px; border: 1px solid transparent;
    transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn-primary { background: linear-gradient(135deg, var(--cyan), #9bf0ff); color: #042029; font-weight: 700; box-shadow: var(--glow); }
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 0 30px rgba(95,212,230,.6); color: #042029; }
.btn-ghost { background: transparent; border-color: var(--panel-border); color: var(--cyan-soft); }
.btn-ghost:hover { transform: translateY(-3px); border-color: var(--cyan); color: #fff; background: rgba(95,212,230,.08); }
.btn-kofi { background: var(--kofi); color: #fff; box-shadow: 0 0 22px rgba(255,94,91,.4); }
.btn-kofi:hover { transform: translateY(-3px); color: #fff; box-shadow: 0 0 30px rgba(255,94,91,.6); }
.btn-ks { background: var(--ks); color: #06210a; font-weight: 700; box-shadow: 0 0 22px rgba(102,192,90,.4); }
.btn-ks:hover { transform: translateY(-3px); color: #06210a; box-shadow: 0 0 30px rgba(102,192,90,.6); }

.chip { display: inline-block; padding: 7px 14px; border-radius: 999px; font-size: .78rem; font-weight: 600; }
.chip-kofi { background: var(--kofi); color: #fff; }
.chip-ks { background: var(--ks); color: #06210a; }

/* ------------------------------------------------- BIG video trailer hero - */
.hero-video-wrap { max-width: var(--maxw); margin: 28px auto 0; padding: 0 22px; }
.video-frame-xl { min-height: 560px; width: 100%; }
.video-frame-xl .video-poster { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .45; }
.video-frame-xl .video-placeholder { z-index: 2; }
.video-frame-xl .play { width: 110px; height: 110px; }
.video-frame-xl .play::after { border-width: 18px 0 18px 30px; }
.video-frame-xl .video-placeholder h3 { font-size: 1.35rem; }
.hero-tagline { text-align: center; padding: 30px 10px 4px; }
.hero-tagline h1 { font-family: "Orbitron", sans-serif; font-size: clamp(1.3rem, 3.2vw, 2.3rem); color: #fff; text-transform: uppercase; letter-spacing: 2px; margin: 0 0 18px; }
.hero-tagline .hero-actions { justify-content: center; }

/* ------------------------------------------------- Your Virtual Life ------ */
.virtual-life { padding-top: 36px; }
.vlife-title { text-align: center; font-size: clamp(1.8rem, 3.6vw, 2.8rem); margin-bottom: 30px; }
.vlife-grid { display: grid; grid-template-columns: 1fr; gap: 22px; align-items: start; }
.vlife-figure { border-radius: var(--radius); overflow: hidden; border: 1px solid var(--panel-border); box-shadow: var(--glow); position: static; max-height: 420px; }
.vlife-figure img { width: 100%; height: 100%; max-height: 420px; object-fit: cover; object-position: center 35%; display: block; }
.vlife-copy { padding: 32px; }
.vlife-copy p { color: var(--ink-dim); }
.vl-head { font-family: "Orbitron", sans-serif; color: var(--cyan); font-size: 1.05rem; letter-spacing: 1px; margin: 22px 0 8px; }
.vl-head:first-child, .vlife-copy > .vl-head:first-of-type { margin-top: 0; }

.early-access { margin-top: 22px; padding: 22px; border-radius: var(--radius); background: rgba(95,212,230,.08); border: 1px solid var(--panel-border); }
.ea-headline { font-family: "Orbitron", sans-serif; color: #fff; font-size: 1.05rem; line-height: 1.5; letter-spacing: .5px; margin: 0 0 10px; }
.ea-headline .dollar { color: var(--cyan); text-shadow: 0 0 14px rgba(95,212,230,.7); font-size: 1.3em; }
.ea-sub { color: var(--cyan-soft); font-weight: 700; margin: 12px 0 4px; }
.kofi-cta { margin-top: 18px; }
.kofi-ico { height: 22px; width: auto; vertical-align: middle; }

/* ------------------------------------------------- page hero banner ------- */
.page-hero { position: relative; max-width: var(--maxw); margin: 28px auto 0; padding: 0 22px; }
.page-hero-inner { position: relative; border-radius: var(--radius); overflow: hidden; min-height: 280px; border: 1px solid var(--panel-border); box-shadow: var(--glow); display: flex; align-items: flex-end; }
.page-hero-inner img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.page-hero-inner::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(7,28,39,.2), rgba(7,28,39,.88)); }
.page-hero-text { position: relative; z-index: 2; padding: 30px 34px; }
.page-hero-text .eyebrow { margin-bottom: 6px; }
.page-hero-text h1 { font-family: "Orbitron", sans-serif; color: #fff; text-transform: uppercase; font-size: clamp(1.6rem, 3.4vw, 2.6rem); margin: 0; letter-spacing: 2px; }
.page-hero-text h1 .vr-accent { color: var(--cyan); }

/* ------------------------------------------------- auth / login ----------- */
.auth-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
.auth-card { padding: 30px; scroll-margin-top: calc(var(--header-h) + 20px); }
.auth-sub { color: var(--ink-dim); font-size: .92rem; margin: 4px 0 18px; }
.auth-form { display: grid; gap: 14px; }
.auth-form label { display: grid; gap: 6px; font-size: .82rem; color: var(--cyan-soft); font-family: "Orbitron", sans-serif; letter-spacing: .5px; }
.auth-form .hint { color: var(--ink-dim); font-family: "Exo 2", sans-serif; font-size: .72rem; text-transform: none; letter-spacing: 0; }
.auth-form input, .auth-form select {
    width: 100%; padding: 11px 13px; border-radius: 10px; font-family: "Exo 2", sans-serif; font-size: .95rem;
    background: rgba(8,30,42,.6); border: 1px solid var(--panel-border); color: #fff;
}
.auth-form input:focus, .auth-form select:focus { outline: none; border-color: var(--cyan); box-shadow: var(--glow); }
.auth-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.auth-row { display: flex; align-items: center; justify-content: space-between; font-size: .8rem; }
.auth-check { display: inline-flex !important; flex-direction: row !important; align-items: center; gap: 7px; color: var(--ink-dim) !important; font-family: "Exo 2", sans-serif !important; letter-spacing: 0 !important; }
.auth-link, .auth-foot a { color: var(--cyan-soft); }
.auth-form button { margin-top: 6px; justify-content: center; }
.auth-foot { margin: 16px 0 0; color: var(--ink-dim); font-size: .88rem; }

.step-list { counter-reset: step; list-style: none; padding: 0; margin: 18px 0 0; display: grid; gap: 12px; }
.step-list li { position: relative; padding-left: 44px; color: var(--ink-dim); }
.step-list li::before { counter-increment: step; content: counter(step); position: absolute; left: 0; top: -2px; width: 28px; height: 28px; border-radius: 50%; display: grid; place-items: center; background: rgba(95,212,230,.14); border: 1px solid var(--cyan); color: var(--cyan); font-family: "Orbitron", sans-serif; font-size: .78rem; }
.step-list li strong { color: var(--ink); }

@media (max-width: 900px) {
    .vlife-grid { grid-template-columns: 1fr; }
    .vlife-figure { position: static; }
    .auth-grid { grid-template-columns: 1fr; }
    .video-frame-xl { min-height: 360px; }
}
@media (max-width: 540px) { .auth-2col { grid-template-columns: 1fr; } }

/* ----------------------------------------------------------------- hero -- */
.hero { position: relative; max-width: var(--maxw); margin: 32px auto 0; padding: 0 22px; }
.hero-grid { display: grid; grid-template-columns: 1.25fr .9fr; gap: 26px; align-items: stretch; }

/* video placeholder that REPLACES the old hero picture */
.video-frame {
    position: relative; border-radius: var(--radius); overflow: hidden;
    border: 1px solid var(--panel-border); box-shadow: var(--glow);
    background:
        radial-gradient(120% 120% at 30% 10%, rgba(95,212,230,.20), transparent 55%),
        linear-gradient(160deg, #11465c 0%, #0a2c3c 60%, #061d28 100%);
    min-height: 420px; display: flex; align-items: center; justify-content: center;
}
.video-frame video, .video-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; border: 0; }
.video-placeholder { position: relative; z-index: 2; text-align: center; padding: 30px; }
.video-placeholder .play {
    width: 84px; height: 84px; border-radius: 50%; margin: 0 auto 18px;
    display: grid; place-items: center; cursor: pointer;
    background: rgba(95,212,230,.14); border: 2px solid var(--cyan);
    box-shadow: var(--glow); transition: transform .25s ease, box-shadow .25s ease;
    animation: pulse 2.6s ease-in-out infinite;
}
.video-placeholder .play:hover { transform: scale(1.08); box-shadow: 0 0 36px rgba(95,212,230,.7); }
.video-placeholder .play::after { content: ""; margin-left: 6px; border-style: solid; border-width: 14px 0 14px 24px; border-color: transparent transparent transparent var(--cyan); }
.video-placeholder h3 { color: #fff; margin: 0 0 6px; font-size: 1.05rem; letter-spacing: 2px; }
.video-placeholder p { color: var(--ink-dim); margin: 0; font-size: .9rem; }
.video-tag { position: absolute; top: 14px; left: 14px; z-index: 3; background: rgba(7,28,39,.7); border: 1px solid var(--panel-border); color: var(--cyan-soft); font-size: .68rem; letter-spacing: 2px; text-transform: uppercase; padding: 5px 12px; border-radius: 999px; }
@keyframes pulse { 0%,100% { box-shadow: 0 0 0 0 rgba(95,212,230,.5); } 50% { box-shadow: 0 0 0 16px rgba(95,212,230,0); } }

.hero-copy { padding: 34px; display: flex; flex-direction: column; justify-content: center; }
.hero-copy h1 { font-size: clamp(1.8rem, 3.4vw, 2.8rem); color: #fff; margin: 0 0 16px; text-transform: uppercase; }
.hero-copy h1 .vr-accent { color: var(--cyan); }
.hero-copy p { color: var(--ink-dim); margin: 0 0 14px; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 12px; }

/* --------------------------------------------------------------- cards --- */
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 22px; }
.card {
    background: var(--panel); border: 1px solid var(--panel-border); border-radius: var(--radius);
    overflow: hidden; transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.card:hover { transform: translateY(-8px); box-shadow: 0 18px 40px rgba(0,0,0,.4), var(--glow); border-color: var(--cyan); }
.card-media { height: 180px; background: linear-gradient(135deg, var(--teal-600), var(--teal-800)); background-size: cover; background-position: center; position: relative; display: grid; place-items: center; overflow: hidden; }
.card-media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.card:hover .card-media img { transform: scale(1.06); }
.card-media .ico { position: relative; z-index: 2; font-size: 2.6rem; filter: drop-shadow(0 0 12px rgba(0,0,0,.6)); background: rgba(7,28,39,.55); width: 64px; height: 64px; border-radius: 50%; display: grid; place-items: center; border: 1px solid var(--panel-border); }
.card-body { padding: 18px 20px 22px; }
.card-body h3 { color: var(--cyan); font-size: 1rem; margin: 0 0 8px; text-transform: uppercase; }
.card-body p { color: var(--ink-dim); font-size: .92rem; margin: 0; }

/* feature list (home) */
.feature-list { list-style: none; padding: 0; margin: 18px 0 0; display: grid; gap: 12px; }
.feature-list li { padding-left: 30px; position: relative; color: var(--ink-dim); }
.feature-list li::before { content: "▸"; position: absolute; left: 6px; color: var(--cyan); }

/* ------------------------------------------------------- pricing table --- */
.pricing-wrap { overflow-x: auto; border-radius: var(--radius); }
.pricing { width: 100%; border-collapse: collapse; min-width: 720px; background: var(--panel); }
.pricing th, .pricing td { padding: 16px 18px; text-align: center; border-bottom: 1px solid rgba(120,220,240,.12); }
.pricing thead th { font-family: "Orbitron", sans-serif; text-transform: uppercase; letter-spacing: 1px; font-size: .9rem; }
.pricing tbody th { text-align: left; color: var(--cyan); font-size: .82rem; letter-spacing: 1px; }
.pricing .tier { font-size: 1.05rem; color: #fff; }
.pricing .price { color: var(--cyan-soft); font-size: .82rem; }
.pricing tbody tr:hover { background: rgba(95,212,230,.06); }
.pricing .check { color: var(--ks); font-weight: 700; font-size: 1.1rem; }
.pricing .tier-col.popular { background: rgba(95,212,230,.10); }
.tier-badge { display: inline-block; font-size: .6rem; letter-spacing: 1px; background: var(--cyan); color: #042029; border-radius: 999px; padding: 2px 8px; margin-left: 6px; vertical-align: middle; }

/* ============================ EVENTS CALENDAR ============================ */
.calendar-shell { display: grid; grid-template-columns: 1.6fr .9fr; gap: 24px; align-items: start; }
.calendar { padding: 22px; }
.cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; gap: 12px; }
.cal-title { font-family: "Orbitron", sans-serif; color: #fff; font-size: 1.25rem; letter-spacing: 2px; margin: 0; text-transform: uppercase; }
.cal-nav { display: flex; gap: 8px; }
.cal-btn { width: 38px; height: 38px; border-radius: 10px; border: 1px solid var(--panel-border); background: rgba(95,212,230,.08); color: var(--cyan-soft); cursor: pointer; font-size: 1.1rem; transition: .2s; }
.cal-btn:hover { background: var(--cyan); color: #042029; }
.cal-today { font-size: .72rem !important; width: auto; padding: 0 12px; letter-spacing: 1px; text-transform: uppercase; font-family: "Orbitron", sans-serif; }

.cal-weekdays { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; margin-bottom: 6px; }
.cal-weekdays span { text-align: center; font-family: "Orbitron", sans-serif; font-size: .68rem; letter-spacing: 1px; color: var(--cyan); text-transform: uppercase; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.cal-cell {
    min-height: 92px; border-radius: 10px; padding: 6px; cursor: default;
    background: rgba(8,30,42,.5); border: 1px solid rgba(120,220,240,.10);
    display: flex; flex-direction: column; gap: 4px; transition: border-color .2s, background .2s;
}
.cal-cell.empty { background: transparent; border-color: transparent; }
.cal-cell.has-events { cursor: pointer; }
.cal-cell.has-events:hover { border-color: var(--cyan); background: rgba(95,212,230,.08); }
.cal-cell.today { border-color: var(--cyan); box-shadow: inset 0 0 0 1px var(--cyan); }
.cal-cell.selected { background: rgba(95,212,230,.14); border-color: var(--cyan); }
.cal-date { font-size: .78rem; color: var(--ink-dim); font-weight: 600; }
.cal-cell.today .cal-date { color: var(--cyan); }
.cal-chip { font-size: .62rem; line-height: 1.3; padding: 2px 6px; border-radius: 6px; color: #04202a; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cal-more { font-size: .6rem; color: var(--cyan-soft); }

/* day detail / agenda panel */
.cal-detail { padding: 22px; position: sticky; top: calc(var(--header-h) + 16px); }
.cal-detail h3 { color: #fff; font-size: 1.05rem; margin: 0 0 4px; letter-spacing: 1px; }
.cal-detail .detail-date { color: var(--cyan); font-size: .8rem; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 14px; }
.agenda { display: grid; gap: 12px; }
.agenda-item { border-left: 3px solid var(--cyan); background: rgba(8,30,42,.5); border-radius: 0 10px 10px 0; padding: 12px 14px; transition: transform .2s; }
.agenda-item:hover { transform: translateX(4px); }
.agenda-item h4 { margin: 0 0 4px; font-size: .92rem; color: #fff; font-family: "Exo 2", sans-serif; letter-spacing: .3px; }
.agenda-item .meta { font-size: .76rem; color: var(--ink-dim); display: grid; gap: 2px; }
.agenda-item .meta b { color: var(--cyan-soft); font-weight: 600; }
.agenda-empty { color: var(--ink-dim); font-size: .9rem; }

.cal-legend { display: flex; flex-wrap: wrap; gap: 10px 16px; margin-top: 22px; }
.legend-item { display: inline-flex; align-items: center; gap: 7px; font-size: .76rem; color: var(--ink-dim); }
.legend-dot { width: 12px; height: 12px; border-radius: 3px; box-shadow: 0 0 8px rgba(0,0,0,.4); }

/* -------------------------------------------------------------- footer --- */
.site-footer { margin-top: 60px; border-top: 1px solid var(--panel-border); background: rgba(6,24,34,.7); backdrop-filter: blur(8px); }
.footer-grid { max-width: var(--maxw); margin: 0 auto; padding: 48px 22px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; }
.footer-col h4 { color: var(--cyan); font-size: .82rem; letter-spacing: 2px; text-transform: uppercase; margin: 0 0 14px; }
.footer-col a { display: block; color: var(--ink-dim); font-size: .9rem; padding: 4px 0; }
.footer-col a:hover { color: #fff; }
.footer-brand .brand-name { font-size: 1.3rem; }
.footer-brand p { color: var(--ink-dim); font-size: .88rem; margin: 12px 0; }
.footer-social { display: flex; gap: 10px; }
.social-icons { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 14px; }
.social-icons a { color: var(--ink-dim); font-size: .82rem; letter-spacing: .5px; }
.social-icons a:hover { color: var(--cyan); }
.footer-brand-row { max-width: var(--maxw); margin: 0 auto; padding: 26px 22px 30px; border-top: 1px solid rgba(120,220,240,.12); display: flex; justify-content: center; }
.footer-brand-row .footer-brand { text-align: center; max-width: 560px; }
.footer-brand-row .footer-social, .footer-brand-row .social-icons { justify-content: center; }
.footer-base { border-top: 1px solid rgba(120,220,240,.12); text-align: center; padding: 18px; color: var(--ink-dim); font-size: .82rem; }
/* "Coming Soon" badge for non-MVP features (links stay active) */
.soon-badge { display: inline-block; font-family: "Orbitron", sans-serif; font-size: .54rem; letter-spacing: 1px; text-transform: uppercase; padding: 3px 9px; border-radius: 999px; background: rgba(255,206,133,.16); border: 1px solid rgba(255,206,133,.5); color: #ffd79a; vertical-align: middle; margin-left: 8px; white-space: nowrap; }
.soon-hero { display:inline-block; font-family:"Orbitron",sans-serif; font-size:.66rem; letter-spacing:2px; text-transform:uppercase; padding:6px 14px; border-radius:999px; background:rgba(255,206,133,.16); border:1px solid rgba(255,206,133,.55); color:#ffd79a; margin-bottom:12px; }

.back-to-top { position: fixed; right: 22px; bottom: 22px; width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; background: var(--cyan); color: #042029; box-shadow: var(--glow); opacity: 0; pointer-events: none; transform: translateY(12px); transition: .3s; z-index: 40; }
.back-to-top.show { opacity: 1; pointer-events: auto; transform: none; }

/* CTA band */
.cta-band { text-align: center; padding: 48px 30px; }
.cta-band h2 { color: #fff; text-transform: uppercase; font-size: clamp(1.4rem, 3vw, 2.2rem); margin: 0 0 12px; }
.cta-band p { color: var(--ink-dim); max-width: 60ch; margin: 0 auto 22px; }
.cta-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ----------------------------------------------------------- responsive -- */
@media (max-width: 900px) {
    .nav-toggle { display: flex; }
    .main-nav {
        position: fixed; inset: var(--header-h) 0 auto 0; flex-direction: column; gap: 0;
        background: rgba(7,28,39,.98); backdrop-filter: blur(12px);
        padding: 10px 22px 24px; border-bottom: 1px solid var(--panel-border);
        transform: translateY(-120%); transition: transform .32s ease; margin: 0;
    }
    .main-nav.open { transform: translateY(0); }
    .nav-link { width: 100%; padding: 14px 0; border-bottom: 1px solid rgba(120,220,240,.08); }
    .nav-cta { margin-top: 14px; text-align: center; }
    .hero-grid { grid-template-columns: 1fr; }
    .calendar-shell { grid-template-columns: 1fr; }
    .cal-detail { position: static; }
    .footer-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
    .footer-grid { grid-template-columns: 1fr; }
    .cal-cell { min-height: 64px; }
    .cal-chip { display: none; }
    .cal-cell.has-events::after { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--cyan); margin: 2px auto 0; }
}
@media (prefers-reduced-motion: reduce) {
    *, .stars, .video-placeholder .play { animation: none !important; transition: none !important; }
}
