Spaces:
Sleeping
Sleeping
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| EVERWRITE β Retro Pixel UI Stylesheet | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| /* ββ Google Font import (fallback β also loaded via HTML link) βββββββββ */ | |
| @import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap'); | |
| /* ββ CSS Variables βββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| :root { | |
| --bg: #05050f; | |
| --panel-bg: #08081a; | |
| --green: #00ff41; | |
| --green-dim: #005c18; | |
| --green-glow: rgba(0, 255, 65, 0.25); | |
| --cyan: #00e5ff; | |
| --cyan-dim: rgba(0, 229, 255, 0.15); | |
| --cyan-glow: rgba(0, 229, 255, 0.4); | |
| --amber: #ffb800; | |
| --amber-dim: rgba(255, 184, 0, 0.15); | |
| --amber-glow: rgba(255, 184, 0, 0.4); | |
| --red: #ff2244; | |
| --purple: #c084fc; | |
| --text-dim: #3a7a4a; | |
| --text-muted: #6abf85; | |
| --border-dim: #0d3318; | |
| --shadow-green: 0 0 8px var(--green), 0 0 24px var(--green-glow); | |
| --shadow-cyan: 0 0 6px var(--cyan), 0 0 18px var(--cyan-glow); | |
| --shadow-amber: 0 0 6px var(--amber), 0 0 18px var(--amber-glow); | |
| --font: 'Press Start 2P', monospace; | |
| } | |
| /* ββ Reset & Base ββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| *, *::before, *::after { | |
| margin: 0; | |
| padding: 0; | |
| box-sizing: border-box; | |
| } | |
| html, body { | |
| height: 100%; | |
| background: var(--bg); | |
| color: var(--green); | |
| font-family: var(--font); | |
| font-size: 14px; | |
| overflow: hidden; | |
| cursor: default; | |
| user-select: none; | |
| } | |
| /* Allow text selection inside narrative */ | |
| .narrative-area { user-select: text; } | |
| /* ββ CRT Scanlines βββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .scanlines { | |
| position: fixed; | |
| inset: 0; | |
| z-index: 9999; | |
| pointer-events: none; | |
| background: repeating-linear-gradient( | |
| to bottom, | |
| transparent 0px, | |
| transparent 3px, | |
| rgba(0,0,0,0.18) 3px, | |
| rgba(0,0,0,0.18) 4px | |
| ); | |
| animation: crt-flicker 12s step-end infinite; | |
| } | |
| @keyframes crt-flicker { | |
| 0%, 85%, 88%, 90%, 92%, 100% { opacity: 1; } | |
| 86%, 89%, 91% { opacity: 0.82; } | |
| } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| START SCREEN | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| #start-screen { | |
| position: fixed; | |
| inset: 0; | |
| z-index: 100; | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| background: var(--bg); | |
| } | |
| .start-inner { | |
| display: flex; | |
| flex-direction: column; | |
| align-items: center; | |
| gap: 22px; | |
| width: 100%; | |
| max-width: 700px; | |
| padding: 40px 20px; | |
| } | |
| /* Pixel border decorations */ | |
| .pixel-deco { | |
| font-size: 12px; | |
| color: var(--green-dim); | |
| letter-spacing: 0px; | |
| white-space: nowrap; | |
| overflow: hidden; | |
| width: 100%; | |
| text-align: center; | |
| } | |
| /* Big title */ | |
| .logo-text { | |
| font-size: 44px; | |
| color: var(--green); | |
| text-shadow: var(--shadow-green); | |
| letter-spacing: 8px; | |
| animation: pulse-glow 2.5s ease-in-out infinite alternate; | |
| } | |
| .logo-sub { | |
| font-size: 14px; | |
| color: var(--cyan); | |
| text-shadow: var(--shadow-cyan); | |
| letter-spacing: 3px; | |
| } | |
| .logo-divider { | |
| color: var(--green-dim); | |
| font-size: 12px; | |
| letter-spacing: 1px; | |
| text-shadow: none; | |
| } | |
| .start-desc { | |
| display: flex; | |
| flex-direction: column; | |
| align-items: center; | |
| gap: 10px; | |
| } | |
| .start-desc p { | |
| font-size: 12px; | |
| color: var(--text-muted); | |
| letter-spacing: 2px; | |
| animation: blink-slow 3s step-end infinite; | |
| } | |
| .start-desc p:nth-child(2) { animation-delay: 0.5s; } | |
| .start-desc p:nth-child(3) { animation-delay: 1s; } | |
| .logo-version { | |
| font-size: 10px; | |
| color: var(--text-muted); | |
| letter-spacing: 1px; | |
| } | |
| /* ββ Start Button βββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| #btn-start { | |
| margin-top: 10px; | |
| padding: 18px 36px; | |
| font-family: var(--font); | |
| font-size: 15px; | |
| background: transparent; | |
| color: var(--green); | |
| border: 2px solid var(--green); | |
| box-shadow: 5px 5px 0 var(--green-dim), var(--shadow-green); | |
| cursor: pointer; | |
| letter-spacing: 3px; | |
| transition: all 0.08s; | |
| outline: none; | |
| position: relative; | |
| } | |
| #btn-start::before { | |
| content: ''; | |
| position: absolute; | |
| inset: 3px; | |
| border: 1px solid var(--green-dim); | |
| pointer-events: none; | |
| } | |
| #btn-start:hover { | |
| background: var(--green); | |
| color: var(--bg); | |
| box-shadow: 6px 6px 0 var(--green-dim), 0 0 40px var(--green), 0 0 80px var(--green-glow); | |
| transform: translate(-2px, -2px); | |
| } | |
| #btn-start:active { | |
| transform: translate(3px, 3px); | |
| box-shadow: 2px 2px 0 var(--green-dim); | |
| } | |
| #btn-start:disabled { | |
| opacity: 0.5; | |
| cursor: not-allowed; | |
| transform: none; | |
| } | |
| /* Blinking "press start" hint */ | |
| .blink-text { | |
| font-size: 10px; | |
| color: var(--amber); | |
| text-shadow: var(--shadow-amber); | |
| animation: blink 1s step-end infinite; | |
| } | |
| /* ββ Animations ββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| @keyframes blink { | |
| 0%, 100% { opacity: 1; } | |
| 50% { opacity: 0; } | |
| } | |
| @keyframes blink-slow { | |
| 0%, 100% { opacity: 0.8; } | |
| 50% { opacity: 0.3; } | |
| } | |
| @keyframes pulse-glow { | |
| from { text-shadow: 0 0 8px var(--green), 0 0 20px var(--green-glow); } | |
| to { text-shadow: 0 0 18px var(--green), 0 0 50px var(--green), 0 0 80px var(--green-glow); } | |
| } | |
| @keyframes fade-out-screen { | |
| 0% { opacity: 1; } | |
| 100% { opacity: 0; pointer-events: none; } | |
| } | |
| #start-screen.fade-out { | |
| animation: fade-out-screen 0.6s ease-in forwards; | |
| } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| GAME UI | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| #game-ui { | |
| display: flex; | |
| flex-direction: column; | |
| height: 100vh; | |
| border: 2px solid var(--green-dim); | |
| box-shadow: | |
| inset 0 0 60px rgba(0,255,65,0.03), | |
| 0 0 30px rgba(0,255,65,0.15); | |
| } | |
| #game-ui.hidden { display: none; } | |
| /* ββ Header / HUD ββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .game-header { | |
| display: flex; | |
| align-items: center; | |
| padding: 10px 18px; | |
| background: var(--panel-bg); | |
| border-bottom: 2px solid var(--border-dim); | |
| flex-shrink: 0; | |
| gap: 14px; | |
| position: relative; | |
| /* inner top border highlight */ | |
| box-shadow: inset 0 -1px 0 var(--green-dim); | |
| } | |
| /* Subtle scanline stripe at top */ | |
| .game-header::after { | |
| content: ''; | |
| position: absolute; | |
| bottom: 0; left: 0; right: 0; | |
| height: 1px; | |
| background: linear-gradient(to right, transparent, var(--green), transparent); | |
| opacity: 0.4; | |
| } | |
| .header-logo { | |
| display: flex; | |
| align-items: center; | |
| gap: 8px; | |
| flex-shrink: 0; | |
| } | |
| .logo-diamond { | |
| color: var(--amber); | |
| font-size: 18px; | |
| text-shadow: var(--shadow-amber); | |
| animation: pulse-glow 3s ease-in-out infinite alternate; | |
| } | |
| .logo-name { | |
| font-size: 14px; | |
| color: var(--green); | |
| text-shadow: var(--shadow-green); | |
| letter-spacing: 2px; | |
| } | |
| /* HUD centre */ | |
| .header-hud { | |
| flex: 1; | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| gap: 12px; | |
| flex-wrap: wrap; | |
| } | |
| .hud-item { | |
| display: flex; | |
| flex-direction: column; | |
| align-items: center; | |
| gap: 4px; | |
| } | |
| .hud-label { | |
| font-size: 9px; | |
| color: var(--text-muted); | |
| letter-spacing: 1px; | |
| } | |
| .hud-value { | |
| font-size: 11px; | |
| color: var(--amber); | |
| max-width: 220px; | |
| white-space: nowrap; | |
| overflow: hidden; | |
| text-overflow: ellipsis; | |
| } | |
| /* Phase-specific colours */ | |
| .hud-value.phase-intro { color: var(--green); text-shadow: var(--shadow-green); } | |
| .hud-value.phase-equipment { color: var(--cyan); text-shadow: var(--shadow-cyan); } | |
| .hud-value.phase-story { color: var(--amber); text-shadow: var(--shadow-amber); } | |
| .hud-value.phase-ended { color: var(--red); text-shadow: 0 0 8px var(--red); } | |
| .hud-sep { | |
| color: var(--border-dim); | |
| font-size: 18px; | |
| line-height: 1; | |
| } | |
| .btn-icon { | |
| font-family: var(--font); | |
| font-size: 9px; | |
| padding: 8px 12px; | |
| background: transparent; | |
| color: var(--text-muted); | |
| border: 1px solid var(--border-dim); | |
| cursor: pointer; | |
| flex-shrink: 0; | |
| letter-spacing: 1px; | |
| transition: all 0.1s; | |
| outline: none; | |
| } | |
| .btn-icon:hover { | |
| color: var(--green); | |
| border-color: var(--green); | |
| box-shadow: var(--shadow-green); | |
| } | |
| /* ββ Narrative Area ββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .narrative-area { | |
| flex: 1; | |
| overflow-y: auto; | |
| padding: 20px 22px; | |
| display: flex; | |
| flex-direction: column; | |
| gap: 16px; | |
| background: var(--bg); | |
| /* subtle inner glow */ | |
| box-shadow: inset 0 0 80px rgba(0,0,0,0.6); | |
| scroll-behavior: smooth; | |
| } | |
| /* Custom scrollbar */ | |
| .narrative-area::-webkit-scrollbar { width: 5px; } | |
| .narrative-area::-webkit-scrollbar-track { background: var(--panel-bg); } | |
| .narrative-area::-webkit-scrollbar-thumb { background: var(--green-dim); } | |
| .narrative-area::-webkit-scrollbar-thumb:hover { background: var(--green); } | |
| /* ββ Message Bubbles βββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .message { | |
| max-width: 88%; | |
| padding: 20px 18px; | |
| font-size: 13px; | |
| line-height: 2.4; | |
| letter-spacing: 0.4px; | |
| border: 1px solid; | |
| position: relative; | |
| word-break: break-word; | |
| white-space: pre-wrap; | |
| animation: msg-appear 0.2s ease-out; | |
| } | |
| @keyframes msg-appear { | |
| from { opacity: 0; transform: translateY(6px); } | |
| to { opacity: 1; transform: translateY(0); } | |
| } | |
| /* ββ AI Message (Weaver) βββ */ | |
| .message.ai { | |
| align-self: flex-start; | |
| color: var(--cyan); | |
| border-color: rgba(0, 229, 255, 0.35); | |
| background: var(--cyan-dim); | |
| /* 3-D pixel shadow */ | |
| box-shadow: | |
| 3px 3px 0 rgba(0,229,255,0.12), | |
| inset 0 0 20px rgba(0,229,255,0.04); | |
| } | |
| .message.ai::before { | |
| content: 'β WEAVER'; | |
| position: absolute; | |
| top: -13px; | |
| left: 0; | |
| font-size: 9px; | |
| color: var(--cyan); | |
| background: var(--bg); | |
| padding: 0 6px; | |
| text-shadow: var(--shadow-cyan); | |
| letter-spacing: 1px; | |
| } | |
| /* ββ User Message (Traveler) βββ */ | |
| .message.user { | |
| align-self: flex-end; | |
| color: var(--amber); | |
| border-color: rgba(255, 184, 0, 0.4); | |
| background: var(--amber-dim); | |
| box-shadow: | |
| -3px 3px 0 rgba(255,184,0,0.12), | |
| inset 0 0 20px rgba(255,184,0,0.04); | |
| } | |
| .message.user::before { | |
| content: 'βΆ TRAVELER'; | |
| position: absolute; | |
| top: -13px; | |
| right: 0; | |
| font-size: 9px; | |
| color: var(--amber); | |
| background: var(--bg); | |
| padding: 0 6px; | |
| text-shadow: var(--shadow-amber); | |
| letter-spacing: 1px; | |
| } | |
| /* ββ System Message βββ */ | |
| .message.system { | |
| align-self: center; | |
| max-width: 100%; | |
| color: var(--text-muted); | |
| border-color: var(--border-dim); | |
| border-style: dashed; | |
| background: transparent; | |
| font-size: 10px; | |
| text-align: center; | |
| letter-spacing: 2px; | |
| box-shadow: none; | |
| } | |
| .message.system::before { display: none; } | |
| /* ββ Streaming cursor βββ */ | |
| .stream-cursor { | |
| display: inline-block; | |
| width: 10px; | |
| height: 18px; | |
| background: var(--cyan); | |
| margin-left: 4px; | |
| vertical-align: text-bottom; | |
| animation: blink 0.55s step-end infinite; | |
| } | |
| /* ββ Loading indicator βββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .loading-msg { | |
| align-self: flex-start; | |
| display: flex; | |
| align-items: center; | |
| gap: 14px; | |
| font-size: 11px; | |
| color: var(--text-muted); | |
| padding: 12px 16px; | |
| border: 1px dashed var(--border-dim); | |
| animation: msg-appear 0.2s ease-out; | |
| letter-spacing: 2px; | |
| } | |
| .spinner::before { | |
| content: attr(data-frame); | |
| color: var(--green); | |
| font-size: 16px; | |
| text-shadow: var(--shadow-green); | |
| } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| INPUT AREA | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .input-area { | |
| display: flex; | |
| align-items: center; | |
| padding: 12px 18px; | |
| background: var(--panel-bg); | |
| border-top: 2px solid var(--border-dim); | |
| flex-shrink: 0; | |
| gap: 10px; | |
| /* top highlight line */ | |
| box-shadow: inset 0 1px 0 var(--green-dim); | |
| position: relative; | |
| } | |
| .input-area::before { | |
| content: ''; | |
| position: absolute; | |
| top: 0; left: 0; right: 0; | |
| height: 1px; | |
| background: linear-gradient(to right, transparent, var(--green), transparent); | |
| opacity: 0.3; | |
| } | |
| .input-caret { | |
| color: var(--green); | |
| font-size: 16px; | |
| flex-shrink: 0; | |
| text-shadow: var(--shadow-green); | |
| animation: blink 1s step-end infinite; | |
| } | |
| .player-input { | |
| flex: 1; | |
| background: transparent; | |
| border: none; | |
| outline: none; | |
| color: var(--green); | |
| font-family: var(--font); | |
| font-size: 13px; | |
| caret-color: var(--green); | |
| letter-spacing: 1px; | |
| } | |
| .player-input::placeholder { | |
| color: var(--text-muted); | |
| font-size: 11px; | |
| } | |
| .player-input:disabled { | |
| color: var(--text-dim); | |
| } | |
| /* ββ Send Button ββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| .btn-send { | |
| font-family: var(--font); | |
| font-size: 11px; | |
| padding: 12px 20px; | |
| background: var(--green-dim); | |
| color: var(--green); | |
| border: 2px solid var(--green); | |
| box-shadow: 4px 4px 0 rgba(0,255,65,0.18), var(--shadow-green); | |
| cursor: pointer; | |
| letter-spacing: 1px; | |
| flex-shrink: 0; | |
| transition: all 0.08s; | |
| outline: none; | |
| position: relative; | |
| } | |
| .btn-send::before { | |
| content: ''; | |
| position: absolute; | |
| inset: 2px; | |
| border: 1px solid var(--green-dim); | |
| pointer-events: none; | |
| opacity: 0.5; | |
| } | |
| .btn-send:hover { | |
| background: var(--green); | |
| color: var(--bg); | |
| box-shadow: 5px 5px 0 rgba(0,255,65,0.3), 0 0 30px var(--green), 0 0 60px var(--green-glow); | |
| transform: translate(-2px, -2px); | |
| } | |
| .btn-send:active { | |
| transform: translate(3px, 3px); | |
| box-shadow: 1px 1px 0 rgba(0,255,65,0.2); | |
| } | |
| .btn-send:disabled { | |
| opacity: 0.35; | |
| cursor: not-allowed; | |
| transform: none; | |
| box-shadow: 4px 4px 0 rgba(0,255,65,0.05); | |
| } | |
| /* βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| RESPONSIVE | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ */ | |
| @media (max-width: 600px) { | |
| .logo-text { font-size: 28px; } | |
| .logo-sub { font-size: 10px; } | |
| #btn-start { font-size: 11px; padding: 14px 22px; } | |
| .game-header { padding: 8px 10px; gap: 8px; } | |
| .logo-name { font-size: 11px; } | |
| .header-hud { gap: 6px; } | |
| .hud-label { font-size: 8px; } | |
| .hud-value { font-size: 9px; max-width: 120px; } | |
| .message { font-size: 11px; max-width: 96%; } | |
| .narrative-area { padding: 14px 12px; } | |
| .input-area { padding: 10px 12px; } | |
| .player-input { font-size: 11px; } | |
| .btn-send { font-size: 9px; padding: 10px 14px; } | |
| } | |