@import "https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700&family=Inter:wght@400;600;700&display=swap";html{scrollbar-gutter:stable}:root{--c-dark:#27374d;--c-mid-dark:#526d82;--c-mid-light:#9db2bf;--c-light:#dde6ed;--bg:var(--c-dark);--surface:#526d8299;--surface-hover:#526d82cc;--border:#9db2bf33;--border-focus:var(--c-light);--accent:var(--c-light);--text-main:var(--c-light);--text-muted:var(--c-mid-light);--error:var(--c-light);--exact:var(--c-light);--exact-text:var(--c-dark);--partial:var(--c-mid-light);--partial-text:var(--c-dark);--wrong:#526d821a;--wrong-text:var(--c-mid-light);--text-xs:.6rem;--text-sm:.75rem;--text-base:.85rem;--text-md:1rem;--text-lg:1.5rem;--text-xl:2.5rem;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--radius-sm:6px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-pill:999px;--z-controls:2;--z-dropdown:10;--z-modal:100;--ease:cubic-bezier(.4, 0, .2, 1);--duration:.2s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg);background-image:radial-gradient(circle at top, var(--c-mid-dark) 0%, var(--c-dark) 100%);color:var(--text-main);-webkit-font-smoothing:antialiased;background-attachment:fixed;min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;overflow-x:hidden}h1,h2,h3,.font-medieval{letter-spacing:.1em;font-family:Cinzel Decorative,serif}.glass{background:var(--surface);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);box-shadow:0 25px 50px -12px #27374d80}.container{max-width:800px;padding:0 var(--space-md);margin:0 auto}.game-view{gap:var(--space-md);flex-direction:column;width:100%;max-width:500px;margin:0 auto;display:flex}button{cursor:pointer;color:inherit;font:inherit;transition:all var(--duration) var(--ease);background:0 0;border:none}button:hover{transform:scale(1.02)}input{outline:none}input::placeholder{color:var(--text-muted);opacity:.5}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app-root{gap:var(--space-xl);min-height:100vh;padding-bottom:var(--space-2xl);flex-direction:column;display:flex}.app-header{padding-top:var(--space-xl);text-align:center;position:relative}.app-title{font-size:var(--text-xl);color:var(--accent)}.app-subtitle{color:var(--text-muted);font-size:var(--text-base);margin-top:var(--space-sm);letter-spacing:.1em}.help-btn{top:var(--space-xl);color:var(--text-muted);justify-content:center;align-items:center;width:44px;height:44px;padding:10px;display:flex;position:absolute;right:0}.mode-switcher{justify-content:center;display:flex}.mode-switcher__track{padding:var(--space-xs);border-radius:var(--radius-pill);display:flex}.mode-switcher__tab{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-pill);z-index:var(--z-controls);font-weight:600}.mode-switcher__tab--active{background:var(--accent);color:var(--bg)}.mode-switcher__tab--inactive{color:var(--text-main);background:0 0}.app-footer{padding:var(--space-2xl) 0;text-align:center;color:var(--text-muted);font-size:var(--text-xs);gap:var(--space-md);border-top:1px solid var(--border);flex-direction:column;margin-top:auto;display:flex}.footer-links{justify-content:center;gap:var(--space-lg);flex-wrap:wrap;display:flex}.footer-link{color:var(--text-muted);transition:color var(--duration) var(--ease);font-weight:600;text-decoration:none}.footer-link:hover{color:var(--accent);transform:none}.footer-disclaimer{opacity:.7;max-width:600px;margin:0 auto;font-size:.65rem;line-height:1.5}.legal-content{color:var(--text-main)}.legal-section-title{font-family:Cinzel Decorative,serif;font-size:var(--text-base);color:var(--accent);margin:var(--space-lg) 0 var(--space-sm);text-transform:uppercase}.legal-body{font-size:var(--text-sm);margin-bottom:var(--space-md);color:var(--text-muted);line-height:1.6}.modal-content{border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:80vh;padding:var(--space-xl);animation:flip .4s var(--ease);position:relative;overflow-y:auto}.modal-title{font-size:var(--text-lg);color:var(--accent)}.modal-close{color:var(--text-muted);font-size:1.5rem;line-height:1}.modal-body{line-height:1.6}.autocomplete{width:100%;max-width:400px;margin:0 auto;position:relative}.autocomplete__input{width:100%;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);color:var(--text-main);font-size:var(--text-md);transition:all var(--duration) var(--ease)}.autocomplete__input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--border-focus)}.autocomplete__dropdown{top:calc(100% + var(--space-sm));border-radius:var(--radius-md);max-height:250px;z-index:var(--z-dropdown);position:absolute;left:0;right:0;overflow:hidden auto}.autocomplete__item{width:100%;padding:var(--space-md) var(--space-lg);text-align:left;display:block}.autocomplete__item--default{color:var(--text-main);background:0 0}.autocomplete__item--selected{background:var(--surface-hover);color:var(--accent)}.autocomplete__item+.autocomplete__item{border-top:1px solid var(--border)}.control-panel{padding:var(--space-lg);border-radius:var(--radius-lg);text-align:center;z-index:var(--z-dropdown)}.status-eyebrow{font-size:var(--text-sm);color:var(--accent);letter-spacing:.1em;text-transform:uppercase;align-items:center;width:100%;font-weight:700;display:flex}.status-eyebrow__item{text-align:center;flex:1;justify-content:center;align-items:center;display:flex}.status-eyebrow__item--center{padding:0 var(--space-sm);flex:none}.status-eyebrow__separator{opacity:.3;font-weight:400}.status-eyebrow__count-animate{animation:pulse-glow 2s var(--ease);display:inline-block}@keyframes pulse-glow{0%{color:var(--accent);transform:scale(1)}20%{color:#fff;text-shadow:0 0 10px var(--accent);transform:scale(1.2)}to{color:var(--accent);transform:scale(1)}}.classic-dashboard{border-radius:var(--radius-md);flex-direction:column;display:flex;overflow:hidden}.classic-grid-header{text-align:center;padding:var(--space-md) var(--space-md) var(--space-sm);border-bottom:1px solid var(--border);background:#27374d33;gap:8px;display:grid}.classic-grid-header__label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.55rem;font-weight:700}.classic-dashboard__guesses{flex-direction:column;display:flex}.classic-row{padding:var(--space-md);border-bottom:1px solid var(--border);gap:var(--space-sm);flex-direction:column;display:flex}.classic-row:last-child{border-bottom:none}.classic-row__meta{align-items:center;gap:var(--space-sm);font-family:monospace;display:flex}.classic-row__attempt{color:var(--accent);font-size:var(--text-xs);opacity:.8}.classic-row__civ{font-size:var(--text-xs);color:var(--text-main);letter-spacing:.1em;font-weight:700}.classic-row__grid{gap:8px;display:grid}.cell{aspect-ratio:.85;border-radius:var(--radius-sm);flex-direction:column;justify-content:center;align-items:center;gap:2px;width:100%;padding:4px 2px;display:flex;overflow:hidden}.cell__icon{text-shadow:0 2px 4px #0003;font-size:1rem;font-weight:700;line-height:1}.cell__value{text-align:center;text-transform:uppercase;opacity:.9;overflow-wrap:break-word;word-break:normal;-webkit-hyphens:auto;hyphens:auto;-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:.5rem;font-weight:700;line-height:1.1;display:-webkit-box;overflow:hidden}.cascade-history{border-radius:var(--radius-md);flex-direction:column;display:flex;overflow:hidden}.cascade-history__group{border-bottom:1px solid var(--border);flex-direction:column;display:flex}.cascade-history__group:last-child{border-bottom:none}.cascade-history__entry{padding:var(--space-md) var(--space-lg);transition:all .4s var(--ease);position:relative}.cascade-history__entry--newest{background:var(--surface-hover)}.cascade-history__entry--newest:before{content:"";background:var(--accent);border-radius:4px;width:4px;height:20px;position:absolute;top:50%;left:8px;transform:translateY(-50%)}.cascade-history__clue{font-size:var(--text-base);color:var(--text-muted);line-height:1.5}.cascade-history__entry--newest .cascade-history__clue{color:var(--text-main);padding-left:8px;font-weight:500}.cascade-history__guesses{padding:var(--space-sm) 0;border-top:1px solid var(--border);background:#27374d33;flex-direction:column;display:flex}.cascade-history__guess{justify-content:center;align-items:center;gap:var(--space-sm);padding:.4rem var(--space-lg);font-size:var(--text-xs);color:var(--wrong-text);letter-spacing:.1em;text-transform:uppercase;opacity:.6;font-family:monospace;display:flex}.cascade-history__guess-attempt{color:var(--accent);opacity:.8}.cascade-history__guess-name{text-decoration:line-through}.cascade-history__guess--accepted{color:var(--exact);opacity:1;background:#dde6ed1a;font-weight:700}.cascade-history__guess--accepted .cascade-history__guess-name{text-decoration:none}.cascade-history__guess--accepted .cascade-history__guess-attempt{opacity:1}.cascade-loading{padding:var(--space-md);text-align:center;color:var(--text-muted);font-size:var(--text-sm);border-top:1px solid var(--border)}.cascade-history__keyword{letter-spacing:.05em;vertical-align:middle;border-radius:4px;margin:0 4px;padding:2px 6px;font-size:.7rem;font-weight:700;display:inline-block}.cascade-history__keyword--has{color:var(--accent);background:#9db2bf33}.cascade-history__keyword--not{color:var(--text-muted);border:1px dotted var(--border);background:#27374d66}.victory-card{padding:var(--space-xl);border-radius:var(--radius-xl);text-align:center;animation:flip .6s var(--ease) both, bloom .8s var(--ease) .2s;position:relative}.victory-card__eyebrow{color:var(--accent);font-size:var(--text-sm);letter-spacing:.2em}.victory-card__name{font-size:var(--text-lg);margin-top:var(--space-md);margin-bottom:var(--space-sm);letter-spacing:.05em;font-weight:700}.victory-card__type{color:var(--text-muted);margin-bottom:var(--space-xl);font-style:italic}.victory-card__community-stats{margin-bottom:var(--space-xl);text-align:left;padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border);background:#27374d33}.victory-card__community-label{font-size:var(--text-xs);color:var(--accent);margin-bottom:var(--space-sm);letter-spacing:.1em;font-weight:700}.victory-card__community-overview{margin-bottom:var(--space-md);align-items:baseline;gap:6px;display:flex}.victory-card__community-count{color:var(--text-main);font-size:.95rem;font-weight:700}.victory-card__community-text{color:var(--text-muted);font-size:.85rem}.victory-card__distribution{flex-direction:column;gap:6px;display:flex}.victory-card__dist-row{align-items:center;gap:var(--space-sm);display:flex}.victory-card__dist-label{width:2.2rem;color:var(--text-muted);text-align:right;padding-right:4px;font-family:Inter,sans-serif;font-size:.75rem;font-weight:700}.victory-card__dist-bar-wrapper{background:#9db2bf1a;border-radius:4px;flex:1;height:1.2rem;position:relative;overflow:hidden}.victory-card__dist-bar{background:var(--c-mid-light);height:100%;transition:width 1s var(--ease);justify-content:flex-end;align-items:center;padding-right:6px;display:flex}.victory-card__dist-count{color:var(--bg);font-size:.65rem;font-weight:700}.victory-card__stats{gap:var(--space-md);text-align:left;margin-bottom:var(--space-xl);grid-template-columns:1fr 1fr;display:grid}.victory-card__stat{padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border);background:#27374d66}.victory-card__stat-label{color:var(--accent);letter-spacing:.1em;opacity:.6;font-size:.55rem;font-weight:700}.victory-card__stat-value{font-weight:600;font-size:var(--text-sm);color:var(--text-main);margin-top:2px;line-height:1.25}.victory-card__bonuses{text-align:left;margin-bottom:var(--space-xl)}.victory-card__bonuses-label{font-size:var(--text-xs);color:var(--accent);margin-bottom:var(--space-sm);font-weight:700}.victory-card__bonuses-list{font-size:var(--text-sm);color:var(--text-muted);flex-direction:column;gap:8px;list-style:none;display:flex}.victory-card__share-btn{border-radius:var(--radius-md);background:var(--accent);width:100%;color:var(--bg);font-weight:700;font-size:var(--text-md);padding:1rem;box-shadow:0 8px 24px #27374d80}.victory-card__countdown{margin-top:var(--space-lg);font-size:var(--text-sm);color:var(--text-muted)}.victory-card__countdown-time{color:var(--text-main);font-weight:700}.feedback-error{color:var(--error);margin-top:var(--space-md);font-size:var(--text-sm);letter-spacing:.02em;opacity:.8;font-weight:500}.loading-text{text-align:center;padding:var(--space-xl);border-radius:var(--radius-md);margin-top:var(--space-xl);color:var(--text-muted);letter-spacing:.1em}.error-text{text-align:center;color:var(--error);padding:var(--space-xl);border-radius:var(--radius-md);margin-top:var(--space-xl);letter-spacing:.1em}.modal-overlay{z-index:var(--z-modal,100);padding:var(--space-xl);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-backdrop{-webkit-backdrop-filter:blur(8px);background:#0009;position:absolute;inset:0}.modal-content{width:100%;max-width:500px;max-height:80vh;padding:var(--space-xl);border-radius:var(--radius-xl);z-index:1;position:relative;overflow-y:auto}.modal-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-lg);color:var(--accent);margin:0}.modal-close{color:var(--text-muted);padding:var(--space-xs);transition:all .2s var(--ease);font-size:1.5rem;line-height:1}.modal-close:hover{color:var(--text-main);transform:scale(1.1)}.help-content{gap:var(--space-lg);flex-direction:column;display:flex}.help-section-title{color:var(--accent);margin-bottom:var(--space-sm);font-size:.9rem}.help-body{font-size:var(--text-base)}.help-list{font-size:var(--text-base);margin-top:var(--space-sm);flex-direction:column;gap:6px;display:flex}.help-footer{color:var(--text-muted);border-top:1px solid var(--border);padding-top:var(--space-md);font-size:.8rem}@keyframes flip{0%{opacity:0;transform:rotateX(90deg)}to{opacity:1;transform:rotateX(0)}}@keyframes ray-out{0%{transform:rotate(var(--rotation,0deg)) scaleX(0);opacity:1}to{transform:rotate(var(--rotation,0deg)) scaleX(1.5) translateX(var(--travel,50px));opacity:0}}@keyframes bloom{0%{background-color:var(--surface)}20%{background-color:#dde6ed66}to{background-color:var(--surface)}}.geometric-burst{pointer-events:none;z-index:50;position:absolute;inset:0;overflow:visible}.geometric-ray{background:var(--c-light);transform-origin:0;height:2px;animation:ray-out .6s var(--ease) forwards;position:absolute}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-4px)}40%,80%{transform:translate(4px)}}.animate-shake{animation:.4s cubic-bezier(.36,.07,.19,.97) both shake}.animate-flip{animation:flip .6s var(--ease) both}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
