 html, body { height: 100%; min-height: 100%; margin: 0; } body { font-family: 'good_timesregular', sans-serif; font-size: 1rem; background-color: black; } a { text-decoration: none; color: inherit; } a:hover { text-shadow: 0 0 5px #fff, 0 0 10px #fff, 0 0 20px #1e84f2, 0 0 30px #1e84f2, 0 0 40px #1e84f2, 0 0 55px #1e84f2, 0 0 75px #1e84f2; }  @font-face { font-family: 'good_timesregular'; src: url('good_times_rg-webfont.woff2') format('woff2'), url('good_times_rg-webfont.woff') format('woff'); font-weight: normal; font-style: normal; }  #sky-canvas, #bg-canvas { position: fixed; inset: 0; width: 100vw; height: 100vh; display: block; pointer-events: none; } #sky-canvas { z-index: 0; } #bg-canvas { z-index: 1; }  .viewport-header { position: relative; min-height: 100dvh; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 24px 16px 120px; box-sizing: border-box; z-index: 1; gap: 14px; } .center { text-align: center; } :root { --neon-shadow: 0 0 5px #fff, 0 0 10px #fff, 0 0 20px #1e84f2, 0 0 30px #1e84f2, 0 0 40px #1e84f2, 0 0 55px #1e84f2, 0 0 75px #1e84f2; } .sign__word { font-family: good_timesregular; font-size: clamp(1.4rem, 2.2vw, 2.3rem); text-align: center; line-height: 1; color: #fff; text-shadow: var(--neon-shadow); } .sign__word2 { font-family: good_timesregular; font-size: clamp(0.95rem, 1.5vw, 1.6rem); text-align: center; line-height: 1.1; color: #fff; text-shadow: var(--neon-shadow); } .sign__word3 { font-size: 1rem; line-height: 1; text-align: center; color: #fff; text-shadow: var(--neon-shadow); } .sign__word3:hover { box-shadow: var(--neon-shadow); } .hover:hover { box-shadow: var(--neon-shadow); }  @keyframes fadeIn { 0% { opacity: 0; } 100% { opacity: 1; } } .fade-in-text { animation: fadeIn 5s; } .fade-in-image { animation: fadeIn 5s; } .fade-in-button { animation: fadeIn 7s; } .sigil-container { position: relative; display: inline-block; width: min(400px, 52vh, 78vw); height: min(400px, 52vh, 78vw); border-radius: 50%; overflow: visible; box-shadow: 0 0 33px 6px rgba(0, 255, 255, 0.3); transition: box-shadow 0.7s ease-in-out; } .sigil-container:hover { box-shadow: 0 0 111px 11px rgba(0, 255, 255, 0.6); } .sigil-img { width: 100%; height: 100%; border-radius: 50%; display: block; } .fade-in-image img { animation: pulseGlow 4s ease-in-out infinite; box-shadow: 0 0 12px #00faff88; border-radius: 50%; } @keyframes pulseGlow { 0%, 100% { box-shadow: 0 0 13px #00faff88; } 50% { box-shadow: 0 0 33px #00faffcc; } }  .sigil-static { position: relative; z-index: 2; transition: opacity 0.6s ease-in-out; } .sigil-video { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-radius: 50%; object-fit: cover; opacity: 0; transition: opacity 0.6s ease-in-out; pointer-events: none; } .sigil-container:hover .sigil-static { opacity: 0; } .sigil-container:hover .sigil-video { opacity: 1; }  .sidenav { height: 100%; width: 0; position: fixed; z-index: 9999; top: 0; left: 0; background-color: rgba(75, 0, 130, 0.77); overflow-x: hidden; transition: 0.5s; padding-top: 60px; font-family: good_timesregular; } .sidenav a { padding: 8px 16px; text-decoration: none; font-size: 1.6rem; color: #cfcfcf; display: block; transition: 0.3s; } .sidenav a:hover { color: #fff; } .sidenav .closebtn { position: absolute; top: 0; right: 2px; font-size: 36px; } .sidenav-links {  }  .sol-glyph-container { text-align: center; margin-bottom: 24px; } .sol-glyph-img { width: 77px; height: auto; opacity: 0.95; transition: filter 0.6s ease-in-out, opacity 0.6s ease-in-out; } .sol-glyph-img:hover { opacity: 1; filter: drop-shadow(0 0 13px #fcd440); } #logo2 { position: fixed; bottom: 11px; left: 11px; z-index: 10000; padding: 6px 10px; border-radius: 8px; background: rgba(0, 0, 0, 0.35); backdrop-filter: blur(4px); } #logo2:hover { box-shadow: 0 0 13px rgba(30, 132, 242, 0.75); }  .button { background-color: #001c2c; border-radius: 4px; color: white; text-align: center; text-decoration: none; font-size: 16px; cursor: pointer; } .button:hover { box-shadow: var(--neon-shadow); } .divider { width: 1px; height: 48px; background: linear-gradient( to bottom, rgba(0, 0, 0, 0), rgba(120, 220, 255, 0.35), rgba(0, 0, 0, 0) ); } .control-dock { position: relative; width: 100%; display: flex; flex-direction: column; align-items: center; margin-top: 18px; z-index: 30; } .control-sigil-btn { position: relative; width: 84px; height: 84px; padding: 0; border: none; border-radius: 50%; background: radial-gradient(circle at 50% 50%, rgba(255, 170, 70, 0.22) 0%, rgba(255, 120, 40, 0.10) 36%, rgba(0, 0, 0, 0.0) 70%); cursor: pointer; isolation: isolate; transition: transform 180ms ease, filter 220ms ease; } .control-sigil-btn:hover { transform: scale(1.05) rotate(6deg); filter: brightness(1.08); } .control-sigil-core { position: absolute; inset: 12px; border-radius: 50%; background: radial-gradient(circle at 50% 50%, rgba(255, 180, 90, 0.95) 0%, rgba(255, 140, 50, 0.82) 22%, rgba(100, 255, 255, 0.22) 58%, rgba(0, 0, 0, 0.0) 78%); box-shadow: 0 0 18px rgba(255, 150, 70, 0.35), 0 0 34px rgba(255, 130, 40, 0.18), inset 0 0 20px rgba(255, 220, 140, 0.14); } .control-sigil-ring { position: absolute; inset: 4px; border-radius: 50%; border: 1px solid rgba(120, 220, 255, 0.22); box-shadow: 0 0 14px rgba(120, 220, 255, 0.12); } .control-sigil-ring-a { animation: sigilSpin 11s linear infinite; } .control-sigil-ring-b { inset: 16px; border-color: rgba(255, 170, 80, 0.35); box-shadow: 0 0 14px rgba(255, 150, 70, 0.15); animation: sigilSpin 7.5s linear infinite reverse; } @keyframes sigilSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } } .control-sigil-glyph { position: absolute; inset: 0; display: grid; place-items: center; color: rgba(255, 245, 220, 0.95); font-size: 28px; text-shadow: 0 0 8px rgba(255, 210, 130, 0.45), 0 0 18px rgba(255, 150, 70, 0.24); pointer-events: none; } .control-overlay { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center; padding: 24px; background: rgba(0, 0, 0, 0.42); backdrop-filter: blur(8px); z-index: 65; opacity: 0; pointer-events: none; transition: opacity 220ms ease; } .control-overlay.is-open { opacity: 1; pointer-events: auto; } .control-panel { position: relative; width: min(560px, calc(100vw - 32px)); max-height: min(84vh, 900px); overflow-y: auto; opacity: 0; transform: translateY(18px) scale(0.97); transition: opacity 220ms ease, transform 220ms ease; } .control-panel.is-open { opacity: 1; transform: translateY(0) scale(1); animation: terminalWake 420ms ease-out; } .control-panel-inner { padding: 18px 16px; border-radius: 18px; background: rgba(0, 10, 18, 0.78); border: 1px solid rgba(120, 220, 255, 0.18); backdrop-filter: blur(8px); box-shadow: 0 0 28px rgba(0, 180, 255, 0.10), inset 0 0 18px rgba(120, 220, 255, 0.04); } .control-row { display: flex; align-items: center; justify-content: center; gap: 14px; flex-wrap: wrap; } .control-audio-row { display: flex; justify-content: center; gap: 16px; margin-top: 18px; } .control-link { text-decoration: none; } .control-btn { width: 92px; height: 92px; padding: 0; border: 1px solid rgba(120, 220, 255, 0.22); border-radius: 18px; background: linear-gradient(to bottom, rgba(24, 36, 52, 0.94), rgba(8, 14, 24, 0.94)); box-shadow: 0 0 18px rgba(0, 180, 255, 0.10), inset 0 0 18px rgba(120, 220, 255, 0.04); display: inline-flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; color: rgba(225, 245, 255, 0.96); cursor: pointer; text-shadow: none; transition: transform 180ms ease, box-shadow 220ms ease, border-color 220ms ease, filter 220ms ease, background 220ms ease; } .control-btn:hover { transform: translateY(-2px) scale(1.04); border-color: rgba(150, 235, 255, 0.46); background: linear-gradient(to bottom, rgba(28, 44, 62, 0.98), rgba(10, 18, 30, 0.98)); box-shadow: 0 0 22px rgba(0, 190, 255, 0.18), 0 0 44px rgba(0, 190, 255, 0.08), inset 0 0 18px rgba(120, 220, 255, 0.08); filter: brightness(1.05); } .control-icon { width: 44px; height: 44px; display: block; object-fit: contain; opacity: 0.96; filter: brightness(0) saturate(100%) invert(88%) sepia(20%) saturate(549%) hue-rotate(162deg) brightness(103%) contrast(102%) drop-shadow(0 0 6px rgba(120, 220, 255, 0.18)); transition: transform 180ms ease, filter 220ms ease, opacity 220ms ease; } .control-btn:hover .control-icon { transform: scale(1.06); filter: brightness(0) saturate(100%) invert(92%) sepia(28%) saturate(622%) hue-rotate(158deg) brightness(106%) contrast(102%) drop-shadow(0 0 8px rgba(120, 220, 255, 0.25)) drop-shadow(0 0 16px rgba(120, 220, 255, 0.10)); } .control-glyph { font-size: 30px; line-height: 1; color: rgba(225, 245, 255, 0.98); text-shadow: 0 0 8px rgba(120, 220, 255, 0.18), 0 0 16px rgba(120, 220, 255, 0.10); } .control-label { font-family: "good_timesregular", sans-serif; font-size: 0.62rem; letter-spacing: 0.14em; line-height: 1; color: rgba(180, 230, 255, 0.84); text-shadow: 0 0 6px rgba(120, 220, 255, 0.12); } .pgp-btn-trigger { border: none; background: transparent; padding: 0; cursor: pointer; } .pgp-btn-trigger.control-btn { border-color: rgba(140, 255, 190, 0.22); box-shadow: 0 0 18px rgba(80, 255, 150, 0.10), inset 0 0 18px rgba(80, 255, 150, 0.04); } .pgp-btn-trigger.control-btn:hover { border-color: rgba(160, 255, 210, 0.44); box-shadow: 0 0 22px rgba(80, 255, 150, 0.18), 0 0 44px rgba(80, 255, 150, 0.08), inset 0 0 18px rgba(80, 255, 150, 0.08); } @keyframes signalBlink { 0%, 49% { opacity: 1; } 50%, 100% { opacity: 0; } } @keyframes signalPulse { 0% { transform: scale(0.9); opacity: 0.85; } 70% { transform: scale(1.8); opacity: 0.25; } 100% { transform: scale(2.2); opacity: 0; } } @keyframes terminalWake { 0% { filter: brightness(1.4); } 100% { filter: brightness(1); } } .signal-overlay { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center; padding: 24px; background: rgba(0, 0, 0, 0.42); backdrop-filter: blur(8px); z-index: 60; opacity: 0; pointer-events: none; transition: opacity 220ms ease; } .signal-overlay.is-open { opacity: 1; pointer-events: auto; } .signal-card { position: relative; width: min(680px, calc(100vw - 32px)); max-height: min(84vh, 900px); overflow-y: auto; opacity: 0; transform: translateY(18px) scale(0.97); transition: opacity 220ms ease, transform 220ms ease; } .signal-card.is-open { opacity: 1; transform: translateY(0) scale(1); animation: terminalWake 420ms ease-out; } .signal-portrait-wrap { margin-bottom: 12px; display: flex; justify-content: center; } .signal-portrait { width: 177px; height: 177px; object-fit: cover; border-radius: 16px; border: 1px solid rgba(120, 255, 180, 0.28); box-shadow: 0 0 18px rgba(80, 255, 150, 0.18), 0 0 42px rgba(80, 255, 150, 0.08); background: rgba(0, 0, 0, 0.45); } .signal-shell { background: rgba(0, 10, 0, 0.58); border: 1px solid rgba(120, 255, 180, 0.20); border-radius: 18px; padding: 18px 20px 20px; box-shadow: 0 0 24px rgba(80, 255, 150, 0.12), inset 0 0 24px rgba(80, 255, 150, 0.04); backdrop-filter: blur(6px); } .signal-header { font-family: "Courier New", monospace; font-size: 15px; letter-spacing: 0.12em; color: rgba(170, 255, 210, 0.92); margin-bottom: 6px; text-shadow: 0 0 8px rgba(80, 255, 150, 0.18); text-align: center; } .signal-subhead { font-family: "Courier New", monospace; font-size: 11px; letter-spacing: 0.08em; color: rgba(140, 255, 190, 0.62); margin-bottom: 12px; text-align: center; } .signal-terminal-window { max-height: 38vh; overflow-y: auto; padding-right: 6px; border-radius: 12px; border: 1px solid rgba(120, 255, 180, 0.14); background: rgba(0, 0, 0, 0.22); box-shadow: inset 0 0 18px rgba(80, 255, 150, 0.05); } .signal-terminal { min-height: 0; padding: 12px 14px; white-space: pre-wrap; font-family: "Courier New", monospace; font-size: 18px; line-height: 1.7; color: rgba(140, 255, 170, 0.92); text-shadow: 0 0 5px rgba(120, 255, 170, 0.18), 0 0 12px rgba(120, 255, 170, 0.10); } .signal-cursor { display: inline-block; width: 9px; height: 1em; margin-left: 2px; vertical-align: -2px; background: rgba(140, 255, 170, 0.88); box-shadow: 0 0 8px rgba(120, 255, 170, 0.28); animation: signalBlink 1s steps(1, end) infinite; } .signal-trigger-btn { position: fixed; left: 45px; bottom: 50px; padding: 0; border: none; background: transparent; cursor: pointer; z-index: 61; border-radius: 50%; } .signal-trigger-img { display: block; width: 77px; height: 77px; object-fit: cover; border-radius: 50%; border: 1px solid rgba(120, 255, 180, 0.28); box-shadow: 0 0 20px rgba(80, 255, 150, 0.22), 0 0 40px rgba(80, 255, 150, 0.12); transition: transform 180ms ease, box-shadow 220ms ease, filter 220ms ease, border-color 220ms ease; } .signal-trigger-btn:hover .signal-trigger-img { transform: scale(1.04); filter: brightness(1.05); box-shadow: 0 0 22px rgba(80, 255, 150, 0.24), 0 0 50px rgba(80, 255, 150, 0.12); } .signal-trigger-btn.is-active .signal-trigger-img { transform: scale(1.03); filter: brightness(1.08); border-color: rgba(140, 255, 190, 0.55); box-shadow: 0 0 20px rgba(80, 255, 150, 0.28), 0 0 48px rgba(80, 255, 150, 0.18), 0 0 80px rgba(120, 255, 190, 0.10); } .signal-trigger-btn::after { content: ""; position: absolute; inset: -8px; border-radius: 50%; border: 2px solid rgba(120, 255, 190, 0.45); opacity: 0; pointer-events: none; } .signal-trigger-btn.is-active::after { animation: signalPulse 900ms ease-out; } .pgp-overlay { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center; padding: 24px; background: rgba(0, 0, 0, 0.42); backdrop-filter: blur(8px); z-index: 70; opacity: 0; pointer-events: none; transition: opacity 220ms ease; } .pgp-overlay.is-open { opacity: 1; pointer-events: auto; } .pgp-modal { width: min(840px, calc(100vw - 32px)); max-height: min(90vh, 920px); overflow-y: auto; opacity: 0; transform: translateY(18px) scale(0.97); transition: opacity 220ms ease, transform 220ms ease; } .pgp-modal.is-open { opacity: 1; transform: translateY(0) scale(1); animation: terminalWake 420ms ease-out; } .pgp-wrap { max-width: 820px; margin: 0 auto; padding: 0; text-align: center; } .pgp-card { position: relative; overflow: hidden; margin: 0 auto; padding: 18px; border-radius: 16px; background: rgba(0, 0, 0, 0.55); border: 1px solid rgba(0, 255, 255, 0.18); box-shadow: 0 0 22px rgba(0, 255, 255, 0.12); backdrop-filter: blur(4px); } .pgp-card::before { content: ""; position: absolute; inset: 0; pointer-events: none; opacity: 0.12; background: repeating-linear-gradient( to bottom, rgba(255, 255, 255, 0.08) 0px, rgba(255, 255, 255, 0.08) 1px, rgba(0, 0, 0, 0) 3px, rgba(0, 0, 0, 0) 6px ); animation: scanDrift 7s linear infinite; } @keyframes scanDrift { 0% { transform: translateY(-20px); } 100% { transform: translateY(20px); } } .pgp-card::after { content: ""; position: absolute; inset: 0; pointer-events: none; opacity: 0.14; background: radial-gradient(circle at 50% 40%, rgba(0, 255, 255, 0.12), rgba(0, 0, 0, 0) 55%); } .pgp-title { font-family: 'good_timesregular', sans-serif; font-size: 1.2rem; letter-spacing: 1px; margin: 6px 0 8px; color: #fff; text-shadow: 0 0 10px rgba(30, 132, 242, 0.35); } .pgp-email a { color: #fff; text-decoration: none; border-bottom: 1px solid rgba(30, 132, 242, 0.65); padding-bottom: 2px; } .pgp-email a:hover { border-bottom-color: rgba(0, 255, 255, 0.95); text-shadow: 0 0 10px rgba(30, 132, 242, 0.6); } .pgp-actions { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin: 14px 0 10px; } .pgp-btn { font-family: 'good_timesregular', sans-serif; letter-spacing: 1px; padding: 10px 14px; border-radius: 10px; border: 1px solid rgba(0, 255, 255, 0.25); background: rgba(0, 28, 44, 0.85); color: #fff; cursor: pointer; transition: transform 0.15s ease-in-out, box-shadow 0.25s ease-in-out, border-color 0.25s ease-in-out; } .pgp-btn:hover { transform: scale(1.03); border-color: rgba(0, 255, 255, 0.55); box-shadow: 0 0 18px rgba(0, 255, 255, 0.25); } .pgp-status { min-height: 1.2em; font-size: 0.95rem; margin-top: 8px; color: rgba(140, 255, 190, 0.95); text-shadow: 0 0 8px rgba(80, 255, 150, 0.18); } .pgp-transmission { margin: 10px 0 12px; font-family: Consolas, monospace; font-size: 0.95rem; letter-spacing: 0.5px; color: rgba(223, 252, 255, 0.9); text-shadow: 0 0 10px rgba(0, 255, 255, 0.18); } .cursor { display: inline-block; width: 8px; height: 1em; margin-left: 6px; background-color: rgba(0, 255, 255, 0.85); animation: blink 1.1s steps(1) infinite; } @keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: 0; } } #pgpKey { width: 100%; max-width: 760px; height: 58vh; min-height: 340px; resize: none; box-sizing: border-box; padding: 12px; border-radius: 12px; border: 1px solid rgba(30, 132, 242, 0.35); background: rgba(0, 0, 0, 0.65); color: #dffcff; outline: none; font-family: Consolas, monospace; font-size: 0.95rem; line-height: 1.25rem; box-shadow: inset 0 0 22px rgba(0, 255, 255, 0.08); } #pgpKey:focus { border-color: rgba(0, 255, 255, 0.65); box-shadow: inset 0 0 22px rgba(0, 255, 255, 0.12), 0 0 16px rgba(0, 255, 255, 0.12); } @media (max-width: 700px) { .control-row { gap: 10px; } .control-btn { width: 82px; height: 82px; gap: 6px; } .control-glyph { font-size: 26px; } .control-label { font-size: 0.56rem; letter-spacing: 0.12em; } .divider { height: 46px; } .control-overlay { padding: 14px; } .control-panel { width: calc(100vw - 20px); max-height: 88vh; } .control-sigil-btn { width: 72px; height: 72px; } .control-sigil-glyph { font-size: 24px; } .signal-terminal-window { max-height: 34vh; } .signal-card { width: calc(100vw - 20px); max-height: 88vh; } .signal-terminal { font-size: 16px; line-height: 1.75; padding: 10px 12px; } .signal-trigger-btn { left: 14px; bottom: 90px; } .signal-trigger-img { width: 68px; height: 68px; } .pgp-overlay { padding: 14px; } .pgp-modal { width: calc(100vw - 20px); max-height: 90vh; } #pgpKey { height: 46vh; min-height: 240px; font-size: 0.88rem; line-height: 1.15rem; } } @media (orientation: landscape) and (max-height: 500px) { .viewport-header { height: 100dvh; display: flex; flex-direction: column; justify-content: center; align-items: center; overflow: hidden; } .viewport-header br { display: none; } .sigil-container { width: min(220px, 42vh); height: min(220px, 42vh); display: inline-block; flex: 0 0 auto; } .sigil-img, .sigil-video { width: 100%; height: 100%; } .sign__word { font-size: 1.2rem; } .sign__word2 { font-size: 0.9rem; } .control-dock { margin-top: 10px; } }