@font-face{font-family:BitPotionExt;src:url(/font/BitPotionExt.ttf) format("truetype");font-weight:400;font-style:normal;font-display:block}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;font-family:BitPotionExt,monospace;color:#2c3e50;font-size:18px}body{background-color:#f0f4f8}#game-container{position:absolute;top:0;left:280px;right:280px;height:100%;z-index:0}#game-container canvas{cursor:url(/assets/ui/cursor_default.png) 1 1,auto;background:#e8edf2}#ui-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;pointer-events:none}#ui-overlay>*{pointer-events:auto}#ui-overlay>.tile-tooltip{pointer-events:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInLeft{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInRight{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes alertPulse{0%{transform:translate(-50%) scale(.9);opacity:0}to{transform:translate(-50%) scale(1);opacity:1}}@keyframes dangerPulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes idle-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulsingDots{0%,80%,to{opacity:.3}40%{opacity:1}}@keyframes roundFadeIn{0%{opacity:0;transform:scale(.8)}60%{opacity:1;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes tutorialFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes reactionSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.left-sidebar{position:fixed;top:0;left:0;width:280px;height:100vh;background:linear-gradient(180deg,#fff,#f8fafc);border-right:1px solid #e2e8f0;z-index:20;display:flex;flex-direction:column;overflow:hidden;box-shadow:2px 0 12px #0000000f;animation:slideInLeft .4s ease}.right-sidebar{position:fixed;top:0;right:0;width:280px;height:100vh;background:linear-gradient(180deg,#fff,#f8fafc);border-left:1px solid #e2e8f0;z-index:20;display:flex;flex-direction:column;overflow:hidden;box-shadow:-2px 0 12px #0000000f;animation:slideInRight .4s ease}.panel-header{font-size:1.6rem;letter-spacing:3px;text-transform:uppercase;color:#1a365d;text-align:center;padding:18px 12px 12px;border-bottom:2px solid #e2e8f0;background:linear-gradient(135deg,#ebf4ff,#f0f4f8);flex-shrink:0}.sidebar-divider{height:1px;background:linear-gradient(90deg,transparent,#cbd5e0,transparent);margin:8px 16px;flex-shrink:0}.resource-panel{padding:16px 18px;color:#2c3e50;flex-shrink:0}.resource-panel .round-info{font-size:2rem;letter-spacing:2px;color:#1a365d;text-align:center;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid #e2e8f0}.resource-panel .resources{display:flex;flex-direction:column;gap:14px;margin-bottom:14px}.resource-bar{display:flex;align-items:center;gap:8px;transition:transform .2s ease}.resource-bar:hover{transform:scale(1.02)}.bar-icon{font-size:1.4rem;flex-shrink:0;width:24px;text-align:center}.resource-bar .bar-label{font-size:1.4rem;min-width:80px;color:#4a5568;font-weight:700}.resource-bar .bar-track{flex:1;height:16px;background:#e2e8f0;border:1px solid #cbd5e0;border-radius:8px;overflow:hidden}.resource-bar .bar-fill{height:100%;border-radius:8px;transition:width .6s ease}.resource-bar .bar-value{font-size:1.5rem;min-width:36px;text-align:right;color:#1a365d;font-weight:700}.resource-bar.ecology .bar-fill{background:linear-gradient(90deg,#48bb78,#38a169)}.resource-bar.economy .bar-fill{background:linear-gradient(90deg,#ecc94b,#d69e2e)}.resource-bar.research .bar-fill{background:linear-gradient(90deg,#4299e1,#3182ce)}.resource-bar.danger .bar-fill{background:linear-gradient(90deg,#fc8181,#e53e3e)!important;animation:dangerPulse 1s ease infinite}.resource-bar.warning .bar-fill{opacity:.8}.resource-panel .actions-info{font-size:1.5rem;color:#4a5568;text-align:center;padding:8px 0}.tech-section{padding:4px 0}.tech-header{font-size:1.1rem;color:#2b6cb0;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;text-align:center}.tech-tree{display:flex;align-items:center;gap:6px}.tech-track{flex:1;height:12px;background:#e2e8f0;border:1px solid #cbd5e0;border-radius:6px;position:relative;overflow:visible}.tech-fill{height:100%;background:linear-gradient(90deg,#805ad5,#9f7aea);border-radius:6px;transition:width .6s}.tech-marker{position:absolute;top:-4px;width:20px;height:20px;transform:translate(-50%)}.tech-icon{display:inline-flex;width:20px;height:20px;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;border-radius:50%;background:#e2e8f0;color:#a0aec0;border:2px solid #cbd5e0;font-family:BitPotionExt,monospace}.tech-marker.unlocked .tech-icon{background:#9f7aea;color:#fff;border-color:#805ad5;box-shadow:0 0 8px #9f7aea80}.tech-icon.solar{background:#f6e05e;color:#744210;border-color:#ecc94b}.tech-icon.fusion{background:#90cdf4;color:#2a4365;border-color:#63b3ed}.tech-marker.unlocked .tech-icon.solar{box-shadow:0 0 8px #ecc94b99}.tech-marker.unlocked .tech-icon.fusion{box-shadow:0 0 8px #63b3ed99}.tech-legend{display:flex;gap:12px;margin-top:8px;font-size:.95rem;color:#718096;justify-content:center}.tech-legend-item{display:flex;align-items:center;gap:4px}.promise-panel{padding:0 18px 14px;color:#2c3e50;flex:1;overflow-y:auto;display:none}.promise-panel.visible{display:block}.promise-panel h3{font-size:1.5rem;color:#1a365d;letter-spacing:2px;text-transform:uppercase;padding:12px 0 8px;border-bottom:1px solid #e2e8f0;margin-bottom:10px}.promise-item{font-size:1.2rem;padding:10px 12px;margin-bottom:6px;border-left:4px solid #cbd5e0;border-radius:0 8px 8px 0;background:#f7fafc;transition:background .2s ease}.promise-item.active{border-color:#ecc94b;color:#744210;background:ivory}.promise-item.kept{border-color:#48bb78;color:#22543d;background:#f0fff4}.promise-item.broken{border-color:#fc8181;color:#9b2c2c;font-style:italic;text-decoration:line-through;opacity:.7;background:#fff5f5}.citizen-panel{padding:0;color:#2c3e50;flex:1;overflow-y:auto}.citizen-panel .panel-header{position:sticky;top:0;z-index:1}.citizen-list{padding:10px 14px;display:flex;flex-direction:column;gap:10px}.citizen-entry{display:flex;align-items:flex-start;gap:10px;padding:12px;background:#fff;border-radius:12px;border:1px solid #e2e8f0;transition:all .2s ease;box-shadow:0 1px 3px #0000000a}.citizen-entry:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.citizen-entry.critical{border-color:#fc8181;background:#fff5f5}.citizen-avatar{width:52px;height:52px;image-rendering:pixelated;border-radius:10px;border:2px solid #e2e8f0;flex-shrink:0;animation:idle-bounce 2s infinite ease-in-out}.citizen-avatar.reacting{animation:none}.citizen-avatar.positive{border-color:#48bb78;box-shadow:0 0 8px #48bb784d}.citizen-avatar.negative{border-color:#fc8181;box-shadow:0 0 8px #fc81814d}.citizen-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.citizen-header{display:flex;justify-content:space-between;align-items:center}.citizen-name{font-size:1.4rem;color:#1a365d;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.citizen-profession{font-size:1rem;color:#718096;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.citizen-bar-track{width:100%;height:10px;background:#e2e8f0;border:1px solid #cbd5e0;border-radius:5px;overflow:hidden;margin-top:2px}.citizen-bar-fill{height:100%;border-radius:5px;transition:width .6s}.citizen-value{font-size:1.4rem;min-width:40px;text-align:right;font-weight:700;flex-shrink:0}.citizen-personality{font-size:.95rem;color:#718096;font-style:italic;line-height:1.3;margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.speech-panel{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:100;animation:fadeIn .3s ease}.speech-panel.visible{display:flex}.speech-modal{width:min(680px,92vw);max-height:90vh;overflow-y:auto;background:#fff;border:2px solid #3182ce;border-radius:16px;padding:32px 40px;box-shadow:0 20px 60px #00000026,0 0 30px #3182ce1a;color:#2c3e50;animation:slideUp .4s ease}.speech-modal h3{font-size:2rem;margin-bottom:20px;letter-spacing:2px;color:#1a365d;text-align:center}.speech-modal textarea{width:100%;height:140px;background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;color:#2c3e50;font-family:BitPotionExt,monospace;font-size:1.4rem;padding:16px;resize:none;outline:none;line-height:1.5;transition:border-color .3s ease,box-shadow .3s ease}.speech-modal textarea:focus{border-color:#3182ce;box-shadow:0 0 12px #3182ce26}.speech-modal textarea::placeholder{color:#a0aec0;font-style:italic}.speech-context,.speech-context-bar{font-size:1.1rem;color:#4a5568;margin-bottom:16px;padding:14px;border:1px solid #e2e8f0;border-radius:10px;background:#f7fafc;line-height:1.8}.speech-charcount{font-size:1rem;color:#a0aec0;text-align:right;margin-top:6px}.speech-charcount.warn{color:#d69e2e}.speech-charcount.over{color:#e53e3e;font-weight:700}.speech-error{display:flex;align-items:center;gap:12px;margin-top:12px;padding:10px 14px;background:#fff5f5;border:1px solid #fc8181;border-radius:8px;color:#9b2c2c;font-size:1.1rem}.speech-error-msg{flex:1}.speech-retry{font-size:1.1rem;padding:6px 16px}.speech-modal .speech-submit.success{background:linear-gradient(135deg,#48bb78,#38a169);border-color:#38a169;box-shadow:0 0 16px #48bb784d}.speech-modal .speech-actions,.speech-actions{display:flex;gap:16px;margin-top:20px;justify-content:center}.speech-modal .speech-submit,.speech-submit{font-size:1.5rem;padding:16px 52px;background:linear-gradient(135deg,#3182ce,#2b6cb0);border:2px solid #2b6cb0;border-radius:12px;color:#fff;letter-spacing:2px;transition:all .3s ease;font-family:BitPotionExt,monospace;cursor:pointer}.speech-modal .speech-submit:hover:not(:disabled){background:linear-gradient(135deg,#2b6cb0,#2c5282);box-shadow:0 4px 20px #3182ce4d;transform:translateY(-2px)}.speech-modal .speech-submit:disabled{opacity:.5;cursor:wait}.speech-modal .end-round{font-size:1.3rem;padding:14px 36px;background:#fff;border:2px solid #d69e2e;border-radius:12px;color:#744210;font-family:BitPotionExt,monospace;cursor:pointer}.speech-modal .end-round:hover:not(:disabled){background:#d69e2e;color:#fff}.loading-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(0,0,0,.1);border-top-color:#3182ce;border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle;margin-right:6px}.pulsing-dots:after{content:"...";animation:pulsingDots 1.4s infinite}.pixel-btn{font-family:BitPotionExt,monospace;font-size:1.2rem;padding:10px 24px;border:2px solid #3182ce;border-radius:10px;background:#ebf8ff;color:#2b6cb0;cursor:pointer;text-transform:uppercase;transition:all .2s ease}.pixel-btn:hover:not(:disabled){background:#3182ce;color:#fff;box-shadow:0 4px 12px #3182ce4d;transform:translateY(-1px)}.pixel-btn:active{transform:translate(1px,1px)}.pixel-btn.warning{border-color:#d69e2e;background:ivory;color:#744210}.pixel-btn.warning:hover:not(:disabled){background:#d69e2e;color:#fff}.pixel-btn.danger{border-color:#e53e3e;background:#fff5f5;color:#9b2c2c}.pixel-btn.danger:hover:not(:disabled){background:#e53e3e;color:#fff}.pixel-btn:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}.contradiction-alert{position:fixed;top:60px;left:50%;transform:translate(-50%);display:flex;align-items:flex-start;gap:14px;background:linear-gradient(135deg,#fff5f5,#fed7d7);border:2px solid #fc8181;border-radius:12px;padding:16px 24px;color:#9b2c2c;z-index:100;max-width:540px;box-shadow:0 8px 24px #e53e3e26;animation:alertPulse .3s ease;transition:opacity .6s ease}.contradiction-alert.fade-out{opacity:0}.contradiction-icon{font-size:36px;flex-shrink:0;line-height:1}.contradiction-content{display:flex;flex-direction:column;gap:4px}.contradiction-title{font-size:1.4rem;font-weight:700;letter-spacing:1px}.contradiction-desc{font-size:1.1rem;opacity:.9}.contradiction-quote{font-size:1rem;font-style:italic;opacity:.8;margin-top:2px}.round-overlay{position:fixed;inset:0;background:radial-gradient(ellipse at center,#fffffff7,#f0f4f8fc);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:200;animation:fadeIn .5s ease}.round-overlay .round-text{font-size:3.5rem;margin-bottom:16px;color:#1a365d;letter-spacing:4px;text-transform:uppercase;animation:roundFadeIn .8s ease}.round-overlay .round-sub{font-size:1.6rem;color:#718096;animation:fadeIn 1s ease}.gameover-panel{position:fixed;inset:0;background:radial-gradient(ellipse at center,#fffffffc,#f0f4f8);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:300;animation:fadeIn .6s ease;color:#2c3e50}.gameover-panel .go-icon{font-size:48px;margin-bottom:8px}.go-icon-badge{display:inline-block;width:72px;height:72px;line-height:72px;text-align:center;font-size:32px;font-weight:700;border-radius:50%;margin-bottom:16px;font-family:BitPotionExt,monospace}.go-icon-badge.victory{background:linear-gradient(135deg,#ecc94b,#d69e2e);color:#fff;border:3px solid #d69e2e;box-shadow:0 0 24px #ecc94b4d}.go-icon-badge.defeat{background:linear-gradient(135deg,#fc8181,#e53e3e);color:#fff;border:3px solid #e53e3e;box-shadow:0 0 24px #e53e3e4d}.gameover-panel .result-title{font-size:2.5rem;margin-bottom:8px;text-transform:uppercase;letter-spacing:3px;color:#1a365d}.gameover-panel .go-rank{font-size:1.5rem;margin-bottom:4px;color:#1a365d}.go-rank-badge{display:inline-block;padding:6px 20px;border-radius:8px;font-size:1.4rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:4px}.go-rank-badge.rank-gold{background:linear-gradient(90deg,#ecc94b,#d69e2e);color:#fff}.go-rank-badge.rank-silver{background:linear-gradient(90deg,#a0aec0,#cbd5e0);color:#2d3748}.go-rank-badge.rank-bronze{background:linear-gradient(90deg,#c47f32,#b87333);color:#fff}.gameover-panel .go-rank-desc{font-size:1.1rem;color:#718096;margin-bottom:16px;font-style:italic}.gameover-panel .go-reason{font-size:1.2rem;color:#e53e3e;margin-bottom:16px}.gameover-panel .go-round{font-size:1rem;color:#718096;margin-bottom:16px}.gameover-panel .go-bars{width:100%;max-width:300px;margin-bottom:16px}.gameover-panel .go-resource{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:1rem}.gameover-panel .go-resource-label{width:72px;text-align:right;color:#4a5568}.gameover-panel .go-bar-track{flex:1;height:12px;background:#e2e8f0;border:1px solid #cbd5e0;border-radius:6px;overflow:hidden}.gameover-panel .go-bar-fill{height:100%;transition:width .6s ease;border-radius:6px}.gameover-panel .go-resource-val{width:32px;text-align:left;color:#4a5568}.gameover-panel .go-approvals{margin-bottom:20px;text-align:center}.gameover-panel .go-approvals-title{font-size:1rem;color:#718096;margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}.gameover-panel .go-citizen{display:inline-block;font-size:.95rem;color:#4a5568;background:#ebf8ff;border:1px solid #bee3f8;padding:3px 10px;margin:2px;border-radius:6px}.reaction-panel{position:fixed;bottom:0;left:280px;right:280px;max-height:40vh;overflow-y:auto;background:linear-gradient(0deg,#fff,#f7fafc);border-top:2px solid #e2e8f0;padding:18px 28px;z-index:60;display:none;animation:slideUp .3s ease;color:#2c3e50;box-shadow:0 -4px 16px #0000000f}.reaction-panel.visible{display:block}.reaction-panel h3{font-size:1.6rem;margin-bottom:14px;letter-spacing:1px;color:#1a365d}.reaction-cards{display:flex;flex-direction:column;gap:12px}.reaction-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px 18px;box-shadow:0 2px 6px #0000000a;animation:reactionSlideIn .4s ease both;transition:transform .2s ease}.reaction-card:hover{transform:translate(3px)}.reaction-card.reaction-angry{border-left:4px solid #fc8181}.reaction-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.reaction-card-info{flex:1;display:flex;flex-direction:column;gap:2px}.reaction-name{font-size:1.3rem;color:#1a365d;font-weight:700}.reaction-tone{font-size:.95rem;display:flex;align-items:center;gap:4px;color:#718096}.reaction-tone-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.reaction-delta{font-size:1.5rem;font-weight:700;min-width:44px;text-align:right}.reaction-delta.positive{color:#38a169}.reaction-delta.negative{color:#e53e3e}.reaction-dialogue{font-size:1.15rem;color:#4a5568;font-style:italic;line-height:1.5;margin:0}.audio-icon{cursor:pointer;color:#3182ce}.audio-icon.playing{color:#38a169;animation:pulse 1s infinite}.tile-tooltip{position:absolute;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:10px 18px;font-size:1.5rem;color:#2c3e50;pointer-events:none;z-index:50;white-space:nowrap;box-shadow:0 4px 16px #0000001a}.tile-tooltip .edit-icon{margin-right:2px}.tile-tooltip.editable .edit-icon{color:#38a169}.tile-tooltip.locked .edit-icon{color:#a0aec0}.tile-tooltip.loading .edit-icon{color:#3182ce}.action-menu-bg{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:4px;box-shadow:0 8px 24px #0000001a}.tutorial-overlay{position:fixed;inset:0;z-index:500;pointer-events:auto}.tutorial-backdrop{position:absolute;inset:0;background:#00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.tutorial-card{position:absolute;width:460px;max-width:90vw;background:#fff;border:2px solid #3182ce;border-radius:16px;padding:32px 36px;box-shadow:0 16px 48px #00000026;color:#2c3e50;z-index:501;animation:tutorialFadeIn .4s ease}.tutorial-center{top:50%;left:50%;transform:translate(-50%,-50%)}.tutorial-top{top:80px;left:50%;transform:translate(-50%)}.tutorial-bottom{bottom:80px;left:50%;transform:translate(-50%)}.tutorial-right{top:80px;right:280px}.tutorial-step-indicator{font-size:.9rem;color:#a0aec0;margin-bottom:8px;letter-spacing:2px;text-transform:uppercase}.tutorial-title{font-size:2rem;color:#1a365d;margin-bottom:14px;letter-spacing:1px}.tutorial-text{font-size:1.3rem;line-height:1.6;color:#4a5568;margin-bottom:22px}.tutorial-dots{display:flex;gap:8px;justify-content:center;margin-bottom:18px}.tutorial-dot{width:10px;height:10px;border-radius:50%;background:#e2e8f0;transition:background .3s}.tutorial-dot.active{background:#3182ce;box-shadow:0 0 8px #3182ce66}.tutorial-actions{display:flex;gap:14px;justify-content:center;align-items:center}.tutorial-skip{background:none;border:none;color:#a0aec0;font-family:BitPotionExt,monospace;font-size:1rem;cursor:pointer;text-decoration:underline}.tutorial-skip:hover{color:#4a5568}.tutorial-highlighted{position:relative;z-index:502;box-shadow:0 0 20px #3182ce66;border-color:#3182ce!important}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f7fafc}::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media(max-width:1100px){.left-sidebar,.right-sidebar{width:240px}#game-container,.reaction-panel{left:240px;right:240px}.citizen-personality{display:none}}@media(max-width:900px){.left-sidebar,.right-sidebar{width:200px}#game-container,.reaction-panel{left:200px;right:200px}.citizen-avatar{width:40px!important;height:40px!important}.citizen-profession,.tech-legend{display:none}.panel-header{font-size:1.3rem}.bar-icon{display:none}}@media(max-width:700px){.left-sidebar{position:fixed;inset:0 0 auto;width:100%;height:auto;flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid #e2e8f0;z-index:25;padding:8px 12px}.left-sidebar .panel-header{display:none}.resource-panel{padding:4px 8px;width:100%}.resource-panel .round-info{font-size:1.3rem;margin-bottom:6px;padding-bottom:4px}.resource-panel .resources{flex-direction:row;gap:8px}.resource-bar{flex:1}.resource-panel .actions-info{font-size:1.1rem}.sidebar-divider,.tech-section,.bar-icon{display:none}.promise-panel{display:none!important}.right-sidebar{position:fixed;inset:auto 0 0;width:100%;height:auto;max-height:35vh;border-left:none;border-top:1px solid #e2e8f0;z-index:25}.citizen-panel .panel-header{font-size:1.2rem;padding:8px}.citizen-list{display:flex;flex-wrap:wrap;gap:6px}.citizen-entry{flex:1 1 45%;min-width:140px}.citizen-personality,.citizen-profession{display:none}#game-container{inset:90px 0 0}.reaction-panel{left:0;right:0}.speech-modal{width:95vw;padding:20px}}
