::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#ffffff20;border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:#ffffff40}
*{scrollbar-width:thin;scrollbar-color:#ffffff20 transparent}
*,::before,::after{box-sizing:border-box}
body,h1,h2,h3,h4,p,figure,blockquote,dl,dd{margin:0}
ul[role="list"],ol[role="list"]{list-style:none;margin:0;padding:0}
img,picture{max-width:100%;display:block}
svg{display:block}
input,button,textarea,select{font:inherit;color:inherit;cursor:pointer}
@media (prefers-reduced-motion: reduce) {
html:focus-within{scroll-behavior:auto}
*,::before,::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
:root{--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji";--font-mono:SFMono-Regular,Consolas,"Liberation Mono",Menlo,monospace;--fw-light:300;--fw-regular:400;--fw-medium:500;--fw-bold:700;--bg:#0d1117;--bg-surface:#161b22;--bg-elevated:#21262d;--border:#30363d;--text-primary:#e6edf3;--text-muted:#b5d7ff;--accent:hsl(142,71%,45%);--accent-hover:hsl(142,65%,55%);--accent-dim:hsl(142,40%,20%);--danger:#f85149;--info:#58a6ff;--success:hsl(142,71%,45%);--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--transition:150ms ease}
[data-theme="light"]{--bg:#f6f8fa;--bg-surface:#fff;--bg-elevated:#f0f2f5;--border:#d0d7de;--text-primary:#13171d;--text-muted:#121820;--accent:hsl(142,76%,32%);--accent-hover:hsl(142,71%,40%);--accent-dim:hsl(142,50%,90%)}
html,body{height:100%}
html{scroll-behavior:smooth}
body{font-family:var(--font-sans);font-weight:var(--fw-light);font-size:1rem;line-height:1.5;text-rendering:optimizeSpeed;background-color:var(--bg);color:var(--text-primary);overflow:hidden;position:absolute;inset:0;display:flex;flex-direction:column;align-items:center}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
hr{border:none;height:1px;background-color:var(--border);margin-block:var(--space-4)}
.visually-hidden{border:0;clip:rect(0 0 0 0);height:1px;margin:0;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}
.accent{color:var(--accent);margin:0!important}
#app{width:min(500px,100%);min-height:0;height:100%;display:flex;flex-direction:column;position:relative;padding-inline:var(--space-3)}
#app svg{width:auto;height:100%}
#app header{display:flex;width:100%;justify-content:space-between;align-items:center;margin-top:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border);margin-bottom:var(--space-5);flex-shrink:0}
#app header > div{display:flex;align-items:center;gap:var(--space-2)}
#app header button{border:none;outline:none;background-color:transparent;height:22px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:transform var(--transition),opacity var(--transition)}
#app header button:hover,#app header button:focus-visible{transform:scale(1.18);opacity:.85}
#app header button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
#app header img{height:22px;cursor:pointer}
.logo{display:flex;flex-direction:column;align-items:center;gap:0}
#app header h1{text-transform:uppercase;font-size:clamp(1.75rem,5vw,2.25rem);font-weight:var(--fw-bold);letter-spacing:3px;margin-bottom:-10px;margin-top:6px;line-height:1}
.logo > span{text-transform:uppercase;font-weight:var(--fw-medium);font-size:.7rem;letter-spacing:2px;color:var(--text-muted)}
.theme-toggle{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px 6px;font-size:.75rem;color:var(--text-muted);cursor:pointer;transition:border-color var(--transition),color var(--transition)}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}
.country{width:100%;height:min(22vh,200px);display:flex;justify-content:center;align-items:center;margin-bottom:var(--space-5);flex-shrink:0}
.country img{max-height:100%;object-fit:contain}
[data-theme="light"] .country{filter:none}
[data-theme="dark"] .country{filter:invert(1) brightness(0.9)}
.guesses{flex-grow:1;display:flex;flex-direction:column;align-items:center;overflow:hidden;min-height:0}
.guess-grid{display:flex;flex-direction:column;gap:var(--space-1);width:100%;margin-bottom:var(--space-2)}
div.blank-guess-row{background-color:var(--bg-elevated);height:32px;width:100%;border-radius:var(--radius-sm);border:1px solid var(--border)}
div.guess-row{background-color:transparent;min-height:34px;width:100%;border-radius:var(--radius-sm);display:grid;grid-template-columns:3fr 2fr 1fr 1fr;gap:var(--space-1)}
div.guess-row img{height:16px}
div.guess-row > div{border:1px solid var(--border);background-color:var(--bg-surface);height:100%;border-radius:var(--radius-sm);text-align:center;display:flex;justify-content:center;align-items:center;font-size:.85rem;padding-inline:var(--space-1)}
div.guess-row > div:first-of-type{text-transform:uppercase;overflow:hidden}
div.guess-row > div:first-of-type p{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}
div.guess-row.animated{grid-template-columns:6fr 1fr}
div.guess-row.animated > :first-child{display:flex;align-items:center;justify-content:space-evenly}
div.guess-row.animated .square{animation:reveal .2s forwards;opacity:0;user-select:none}
div.guess-row.animated > :first-child img{height:25px}
.make-guess{width:100%;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);flex-shrink:0;padding-bottom:var(--space-2)}
.autocomplete{position:relative;width:100%}
.autocomplete input{width:100%;font-weight:var(--fw-light);padding:.4em .6em;border:1px solid var(--border);border-radius:var(--radius-sm);background-color:var(--bg-surface);color:var(--text-primary);cursor:text;transition:border-color var(--transition),box-shadow var(--transition);margin-bottom:0}
.autocomplete input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}
.autocomplete .suggestions{position:absolute;bottom:100%;max-height:30vh;overflow-y:auto;background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);width:100%;margin-bottom:var(--space-1);z-index:50;box-shadow:0 8px 24px #00000059;list-style:none}
.autocomplete .suggestions > li{background-color:transparent;padding:.35em .4em;font-weight:var(--fw-light);font-size:.95rem;text-transform:uppercase;cursor:pointer;border-radius:var(--radius-sm);transition:background-color var(--transition)}
.autocomplete .suggestions > li:hover{background-color:var(--bg-elevated)}
.guess-country{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);border:1px solid var(--border);outline:none;background-color:var(--bg-surface);padding:.4em .6em;border-radius:var(--radius-sm);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.5px;transition:background-color var(--transition),border-color var(--transition)}
.guess-country:hover,.guess-country:focus-visible{background-color:var(--bg-elevated);border-color:var(--accent)}
.guess-country:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.guess-country img{max-height:1.1rem}
.skip-button{text-transform:uppercase;letter-spacing:.5px;width:100%;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);outline:none;background-color:var(--bg-elevated);color:var(--text-muted);font-weight:var(--fw-medium);padding:.4em;border-radius:var(--radius-sm);height:34px;transition:background-color var(--transition),color var(--transition)}
.skip-button:hover,.skip-button:focus-visible{background-color:var(--border);color:var(--text-primary)}
.share-button{background-color:var(--accent);text-transform:uppercase;letter-spacing:.5px;width:100%;border:none;outline:none;color:#fff;font-weight:var(--fw-bold);border-radius:var(--radius-sm);height:34px;transition:background-color var(--transition),transform var(--transition);display:flex;align-items:center;justify-content:center;gap:var(--space-2)}
.share-button:hover,.share-button:focus-visible{background-color:var(--accent-hover);transform:translateY(-1px)}
.share-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.play-again-button{text-transform:uppercase;letter-spacing:.5px;width:100%;border:1px solid var(--border);outline:none;background-color:var(--bg-elevated);color:var(--text-primary);font-weight:var(--fw-medium);border-radius:var(--radius-sm);height:34px;margin-top:var(--space-2);transition:background-color var(--transition);display:flex;align-items:center;justify-content:center}
.play-again-button:hover,.play-again-button:focus-visible{background-color:var(--border)}
.share-group{display:flex;gap:var(--space-2);width:100%;margin-top:var(--space-2)}
.share-social-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);font-size:.78rem;font-weight:var(--fw-medium);border:1px solid var(--border);border-radius:var(--radius-sm);height:30px;background-color:var(--bg-surface);color:var(--text-muted);cursor:pointer;text-decoration:none;transition:border-color var(--transition),color var(--transition),background-color var(--transition);letter-spacing:.3px}
.share-social-btn:hover{border-color:var(--accent);color:var(--accent);background-color:var(--accent-dim);text-decoration:none}
.view-on{margin-top:var(--space-5);width:60%;display:flex;justify-content:center;align-items:center;gap:var(--space-2)}
.view-on + .view-on{margin-top:var(--space-2)}
.view-on img{height:20px}
.view-on a{color:var(--text-muted);text-decoration:underline;font-size:.9rem}
.view-on a:hover{color:var(--accent)}
.alert-container{position:fixed;top:10vh;left:50vw;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);pointer-events:none}
.alert{min-width:220px;pointer-events:none;user-select:none;background-color:var(--bg-surface);border:1px solid var(--border);box-shadow:0 4px 20px #0006;padding:.85em 1.5em;border-radius:var(--radius-md);opacity:1;transition:opacity 600ms ease-in-out;display:flex;align-items:center;gap:var(--space-3);font-size:.9rem}
.alert svg{height:22px!important;flex-shrink:0}
.alert.hide{opacity:0}
#modal{width:100%;height:100%;position:absolute;top:0;left:0;background-color:var(--bg);z-index:100;overflow-y:auto;padding-inline:var(--space-4);padding-bottom:var(--space-6)}
#modal header{position:relative;display:flex;justify-content:center;align-items:center;margin:var(--space-7) 0 var(--space-3)!important;padding-block:var(--space-2);border-bottom:none}
#modal .close-btn{position:absolute;right:0;background-color:transparent;border:none;outline:none;display:flex;justify-content:center;align-items:center;width:24px;height:24px;padding:0;border-radius:var(--radius-sm);transition:opacity var(--transition)}
#modal .close-btn:hover{opacity:.7}
#modal .close-btn img{width:100%;height:100%}
#modal .content > p{margin-bottom:var(--space-3);font-size:.9em;line-height:1.6}
#modal .content > p img{height:.9em;display:inline;margin-left:2px}
#modal .guess-row:first-of-type{margin-top:var(--space-3)}
#modal .guess-row{margin-bottom:var(--space-3)}
#modal input[type="checkbox"]{accent-color:var(--accent);cursor:pointer}
.top-stats{margin:0 auto var(--space-7);width:85%;display:flex;justify-content:center;gap:var(--space-2)}
.top-stats > div{padding-inline:var(--space-3);display:flex;flex-direction:column;align-items:center;text-align:center}
.top-stats h1{font-size:2rem;font-weight:var(--fw-bold);color:var(--accent)}
.top-stats p{font-size:.75rem;color:var(--text-muted);line-height:1.3}
.average{font-size:2.25em;font-weight:var(--fw-bold);display:block;text-align:center;color:var(--accent)}
.average-label{font-size:1rem;display:block;text-align:center;margin-bottom:var(--space-5);color:var(--text-muted)}
.guess-distribution{margin:0;padding:0;margin-inline:var(--space-1);list-style:none}
.guess-distribution > li{display:flex;align-items:center;margin:var(--space-2) 0;gap:var(--space-2)}
.guess-distribution .index{font-weight:var(--fw-bold);width:14px;flex-shrink:0}
.guess-distribution .bar{background-color:var(--accent-dim);border-radius:2px;min-width:4px;height:18px}
.guess-distribution .count{font-weight:var(--fw-bold);padding-inline:var(--space-2);background-color:var(--accent);color:#fff;border-radius:2px;font-size:.8rem;height:18px;display:flex;align-items:center}
#seo-content{width:min(700px,100%);padding:var(--space-7) var(--space-4) var(--space-6);color:var(--text-muted);font-size:.88rem;line-height:1.7}
.seo-section{margin-bottom:var(--space-7)}
.seo-section h2{font-size:1.1rem;font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:var(--space-3);letter-spacing:.3px}
.seo-steps{margin:var(--space-3) 0 0 var(--space-5);display:flex;flex-direction:column;gap:var(--space-2)}
.faq-list{display:flex;flex-direction:column;gap:var(--space-4)}
.faq-list dt{font-weight:var(--fw-medium);color:var(--text-primary)}
.faq-list dd{margin-left:0}
#site-footer{width:min(700px,100%);padding:var(--space-4) var(--space-4) var(--space-6);border-top:1px solid var(--border)}
.footer-disclaimer{font-size:.75rem;color:var(--text-muted);line-height:1.6}
.footer-disclaimer a{color:var(--text-muted);text-decoration:underline}
.footer-disclaimer a:hover{color:var(--accent)}
@keyframes reveal {
from{opacity:0}
to{opacity:1}
}
@keyframes pop {
0%{transform:scale(1)}
75%{transform:scale(1.22)}
100%{transform:scale(1)}
}
@media screen and (max-width: 768px) {
body{overflow-x:hidden;overflow-y:auto;position:relative;inset:auto}
#app{width:100%;padding-inline:var(--space-3);height:auto;min-height:100svh}
.guesses{overflow:visible}
.country{height:min(20vh,160px)}
.alert-container{top:0;width:100%;transform:none;left:0}
.alert{width:100%;border-radius:0;border-left:none;border-right:none;justify-content:flex-start}
}
@media screen and (max-width: 400px) {
#app header h1{font-size:1.6rem;letter-spacing:2px}
.top-stats{width:100%}
.top-stats > div{padding-inline:var(--space-2)}
.share-group{flex-wrap:wrap}
.share-social-btn{min-width:calc(50% - var(--space-1))}
}
@media screen and (max-height: 600px) {
.country{height:80px;margin-bottom:var(--space-3)}
#app header{margin-bottom:var(--space-3)}
}
.modal-hidden{display:none!important;visibility:hidden;pointer-events:none}
.setting-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) 0;border-bottom:1px solid var(--border)}
.setting-row:last-child{border-bottom:none}
.setting-label{font-size:.9rem;color:var(--text-primary);font-weight:var(--fw-medium);flex:1}
.setting-toggle-group{display:flex;gap:var(--space-1)}
.setting-chip{padding:var(--space-1) var(--space-3);border:1px solid var(--border);border-radius:20px;background-color:var(--bg-elevated);color:var(--text-muted);font-size:.82rem;font-weight:var(--fw-medium);cursor:pointer;transition:all var(--transition);white-space:nowrap}
.setting-chip:hover{border-color:var(--accent);color:var(--accent)}
.setting-chip.active{background-color:var(--accent);border-color:var(--accent);color:#fff}
.setting-switch{position:relative;width:44px;height:24px;border-radius:12px;border:none;background-color:var(--bg-elevated);cursor:pointer;transition:background-color var(--transition);flex-shrink:0;padding:0;outline:none;border:1px solid var(--border)}
.setting-switch:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.setting-switch.on{background-color:var(--accent);border-color:var(--accent)}
.setting-switch-thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background-color:var(--text-muted);transition:transform var(--transition),background-color var(--transition);pointer-events:none;display:block}
.setting-switch.on .setting-switch-thumb{transform:translateX(20px);background-color:#fff}
#modal .difficulty{margin-top:var(--space-4)}
#modal .difficulty h3{margin-bottom:var(--space-3);font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:var(--fw-medium)}
#modal .difficulty .setting-row{padding:var(--space-3) 0}
.howto-list{margin:var(--space-3) 0 0 var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);font-size:.9em;line-height:1.6}
.howto-faq-heading{margin-top:var(--space-2)}
.howto-credit{font-size:.82em;color:var(--text-muted);line-height:1.6}
.howto-credit a{color:var(--text-muted);text-decoration:underline}
.howto-credit a:hover{color:var(--accent)}
.autocomplete .suggestions > li.active{background-color:var(--accent-dim);color:var(--accent)}
#app header .theme-toggle{height:auto;min-height:22px;transform:none!important}
#app header .theme-toggle:hover,#app header .theme-toggle:focus-visible{transform:none!important;opacity:1!important;border-color:var(--accent);color:var(--accent)}
@media screen and (max-height: 700px) {
body{overflow-y:auto;position:relative;inset:auto}
#app{height:auto;min-height:100dvh}
.guesses{overflow:visible}
}
.skip-button{margin-top:var(--space-2)}
button.theme-toggle{display:none!important}