@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;450;500;600&family=Playfair+Display:wght@500;600&display=swap');

:root {
  color-scheme: dark;
  --bg: #070a11;
  --panel: rgba(11, 17, 29, .76);
  --panel-solid: #0d1421;
  --line: rgba(255, 255, 255, .13);
  --line-bright: rgba(143, 211, 255, .36);
  --text: #edf2ff;
  --muted: #9da9c1;
  --soft: #dbe5ff;
  --accent: #8fd3ff;
  --mint: #b9fbc0;
  --gold: #ffd6a5;
  --violet: #a89cff;
  --font: Inter, system-ui, sans-serif;
  --display: 'Playfair Display', Georgia, serif;
}

* { box-sizing: border-box; }
html { max-width: 100%; overflow-x: hidden; scroll-behavior: smooth; background: var(--bg); }
body { max-width: 100%; margin: 0; overflow-x: hidden; background: var(--bg); color: var(--text); font-family: var(--font); -webkit-font-smoothing: antialiased; }
body.world-active, body.core-active, body.memory-active { height: 100svh; overflow-y: hidden; }
button, a { font: inherit; }
a { color: inherit; text-decoration: none; }
button { color: inherit; }

.skip-link { position: fixed; left: 20px; top: -80px; z-index: 100; padding: 12px 16px; border-radius: 999px; background: white; color: #07111f; transition: top .2s; }
.skip-link:focus { top: 18px; }
.global-exit { position: fixed; right: clamp(20px, 3vw, 38px); top: clamp(20px, 3vw, 38px); z-index: 60; display: inline-flex; align-items: center; min-height: 44px; padding: 12px 16px; border: 1px solid var(--line); border-radius: 999px; background: rgba(7,10,17,.62); color: var(--muted); font-size: 11px; backdrop-filter: blur(16px); transition: color .2s, border-color .2s, background .2s, opacity .2s; }
.global-exit:hover, .global-exit:focus-visible { border-color: var(--line-bright); background: rgba(20,31,49,.9); color: var(--text); outline: none; }

.universe-shell { position: relative; min-height: 100svh; overflow: hidden; background: radial-gradient(circle at 50% 42%, rgba(52, 102, 180, .13), transparent 33rem), #070a11; }
.universe-shell::after { content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none; background: linear-gradient(180deg, rgba(7,10,17,.24), transparent 22%, transparent 68%, rgba(7,10,17,.82)); }
#universe-canvas { position: absolute; inset: 0; z-index: 1; width: 100%; height: 100%; outline: 0; cursor: grab; touch-action: none; }
#universe-canvas.is-dragging { cursor: grabbing; }

.topbar { position: absolute; inset: 0 0 auto; z-index: 8; display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; padding: clamp(20px, 3vw, 38px); pointer-events: none; }
.universe-brand, .universe-nav { pointer-events: auto; }
.universe-brand { display: grid; gap: 5px; }
.universe-brand strong { font-family: var(--display); font-size: 20px; font-weight: 600; letter-spacing: -.02em; }
.universe-brand span { color: var(--muted); font-size: 10px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; }
.universe-nav { display: flex; align-items: center; gap: 6px; padding: 5px; border: 1px solid var(--line); border-radius: 999px; background: rgba(7, 10, 17, .55); backdrop-filter: blur(16px); }
.universe-nav a { padding: 7px 10px; border-radius: 999px; color: var(--muted); font-size: 11px; transition: .25s; }
.universe-nav a:hover, .universe-nav a:focus-visible { background: rgba(255,255,255,.08); color: var(--text); outline: none; }

.node-layer { position: absolute; inset: 0; z-index: 6; opacity: 0; pointer-events: none; transition: opacity .8s ease; }
.node-layer.is-ready { opacity: 1; }
body.world-active .node-layer { opacity: 0; pointer-events: none; }
body.memory-active .node-layer { opacity: 0; pointer-events: none; }
.orbit-button { position: absolute; left: 0; top: 0; display: flex; align-items: center; gap: 9px; min-height: 42px; padding: 8px 12px 8px 9px; transform: translate(-50%, -50%); border: 1px solid rgba(255,255,255,.13); border-radius: 999px; background: rgba(8, 13, 23, .76); box-shadow: 0 14px 36px rgba(0,0,0,.3); color: var(--soft); font-size: 12px; font-weight: 550; white-space: nowrap; backdrop-filter: blur(14px); cursor: pointer; pointer-events: auto; transition: opacity .25s, background .25s, border-color .25s, transform .25s; }
.orbit-button:not(.is-revealed) { visibility: hidden; pointer-events: none; }
.orbit-button::before { content: ""; width: 8px; height: 8px; flex: 0 0 auto; border-radius: 50%; background: var(--node-color, var(--accent)); box-shadow: 0 0 14px var(--node-color, var(--accent)); }
.orbit-button:hover, .orbit-button:focus-visible, .orbit-button[aria-pressed="true"] { outline: none; background: rgba(20, 31, 49, .92); border-color: color-mix(in srgb, var(--node-color, var(--accent)) 65%, transparent); transform: translate(-50%, -50%) scale(1.06); }
.orbit-button[aria-pressed="true"] { box-shadow: 0 0 0 5px rgba(143,211,255,.06), 0 14px 40px rgba(0,0,0,.4); }
.orbit-button[data-visited="true"] { border-color: color-mix(in srgb, var(--node-color, var(--accent)) 45%, transparent); background: color-mix(in srgb, var(--node-color, var(--accent)) 10%, rgba(8,13,23,.82)); }
.orbit-button[data-visited="true"]::before { box-shadow: 0 0 0 3px color-mix(in srgb, var(--node-color, var(--accent)) 13%, transparent), 0 0 18px var(--node-color, var(--accent)); }

.journey-status { position: absolute; left: clamp(20px,3vw,38px); top: 104px; z-index: 9; display: flex; align-items: center; gap: 13px; padding: 9px 10px 9px 13px; border: 1px solid var(--line); border-radius: 18px; background: rgba(7,10,17,.58); opacity: 0; pointer-events: none; backdrop-filter: blur(16px); transition: opacity .5s; }
body.scene-ready .journey-status { opacity: 1; pointer-events: auto; }
body.world-active .journey-status, body.core-active .journey-status, body.memory-active .journey-status { opacity: 0; pointer-events: none; }
.journey-status > div { display: grid; gap: 3px; }
.journey-progress { color: var(--soft); font-size: 10px; font-weight: 600; }
.journey-recommendation { color: var(--muted); font-size: 8px; letter-spacing: .08em; text-transform: uppercase; }
.next-path { min-height: 34px; padding: 8px 11px; border: 1px solid var(--line-bright); border-radius: 12px; background: rgba(143,211,255,.08); color: var(--accent); font-size: 9px; cursor: pointer; }
.next-path:hover, .next-path:focus-visible { background: rgba(143,211,255,.14); color: var(--text); outline: none; }
.mobile-path-nav { display: none; }

.core-label { position: absolute; z-index: 5; left: 50%; top: 50%; transform: translate(-50%, -50%) scale(.94); display: grid; place-items: center; text-align: center; opacity: 0; pointer-events: none; text-shadow: 0 3px 30px #07111f; transition: opacity .8s, transform 1.2s; }
body.scene-ready .core-label { opacity: 1; transform: translate(-50%, -50%) scale(1); }
body.world-active .core-label { opacity: 0; transform: translate(-50%, -50%) scale(.82); }
body.memory-active .core-label { opacity: 0; transform: translate(-50%, -50%) scale(.82); }
.core-label strong { font-family: var(--display); font-size: clamp(30px, 4vw, 52px); line-height: .92; letter-spacing: -.045em; }
.core-label span { margin-top: 10px; color: rgba(237,242,255,.72); font-size: 9px; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; }

.helper { position: absolute; left: 50%; bottom: 34px; z-index: 5; transform: translateX(-50%); display: flex; align-items: center; gap: 10px; color: var(--muted); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; white-space: nowrap; transition: opacity .25s; }
.helper::before { content: ""; width: 28px; height: 1px; background: linear-gradient(90deg, transparent, var(--accent)); }
.helper { opacity: 0; }
body.scene-ready .helper { opacity: 1; }
body.world-active .helper { opacity: 0; }
body.memory-active .helper { opacity: 0; }
.scene-status { position: absolute; left: 50%; top: 50%; z-index: 7; margin: 82px 0 0; transform: translateX(-50%); color: var(--accent); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; opacity: 0; transition: opacity .3s; }
body.scene-loading .scene-status { opacity: 1; }
.scene-controls { position: absolute; left: clamp(18px, 3vw, 38px); bottom: 24px; z-index: 9; display: flex; align-items: center; gap: 5px; padding: 5px; border: 1px solid var(--line); border-radius: 999px; background: rgba(7,10,17,.62); opacity: 0; pointer-events: none; backdrop-filter: blur(16px); transition: opacity .5s; }
body.scene-ready .scene-controls { opacity: 1; pointer-events: auto; }
.scene-controls span { padding: 0 8px; color: var(--muted); font-size: 9px; letter-spacing: .08em; text-transform: uppercase; }
.scene-controls button { padding: 7px 9px; border: 0; border-radius: 999px; background: transparent; color: var(--muted); font-size: 9px; cursor: pointer; }
.scene-controls button:hover, .scene-controls button:focus-visible { background: rgba(255,255,255,.08); color: var(--text); outline: none; }

.content-panel { position: absolute; right: clamp(20px, 3vw, 38px); top: 50%; z-index: 12; display: flex; flex-direction: column; width: min(430px, calc(100vw - 40px)); max-height: calc(100svh - 132px); overflow: hidden; padding: 0; border: 1px solid var(--line); border-radius: 27px; background: var(--panel); box-shadow: 0 28px 100px rgba(0,0,0,.48); backdrop-filter: blur(26px) saturate(1.25); transform: translate(28px, -45%); opacity: 0; visibility: hidden; transition: opacity .35s, transform .35s, visibility .35s; }
.content-panel.is-open { transform: translate(0, -50%); opacity: 1; visibility: visible; }
.panel-scroll { min-height: 0; overflow: auto; padding: 27px 27px 8px; scrollbar-width: thin; scrollbar-color: rgba(143,211,255,.22) transparent; }
.panel-close { position: absolute; right: 18px; top: 18px; z-index: 2; min-height: 36px; padding: 8px 11px; border: 1px solid var(--line); border-radius: 999px; background: rgba(8,14,25,.9); color: var(--muted); font-size: 10px; cursor: pointer; }
.panel-close:hover, .panel-close:focus-visible { color: white; border-color: var(--line-bright); outline: none; }
.panel-index { color: var(--accent); font-size: 10px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; }
.content-panel h1 { margin: 18px 40px 0 0; font-family: var(--display); font-size: clamp(32px, 4vw, 48px); font-weight: 540; letter-spacing: -.04em; line-height: .96; }
.panel-label { margin: 11px 0 0; color: var(--soft); font-size: 14px; }
.panel-body { margin: 24px 0 0; padding-top: 22px; border-top: 1px solid var(--line); color: var(--muted); font-size: 14px; line-height: 1.72; }
.keywords { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
.keywords span { padding: 7px 9px; border: 1px solid rgba(255,255,255,.1); border-radius: 999px; background: rgba(255,255,255,.035); color: var(--soft); font-size: 10px; }
.keywords.is-hidden { display: none; }
.panel-actions { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr; flex: 0 0 auto; gap: 8px; margin: 0; padding: 14px 27px 27px; background: linear-gradient(180deg,rgba(11,17,29,.25),rgba(11,17,29,.98) 34%); box-shadow: 0 -18px 28px rgba(7,10,17,.28); }
.panel-cta, .enter-world { display: inline-flex; align-items: center; justify-content: center; width: 100%; min-height: 44px; margin: 0; padding: 13px 16px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.045); color: var(--soft); font-size: 12px; font-weight: 550; cursor: pointer; transition: .25s; }
.enter-world { border: 0; background: linear-gradient(135deg, #eaf7ff, #c7ffd0); color: #07111f; font-weight: 600; }
.enter-world:disabled { cursor: not-allowed; opacity: .55; }
.panel-cta:hover, .panel-cta:focus-visible, .enter-world:hover, .enter-world:focus-visible { transform: translateY(-2px); border-color: var(--line-bright); box-shadow: 0 12px 30px rgba(143,211,255,.12); outline: none; }

.deep-dive { display: none; margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--line); }
.deep-dive.is-visible { display: block; }
.deep-dive h2 { margin: 0 0 12px; font-family: var(--font); color: var(--soft); font-size: 10px; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; }
.experience-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 7px; }
.experience-card { min-width: 0; padding: 11px; border: 1px solid rgba(255,255,255,.10); border-radius: 15px; background: rgba(255,255,255,.035); color: var(--text); text-align: left; cursor: pointer; transition: .2s; }
.experience-card small { display: block; margin-bottom: 5px; color: var(--accent); font-size: 8px; letter-spacing: .11em; text-transform: uppercase; }
.experience-card strong { display: block; overflow: hidden; font-size: 11px; font-weight: 550; line-height: 1.35; text-overflow: ellipsis; }
.experience-card:hover, .experience-card:focus-visible, .experience-card[aria-pressed="true"] { border-color: var(--line-bright); background: rgba(143,211,255,.08); outline: none; }
.experience-card[aria-pressed="true"] { box-shadow: inset 0 0 0 1px rgba(143,211,255,.08); }
.experience-detail { display: none; margin-top: 9px; padding: 13px 14px; border-left: 1px solid var(--accent); background: linear-gradient(90deg,rgba(143,211,255,.07),transparent); color: var(--muted); font-size: 11px; line-height: 1.6; }
.experience-detail.is-visible { display: block; }
.experience-detail strong { color: var(--soft); }
.evidence-status { display: block; margin-bottom: 6px; color: var(--mint); font-size: 7px; font-style: normal; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; }

.world-hud { position: absolute; right: clamp(20px, 3vw, 38px); top: 50%; z-index: 13; width: min(390px, calc(100vw - 40px)); max-height: calc(100svh - 132px); overflow: auto; padding: 25px; border: 1px solid rgba(255,255,255,.14); border-radius: 27px; background: rgba(9,15,27,.76); box-shadow: 0 28px 100px rgba(0,0,0,.5); opacity: 0; visibility: hidden; transform: translate(30px,-46%); backdrop-filter: blur(26px) saturate(1.2); transition: opacity .45s, transform .55s, visibility .45s; scrollbar-width: thin; scrollbar-color: rgba(143,211,255,.22) transparent; }
body.world-active .world-hud { opacity: 1; visibility: visible; transform: translate(0,-50%); }
.world-hud-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.world-back, .world-switcher button { padding: 8px 11px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.035); color: var(--muted); font-size: 9px; cursor: pointer; }
.world-back:hover, .world-back:focus-visible, .world-switcher button:hover, .world-switcher button:focus-visible { border-color: var(--line-bright); color: var(--text); outline: none; }
.world-count { color: var(--accent); font-size: 9px; letter-spacing: .14em; text-transform: uppercase; }
.world-kicker { display: block; margin-top: 25px; color: var(--accent); font-size: 9px; font-weight: 600; letter-spacing: .17em; text-transform: uppercase; }
.world-title { margin: 11px 0 0; font-family: var(--display); font-size: clamp(38px,4vw,52px); font-weight: 540; letter-spacing: -.045em; line-height: .94; }
.world-label { margin: 10px 0 0; color: var(--soft); font-size: 13px; }
.world-description { margin: 19px 0 0; padding-top: 18px; border-top: 1px solid var(--line); color: var(--muted); font-size: 12px; line-height: 1.65; }
.world-items { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 7px; margin-top: 19px; }
.world-item { min-width: 0; padding: 10px; border: 1px solid rgba(255,255,255,.1); border-radius: 14px; background: rgba(255,255,255,.03); color: var(--text); text-align: left; cursor: pointer; }
.world-item small { display: block; overflow: hidden; margin-bottom: 4px; color: var(--accent); font-size: 7px; letter-spacing: .1em; text-overflow: ellipsis; text-transform: uppercase; }
.world-item strong { display: block; overflow: hidden; font-size: 10px; font-weight: 550; line-height: 1.35; text-overflow: ellipsis; }
.world-item:hover, .world-item:focus-visible, .world-item[aria-pressed="true"] { border-color: var(--line-bright); background: rgba(143,211,255,.08); outline: none; }
.world-primary-action { width: 100%; min-height: 44px; margin-top: 16px; padding: 11px 14px; border: 0; border-radius: 999px; background: linear-gradient(135deg,#eaf7ff,#c7ffd0); color: #07111f; font-size: 10px; font-weight: 600; cursor: pointer; }
.world-primary-action:hover, .world-primary-action:focus-visible { transform: translateY(-1px); box-shadow: 0 12px 30px rgba(143,211,255,.12); outline: none; }
.world-switcher { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; margin-top: 20px; padding-top: 17px; border-top: 1px solid var(--line); }

.contact-chamber { position: absolute; right: clamp(20px,3vw,38px); top: 50%; z-index: 17; width: min(560px,calc(100vw - 40px)); max-height: calc(100svh - 108px); overflow: auto; overflow-anchor: none; padding: 27px; border: 1px solid rgba(255,255,255,.15); border-radius: 29px; background: rgba(8,14,25,.91); box-shadow: 0 28px 100px rgba(0,0,0,.58); opacity: 0; visibility: hidden; transform: translate(32px,-46%); backdrop-filter: blur(30px) saturate(1.2); transition: opacity .4s,transform .5s,visibility .4s; scrollbar-width: thin; scrollbar-color: rgba(143,211,255,.22) transparent; }
body.contact-active .contact-chamber { opacity: 1; visibility: visible; transform: translate(0,-50%); }
body.contact-active .world-hud { opacity: 0; visibility: hidden; transform: translate(28px,-48%); pointer-events: none; }
body.contact-active .global-exit { opacity: .48; }
.contact-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; }
.contact-kicker { color: var(--accent); font-size: 8px; font-weight: 600; letter-spacing: .17em; text-transform: uppercase; }
.contact-head h2 { max-width: 340px; margin: 8px 0 0; font-family: var(--display); font-size: clamp(34px,4vw,48px); font-weight: 540; letter-spacing: -.045em; line-height: .96; }
.contact-chamber.is-ready .contact-head h2 { display: none; }
.contact-chamber.is-ready .contact-head { align-items: center; }
.contact-close, .contact-edit { min-height: 38px; padding: 8px 11px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.035); color: var(--muted); font-size: 9px; cursor: pointer; }
.contact-close:hover, .contact-close:focus-visible, .contact-edit:hover, .contact-edit:focus-visible { border-color: var(--line-bright); color: var(--text); outline: none; }
.contact-form { margin-top: 24px; }
.contact-form fieldset { margin: 0; padding: 0; border: 0; }
.contact-form legend, .contact-fields label > span { display: block; margin-bottom: 8px; color: var(--soft); font-size: 8px; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; }
.contact-offers { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 7px; }
.contact-offers label { position: relative; cursor: pointer; }
.contact-offers input { position: absolute; opacity: 0; pointer-events: none; }
.contact-offers span { display: flex; align-items: center; min-height: 44px; padding: 9px 11px; border: 1px solid rgba(255,255,255,.1); border-radius: 14px; background: rgba(255,255,255,.03); color: var(--muted); font-size: 9px; line-height: 1.35; transition: .2s; }
.contact-offers input:checked + span { border-color: var(--line-bright); background: rgba(143,211,255,.1); color: var(--text); box-shadow: inset 0 0 0 1px rgba(143,211,255,.08); }
.contact-offers input:focus-visible + span { outline: 2px solid var(--accent); outline-offset: 2px; }
.contact-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; margin-top: 18px; }
.contact-fields label { display: block; min-width: 0; }
.contact-fields input, .contact-fields select, .contact-fields textarea { width: 100%; min-height: 44px; padding: 11px 12px; border: 1px solid var(--line); border-radius: 14px; background: rgba(255,255,255,.035); color: var(--text); font: inherit; font-size: 10px; outline: none; }
.contact-fields select { color-scheme: dark; }
.contact-fields textarea { min-height: 94px; resize: vertical; line-height: 1.5; }
.contact-fields input:focus, .contact-fields select:focus, .contact-fields textarea:focus { border-color: var(--line-bright); box-shadow: 0 0 0 3px rgba(143,211,255,.06); }
.contact-brief { grid-column: 1/-1; }
.contact-privacy { margin: 14px 0 0; color: var(--muted); font-size: 8.5px; line-height: 1.5; }
.contact-prepare, .contact-send { display: flex; align-items: center; justify-content: center; width: 100%; min-height: 46px; margin-top: 13px; border: 0; border-radius: 999px; background: linear-gradient(135deg,#eaf7ff,#c7ffd0); color: #07111f; font-size: 10px; font-weight: 600; cursor: pointer; }
.contact-ready { margin-top: 26px; }
.contact-ready h3 { margin: 10px 0 0; font-family: var(--display); font-size: 34px; font-weight: 540; letter-spacing: -.04em; }
.contact-summary { display: grid; grid-template-columns: 110px 1fr; gap: 8px 12px; margin: 20px 0 0; padding: 17px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.03); }
.contact-summary dt { color: var(--muted); font-size: 8px; letter-spacing: .1em; text-transform: uppercase; }
.contact-summary dd { margin: 0; color: var(--soft); font-size: 10px; line-height: 1.5; overflow-wrap: anywhere; }
.contact-ready > p { color: var(--muted); font-size: 10px; line-height: 1.6; }
.contact-edit { display: block; margin: 9px auto 0; }

.core-console { position: absolute; right: clamp(20px,3vw,38px); top: 50%; z-index: 15; width: min(410px,calc(100vw - 40px)); max-height: calc(100svh - 112px); overflow: auto; padding: 24px; border: 1px solid rgba(255,255,255,.14); border-radius: 27px; background: rgba(8,14,25,.82); box-shadow: 0 28px 100px rgba(0,0,0,.54); opacity: 0; visibility: hidden; transform: translate(30px,-46%); backdrop-filter: blur(28px) saturate(1.2); transition: opacity .4s,transform .5s,visibility .4s; scrollbar-width: thin; scrollbar-color: rgba(143,211,255,.22) transparent; }
body.core-active .core-console { opacity: 1; visibility: visible; transform: translate(0,-50%); }
.core-console-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.core-console-kicker { color: var(--accent); font-size: 8px; font-weight: 600; letter-spacing: .17em; text-transform: uppercase; }
.core-console h2 { margin: 7px 0 0; font-family: var(--display); font-size: 38px; font-weight: 540; letter-spacing: -.04em; }
.core-console-close { padding: 8px 11px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.035); color: var(--muted); font-size: 9px; cursor: pointer; }
.core-console-close:hover,.core-console-close:focus-visible { border-color: var(--line-bright); color: var(--text); outline: none; }
.core-state { display: flex; align-items: center; gap: 8px; margin-top: 17px; padding: 9px 11px; border: 1px solid rgba(255,255,255,.09); border-radius: 14px; background: rgba(255,255,255,.028); }
.core-state > span { width: 7px; height: 7px; flex: 0 0 auto; border-radius: 50%; background: var(--mint); box-shadow: 0 0 12px rgba(185,251,192,.55); }
.core-state strong { font-size: 10px; font-weight: 550; }
.core-state small { margin-left: auto; color: var(--muted); font-size: 8px; }
.core-console[data-state="thinking"] .core-state > span { background: var(--violet); box-shadow: 0 0 14px rgba(168,156,255,.7); }
.core-console[data-state="speaking"] .core-state > span { background: var(--accent); box-shadow: 0 0 14px rgba(143,211,255,.75); }
.core-console[data-state="memory"] .core-state > span { background: var(--gold); box-shadow: 0 0 14px rgba(255,214,165,.7); }
.core-transcript { display: grid; gap: 8px; max-height: 156px; margin-top: 14px; overflow: auto; padding: 2px; }
.core-message { width: fit-content; max-width: 92%; margin: 0; padding: 10px 12px; border: 1px solid rgba(255,255,255,.08); border-radius: 15px 15px 15px 5px; background: rgba(143,211,255,.055); color: var(--muted); font-size: 10.5px; line-height: 1.55; }
.core-message.user { justify-self: end; border-radius: 15px 15px 5px 15px; background: rgba(255,255,255,.07); color: var(--soft); }
.core-prompts { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 13px; }
.core-prompts button { padding: 7px 9px; border: 1px solid rgba(255,255,255,.09); border-radius: 999px; background: transparent; color: var(--muted); font-size: 8px; cursor: pointer; }
.core-prompts button:hover,.core-prompts button:focus-visible { border-color: var(--line-bright); color: var(--text); outline: none; }
.core-form { margin-top: 14px; }
.core-form label { display: block; margin-bottom: 7px; color: var(--soft); font-size: 8px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; }
.core-form > div { display: grid; grid-template-columns: 1fr auto; gap: 7px; }
.core-form input { min-width: 0; padding: 11px 13px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.035); color: var(--text); font: inherit; font-size: 11px; outline: none; }
.core-form input:focus { border-color: var(--line-bright); box-shadow: 0 0 0 3px rgba(143,211,255,.06); }
.core-form button { padding: 10px 14px; border: 0; border-radius: 999px; background: linear-gradient(135deg,#eaf7ff,#c7ffd0); color: #07111f; font-size: 10px; font-weight: 600; cursor: pointer; }
.journey-memory { margin-top: 15px; padding-top: 14px; border-top: 1px solid var(--line); }
.memory-heading { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.memory-heading h3 { margin: 0; font-size: 9px; letter-spacing: .14em; text-transform: uppercase; }
.memory-heading span { color: var(--muted); font-size: 8px; }
.memory-chips { display: flex; flex-wrap: wrap; gap: 6px; min-height: 27px; margin-top: 10px; }
.memory-chip { padding: 6px 8px; border: 1px solid rgba(255,255,255,.09); border-radius: 999px; background: rgba(255,255,255,.03); color: var(--muted); font-size: 8px; cursor: pointer; }
.memory-chip:hover,.memory-chip:focus-visible { border-color: var(--line-bright); color: var(--text); outline: none; }
.memory-empty { color: var(--muted); font-size: 9px; }
.core-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; margin-top: 14px; }
.core-actions button { padding: 9px 10px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.035); color: var(--soft); font-size: 8.5px; cursor: pointer; }
.core-actions button:hover,.core-actions button:focus-visible,.core-actions button[aria-pressed="true"] { border-color: var(--line-bright); background: rgba(143,211,255,.08); outline: none; }
.core-actions .continue-world { grid-column: 1/-1; }

.cycle-panel { display: none; margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--line); }
.cycle-panel.is-visible { display: block; }
.cycle-panel h2 { margin: 0 0 12px; font-family: var(--font); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; }
.cycle-list { display: flex; flex-wrap: wrap; gap: 7px; }
.phase-pill { padding: 7px 9px; border: 1px solid rgba(255,255,255,.11); border-radius: 999px; background: rgba(255,255,255,.035); color: var(--muted); font-size: 10px; cursor: help; }
.phase-pill:hover, .phase-pill:focus-visible { color: var(--text); border-color: rgba(255,214,165,.35); outline: none; }
.phase-meaning { min-height: 40px; margin: 12px 0 0; color: var(--gold); font-size: 11px; line-height: 1.55; }

.intro { position: fixed; inset: 0; z-index: 40; display: grid; place-items: center; padding: 24px; background: radial-gradient(circle at 50% 46%, rgba(68,129,217,.19), transparent 28rem), rgba(5,8,14,.92); backdrop-filter: blur(14px); transition: opacity .75s, visibility .75s; }
.intro.is-hidden { opacity: 0; visibility: hidden; pointer-events: none; }
.intro-card { width: min(760px, 100%); text-align: center; }
.intro-kicker { color: var(--accent); font-size: 10px; font-weight: 600; letter-spacing: .25em; text-transform: uppercase; }
.intro h1 { margin: 20px 0 0; font-family: var(--display); font-size: clamp(52px, 9vw, 106px); font-weight: 540; letter-spacing: -.06em; line-height: .88; background: linear-gradient(145deg, #fff 18%, #a7ddff 55%, #c7ffd0); background-clip: text; color: transparent; }
.intro p { max-width: 570px; margin: 27px auto 0; color: var(--muted); font-size: clamp(15px, 2vw, 18px); line-height: 1.65; }
.intro .intro-thesis { margin-top: 14px; color: var(--soft); font-size: 12px; letter-spacing: .06em; }
.intro-actions { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin-top: 34px; }
.intro-button { min-width: 168px; padding: 13px 18px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.055); color: var(--text); cursor: pointer; transition: .25s; }
.intro-button.primary { border: 0; background: linear-gradient(135deg,#eaf7ff,#c7ffd0); color: #07111f; font-weight: 600; }
.intro-button:hover, .intro-button:focus-visible { transform: translateY(-2px); border-color: var(--line-bright); outline: none; }
.intro-button:disabled { cursor: wait; opacity: .68; transform: none; }
.intro-status { min-height: 18px; margin-top: 16px; color: var(--accent); font-size: 9px; letter-spacing: .14em; text-transform: uppercase; }
.intro-note { margin-top: 20px; color: rgba(157,169,193,.78); font-size: 10px; letter-spacing: .08em; }

.webgl-fallback { position: absolute; inset: 0; z-index: 4; display: none; place-items: center; padding: 28px; text-align: center; background: radial-gradient(circle, rgba(84,142,224,.18), transparent 30rem); }
.webgl-fallback.is-visible { display: grid; }
.webgl-fallback div { max-width: 480px; }
.webgl-fallback h2 { font-family: var(--display); font-size: 42px; margin: 0; }
.webgl-fallback p { color: var(--muted); line-height: 1.7; }

.mobile-directory { position: relative; z-index: 4; display: none; padding: 70px 18px; background: #090d16; }
.directory-head { margin: 0 auto 28px; max-width: 680px; }
.directory-head span { color: var(--accent); font-size: 10px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; }
.directory-head h2 { margin: 12px 0 0; font-family: var(--display); font-size: 34px; letter-spacing: -.03em; }
.directory-grid { display: grid; gap: 12px; max-width: 680px; margin: auto; }
.directory-card { display: block; width: 100%; padding: 20px; border: 1px solid var(--line); border-radius: 22px; background: rgba(255,255,255,.045); color: var(--text); text-align: left; cursor: pointer; }
.directory-card strong { font-family: var(--display); font-size: 22px; }
.directory-card small { display: block; margin-top: 6px; color: var(--muted); line-height: 1.5; }
.directory-card p { margin: 13px 0 0; color: var(--muted); font-size: 12px; line-height: 1.65; }
.directory-card span { display: inline-block; margin-top: 13px; color: var(--accent); font-size: 11px; }
.directory-card:hover, .directory-card:focus-visible { border-color: var(--line-bright); background: rgba(255,255,255,.07); outline: none; }
body.webgl-unavailable .mobile-directory { display: block; }

.universe-footer { position: relative; z-index: 4; padding: 72px 20px; background: #090d16; }
.footer-card { width: min(980px, 100%); margin: auto; padding: clamp(28px, 5vw, 54px); border: 1px solid var(--line); border-radius: 34px; background: radial-gradient(circle at 12% 10%, rgba(143,211,255,.16), transparent 24rem), rgba(255,255,255,.045); text-align: center; }
.footer-card h2 { margin: 0; font-family: var(--display); font-size: clamp(31px, 5vw, 54px); letter-spacing: -.04em; }
.footer-actions { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin-top: 25px; }
.footer-actions a, .footer-actions button { padding: 12px 17px; border: 1px solid var(--line); border-radius: 999px; background: transparent; color: var(--text); font-size: 13px; cursor: pointer; }
.footer-actions a:first-child, .footer-actions button:first-child { background: linear-gradient(135deg,#eaf7ff,#c7ffd0); border: 0; color: #07111f; font-weight: 600; }

@media (max-width: 860px) {
  .universe-shell { min-height: 760px; height: 100svh; }
  .content-panel { left: 14px; right: 14px; top: auto; bottom: 14px; width: auto; max-height: 56svh; padding: 0; border-radius: 24px; transform: translateY(28px); }
  .content-panel.is-open { transform: none; }
  .panel-scroll { padding: 22px 22px 8px; }
  .panel-actions { padding: 12px 22px 22px; }
  .world-hud { left: 14px; right: 14px; top: auto; bottom: 14px; width: auto; max-height: 48svh; padding: 21px; border-radius: 24px; transform: translateY(28px); }
  body.world-active .world-hud { transform: none; }
  body.world-active .scene-controls { opacity: 0; pointer-events: none; }
  .core-console { left: 14px; right: 14px; top: auto; bottom: 14px; width: auto; max-height: 56svh; padding: 20px; border-radius: 24px; transform: translateY(28px); }
  body.core-active .core-console { transform: none; }
  body.memory-active .scene-controls { opacity: 0; pointer-events: none; }
  .contact-chamber { left: 14px; right: 14px; top: auto; bottom: 14px; width: auto; max-height: 72svh; padding: 22px; border-radius: 24px; transform: translateY(28px); }
  body.contact-active .contact-chamber { transform: none; }
  body.contact-active .scene-controls { opacity: 0; pointer-events: none; }
  .helper { bottom: 82px; }
  .helper.is-hidden { opacity: 0; }
  .scene-controls { left: 50%; bottom: 20px; transform: translateX(-50%); justify-content: center; flex-wrap: wrap; width: min(350px, calc(100vw - 28px)); }
  .scene-controls span { display: none; }
  .mobile-directory { display: block; }
  .orbit-button { min-height: 38px; padding: 7px 10px 7px 8px; font-size: 10px; }
  .core-label strong { font-size: 32px; }
}

@media (max-width: 540px) {
  .topbar { padding: 18px 16px; }
  .global-exit { right: 16px; top: 16px; min-height: 44px; padding: 10px 13px; font-size: 10px; }
  .universe-brand strong { font-size: 17px; }
  .universe-brand span { font-size: 8px; }
  .universe-nav a { display: block; padding: 7px 10px; }
  .journey-status { display: none; }
  .mobile-path-nav { position: absolute; left: 14px; right: 14px; bottom: 70px; z-index: 10; display: grid; gap: 8px; opacity: 0; pointer-events: none; transition: opacity .35s; }
  body.scene-ready .mobile-path-nav { opacity: 1; pointer-events: auto; }
  body.panel-active .mobile-path-nav, body.world-active .mobile-path-nav, body.core-active .mobile-path-nav, body.memory-active .mobile-path-nav { opacity: 0; pointer-events: none; }
  .mobile-path-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 0 5px; }
  .mobile-progress { color: var(--muted); font-size: 9px; letter-spacing: .08em; text-transform: uppercase; }
  .mobile-next-path { min-height: 36px; padding: 8px 11px; border: 1px solid var(--line-bright); border-radius: 999px; background: rgba(7,10,17,.78); color: var(--accent); font-size: 9px; cursor: pointer; }
  .mobile-path-track { display: flex; gap: 7px; width: 100%; overflow-x: auto; padding: 2px 1px 8px; scroll-snap-type: x proximity; scrollbar-width: none; }
  .mobile-path-track::-webkit-scrollbar { display: none; }
  .mobile-path-button { display: grid; flex: 0 0 auto; place-items: center; min-width: 82px; min-height: 44px; padding: 7px 11px; border: 1px solid var(--line); border-radius: 999px; background: rgba(7,10,17,.78); color: var(--soft); font-size: 10px; scroll-snap-align: start; cursor: pointer; backdrop-filter: blur(14px); }
  .mobile-path-button small { display: none; color: var(--mint); font-size: 7px; letter-spacing: .08em; text-transform: uppercase; }
  .mobile-path-button[data-visited="true"] { border-color: rgba(185,251,192,.28); background: rgba(185,251,192,.08); }
  .mobile-path-button[data-visited="true"] small { display: block; }
  .mobile-path-button:hover, .mobile-path-button:focus-visible, .mobile-path-button[aria-pressed="true"] { border-color: var(--line-bright); background: rgba(143,211,255,.11); outline: none; }
  .orbit-button { font-size: 0; width: 34px; height: 34px; min-height: 34px; padding: 0; justify-content: center; pointer-events: none !important; opacity: .46 !important; }
  .orbit-button::before { width: 9px; height: 9px; }
  .orbit-button:hover, .orbit-button:focus-visible, .orbit-button[aria-pressed="true"] { transform: translate(-50%, -50%) scale(1.14); }
  .content-panel h1 { font-size: 34px; }
  .panel-close { min-height: 44px; padding-inline: 13px; }
  .panel-body { font-size: 13px; }
  .experience-grid { grid-template-columns: 1fr 1fr; }
  .scene-controls { bottom: 14px; }
  .scene-controls button { min-height: 40px; padding: 8px 13px; font-size: 9px; }
  .helper { display: none; }
  body.core-active .scene-controls { opacity: 0; pointer-events: none; }
  body.panel-active .scene-controls { opacity: 0; pointer-events: none; }
  .world-title { font-size: 34px; }
  .world-items { grid-template-columns: 1fr 1fr; }
  .panel-actions { grid-template-columns: 1fr; }
  .contact-head { display: block; }
  .contact-close { position: absolute; right: 18px; top: 18px; min-height: 44px; }
  .contact-head h2 { padding-right: 92px; font-size: 34px; }
  .contact-offers, .contact-fields { grid-template-columns: 1fr; }
  .contact-brief { grid-column: auto; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; }
  .intro, .content-panel, .orbit-button { transition-duration: .01ms; }
}
