*{margin:0;padding:0;box-sizing:border-box}
:root{--bg-primary:#0d1117;--bg-secondary:#161b22;--bg-tertiary:#21262d;--text-primary:#f0f6fc;--text-secondary:#8b949e;--text-muted:#656d76;--accent-blue:#58a6ff;--accent-purple:#a5a5ff;--accent-green:#3fb950;--border-default:#30363d;--border-muted:#21262d;--shadow-default:0 8px 24px #0000004d;--shadow-strong:0 16px 48px #0006}
body.theme-2006{--bg-primary:#fff;--bg-secondary:#fff;--bg-tertiary:#f8f8f8;--text-primary:#000;--text-secondary:#333;--text-muted:#666;--accent-blue:#00f;--accent-purple:navy;--accent-green:green;--border-default:navy;--border-muted:#ccc;--shadow-default:0 2px 4px #0000001a;--shadow-strong:0 4px 8px #0003}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden;position:relative}
body.theme-2006{font-family:'Verdana',Arial,sans-serif;background:var(--bg-primary)}
body.theme-2006 .navbar{background:var(--bg-secondary);border-bottom:2px solid var(--border-default)}
body.theme-2006 .navbar-link.active{color:var(--accent-purple);background:#0000801a}
body.theme-2006 .navbar-link.active::after{background:var(--accent-purple)}
body.theme-2006 .main-content{background:var(--bg-secondary);border:2px solid var(--border-default);border-radius:0;box-shadow:none}
body.theme-2006 .title{color:var(--accent-purple);font-family:'Verdana',Arial,sans-serif;font-weight:700}
body.theme-2006 .subtitle{font-family:'Verdana',Arial,sans-serif;color:var(--text-secondary)}
body.theme-2006 .alliance-input{background:var(--bg-tertiary);border:1px solid var(--border-muted);border-radius:0;font-family:'Verdana',Arial,sans-serif}
body.theme-2006 .alliance-input:hover{border-color:var(--accent-purple)}
body.theme-2006 .alliance-input:focus{border-color:var(--accent-purple)}
body.theme-2006 .alliance-input:hover + .dropdown-arrow{color:var(--accent-purple)}
body.theme-2006 .alliance-input:focus + .dropdown-arrow{color:var(--accent-purple)}
body.theme-2006 .dropdown-options.show + .dropdown-input-wrapper .dropdown-arrow{color:var(--accent-purple)}
body.theme-2006 .dropdown-options{background:var(--bg-tertiary);border:1px solid var(--border-muted);border-radius:0}
body.theme-2006 .dropdown-option:hover{background:#e0e0e0;color:var(--text-primary)}
body.theme-2006 .dropdown-option.selected{background:#e0e0e0;color:var(--text-primary);font-weight:700}
body.theme-2006 .selected-alliance-name{color:var(--accent-purple)}
body.theme-2006 .rng-button,body.theme-2006 .rng-action-button{background:linear-gradient(135deg,var(--accent-purple),#000060);color:#fff}
body.theme-2006 .rng-button:hover,body.theme-2006 .rng-action-button:hover{background:linear-gradient(135deg,#0000a0,navy)}
body.theme-2006 .action-button{background:var(--bg-tertiary);border:2px solid var(--border-default);border-radius:0;font-family:'Verdana',Arial,sans-serif}
body.theme-2006 .treaty-content{background:var(--bg-tertiary);border:1px solid var(--border-muted);border-radius:0}
body.theme-2006 .treaty-text{font-family:'Courier New',monospace}
body.theme-2006 .grid-bg{display:none}
body.theme-2006 :focus-visible{outline:2px solid var(--accent-purple)}
body.theme-2006 .theme-toggle{background:var(--bg-tertiary);border:1px solid var(--border-default);color:var(--text-secondary);font-family:'Verdana',Arial,sans-serif}
body.theme-2006 .theme-toggle:hover{border-color:var(--accent-purple);color:var(--accent-purple);background:#0000801a}
body.theme-2006 .theme-toggle.active{border-color:var(--accent-purple);color:var(--accent-purple);background:#0000801a}
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--bg-secondary);border-bottom:1px solid var(--border-default);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);height:50px;display:flex;align-items:center;justify-content:center;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}
.navbar::-webkit-scrollbar{display:none}
.navbar{-ms-overflow-style:none;scrollbar-width:none}
.navbar-content{display:flex;align-items:center;justify-content:center;gap:1.5rem;max-width:1200px;width:auto;min-width:max-content;padding:0 2rem;flex-shrink:0}
@media (max-width: 768px) {
.navbar{justify-content:flex-start;padding-left:1rem}
.navbar-content{justify-content:flex-start;padding:0 1rem;margin-left:0}
.navbar-scroll-indicator{position:fixed;top:0;right:-40px;width:80px;height:50px;background:linear-gradient(to left,var(--bg-secondary) 30%,#8b71d666 70%,transparent 100%);pointer-events:none;z-index:1001;opacity:0;transition:opacity .3s ease}
.navbar-scroll-indicator.visible{opacity:1}
}
.navbar-link{font-family:'Inter',sans-serif;font-size:.9rem;font-weight:500;color:var(--text-secondary);text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:all .3s ease;position:relative;white-space:nowrap}
.navbar-link:hover{color:var(--text-primary);background:var(--bg-tertiary)}
.navbar-link.active{color:#c9a8ff;background:#c9a8ff1a}
.navbar-link.active::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:#c9a8ff;border-radius:2px 2px 0 0}
.navbar-divider{width:1px;height:20px;background:var(--border-default);flex-shrink:0}
.theme-toggle{display:flex;align-items:center;justify-content:center;padding:.6rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:4px;color:var(--text-secondary);font-family:'JetBrains Mono',monospace;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap;opacity:.8}
.theme-toggle:hover{color:var(--text-primary);border-color:var(--accent-purple);background:#c9a8ff1a;opacity:1}
.theme-toggle.active{color:var(--accent-purple);border-color:var(--accent-purple);background:#c9a8ff1a;opacity:1}
.grid-bg{position:fixed;top:0;left:0;width:100%;height:100%;opacity:.03;z-index:-1;background-image:linear-gradient(#58a6ff1a 1px,transparent 1px),linear-gradient(90deg,#58a6ff1a 1px,transparent 1px);background-size:50px 50px;animation:gridShift 60s linear infinite}
@keyframes gridShift {
0%{transform:translate(0,0)}
100%{transform:translate(50px,50px)}
}
.container{min-height:calc(100vh - 80px);display:flex;flex-direction:column;align-items:center;padding:2rem;padding-top:calc(50px + 2rem);position:relative;z-index:1}
.header{text-align:center;margin-bottom:2.5rem;animation:slideInUp .8s ease-out}
.title-wrapper{position:relative;display:inline-block;margin-bottom:1.5rem}
.title{font-family:'Inter',sans-serif;font-size:clamp(2.5rem,7vw,4.5rem);font-weight:700;color:#c9a8ff;margin:0;letter-spacing:-.05em;line-height:1.1;position:relative}
.subtitle{font-family:'JetBrains Mono',monospace;font-size:clamp(0.9rem,2vw,1.1rem);color:var(--text-secondary);font-weight:400;letter-spacing:.05em;opacity:.9}
.main-content{width:100%;max-width:1000px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:4px;padding:3rem;margin-top:1rem;min-height:300px;display:flex;align-items:center;justify-content:center;position:relative;overflow:visible;animation:slideInUp .8s ease-out .2s both}
.generator-section{width:100%;max-width:500px;display:flex;flex-direction:column;gap:2rem}
.input-group{display:flex;flex-direction:column;align-items:center;gap:.75rem}
.input-label{font-family:'Inter',sans-serif;font-size:1.1rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}
.custom-dropdown{position:relative;width:100%}
.dropdown-input-wrapper{position:relative;width:100%;display:flex;align-items:center}
.alliance-input{width:100%;padding:1rem 3rem 1rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:4px;color:var(--text-primary);font-family:'Inter',sans-serif;font-size:1rem;transition:all .3s ease;outline:none}
.alliance-input::placeholder{color:var(--text-muted)}
.alliance-input:hover{border-color:#c9a8ff}
.alliance-input:focus{border-color:#c9a8ff}
.dropdown-arrow{position:absolute;right:1rem;color:var(--text-secondary);transition:transform .3s ease,color .3s ease;pointer-events:none}
.alliance-input:hover + .dropdown-arrow{color:#c9a8ff}
.alliance-input:focus + .dropdown-arrow{transform:rotate(180deg);color:#c9a8ff}
.dropdown-options.show + .dropdown-input-wrapper .dropdown-arrow{transform:rotate(180deg);color:#c9a8ff}
.dropdown-options{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:4px;max-height:300px;overflow-y:auto;z-index:1000;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .3s ease}
.dropdown-options.show{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-option{padding:.75rem 1rem;color:var(--text-primary);font-family:'Inter',sans-serif;font-size:.95rem;cursor:pointer;transition:all .2s ease;border-bottom:1px solid var(--border-muted)}
.dropdown-option:last-child{border-bottom:none}
.dropdown-option:hover{background:var(--bg-secondary);color:#c9a8ff}
.dropdown-option.selected{background:#c9a8ff1a;color:#c9a8ff;font-weight:500}
.dropdown-options::-webkit-scrollbar{width:8px}
.dropdown-options::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px;margin:4px}
.dropdown-options::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#c9a8ff,#8b71d6);border-radius:4px;border:1px solid var(--bg-tertiary)}
.dropdown-options::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#d4b3ff,#9b81e6)}
.dropdown-options{scrollbar-width:thin;scrollbar-color:#c9a8ff var(--bg-secondary)}
.divider{display:flex;align-items:center;margin:1rem 0;position:relative}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border-default)}
.divider-text{padding:0 1rem;font-family:'JetBrains Mono',monospace;font-size:.9rem;color:var(--text-muted);font-weight:500}
.rng-section{display:flex;flex-direction:column;align-items:center;gap:1rem}
.rng-text{font-family:'Inter',sans-serif;font-size:1.1rem;color:var(--text-secondary);margin:0}
.rng-button{display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,#8b71d6,#7c65d8);border:none;border-radius:4px;color:#fff;font-family:'Inter',sans-serif;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:60px;height:60px}
.rng-button:hover{background:linear-gradient(135deg,#9b81e6,#8c6fda)}
.rng-button:active{transform:translateY(0);box-shadow:0 2px 8px #8b71d64d}
.dice-icon{font-size:1.5em}
.rng-button:hover .dice-icon,.rng-action-button:hover .dice-icon{animation:diceRoll 1.5s ease-in-out infinite}
@keyframes diceRoll {
0%,100%{transform:rotate(0deg)}
25%{transform:rotate(90deg)}
50%{transform:rotate(180deg)}
75%{transform:rotate(270deg)}
}
.alliance-selection-phase,.action-selection-phase{opacity:1;transform:translateY(0);transition:all .5s ease-in-out}
.alliance-selection-phase.fade-out,.action-selection-phase.fade-out{opacity:0;transform:translateY(-20px)}
.alliance-selection-phase.fade-in,.action-selection-phase.fade-in{opacity:1;transform:translateY(0)}
.selected-alliance-info{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2rem;padding:1rem 1.5rem;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:8px}
.alliance-label{font-family:'Inter',sans-serif;font-size:1rem;color:var(--text-secondary);font-weight:500}
.selected-alliance-name{font-family:'Inter',sans-serif;font-size:1.1rem;color:#c9a8ff;font-weight:600;flex-grow:1;text-align:center}
.change-alliance-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-default);border-radius:4px;color:var(--text-secondary);font-family:'Inter',sans-serif;font-size:.9rem;cursor:pointer;transition:all .3s ease}
.change-alliance-btn:hover{border-color:#c9a8ff;color:#c9a8ff;background:#c9a8ff1a}
.action-buttons{display:flex;gap:1.5rem;justify-content:center;margin-bottom:2rem}
.action-button{display:flex;align-items:center;justify-content:center;padding:1.5rem 3rem;background:var(--bg-tertiary);border:2px solid var(--border-default);border-radius:4px;color:var(--text-primary);font-family:'Inter',sans-serif;cursor:pointer;transition:all .3s ease;min-width:150px}
.treaty-button:hover{border-color:#3fb950;background:#3fb9501a}
.war-button:hover{border-color:#ff6b6b;background:#ff6b6b1a}
.action-text{font-size:1.2rem;font-weight:600}
.treaty-button:hover .action-text{color:#3fb950}
.war-button:hover .action-text{color:#ff6b6b}
.rng-action-button{display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,#8b71d6,#7c65d8);border:none;border-radius:4px;color:#fff;font-family:'Inter',sans-serif;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:60px;height:60px}
.rng-action-button:hover{background:linear-gradient(135deg,#9b81e6,#8c6fda)}
.rng-action-button:active{background:linear-gradient(135deg,#7c65d8,#6d57ca)}
.treaty-display-phase{display:flex;flex-direction:column;gap:2rem;width:100%;opacity:1}
.treaty-display-phase.fade-in{animation:fadeIn .5s ease-in}
.treaty-display-phase.fade-out{animation:fadeOut .5s ease-out}
@keyframes fadeIn {
from{opacity:0;transform:translateY(10px)}
to{opacity:1;transform:translateY(0)}
}
@keyframes fadeOut {
from{opacity:1;transform:translateY(0)}
to{opacity:0;transform:translateY(-10px)}
}
.treaty-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.back-to-selection-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-default);border-radius:4px;color:var(--text-secondary);font-family:'Inter',sans-serif;font-size:.9rem;cursor:pointer;transition:all .3s ease}
.back-to-selection-btn:hover{border-color:#c9a8ff;color:#c9a8ff;background:#c9a8ff1a}
.treaty-type-label{font-family:'Inter',sans-serif;font-size:1.1rem;font-weight:600;color:#c9a8ff}
.treaty-content{background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:4px;padding:2rem;margin:1rem 0}
.treaty-text{font-family:'JetBrains Mono',monospace;font-size:.9rem;line-height:1.6;color:var(--text-primary);white-space:pre-wrap;word-wrap:break-word;margin:0}
.treaty-actions{display:flex;gap:1rem;justify-content:center}
.copy-treaty-btn,.regenerate-treaty-btn{padding:.75rem 1.5rem;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:4px;color:var(--text-primary);font-family:'Inter',sans-serif;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease}
.copy-treaty-btn:hover{border-color:#3fb950;color:#3fb950;background:#3fb9501a}
.regenerate-treaty-btn:hover{border-color:#c9a8ff;color:#c9a8ff;background:#c9a8ff1a}
@keyframes slideInUp {
from{opacity:0;transform:translateY(20px)}
to{opacity:1;transform:translateY(0)}
}
@media (max-width: 768px) {
.container{padding:1rem;padding-top:calc(50px + 1rem)}
.navbar-content{padding:0 1rem}
.navbar-link{font-size:.85rem;padding:.4rem .8rem}
.header{margin-bottom:3rem}
.main-content{padding:2rem;margin-top:1rem}
.generator-section{gap:1.5rem}
.rng-button{width:55px;height:55px;padding:.875rem}
}
@media (max-width: 480px) {
.header{margin-bottom:2rem}
.main-content{padding:1.5rem;border-radius:2px}
.generator-section{gap:1.25rem}
.input-label{font-size:1rem}
.alliance-input{padding:.875rem 2.5rem .875rem .875rem;font-size:.95rem}
.dropdown-arrow{right:.75rem}
.rng-button{width:50px;height:50px;padding:.75rem}
.action-buttons{flex-direction:column;gap:1rem}
.action-button{padding:1.25rem 2rem;min-width:120px}
.action-text{font-size:1.1rem}
.selected-alliance-info{flex-direction:column;gap:.75rem;text-align:center}
.rng-action-button{width:50px;height:50px;padding:.75rem}
.treaty-content{padding:1.5rem}
.treaty-text{font-size:.8rem;line-height:1.5}
.treaty-actions{flex-direction:column;gap:.75rem}
.copy-treaty-btn,.regenerate-treaty-btn{padding:.75rem 1rem;font-size:.9rem}
}
@media (prefers-color-scheme: dark) {
body{background:var(--bg-primary)}
}
@media (prefers-reduced-motion: reduce) {
*,::before,::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}
:focus-visible{outline:2px solid #c9a8ff;outline-offset:2px;border-radius:4px}
.footer-credit{text-align:center;margin-top:1.5rem;padding:1.5rem;font-family:'JetBrains Mono',monospace;font-size:.8rem;color:var(--text-muted);opacity:.7;transition:opacity .3s ease;border-top:1px solid var(--border-muted);position:relative}
.footer-content{display:flex;flex-direction:column;align-items:center;gap:1rem}
.footer-text{position:relative}
.footer-credit:hover{opacity:1}
.footer-default{transition:opacity .3s ease;user-select:none}
.footer-easter-egg{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;pointer-events:none;user-select:none}
@media (hover: hover) {
.footer-credit:hover .footer-default{opacity:0}
.footer-credit:hover .footer-easter-egg{opacity:1}
}
@media (hover: none) {
.footer-credit.tapped .footer-default{opacity:0}
.footer-credit.tapped .footer-easter-egg{opacity:1}
}
.heart{color:#ff6b9d;font-size:.9em;animation:heartbeat 2s ease-in-out infinite}
@keyframes heartbeat {
0%,100%{transform:scale(1)}
50%{transform:scale(1.1)}
}
::selection{background:#58a6ff33;color:var(--text-primary)}