@charset "UTF-8";.strategy-cards-stack{display:flex;flex-direction:column;gap:.25rem}.strategy-card{width:100%;min-height:280px;position:relative;cursor:pointer}.strategy-card.selected .card-shape{border-color:var(--accent);box-shadow:inset 0 0 30px #f59e0b26,0 0 24px #f59e0b66}.strategy-card.disabled{opacity:.4;cursor:not-allowed}.strategy-card:hover:not(.disabled) .card-shape{border-color:var(--accent);box-shadow:inset 0 2px 4px var(--overlay-heavy),0 0 16px #f59e0b40}.strategy-card .outer-glow{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;background:radial-gradient(circle at 50% 0%,rgba(100,100,100,.4) 0%,transparent 70%);border-radius:14px;z-index:-1}.strategy-card .card-shape{width:100%;min-height:100%;border-radius:12px;border:3px solid var(--overlay-heavy);overflow:hidden;position:relative;display:flex;flex-direction:column;box-shadow:inset 0 2px 4px var(--overlay-heavy),inset 0 -2px 4px #0000004d}.strategy-card .card-shape.selected{border:3px solid var(--accent);box-shadow:inset 0 0 30px #f59e0b26,inset 0 2px 4px var(--overlay-heavy)}.strategy-card .trade-goods-display{position:absolute;top:12px;right:12px;background:var(--bg-deep);border:2px solid var(--accent);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;z-index:10}.strategy-card .trade-goods-display:hover{background:rgba(245,158,11,.15);transform:scale(1.1)}.strategy-card .trade-goods-display .tg-count{color:var(--accent);font-weight:700;font-size:1rem}.strategy-card .card-content{padding:16px;display:flex;flex-direction:column;flex:1;color:var(--text-primary)}.strategy-card .card-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.strategy-card .card-header .card-number{background:var(--bg-deep);font-size:1.4rem;font-weight:700;width:36px;height:36px;min-width:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid}.strategy-card .card-header .card-name{font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin:0}.strategy-card .primary-ability{background:var(--overlay-light);padding:.7rem;margin-bottom:.5rem;border-left:2px solid var(--accent-dim);border-radius:4px}.strategy-card .primary-ability .ability-title{color:var(--accent);font-weight:700;font-size:.8rem;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:1px}.strategy-card .primary-ability .ability-text{line-height:1.4;font-size:.8rem;color:var(--text-primary)}.strategy-card .primary-ability .ability-text .clause{margin-bottom:.5rem}.strategy-card .primary-ability .ability-text .clause:last-child{margin-bottom:0}.strategy-card .secondary-ability{background:var(--overlay-light);padding:.7rem;border-left:2px solid var(--text-muted);border-radius:4px}.strategy-card .secondary-ability .ability-title{color:var(--text-secondary);font-weight:700;font-size:.8em;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:1px}.strategy-card .secondary-ability .ability-text{line-height:1.4;font-size:.8rem;color:var(--text-primary)}.strategy-card .secondary-ability .ability-text .clause{margin-bottom:.5rem}.strategy-card .secondary-ability .ability-text .clause:last-child{margin-bottom:0}.tech-grid-container{width:100%;height:100%;overflow:auto;padding:0 16px 16px;scrollbar-width:thin;scrollbar-color:var(--scrollbar) transparent}.tech-grid-container::-webkit-scrollbar{width:6px;height:6px}.tech-grid-container::-webkit-scrollbar-track{background:transparent}.tech-grid-container::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:3px}.tech-grid{display:grid;grid-template-columns:repeat(var(--col-count, 4),1fr);gap:0;max-width:1600px;margin:0 auto}.tech-grid--level-view{grid-template-columns:repeat(4,1fr)!important}.tech-grid__level-column{display:flex;flex-direction:column;padding:10px 8px;border-right:1px solid var(--divider)}.tech-grid__level-column:last-child{border-right:none}.tech-grid__level-header{display:flex;align-items:center;justify-content:center;padding:8px 6px;margin-bottom:12px;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;background:var(--overlay-light);border:1px solid var(--overlay-medium);border-radius:6px;color:var(--card-text-soft)}.tech-grid__level-content{display:flex;flex-direction:column;gap:8px;flex:1}.tech-grid__col-header{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 6px;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;position:sticky;top:0;z-index:10;background:var(--bg-deep);-webkit-backdrop-filter:none;backdrop-filter:none;white-space:nowrap;overflow:hidden;min-width:0}.tech-grid__col-icon{width:24px;height:24px}.tech-grid__cell{display:flex;flex-direction:column;gap:8px;padding:10px 8px;position:relative;border-right:1px solid var(--divider);min-width:0;overflow:hidden}.tech-grid__cell:last-child{border-right:none}.tech-grid__level-hr{border:none;border-top:1px solid;margin:4px 0}.tech-card{background:linear-gradient(135deg,var(--card-bg),var(--bg-deep));border:2px solid var(--card-border);border-radius:10px;padding:12px 14px;cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all .2s ease;box-shadow:0 0 10px var(--card-glow),inset 0 1px 0 var(--overlay-light)}.tech-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px var(--card-glow),inset 0 1px 0 var(--overlay-medium)}.tech-card--dimmed{opacity:.15;filter:grayscale(.7);box-shadow:none}.tech-card--dimmed:hover{transform:none;filter:grayscale(.7);box-shadow:none}.tech-card__header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.tech-card__icon{width:22px;height:22px;flex-shrink:0}.tech-card__name{color:var(--card-text);font-weight:700;font-size:.92rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.tech-card__text{color:var(--card-text-soft);font-size:.78rem;line-height:1.5}.prereq-pips{display:flex;gap:4px;margin-bottom:6px}.prereq-pip{border-radius:50%;border:2px solid var(--overlay-heavy)}.unit-card__stats{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.unit-card__stat{background:rgba(168,85,247,.3);border:1px solid rgba(168,85,247,.5);border-radius:4px;padding:2px 7px;font-size:.72rem;color:var(--text-primary);white-space:nowrap;font-weight:600}.unit-card__special{color:var(--card-text-soft);font-size:.75rem;line-height:1.4;font-style:italic}.unit-upgrades-section{margin-top:24px;max-width:1600px;margin-left:auto;margin-right:auto}.unit-upgrades-section__header{display:flex;align-items:center;justify-content:center;padding:12px 0;border-top:1px solid var(--phase-status);margin-bottom:12px}.unit-upgrades-section__title{font-weight:700;font-size:1.05rem;text-transform:uppercase;letter-spacing:.08em}.unit-upgrades-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}@media (min-width: 601px) and (max-width: 960px){.tech-grid{grid-template-columns:repeat(2,1fr);max-width:800px}.tech-grid--level-view{grid-template-columns:repeat(4,1fr)!important;max-width:100%!important}.tech-grid__cell{padding:8px 6px}.tech-grid__level-column{padding:6px 4px}.tech-card{padding:10px 12px}.tech-card__name{font-size:.88rem}.tech-card__text{font-size:.76rem}}@media (min-width: 961px) and (max-width: 1200px){.tech-grid{max-width:1200px;gap:4px}.tech-grid__cell,.tech-grid__level-column{padding:8px 6px}}@media (min-width: 1201px){.tech-grid{max-width:1600px}.unit-upgrades-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (min-width: 601px) and (max-width: 960px){.unit-upgrades-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px}}@media (min-width: 961px) and (max-width: 1200px){.unit-upgrades-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}.tech-grid-container--mobile{padding:12px}.tech-grid-container--mobile .tech-card{padding:10px 12px}.tech-grid-container--mobile .tech-card__icon{width:18px;height:18px}.tech-grid-container--mobile .tech-card__name{font-size:.85rem}.tech-grid-container--mobile .tech-card__text{font-size:.75rem;line-height:1.4}.tech-grid-container--mobile .unit-card__stat{font-size:.68rem;padding:1px 6px}.tech-grid-container--mobile .unit-card__special{font-size:.72rem}.mobile-section{margin-bottom:1.5rem}.mobile-section__header{font-size:1.1rem;font-weight:700;text-transform:capitalize;display:flex;align-items:center;gap:8px;padding-bottom:6px;margin-bottom:10px;border-bottom:2px solid}.mobile-section__icon{width:20px;height:20px}.mobile-level-group{margin-bottom:12px}.mobile-level-group__label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--card-text-dim);margin-bottom:6px}.mobile-level-group__cards{display:flex;flex-direction:column;gap:8px}@media print{.tech-grid-container{height:auto!important;overflow:visible!important;padding:0}.tech-card{break-inside:avoid;box-shadow:none!important;border-width:1px}.tech-grid__col-header{position:static}}.tech-tree-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1}.chatbot button{background:none;border:none;padding:0;margin:0;box-shadow:none;font-size:inherit;font-weight:inherit;color:inherit;transform:none}.chatbot button:hover{background:none;transform:none;box-shadow:none}.chatbot{display:flex;flex-direction:column;height:100%;min-height:0;background:var(--bg-deep);color:var(--text-primary);font-family:Segoe UI,system-ui,-apple-system,sans-serif}.chatbot-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.chatbot-header-left{display:flex;align-items:center;gap:.75rem}.chatbot-header-icon{width:36px;height:36px;border-radius:10px;background:rgba(59,130,246,.15);color:var(--info);display:flex;align-items:center;justify-content:center}.chatbot-header h2{font-size:1.1rem;font-weight:700;color:var(--info);margin:0}.chatbot-header-sub{font-size:.75rem;color:var(--text-muted);margin:0}.chatbot-header-content-actions{display:flex;align-items:center;gap:.15rem;margin-left:.25rem}.chatbot-header-btn-sending{opacity:.6;cursor:wait}.chatbot-header-actions{display:flex;align-items:center;gap:.25rem}.chatbot-new-chat{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.4rem;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.chatbot-new-chat:hover{background:rgba(59,130,246,.15);color:var(--info)}.chatbot-header-btn-done{color:#22c55e}.chatbot-header-btn-done:hover{color:#22c55e;background:rgba(34,197,94,.12)}.chatbot-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.4rem;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.chatbot-close:hover{background:rgba(239,68,68,.15);color:#ef4444}.chatbot-messages{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;min-height:0}.chatbot-welcome{text-align:center;padding:2rem 1rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.chatbot-welcome-icon{width:56px;height:56px;border-radius:16px;background:rgba(59,130,246,.12);color:var(--info);display:flex;align-items:center;justify-content:center}.chatbot-welcome h3{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin:0}.chatbot-welcome p{font-size:.9rem;color:var(--text-secondary);max-width:360px;line-height:1.5;margin:0}.chatbot-suggestions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:.5rem}.chatbot-suggestion{background:var(--bg-surface)!important;border:1px solid var(--border-subtle)!important;border-radius:20px!important;padding:.45em .9em!important;font-size:.8rem!important;color:var(--text-secondary)!important;cursor:pointer;transition:border-color .2s,color .2s,background .2s;font-family:inherit}.chatbot-suggestion:hover{border-color:var(--info)!important;color:var(--info)!important;background:rgba(59,130,246,.08)!important}.chatbot-msg{display:flex;gap:.6rem;max-width:85%;animation:chatbot-fade-in .2s ease}.chatbot-msg-user{align-self:flex-end;flex-direction:row-reverse}.chatbot-msg-assistant{align-self:flex-start}.chatbot-msg-avatar{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.75rem;font-weight:700;margin-top:2px}.chatbot-msg-user .chatbot-msg-avatar{background:rgba(245,158,11,.15);color:var(--accent)}.chatbot-msg-assistant .chatbot-msg-avatar{background:rgba(59,130,246,.15);color:var(--info)}.chatbot-msg-bubble{padding:.7rem 1rem;border-radius:12px;font-size:.9rem;line-height:1.55;min-width:0;word-wrap:break-word;overflow-wrap:break-word}.chatbot-msg-user .chatbot-msg-bubble{background:var(--bg-elevated);border:1px solid var(--border-subtle);color:var(--text-primary);border-bottom-right-radius:4px}.chatbot-msg-assistant .chatbot-msg-bubble{background:var(--bg-surface);border:1px solid var(--border-subtle);color:var(--text-primary);border-bottom-left-radius:4px}.chatbot-msg-assistant .chatbot-msg-bubble h1,.chatbot-msg-assistant .chatbot-msg-bubble h2,.chatbot-msg-assistant .chatbot-msg-bubble h3,.chatbot-msg-assistant .chatbot-msg-bubble h4{color:var(--accent-bright);margin:.6em 0 .3em;line-height:1.3}.chatbot-msg-assistant .chatbot-msg-bubble h1:first-child,.chatbot-msg-assistant .chatbot-msg-bubble h2:first-child,.chatbot-msg-assistant .chatbot-msg-bubble h3:first-child,.chatbot-msg-assistant .chatbot-msg-bubble h4:first-child{margin-top:0}.chatbot-msg-assistant .chatbot-msg-bubble h1{font-size:1.15em}.chatbot-msg-assistant .chatbot-msg-bubble h2{font-size:1.05em}.chatbot-msg-assistant .chatbot-msg-bubble h3{font-size:.95em}.chatbot-msg-assistant .chatbot-msg-bubble h4{font-size:.9em}.chatbot-msg-assistant .chatbot-msg-bubble p{margin:0 0 .5em}.chatbot-msg-assistant .chatbot-msg-bubble p:last-child{margin-bottom:0}.chatbot-msg-assistant .chatbot-msg-bubble strong{color:var(--accent-bright)}.chatbot-msg-assistant .chatbot-msg-bubble em{font-style:italic;color:var(--text-secondary, #b0b8c8)}.chatbot-msg-assistant .chatbot-msg-bubble code{background:var(--bg-elevated);padding:.15em .35em;border-radius:4px;font-size:.85em}.chatbot-msg-assistant .chatbot-msg-bubble ul,.chatbot-msg-assistant .chatbot-msg-bubble ol{margin:.4em 0;padding-left:1.4em}.chatbot-msg-assistant .chatbot-msg-bubble li{margin-bottom:.25em}.prereq-dots{display:inline-flex;align-items:center;gap:3px;vertical-align:middle;margin:0 2px}.prereq-dot{display:inline-block;width:12px;height:12px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);flex-shrink:0}.chatbot-system-note{align-self:center;font-size:.75rem;color:var(--text-muted);border:1px solid var(--border-subtle);border-radius:10px;padding:.35rem .85rem;display:flex;align-items:center;gap:.4rem;animation:chatbot-fade-in .2s ease,chatbot-pulse 2s ease-in-out infinite}.chatbot-system-note:has(.chatbot-system-check){animation:chatbot-fade-in .2s ease}@keyframes chatbot-pulse{0%,to{opacity:1}50%{opacity:.55}}.chatbot-system-spinner{display:inline-block;width:12px;height:12px;border:2px solid var(--border-subtle);border-top-color:var(--text-muted);border-radius:50%;animation:chatbot-spin .8s linear infinite}.chatbot-system-check{color:#22c55e;font-weight:700;font-size:.85rem}@keyframes chatbot-spin{to{transform:rotate(360deg)}}.chatbot-thinking-pulse{animation:chatbot-pulse 2.4s ease-in-out infinite}.chatbot-thinking-text{font-size:.82rem;font-style:italic;color:var(--text-muted);letter-spacing:.02em;display:inline-block;animation:chatbot-text-fade 2.4s ease-in-out infinite}@keyframes chatbot-pulse{0%,to{opacity:.55}50%{opacity:1}}@keyframes chatbot-text-fade{0%{opacity:0;transform:translateY(2px)}15%{opacity:1;transform:translateY(0)}85%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-2px)}}.chatbot-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:10px;padding:.6rem 1rem;font-size:.85rem;color:#f87171;text-align:center}.chatbot-input-area{padding:.75rem 1.25rem 1rem;border-top:1px solid var(--border-subtle);flex-shrink:0}.chatbot-input-row{display:flex;gap:.5rem;align-items:flex-end}.chatbot-input{flex:1;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:12px;padding:.65rem 1rem;color:var(--text-primary);font-size:.9rem;font-family:inherit;resize:none;min-height:42px;max-height:120px;line-height:1.4;outline:none;transition:border-color .2s}.chatbot-input::placeholder{color:var(--text-muted)}.chatbot-input:focus{border-color:var(--info)}.chatbot-send{width:42px;height:42px;border-radius:12px;border:none;background:var(--info);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s,transform .15s,opacity .2s}.chatbot-send:hover:not(:disabled){background:#60a5fa;transform:translateY(-1px)}.chatbot-send:disabled{opacity:.4;cursor:not-allowed}.chatbot-disclaimer{font-size:.7rem;color:var(--text-muted);text-align:center;margin-top:.5rem}.chatbot-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;animation:chatbot-fade-in .2s ease}.chatbot-overlay-panel{width:95%;max-width:560px;height:85vh;max-height:700px;border-radius:20px;border:1px solid var(--border-medium);overflow:hidden;box-shadow:0 24px 80px #0009}@keyframes chatbot-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 600px){.chatbot-overlay-panel{width:100%;height:100%;max-height:none;border-radius:0;border:none}.chatbot-msg{max-width:92%}.chatbot-suggestions{flex-direction:column;align-items:center}.chatbot-suggestion:nth-child(n+4){display:none}}.chatbot-feedback-link{color:#10b981;text-decoration:none;font-weight:500}.chatbot-feedback-link:hover{text-decoration:underline}.feedback-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;padding:.75rem}.feedback-type-btn{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.75rem;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:10px;cursor:pointer;text-align:left;transition:all .15s ease}.feedback-type-btn:hover{background:rgba(16,185,129,.1);border-color:#10b981}.feedback-type-label{font-size:.95rem;font-weight:600;color:var(--text-primary)}.feedback-type-desc{font-size:.75rem;color:var(--text-muted)}.feedback-confirm{display:flex;flex-direction:column;align-items:center;padding:1rem;gap:.5rem}.feedback-send-btn{padding:.75rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:#10b981;border:none;border-radius:8px;cursor:pointer;transition:background .15s ease}.feedback-send-btn:hover{background:#059669}.feedback-done-btn{padding:.6rem 1.5rem;font-size:.9rem;font-weight:500;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border-medium);border-radius:8px;cursor:pointer;transition:all .15s ease}.feedback-done-btn:hover{background:var(--bg-elevated)}.chatbot-maintenance-icon{width:128px;height:128px;background:transparent;border-radius:0;margin-bottom:1rem}.chatbot-maintenance h3{color:var(--text-primary);font-size:1.25rem}.chatbot-mic{width:42px;height:42px;border-radius:12px;border:1px solid var(--border-subtle);background:var(--bg-surface);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s,color .2s,border-color .2s,box-shadow .2s}.chatbot-mic:hover:not(:disabled){border-color:var(--info);color:var(--info);background:rgba(59,130,246,.08)}.chatbot-mic:disabled{opacity:.4;cursor:not-allowed}.chatbot-mic-active{background:rgba(239,68,68,.12);border-color:#ef4444;color:#ef4444;animation:chatbot-mic-pulse 1.5s ease-in-out infinite}.chatbot-mic-active:hover:not(:disabled){background:rgba(239,68,68,.2);border-color:#ef4444;color:#ef4444}@keyframes chatbot-mic-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}.chatbot-tts-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.4rem;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.chatbot-tts-toggle:hover{background:rgba(59,130,246,.15);color:var(--info)}.chatbot-tts-on{color:var(--info)}.chatbot-tts-speaking{animation:chatbot-tts-glow 1s ease-in-out infinite alternate}@keyframes chatbot-tts-glow{0%{color:var(--info)}to{color:#60a5fa;filter:drop-shadow(0 0 4px rgba(59,130,246,.5))}}.chatbot-wake-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.4rem;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s;position:relative}.chatbot-wake-toggle:hover{background:rgba(34,197,94,.15);color:#22c55e}.chatbot-wake-on{color:#22c55e}.chatbot-wake-active{animation:chatbot-wake-pulse 2s ease-in-out infinite}@keyframes chatbot-wake-pulse{0%,to{color:#22c55e}50%{color:#4ade80;filter:drop-shadow(0 0 3px rgba(34,197,94,.4))}}.chatbot-wake-dot{position:absolute;top:4px;right:4px;width:6px;height:6px;border-radius:50%;background:#22c55e;border:1.5px solid var(--bg-deep);animation:chatbot-wake-blink 2s ease-in-out infinite}@keyframes chatbot-wake-blink{0%,to{opacity:1}50%{opacity:.3}}.chatbot-msg-content{position:relative;min-width:0;flex:1}.chatbot-copy-msg{position:absolute;top:4px;right:-28px;width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;opacity:0;transition:opacity .15s,background .15s,color .15s}.chatbot-msg:hover .chatbot-copy-msg{opacity:1}.chatbot-copy-msg:hover{background:rgba(59,130,246,.12);color:var(--info)}.chatbot-copy-msg-done{opacity:1;color:#22c55e}.chatbot-msg-user .chatbot-copy-msg{right:auto;left:-28px}.chatbot-footer-actions{display:flex;gap:.75rem;justify-content:center;align-items:center;margin-top:.5rem;min-height:2rem}.chatbot-footer-actions .chatbot-footer-sep{width:1px;height:14px;background:var(--border-subtle);flex-shrink:0}.chatbot-footer-btn{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--text-muted);cursor:pointer;padding:.35rem .75rem;border-radius:8px;border:1px solid var(--border-subtle);transition:background .15s,color .15s,border-color .15s}.chatbot-footer-btn:hover:not(:disabled){background:rgba(59,130,246,.1);color:var(--info)}.chatbot-footer-btn:disabled{opacity:.5;cursor:not-allowed}.chatbot-footer-btn-done{color:#22c55e}.chatbot-footer-btn-feedback:hover:not(:disabled){background:rgba(16,185,129,.1);color:#10b981}.chatbot-rate-limit{text-align:center;padding:1rem 1.25rem;background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.25);border-radius:12px;animation:chatbot-fade-in .2s ease}.chatbot-rate-limit p{font-size:.85rem;color:var(--text-secondary);margin:0 0 .75rem}.chatbot-rate-limit-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;color:#fff;background:#5865f2;border-radius:8px;text-decoration:none;transition:background .2s}.chatbot-rate-limit-btn:hover{background:#4752c4}.chatbot-rate-info{color:var(--text-muted);opacity:.8}.chatbot-spark{animation:chatbot-spark-flicker .8s ease-in-out infinite alternate}@keyframes chatbot-spark-flicker{0%,to{opacity:1}25%{opacity:.3}50%{opacity:.9}75%{opacity:.5}}.fw-trigger{display:flex;justify-content:center;padding:1.5rem 0 .5rem}.fw-trigger-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;font-size:.85rem;font-weight:500;color:#10b981;background:transparent;border:1px solid rgba(16,185,129,.3);border-radius:8px;cursor:pointer;transition:all .15s ease;font-family:inherit}.fw-trigger-btn:hover{background:rgba(16,185,129,.08);border-color:#10b981}.fw-container{max-width:480px;margin:1.5rem auto .5rem;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:12px;padding:1rem 1.25rem 1.25rem;animation:fwSlideIn .2s ease}@keyframes fwSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fw-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.fw-title{font-size:.95rem;font-weight:700;color:#10b981}.fw-page-badge{font-size:.7rem;font-weight:500;color:var(--text-muted);background:var(--overlay-light);padding:2px 8px;border-radius:4px;border:1px solid var(--border-subtle)}.fw-close{margin-left:auto;display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.fw-close:hover{background:var(--overlay-medium);color:var(--text-primary)}.fw-form{display:flex;flex-direction:column;gap:.6rem}.fw-categories{display:flex;flex-wrap:wrap;gap:.35rem}.fw-cat-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .65rem;font-size:.78rem;font-weight:500;color:var(--text-secondary);background:var(--overlay-light);border:1px solid var(--border-subtle);border-radius:6px;cursor:pointer;transition:all .15s ease;font-family:inherit}.fw-cat-btn:hover{background:rgba(16,185,129,.06);border-color:#10b9814d}.fw-cat-active{background:rgba(16,185,129,.12);border-color:#10b981;color:#10b981}.fw-cat-icon{font-size:.85rem;line-height:1}.fw-cat-label{line-height:1}.fw-textarea{width:100%;min-height:70px;padding:.6rem .75rem;font-size:.85rem;font-family:inherit;color:var(--text-primary);background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:8px;resize:vertical;outline:none;transition:border-color .15s ease;box-sizing:border-box}.fw-textarea:focus{border-color:#10b981}.fw-textarea::placeholder{color:var(--text-muted)}.fw-email{width:100%;padding:.45rem .75rem;font-size:.82rem;font-family:inherit;color:var(--text-primary);background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:8px;outline:none;transition:border-color .15s ease;box-sizing:border-box}.fw-email:focus{border-color:#10b981}.fw-email::placeholder{color:var(--text-muted)}.fw-error{font-size:.8rem;color:#f87171;padding:.3rem 0}.fw-actions{display:flex;justify-content:flex-end}.fw-submit{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;color:#fff;background:#10b981;border:none;border-radius:8px;cursor:pointer;transition:all .15s ease;font-family:inherit}.fw-submit:hover:not(:disabled){background:#059669}.fw-submit:disabled{opacity:.5;cursor:not-allowed}.fw-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:fwSpin .6s linear infinite}@keyframes fwSpin{to{transform:rotate(360deg)}}.fw-success{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;color:#10b981;font-size:.9rem;font-weight:500}.fw-link-btn{background:none;border:none;color:var(--text-muted);font-size:.8rem;cursor:pointer;text-decoration:underline;font-family:inherit;padding:0}.fw-link-btn:hover{color:var(--text-secondary)}.fw-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1300;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fwFadeIn .15s ease}@keyframes fwFadeIn{0%{opacity:0}to{opacity:1}}.fw-dialog{width:90%;max-width:480px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:14px;padding:1.25rem 1.5rem 1.5rem;box-shadow:0 20px 60px #00000080;animation:fwDialogIn .2s ease;max-height:90vh;overflow-y:auto}@keyframes fwDialogIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width: 600px){.fw-container{margin:1rem 0 .5rem;border-radius:10px}.fw-categories{gap:.3rem}.fw-cat-btn{font-size:.72rem;padding:.25rem .5rem}.fw-dialog{width:95%;padding:1rem 1.25rem 1.25rem}}.objectives-page{min-height:100vh;background:linear-gradient(135deg,var(--bg-deep) 0%,var(--bg-surface) 100%);color:var(--text-primary);padding:2rem}.objectives-header{text-align:center;margin-bottom:3rem}.objectives-header h1{font-size:3rem;font-weight:700;color:var(--accent);margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.objectives-header p{font-size:1.2rem;color:var(--text-secondary)}.objectives-tabs{display:flex;justify-content:center;gap:1rem;margin-bottom:3rem}.tab-button{padding:.75rem 2rem;background:var(--overlay-light);border:2px solid var(--overlay-medium);color:var(--text-secondary);font-size:1.1rem;font-weight:600;cursor:pointer;border-radius:8px;transition:all .3s ease}.tab-button:hover{background:var(--overlay-medium);border-color:var(--overlay-heavy);color:var(--text-primary)}.tab-button.active{background:var(--accent);border-color:var(--accent);color:var(--bg-deep)}.objectives-content{max-width:1400px;margin:0 auto}.objectives-controls{display:flex;justify-content:center;margin-bottom:2rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;color:var(--text-secondary);cursor:pointer}.checkbox-label input[type=checkbox]{width:1.2rem;height:1.2rem;cursor:pointer}.objective-section{margin-bottom:3rem}.objective-section h3{font-size:1.8rem;font-weight:600;color:var(--accent);margin-bottom:1.5rem;text-align:center}.objectives-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.objective-card{background:var(--overlay-light);border:1px solid var(--overlay-medium);border-radius:12px;padding:1.5rem;transition:all .3s ease}.objective-card:hover{background:var(--overlay-medium);border-color:var(--overlay-heavy);transform:translateY(-2px)}.objective-card.secret{border-color:#7c3aed4d;background:rgba(124,58,237,.05)}.objective-card.secret:hover{border-color:#7c3aed80;background:rgba(124,58,237,.1)}.objective-card h4{font-size:1.3rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.objective-card .condition{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin-bottom:1rem}.objective-meta{display:flex;gap:1rem;font-size:.9rem}.objective-meta .points{background:var(--accent);color:var(--bg-deep);padding:.25rem .75rem;border-radius:4px;font-weight:600}.objective-meta .phase{background:var(--overlay-medium);color:var(--text-secondary);padding:.25rem .75rem;border-radius:4px;font-weight:500}.objective-meta .expansion{background:var(--overlay-light);color:var(--text-muted);padding:.25rem .75rem;border-radius:4px;font-size:.8rem;text-transform:uppercase}@media (max-width: 768px){.objectives-page{padding:1rem}.objectives-header h1{font-size:2rem}.objectives-tabs{flex-direction:column;align-items:center}.tab-button{width:100%;max-width:300px}.objectives-grid{grid-template-columns:1fr}}.overlay-root{position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;font-family:Segoe UI,Inter,system-ui,-apple-system,sans-serif;color:#fff;overflow:hidden;pointer-events:none}.overlay-status{position:absolute;top:12px;left:50%;transform:translate(-50%);font-size:13px;padding:6px 16px;border-radius:20px;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);text-shadow:0 1px 3px rgba(0,0,0,.8);opacity:.8;pointer-events:auto}.overlay-status.connected{display:none}.overlay-status.error{border-color:#ef444466;color:#fca5a5}.overlay-bottom{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:flex-end;justify-content:center;padding:0 16px 8px;gap:4px}.overlay-game-info{position:absolute;top:12px;right:16px;display:flex;flex-direction:column;align-items:flex-end;gap:6px}.overlay-round{font-size:16px;font-weight:700;padding:6px 14px;border-radius:8px;background:rgba(0,0,0,.65);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(245,158,11,.3);text-shadow:0 1px 4px rgba(0,0,0,.9);letter-spacing:.5px}.overlay-round .round-label{color:#f59e0be6;font-size:11px;text-transform:uppercase;letter-spacing:1.5px;margin-right:6px}.overlay-timer{font-size:14px;font-weight:600;padding:4px 12px;border-radius:6px;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);font-variant-numeric:tabular-nums;text-shadow:0 1px 3px rgba(0,0,0,.8)}.overlay-speaker{font-size:12px;padding:3px 10px;border-radius:6px;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);text-shadow:0 1px 3px rgba(0,0,0,.8)}.overlay-speaker .speaker-icon{color:#fbbf24;margin-right:4px}.overlay-player{display:flex;flex-direction:column;align-items:center;padding:8px 6px 6px;border-radius:10px;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);min-width:130px;max-width:180px;flex:1;transition:border-color .3s ease,box-shadow .3s ease;position:relative}.overlay-player.is-active{border-color:#f59e0b80;box-shadow:0 0 12px #f59e0b40,inset 0 0 12px #f59e0b0f}.overlay-player.is-active:before{content:"▶";position:absolute;top:-8px;left:50%;transform:translate(-50%);font-size:10px;color:#f59e0b;text-shadow:0 0 6px rgba(245,158,11,.8)}.overlay-player-color{position:absolute;top:0;left:8px;right:8px;height:3px;border-radius:0 0 3px 3px}.overlay-faction-icon{width:36px;height:36px;border-radius:50%;object-fit:contain;margin-bottom:2px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.6))}.overlay-faction-name{font-size:11px;font-weight:600;text-align:center;text-shadow:0 1px 3px rgba(0,0,0,.9);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;line-height:1.2}.overlay-player-name{font-size:9px;color:#ffffff80;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;margin-bottom:4px}.overlay-score{font-size:28px;font-weight:800;line-height:1;text-shadow:0 2px 6px rgba(0,0,0,.8);margin:2px 0}.overlay-score-max{font-size:12px;font-weight:400;color:#ffffff59}.overlay-strategy-cards{display:flex;gap:3px;flex-wrap:wrap;justify-content:center;margin-top:2px}.overlay-sc{font-size:8px;font-weight:700;padding:1px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px;background:rgba(255,255,255,.12);text-shadow:0 1px 2px rgba(0,0,0,.6)}.overlay-sc.face-down{opacity:.4;text-decoration:line-through}.overlay-sc.sc-leadership{background:rgba(239,68,68,.5)}.overlay-sc.sc-diplomacy{background:rgba(249,115,22,.5)}.overlay-sc.sc-politics{background:rgba(234,179,8,.5);color:#000}.overlay-sc.sc-construction{background:rgba(34,197,94,.5)}.overlay-sc.sc-trade{background:rgba(168,85,247,.5)}.overlay-sc.sc-warfare{background:rgba(59,130,246,.5)}.overlay-sc.sc-technology{background:rgba(6,182,212,.5)}.overlay-sc.sc-imperial{background:rgba(255,255,255,.3)}.overlay-tokens{display:flex;gap:6px;margin-top:3px;font-size:9px;color:#fff9}.overlay-token{display:flex;align-items:center;gap:2px}.overlay-token-label{font-weight:600;font-size:8px;text-transform:uppercase;opacity:.6}.overlay-resources-row{display:flex;gap:8px;margin-top:2px;font-size:9px}.overlay-tg{color:#fbbf24;font-weight:700}.overlay-commodities{color:#a78bfa;font-weight:600}.overlay-laws{position:absolute;top:12px;left:16px;display:flex;flex-direction:column;gap:4px}.overlay-law{font-size:11px;padding:3px 10px;border-radius:6px;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(168,85,247,.3);color:#c4b5fd;text-shadow:0 1px 3px rgba(0,0,0,.8)}.overlay-law:before{content:"⚖ ";opacity:.6}.overlay-objectives{position:absolute;top:60px;left:16px;display:flex;flex-direction:column;gap:3px;max-width:320px}.overlay-obj-section-label{font-size:9px;text-transform:uppercase;letter-spacing:1.5px;color:#fff6;margin-top:4px}.overlay-obj{font-size:10px;padding:2px 8px;border-radius:4px;background:rgba(0,0,0,.45);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.06);text-shadow:0 1px 2px rgba(0,0,0,.8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.overlay-obj.stage1{border-left:2px solid rgba(234,179,8,.6)}.overlay-obj.stage2{border-left:2px solid rgba(59,130,246,.6)}.player-color-white{color:#e5e7eb}.player-color-blue{color:#60a5fa}.player-color-purple{color:#a78bfa}.player-color-yellow{color:#fbbf24}.player-color-red{color:#f87171}.player-color-green{color:#34d399}.player-color-orange{color:#fb923c}.player-color-pink{color:#f472b6}.bg-white{background-color:#e5e7eb}.bg-blue{background-color:#60a5fa}.bg-purple{background-color:#a78bfa}.bg-yellow{background-color:#fbbf24}.bg-red{background-color:#f87171}.bg-green{background-color:#34d399}.bg-orange{background-color:#fb923c}.bg-pink{background-color:#f472b6}.overlay-demo-badge{position:absolute;top:12px;left:50%;transform:translate(-50%);font-size:11px;padding:4px 12px;border-radius:12px;background:rgba(234,179,8,.2);border:1px solid rgba(234,179,8,.4);color:#fbbf24;letter-spacing:1px;text-transform:uppercase;font-weight:600}.overlay-config-toggle{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:#ffffff80;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;pointer-events:auto;transition:all .2s;z-index:100}.overlay-config-toggle:hover{background:rgba(255,255,255,.15);color:#fff}.overlay-config-panel{position:absolute;top:42px;right:8px;width:260px;padding:12px 16px;border-radius:10px;background:rgba(0,0,0,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);pointer-events:auto;z-index:99;display:flex;flex-direction:column;gap:8px}.overlay-config-panel label{display:flex;align-items:center;gap:8px;font-size:12px;cursor:pointer;color:#fffc}.overlay-config-panel label:hover{color:#fff}.overlay-config-panel input[type=checkbox]{accent-color:#f59e0b}.overlay-config-panel h4{margin:0;font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:#f59e0bb3;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:4px}.overlay-config-panel .config-url{font-size:11px;padding:4px 8px;border-radius:4px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#fff;width:100%;box-sizing:border-box;font-family:monospace}.app{min-height:100vh}*{scrollbar-width:thin;scrollbar-color:var(--accent) rgba(245,158,11,.1)}*::-webkit-scrollbar{width:12px;height:12px}*::-webkit-scrollbar-track{background:rgba(245,158,11,.1);border-radius:6px}*::-webkit-scrollbar-thumb{background:var(--accent);border-radius:6px;border:2px solid rgba(0,0,0,.3);box-shadow:0 0 6px #f59e0b80}*::-webkit-scrollbar-thumb:hover{background:var(--accent-bright);box-shadow:0 0 10px #f59e0bcc}*::-webkit-scrollbar-thumb:active{background:var(--accent)}*::-webkit-scrollbar-corner{background:rgba(245,158,11,.1)}input[type=checkbox],input[type=radio]{margin:0;flex-shrink:0}label:has(input[type=checkbox]),label:has(input[type=radio]){display:inline-flex;align-items:center;gap:.4rem;cursor:pointer}.data-manager-page{padding:20px;max-width:1400px;margin:0 auto}.data-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid var(--border-medium)}.data-manager-header h1{margin:0;font-size:1.8rem}.btn-back{padding:8px 16px;background:var(--bg-elevated);color:var(--text-primary);border:none;border-radius:4px;cursor:pointer}.btn-back:hover{background:var(--overlay-heavy)}.data-manager-tabs{display:flex;gap:10px;margin-bottom:20px}.data-manager-tabs button{padding:10px 20px;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border-medium);border-radius:4px;cursor:pointer}.data-manager-tabs button.active{background:var(--info);color:var(--card-text);border-color:var(--info)}.data-manager-tabs button:disabled{opacity:.5;cursor:not-allowed}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.btn-primary{padding:8px 20px;background:#4a9eff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600}.btn-primary:hover{background:#3a8eef}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-cancel{padding:8px 20px;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-medium);border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600}.btn-cancel:hover{background:var(--overlay-medium)}.actions-cell{white-space:nowrap}.btn-edit,.btn-delete{padding:4px 12px;border:none;border-radius:4px;cursor:pointer;font-size:.78rem;font-weight:600}.btn-edit{background:rgba(74,158,255,.15);color:#4a9eff;border:1px solid rgba(74,158,255,.3);margin-right:6px}.btn-edit:hover{background:rgba(74,158,255,.25)}.btn-delete{background:rgba(239,68,68,.15);color:#f87171;border:1px solid rgba(239,68,68,.3)}.btn-delete:hover{background:rgba(239,68,68,.25)}.data-table{width:100%;border-collapse:collapse;background:var(--bg-surface);border-radius:8px;overflow:hidden}.data-table th,.data-table td{padding:12px;text-align:left;border-bottom:1px solid var(--border-medium)}.data-table th{background:var(--bg-elevated);font-weight:600}.data-table tr:hover{background:var(--overlay-light)}.effect-cell{max-width:300px;font-size:.9rem;line-height:1.4}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-content{background:var(--bg-surface);border-radius:8px;border:1px solid var(--border-medium);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;padding:24px}.modal-content.tech-form.enhanced{max-width:1200px;width:95vw;max-height:90vh;background:var(--bg-surface);border:1px solid var(--border-medium);border-radius:8px;box-shadow:0 20px 60px #00000080;padding:0}.relic-form h3{margin-top:0;margin-bottom:20px;color:var(--info)}.relic-form label{display:block;margin-bottom:5px;color:var(--text-secondary);font-size:.9rem}.relic-form input,.relic-form textarea,.relic-form select{width:100%;padding:10px;margin-bottom:15px;background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:4px;color:var(--text-primary);font-size:1rem}.data-manager-page input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;min-width:18px;background:var(--bg-elevated);border:2px solid var(--border-medium);border-radius:4px;cursor:pointer;position:relative;transition:background .15s,border-color .15s;vertical-align:middle;margin:0}.data-manager-page input[type=checkbox]:hover{border-color:var(--info);background:var(--overlay-medium)}.data-manager-page input[type=checkbox]:checked{background:var(--info);border-color:var(--info)}.data-manager-page input[type=checkbox]:checked:after{content:"";position:absolute;left:4px;top:1px;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.data-manager-page input[type=checkbox]:focus-visible{outline:2px solid #4a9eff;outline-offset:2px}.data-manager-page input[type=checkbox]:disabled{opacity:.4;cursor:not-allowed}.data-manager-page label:has(>input[type=checkbox]),.data-manager-page label:has(input[type=checkbox]:first-child){display:inline-flex;align-items:center;gap:8px;cursor:pointer;color:#ccc;font-size:.9rem;-webkit-user-select:none;user-select:none}.relic-form input[type=checkbox]{width:18px;margin-right:0}.form-actions{display:flex;gap:10px;margin-top:20px}.error{color:var(--danger);padding:10px;background:rgba(239,68,68,.1);border-radius:4px}.config-section .section-header{display:flex;justify-content:space-between;align-items:center}.filter-controls{display:flex;align-items:center;gap:10px}.filter-controls select{padding:6px 12px;background:#2a2a2a;border:1px solid #444;border-radius:4px;color:var(--text-primary);font-size:.9rem}.config-help{color:var(--text-muted);font-size:.9rem;margin-bottom:15px;padding:10px;background:var(--bg-surface);border-radius:4px;border-left:3px solid var(--info)}.config-table .key-cell code{background:var(--bg-elevated);padding:4px 8px;border-radius:4px;font-family:Consolas,Monaco,monospace;font-size:.85rem;color:var(--info)}.category-badge{padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.category-prompt{background:rgba(139,92,246,.2);color:#a78bfa;border:1px solid rgba(139,92,246,.3)}.category-mapping{background:rgba(34,197,94,.2);color:#4ade80;border:1px solid rgba(34,197,94,.3)}.category-search{background:rgba(59,130,246,.2);color:#60a5fa;border:1px solid rgba(59,130,246,.3)}.category-template{background:rgba(245,158,11,.2);color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.category-config{background:rgba(156,163,175,.2);color:#9ca3af;border:1px solid rgba(156,163,175,.3)}.value-preview{font-family:Consolas,Monaco,monospace;font-size:.8rem;color:var(--text-muted);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.date-cell{font-size:.85rem;color:var(--text-muted);white-space:nowrap}.modal-wide{max-width:700px}.config-form h3{margin-top:0;margin-bottom:20px;color:var(--info)}.config-form .form-row{margin-bottom:15px}.config-form label{display:block;margin-bottom:5px;color:var(--text-secondary);font-size:.9rem}.config-form input,.config-form textarea,.config-form select{width:100%;padding:10px;background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:4px;color:var(--text-primary);font-size:1rem}.config-form input:disabled{background:var(--bg-surface);color:var(--text-muted);cursor:not-allowed}.config-form .value-textarea{font-family:Consolas,Monaco,monospace;font-size:.9rem;line-height:1.4}.config-form .help-text{display:block;color:var(--text-muted);font-size:.8rem;margin-top:5px}.radio-group{display:flex;gap:20px}.radio-group label{display:flex;align-items:center;gap:6px;cursor:pointer;color:var(--text-primary)!important}.radio-group input[type=radio]{width:auto;margin:0 8px 0 0}.dm-grid-dashboard{display:flex;flex-direction:column;gap:1.5rem}.dm-category-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin:0 0 .75rem}.dm-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.dm-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1.25rem 1rem;background:var(--bg-surface);border:1px solid var(--border-medium);border-top:3px solid var(--border-medium);border-radius:10px;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;position:relative}.dm-card:hover{background:var(--bg-elevated);border-color:var(--overlay-heavy);transform:translateY(-2px)}.dm-card:active{transform:translateY(0)}.dm-card-disabled{opacity:.4;cursor:not-allowed}.dm-card-disabled:hover{background:var(--bg-surface);border-color:var(--border-medium);transform:none}.dm-card-label{font-size:.9rem;font-weight:600;color:var(--text-primary);text-align:center}.dm-card-badge{position:absolute;top:6px;right:6px;font-size:.6rem;font-weight:700;text-transform:uppercase;padding:2px 6px;border-radius:4px;background:rgba(245,158,11,.15);color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.dm-item-list{display:flex;flex-direction:column;gap:.5rem}.dm-item-card{background:var(--bg-surface);border:1px solid var(--border-medium);border-radius:8px;padding:.75rem 1rem;transition:border-color .15s}.dm-item-card:hover{border-color:var(--overlay-heavy)}.dm-item-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem;flex-wrap:wrap}.dm-item-card-name{font-weight:700;font-size:1rem;color:var(--text-primary)}.dm-item-card-body{font-size:.88rem;line-height:1.5;color:var(--text-secondary)}.dm-item-card-body p{margin:.25rem 0}.dm-item-card-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-top:.4rem;font-size:.78rem;color:var(--text-muted)}.dm-item-card-actions{display:flex;gap:.5rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--divider)}.dm-badge{display:inline-block;padding:1px 8px;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap}.dm-badge-law{background:rgba(245,158,11,.15);color:#fbbf24;border:1px solid rgba(245,158,11,.25)}.dm-badge-directive{background:rgba(96,165,250,.15);color:#60a5fa;border:1px solid rgba(96,165,250,.25)}.dm-badge-expansion{background:rgba(156,163,175,.12);color:#9ca3af;border:1px solid rgba(156,163,175,.2)}.dm-badge-removed{background:rgba(239,68,68,.12);color:#f87171;border:1px solid rgba(239,68,68,.2)}.dm-badge-omega{background:rgba(168,85,247,.15);color:#a855f7;border:1px solid rgba(168,85,247,.25)}.dm-badge-legendary{background:rgba(245,158,11,.15);color:#fbbf24;border:1px solid rgba(245,158,11,.25)}.dm-badge-notes{background:rgba(96,165,250,.12);color:#60a5fa;border:1px solid rgba(96,165,250,.2);cursor:help}.dm-badge-cultural{background:rgba(59,130,246,.15);color:#93c5fd;border:1px solid rgba(59,130,246,.25)}.dm-badge-industrial{background:rgba(34,197,94,.15);color:#86efac;border:1px solid rgba(34,197,94,.25)}.dm-badge-hazardous{background:rgba(239,68,68,.15);color:#fca5a5;border:1px solid rgba(239,68,68,.25)}.dm-badge-home{background:rgba(168,85,247,.15);color:#c084fc;border:1px solid rgba(168,85,247,.25)}.dm-for-against strong{font-size:.8rem}.dm-for-against .dm-for{color:#4ade80}.dm-for-against .dm-against{color:#f87171}.faction-form .modal-wide{max-width:900px}.faction-form .form-tabs{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:20px;border-bottom:1px solid #444;padding-bottom:10px}.faction-form .form-tabs button{padding:8px 16px;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border-medium);border-radius:4px;cursor:pointer;font-size:.85rem}.faction-form .form-tabs button.active{background:var(--info);color:var(--card-text);border-color:var(--info)}.faction-form .form-content{max-height:60vh;overflow-y:auto;padding-right:10px}.faction-form .tab-content{display:flex;flex-direction:column;gap:15px}.faction-form .tab-content h4{margin:15px 0 10px;color:var(--info);font-size:1rem;border-bottom:1px solid var(--border-medium);padding-bottom:5px}.faction-form .form-row{display:flex;gap:15px;flex-wrap:wrap}.faction-form .form-field{flex:1;min-width:150px}.faction-form .form-field label{display:block;margin-bottom:5px;color:var(--text-secondary);font-size:.85rem}.faction-form input,.faction-form textarea,.faction-form select{width:100%;padding:8px 10px;background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:4px;color:var(--text-primary);font-size:.95rem}.faction-form input:focus,.faction-form textarea:focus,.faction-form select:focus{outline:none;border-color:var(--info)}.array-item{display:flex;gap:8px;align-items:center;margin-bottom:8px;flex-wrap:wrap}.array-item input[type=text],.array-item input[type=number]{flex:1}.array-item input[type=number]{min-width:60px;flex:0}.array-item label{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.array-item input[type=checkbox]{width:auto}.complex-item{background:var(--bg-elevated);padding:12px;border-radius:6px;margin-bottom:10px;border:1px solid var(--border-medium)}.complex-item .form-row{margin-bottom:8px}.unit-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:10px;margin-bottom:15px}.unit-stats input{width:100%}.starting-units{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.unit-count{display:flex;flex-direction:column}.unit-count label{font-size:.75rem;color:var(--text-muted);text-transform:capitalize;margin-bottom:3px}.unit-count input{width:100%}.leader-form{background:var(--bg-elevated);padding:15px;border-radius:6px;margin-bottom:15px;border:1px solid var(--border-medium)}.leader-form input,.leader-form textarea{margin-bottom:10px}.promissory-form,.breakthrough-form{background:var(--bg-elevated);padding:15px;border-radius:6px;border:1px solid var(--border-medium)}.promissory-form input,.promissory-form textarea,.breakthrough-form input,.breakthrough-form textarea{margin-bottom:10px}.string-array{display:flex;flex-direction:column;gap:5px}.string-array .array-item{display:flex;gap:8px}.string-array .array-item input{flex:1}.btn-secondary{padding:6px 16px;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-medium);border-radius:4px;cursor:pointer;font-size:.85rem}.btn-secondary:hover{background:var(--overlay-medium)}.btn-add{padding:4px 12px;background:#2a4a2a;color:#6abf6a;border:1px solid #3a5a3a;border-radius:4px;cursor:pointer;font-size:.8rem;align-self:flex-start}.btn-add:hover{background:#3a5a3a}@media (max-width: 768px){.data-manager-page{padding:10px}.data-manager-header{flex-direction:column;align-items:flex-start;gap:10px}.data-manager-header h1{font-size:1.3rem}.dm-card-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.dm-card{padding:1rem .75rem}.dm-card-label{font-size:.8rem}.dm-item-card{padding:.6rem .75rem}.dm-item-card-name{font-size:.95rem}.dm-item-card-body{font-size:.85rem}.dm-item-card-actions{gap:.5rem}.dm-item-card-actions .btn-edit,.dm-item-card-actions .btn-delete{flex:1;padding:8px 12px;text-align:center;font-size:.85rem}.section-header{flex-direction:column;align-items:flex-start;gap:10px}.data-table thead{display:none}.data-table,.data-table tbody,.data-table tr,.data-table td{display:block;width:100%}.data-table tr{margin-bottom:12px;background:var(--bg-surface);border-radius:8px;border:1px solid var(--border-medium);padding:10px}.data-table tr:hover{background:var(--overlay-light)}.data-table td{padding:4px 0;border-bottom:none;text-align:left}.data-table td:before{content:attr(data-label);display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.effect-cell{max-width:none!important}.actions-cell{display:flex;gap:8px;padding-top:8px!important;border-top:1px solid var(--border-medium);margin-top:6px}.btn-edit,.btn-delete{flex:1;padding:8px 12px;text-align:center;font-size:.85rem}.modal-overlay{padding:0;align-items:stretch}.modal-content,.modal-wide{max-width:100%;max-height:100vh;border-radius:0;border:none;padding:16px}.relic-form input,.relic-form textarea,.relic-form select,.config-form input,.config-form textarea,.config-form select,.faction-form input,.faction-form textarea,.faction-form select{padding:12px;font-size:16px}.relic-form label,.config-form label,.faction-form .form-field label{font-size:.85rem}.relic-form>div[style*="display: flex"],.faction-form .form-row{flex-direction:column!important;gap:0!important}.form-actions{flex-direction:column}.form-actions button{width:100%;padding:12px;font-size:1rem}.filter-controls{flex-direction:column;align-items:stretch;width:100%}.filter-controls select{width:100%;padding:10px;font-size:16px}.faction-form .form-tabs{gap:4px}.faction-form .form-tabs button{padding:6px 10px;font-size:.75rem}.faction-form .form-content{max-height:70vh}.array-item{flex-direction:column;align-items:stretch}.unit-stats,.starting-units{grid-template-columns:repeat(3,1fr)}.value-preview{white-space:normal;max-width:none}.category-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:0;padding-bottom:0}.category-tabs::-webkit-scrollbar{display:none}.tab-btn{padding:.5rem .75rem;font-size:.8rem;white-space:nowrap;flex-shrink:0}.tech-grid{grid-template-columns:1fr}.tech-header{flex-direction:column;gap:.5rem}.tech-header h3{font-size:1rem}.tech-badges{gap:.25rem}.tech-card{padding:.75rem}.tech-text{font-size:.875rem}.card-actions{flex-direction:row;gap:.5rem;margin-top:.75rem}.card-actions .btn{flex:1;padding:8px 12px;text-align:center;font-size:.85rem}.tech-form{max-width:100%;width:100%;max-height:100vh;border-radius:0}.form-row{grid-template-columns:1fr}.form-group input,.form-group select,.form-group textarea{padding:12px;font-size:16px}.modal-actions{flex-direction:column}.modal-actions button{width:100%;padding:12px;font-size:1rem}.objectives-table table thead{display:none}.objectives-table table,.objectives-table table tbody,.objectives-table table tr,.objectives-table table td{display:block;width:100%}.objectives-table table tr{margin-bottom:12px;background:var(--card-bg, #1e1e1e);border-radius:8px;border:1px solid var(--border, #333);padding:10px}.objectives-table table td{padding:3px 0;border-bottom:none;text-align:left;font-size:.875rem}.objectives-table table td:first-child{font-weight:600;font-size:.7rem;color:var(--text-muted, #888);text-transform:uppercase}.objectives-table table td:nth-child(2){font-weight:600;font-size:1rem}.objectives-table .btn{padding:8px 12px;font-size:.85rem}.data-manager-form{padding:1rem}.data-manager-form .form-grid{grid-template-columns:1fr}.data-manager-form input,.data-manager-form select,.data-manager-form textarea{padding:12px;font-size:16px}.data-manager-form .form-actions{flex-direction:column}.data-manager-form .form-actions button{width:100%;padding:12px}.manager-header{flex-direction:column;align-items:flex-start;gap:.75rem}.manager-header h2{font-size:1.2rem}.manager-header .btn{width:100%;text-align:center}}.tech-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1rem;margin-top:1rem}.tech-card{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:1rem;display:flex;flex-direction:column}.tech-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.75rem}.tech-header h3{margin:0;font-size:1.1rem;color:var(--text)}.tech-badges{display:flex;gap:.5rem;flex-wrap:wrap}.tech-type{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.tech-biotic{background:#22c55e;color:#fff}.tech-propulsion{background:#3b82f6;color:#fff}.tech-cybernetic{background:#eab308;color:#000}.tech-warfare{background:#ef4444;color:#fff}.tech-level{padding:.25rem .5rem;background:var(--muted);border-radius:4px;font-size:.75rem;font-weight:600}.tech-omega{padding:.25rem .5rem;background:#8b5cf6;color:#fff;border-radius:4px;font-size:.75rem;font-weight:700}.tech-details{flex:1;display:flex;flex-direction:column;gap:.5rem}.tech-text{margin:0;color:var(--text);line-height:1.4}.unit-stats,.faction-info{background:var(--muted);padding:.5rem;border-radius:4px;font-size:.875rem}.unit-stats div,.faction-info div{margin-bottom:.25rem}.prerequisites{font-size:.875rem;color:var(--text-muted)}.admin-notes{font-size:.875rem;color:var(--text-muted);font-style:italic;margin-top:auto}.tech-form{max-width:800px;width:90vw;max-height:90vh;overflow-y:auto}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-group{display:flex;flex-direction:column;gap:.25rem}.form-group label{font-weight:600;color:var(--text)}.form-group input,.form-group select,.form-group textarea{padding:.5rem;border:1px solid var(--border);border-radius:4px;background:var(--input-bg);color:var(--text)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary)}.form-group.checkbox{flex-direction:row;align-items:center}.form-group.checkbox input{margin-right:.5rem}.form-group small{color:var(--text-muted);font-size:.875rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.tech-form-layout{display:grid;grid-template-columns:1fr 400px;gap:2rem;height:calc(90vh - 120px)}.tech-form-column{display:flex;flex-direction:column;overflow-y:auto;padding:1.5rem}.modal-content.tech-form.enhanced .modal-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-content.tech-form.enhanced .error{margin:0 1.5rem 1.5rem;padding:1rem;background:rgba(239,68,68,.1);border:1px solid var(--danger);border-radius:6px;color:var(--danger)}.form-section-nav{display:flex;gap:.5rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border);flex-wrap:wrap}.section-nav-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:.9rem;box-shadow:0 1px 3px #0000001a}.section-nav-btn:hover{background:var(--overlay-medium);color:var(--text)}.section-nav-btn.active{background:var(--info);color:#fff;border-color:var(--info)}.section-icon{font-size:1.1rem}.form-section{animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tech-type-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.tech-type-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:transparent;border:2px solid;border-radius:6px;cursor:pointer;transition:all .2s;font-weight:500}.tech-type-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.tech-type-btn.active{transform:translateY(-1px);box-shadow:0 2px 12px #00000026}.tech-type-swatch{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.2)}.unit-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.form-group input.error,.form-group textarea.error,.form-group select.error{border-color:var(--danger)}.error-text{display:block;color:var(--danger);font-size:.8rem;margin-top:.25rem}.form-group small{display:block;color:var(--text-muted);font-size:.8rem;margin-top:.25rem}.form-group.checkbox label{display:flex;flex-direction:column;gap:.5rem;cursor:pointer}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-weight:500}.tech-preview-column{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:1.5rem;margin:1.5rem;margin-top:0;overflow-y:auto;position:sticky;top:0;box-shadow:0 2px 8px #0000001a}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.preview-header h4{margin:0;font-size:1.1rem;color:var(--text-primary)}.preview-badge{background:var(--info);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.faction-selector,.faction-input-wrapper{position:relative}.faction-input{width:100%;padding:.5rem 2.5rem .5rem .5rem;border:1px solid var(--border);border-radius:4px;background:var(--input-bg);color:var(--text);font-size:1rem}.faction-input:focus{outline:none;border-color:var(--primary)}.faction-icon-input{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%}.faction-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;box-shadow:0 8px 24px #0003;max-height:200px;overflow-y:auto;z-index:100;margin-top:.25rem}.faction-option{display:flex;align-items:center;gap:.75rem;padding:.75rem;cursor:pointer;transition:background .2s}.faction-option:hover{background:var(--overlay-light)}.faction-icon-option{width:24px;height:24px;border-radius:50%}.faction-icon-placeholder{width:24px;height:24px;border-radius:50%;background:var(--overlay-medium);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:var(--text-muted)}.faction-name{flex:1;font-weight:500}.faction-key{font-size:.8rem;color:var(--text-muted)}.faction-no-results{padding:1rem;text-align:center;color:var(--text-muted);font-style:italic}@media (max-width: 1024px){.tech-form-layout{grid-template-columns:1fr;height:auto}.tech-preview-column{position:static;margin-top:1rem}}@media (max-width: 640px){.tech-form.enhanced{width:100vw;max-height:100vh;border-radius:0}.tech-type-selector{grid-template-columns:1fr}.unit-stats-grid{grid-template-columns:repeat(2,1fr)}.form-section-nav{flex-direction:column}.section-nav-btn{justify-content:center}}.category-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:1px solid var(--border)}.tab-btn{padding:.5rem 1rem;background:none;border:none;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.card-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.card-item{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:1rem;display:flex;justify-content:space-between;align-items:center}.card-content{flex:1}.card-title{font-weight:600;color:var(--text);margin-bottom:.25rem}.card-subtitle{color:var(--text-muted);font-size:.875rem}.card-meta{display:flex;gap:1rem;margin-top:.5rem}.card-meta-item{color:var(--text-muted);font-size:.875rem}.loading{text-align:center;padding:2rem;color:var(--text-muted)}.error{background:#dc2626;color:#fff;padding:1rem;border-radius:4px;margin-bottom:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--card-bg);border-radius:8px;padding:1.5rem;width:90vw;max-width:600px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.modal-header h3{margin:0;color:var(--text)}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:var(--text)}.faction-group{margin-bottom:2rem;background:var(--bg-surface);border-radius:8px;border:1px solid var(--border-medium);overflow:hidden}.faction-group-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--bg-elevated);border-bottom:1px solid var(--border-medium)}.faction-icon{width:48px;height:48px;border-radius:8px;object-fit:cover;border:2px solid var(--border-medium)}.faction-icon-placeholder{width:48px;height:48px;border-radius:8px;background:var(--overlay-medium);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:var(--text-muted);border:2px solid var(--border-medium)}.faction-group-header h3{margin:0;flex:1;color:var(--text-primary);font-size:1.2rem}.tech-count{color:var(--text-muted);font-size:.9rem;background:var(--overlay-light);padding:.25rem .75rem;border-radius:12px}.faction-tech-list{padding:1rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.faction-tech-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:6px;padding:1rem}.faction-tech-card .tech-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.faction-tech-card .tech-header h4{margin:0;font-size:1rem;color:var(--text-primary);flex:1}.faction-tech-card .tech-badges{display:flex;gap:.5rem;align-items:center}.faction-tech-card .tech-details{margin-bottom:1rem}.faction-tech-card .tech-text{margin:0 0 .75rem;font-size:.9rem;color:var(--text-secondary);line-height:1.4}.faction-tech-card .prerequisites{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem}.faction-tech-card .admin-notes{font-size:.85rem;color:var(--text-muted);font-style:italic}.faction-tech-card .card-actions{display:flex;gap:.5rem}.faction-tech-card .card-actions .btn{padding:.375rem .75rem;font-size:.875rem}:root{--bg-deep: #0a0e1a;--bg-surface: #111827;--bg-elevated: #1e293b;--accent: #f59e0b;--accent-bright: #fbbf24;--accent-dim: #b45309;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--success: #22c55e;--danger: #ef4444;--info: #3b82f6;--phase-setup: #f59e0b;--phase-strategy: #3b82f6;--phase-action: #22c55e;--phase-status: #a855f7;--phase-agenda: #ef4444;--border-subtle: rgba(245, 158, 11, .15);--border-medium: rgba(245, 158, 11, .3);--surface-glass: rgba(17, 24, 39, .8);--overlay-light: rgba(255, 255, 255, .06);--overlay-medium: rgba(255, 255, 255, .1);--overlay-heavy: rgba(255, 255, 255, .2);--card-text: #ffffff;--card-text-soft: rgba(255, 255, 255, .88);--card-text-dim: rgba(255, 255, 255, .45);--divider: rgba(255, 255, 255, .04);--scrollbar: rgba(255, 255, 255, .2)}:root[data-theme=light]{--bg-deep: #f1f5f9;--bg-surface: #ffffff;--bg-elevated: #e2e8f0;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--border-subtle: rgba(0, 0, 0, .08);--border-medium: rgba(0, 0, 0, .15);--surface-glass: rgba(255, 255, 255, .8);--overlay-light: rgba(0, 0, 0, .04);--overlay-medium: rgba(0, 0, 0, .07);--overlay-heavy: rgba(0, 0, 0, .12);--card-text: #1e293b;--card-text-soft: rgba(0, 0, 0, .78);--card-text-dim: rgba(0, 0, 0, .45);--divider: rgba(0, 0, 0, .06);--scrollbar: rgba(0, 0, 0, .15)}*{box-sizing:border-box}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;margin:0;padding:2rem;background:transparent;color:var(--text-primary);min-height:100vh;font-size:18px;line-height:1.6}.main-title{color:var(--accent);text-align:center;font-size:1.5rem;margin-bottom:.5rem;text-shadow:0 0 30px rgba(245,158,11,.4);font-weight:700}.section-header{color:var(--text-primary);font-size:2rem;margin-bottom:1.5rem;border-bottom:2px solid var(--accent-dim);padding-bottom:.5rem;text-shadow:0 0 15px rgba(245,158,11,.3)}.subsection-header{color:var(--text-secondary);font-size:1.5rem;margin-bottom:1rem}.mainNav{display:flex;gap:1rem;margin-bottom:2rem;justify-content:center;flex-wrap:wrap}.navBtn{background:rgba(245,158,11,.1);border:2px solid var(--accent);color:var(--text-primary);padding:1rem 2rem;border-radius:8px;cursor:pointer;font-size:1.1rem;font-weight:600;transition:all .3s ease}.navBtn:hover{background:rgba(245,158,11,.2);transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b66}.navBtn.active{background:var(--accent);color:#000;box-shadow:0 0 20px #f59e0b99}.screen{display:none;background:var(--bg-surface);border-radius:12px;padding:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-subtle);box-shadow:0 0 30px #f59e0b0d}.screen.active{display:block}.setupControls{margin-bottom:2rem;text-align:center}.playersSetup{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;margin-bottom:2rem}.setupPlayer{background:var(--bg-elevated);padding:1rem;border-radius:8px;border:1px solid var(--border-medium);font-size:1.2rem;display:flex;justify-content:space-between;align-items:center}.addPlayerRow{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;align-items:center}input:not([type=checkbox]):not([type=radio]),select{padding:.8rem 1rem;border-radius:8px;border:2px solid var(--bg-elevated);background:var(--bg-deep);color:var(--text-primary);font-size:1rem;min-width:200px}input:not([type=checkbox]):not([type=radio]):focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #f59e0b33}button{background:var(--accent);border:none;padding:.8rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;color:#000;transition:all .3s ease;box-shadow:0 4px 6px #0000004d}button:hover{background:var(--accent-bright);transform:translateY(-2px);box-shadow:0 6px 12px #f59e0b66}button:disabled{background:var(--bg-elevated);color:var(--text-muted);cursor:not-allowed;transform:none;opacity:.5}button.primary{background:var(--accent);font-size:1.2rem;padding:1rem 2rem;box-shadow:0 0 20px #f59e0b66}button.primary:hover{background:var(--accent-bright);box-shadow:0 0 30px #f59e0b99}.custom-dropdown{position:relative;min-width:250px;font-size:1rem}.dropdown-selected{padding:.8rem 1rem;border-radius:8px;border:2px solid var(--bg-elevated);background:var(--bg-deep);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:all .3s ease}.dropdown-selected:hover{border-color:var(--accent);box-shadow:0 0 0 3px #f59e0b33}.dropdown-selected.active{border-color:var(--accent);box-shadow:0 0 0 3px #f59e0b4d}.dropdown-options{position:absolute;top:100%;left:0;right:0;background:var(--bg-elevated);border:2px solid var(--accent);border-radius:8px;margin-top:.5rem;max-height:300px;overflow-y:auto;z-index:1000;display:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dropdown-options.show{display:block}.dropdown-option{padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid var(--divider)}.dropdown-option:last-child{border-bottom:none}.dropdown-option:hover{background:rgba(245,158,11,.15)}.dropdown-option.disabled:hover{background:transparent}.dropdown-option.selected{background:rgba(245,158,11,.2);color:var(--accent)}.dropdown-group-label{padding:.5rem 1rem;background:var(--bg-surface);color:var(--text-secondary);font-size:.9rem;font-weight:600;border-bottom:1px solid var(--divider)}.dropdown-faction-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:10px;border:1px solid var(--overlay-heavy);flex-shrink:0}.dropdown-faction-name{flex:1}.faction-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;border:2px solid rgba(255,255,255,.3);box-shadow:0 2px 4px #0003}.hint{color:var(--text-secondary);font-style:italic;text-align:center;margin-top:1rem}.grid-layout{display:grid;gap:1rem}.grid-auto-fit{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.flex-center{display:flex;align-items:center;justify-content:center}.flex-column{display:flex;flex-direction:column}.flex-row{display:flex;flex-direction:row}.text-center{text-align:center}.text-uppercase{text-transform:uppercase}.font-bold{font-weight:700}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.gap-4{gap:2rem}.card{background:var(--bg-surface);border-radius:8px;padding:1rem;border:1px solid var(--border-subtle)}.card-header{border-bottom:1px solid var(--border-subtle);padding-bottom:.5rem;margin-bottom:1rem}.status-active{color:var(--success)}.status-inactive{color:var(--text-muted)}.status-warning{color:var(--accent-bright)}.status-error{color:var(--danger)}.clickable{cursor:pointer;transition:all .3s ease}.clickable:hover{transform:translateY(-2px)}.disabled{opacity:.5;cursor:not-allowed}.text-accent{color:var(--accent)}.text-accent-bright{color:var(--accent-bright)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.bg-accent{background-color:var(--accent)}.bg-accent-subtle{background-color:#f59e0b1a}.border-accent{border-color:var(--accent)}.shadow-accent{box-shadow:0 0 20px #f59e0b66}.glow-accent{text-shadow:0 0 15px rgba(245,158,11,.4)}@media (max-width: 768px){body{padding:.5rem;font-size:16px}h1{font-size:2rem}.screen{padding:1rem}input:not([type=checkbox]):not([type=radio]),select{min-width:0;width:100%}.custom-dropdown{min-width:0;width:100%}.addPlayerRow{flex-direction:column;gap:.5rem}.addPlayerRow>*{width:100%}.setupControls{flex-direction:column;align-items:stretch}button{white-space:nowrap;min-width:0}}
