:root { color-scheme: dark; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; background: radial-gradient(circle at top, rgba(48, 72, 104, 0.35), transparent 42%), linear-gradient(180deg, #0b1220 0%, #070b13 100%); color: #f4f7fb; } * { box-sizing: border-box; } html, body { margin: 0; padding: 0; height: 100%; width: 100%; overflow: hidden; background: transparent; } /* TV/Fullscreen optimized container - 16:9 aspect ratio accounting for browser chrome */ #app { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; padding: 0.5rem; min-height: auto; } #app > * { /* 16:9 aspect ratio container */ aspect-ratio: 16 / 9; /* Account for browser chrome (~100px) on height, then let width follow 16:9 */ max-height: calc(100vh - 100px); max-width: 100vw; width: auto; height: auto; /* Ensure it doesn't overflow */ min-width: 0; min-height: 0; /* Contain everything inside */ display: flex; flex-direction: column; } /* When in fullscreen, use full viewport */ :fullscreen #app > *, :-webkit-full-screen #app > *, :-moz-full-screen #app > * { max-height: 100vh; padding: 0; } button, input, select { font: inherit; } input[type="number"], input[type="text"], select { width: 100%; min-height: 2.8rem; padding: 0.7rem 0.85rem; border-radius: 0.9rem; border: 1px solid rgba(255, 255, 255, 0.12); background: rgba(255, 255, 255, 0.05); color: #f4f7fb; } button { border: 0; cursor: pointer; } .layout { width: 100%; height: 100%; padding: 0.5rem; display: flex; flex-direction: column; gap: 0.5rem; overflow: hidden; } .scoreboard { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 0.75rem; } .scoreboard--bottom { align-items: end; position: relative; z-index: 25; } .score-card { border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 1.25rem; padding: 0.8rem 1rem; background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06); } .score-card.active { border-color: color-mix(in srgb, var(--player-color) 55%, white); box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08), 0 0 24px var(--player-glow); } .score-card__head, .score-card__numbers, .panel__title-row, .button-row, .setup-grid, .toggle-row, .active-turn { display: flex; align-items: center; } .score-card__head, .panel__title-row, .button-row, .toggle-row { justify-content: space-between; } .score-card__identity { display: flex; align-items: center; gap: 0.6rem; } .score-card__head h2, .panel h1, .panel h2, .active-turn h2 { margin: 0; } .score-card__numbers { margin-top: 0.65rem; gap: 1rem; } .score-card__footer { margin-top: 0.65rem; padding-top: 0.55rem; border-top: 1px solid rgba(255, 255, 255, 0.08); color: rgba(231, 238, 247, 0.72); font-size: 0.82rem; } .score-card__numbers div { display: grid; gap: 0.15rem; } .score-card__numbers span, .eyebrow, label span, .log-list p, .status-panel p, .active-turn p, .effect-empty { color: rgba(231, 238, 247, 0.72); } .score-card__meta { font-size: 0.82rem; color: rgba(231, 238, 247, 0.7); } .score-card__numbers strong { font-size: 1.35rem; } .score-value { display: inline-block; } .score-value.changed { animation: score-pop 0.7s ease; } .player-dot { width: 0.95rem; height: 0.95rem; border-radius: 999px; background: var(--player-color); box-shadow: 0 0 18px var(--player-glow); } .game-area { flex: 1; position: relative; display: grid; grid-template-columns: minmax(0, 1.9fr) minmax(280px, 0.85fr); gap: 0.5rem; min-height: 0; align-items: center; overflow: hidden; } .board-shell, .panel { border-radius: 1.5rem; border: 1px solid rgba(255, 255, 255, 0.08); background: rgba(9, 16, 29, 0.72); backdrop-filter: blur(20px); } .board-shell { min-height: 0; padding: 0.4rem; display: flex; align-items: center; justify-content: center; overflow: hidden; } .board { position: relative; width: 100%; height: auto; max-width: 100%; max-height: 100%; aspect-ratio: var(--board-columns) / var(--board-rows); display: grid; gap: 0.15rem; margin: 0 auto; align-self: center; } .board__lines { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.18)); z-index: 1; } .board__fx { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; z-index: 4; } .cell { position: relative; background: rgba(255, 255, 255, 0.03); border-radius: 0.8rem; border: 1px solid rgba(255, 255, 255, 0.05); overflow: hidden; z-index: 2; } .cell__shade { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), var(--column-tint)); } .cell__root-ring { position: absolute; inset: 18% 18%; border: 1px dashed rgba(255, 255, 255, 0.28); border-radius: 999px; } .cell__node, .cell__target-label { position: absolute; inset: 50% auto auto 50%; transform: translate(-50%, -50%); } .cell__node { width: min(1.5em, 1.6rem); height: min(1.5em, 1.6rem); min-width: 1rem; min-height: 1rem; border-radius: 50%; background: var(--node-color); box-shadow: 0 0 0 0.2rem rgba(255, 255, 255, 0.06), 0 0 1.2rem var(--node-glow); } .cell.selected { border-color: rgba(255, 255, 255, 0.55); box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22); } .cell.pending { border-color: rgba(255, 255, 255, 0.28); box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12), 0 0 18px rgba(255, 255, 255, 0.08); } .cell.pending .cell__node { box-shadow: 0 0 0 0.22rem rgba(255, 255, 255, 0.08), 0 0 1.4rem var(--node-glow), 0 0 2rem rgba(255, 255, 255, 0.08); } .board__drop-layer { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 5; } .board__energy-layer { position: absolute; inset: 0; pointer-events: none; z-index: 4; } .board__energy-cell { position: absolute; border-radius: 0.8rem; background: radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.95), color-mix(in srgb, var(--flash-color) 70%, #ffe08a) 34%, rgba(255, 224, 138, 0.18) 72%, transparent 100%), linear-gradient(180deg, rgba(255, 255, 255, 0.18), transparent); box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12), 0 0 18px color-mix(in srgb, var(--flash-color) 55%, #ffe08a); opacity: 0; } .board__energy-cell--sunlight { inset: 12%; background: linear-gradient(180deg, rgba(255, 244, 214, 0.05), rgba(255, 244, 214, 0.008)), radial-gradient(circle at 50% 50%, rgba(255, 242, 196, 0.11), color-mix(in srgb, var(--flash-color) 10%, #ffe3a3) 42%, rgba(255, 221, 128, 0.03) 72%, transparent 100%); box-shadow: inset 0 0 0 1px rgba(255, 245, 224, 0.02), 0 0 6px color-mix(in srgb, var(--flash-color) 8%, #ffe3a3); } .board--sunlight .board__energy-cell--sunlight, .board--branches .board__energy-cell, .board--bonus .board__energy-cell--bonus { animation: energy-cell-flash 0.48s ease forwards; animation-delay: var(--flash-delay, 0ms); } .board__energy-cell--bonus { box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18), 0 0 22px rgba(255, 216, 94, 0.9); } .board--bonus .board__drop--bonus { animation: sunlight-drop 0.85s cubic-bezier(0.2, 0.7, 0.2, 1) forwards; } .board__drop-core, .board__drop-spark { position: absolute; inset: 0; border-radius: 999px; } .board__drop-core { background: radial-gradient(circle at 35% 30%, rgba(255, 255, 255, 0.98), color-mix(in srgb, var(--drop-color) 72%, #ffe38a) 45%, rgba(255, 227, 138, 0.18) 100%); box-shadow: 0 0 18px color-mix(in srgb, var(--drop-color) 40%, #ffe38a), 0 0 32px rgba(255, 236, 174, 0.65); } .board__drop-spark { inset: 35%; border: 1px solid rgba(255, 248, 220, 0.95); opacity: 0.9; } .board__drop-spark--a { transform: translate(-0.8rem, -0.15rem) scale(0.55); } .board__drop-spark--b { transform: translate(0.75rem, -0.1rem) scale(0.45); } .board__drop-spark--c { transform: translate(0.1rem, -0.75rem) scale(0.35); } .board__root-burst, .board__disease-mark, .board__sunbeam-burst { opacity: 0; } .board__root-burst circle, .board__sunbeam-burst { fill: color-mix(in srgb, var(--burst-color, #ffd85e) 70%, white); stroke: rgba(255, 255, 255, 0.65); stroke-width: 0.35; } .board__root-burst text { fill: #08111c; font-size: 2.1px; font-weight: 800; } .board__disease-mark circle { fill: rgba(162, 255, 142, 0.2); stroke: rgba(162, 255, 142, 0.9); stroke-width: 0.35; } .board__disease-mark path { stroke: rgba(162, 255, 142, 1); stroke-width: 0.5; stroke-linecap: round; } .board--branches .board__root-burst, .board--events .board__root-burst, .board--events .board__disease-mark, .board--bonus .board__sunbeam-burst, .board--events .board__sunbeam-burst { animation: pop-fade 0.8s ease forwards; animation-delay: var(--trace-delay, 0ms); } .board__sunbeam-burst text { fill: #08111c; font-size: 2.1px; font-weight: 800; } .cell.target { border-color: rgba(255, 255, 255, 0.22); background: rgba(255, 255, 255, 0.05); } .cell.target:hover { transform: translateY(-1px); } .cell__target-label { width: 2rem; height: 2rem; display: grid; place-items: center; border-radius: 999px; background: rgba(255, 255, 255, 0.09); border: 1px solid rgba(255, 255, 255, 0.18); font-weight: 700; } .sidebar { display: flex; flex-direction: column; gap: 1rem; } .panel { padding: 1rem; } .controls-panel { display: grid; gap: 0.8rem; } .panel__actions { display: flex; gap: 0.55rem; } .modal-backdrop { position: fixed; inset: 0; display: grid; place-items: center; padding: 1.25rem; background: rgba(3, 8, 16, 0.72); backdrop-filter: blur(14px); z-index: 20; } .modal { width: min(1180px, 100%); max-height: min(92%, 980px); overflow: auto; } .draft-panel { position: fixed; top: 1rem; right: 1rem; width: max(320px, 30%); max-width: calc(100% - 2rem); max-height: calc(100% - 9.5rem); overflow: auto; z-index: 24; border-color: rgba(255, 255, 255, 0.12); background: rgba(9, 16, 29, 0.5); backdrop-filter: blur(18px); box-shadow: 0 16px 48px rgba(0, 0, 0, 0.32); } .modal-setup-grid, .modal-grid { display: grid; gap: 0.9rem; } .modal-setup-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); } .modal-grid { margin-top: 0.9rem; grid-template-columns: repeat(2, minmax(0, 1fr)); } .modal-actions { margin-top: 0.9rem; justify-content: flex-end; } .eyebrow { margin: 0 0 0.3rem; font-size: 0.82rem; letter-spacing: 0.12em; text-transform: uppercase; } .setup-grid { gap: 1rem; align-items: end; } .setup-grid label { flex: 1; display: grid; gap: 0.35rem; } .seed-editor { display: grid; gap: 0.65rem; padding: 0.8rem; border-radius: 1rem; background: rgba(255, 255, 255, 0.03); border: 1px solid rgba(255, 255, 255, 0.06); } .seed-row { display: grid; gap: 0.35rem; } .order-row, .order-row__label, .order-row__actions { display: flex; align-items: center; } .order-row { justify-content: space-between; gap: 0.75rem; } .order-row__label { gap: 0.6rem; font-weight: 600; } .order-row__actions { gap: 0.4rem; } .mini-button { min-height: 2rem; padding: 0.35rem 0.65rem; border-radius: 0.7rem; background: rgba(255, 255, 255, 0.08); color: #f4f7fb; border: 1px solid rgba(255, 255, 255, 0.1); font-weight: 600; } .seed-help { margin: 0; color: rgba(231, 238, 247, 0.72); } .initiative-order-row { display: flex; flex-wrap: wrap; gap: 0.55rem; } .initiative-pill { padding: 0.45rem 0.7rem; border-radius: 999px; background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255, 255, 255, 0.08); color: rgba(231, 238, 247, 0.76); } .initiative-pill--active { border-color: color-mix(in srgb, var(--player-color) 62%, white); box-shadow: 0 0 18px color-mix(in srgb, var(--player-color) 40%, transparent); color: #f4f7fb; } .initiative-seat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 0.8rem; margin-top: 0.9rem; } .initiative-seat { min-height: 8rem; padding: 0.9rem; border-radius: 1rem; display: grid; gap: 0.35rem; text-align: left; background: rgba(255, 255, 255, 0.06); color: #f4f7fb; border: 1px solid rgba(255, 255, 255, 0.1); } .initiative-seat--taken { opacity: 0.68; } .weather-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 0.9rem; margin-top: 0.9rem; } .weather-card { display: grid; gap: 0.8rem; padding: 0.95rem; border-radius: 1rem; background: rgba(255, 255, 255, 0.05); border: 1px solid rgba(255, 255, 255, 0.08); } .weather-card h2, .weather-card p { margin: 0; } .weather-card--drafted { border-color: rgba(130, 224, 182, 0.55); } .weather-card--banned { border-color: rgba(255, 128, 128, 0.45); opacity: 0.72; } .weather-card__actions { display: flex; gap: 0.6rem; flex-wrap: wrap; } .weather-key { display: grid; gap: 0.25rem; color: rgba(231, 238, 247, 0.78); font-size: 0.86rem; } .active-effects { display: grid; gap: 0.55rem; margin-top: 0.65rem; } .effect-chip { display: flex; align-items: center; min-height: 3rem; padding: 0.75rem 0.9rem; border-radius: 1rem; background: linear-gradient(180deg, rgba(255, 208, 96, 0.14), rgba(255, 208, 96, 0.04)); border: 1px solid rgba(255, 208, 96, 0.2); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06); } .effect-chip__title { font-size: 1rem; font-weight: 700; color: #f4f7fb; } .weather-action { flex: 1; min-width: 0; display: flex; align-items: center; gap: 0.7rem; padding: 0.75rem 0.85rem; border-radius: 0.95rem; color: #f4f7fb; border: 1px solid rgba(255, 255, 255, 0.12); background: rgba(255, 255, 255, 0.06); text-align: left; } .weather-action span { display: grid; gap: 0.12rem; } .weather-action strong { display: block; } .weather-action__icon { width: 2rem; height: 2rem; display: grid; place-items: center; border-radius: 999px; font-size: 1rem; line-height: 1; background: rgba(255, 255, 255, 0.12); flex: 0 0 auto; } .weather-action--draft { background: linear-gradient(180deg, rgba(255, 208, 96, 0.2), rgba(255, 208, 96, 0.08)); border-color: rgba(255, 208, 96, 0.4); } .weather-action--draft .weather-action__icon { background: rgba(255, 208, 96, 0.22); } .weather-action--ban { background: linear-gradient(180deg, rgba(255, 110, 110, 0.16), rgba(255, 110, 110, 0.06)); border-color: rgba(255, 110, 110, 0.32); } .weather-action--ban .weather-action__icon { background: rgba(255, 110, 110, 0.18); } .weather-action:hover { transform: translateY(-1px); } .randomize-button { width: 100%; } .finish-game-button { width: 100%; } input[type="range"] { width: 100%; } .active-turn { flex-direction: column; align-items: flex-start; gap: 0.35rem; padding: 0.8rem; border-radius: 1rem; background: linear-gradient(135deg, color-mix(in srgb, var(--player-color) 22%, rgba(255, 255, 255, 0.04)), rgba(255, 255, 255, 0.04)); border: 1px solid color-mix(in srgb, var(--player-color) 35%, rgba(255, 255, 255, 0.08)); } .root-shift-row { display: flex; gap: 0.55rem; flex-wrap: wrap; } .root-shift-button { min-height: 2.2rem; } .button-row { gap: 0.75rem; } .button-row button, .ghost-button { min-height: 2.7rem; padding: 0.65rem 0.9rem; border-radius: 0.95rem; background: #f4f7fb; color: #0a1020; font-weight: 700; } .ghost-button, #finish-game { background: rgba(255, 255, 255, 0.08); color: #f4f7fb; border: 1px solid rgba(255, 255, 255, 0.1); } button:disabled { opacity: 0.45; cursor: not-allowed; } .log-list { display: grid; gap: 0.55rem; max-height: 30%; overflow: auto; } .log-list p, .status-panel p, .active-turn p { margin: 0; } .event-note { color: #ffd577; } @keyframes sunlight-drop { 0% { opacity: 0; top: -0.9rem; transform: scale(0.65); } 12% { opacity: 1; } 85% { opacity: 1; top: calc(var(--drop-end) - 0.55rem); transform: scale(1); } 100% { opacity: 0; top: calc(var(--drop-end) - 0.55rem); transform: scale(1.25); } } @keyframes pop-fade { 0% { opacity: 0; transform: scale(0.65); } 25% { opacity: 1; transform: scale(1); } 100% { opacity: 1; transform: scale(1); } } @keyframes energy-cell-flash { 0% { opacity: 0; } 20% { opacity: 0.98; } 100% { opacity: 0; } } @keyframes score-pop { 0% { transform: scale(0.88); color: #fff7d6; text-shadow: 0 0 0 rgba(255, 235, 153, 0); } 35% { transform: scale(1.18); color: #ffe480; text-shadow: 0 0 16px rgba(255, 228, 128, 0.9); } 100% { transform: scale(1); color: inherit; text-shadow: 0 0 0 rgba(255, 235, 153, 0); } } @media (max-width: 1100px) { .game-area { grid-template-columns: 1fr; } .modal-grid { grid-template-columns: 1fr; } .board { max-height: none; width: 100%; } } @media (max-width: 720px) { .layout { padding: 1rem; } .scoreboard { grid-template-columns: repeat(2, minmax(0, 1fr)); } .score-card__numbers { gap: 1rem; } .cell__node { width: 1rem; height: 1rem; } }