.app-shell{color:#2c3750;grid-template-rows:auto minmax(0,1fr);height:100vh;padding:14px;display:grid;overflow:hidden}.title-bar{grid-template-columns:minmax(0,.3fr) minmax(280px,.8fr);align-items:start;gap:14px;max-width:1480px;margin:0 auto 22px;padding:0 0 0 20px;display:grid}.eyebrow{letter-spacing:.18em;text-transform:uppercase;color:#ff7c67;margin:0 0 10px;font-size:.75rem;font-weight:700}.title-bar h1,.hud-card h2,.stage-overlay h2{letter-spacing:-.04em;margin:0;font-family:Avenir Next Condensed,Arial Narrow,sans-serif}.title-bar h1{font-size:clamp(2.4rem,4vw,4.8rem);line-height:.95}.lede{color:#5c6476;justify-self:end;margin:0;font-size:1rem}.game-layout{grid-template-columns:minmax(0,1.6fr) minmax(320px,.64fr);align-items:stretch;gap:18px;max-width:1480px;height:100%;min-height:0;margin:0 auto;display:grid}.stage-card{background:radial-gradient(circle at 0 0,#ffffffe0,#ffffff9e),linear-gradient(160deg,#ffefe3 0%,#f4efee 50%,#dddbe7 100%);border-radius:34px;height:100%;min-height:0;position:relative;overflow:hidden;box-shadow:0 30px 70px #7969762e,inset 0 1px #ffffffbf}.stage-card canvas{touch-action:none;width:100%;height:100%;display:block}.stage-overlay{z-index:2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffbf7c7;border-radius:22px;gap:8px;padding:14px 16px;display:grid;position:absolute;box-shadow:0 12px 40px #514e591f}.stage-overlay--compact{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;gap:6px;padding:10px 12px}.stage-overlay--compact p{font-size:.82rem;line-height:1.25}.stage-overlay--compact h2{font-size:1.5rem}.stage-overlay--compact .badge{border-radius:14px;width:52px;height:52px;font-size:1.5rem}.stage-overlay--compact .metric{min-width:72px}.stage-overlay--compact .metric span{font-size:.68rem}.stage-overlay--compact .metric strong{font-size:1.16rem}.top-left{grid-template-columns:auto 1fr;align-items:center;max-width:300px;top:20px;left:20px}.top-right{grid-template-columns:repeat(2,minmax(88px,auto));gap:12px;top:20px;right:20px}.bottom-left{max-width:390px;bottom:20px;left:20px}.bottom-right{max-width:360px;bottom:20px;right:20px}.badge{color:#fff8f3;background:linear-gradient(#ff8d78 0%,#ff7058 100%);border-radius:20px;place-items:center;width:66px;height:66px;font-size:2rem;font-weight:800;display:grid}.metric{gap:2px;min-width:90px;display:grid}.metric span{text-transform:uppercase;letter-spacing:.08em;color:#667085;font-size:.8rem}.metric strong{font-size:1.55rem}.hud-column{grid-template-rows:minmax(0,1.28fr) auto auto;gap:16px;min-height:0;display:grid}.hud-column--mobile-drawer{z-index:5;width:min(360px,100% - 28px);display:block;position:absolute;top:14px;right:14px}.hud-drawer{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffbf7d6;border-radius:18px;box-shadow:0 14px 32px #5a505f2e,inset 0 1px #ffffffc7}.hud-drawer__summary{cursor:pointer;text-transform:uppercase;letter-spacing:.08em;color:#3b4460;border-radius:18px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;font-size:.84rem;font-weight:700;list-style:none;display:flex}.hud-drawer__summary:focus-visible{outline-offset:2px;outline:3px solid #ff7c6747}.hud-drawer__summary::-webkit-details-marker{display:none}.hud-drawer__chevron{font-size:.95rem;transition:transform .16s}details[open] .hud-drawer__chevron{transform:rotate(180deg)}.hud-drawer__content{overscroll-behavior:contain;max-height:min(58dvh,420px);padding:0 10px 10px;overflow:auto}.hud-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffbf7d1;border-radius:28px;padding:22px;box-shadow:0 24px 48px #77666f1f,inset 0 1px #ffffffd9}.hud-card.highlight{background:linear-gradient(#ffffffeb,#fff1e9eb)}.hud-card p,.stage-overlay p,.hud-card blockquote{margin:0}.hud-card{gap:12px;display:grid}.hud-card--compact{border-radius:18px;gap:8px;padding:14px}.hud-card--compact h2{font-size:1.52rem}.hud-card--compact .eyebrow{letter-spacing:.12em;margin:0 0 4px;font-size:.62rem}.hud-card--compact .artifact-lead,.hud-card--compact .artifact-summary-copy{font-size:.86rem;line-height:1.3}.hud-card--compact blockquote{border-radius:14px;padding:10px 12px;font-size:.78rem}.hud-card--compact .artifact-list{gap:8px;min-height:0}.hud-card--compact .artifact-list li{border-radius:12px;min-height:44px;padding:9px 10px}.hud-card--compact .status-note{padding:8px 10px;font-size:.8rem}.artifact-card{grid-template-rows:auto minmax(0,1fr) auto;min-height:0;overflow:hidden}.artifact-card-body{grid-auto-rows:min-content;align-content:start;gap:8px;min-height:0;display:grid;overflow:hidden;-webkit-mask-image:linear-gradient(#000 0% 82%,#0000 100%);mask-image:linear-gradient(#000 0% 82%,#0000 100%)}.artifact-card-body h2,.artifact-card-body blockquote,.artifact-list li span,.empty-row{-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.artifact-card-body h2{-webkit-line-clamp:2}.artifact-lead{color:#545e72;font-size:.98rem;line-height:1.42}.artifact-summary-copy{color:#34405c;font-size:.98rem;font-weight:500;line-height:1.38}.hud-card blockquote{color:#4f5668;-webkit-line-clamp:3;background:#ffffffb3;border-radius:18px;padding:12px 14px;font-size:.88rem;line-height:1.4}.found-card{min-height:284px}.artifact-list{align-content:start;gap:10px;min-height:194px;margin:0;padding:0;list-style:none;display:grid}.artifact-list li{background:#f4f7ffcc;border-radius:16px;justify-content:space-between;align-items:center;gap:14px;min-height:58px;padding:12px 14px;display:flex}.artifact-summary{background:#ffefe3e6}.welcome-page{background:radial-gradient(circle at 18% 22%,#ffffffe6,#0000 38%),radial-gradient(circle at 86% 18%,#ffe1d29e,#0000 28%),linear-gradient(145deg,#f8f2ed 0%,#f1ecee 48%,#e9e4ef 100%);place-items:center;min-height:100vh;padding:24px;display:grid;overflow:hidden}.welcome-screen{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffbf7cc;border-radius:34px;place-self:center;gap:16px;width:min(100%,580px);padding:clamp(24px,3vw,36px);display:grid;box-shadow:0 24px 48px #77666f24,inset 0 1px #ffffffe6}.welcome-screen h1{letter-spacing:-.04em;margin:0;font-family:Avenir Next Condensed,Arial Narrow,sans-serif;font-size:clamp(2.2rem,4vw,4rem);line-height:.95}.welcome-screen__lede{color:#4f5668;margin:0;line-height:1.5}.welcome-screen__note{color:#42506a;background:#ffffffb8;border-radius:18px;margin:0;padding:12px 14px;font-weight:600;line-height:1.45;box-shadow:inset 0 1px #ffffffd1}.welcome-screen__actions{flex-wrap:wrap;gap:12px;display:flex}.welcome-screen__button{font:inherit;color:#fff8f3;cursor:pointer;background:linear-gradient(#ff8d78 0%,#ff7058 100%);border:0;border-radius:999px;padding:14px 24px;font-weight:700;transition:transform .14s,box-shadow .14s,background .14s,color .14s,border-color .14s;box-shadow:0 14px 28px #ff765a3d,inset 0 1px #fff3}.welcome-screen__button:hover{transform:translateY(-1px)}.welcome-screen__button:focus-visible{outline-offset:3px;outline:3px solid #ff7c6742}.welcome-screen__button--secondary{color:#34405c;background:#ffffffeb;box-shadow:0 12px 24px #5960781f,inset 0 0 0 1px #5e667e29}.mobile-orientation-lock{background:radial-gradient(circle at 24% 16%,#ffffffdb,#0000 38%),radial-gradient(circle at 80% 82%,#ffceb770,#0000 32%),linear-gradient(145deg,#f6efea 0%,#efe8eb 50%,#e4e2ee 100%);place-items:center;min-height:100dvh;padding:20px;display:grid}.mobile-orientation-lock__card{background:#fffbf7d6;border-radius:28px;gap:12px;width:min(100%,420px);padding:24px;display:grid;box-shadow:0 20px 40px #6c607226,inset 0 1px #ffffffe6}.mobile-orientation-lock__card h1{letter-spacing:-.04em;margin:0;font-family:Avenir Next Condensed,Arial Narrow,sans-serif;font-size:clamp(2rem,8vw,3rem);line-height:.95}.mobile-orientation-lock__card p{color:#4e586d;margin:0;line-height:1.45}.artifact-list li span,.empty-row{-webkit-line-clamp:2}.artifact-list strong{color:#ff775f;flex-shrink:0}.empty-row{color:#6d7385}.status-note{color:#6a5560;background:#fac9ac3d;border-radius:16px;padding:12px 14px}.status-note-complete{color:#1f5f4a;background:#8fecd24d}.prompt-overlay{align-content:start;min-height:164px;transition:left .18s,right .18s,opacity .18s}.prompt-overlay--compact{min-height:0}.touch-controls{inset-inline:20px;z-index:3;pointer-events:none;justify-content:space-between;align-items:end;display:none;position:absolute;bottom:22px}.touch-controls--compact{inset-inline:14px;bottom:12px}.dpad{pointer-events:auto;grid-template-rows:repeat(3,56px);grid-template-columns:repeat(3,56px);gap:8px;display:grid}.touch-controls--compact .dpad{grid-template-rows:repeat(3,48px);grid-template-columns:repeat(3,48px);gap:6px}.control-button{color:#384057;-webkit-user-select:none;user-select:none;touch-action:manipulation;background:#fffbf7d6;border:none;border-radius:20px;font-size:1.2rem;box-shadow:0 12px 28px #60535f29}.control-button--compact{border-radius:16px;font-size:1rem}.control-button.action.control-button--compact{width:62px;height:62px;font-size:1.22rem}.control-button:active{transform:scale(.97)}.control-button.up{grid-area:1/2}.control-button.left{grid-area:2/1}.control-button.right{grid-area:2/3}.control-button.down{grid-area:3/2}.control-button.action{pointer-events:auto;border-radius:999px;width:74px;height:74px;font-size:1.4rem}@media (width<=1100px){.app-shell{height:auto;min-height:100vh;padding:18px;overflow:visible}.title-bar,.game-layout{grid-template-columns:1fr}.game-layout{height:auto}.hud-column{grid-template-rows:none}.lede{justify-self:start}.welcome-screen{width:min(100%,640px)}}@media (width<=760px){.app-shell{padding:12px}.stage-card{border-radius:26px;height:auto;min-height:620px}.stage-card canvas{height:620px;min-height:620px}.top-right,.top-left,.bottom-left,.bottom-right{max-width:none}.top-left,.top-right{inset-inline:14px}.top-right{grid-template-columns:repeat(2,1fr);top:112px;left:14px;right:14px}.artifact-card,.found-card,.artifact-list{min-height:auto}.welcome-screen{padding:22px}.welcome-screen__actions{flex-direction:column;align-items:stretch}.welcome-screen__button{width:100%}.welcome-page{padding:16px;overflow:auto}.bottom-left{bottom:116px;left:14px;right:14px}.touch-controls{display:flex}}@media (width<=900px) and (orientation:landscape){.app-shell--mobile-landscape{min-height:100dvh;padding:10px}.app-shell--mobile-landscape .title-bar{gap:8px;margin:0 auto 10px;padding:0 0 0 8px}.app-shell--mobile-landscape .eyebrow{margin:0;font-size:.65rem}.app-shell--mobile-landscape .lede{font-size:.88rem;line-height:1.35}.app-shell--mobile-landscape .game-layout{grid-template-columns:minmax(0,1fr);gap:0;position:relative}.app-shell--mobile-landscape .touch-controls{display:flex}.app-shell--mobile-landscape .stage-card{border-radius:22px}.app-shell--mobile-landscape .top-left{max-width:240px;top:10px;left:10px}.app-shell--mobile-landscape .top-right{grid-template-columns:repeat(2,minmax(72px,auto));gap:8px;top:10px;right:10px}.app-shell--mobile-landscape .bottom-left{max-width:min(300px,100% - 22px);bottom:96px;left:10px;right:auto}.app-shell--mobile-landscape .bottom-right{max-width:min(268px,100% - 22px);bottom:96px;right:10px}.app-shell--mobile-landscape .prompt-overlay--compact p:last-child{opacity:.86}}:root{color:#263044;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at top,#fffaf6 0%,#f6efe8 36%,#ddd6d9 100%);font-family:Avenir Next,Trebuchet MS,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#root{height:100%}body{min-width:320px;margin:0}button,input,textarea,select{font:inherit}button{cursor:pointer}a{color:inherit}
