:root{--charcoal: #2C2A25;--ivory: #F5F2EE;--tan: #D6CFC7;--tan-100: #FBFAF6;--tan-300: #ECE7E1;--surface: #3A3832;--surface-2: #4A4744;--ink-soft: #C9C5BD;--ink-mute: #8A8580;--teal: #274249;--danger: #C95A5A;--win: #5BA467;--radius: 12px;--game-w: min(960px, 94vw, calc((100vh - 300px)*1.6) )}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--charcoal);color:var(--ivory);font-family:Inter,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:17px;line-height:1.45;overflow:hidden;height:100vh}h1,h2,h3{font-family:FH Oscar Pro,Inter,sans-serif;font-weight:600;letter-spacing:-.01em;margin:0}body{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:20px}#canvas-wrap{position:relative;width:var(--game-w);aspect-ratio:960 / 600}canvas{background:var(--surface);border:1px solid var(--surface-2);border-radius:var(--radius);display:block;width:100%;height:100%}#banner{position:absolute;top:50%;left:50%;transform:translate(-50%,-60%) scale(.97);background:#2c2a25c7;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(245,242,238,.12);color:var(--ivory);padding:28px 56px;border-radius:16px;font-family:FH Oscar Pro,Inter,sans-serif;font-weight:700;font-size:36px;letter-spacing:-.025em;line-height:1.05;text-align:center;opacity:0;pointer-events:none;white-space:nowrap;transition:opacity .22s ease,transform .22s cubic-bezier(.2,.7,.2,1)}#banner.show{opacity:1;transform:translate(-50%,-50%) scale(1)}#banner .banner-eyebrow{display:block;font-family:Inter,sans-serif;font-weight:500;font-size:14px;color:var(--ink-soft);margin-bottom:8px;letter-spacing:0}.boss-defeated-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:var(--surface);border:1px solid rgba(245,242,238,.1);border-radius:20px;padding:56px 88px;text-align:center;animation:boss-defeated-in .32s cubic-bezier(.2,.7,.2,1) both}.boss-defeated-eyebrow{font-family:Inter,sans-serif;font-weight:500;font-size:15px;color:var(--ink-mute);letter-spacing:0}.boss-defeated-name{margin:0;font-family:FH Oscar Pro,Inter,sans-serif;font-weight:700;font-size:64px;letter-spacing:-.025em;color:var(--ivory);line-height:1.05}@keyframes boss-defeated-in{0%{opacity:0;transform:translateY(8px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}#hud{width:var(--game-w);display:grid;grid-template-columns:1fr 1fr 1fr;align-items:stretch;font-family:Inter,sans-serif;font-size:17px;gap:10px}.hud-card{background:var(--surface);border:1px solid var(--surface-2);border-radius:var(--radius);padding:12px 14px;display:flex;flex-direction:column;gap:8px;min-width:0}.hud-card-title{font-family:FH Oscar Pro,Inter,sans-serif;font-size:18px;font-weight:600;color:var(--ivory);letter-spacing:-.01em;display:flex;justify-content:space-between;align-items:baseline;width:100%}.stat-block{display:flex;flex-direction:column;gap:6px}.stat-head{display:flex;justify-content:space-between;align-items:baseline}.stat-name{font-family:Inter,sans-serif;font-size:14px;font-weight:500;color:var(--ivory);letter-spacing:-.005em}.stat-value{font-family:Inter,sans-serif;font-size:14px;font-weight:600;color:var(--ivory);font-variant-numeric:tabular-nums}.stat-value.low{color:var(--danger)}.tier-dots{display:flex;gap:4px;width:100%;height:12px}.tier-dot{flex:1;border-radius:999px;background:#f5f2ee14;border:1px solid rgba(245,242,238,.1);transition:background .2s ease,border-color .2s ease}.tier-dot.done,.tier-dot.active{background:var(--ivory);border-color:var(--ivory)}.tier-name{font-family:FH Oscar Pro,Inter,sans-serif;font-size:22px;font-weight:700;letter-spacing:-.015em;color:var(--ivory);line-height:1.1;margin-top:auto}.tools-count{font-family:Inter,sans-serif;font-size:14px;font-weight:600;color:var(--ivory);font-variant-numeric:tabular-nums;letter-spacing:-.005em}.tools-grid{display:flex;flex-wrap:wrap;gap:5px;justify-content:flex-start}#powered-by{display:flex;align-items:center;gap:12px;margin-top:14px;font-family:Inter,sans-serif;font-size:15px;color:var(--ink-soft)}#powered-by a{display:inline-flex;align-items:center;line-height:0;transition:opacity .12s ease}#powered-by a:hover{opacity:.7}#powered-by img{display:block;height:26px;width:auto;filter:invert(1)}#overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:#2c2a25eb}#overlay.fullbleed,#overlay.inverse{background:var(--charcoal)}#overlay.active{display:flex}.panel{background:var(--surface);border:1px solid var(--surface-2);border-radius:var(--radius);padding:28px 32px;max-width:720px;width:90%;max-height:92vh;overflow-y:auto;display:flex;flex-direction:column;gap:16px;align-items:center}.panel h1{font-size:40px;color:var(--ivory)}.panel h2{font-size:30px;color:var(--ivory)}.tool-option{background:var(--charcoal);border:1px solid var(--surface-2);border-radius:var(--radius);padding:14px 18px;width:100%;cursor:pointer;text-align:left;font-family:Inter,sans-serif;font-size:17px;color:var(--ivory)}.tool-option:hover{border-color:var(--ivory)}.tool-option-head{display:flex;align-items:center;gap:9px;margin-bottom:5px}.tool-option .tool-mark{height:18px;width:auto;display:block;filter:invert(1)}.tool-option .name{font-family:FH Oscar Pro,sans-serif;font-weight:600;font-size:18px;line-height:1.2;color:var(--ivory)}.tool-option .desc{color:var(--ink-soft);font-size:14px;line-height:1.35}button.primary{background:var(--ivory);color:var(--charcoal);border:none;border-radius:var(--radius);padding:14px 28px;font-family:Inter,sans-serif;font-size:17px;font-weight:600;cursor:pointer}button.ghost{background:transparent;color:var(--ivory);border:1px solid var(--ivory);border-radius:var(--radius);padding:14px 28px;font-size:17px;cursor:pointer}.hp-bar{width:100%;height:12px;border:1px solid rgba(245,242,238,.18);border-radius:999px;overflow:hidden;background:#f5f2ee0f}.hp-bar .fill{height:100%;background:var(--ivory);transition:width .12s linear,background .12s ease}.hp-bar.low{border-color:var(--danger)}.hp-bar.low .fill{background:var(--danger)}.token-bar,.xp-bar{width:100%;height:12px;border:1px solid rgba(156,178,135,.25);border-radius:999px;overflow:hidden;background:#9cb2871a}.token-bar .fill,.xp-bar .fill{height:100%;background:#e5c45a;transition:width .12s linear}.stat-sub{font-family:Inter,sans-serif;font-weight:400;font-size:11px;color:var(--ink-mute);letter-spacing:-.005em;margin-left:2px}.tool-slot{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--ivory);color:var(--ivory);border-radius:999px;padding:5px 12px;font-size:12px;font-family:Inter,sans-serif;font-weight:500;cursor:default;letter-spacing:-.005em;line-height:1.2;white-space:nowrap}.tool-slot.branded{background:var(--ivory);color:var(--charcoal);border-color:var(--ivory)}.tool-slot .slot-mark{height:12px;width:auto;display:block}.tool-slot.branded .slot-mark{filter:invert(1)}.start-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;width:100vw;height:100vh;padding:40px;position:relative}.start-lockup{position:absolute;top:32px;left:50%;transform:translate(-50%)}.start-lockup img{height:28px;width:auto;display:block;filter:invert(1);opacity:.55}.start-stack{display:flex;flex-direction:column;align-items:center;gap:16px;position:relative;z-index:2}.start-title,.start-subtitle{font-family:FH Oscar Pro,Inter,sans-serif;font-size:clamp(40px,5.6vw,84px);font-weight:700;letter-spacing:-.035em;line-height:1;color:var(--ivory);margin:0;text-align:center;white-space:nowrap}.start-cta{font-size:22px!important;padding:18px 56px!important;letter-spacing:.01em;font-weight:600;position:relative;z-index:2;margin-top:32px;animation:cta-pulse 2.4s ease-in-out infinite}@keyframes cta-pulse{0%,to{transform:scale(1);box-shadow:0 0 #f5f2ee40}50%{transform:scale(1.03);box-shadow:0 0 0 10px #f5f2ee00}}.ambient-field{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}.ambient-dot{position:absolute;background:#e5c45a;border-radius:50%;opacity:.45;animation:ambient-drift var(--drift-dur, 25s) linear infinite var(--drift-delay, 0s),ambient-flip var(--flip-dur, 2.5s) ease-in-out infinite var(--flip-delay, 0s)}.ambient-dot:after{content:"";position:absolute;inset:28%;border:1.5px solid var(--ivory);border-radius:50%;box-sizing:border-box}@keyframes ambient-flip{0%,to{scale:1 1}50%{scale:-1 1}}@keyframes ambient-drift{0%{translate:0 0}25%{translate:40px -30px}50%{translate:80px 20px}75%{translate:20px 50px}to{translate:0 0}}.start-lockup,.start-footnote{position:absolute;z-index:2}.rules-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100vw;height:100vh;padding:40px;position:relative;color:var(--ivory)}.rules-stack{display:flex;flex-direction:column;align-items:center;gap:28px;max-width:640px;width:100%}.rules-title{font-family:FH Oscar Pro,Inter,sans-serif;font-size:clamp(40px,5.6vw,72px);font-weight:700;letter-spacing:-.03em;line-height:1;margin:0;text-align:center}.rules-list{display:flex;flex-direction:column;gap:14px;width:100%;font-family:Inter,sans-serif;font-size:18px;line-height:1.4}.rules-row{display:grid;grid-template-columns:130px 1fr;gap:18px;align-items:baseline}.rules-label{font-family:FH Oscar Pro,Inter,sans-serif;font-weight:600;color:var(--ivory);letter-spacing:-.005em}.rules-text{color:var(--ink-soft)}.rules-cta{font-size:18px!important;padding:14px 36px!important;font-weight:600;margin-top:12px}.start-footnote{position:absolute;bottom:48px;font-family:Inter,sans-serif;font-size:20px;color:var(--ink-mute)}.start-rules{position:absolute;bottom:28px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:4px;text-align:center;font-family:Inter,sans-serif;font-size:15px;color:var(--ink-soft);max-width:720px;line-height:1.45}.lose-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;width:100vw;height:100vh;padding:60px 40px;color:var(--ivory);position:relative;text-align:center}.lose-title{font-family:FH Oscar Pro,Inter,sans-serif;font-size:clamp(72px,10vw,160px);font-weight:700;letter-spacing:-.035em;line-height:1;margin:0;color:var(--ivory)}.lose-narrative{font-family:FH Oscar Pro,Inter,sans-serif;font-size:clamp(24px,2.4vw,36px);font-weight:400;color:var(--ivory);margin:0;max-width:900px;line-height:1.3}.lose-narrative strong{font-weight:700}.lose-loadout-line{font-family:Inter,sans-serif;font-size:clamp(18px,1.6vw,24px);font-weight:400;color:var(--ink-soft);margin:0;max-width:900px;line-height:1.4}.lose-cta-row{display:flex;gap:20px;align-items:center;margin-top:12px;flex-wrap:wrap;justify-content:center}.lose-retry{background:var(--ivory);color:var(--charcoal);border:none;border-radius:var(--radius);padding:22px 56px;font-family:Inter,sans-serif;font-size:24px;font-weight:600;cursor:pointer}.lose-merge{display:inline-flex;align-items:center;gap:12px;color:var(--ivory);text-decoration:none;font-family:Inter,sans-serif;font-size:22px;font-weight:500;padding:22px 36px;border:1px solid var(--ivory);border-radius:var(--radius);transition:opacity .12s ease}.lose-merge:hover{opacity:.8}.lose-merge img{height:20px;width:auto}.lose-closer{font-family:Inter,sans-serif;font-size:18px;color:var(--ink-mute);margin:0}.endgame{width:100vw;height:100vh;display:grid;grid-template-rows:auto 1fr auto;padding:48px 56px;box-sizing:border-box;color:var(--ivory);position:relative}.endgame-lockup img{height:30px;width:auto;display:block;filter:invert(1);opacity:.92}.endgame-center{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.endgame-title{font-family:FH Oscar Pro,Inter,sans-serif;font-size:clamp(60px,7.5vw,104px);font-weight:700;letter-spacing:-.035em;line-height:.98;margin:0;color:var(--ivory)}.endgame-joke{font-family:Inter,sans-serif;font-size:clamp(26px,2.6vw,36px);font-weight:400;color:var(--ink-soft);letter-spacing:-.015em;line-height:1.3;margin:24px 0 0;max-width:640px}.endgame-footnote{font-family:Inter,sans-serif;font-size:20px;font-weight:500;color:var(--ink-mute);font-variant-numeric:tabular-nums;letter-spacing:-.005em;margin:18px 0 0}.endgame-stat{font-family:Inter,sans-serif;font-size:clamp(26px,2.6vw,36px);font-weight:400;color:var(--ink-soft);letter-spacing:-.015em;margin:24px 0 0}.endgame-actions{display:flex;flex-direction:column;align-items:center;gap:18px}.endgame-buttons{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center}.endgame-primary{background:var(--ivory);color:var(--charcoal);border:1px solid var(--ivory);border-radius:12px;padding:16px 36px;font-family:Inter,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.005em;cursor:pointer;transition:opacity .12s ease}.endgame-primary:hover{opacity:.88}.endgame-primary-link{display:inline-flex;align-items:center;gap:10px;text-decoration:none}.endgame-primary-link img{height:15px;width:auto;display:block}.endgame-share-group{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:18px}.endgame-share-group .endgame-share{margin-top:0}.endgame-offer{margin:0;max-width:680px;font-family:Inter,sans-serif;font-size:14px;font-weight:500;color:var(--ink-mute);text-align:center;letter-spacing:-.005em;line-height:1.45}.endgame-offer a{color:var(--ivory);text-decoration:underline;text-decoration-color:#f5f2ee59;text-underline-offset:2px}.endgame-offer a:hover{text-decoration-color:var(--ivory)}.endgame-secondary{display:inline-flex;align-items:center;gap:10px;background:transparent;color:var(--ivory);border:1px solid rgba(245,242,238,.22);border-radius:12px;padding:16px 30px;font-family:Inter,sans-serif;font-size:18px;font-weight:500;letter-spacing:-.005em;cursor:pointer;text-decoration:none;transition:border-color .12s ease}.endgame-secondary:hover{border-color:#f5f2ee73}.endgame-secondary img{height:15px;width:auto;display:block}.endgame-link-button{background:transparent;border:none;font-family:Inter,sans-serif;font-size:17px;font-weight:500;color:var(--ink-mute);cursor:pointer;padding:6px 10px;letter-spacing:-.005em;transition:color .12s ease}.endgame-link-button:hover{color:var(--ivory)}.endgame-link{font-family:Inter,sans-serif;font-size:17px;font-weight:500;color:var(--ink-mute);text-decoration:none;letter-spacing:-.005em;transition:color .12s ease}.endgame-link:hover{color:var(--ivory)}.endgame-share{display:flex;align-items:center;gap:10px;margin-top:18px;color:var(--ink-mute)}.endgame-share-label{font-family:Inter,sans-serif;font-size:13px;font-weight:500;letter-spacing:-.005em}.endgame-share-btn{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid rgba(245,242,238,.22);color:var(--ink-mute);border-radius:999px;width:32px;height:32px;padding:0;cursor:pointer;transition:border-color .12s ease,color .12s ease}.endgame-share-btn:hover{border-color:#f5f2ee73;color:var(--ivory)}.endgame-share-btn svg{display:block}.win-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;width:100vw;height:100vh;padding:60px 40px;color:var(--ivory);position:relative;text-align:center}.win-title{font-family:FH Oscar Pro,Inter,sans-serif;font-size:clamp(72px,10vw,160px);font-weight:700;letter-spacing:-.035em;line-height:1;margin:0;color:var(--ivory)}.win-narrative{font-family:FH Oscar Pro,Inter,sans-serif;font-size:clamp(24px,2.4vw,36px);font-weight:400;color:var(--ivory);margin:0;max-width:900px;line-height:1.3}.win-narrative strong{font-weight:700}.win-loadout-line{font-family:Inter,sans-serif;font-size:clamp(18px,1.6vw,24px);font-weight:400;color:var(--ink-soft);margin:0;max-width:900px;line-height:1.4}.win-cta-row{display:flex;gap:16px;align-items:center;margin-top:12px;flex-wrap:wrap;justify-content:center}.win-share-x{background:var(--ivory);color:var(--charcoal);border:none;border-radius:var(--radius);padding:22px 56px;font-family:Inter,sans-serif;font-size:24px;font-weight:600;cursor:pointer}.win-share-li,.win-retry{background:transparent;color:var(--ivory);border:1px solid var(--ivory);border-radius:var(--radius);padding:22px 36px;font-family:Inter,sans-serif;font-size:20px;font-weight:500;cursor:pointer}.win-closer{font-family:Inter,sans-serif;font-size:18px;color:var(--ink-mute);margin:0}.merge-flash{position:fixed;inset:0;background:var(--ivory);pointer-events:none;z-index:100;animation:merge-flash .6s ease-out forwards}@keyframes merge-flash{0%{opacity:0}15%{opacity:.6}to{opacity:0}}@keyframes canvas-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px,4px)}40%{transform:translate(5px,-5px)}60%{transform:translate(-3px,-3px)}80%{transform:translate(4px,2px)}}canvas.shake{animation:canvas-shake .45s ease-out}
