@import url("https://fonts.googleapis.com/css2?family=Fredoka+One&family=Nunito:wght@400;600;700;800&display=swap");:root{--bg-deep:#0d0a1a;--bg-mid:#1a1230;--bg-card:rgba(26,18,48,.92);--accent-green:#7fff6e;--accent-yellow:#ffe94d;--accent-orange:#ff8a3d;--accent-purple:#c084fc;--accent-pink:#f472b6;--text-primary:#f0eaff;--text-muted:#a89cc8;--border-subtle:rgba(168,156,200,.2);--border-glow:rgba(127,255,110,.35);--shadow-card:0 8px 32px rgba(0,0,0,.55),0 2px 8px rgba(0,0,0,.4);--shadow-btn:0 4px 20px rgba(127,255,110,.3);--radius-pill:999px;--radius-card:20px;--font-display:"Fredoka One",cursive;--font-body:"Nunito",sans-serif;color:var(--text-primary);background:var(--bg-deep);font-family:var(--font-body)}*{box-sizing:border-box}body,html,main{width:100%;height:100%;margin:0}body{overflow:hidden;background:var(--bg-deep)}.app-shell{position:relative;width:100vw;height:100vh}.map-root{position:absolute;inset:0;z-index:1}.map-canvas{width:100%;height:100%}.map-status{position:absolute;top:16px;left:50%;transform:translateX(-50%);z-index:2;background:rgba(13,10,26,.82);border:1px solid var(--border-subtle);border-radius:var(--radius-pill);padding:6px 14px;font-size:12px;font-weight:600;letter-spacing:.02em;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-family:var(--font-body)}.map-status.error{border-color:rgba(244,114,182,.5);color:#fda4af}.hud-bottom-left,.hud-error,.hud-right-center,.hud-top-left,.hud-top-right{position:absolute;z-index:10}.hud-top-left{top:18px;left:18px}.hud-top-right{top:18px;right:18px;display:flex;gap:8px;align-items:center}.hud-top-center{position:absolute;z-index:10;top:18px;left:50%;transform:translateX(-50%)}.ai-commentary-banner{max-width:min(72vw,760px);background:rgba(13,10,26,.86);border:1px solid var(--border-subtle);border-radius:var(--radius-pill);padding:8px 14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:baseline;gap:8px}.ai-commentary-text{font-size:13px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.ai-commentary-meta{font-size:11px;color:var(--text-muted);white-space:nowrap;flex:0 0 auto}.hud-right-center{top:50%;right:18px;transform:translateY(-50%)}.hud-bottom-left{left:24px;bottom:24px}.hud-error{left:50%;bottom:24px;transform:translateX(-50%);background:rgba(127,29,29,.9);color:#fecaca;border-radius:var(--radius-pill);padding:8px 18px;border:1px solid hsla(0,91%,71%,.4);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap}.hud-error,.overlay-btn{font-size:13px;font-weight:700}.overlay-btn{background:rgba(13,10,26,.78);border:1px solid var(--border-subtle);color:var(--text-primary);border-radius:var(--radius-pill);padding:9px 16px;font-family:var(--font-body);cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all .18s ease;letter-spacing:.01em}.overlay-btn:hover{border-color:var(--accent-green);color:var(--accent-green);box-shadow:0 0 16px rgba(127,255,110,.2)}.admin-btn{border-color:rgba(251,191,36,.45);color:var(--accent-yellow)}.admin-btn:hover{border-color:var(--accent-yellow);color:var(--accent-yellow);box-shadow:0 0 16px rgba(255,233,77,.25)}.refresh-btn{width:38px;height:38px;padding:0;font-size:18px;line-height:1;display:grid;place-items:center;border-color:rgba(192,132,252,.35)}.refresh-btn:hover{border-color:var(--accent-purple);color:var(--accent-purple);box-shadow:0 0 14px rgba(192,132,252,.25)}.create-event-btn{width:80px;height:80px;border-radius:999px;border:2px solid rgba(127,255,110,.5);background:radial-gradient(circle at 35% 35%,#9ef578,#4ade80 45%,#16a34a);color:#0d1a0a;font-size:38px;display:grid;place-items:center;box-shadow:0 0 0 6px rgba(127,255,110,.12),0 0 30px rgba(127,255,110,.35),0 8px 24px rgba(0,0,0,.55);cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);font-family:var(--font-body);animation:fart-pulse 2.8s ease-in-out infinite}.create-event-wrap{position:relative;width:80px;height:80px}.create-event-wrap.disabled{opacity:.65}.create-event-btn:hover:not(:disabled){transform:scale(1.1);box-shadow:0 0 0 10px rgba(127,255,110,.15),0 0 50px rgba(127,255,110,.5),0 12px 30px rgba(0,0,0,.6)}.create-event-btn:active:not(:disabled){transform:scale(.93);animation:none}.create-event-btn:disabled{opacity:.4;cursor:not-allowed;animation:none;filter:grayscale(.5)}@keyframes fart-pulse{0%,to{box-shadow:0 0 0 6px rgba(127,255,110,.12),0 0 30px rgba(127,255,110,.35),0 8px 24px rgba(0,0,0,.55)}50%{box-shadow:0 0 0 10px rgba(127,255,110,.18),0 0 50px rgba(127,255,110,.55),0 8px 24px rgba(0,0,0,.55)}}.create-event-icon{line-height:1;transform:translateY(-1px);filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));animation:icon-bob 1.6s ease-in-out infinite}.create-event-btn:active:not(:disabled) .create-event-icon{animation:icon-pop .22s ease}.create-event-burst{position:absolute;inset:-6px;pointer-events:none}.create-event-particle{position:absolute;left:50%;top:50%;width:9px;height:9px;margin-left:-4.5px;margin-top:-4.5px;border-radius:999px;background:radial-gradient(circle,#fff9c4 0,#7fff6e 65%,#16a34a 100%);box-shadow:0 0 10px rgba(127,255,110,.5);transform:rotate(var(--burst-angle)) translateY(0);opacity:0;animation:burst-out .52s ease-out}@keyframes burst-out{0%{opacity:.95;transform:rotate(var(--burst-angle)) translateY(0) scale(1)}to{opacity:0;transform:rotate(var(--burst-angle)) translateY(-52px) scale(.6)}}@keyframes icon-bob{0%,to{transform:translateY(-1px) rotate(-2deg)}50%{transform:translateY(1px) rotate(2deg)}}@keyframes icon-pop{0%{transform:scale(1) translateY(-1px)}60%{transform:scale(1.35) translateY(-2px)}to{transform:scale(1) translateY(-1px)}}.zoom-buttons{width:46px;border-radius:23px;background:rgba(13,10,26,.82);border:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:5px;padding:8px 6px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-card)}.zoom-level-btn{width:32px;height:32px;border-radius:999px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-muted);font-size:12px;font-weight:800;font-family:var(--font-body);padding:0;cursor:pointer;transition:all .16s ease}.zoom-level-btn:hover{border-color:var(--accent-purple);color:var(--accent-purple)}.zoom-level-btn.active{background:var(--accent-green);color:#0d1a0a;border-color:var(--accent-green);box-shadow:0 0 10px rgba(127,255,110,.4)}.first-screen-overlay{position:absolute;inset:0;z-index:20;background:radial-gradient(ellipse at 30% 20%,rgba(127,255,110,.06) 0,transparent 55%),radial-gradient(ellipse at 75% 80%,rgba(192,132,252,.08) 0,transparent 50%),linear-gradient(160deg,rgba(13,10,26,.7),rgba(26,18,48,.88));-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:16px}.first-screen-card{width:min(440px,100%);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-card);padding:28px 24px 24px;box-shadow:var(--shadow-card),0 0 60px rgba(127,255,110,.06);position:relative;overflow:hidden}.first-screen-card:before{content:"";position:absolute;inset:0;border-radius:var(--radius-card);background:linear-gradient(135deg,rgba(127,255,110,.05),transparent 50%);pointer-events:none}.first-screen-title{margin:0 0 4px;font-size:42px;font-family:var(--font-display);letter-spacing:.02em;line-height:1.1}.first-screen-title-text{background:linear-gradient(135deg,var(--accent-green) 0,var(--accent-yellow) 60%,var(--accent-orange) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.first-screen-emoji{font-size:32px;display:inline-block;margin-right:8px;animation:wobble 2s ease-in-out infinite}@keyframes wobble{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.first-screen-subtitle{margin:6px 0 22px;font-size:14px;color:var(--text-muted);font-weight:600;line-height:1.5}.first-screen-error{margin:12px 0 0;font-size:13px;color:#fda4af;font-weight:700}.geo-gate,.nickname-form{margin-bottom:14px}.field-label{display:block;font-size:11px;font-weight:800;color:var(--text-muted);margin-bottom:7px;letter-spacing:.08em;text-transform:uppercase}.field-input{width:100%;border-radius:12px;border:1px solid var(--border-subtle);background:rgba(13,10,26,.6);color:var(--text-primary);padding:12px 14px;font-size:14px;font-family:var(--font-body);font-weight:600;transition:border-color .18s ease,box-shadow .18s ease;outline:none}.field-input:focus{border-color:var(--accent-green);box-shadow:0 0 0 3px rgba(127,255,110,.12)}.field-input::placeholder{color:rgba(168,156,200,.45)}.admin-action-btn,.geo-btn{width:100%;border-radius:12px;border:1px solid var(--border-subtle);background:rgba(13,10,26,.6);color:var(--text-primary);padding:12px 14px;font-size:14px;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:all .2s ease;text-align:left}.admin-action-btn:hover,.geo-btn:hover{border-color:var(--accent-purple);background:rgba(192,132,252,.1);color:var(--accent-purple)}.geo-copy,.small-copy{margin:8px 2px 0;font-size:12px;color:var(--text-muted);font-weight:600}.modal-backdrop{position:absolute;inset:0;z-index:30;background:rgba(13,10,26,.65);display:grid;place-items:center;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fade-in .18s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-card{width:min(520px,100%);max-height:min(80vh,640px);overflow-y:auto;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-card);padding:20px 18px;box-shadow:var(--shadow-card),0 0 80px rgba(0,0,0,.4);animation:slide-up .22s cubic-bezier(.34,1.56,.64,1)}@keyframes slide-up{0%{transform:translateY(24px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-card::-webkit-scrollbar{width:5px}.modal-card::-webkit-scrollbar-track{background:transparent}.modal-card::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:99px}.modal-header-row{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px}.modal-title{margin:0;font-size:22px;font-family:var(--font-display);background:linear-gradient(135deg,var(--accent-green),var(--accent-yellow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-subtitle{margin:0 0 10px;font-size:11px;font-weight:800;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}.leaderboard-list,.summary-list{margin:0 0 18px;padding:0;list-style:none;display:grid;grid-gap:6px;gap:6px}.leaderboard-item,.summary-list li{display:grid;grid-template-columns:44px 1fr auto;align-items:center;grid-gap:10px;gap:10px;background:rgba(13,10,26,.6);border:1px solid var(--border-subtle);border-radius:12px;padding:10px 12px;font-size:13px;font-weight:700;transition:border-color .15s ease,background .15s ease}.leaderboard-item:hover,.summary-list li:hover{border-color:rgba(127,255,110,.25);background:rgba(127,255,110,.04)}.leaderboard-item:first-child{border-color:rgba(255,233,77,.35);background:rgba(255,233,77,.05)}.leaderboard-item:first-child span:first-child{color:var(--accent-yellow)}.leaderboard-item:nth-child(2) span:first-child{color:#d0d0d0}.leaderboard-item:nth-child(3) span:first-child{color:#cd7f32}.leaderboard-item span:first-child{color:var(--text-muted);font-size:12px}.leaderboard-item strong,.summary-list li strong{color:var(--accent-green);font-size:14px}.summary-list li{grid-template-columns:1fr auto}.inline-error{margin:8px 0;color:#fda4af}.inline-error,.inline-success{font-size:12px;font-weight:700}.inline-success{margin-top:8px;color:var(--accent-green)}.mock-generator-inline{margin-bottom:16px;padding:14px;border-radius:14px;background:rgba(255,138,61,.07);border:1px solid rgba(255,138,61,.25)}.mock-generator-inline .admin-action-btn+.admin-action-btn{margin-top:8px}.ai-monetization-block{margin-top:12px;padding-top:12px;border-top:1px dashed var(--border-subtle)}.admin-ai-actions{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}.admin-ai-skeleton{display:grid;grid-gap:6px;gap:6px;margin:8px 0}.admin-ai-skeleton>div{height:14px;border-radius:8px;background:linear-gradient(90deg,rgba(168,156,200,.18),rgba(168,156,200,.35),rgba(168,156,200,.18));background-size:180% 100%;animation:ai-skeleton 1.2s ease-in-out infinite}.admin-ai-report,.admin-ai-sns{margin-top:10px;padding:10px;border-radius:12px;border:1px solid var(--border-subtle);background:rgba(13,10,26,.55)}.admin-ai-title{margin:0 0 8px;font-size:16px;font-weight:800}.admin-ai-label{margin:0 0 4px;font-size:11px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.admin-ai-line{margin:0 0 8px;font-size:13px;font-weight:700;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.admin-ai-chips{display:flex;flex-wrap:wrap;gap:6px}.admin-chip{border:1px solid var(--border-subtle);border-radius:999px;padding:4px 8px;font-size:11px;font-weight:700;color:var(--text-muted)}.sns-row{margin-bottom:10px;padding-bottom:10px;border-bottom:1px dashed rgba(168,156,200,.18)}.sns-row:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;clip:rect(0,0,0,0);overflow:hidden}.card{display:block}button,input{font:inherit}*{scrollbar-width:thin;scrollbar-color:var(--border-subtle) transparent}@media (max-width:768px){.hud-top-left{left:10px}.hud-top-left,.hud-top-right{top:calc(env(safe-area-inset-top, 0px) + 10px)}.hud-top-right{right:10px;flex-direction:row;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:6px;max-width:min(66vw,280px)}.hud-top-left .overlay-btn,.hud-top-right .overlay-btn{font-size:12px;padding:8px 12px}.hud-top-right .overlay-btn{max-width:50vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hud-top-right .refresh-btn{width:34px;height:34px;font-size:16px;padding:0}.create-event-btn,.create-event-wrap{width:70px;height:70px}.create-event-btn{font-size:34px}.zoom-buttons{width:42px;gap:4px;padding:6px 5px}.zoom-level-btn{width:30px;height:30px;font-size:11px}.modal-card{max-height:86vh;padding:16px 14px}.first-screen-title{font-size:36px}.first-screen-card{padding:22px 18px 20px}.hud-top-center{top:calc(env(safe-area-inset-top, 0px) + 56px);left:12px;right:12px;transform:none}.ai-commentary-banner{max-width:100%;padding:7px 10px;gap:6px}.ai-commentary-text{font-size:12px}.ai-commentary-meta{font-size:10px}}