:root{--font:"Bricolage Grotesque", system-ui, sans-serif;--accent:#9e2b30;--accent-contrast:#fdf7e3;--accent2:#d6394e;--gold:#e0a33a;--radius:18px;--maxw:480px;--t-sm:.95rem;--t-base:1.125rem;--t-lg:1.4rem;--t-xl:1.75rem;--t-2xl:clamp(1.6rem, 3vw, 2.3rem);--t-display:clamp(2.2rem, 9vw, 3.6rem);--s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px}[data-theme=dark]{--bg:#231019;--bg2:#2e1320;--mesh1:#3a1a20;--mesh2:#2a1810;--surface:#fff4e00f;--surface-solid:#2e1822;--border:#f5ecc821;--text:#f5ecc8;--text-dim:#d8c39a;--accent:#e8b24a;--accent-contrast:#2e1320;--accent-ink:#f0c869;--shadow:0 18px 50px #0000008c}[data-theme=light]{--bg:#f5ecc8;--bg2:#fdf7e3;--mesh1:#f0d9a0;--mesh2:#ecc9a6;--surface:#fffbf0b8;--surface-solid:#fffdf5;--border:#35132426;--text:#2e1320;--text-dim:#5e3a2e;--accent:#9e2b30;--accent-contrast:#fdf7e3;--accent-ink:#8c2329;--shadow:0 16px 44px #0000001f}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100dvh;font-size:18px;font-weight:500;line-height:1.6;position:relative;overflow-x:hidden}button,[role=button],a{touch-action:manipulation;-webkit-tap-highlight-color:transparent}body:before{content:"";background:radial-gradient(40% 40% at 20% 25%, var(--mesh1) 0%, transparent 60%), radial-gradient(45% 45% at 82% 18%, var(--mesh2) 0%, transparent 60%), radial-gradient(50% 50% at 60% 90%, var(--mesh1) 0%, transparent 55%);filter:blur(20px);opacity:.9;z-index:-2;animation:22s ease-in-out infinite alternate drift;position:fixed;inset:-30%}body:after{content:"";z-index:-1;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:fixed;inset:0}@keyframes drift{0%{transform:translate(0)scale(1)}to{transform:translate(-4%,3%)scale(1.08)}}@keyframes rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}@keyframes spin{to{transform:rotate(360deg)}}button,input{font-family:var(--font)}.app-header{z-index:50;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:color-mix(in srgb, var(--bg) 72%, transparent);border-bottom:1px solid var(--border);padding-top:env(safe-area-inset-top);position:sticky;top:0}.app-header .bar{max-width:var(--maxw);padding:12px 20px;padding-left:calc(20px + env(safe-area-inset-left));padding-right:calc(20px + env(safe-area-inset-right));align-items:center;gap:12px;margin:0 auto;display:flex}.logo-btn{cursor:pointer;letter-spacing:-.03em;color:var(--text);background:0 0;border:none;border-radius:10px;align-items:center;gap:8px;padding:4px 6px;font-size:1.35rem;font-weight:800;display:flex}.logo-btn .ball{animation:6s linear infinite spin;display:inline-block}.logo-btn .hl{color:var(--accent-ink)}.spacer{flex:1}.toggle{background:var(--surface);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:999px;min-height:44px;padding:9px 14px;font-size:1rem;font-weight:700;transition:transform .15s,background .2s}.toggle:hover{transform:translateY(-2px)}.col{max-width:var(--maxw);padding:var(--s5) 20px 90px;padding-bottom:calc(90px + env(safe-area-inset-bottom));gap:var(--s5);flex-direction:column;margin:0 auto;animation:.45s both rise;display:flex}.hero{text-align:center;padding:var(--s4) 0 0}.hero h1{font-size:var(--t-display);letter-spacing:-.04em;text-wrap:balance;margin-bottom:8px;font-weight:800;line-height:1.02}.hero h1 .hl,.hl{color:var(--accent-ink)}.hero .sub{color:var(--text-dim);font-size:1.2rem;font-weight:600}h2.section-h{font-size:var(--t-lg);letter-spacing:-.02em;font-weight:800}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--s5) var(--s4);gap:var(--s4);flex-direction:column;display:flex}.btn{font-weight:800;font-size:var(--t-base);cursor:pointer;border:2px solid #0000;border-radius:16px;justify-content:center;align-items:center;gap:10px;min-height:56px;padding:14px 22px;text-decoration:none;transition:transform .15s,box-shadow .2s,background .2s;display:inline-flex}.btn:hover:not(:disabled){transform:translateY(-2px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent);box-shadow:0 8px 24px color-mix(in srgb, var(--accent) 40%, transparent)}.btn-secondary{background:var(--surface-solid);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){border-color:var(--accent)}.btn-xl{width:100%;min-height:68px;font-size:1.35rem}.btn-block{width:100%}.btn-ghost{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:999px;align-self:center;min-height:48px;padding:10px 18px;font-size:1rem;font-weight:700}.btn-ghost:hover{color:var(--accent2);border-color:var(--accent2)}.link-btn{cursor:pointer;color:var(--accent-ink);font-weight:700;font-size:var(--t-base);text-underline-offset:4px;background:0 0;border:none;border-radius:8px;align-self:center;padding:8px;text-decoration:underline}.btn:focus-visible,.toggle:focus-visible,.logo-btn:focus-visible,.link-btn:focus-visible,.btn-ghost:focus-visible,input:focus-visible,.avatar-btn:focus-visible,.code-big:focus-visible,.member-pick:focus-visible,.dice-btn:focus-visible{outline:3px solid var(--accent);outline-offset:3px}.lbl{letter-spacing:-.01em;margin-bottom:8px;font-size:1.05rem;font-weight:800;display:block}.field{width:100%;min-height:58px;font-size:var(--t-base);color:var(--text);background:var(--surface-solid);border:2px solid var(--border);border-radius:14px;padding:12px 16px;font-weight:700}.field::placeholder{color:var(--text-dim);opacity:.7;font-weight:600}.field:focus{border-color:var(--accent);outline:none}.field[aria-invalid=true]{border-color:var(--accent2)}.field-err{color:var(--accent2);margin-top:8px;font-size:1.02rem;font-weight:700}.field-err[hidden]{display:none}.name-row{gap:10px;display:flex}.name-row .field{flex:1}.dice-btn{background:var(--surface-solid);border:2px solid var(--border);cursor:pointer;border-radius:14px;flex:none;width:58px;min-height:58px;font-size:1.6rem;transition:transform .15s,border-color .2s}.dice-btn:hover{border-color:var(--accent);transform:translateY(-2px)rotate(-12deg)}.code-input{text-align:center;text-transform:uppercase;letter-spacing:.35em;font-variant-numeric:tabular-nums;font-size:1.7rem;font-weight:800}.code-input::placeholder{letter-spacing:.35em}.avatar-grid{grid-template-columns:repeat(6,1fr);gap:8px;display:grid}.avatar-btn{aspect-ratio:1;background:var(--surface-solid);border:2px solid var(--border);cursor:pointer;border-radius:14px;place-items:center;min-height:52px;font-size:1.7rem;line-height:1;transition:transform .12s,border-color .15s,box-shadow .15s;display:grid}.avatar-btn:hover{transform:translateY(-2px)}.avatar-btn[aria-checked=true]{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 45%, transparent);background:color-mix(in srgb, var(--accent) 16%, var(--surface-solid))}@media (width<=380px){.avatar-grid{grid-template-columns:repeat(5,1fr)}}.group-title{text-align:center;font-size:var(--t-2xl);letter-spacing:-.03em;font-weight:800}.lobby-sub{text-align:center;color:var(--text-dim);font-weight:600}.code-big{background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);width:100%;padding:var(--s4);cursor:pointer;letter-spacing:.18em;text-indent:.18em;color:var(--accent-ink);text-align:center;font-size:clamp(2.4rem,14vw,3.6rem);font-weight:800;line-height:1.1;transition:border-color .2s,transform .15s;display:block}.code-big:hover{border-color:var(--accent);transform:translateY(-2px)}.code-hint{text-align:center;color:var(--text-dim);margin-top:-14px;font-size:1rem;font-weight:600}.qr-wrap{justify-content:center;display:flex}.qr-tile{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;place-items:center;min-width:min(70vw,308px);min-height:min(70vw,308px);padding:14px;display:grid}.qr-tile img{width:min(70vw,280px);height:min(70vw,280px);display:block}.qr-fallback{color:#0c0c0c;word-break:break-all;padding:10px;font-size:.95rem;font-weight:700}.share-row{gap:12px;display:flex}.share-row .btn{flex:1}.member-list{flex-direction:column;gap:10px;list-style:none;display:flex}.member-row{background:var(--surface);border:1px solid var(--border);border-radius:16px;align-items:center;gap:14px;min-height:60px;padding:12px 16px;animation:.35s both rise;display:flex}.m-avatar{flex:none;font-size:1.8rem;line-height:1}.m-name{font-weight:800;font-size:var(--t-base);flex-wrap:wrap;flex:1;align-items:center;gap:8px;display:flex}.m-name .you{color:var(--text-dim);font-size:.95rem;font-weight:700}.host-badge{background:var(--gold);color:#1a1400;letter-spacing:.04em;white-space:nowrap;border-radius:999px;padding:3px 9px;font-size:.78rem;font-weight:800}.m-dot{border:2px solid var(--border);border-radius:50%;flex:none;width:13px;height:13px}.m-dot.online{background:var(--accent);border-color:var(--accent);box-shadow:0 0 8px color-mix(in srgb, var(--accent) 70%, transparent)}.empty-note{text-align:center;color:var(--text-dim);background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);padding:var(--s5) var(--s4);font-weight:600}.chip-row{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.chip{background:var(--surface);border:1px solid var(--border);border-radius:999px;align-items:center;gap:6px;padding:7px 14px;font-size:1rem;font-weight:700;display:inline-flex}.member-pick{background:var(--surface-solid);border:2px solid var(--border);width:100%;min-height:64px;font-weight:800;font-size:var(--t-base);color:var(--text);cursor:pointer;text-align:left;border-radius:16px;align-items:center;gap:14px;padding:14px 18px;transition:transform .15s,border-color .15s;display:flex}.member-pick:hover:not(:disabled){border-color:var(--accent);transform:translateY(-2px)}.member-pick:disabled{opacity:.55;cursor:wait}.member-pick .m-avatar{font-size:1.7rem}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}.spinner.sm{border-width:2px;width:18px;height:18px}.boot{justify-content:center;align-items:center;gap:var(--s4);min-height:70vh;color:var(--text-dim);flex-direction:column;font-weight:700;display:flex}.loading-block{align-items:center;gap:var(--s4);padding:var(--s6) 0;color:var(--text-dim);flex-direction:column;font-weight:700;display:flex}.notfound{text-align:center;gap:var(--s4);flex-direction:column;display:flex}.notfound .big{font-size:3rem;line-height:1}.code-echo{letter-spacing:.14em;color:var(--accent-ink);font-size:1.3rem;font-weight:800}.toast-wrap{bottom:calc(22px + env(safe-area-inset-bottom));z-index:200;pointer-events:none;flex-direction:column;align-items:center;gap:10px;width:min(92vw,440px);display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast{background:var(--surface-solid);color:var(--text);border:1px solid var(--border);border-left:4px solid var(--accent);font-weight:700;font-size:var(--t-base);box-shadow:var(--shadow);border-radius:14px;max-width:100%;padding:13px 20px;animation:.3s both rise}.toast.out{opacity:0;transition:opacity .35s,transform .35s;transform:translateY(10px)}.divider{color:var(--text-dim);text-transform:uppercase;letter-spacing:.12em;align-items:center;gap:14px;font-size:.9rem;font-weight:800;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.suggest-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.suggest-btn{background:color-mix(in srgb, var(--accent) 16%, var(--surface-solid));border:2px solid var(--accent);color:var(--text);cursor:pointer;border-radius:999px;min-height:44px;padding:8px 16px;font-size:1rem;font-weight:800}.suggest-btn:focus-visible{outline:3px solid var(--accent);outline-offset:3px}.lock-toggle{background:var(--surface);width:100%;min-height:56px;color:var(--text);border:2px solid var(--border);font-weight:800;font-size:var(--t-base);cursor:pointer;border-radius:16px;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;padding:12px 18px;transition:transform .15s,border-color .2s,background .2s;display:flex}.lock-toggle:hover:not(:disabled){border-color:var(--accent);transform:translateY(-2px)}.lock-toggle:disabled{opacity:.6;cursor:wait}.lock-toggle:focus-visible{outline:3px solid var(--accent);outline-offset:3px}.lock-toggle.is-locked{background:color-mix(in srgb, var(--gold) 14%, var(--surface-solid));border-color:var(--gold)}.lock-toggle.is-locked:hover:not(:disabled){border-color:var(--gold)}.lock-sub{color:var(--text-dim);font-size:.92rem;font-weight:700}.locked-badge{text-align:center;background:color-mix(in srgb, var(--gold) 14%, var(--surface-solid));border:1px solid var(--gold);color:var(--text);border-radius:999px;padding:10px 18px;font-size:1.02rem;font-weight:800}.invite-section{gap:var(--s5);flex-direction:column;transition:opacity .25s;display:flex}.invite-section.is-locked .qr-wrap,.invite-section.is-locked .share-row{opacity:.4}.locked-note{text-align:center;color:var(--text);background:var(--surface);border:1px dashed var(--gold);border-radius:14px;padding:12px 16px;font-weight:700}.locked-note[hidden]{display:none}.kick-btn{border:2px solid var(--border);cursor:pointer;background:0 0;border-radius:12px;flex:none;width:44px;min-height:44px;font-size:1.25rem;transition:transform .15s,border-color .15s}.kick-btn:hover{border-color:var(--accent2);transform:translateY(-2px)}.kick-btn:focus-visible{outline:3px solid var(--accent2);outline-offset:2px}.member-row.confirming{border-color:var(--accent2);align-items:flex-start}.kick-confirm{flex-direction:column;flex:1;gap:10px;display:flex}.kick-q{font-weight:800;font-size:var(--t-base)}.kick-actions{flex-wrap:wrap;gap:10px;display:flex}.btn-mini{background:var(--surface-solid);min-height:46px;color:var(--text);border:2px solid var(--border);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:8px 18px;font-size:1rem;font-weight:800;transition:transform .15s,border-color .15s;display:inline-flex}.btn-mini:hover:not(:disabled){border-color:var(--accent);transform:translateY(-2px)}.btn-mini:disabled{opacity:.55;cursor:not-allowed}.btn-mini:focus-visible{outline:3px solid var(--accent);outline-offset:3px}.btn-mini.danger{border-color:var(--accent2);color:var(--accent2)}.btn-mini.danger:hover:not(:disabled){background:color-mix(in srgb, var(--accent2) 14%, var(--surface-solid));border-color:var(--accent2)}.btn-mini.danger:focus-visible{outline-color:var(--accent2)}.tab-bar{background:var(--surface);border:1px solid var(--border);border-radius:999px;gap:8px;padding:6px;display:flex}.tab-btn{min-height:48px;font-family:var(--font);font-weight:800;font-size:var(--t-base);color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:999px;flex:1;padding:10px 16px;transition:background .18s,color .18s,box-shadow .18s}.tab-btn:hover:not(.active){color:var(--text);background:color-mix(in srgb, var(--text) 8%, transparent)}.tab-btn.active{background:var(--accent);color:var(--accent-contrast);box-shadow:0 4px 14px color-mix(in srgb, var(--accent) 40%, transparent)}.tab-btn:focus-visible{outline:3px solid var(--accent);outline-offset:2px}.tab-panel{gap:var(--s5);flex-direction:column;display:none}.tab-panel.active{animation:.3s both rise;display:flex}.ldgr-header{text-align:center}.ldgr-sub{color:var(--text-dim);margin-top:6px;font-size:1.05rem;font-weight:600}.balance-list{flex-direction:column;gap:10px;display:flex}.balance-row{background:var(--surface);border:1px solid var(--border);border-radius:16px;align-items:center;gap:14px;min-height:60px;padding:14px 16px;transition:border-color .2s;animation:.35s both rise;display:flex}.balance-row.top{border-color:var(--gold);background:color-mix(in srgb, var(--gold) 10%, var(--surface));box-shadow:0 6px 20px color-mix(in srgb, var(--gold) 22%, transparent)}.balance-score{letter-spacing:-.02em;text-align:right;flex:none;min-width:72px;font-size:1.35rem;font-weight:900}.balance-score.pos{color:var(--accent-ink)}.balance-score.neg{color:var(--accent2)}.balance-unit{opacity:.75;margin-left:3px;font-size:.75rem;font-weight:700}.leader-badge{margin-left:4px;font-size:.85rem}.ldgr-form{gap:var(--s4)}.ldgr-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23aaa' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:40px}.lbl-opt{color:var(--text-dim);margin-left:4px;font-size:.88rem;font-weight:600}.member-for{font-size:var(--t-base);background:var(--surface-solid);border:2px solid var(--border);border-radius:14px;align-items:center;min-height:56px;padding:14px 16px;font-weight:800;display:flex}.history-toggle{background:var(--surface);border:1px solid var(--border);width:100%;min-height:52px;font-family:var(--font);font-weight:800;font-size:var(--t-base);color:var(--text);cursor:pointer;border-radius:16px;justify-content:center;align-items:center;gap:10px;padding:12px 18px;transition:transform .15s,border-color .2s;display:flex}.history-toggle:hover{border-color:var(--accent);transform:translateY(-2px)}.history-toggle:focus-visible{outline:3px solid var(--accent);outline-offset:3px}.history-toggle .arrow{opacity:.7;font-size:1rem;transition:transform .2s}.history-toggle.open .arrow{transform:rotate(180deg)}.history-list-wrap[hidden]{display:none}.history-list{flex-direction:column;gap:8px;padding:4px 0 8px;list-style:none;display:flex}.history-item{background:var(--surface);border:1px solid var(--border);border-radius:14px;align-items:flex-start;gap:12px;padding:12px 14px;animation:.3s both rise;display:flex}.hi-avatar{flex:none;margin-top:2px;font-size:1.5rem;line-height:1}.hi-meta{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.hi-name{font-size:1.02rem;font-weight:800}.hi-note{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.hi-time{color:var(--text-dim);font-size:.88rem;font-weight:600}.hi-delta{letter-spacing:-.02em;flex:none;margin-top:2px;font-size:1.15rem;font-weight:900}.hi-delta.pos{color:var(--accent-ink)}.hi-delta.neg{color:var(--accent2)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}html{scroll-behavior:auto}}.matches-grid{flex-direction:column;gap:16px;display:flex}.match-card{padding:16px}.m-header{color:var(--text-dim);justify-content:space-between;font-size:1rem;font-weight:800;display:flex}.m-num{color:var(--accent-ink)}.m-teams{justify-content:center;align-items:center;gap:12px;margin:12px 0;font-size:1.3rem;font-weight:800;display:flex}.m-teams .vs{opacity:.5;font-size:1rem;font-weight:600}.m-venue{text-align:center;color:var(--text-dim);margin-bottom:12px;font-size:1rem}.m-broadcaster{border-top:1px solid var(--border);padding-top:12px}.m-broadcaster .field.sm{min-height:40px;padding:8px 12px;font-size:1rem}.note-pill{background:var(--accent);color:var(--accent-contrast);border-radius:999px;padding:4px 10px;font-size:1rem;font-weight:800}.m-explainer{background:color-mix(in srgb, var(--accent) 10%, transparent);border:1px dashed var(--accent);border-radius:12px;margin-top:12px;padding:12px;font-size:1rem}.m-explainer strong{color:var(--accent-ink);margin-bottom:4px;display:block}.sweep-list{flex-direction:column;gap:12px;margin-top:16px;display:flex}.sweep-card{gap:12px}.s-member{align-items:center;gap:10px;font-weight:800;display:flex}.s-teams{flex-wrap:wrap;gap:6px;display:flex}.team-pill{background:var(--surface-solid);border:1px solid var(--border);border-radius:8px;padding:4px 10px;font-size:1rem;font-weight:700}.third-place{flex-direction:column;gap:20px;display:flex}.info-card h3{margin-bottom:8px;font-size:1.1rem}.info-card ol{margin-left:20px;font-size:1rem}.qualifier-table{padding:0;overflow:hidden}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table th,.data-table td{border-bottom:1px solid var(--border);padding:12px 16px}.data-table th{background:var(--surface-solid);color:var(--text-dim);font-size:1rem;font-weight:800}.data-table tr.advancing{background:color-mix(in srgb, var(--accent) 8%, transparent)}.data-table tr.eliminated{opacity:.6}.footnote{color:var(--text-dim);text-align:center;font-size:1rem}.fan-toggle{background:var(--surface-solid)!important;color:var(--accent-ink)!important;border-color:var(--accent-ink)!important}.flag-toggle{padding:9px 12px;font-size:1.25rem}.sheet-backdrop{z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;animation:.2s both fade-in;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.sheet{z-index:301;overscroll-behavior:contain;background:var(--bg2);border:1px solid var(--border);width:min(100%,520px);max-height:86dvh;box-shadow:var(--shadow);padding:14px 20px calc(24px + env(safe-area-inset-bottom));gap:var(--s4);border-bottom:none;border-radius:26px 26px 0 0;flex-direction:column;animation:.3s cubic-bezier(.2,.9,.3,1) both sheet-up;display:flex;position:fixed;bottom:0;left:50%;overflow-y:auto;transform:translate(-50%)}@keyframes sheet-up{0%{opacity:.4;transform:translate(-50%,30%)}to{opacity:1;transform:translate(-50%)}}.sheet:focus-visible{outline:none}.sheet-handle{background:var(--border);border-radius:999px;width:48px;height:5px;margin:0 auto}.sheet-title{font-size:var(--t-xl);letter-spacing:-.03em;text-align:center;font-weight:800}.sheet-sub{text-align:center;color:var(--text-dim);font-size:1.05rem;font-weight:600}.theme-preview{text-align:center;font-size:var(--t-base);background:var(--surface);border:1px dashed var(--accent);border-radius:14px;padding:10px 14px;font-weight:700}.theme-preview .theme-emojis{margin-left:6px}.flag-grid{grid-template-columns:repeat(6,1fr);gap:8px;display:grid}@media (width<=380px){.flag-grid{grid-template-columns:repeat(5,1fr)}}.flag-btn{aspect-ratio:1;background:var(--surface-solid);border:2px solid var(--border);cursor:pointer;border-radius:14px;place-items:center;min-height:52px;font-size:1.65rem;line-height:1;transition:transform .12s,border-color .15s,box-shadow .15s;display:grid;position:relative}.flag-btn:hover{transform:translateY(-2px)}.flag-btn:focus-visible{outline:3px solid var(--accent);outline-offset:3px}.flag-btn[aria-pressed=true]{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 45%, transparent);background:color-mix(in srgb, var(--accent) 16%, var(--surface-solid))}.flag-btn .lock{filter:drop-shadow(0 1px 1px #0006);font-size:.68rem;line-height:1;position:absolute;bottom:2px;right:3px}.flag-btn .flag-img{object-fit:cover;border-radius:4px;width:44px;height:33px;box-shadow:0 1px 3px #00000047}.flag-btn .flag-emoji{font-size:1.65rem;line-height:1}.theme-preview .flag-img{object-fit:cover;vertical-align:middle;border-radius:3px;width:30px;height:22px;box-shadow:0 1px 2px #00000040}.unlock-card{gap:var(--s3);background:color-mix(in srgb, var(--gold) 10%, var(--surface-solid));border:2px dashed var(--gold);border-radius:var(--radius);padding:var(--s4);flex-direction:column;display:flex}.unlock-card[hidden]{display:none}.unlock-title{font-weight:800;font-size:var(--t-lg);text-align:center}.unlock-sub{color:var(--text-dim);text-align:center;font-size:1.02rem;font-weight:600}@media (width<=430px){.app-header .bar{gap:8px}.toggle{padding:8px 10px;font-size:.92rem}.logo-btn{font-size:1.15rem}}@media (width<=360px){.logo-btn .hl{display:none}}:root{--font-display:"Bungee", "Bricolage Grotesque", system-ui, sans-serif;--carn-red:#9e2b30;--carn-gold:#e0a33a;--carn-teal:#1f7a72;--carn-purple:#7a3b5c;--carn-cream:#f5ecc8}.alley{gap:var(--s4);flex-direction:column;display:flex}.alley-head{text-align:center}.bunting{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='22' viewBox='0 0 48 22'%3E%3Cline x1='0' y1='3' x2='48' y2='3' stroke='%23caa24a' stroke-width='2'/%3E%3Cpolygon points='2,3 14,3 8,19' fill='%239e2b30'/%3E%3Cpolygon points='18,3 30,3 24,19' fill='%231f7a72'/%3E%3Cpolygon points='34,3 46,3 40,19' fill='%23e0a33a'/%3E%3C/svg%3E");background-position:top;background-repeat:repeat-x;width:100%;height:22px}.alley-title{font-family:var(--font-display);letter-spacing:.01em;color:var(--text);margin:var(--s3) 0 4px;font-size:clamp(1.6rem,7vw,2.4rem);line-height:1.04}.alley-sub{color:var(--text-dim);font-size:1.1rem;font-weight:600}.stall-grid{gap:var(--s3);grid-template-columns:repeat(auto-fill,minmax(165px,1fr));display:grid}.stall{background:var(--surface-solid);border:1px solid var(--border);box-shadow:var(--shadow);text-align:center;padding:0 0 var(--s3);opacity:0;animation:.45s cubic-bezier(.2,.7,.3,1) forwards stall-in;animation-delay:calc(var(--n,0) * 70ms);border-radius:14px;flex-direction:column;display:flex;position:relative;overflow:hidden;transform:translateY(10px)}@keyframes stall-in{to{opacity:1;transform:none}}.stall-awning{border-bottom:2px solid var(--carn-gold);background:repeating-linear-gradient(90deg, var(--awn,var(--carn-red)) 0 15px, var(--carn-cream) 15px 30px);height:18px}.stall:nth-child(4n+1){--awn:var(--carn-red)}.stall:nth-child(4n+2){--awn:var(--carn-teal)}.stall:nth-child(4n+3){--awn:var(--carn-purple)}.stall:nth-child(4n+4){--awn:var(--carn-gold)}.stall-emoji{margin-top:var(--s3);font-size:2.5rem;line-height:1}.stall-name{font-family:var(--font-display);color:var(--text);margin:var(--s2) var(--s2) 4px;font-size:1.05rem;line-height:1.12}.stall-barker{color:var(--text-dim);margin:0 var(--s3) var(--s3);flex:1;font-size:1rem;font-weight:600;line-height:1.4}.stall-tag{color:#2e1320;background:var(--gold);margin:0 0 var(--s3);border-radius:5px;align-self:center;padding:4px 12px;font-size:.85rem;font-weight:800;display:inline-block}.stall-btn{margin:0 var(--s3);background:var(--accent);color:var(--accent-contrast);font-family:var(--font);cursor:pointer;border:none;border-radius:10px;min-height:48px;font-size:1.05rem;font-weight:800;transition:transform .12s}.stall-btn:hover{transform:translateY(-2px)}.stall-btn:active{transform:translateY(0)}.stall-btn:focus-visible{outline:3px solid var(--carn-gold);outline-offset:2px}.stall.needs-crew .stall-btn{color:var(--accent-ink);border:2px solid var(--accent);background:0 0}@media (prefers-reduced-motion:reduce){.stall{opacity:1;animation:none;transform:none}}
