*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden}#root{width:100%;height:100%}:root{font-family:Avenir Next,Segoe UI,Helvetica,Arial,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.page-title{margin:0;font-size:2rem;color:#1f2937}.page-subtitle{margin:8px 0 0;font-size:1.1rem;color:#6b7280}.hex-pointer{cursor:pointer}.hex-disabled{cursor:not-allowed}.game-shell{position:relative}.lobby-page{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background:#1f2937}.auth-page,.player-launcher-page{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background:#111827}.lobby-card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000040;margin:0 16px;padding:28px;text-align:center;width:min(100%,760px)}.auth-card,.player-launcher-card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000040;margin:0 16px;padding:28px;text-align:center;width:min(100%,520px)}@media (min-width: 640px){.lobby-item__row{flex-direction:row;align-items:center;justify-content:space-between}.lobby-item__select{flex:1}}@media (max-width: 768px){.app-player-indicator{top:68px}.lobby-item__row{gap:8px}}.app-back-button{border:1px solid transparent;border-radius:10px;cursor:pointer;font-weight:700;transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease}.app-back-button:disabled{opacity:.6;cursor:not-allowed}.app-back-button{position:absolute;top:16px;left:16px;z-index:40;padding:8px 12px;background:#000000c7;color:#fff;font-size:.85rem}.app-back-button:hover{background:#000000e6}.app-player-indicator{position:absolute;top:16px;right:16px;z-index:40;display:flex;flex-direction:column;gap:6px;align-items:flex-end}.app-player-badge{border-radius:8px;padding:8px 12px;color:#fff;font-size:.85rem;font-weight:700}.app-single-player-tag{border-radius:6px;padding:4px 8px;background:#000000b3;color:#e5e7eb;font-size:.72rem}.hex-game-ui{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background:#111827;position:relative;overflow:hidden}.hex-game-over-banner{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:40;border-radius:8px;padding:8px 16px;background:#000c;color:#fff;font-size:.875rem;font-weight:700}.hex-game-board{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.hex-game-loading{color:#f9fafb;font-size:1.125rem}.game-controls{position:fixed;top:80px;right:16px;z-index:40;min-width:220px;border-radius:10px;padding:16px;background:#000000bf;color:#fff;text-align:right;font-size:.875rem}.game-controls__section{margin-bottom:12px}.game-controls__title{margin:0 0 8px;font-size:.92rem;font-weight:700}.game-controls__priority{margin-bottom:16px;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:12px;text-align:center}.game-controls__priority-pill{display:inline-block;border-radius:999px;padding:8px 16px;color:#fff;font-weight:700}.game-controls__hint{margin-top:6px;color:#d1d5db;font-size:.75rem}.game-controls__toggle{display:flex;justify-content:flex-end;gap:8px;align-items:center;margin-bottom:12px;font-size:.75rem;color:#d1d5db}.game-controls__list{display:flex;flex-direction:column;gap:6px}.game-controls__action-button{border:1px solid transparent;border-radius:10px;cursor:pointer;font-weight:700;transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease}.game-controls__action-button:disabled{opacity:.6;cursor:not-allowed}.game-controls__action-button{width:100%;padding:6px 10px;font-size:.75rem;font-weight:600}.game-controls__action-button--enabled{background:#2563eb;border-color:#3b82f6;color:#fff}.game-controls__action-button--enabled:hover{background:#1d4ed8;border-color:#60a5fa}.game-controls__action-button--disabled{background:#4b5563;border-color:#4b5563;color:#9ca3af}.game-controls__play-again-title{color:#4ade80}.game-controls__concede-title{color:#f87171}.game-controls__play-again-button,.game-controls__concede-button{border:1px solid transparent;border-radius:10px;cursor:pointer;font-weight:700;transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease}.game-controls__play-again-button:disabled,.game-controls__concede-button:disabled{opacity:.6;cursor:not-allowed}.game-controls__play-again-button,.game-controls__concede-button{width:100%;padding:8px 10px;border-width:1px;border-style:solid;color:#fff;font-size:.75rem}.game-controls__play-again-button{border-color:#22c55e;background:#16a34a}.game-controls__play-again-button:hover{background:#15803d}.game-controls__concede-button{border-color:#f87171;background:#ef4444}.game-controls__concede-button:hover{background:#dc2626}.game-controls__meta{font-size:.75rem}.lobby-form{margin:24px 0;display:flex;flex-direction:column;gap:12px}.lobby-label{text-align:left;font-size:.875rem;color:#374151}.lobby-input,.auth-input{width:100%;border:1px solid #d1d5db;border-radius:10px;padding:10px 12px;font-size:14px;color:#1f2937;outline:none}.lobby-input:focus,.auth-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa40}.lobby-input:disabled,.auth-input:disabled{background:#f3f4f6;cursor:not-allowed}.lobby-input{margin-top:6px}.lobby-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}.lobby-primary-button,.lobby-danger-button,.auth-submit,.player-launcher-back,.player-launcher-option,.game-over-modal__button{border:1px solid transparent;border-radius:10px;cursor:pointer;font-weight:700;transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease}.lobby-primary-button:disabled,.lobby-danger-button:disabled,.auth-submit:disabled,.player-launcher-back:disabled,.player-launcher-option:disabled,.game-over-modal__button:disabled{opacity:.6;cursor:not-allowed}.lobby-primary-button,.lobby-danger-button{padding:10px 16px;color:#fff}.lobby-primary-button{background:#16a34a}.lobby-primary-button:hover{background:#15803d}.lobby-danger-button{background:#dc2626}.lobby-danger-button:hover{background:#b91c1c}.lobby-error{margin-bottom:16px;color:#dc2626;font-size:.875rem}.lobby-list{display:flex;flex-direction:column;gap:10px}.lobby-empty,.lobby-loading{color:#6b7280}.lobby-item{width:100%;border:2px solid #e5e7eb;border-radius:12px;padding:16px;transition:border-color .15s ease}.lobby-item:hover{border-color:#3b82f6}.lobby-item__row{display:flex;flex-direction:column;gap:10px;align-items:stretch}.lobby-item__select{border:0;background:transparent;text-align:left;padding:0;color:inherit;cursor:pointer}.lobby-item__select:hover{color:#1d4ed8}.lobby-item__name{color:#1f2937;font-weight:700}.lobby-item__meta{color:#6b7280;font-size:.875rem}.auth-form{margin-top:20px}.auth-field{margin-bottom:14px;text-align:left}.auth-label{display:block;margin-bottom:8px;color:#374151;font-size:.875rem;font-weight:600}.auth-error{margin-bottom:14px;border:1px solid #fecaca;border-radius:10px;background:#fef2f2;padding:8px;color:#dc2626;font-size:.875rem}.auth-submit{width:100%;padding:12px 14px;background:#2563eb;color:#fff;font-size:1rem}.auth-submit:hover{background:#1d4ed8}.player-launcher-back{border:0;background:transparent;margin-bottom:16px;color:#6b7280;font-size:.85rem}.player-launcher-back:hover{color:#374151}.player-launcher-instance{margin:0 0 14px;color:#6b7280;font-size:.875rem}.player-launcher-description{margin:8px 0 24px;color:#4b5563}.player-launcher-options{display:flex;flex-direction:column;gap:12px}.player-launcher-option{width:100%;border-width:2px;border-style:solid;border-radius:12px;padding:14px 18px;background:transparent;font-size:1.05rem}.player-launcher-option__side{margin-top:4px;display:block;opacity:.75;font-size:.875rem}.player-launcher-option--single{border-color:#6b7280;color:#374151}.player-launcher-option--single:hover{background:#f3f4f6}.player-launcher-footnote{margin-top:24px;color:#6b7280;font-size:.875rem}.tooltip{position:fixed;right:24px;bottom:24px;z-index:9999;min-width:210px;border:1px solid #4b5563;border-radius:10px;padding:12px;background:#1f2937;box-shadow:0 10px 15px -3px #00000040;pointer-events:none}.tooltip__header{margin:0 0 10px;border-bottom:1px solid #4b5563;padding-bottom:4px;color:#fff;font-size:.85rem;font-weight:700}.tooltip__stats{margin-top:8px}.tooltip__stat{margin-bottom:8px}.tooltip__stat-row{margin-bottom:4px;display:flex;align-items:center;justify-content:space-between}.tooltip__stat-label{color:#d1d5db;font-size:.75rem;font-weight:500}.tooltip__stat-value{color:#fff;font-size:.75rem;font-family:Menlo,Consolas,monospace}.tooltip__bar-bg{width:100%;height:12px;border:1px solid #4b5563;border-radius:6px;overflow:hidden;background:#374151}.tooltip__bar-fill{height:100%;border-radius:6px;transition:width .3s ease-out}.tooltip__status{border-top:1px solid #4b5563;padding-top:6px;display:flex;align-items:center;justify-content:space-between}.tooltip__status-left{display:flex;align-items:center;gap:8px}.tooltip__dot{width:8px;height:8px;border-radius:999px}.tooltip__dot--alive{background:#22c55e}.tooltip__dot--dead{background:#ef4444}.tooltip__status-text{color:#d1d5db;font-size:.75rem}.debug-panel{position:absolute;top:16px;left:16px;z-index:30}.debug-panel__toggle{border:1px solid transparent;border-radius:10px;cursor:pointer;font-weight:700;transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease}.debug-panel__toggle:disabled{opacity:.6;cursor:not-allowed}.debug-panel__toggle{border-radius:8px 8px 0 0;padding:8px 12px;background:#000000bf;color:#fff;font-size:.875rem}.debug-panel__toggle:hover{background:#000000e6}.debug-panel__content{max-width:420px;max-height:24rem;overflow-y:auto;border-radius:0 0 10px 10px;padding:16px;background:#000000bf;color:#fff;font-size:.875rem}.debug-panel__block{margin-top:8px}.debug-panel__title{font-weight:700}.debug-panel__box{margin-top:4px;border-radius:8px;padding:8px;max-height:80px;overflow-y:auto;background:#1f2937;font-size:.75rem}.debug-panel__box--tall{max-height:128px}.debug-panel__status--connected{color:#4ade80}.debug-panel__status--error{color:#f87171}.debug-panel__status--other{color:#facc15}.debug-panel__alert{color:#f87171;font-weight:700}.debug-panel__ok{color:#4ade80}.game-over-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#00000080}.game-over-modal__card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000040;margin:0 16px;padding:28px;text-align:center;width:min(100%,420px)}.game-over-modal__title{margin:0 0 12px;color:#1f2937}.game-over-modal__message{margin:0 0 18px;color:#4b5563}.game-over-modal__button{padding:10px 20px;background:#2563eb;color:#fff}.game-over-modal__button:hover{background:#1d4ed8}.army-select{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background:#111827;padding:16px}.army-select--single{padding:20px}.army-select__card{width:min(100%,640px);border:1px solid #4b5563;border-radius:12px;padding:32px;background:#1f2937;color:#fff;box-shadow:0 14px 30px #00000059}.army-select__card--wide{width:min(100%,980px)}.army-select__card--narrow{width:min(100%,460px);text-align:center}.army-select__back-link{border:1px solid transparent;border-radius:10px;cursor:pointer;font-weight:700;transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease}.army-select__back-link:disabled{opacity:.6;cursor:not-allowed}.army-select__back-link{border:0;background:transparent;margin-bottom:16px;padding:0;color:#9ca3af;font-size:.875rem;font-weight:600}.army-select__back-link:hover{color:#fff}.army-select__back-link--spaced{margin-top:24px;margin-bottom:0}.army-select__title{margin:0 0 6px;color:#fff;font-size:1.8rem}.army-select__subtitle{margin:0 0 24px;color:#9ca3af;font-size:.9rem}.army-select__section-title{margin:0 0 12px;color:#fff;font-size:1.35rem}.army-select__player-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}.army-select__player-panel{border:1px solid #4b5563;border-radius:10px;padding:16px}.army-select__player-panel--current{border-width:2px;border-color:#f59e0b}.army-select__player-title{margin:0 0 12px;color:#fff;font-size:1.1rem}.army-select__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.army-select__button{border:1px solid transparent;border-radius:10px;cursor:pointer;font-weight:700;transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease}.army-select__button:disabled{opacity:.6;cursor:not-allowed}.army-select__button{width:100%;padding:10px 12px;border:1px solid #4b5563;border-radius:10px;text-align:left;color:#fff;font-size:.875rem}.army-select__button--unselected{background:#374151}.army-select__button--unselected:hover{border-color:#f59e0b;background:#d97706}.army-select__button--selected{border-color:#f59e0b;background:#d97706;box-shadow:0 0 0 2px #fbbf2480;cursor:default}.army-select__button--disabled{opacity:.5}.army-select__button-title{font-weight:700}.army-select__button-units{margin-top:4px;color:#e5e7eb;font-size:.75rem;opacity:.9}.army-select__selected-preview{margin-bottom:16px;display:flex;justify-content:center}.army-select__waiting-text{color:#d1d5db}.army-select__progress-track{margin-top:24px;width:100%;height:8px;border-radius:999px;overflow:hidden;background:#374151}.army-select__progress-fill{width:60%;height:100%;border-radius:999px;background:#f59e0b;animation:army-select-pulse 1.1s ease-in-out infinite alternate}@keyframes army-select-pulse{0%{opacity:.65}to{opacity:1}}@media (max-width: 768px){.game-controls{top:auto;right:16px;bottom:16px;left:16px;min-width:0}.army-select{padding:14px}.army-select__card{padding:24px}.army-select__player-grid{grid-template-columns:1fr;gap:16px}.army-select__grid{grid-template-columns:1fr}}
