:root{--color-primary: #6C5CE7;--color-primary-light: #A29BFE;--color-primary-dark: #5541D7;--color-secondary: #00CEC9;--color-secondary-light: #81ECEC;--color-secondary-dark: #00B5B0;--color-accent: #FD79A8;--color-accent-light: #FDCBDF;--color-accent-dark: #E84393;--color-gold: #FDCB6E;--color-gold-light: #FFEAA7;--color-gold-dark: #F39C12;--color-xp: #00B894;--color-xp-light: #55EFC4;--color-xp-dark: #00A185;--color-coins: #FDCB6E;--color-gems: #A29BFE;--color-common: #B2BEC3;--color-rare: #74B9FF;--color-epic: #A29BFE;--color-legendary: #FDCB6E;--color-event: #FD79A8;--bg-primary: #0D1117;--bg-secondary: #161B22;--bg-tertiary: #21262D;--bg-card: #1C2128;--bg-elevated: #2D333B;--text-primary: #F0F6FC;--text-secondary: #8B949E;--text-muted: #6E7681;--text-link: #58A6FF;--border-default: #30363D;--border-muted: #21262D;--border-subtle: #1C2128;--color-success: #00B894;--color-warning: #FDCB6E;--color-error: #FF6B6B;--color-info: #74B9FF;--gradient-primary: linear-gradient(135deg, #6C5CE7 0%, #A29BFE 100%);--gradient-secondary: linear-gradient(135deg, #00CEC9 0%, #81ECEC 100%);--gradient-accent: linear-gradient(135deg, #FD79A8 0%, #FDCBDF 100%);--gradient-gold: linear-gradient(135deg, #F39C12 0%, #FDCB6E 100%);--gradient-xp: linear-gradient(135deg, #00B894 0%, #55EFC4 100%);--gradient-dark: linear-gradient(135deg, #0D1117 0%, #161B22 100%);--gradient-neon: linear-gradient(135deg, #6C5CE7 0%, #00CEC9 50%, #FD79A8 100%);--gradient-fire: linear-gradient(135deg, #FF6B6B 0%, #FDCB6E 100%);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .6);--shadow-glow-primary: 0 0 20px rgba(108, 92, 231, .5);--shadow-glow-secondary: 0 0 20px rgba(0, 206, 201, .5);--shadow-glow-accent: 0 0 20px rgba(253, 121, 168, .5);--shadow-glow-gold: 0 0 20px rgba(253, 203, 110, .5);--shadow-glow-xp: 0 0 20px rgba(0, 184, 148, .5);--glass-bg: rgba(22, 27, 34, .8);--glass-border: rgba(48, 54, 61, .5);--glass-blur: blur(12px);--scrollbar-size: 6px;--scrollbar-track: rgba(22, 27, 34, .35);--scrollbar-thumb: rgba(108, 92, 231, .45);--scrollbar-thumb-hover: rgba(162, 155, 254, .75);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55);--font-main: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Poppins", var(--font-main);--font-mono: "JetBrains Mono", "Fira Code", monospace;--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 900;--z-modal: 1000;--z-notification: 2000;--z-tooltip: 3000}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-md);font-family:var(--font-main);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-normal);text-decoration:none}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow-primary)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 30px #6c5ce799}.btn-secondary{background:var(--gradient-secondary);color:var(--bg-primary);box-shadow:var(--shadow-md),var(--shadow-glow-secondary)}.btn-secondary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 30px #00cec999}.btn-accent{background:var(--gradient-accent);color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow-accent)}.btn-gold{background:var(--gradient-gold);color:var(--bg-primary);box-shadow:var(--shadow-md),var(--shadow-glow-gold)}.btn-ghost{background:transparent;color:var(--text-primary);border:1px solid var(--border-default)}.btn-ghost:hover{background:var(--bg-tertiary);border-color:var(--color-primary)}.btn-icon{width:48px;height:48px;padding:0;border-radius:var(--radius-full);font-size:20px}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:16px}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:12px}.card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-lg)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-default)}.card-title{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--text-primary)}.card-body{color:var(--text-secondary)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);opacity:0;visibility:hidden;transition:all var(--transition-normal)}.modal-backdrop.active{opacity:1;visibility:visible}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-xl);max-width:90vw;max-height:90vh;overflow-y:auto;z-index:var(--z-modal);opacity:0;visibility:hidden;transition:all var(--transition-normal)}.modal.active{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.modal-title{font-family:var(--font-display);font-size:24px;font-weight:700;background:var(--gradient-neon);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-close{flex-shrink:0;margin-left:var(--space-md);width:44px;height:44px;border-radius:var(--radius-full);background:var(--bg-tertiary);border:none;color:var(--text-secondary);font-size:22px;line-height:1;cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--color-error);color:#fff}.badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:2px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-primary{background:var(--color-primary);color:#fff}.badge-secondary{background:var(--color-secondary);color:var(--bg-primary)}.badge-accent{background:var(--color-accent);color:#fff}.badge-gold{background:var(--color-gold);color:var(--bg-primary)}.badge-success{background:var(--color-success);color:#fff}.badge-warning{background:var(--color-warning);color:var(--bg-primary)}.badge-error{background:var(--color-error);color:#fff}.badge-common{background:var(--color-common);color:var(--bg-primary)}.badge-rare{background:var(--color-rare);color:#fff}.badge-epic{background:var(--color-epic);color:#fff}.badge-legendary{background:var(--gradient-gold);color:var(--bg-primary);box-shadow:var(--shadow-glow-gold)}.input{width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-main);font-size:14px;transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6c5ce733}.input::placeholder{color:var(--text-muted)}.input-group{margin-bottom:var(--space-md)}.input-label{display:block;margin-bottom:var(--space-xs);font-size:14px;font-weight:500;color:var(--text-secondary)}.progress{width:100%;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background:var(--gradient-xp);border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-bar.animated{animation:progressPulse 2s ease-in-out infinite}@keyframes progressPulse{0%,to{opacity:1}50%{opacity:.7}}.toast{position:fixed;top:var(--space-lg);right:var(--space-lg);padding:var(--space-md) var(--space-lg);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:var(--z-notification);transform:translate(120%);transition:transform var(--transition-bounce)}.toast.show{transform:translate(0)}.toast-success{border-left:4px solid var(--color-success)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-error{border-left:4px solid var(--color-error)}.toast-info{border-left:4px solid var(--color-info)}.toast-xp{border-left:4px solid var(--color-xp)}.toast-achievement{border-left:4px solid var(--color-gold);background:linear-gradient(135deg,rgba(253,203,110,.1) 0%,var(--glass-bg) 100%)}.avatar{width:48px;height:48px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;border:2px solid var(--border-default)}.avatar-sm{width:32px;height:32px;font-size:14px}.avatar-lg{width:64px;height:64px;font-size:28px}.avatar-xl{width:96px;height:96px;font-size:40px;border-width:3px}.avatar-img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-full)}.level-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 var(--space-sm);background:var(--gradient-primary);border-radius:var(--radius-full);font-size:12px;font-weight:700;color:#fff;box-shadow:var(--shadow-glow-primary)}.level-badge-lg{min-width:40px;height:40px;font-size:16px}.divider{height:1px;background:var(--border-default);margin:var(--space-lg) 0}.divider-vertical{width:1px;height:100%;background:var(--border-default)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-gold{color:var(--color-gold)}.text-xp{color:var(--color-xp)}.text-gradient{background:var(--gradient-neon);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.glow-primary{box-shadow:var(--shadow-glow-primary)}.glow-secondary{box-shadow:var(--shadow-glow-secondary)}.glow-accent{box-shadow:var(--shadow-glow-accent)}.glow-gold{box-shadow:var(--shadow-glow-gold)}.glow-xp{box-shadow:var(--shadow-glow-xp)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.w-full{width:100%}.h-full{height:100%}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}:where(.modal,#balloon-form,#category-filter,#debug-logs,#settings-modal,#arena-modal,#arena-editor-modal,#brand-edit-modal,.leaderboard-list,.shop-body,.settings-content,.category-list,.brands-list){scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}#search-modal,#search-modal .results-list{scrollbar-width:none}::-webkit-scrollbar{width:var(--scrollbar-size);height:var(--scrollbar-size)}::-webkit-scrollbar-track{background:var(--scrollbar-track);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:var(--radius-full);border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover);background-clip:padding-box}::-webkit-scrollbar-corner{background:transparent}::selection{background:var(--color-primary);color:#fff}:root{--color-paper: #f1e8d5;--color-paper-light: #f8f1df;--color-surface: #fefaf0;--color-surface-alt: #fbf3e2;--color-ink: #2a2018;--color-ink-2: #5b4a38;--color-ink-3: #8a7560;--color-hairline: rgba(60, 40, 20, .1);--color-border: rgba(60, 40, 20, .15);--color-coral: #ff7e6b;--color-sky: #85c5e3;--color-sage: #a8c9a8;--color-sun: #f4c95d;--color-plum: #c89db0;--font-display: "Fraunces", "Instrument Serif", Georgia, serif;--font-body: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Geist Mono", "JetBrains Mono", "Courier New", monospace;--shadow-paper-sm: 0 2px 0 rgba(60, 40, 20, .08), 0 0 0 1px rgba(60, 40, 20, .06);--shadow-paper-md: 0 6px 0 rgba(60, 40, 20, .06), 0 12px 28px rgba(60, 40, 20, .1), 0 0 0 1px rgba(60, 40, 20, .06);--shadow-balloon: 0 6px 14px rgba(40, 20, 10, .22);--bg-primary: var(--color-paper);--bg-secondary: var(--color-paper-light);--bg-tertiary: var(--color-surface-alt);--bg-card: var(--color-surface);--bg-elevated: var(--color-surface);--text-primary: var(--color-ink);--text-secondary: var(--color-ink-2);--text-muted: var(--color-ink-3);--text-link: #4f95b5;--border-default: var(--color-border);--border-muted: var(--color-hairline);--border-subtle: rgba(60, 40, 20, .06);--color-primary: var(--color-coral);--color-primary-light: #ffac9c;--color-primary-dark: #c95a48;--color-secondary: var(--color-sky);--color-secondary-light: #cfe6f0;--color-secondary-dark: #4f95b5;--color-accent: var(--color-plum);--color-accent-light: #ead0da;--color-accent-dark: #9b6a80;--color-gold: var(--color-sun);--color-gold-light: #ffe7a3;--color-gold-dark: #c9972c;--color-xp: var(--color-sage);--color-xp-light: #d8e8c8;--color-xp-dark: #749d70;--color-coins: var(--color-sun);--color-gems: var(--color-sky);--gradient-primary: linear-gradient(135deg, #ff7e6b 0%, #f4c95d 100%);--gradient-secondary: linear-gradient(135deg, #85c5e3 0%, #cfe6f0 100%);--gradient-accent: linear-gradient(135deg, #c89db0 0%, #f3cfda 100%);--gradient-gold: linear-gradient(135deg, #f4c95d 0%, #ffe7a3 100%);--gradient-xp: linear-gradient(135deg, #a8c9a8 0%, #d8e8c8 100%);--gradient-dark: linear-gradient(135deg, #f1e8d5 0%, #f8f1df 100%);--gradient-neon: linear-gradient(135deg, #ff7e6b 0%, #f4c95d 48%, #85c5e3 100%);--gradient-fire: linear-gradient(135deg, #ff7e6b 0%, #f4c95d 100%);--shadow-sm: 0 1px 2px rgba(40, 20, 10, .08);--shadow-md: 0 4px 8px rgba(40, 20, 10, .12);--shadow-lg: 0 8px 16px rgba(40, 20, 10, .16);--shadow-xl: 0 16px 34px rgba(40, 20, 10, .18);--shadow-glow-primary: 0 8px 22px rgba(255, 126, 107, .24);--shadow-glow-secondary: 0 8px 22px rgba(133, 197, 227, .24);--shadow-glow-accent: 0 8px 22px rgba(200, 157, 176, .24);--shadow-glow-gold: 0 8px 22px rgba(244, 201, 93, .28);--shadow-glow-xp: 0 8px 22px rgba(168, 201, 168, .26);--glass-bg: rgba(254, 250, 240, .92);--glass-border: rgba(60, 40, 20, .1);--glass-blur: blur(10px);--font-main: var(--font-body)}@keyframes float{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-15px) rotate(2deg)}}@keyframes sway{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #6c5ce766}50%{transform:scale(1.05);box-shadow:0 0 20px 10px #6c5ce700}}@keyframes xpPulse{0%{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.1);filter:brightness(1.3)}to{transform:scale(1);filter:brightness(1)}}@keyframes levelUp{0%{transform:scale(.5) rotate(-10deg);opacity:0}50%{transform:scale(1.2) rotate(5deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}@keyframes shine{0%{background-position:-200% center}to{background-position:200% center}}@keyframes bounceIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.15)}70%{transform:scale(.9)}to{transform:scale(1);opacity:1}}@keyframes bounceOut{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1)}to{transform:scale(0);opacity:0}}@keyframes slideUpFadeIn{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDownFadeOut{0%{transform:translateY(0);opacity:1}to{transform:translateY(30px);opacity:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes rotateIn{0%{transform:rotate(-180deg) scale(0);opacity:0}to{transform:rotate(0) scale(1);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}@keyframes heartbeat{0%,to{transform:scale(1)}25%{transform:scale(1.1)}50%{transform:scale(1)}75%{transform:scale(1.1)}}@keyframes glowPulse{0%,to{box-shadow:0 0 5px currentColor,0 0 10px currentColor}50%{box-shadow:0 0 20px currentColor,0 0 40px currentColor}}@keyframes rainbow{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes ripple{0%{transform:scale(0);opacity:1}to{transform:scale(4);opacity:0}}@keyframes xpParticle{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-100px) scale(.5);opacity:0}}.xp-particle{position:fixed;pointer-events:none;font-size:16px;font-weight:700;color:var(--color-xp);text-shadow:0 0 10px var(--color-xp);animation:xpParticle 1.5s ease-out forwards;z-index:9999}@keyframes coinParticle{0%{transform:translateY(0) rotate(0) scale(1);opacity:1}to{transform:translateY(-80px) rotate(360deg) scale(.3);opacity:0}}.coin-particle{position:fixed;pointer-events:none;width:24px;height:24px;animation:coinParticle 1s ease-out forwards;z-index:9999}@keyframes starParticle{0%{transform:translate(0) rotate(0) scale(0);opacity:1}50%{transform:translate(var(--tx),var(--ty)) rotate(180deg) scale(1);opacity:1}to{transform:translate(calc(var(--tx) * 2),calc(var(--ty) * 2)) rotate(360deg) scale(0);opacity:0}}.star-particle{position:fixed;pointer-events:none;font-size:20px;animation:starParticle 1s ease-out forwards;z-index:9999}@keyframes confettiFall{0%{transform:translateY(-100vh) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.confetti{position:fixed;top:0;pointer-events:none;z-index:9998}.confetti-piece{position:absolute;width:10px;height:10px;animation:confettiFall linear forwards}.confetti-piece:nth-child(odd){border-radius:50%}.confetti-piece:nth-child(2n){border-radius:2px}@keyframes achievementUnlock{0%{transform:translate(100%) scale(.8);opacity:0}20%{transform:translate(0) scale(1.1);opacity:1}30%{transform:translate(0) scale(1)}80%{transform:translate(0) scale(1);opacity:1}to{transform:translate(100%) scale(.8);opacity:0}}.achievement-toast{position:fixed;top:80px;right:20px;display:flex;align-items:center;gap:16px;padding:16px 24px;background:linear-gradient(135deg,#fdcb6e33,#161b22f2);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:2px solid var(--color-gold);border-radius:16px;box-shadow:0 0 30px #fdcb6e4d;z-index:9999;animation:achievementUnlock 4s ease-in-out forwards}.achievement-toast-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:32px;background:var(--gradient-gold);border-radius:50%;animation:heartbeat .5s ease-in-out .3s}.achievement-toast-content{display:flex;flex-direction:column;gap:4px}.achievement-toast-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--color-gold)}.achievement-toast-title{font-size:18px;font-weight:700;color:#fff}@keyframes balloonAppear{0%{transform:scale(0) translateY(50px);opacity:0}60%{transform:scale(1.2) translateY(-10px)}80%{transform:scale(.9) translateY(5px)}to{transform:scale(1) translateY(0);opacity:1}}.balloon-new{animation:balloonAppear .6s cubic-bezier(.68,-.55,.265,1.55) forwards}@keyframes balloonPop{0%{transform:scale(1);opacity:1}50%{transform:scale(1.3)}to{transform:scale(0);opacity:0}}.balloon-pop{animation:balloonPop .3s ease-out forwards}.balloon-float{animation:float 3s ease-in-out infinite}.balloon-tail-svg{transform-origin:top center;animation:sway 4s ease-in-out infinite}@keyframes voteUp{0%{transform:scale(1)}25%{transform:scale(1.3)}50%{transform:scale(.9)}75%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes voteDown{0%{transform:scale(1) rotate(0)}25%{transform:scale(.8) rotate(-5deg)}50%{transform:scale(1.1) rotate(5deg)}75%{transform:scale(.95) rotate(-2deg)}to{transform:scale(1) rotate(0)}}.vote-up-effect{animation:voteUp .4s ease-out}.vote-down-effect{animation:voteDown .4s ease-out}@keyframes dotsLoading{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}.loading-dots{display:flex;gap:8px}.loading-dots span{width:12px;height:12px;background:var(--color-primary);border-radius:50%;animation:dotsLoading 1.4s ease-in-out infinite}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}.spinner{width:40px;height:40px;border:3px solid var(--bg-tertiary);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes skeleton{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-elevated) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:skeleton 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes eventPulse{0%,to{box-shadow:0 0 #fd79a866}50%{box-shadow:0 0 0 15px #fd79a800}}.event-active{animation:eventPulse 2s ease-in-out infinite}@keyframes timerUrgent{0%,to{color:var(--color-error)}50%{color:var(--color-warning)}}.timer-urgent{animation:timerUrgent 1s ease-in-out infinite}@keyframes streakFire{0%,to{transform:scale(1) rotate(-2deg);filter:brightness(1)}50%{transform:scale(1.1) rotate(2deg);filter:brightness(1.2)}}.streak-fire{animation:streakFire .5s ease-in-out infinite}.animate-float{animation:float 3s ease-in-out infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-bounce-in{animation:bounceIn .5s cubic-bezier(.68,-.55,.265,1.55) forwards}.animate-fade-in{animation:fadeIn .3s ease-out forwards}.animate-slide-up{animation:slideUpFadeIn .4s ease-out forwards}.animate-shake{animation:shake .5s ease-in-out}.animate-heartbeat{animation:heartbeat 1s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-glow{animation:glowPulse 2s ease-in-out infinite}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.game-hud{position:fixed;top:0;left:0;right:0;padding:14px var(--space-md);background:linear-gradient(180deg,#f1e8d5f5,#f1e8d500);z-index:500;pointer-events:none}.game-hud .hud-top{pointer-events:none}.game-hud .hud-left-cluster,.game-hud .quick-stats,.game-hud #auth-root,.game-hud .soft-search-pill{pointer-events:auto}.game-hud--guest .player-info,.game-hud--guest .quick-stats{display:none}.hud-top{display:flex;align-items:center;justify-content:space-between;gap:12px}@media (min-width: 769px){.hud-top .soft-search-pill{position:static;flex:0 1 clamp(200px,28vw,320px);width:100%;max-width:320px;min-width:0;margin:0;z-index:1}.game-hud--guest .hud-top .soft-search-pill{flex:0 1 min(320px,48vw);max-width:320px;margin-inline:auto}}.hud-left-cluster{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:1;min-width:0;padding-right:6px}.player-info{position:relative;display:flex;align-items:center;gap:var(--space-sm);background:var(--color-surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--color-hairline);border-radius:var(--radius-full);padding:5px 14px 5px 5px;box-shadow:var(--shadow-paper-sm);cursor:pointer}.hud-account-dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:204px;padding:var(--space-xs);background:#fefaf0f5;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--color-hairline);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:600}.hud-account-dropdown[hidden]{display:none!important}.hud-account-item{display:flex;width:100%;align-items:center;gap:var(--space-sm);padding:10px 12px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-ink);font-family:var(--font-body);font-size:13px;font-weight:600;text-align:left;cursor:pointer;transition:background var(--transition-fast)}.hud-account-item:hover{background:var(--color-surface-alt)}.hud-account-item--danger{color:var(--color-error);font-weight:600}.auth-profile-host{position:relative;flex-shrink:0}#game-hud button.auth-hud-icon-btn{box-sizing:border-box;flex:none;width:44px;height:44px;min-width:44px;min-height:44px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:50%;aspect-ratio:1;background:var(--color-surface);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--color-hairline);color:var(--color-ink);cursor:pointer;box-shadow:var(--shadow-paper-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast);flex-shrink:0;-webkit-tap-highlight-color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none}#game-hud button.auth-hud-icon-btn:hover{transform:translateY(-1px);border-color:#3c28142e;box-shadow:var(--shadow-paper-md);background:var(--color-surface)}#game-hud button.auth-hud-icon-btn:active{transform:scale(.97)}#game-hud button.auth-hud-icon-btn:focus-visible{outline:none;border-color:var(--color-secondary);box-shadow:var(--shadow-md),var(--shadow-glow-secondary)}#game-hud button.auth-hud-icon-btn svg path{fill:currentColor}#game-hud button.auth-hud-icon-btn svg{display:block}.player-avatar{position:relative;width:40px;height:40px}.player-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:2px solid #fff;box-shadow:0 0 0 2px var(--color-coral)}.player-avatar-emoji{width:100%;height:100%;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:20px;border:2px solid #fff;box-shadow:0 0 0 1.5px #3c28141a;color:#fff;text-transform:uppercase}.player-avatar-emoji.player-avatar-emoji--letter{font-family:var(--font-display);font-size:22px;font-weight:600;letter-spacing:-.02em;color:#fff}.player-level-badge{position:absolute;bottom:-4px;right:-4px;min-width:20px;height:20px;padding:0 4px;background:var(--gradient-gold);border-radius:var(--radius-full);font-size:10px;font-weight:700;color:var(--color-ink);display:flex;align-items:center;justify-content:center;border:2px solid #fff;box-shadow:var(--shadow-sm)}.player-details{display:flex;flex-direction:column;gap:2px}.player-name{font-size:13px;font-weight:600;color:var(--color-ink);line-height:1;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-xp-bar{width:100px;height:6px;background:#efe2c8;border-radius:var(--radius-full);overflow:hidden}.player-xp-fill{height:100%;background:var(--gradient-xp);border-radius:var(--radius-full);transition:width .5s ease-out;box-shadow:none}.player-xp-text{font-size:10px;color:var(--color-ink-3)}.quick-stats{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.stat-item{display:flex;align-items:center;gap:4px;padding:5px 10px 5px 5px;background:var(--color-surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--color-hairline);border-radius:var(--radius-full);font-size:13px;font-weight:600;cursor:pointer;color:var(--color-ink);box-shadow:var(--shadow-paper-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.stat-item:hover{border-color:#3c28142e;transform:translateY(-1px);box-shadow:var(--shadow-paper-md)}.stat-icon{font-size:16px;width:24px;height:24px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;background:var(--color-paper-light)}.coin-icon-visual{display:inline-block;width:1.125rem;height:1.125rem;flex-shrink:0;border-radius:50%;background:radial-gradient(circle at 32% 28%,#fffef5,#ffeaa7 22%,#fdcb6e 48%,#f39c12 78%,#d35400);box-shadow:inset 0 -2px 5px #00000061,inset 0 2px 4px #ffffff6b,0 1px 3px #00000038;vertical-align:-.22em}.coin-icon-visual--sm{width:.95em;height:.95em;vertical-align:-.14em}.coin-icon-visual--lg{width:2.35rem;height:2.35rem;vertical-align:middle}.stat-value{color:var(--color-ink)}.stat-coins .stat-icon{color:var(--color-coins)}.stat-gems .stat-icon{color:var(--color-gems)}.stat-balloons .stat-icon{color:var(--color-accent)}.stat-streak{background:linear-gradient(135deg,rgba(255,107,107,.2) 0%,var(--glass-bg) 100%);border-color:var(--color-error)}.stat-streak .stat-icon{animation:streakFire .5s ease-in-out infinite}.xp-gain-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);padding:var(--space-lg) var(--space-2xl);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:2px solid var(--color-xp);border-radius:var(--radius-xl);text-align:center;z-index:9999;animation:bounceIn .5s cubic-bezier(.68,-.55,.265,1.55)}.xp-gain-amount{font-size:48px;font-weight:800;color:var(--color-xp);text-shadow:0 0 20px var(--color-xp);animation:xpPulse .5s ease-out}.xp-gain-label{font-size:14px;color:var(--text-secondary);margin-top:var(--space-xs)}.level-up-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .3s ease-out}.level-up-content{text-align:center;animation:levelUp .6s cubic-bezier(.68,-.55,.265,1.55)}.level-up-badge{width:120px;height:120px;margin:0 auto var(--space-lg);background:var(--gradient-gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:800;color:var(--bg-primary);box-shadow:0 0 60px #fdcb6e80;animation:glowPulse 1s ease-in-out infinite}.level-up-title{font-family:var(--font-display);font-size:36px;font-weight:700;background:var(--gradient-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-sm)}.level-up-subtitle{font-size:18px;color:var(--text-secondary);margin-bottom:var(--space-xl)}.level-up-rewards{display:flex;justify-content:center;gap:var(--space-lg);margin-bottom:var(--space-xl)}.level-up-reward{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.level-up-reward-icon{font-size:32px}.level-up-reward-amount{font-size:18px;font-weight:700;color:var(--color-gold)}.level-up-reward-label{font-size:12px;color:var(--text-muted)}.achievements-panel{max-width:600px;width:100%}.achievements-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.achievements-progress{display:flex;align-items:center;gap:var(--space-sm);font-size:14px;color:var(--text-secondary)}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-md)}.achievement-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-tertiary);border:2px solid var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal)}.achievement-item:hover{border-color:var(--color-primary);transform:translateY(-4px)}.achievement-item.locked{opacity:.5;filter:grayscale(1)}.achievement-item.unlocked{border-color:var(--color-gold);background:linear-gradient(135deg,rgba(253,203,110,.1) 0%,var(--bg-tertiary) 100%)}.achievement-item.unlocked:hover{box-shadow:var(--shadow-glow-gold)}.achievement-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:28px;background:var(--bg-elevated);border-radius:50%}.achievement-item.unlocked .achievement-icon{background:var(--gradient-gold)}.achievement-name{font-size:11px;font-weight:600;text-align:center;color:var(--text-secondary);line-height:1.2}.achievement-item.unlocked .achievement-name{color:var(--text-primary)}.achievement-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);width:200px;padding:var(--space-sm);background:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:100}.achievement-item:hover .achievement-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(-8px)}.achievement-tooltip-title{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.achievement-tooltip-desc{font-size:11px;color:var(--text-secondary);margin-bottom:var(--space-xs)}.achievement-tooltip-reward{font-size:11px;color:var(--color-gold)}.challenges-panel{max-width:500px;width:100%}.challenges-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.challenges-timer{display:flex;align-items:center;gap:var(--space-xs);font-size:14px;color:var(--text-secondary)}.challenges-timer-icon{color:var(--color-warning)}.challenges-list{display:flex;flex-direction:column;gap:var(--space-md)}.challenge-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-lg);transition:all var(--transition-normal)}.challenge-item.completed{border-color:var(--color-success);background:linear-gradient(135deg,rgba(0,184,148,.1) 0%,var(--bg-tertiary) 100%)}.challenge-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:24px;background:var(--bg-elevated);border-radius:var(--radius-md);flex-shrink:0}.challenge-item.completed .challenge-icon{background:var(--color-success)}.challenge-content{flex:1;min-width:0}.challenge-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.challenge-progress{display:flex;align-items:center;gap:var(--space-sm)}.challenge-progress-bar{flex:1;height:6px;background:var(--bg-primary);border-radius:var(--radius-full);overflow:hidden}.challenge-progress-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width .3s ease-out}.challenge-item.completed .challenge-progress-fill{background:var(--gradient-xp)}.challenge-progress-text{font-size:12px;color:var(--text-muted);white-space:nowrap}.challenge-reward{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-sm);background:var(--bg-elevated);border-radius:var(--radius-md);flex-shrink:0}.challenge-reward-icon{font-size:16px}.challenge-reward-amount{font-size:12px;font-weight:600;color:var(--color-xp)}.challenge-item.completed .challenge-reward{background:var(--gradient-xp)}.challenge-item.completed .challenge-reward-amount{color:#fff}.leaderboard-panel{max-width:500px;width:100%}.leaderboard-tabs{display:flex;gap:var(--space-xs);margin-bottom:var(--space-lg);padding:var(--space-xs);background:var(--bg-tertiary);border-radius:var(--radius-full)}.leaderboard-tab{flex:1;padding:var(--space-sm);background:transparent;border:none;border-radius:var(--radius-full);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.leaderboard-tab.active{background:var(--gradient-primary);color:#fff}.leaderboard-tab:hover:not(.active){color:var(--text-primary)}.leaderboard-list{display:flex;flex-direction:column;gap:var(--space-sm)}.leaderboard-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg);transition:all var(--transition-normal)}.leaderboard-item:hover{background:var(--bg-elevated)}.leaderboard-item.current-user{border:2px solid var(--color-primary);background:linear-gradient(135deg,rgba(108,92,231,.1) 0%,var(--bg-tertiary) 100%)}.leaderboard-rank{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;border-radius:50%;flex-shrink:0}.leaderboard-item:nth-child(1) .leaderboard-rank{background:var(--gradient-gold);color:var(--bg-primary);box-shadow:var(--shadow-glow-gold)}.leaderboard-item:nth-child(2) .leaderboard-rank{background:linear-gradient(135deg,silver,#e8e8e8);color:var(--bg-primary)}.leaderboard-item:nth-child(3) .leaderboard-rank{background:linear-gradient(135deg,#cd7f32,#e6a860);color:var(--bg-primary)}.leaderboard-rank:not(:nth-child(-n+3)){background:var(--bg-elevated);color:var(--text-secondary)}.leaderboard-player{display:flex;align-items:center;gap:var(--space-sm);flex:1;min-width:0}.leaderboard-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.leaderboard-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard-stats{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.leaderboard-level{font-size:11px;color:var(--text-muted)}.profile-panel{max-width:400px;width:100%}.profile-header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--space-xl)}.profile-avatar{position:relative;margin-bottom:var(--space-md)}.profile-avatar-img{width:96px;height:96px;border-radius:50%;object-fit:cover;border:3px solid var(--color-primary);box-shadow:var(--shadow-glow-primary)}.profile-level{position:absolute;bottom:0;right:0;min-width:32px;height:32px;padding:0 8px;background:var(--gradient-gold);border-radius:var(--radius-full);font-size:14px;font-weight:700;color:var(--bg-primary);display:flex;align-items:center;justify-content:center;border:3px solid var(--bg-primary);box-shadow:var(--shadow-glow-gold)}.profile-name{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.profile-title{font-size:14px;color:var(--color-gold)}.profile-xp-section{margin-bottom:var(--space-xl)}.profile-xp-label{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary);margin-bottom:var(--space-xs)}.profile-xp-bar{height:12px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.profile-xp-fill{height:100%;background:var(--gradient-xp);border-radius:var(--radius-full);transition:width .5s ease-out}.profile-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.profile-stat{display:flex;flex-direction:column;align-items:center;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.profile-stat-value{font-size:24px;font-weight:700;color:var(--text-primary)}.profile-stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase}@media (max-width: 768px){.game-hud{padding:var(--space-xs) var(--space-sm)}.player-info{padding-right:var(--space-sm);max-width:50vw}.player-xp-bar{width:60px}.player-xp-text{display:none}.stat-item{padding:var(--space-xs);min-width:44px;min-height:44px}.stat-value{font-size:12px}.achievements-grid{grid-template-columns:repeat(3,1fr)}.challenge-item{flex-wrap:wrap}.challenge-reward{margin-left:auto}.profile-panel,.challenges-panel,.achievements-panel,.leaderboard-container{border-radius:var(--radius-lg) var(--radius-lg) 0 0}}@media (max-width: 480px){.quick-stats{gap:4px}.stat-item:not(.stat-streak) .stat-icon{font-size:14px}.stat-value{font-size:11px}.player-name{max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.achievements-grid{grid-template-columns:repeat(2,1fr)}}.event-banner{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:1000;padding:12px 24px;background:var(--gradient-neon);border-radius:50px;display:flex;align-items:center;gap:12px;box-shadow:0 8px 32px #6c5ce766;animation:slideDown .5s ease-out,pulse 2s ease-in-out infinite;cursor:pointer;transition:transform .3s ease}.event-banner:hover{transform:translate(-50%) scale(1.05)}.event-banner-icon{font-size:24px;animation:bounce 1s ease-in-out infinite}.event-banner-content{display:flex;flex-direction:column}.event-banner-title{font-size:14px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:1px}.event-banner-timer{font-size:12px;color:#fffc}.weekly-battle-modal{background:var(--bg-secondary);border-radius:24px;padding:0;overflow:hidden;max-width:400px;width:90%}.battle-header{background:var(--gradient-neon);padding:24px;text-align:center}.battle-title{font-size:24px;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:2px;margin-bottom:8px}.battle-subtitle{font-size:14px;color:#fffc}.battle-teams{display:flex;padding:24px;gap:16px}.battle-team{flex:1;padding:20px;border-radius:16px;text-align:center;cursor:pointer;transition:all .3s ease;border:3px solid transparent}.battle-team-a{background:linear-gradient(135deg,#00b89433,#00b8941a)}.battle-team-b{background:linear-gradient(135deg,#6c5ce733,#6c5ce71a)}.battle-team:hover{transform:scale(1.02)}.battle-team.selected{border-color:var(--color-gold);box-shadow:0 0 20px #fdcb6e66}.battle-team.joined{border-color:var(--color-xp);background:linear-gradient(135deg,#00b8944d,#00b89426)}.battle-team-icon{font-size:48px;margin-bottom:12px}.battle-team-name{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.battle-team-score{font-size:32px;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.battle-team-members{font-size:12px;color:var(--text-secondary);margin-top:8px}.battle-vs{display:flex;align-items:center;justify-content:center;width:50px;height:50px;background:var(--bg-primary);border-radius:50%;font-size:18px;font-weight:800;color:var(--color-accent);position:relative}.battle-progress{padding:0 24px 24px}.battle-progress-bar{height:12px;background:var(--bg-tertiary);border-radius:6px;overflow:hidden;display:flex}.battle-progress-a{height:100%;background:linear-gradient(90deg,#00b894,#00cec9);transition:width .5s ease}.battle-progress-b{height:100%;background:linear-gradient(90deg,#6c5ce7,#a29bfe);transition:width .5s ease}.battle-timer{text-align:center;padding:16px 24px;background:var(--bg-tertiary);border-radius:0 0 24px 24px}.battle-timer-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.battle-timer-value{font-size:24px;font-weight:700;color:var(--text-primary);font-family:JetBrains Mono,monospace}.battle-rewards{padding:16px 24px;background:#fdcb6e1a;border-top:1px solid rgba(253,203,110,.2)}.battle-rewards-title{font-size:12px;color:var(--color-gold);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.battle-rewards-list{display:flex;gap:16px;justify-content:center}.battle-reward-item{display:flex;align-items:center;gap:4px;font-size:14px;color:var(--text-primary)}.flash-event-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10000;padding:32px;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;border:2px solid var(--color-gold);box-shadow:0 0 60px #fdcb6e66;text-align:center;animation:bounceIn .6s cubic-bezier(.68,-.55,.265,1.55);max-width:320px}.flash-event-icon{font-size:64px;margin-bottom:16px;animation:pulse 1s ease-in-out infinite}.flash-event-label{font-size:12px;color:var(--color-gold);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px}.flash-event-title{font-size:28px;font-weight:800;color:#fff;margin-bottom:12px}.flash-event-description{font-size:14px;color:var(--text-secondary);margin-bottom:20px}.flash-event-timer{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#fdcb6e33;border-radius:20px;font-size:14px;color:var(--color-gold);font-weight:600}.seasonal-theme{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0}.seasonal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.1}.seasonal-valentines .seasonal-overlay{background:linear-gradient(135deg,#ff6b6b,#fd79a8)}.seasonal-halloween .seasonal-overlay{background:linear-gradient(135deg,#ff7675,#6c5ce7)}.seasonal-christmas .seasonal-overlay{background:linear-gradient(135deg,#ff6b6b,#00b894)}.seasonal-summer .seasonal-overlay{background:linear-gradient(135deg,#fdcb6e,#74b9ff)}.seasonal-particles{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.seasonal-particle{position:absolute;animation:fall linear forwards}@keyframes fall{0%{transform:translateY(-100vh) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.community-goal-banner{position:fixed;bottom:100px;left:50%;transform:translate(-50%);z-index:900;padding:16px 24px;background:var(--glass-bg);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:16px;border:1px solid rgba(255,255,255,.1);min-width:300px;box-shadow:0 8px 32px #0000004d}.community-goal-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.community-goal-icon{font-size:28px}.community-goal-info{flex:1}.community-goal-title{font-size:14px;font-weight:600;color:var(--text-primary)}.community-goal-subtitle{font-size:12px;color:var(--text-secondary)}.community-goal-progress{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin-bottom:8px}.community-goal-fill{height:100%;background:var(--gradient-xp);border-radius:4px;transition:width .5s ease}.community-goal-stats{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary)}#leaderboard-modal.modal{padding:0;overflow:hidden;overflow-x:hidden}.leaderboard-container{background:var(--bg-secondary);border-radius:20px;overflow:hidden;max-height:min(85vh,720px);min-height:0;display:flex;flex-direction:column}.leaderboard-header{flex-shrink:0;padding:20px;background:var(--gradient-primary);text-align:center}.leaderboard-title{font-size:20px;font-weight:700;color:#fff}.leaderboard-meta{font-size:12px;color:#ffffffb3;margin-top:4px}.demo-badge{display:inline-block;padding:2px 8px;background:#fff3;border-radius:10px;font-size:10px;margin-left:8px}.leaderboard-tabs{flex-shrink:0;display:flex;background:var(--bg-tertiary);padding:4px}.leaderboard-tab{flex:1;padding:12px;background:none;border:none;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .3s ease}.leaderboard-tab:hover{color:var(--text-primary);background:#ffffff0d}.leaderboard-tab.active{background:var(--color-primary);color:#fff}.leaderboard-list{flex:1 1 auto;min-height:0;overflow-y:auto;padding:12px}.leaderboard-loading{padding:40px;text-align:center;color:var(--text-secondary)}.leaderboard-entry{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:12px;margin-bottom:8px;transition:all .3s ease;border-left:3px solid var(--rank-color, var(--color-primary))}.leaderboard-entry:hover{transform:translate(4px);background:#6c5ce71a}.leaderboard-entry.current-player{background:linear-gradient(135deg,#6c5ce733,#00cec933);border:1px solid var(--color-primary)}.leaderboard-rank{width:40px;text-align:center;font-size:18px;font-weight:700;color:var(--rank-color, var(--text-primary))}.leaderboard-avatar{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:50%;font-size:20px}.leaderboard-info{flex:1;min-width:0}.leaderboard-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard-level{font-size:12px;color:var(--text-secondary)}.leaderboard-stats{text-align:right}.leaderboard-xp{font-size:14px;font-weight:600;color:var(--color-xp)}.leaderboard-balloons{font-size:12px;color:var(--text-secondary)}.leaderboard-xp-simple{font-size:14px;font-weight:600;color:var(--color-xp)}.player-rank-card{flex-shrink:0;margin:12px;padding:16px;background:var(--gradient-primary);border-radius:16px;box-shadow:0 8px 24px #6c5ce74d}.player-rank-header{font-size:12px;color:#ffffffb3;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}.player-rank-content{display:flex;align-items:center;gap:20px}.player-rank-position{text-align:center}.rank-number{display:block;font-size:32px;font-weight:800;color:#fff}.rank-percentile{font-size:12px;color:#fffc}.player-rank-stats{display:flex;gap:16px;flex:1}.rank-stat{text-align:center}.rank-stat-value{display:block;font-size:18px;font-weight:700;color:#fff}.rank-stat-label{font-size:11px;color:#ffffffb3}.event-modal{max-width:450px;width:95%}.event-header{padding:24px;text-align:center;position:relative}.event-icon{font-size:56px;margin-bottom:12px}.event-type-badge{position:absolute;top:16px;right:16px;padding:4px 12px;background:#fff3;border-radius:20px;font-size:11px;color:#fff;text-transform:uppercase;letter-spacing:1px}.event-title{font-size:24px;font-weight:800;color:#fff;margin-bottom:8px}.event-description{font-size:14px;color:#fffc}.event-content{padding:24px}.event-rewards-section{background:#fdcb6e1a;border-radius:12px;padding:16px;margin-bottom:16px}.event-rewards-title{font-size:12px;color:var(--color-gold);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}.event-rewards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.event-reward-card{text-align:center;padding:12px;background:var(--bg-tertiary);border-radius:8px}.event-reward-icon{font-size:24px;margin-bottom:4px}.event-reward-value{font-size:16px;font-weight:700;color:var(--text-primary)}.event-reward-label{font-size:11px;color:var(--text-secondary)}.event-action-btn{width:100%;padding:16px;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease}.event-action-btn.join{background:var(--gradient-xp);color:#fff}.event-action-btn.join:hover{transform:scale(1.02);box-shadow:0 8px 24px #00b89466}.event-action-btn.joined{background:var(--bg-tertiary);color:var(--color-xp);border:2px solid var(--color-xp)}@keyframes slideDown{0%{transform:translate(-50%) translateY(-100px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@media (max-width: 480px){.event-banner{width:calc(100% - 32px);left:16px;right:16px;transform:none}.event-banner:hover{transform:scale(1.02)}.battle-teams{flex-direction:column}.battle-vs{order:-1;margin-bottom:-25px;z-index:1}.leaderboard-container{max-height:80vh}.player-rank-content{flex-direction:column}.community-goal-banner{left:16px;right:16px;transform:none;min-width:auto}}#map{height:100vh;width:100%;position:relative;z-index:1;background:var(--color-paper)}body{font-family:var(--font-body);color:var(--color-ink);background:var(--color-paper)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;pointer-events:none;background-image:url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" width="100" height="100"%3E%3Cfilter id="noise"%3E%3CfeTurbulence type="fractalNoise" baseFrequency="0.9" numOctaves="2"/%3E%3CfeColorMatrix values="0 0 0 0 0.18 0 0 0 0 0.13 0 0 0 0 0.07 0 0 0 0.06 0"/%3E%3C/filter%3E%3Crect width="100" height="100" filter="url(%23noise)"/%3E%3C/svg%3E');opacity:.42;mix-blend-mode:multiply}h1,h2,h3,h4,h5,h6,.app-title{font-family:var(--font-display);letter-spacing:0}#add-balloon-btn{position:fixed;bottom:30px;right:30px;width:68px;height:68px;border-radius:50%;background:var(--color-coral);border:3px solid #fff;color:#fff;font-size:32px;font-weight:900;cursor:pointer;box-shadow:0 4px #c95a48,var(--shadow-paper-md),inset 0 1px #ffffff47;transition:all .2s cubic-bezier(.34,1.56,.64,1);z-index:1000;display:flex;align-items:center;justify-content:center;animation:addBtnPulse 3s ease-in-out infinite}@keyframes addBtnPulse{0%,to{box-shadow:0 4px #c95a48,var(--shadow-paper-md),inset 0 1px #ffffff47}50%{box-shadow:0 4px #c95a48,0 10px 28px #ff7e6b3d,0 0 0 8px #ff7e6b1a,inset 0 1px #ffffff47}}#add-balloon-btn:hover{transform:translateY(-5px) scale(1.1);box-shadow:0 4px #c95a48,0 14px 30px #28140a2e,inset 0 1px #ffffff4d;animation:none}#add-balloon-btn:active{transform:translateY(-2px) scale(1.03);box-shadow:0 4px 16px #ff416c8c,0 2px 6px #0000004d,inset 0 1px #fff3}.icon-btn{width:50px;height:50px;border-radius:50%;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);cursor:pointer;font-size:20px;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center;color:var(--color-ink);box-shadow:var(--shadow-paper-sm)}.icon-btn:hover{background:var(--color-surface);transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#3c28142e}.location-btn{position:fixed!important;bottom:110px!important;right:30px!important;background:var(--color-sage)!important;color:var(--color-ink)!important;border:3px solid #fff!important;box-shadow:var(--shadow-paper-sm)!important;z-index:1000!important}.location-btn:hover{transform:translateY(-3px) scale(1.05)!important;box-shadow:var(--shadow-paper-md)!important}.location-btn.loading{animation:pulse 1.5s ease-in-out infinite}.arena-btn{position:fixed!important;bottom:170px!important;right:30px!important;background:var(--color-plum)!important;color:var(--color-ink)!important;border:3px solid #fff!important;box-shadow:var(--shadow-paper-sm)!important;z-index:1000!important}.arena-btn:hover{transform:translateY(-3px) scale(1.05)!important;box-shadow:var(--shadow-lg),0 0 30px #fd79a880!important}.events-btn{position:fixed!important;bottom:230px!important;right:30px!important;background:var(--color-sun)!important;color:var(--color-ink)!important;border:3px solid #fff!important;box-shadow:var(--shadow-paper-sm)!important;z-index:1000!important}.events-btn:hover{transform:translateY(-3px) scale(1.05)!important;box-shadow:var(--shadow-lg),0 0 30px #fdcb6e99!important}.leaderboard-btn{position:fixed!important;bottom:290px!important;right:30px!important;background:var(--color-sky)!important;color:var(--color-ink)!important;border:3px solid #fff!important;box-shadow:var(--shadow-paper-sm)!important;z-index:1000!important}.leaderboard-btn:hover{transform:translateY(-3px) scale(1.05)!important;box-shadow:var(--shadow-lg),0 0 30px #6c5ce799!important}.menu-toggle-btn{position:fixed!important;bottom:350px!important;right:30px!important;z-index:1001!important}.menu-toggle-btn.active{background:var(--color-coral)!important;color:#fff!important;transform:rotate(90deg)!important;box-shadow:var(--shadow-glow-primary)!important}.expandable-menu{position:fixed;bottom:350px;right:30px;z-index:999;pointer-events:none;--menu-radius: 110px}.expandable-menu .menu-items{position:relative;width:0;height:0;overflow:visible}.expandable-menu .menu-item{position:absolute;bottom:0;right:0;transform-origin:bottom right;width:46px!important;height:46px!important;font-size:18px!important;opacity:0;transform:translate(0) scale(.35);transition:transform .42s cubic-bezier(.175,.885,.32,1.275),opacity .35s ease;transition-delay:0s;pointer-events:none;background:var(--glass-bg)!important;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border)!important}.expandable-menu .menu-item:nth-child(1){--angle: 136deg}.expandable-menu .menu-item:nth-child(2){--angle: 170deg}.expandable-menu .menu-item:nth-child(3){--angle: 203deg}.expandable-menu .menu-item:nth-child(4){--angle: 237deg}.expandable-menu .menu-item:nth-child(5){--angle: 270deg}.expandable-menu.expanded{pointer-events:auto}.expandable-menu.expanded .menu-item{opacity:1;pointer-events:auto;transform:translate(calc(var(--menu-radius) * cos(var(--angle))),calc(var(--menu-radius) * sin(var(--angle)))) scale(1)}.expandable-menu.expanded .menu-item:nth-child(1){transition-delay:.05s}.expandable-menu.expanded .menu-item:nth-child(2){transition-delay:.1s}.expandable-menu.expanded .menu-item:nth-child(3){transition-delay:.14s}.expandable-menu.expanded .menu-item:nth-child(4){transition-delay:.18s}.expandable-menu.expanded .menu-item:nth-child(5){transition-delay:.22s}#balloon-form,#category-filter,#debug-logs,#settings-modal,#arena-modal,#arena-editor-modal,#brand-edit-modal{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:0;box-shadow:var(--shadow-xl);z-index:2000;min-width:340px;max-width:90vw;max-height:90vh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}#search-modal{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);flex-direction:column;align-items:stretch;padding:0;z-index:2000;min-width:0;max-width:90vw;max-height:min(88vh,620px);overflow:hidden;-webkit-overflow-scrolling:touch}#settings-modal,#search-modal{overflow:hidden}#balloon-form{display:none;flex-direction:column}#balloon-form:before,#category-filter:before,#debug-logs:before,#search-modal:before,#settings-modal:before,#arena-modal:before{content:"";position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:-1}#balloon-form h3,#category-filter h3,#debug-logs h3,#search-modal h3,#settings-modal h3,#arena-modal h3{margin:0;padding:var(--space-lg);font-family:var(--font-display);font-size:1.4rem;font-weight:700;background:var(--gradient-neon);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;border-bottom:1px solid var(--border-default)}.form-group{margin-bottom:var(--space-md)}label{display:block;margin-bottom:var(--space-xs);color:var(--text-secondary);font-weight:500;font-size:14px}input[type=file],input[type=text],input[type=number],select,textarea{width:100%;padding:var(--space-sm) var(--space-md);border:2px solid var(--border-default);border-radius:var(--radius-md);font-size:14px;font-family:var(--font-main);transition:all var(--transition-fast);background:var(--bg-tertiary);color:var(--text-primary)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6c5ce733;background:var(--bg-secondary)}textarea{resize:vertical;min-height:80px}#add-balloon-form{padding:0}.btn-group{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}button[type=submit],button[type=button]{flex:1;padding:var(--space-sm) var(--space-lg);border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-normal);font-family:var(--font-main)}button[type=submit]{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-sm),var(--shadow-glow-primary)}button[type=submit]:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 25px #6c5ce780}button[type=button]{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-default)}button[type=button]:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--color-primary)}.primary-btn{background:var(--gradient-primary)!important;color:#fff!important;border:none!important;box-shadow:var(--shadow-sm),var(--shadow-glow-primary)}.primary-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 25px #6c5ce780!important}.secondary-btn{background:var(--bg-tertiary)!important;color:var(--text-primary)!important;border:1px solid var(--border-default)!important}.secondary-btn:hover{background:var(--bg-elevated)!important;border-color:var(--color-secondary)!important}.danger-btn{background:linear-gradient(135deg,#ff6b6b,#ee5a24)!important;color:#fff!important;border:none!important;box-shadow:0 0 15px #ff6b6b4d}.danger-btn:hover{transform:translateY(-2px);box-shadow:0 0 25px #ff6b6b80!important}#pin-placement-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1900;flex-direction:column;gap:10px;padding:16px 20px calc(16px + env(safe-area-inset-bottom,0px));background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-top:1px solid var(--glass-border);box-shadow:0 -8px 32px #00000073}.pin-bar-text{display:flex;align-items:center;gap:10px;color:var(--text-primary);font-size:14px;font-weight:500}.pin-bar-icon{font-size:22px;animation:pinBounce 1.2s ease-in-out infinite}@keyframes pinBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.pin-bar-actions{display:flex;gap:10px}#pin-bar-cancel{flex:0 0 auto;padding:11px 18px;background:var(--bg-tertiary);border:1.5px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}#pin-bar-cancel:hover{background:var(--bg-elevated);border-color:var(--color-error);color:var(--color-error);transform:none!important;box-shadow:none!important}#pin-bar-next,.pin-bar-next-btn{flex:1;padding:12px;background:var(--gradient-primary);border:none;border-radius:var(--radius-lg);color:#fff;font-size:15px;font-weight:700;cursor:pointer;box-shadow:var(--shadow-sm),var(--shadow-glow-primary);transition:all var(--transition-normal)}#pin-bar-next:hover,.pin-bar-next-btn:hover{transform:translateY(-2px)!important;box-shadow:var(--shadow-md),0 0 20px #6c5ce780!important}.sheet-handle{width:40px;height:4px;background:var(--border-default);border-radius:2px;margin:10px auto 0;flex-shrink:0}.balloon-form-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-default)}.balloon-form-header h3{margin:0;padding:0;border:none;font-size:1.2rem;font-family:var(--font-display);font-weight:700;background:var(--gradient-neon);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sheet-close-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px 8px;line-height:1;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);flex:none!important}.sheet-close-btn:hover{color:var(--text-primary);background:var(--bg-elevated);transform:none!important;box-shadow:none!important}.image-upload-zone{position:relative;margin:var(--space-md) var(--space-lg);border:2px dashed var(--border-default);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast);aspect-ratio:16 / 7;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary)}.image-upload-zone:hover,.image-upload-zone.drag-over{border-color:var(--color-primary);background:#6c5ce70f}.image-upload-zone.has-image{border-style:solid;border-color:var(--color-primary)}.image-file-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%!important;height:100%!important;padding:0!important;border:none!important;z-index:2}.image-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--text-secondary);pointer-events:none;padding:var(--space-lg);text-align:center}.image-placeholder-icon{font-size:2rem;line-height:1}.image-placeholder-text{font-size:14px;font-weight:500;color:var(--text-secondary)}.image-placeholder small{font-size:11px;color:var(--text-muted)}.image-preview-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:none;z-index:0}.image-preview-remove{position:absolute;top:8px;right:8px;background:#0009;border:none;color:#fff;font-size:14px;width:28px;height:28px;border-radius:50%;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:3;padding:0;flex:none!important;transition:background var(--transition-fast)}.image-preview-remove:hover{background:#dc3232cc;transform:none!important;box-shadow:none!important}.image-upload-zone.has-image .image-placeholder{display:none}.image-upload-zone.has-image .image-preview-img{display:block}.image-upload-zone.has-image .image-preview-remove{display:flex}.image-upload-zone.has-image .image-file-input{z-index:2;pointer-events:auto}.image-upload-zone.has-image:after{content:"📷 tap to change";position:absolute;bottom:8px;left:50%;transform:translate(-50%);background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;pointer-events:none;opacity:0;transition:opacity .2s ease;white-space:nowrap;z-index:1}.image-upload-zone.has-image:hover:after,.image-upload-zone.has-image:focus-within:after{opacity:1}.image-upload-zone.has-image .image-preview-remove{z-index:4}.form-section{padding:var(--space-sm) var(--space-lg)}.form-section-label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:var(--space-sm)}.category-chips{display:flex;flex-wrap:wrap;gap:8px}.chip{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:20px;border:1.5px solid var(--border-default);background:var(--bg-tertiary);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex:none!important}.chip:hover{border-color:var(--color-primary-light);color:var(--text-primary);background:#6c5ce71a;transform:none!important;box-shadow:none!important}.chip.selected{border-color:var(--chip-accent, var(--color-primary));background:color-mix(in srgb,var(--chip-accent, var(--color-primary)) 20%,var(--bg-tertiary));color:var(--text-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--chip-accent, var(--color-primary)) 38%,transparent),0 0 14px color-mix(in srgb,var(--chip-accent, var(--color-primary)) 22%,transparent)}.form-section textarea{width:100%;padding:var(--space-sm) var(--space-md);border:2px solid var(--border-default);border-radius:var(--radius-md);font-size:14px;font-family:var(--font-main);background:var(--bg-tertiary);color:var(--text-primary);resize:none;min-height:80px;transition:border-color var(--transition-fast)}.form-section textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6c5ce733}.form-hint{display:block;font-size:11px;color:var(--text-muted);margin-top:6px}.theme-picker-row{display:flex;flex-wrap:wrap;gap:10px;padding:4px 0 6px}.theme-swatch-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;flex:none}.theme-swatch-wrap.swatch-equipped .theme-swatch{border-color:#fff;box-shadow:0 0 0 3px #ffffff40,0 0 12px #ffffff26}.theme-swatch-wrap.swatch-cant-afford{opacity:.42}.theme-swatch-wrap.swatch-cant-afford .theme-swatch{cursor:not-allowed}.theme-swatch-wrap.swatch-cant-afford:hover .theme-swatch{transform:none!important}.theme-swatch{position:relative;width:40px;height:40px;border-radius:50%;border:3px solid transparent;background:transparent!important;padding:0;cursor:pointer;transition:transform var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast);display:flex;align-items:center;justify-content:center;overflow:hidden}.theme-swatch:hover{transform:scale(1.15)!important;box-shadow:0 0 0 3px #ffffff1f,0 2px 8px #0006}.swatch-dot{display:block;flex:0 0 auto;width:32px;height:32px;min-width:32px;min-height:32px;border-radius:50%;pointer-events:none}.swatch-check{position:absolute;font-size:16px;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.6);pointer-events:none}.swatch-lbl{font-size:9px;font-weight:700;white-space:nowrap;line-height:1;display:flex;align-items:center;gap:2px}.swatch-lbl--price{color:var(--text-muted)}.swatch-lbl--owned{color:var(--accent)}.swatch-lbl--on{color:#4ade80}.swatch-coin{flex-shrink:0}.swatch-gem-icon{font-size:10px;line-height:1}.theme-picker-row--frames{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:12px;align-items:stretch}.balloon-frame-card{width:100%}.balloon-frame-card .balloon-frame-card__btn.theme-swatch{width:100%;height:auto;min-height:112px;border-radius:14px;border:2px solid rgba(255,255,255,.12);background:#00000061;padding:8px 6px;display:flex;flex-direction:column;align-items:stretch;gap:6px;overflow:visible}.balloon-frame-card .balloon-frame-card__btn.theme-swatch:hover{transform:scale(1.02);border-color:#ffffff38}.balloon-frame-card.swatch-equipped .balloon-frame-card__btn.theme-swatch{border-color:#fff;box-shadow:0 0 0 2px #ffffff2e,0 0 16px #6c5ce759}.balloon-frame-card__head{display:flex;align-items:center;justify-content:center;gap:5px;flex-wrap:wrap}.balloon-frame-card__ico{font-size:17px;line-height:1}.balloon-frame-card__name{font-size:10px;font-weight:700;color:var(--text-primary);text-align:center;line-height:1.15;max-width:100%}.balloon-frame-card__zoom{display:flex;justify-content:center;align-items:flex-end;gap:10px;flex:1;min-height:54px}.bf-zoom-lane{display:flex;flex-direction:column;align-items:center;gap:5px}.bf-zoom-lane__cap{width:20px;height:2px;border-radius:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent)}.bf-zoom-lane__cap--near{width:32px}.bf-thumb-dot{display:block;width:9px;height:9px;border-radius:50%;border:1.5px solid rgba(255,255,255,.92);box-sizing:border-box}.bf-thumb-dot--spotlight{animation:bf-thumb-dot-burn 2.2s ease-in-out infinite}.bf-thumb-dot--halo{box-shadow:0 0 0 1.5px #ffffff8c,0 0 8px rgba(var(--bf-rgb),.75)!important}.bf-thumb-dot--double_ring{box-shadow:0 0 0 1px #fffffff2,0 0 0 3px rgba(var(--bf-rgb),.88),0 0 6px rgba(var(--bf-rgb),.5)!important}.bf-thumb-dot--bounce{animation:bf-thumb-dot-bounce 1.6s ease-in-out infinite}@keyframes bf-thumb-dot-burn{0%,to{transform:scale(1);filter:brightness(1);box-shadow:0 0 6px rgba(var(--bf-rgb),.6),0 0 3px #ff824673,0 1px 3px #00000059!important}50%{transform:scale(1.12);filter:brightness(1.12);box-shadow:0 0 12px rgba(var(--bf-rgb),.95),0 0 8px #ff6437a6,0 1px 3px #00000059!important}}@keyframes bf-thumb-dot-bounce{0%,to{transform:scale(1)}35%{transform:scale(1.2)}70%{transform:scale(.92)}}.bf-thumb-balloon{display:block;flex-shrink:0;box-sizing:border-box;will-change:transform,filter}.balloon-frame-card .swatch-check{right:6px;top:6px}#theme-picker-section{padding-bottom:var(--space-sm)}.pin-location-hint{display:flex;align-items:center;gap:8px;margin:0 var(--space-lg) var(--space-sm);padding:8px 12px;background:#6c5ce714;border:1px solid rgba(108,92,231,.2);border-radius:var(--radius-md);font-size:12px;color:var(--text-secondary)}.pin-hint-icon{font-size:16px;flex-shrink:0}.form-submit-row{padding:var(--space-md) var(--space-lg) var(--space-lg)}.form-submit-row button[type=submit],#balloon-submit-btn{width:100%;padding:14px;background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-lg);font-size:15px;font-weight:700;font-family:var(--font-main);cursor:pointer;box-shadow:var(--shadow-sm),var(--shadow-glow-primary);transition:all var(--transition-normal);flex:none!important}.form-submit-row button[type=submit]:hover,#balloon-submit-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 25px #6c5ce780}#balloon-form .balloon-form-header h3{padding:0;border-bottom:none;font-size:1.2rem}.balloon-marker{background:transparent!important;border:none!important}.balloon-icon{cursor:pointer;transition:box-shadow var(--transition-normal),filter var(--transition-normal);will-change:filter;border-radius:48% 52% 50% 50%;filter:drop-shadow(var(--shadow-balloon))}.balloon-marker .balloon-visual-wrap{cursor:pointer}.balloon-marker .balloon-visual-wrap:hover{z-index:9999!important}.balloon-marker .balloon-visual-wrap:hover .balloon-pattern-shell{transform:scale(1.03)}.balloon-marker .balloon-visual-wrap:hover .balloon-head--pattern,.balloon-marker .balloon-visual-wrap:hover .balloon-ring-stack{filter:drop-shadow(0 4px 12px rgba(40,20,10,.2)) brightness(1.06)}.balloon-marker .balloon-visual-wrap:hover .balloon-head--standard{filter:drop-shadow(0 4px 10px rgba(40,20,10,.18)) brightness(1.04)}.balloon-pattern-shell .balloon-icon:hover{transform:none!important}.custom-popup .leaflet-popup-content-wrapper{background:var(--color-surface);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);box-shadow:var(--shadow-paper-md);color:var(--color-ink);overflow:hidden}.custom-popup .leaflet-popup-tip{background:var(--color-surface);border:1px solid var(--color-hairline)}.custom-popup .leaflet-popup-content{margin:0;padding:0}.balloon-popup{min-width:0;max-width:280px}.popup-hero{position:relative;width:100%;height:180px;overflow:hidden;background:var(--bg-tertiary)}.popup-hero-img{width:100%;height:100%;object-fit:cover;display:block}.popup-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:space-between;align-items:stretch;padding:10px 12px;background:linear-gradient(180deg,rgba(42,32,24,.22) 0%,transparent 38%,transparent 55%,rgba(42,32,24,.32) 100%);pointer-events:none}.popup-hero-overlay__top,.popup-hero-overlay__bottom{display:flex;align-items:flex-start;justify-content:flex-start}.popup-hero-overlay__bottom{align-items:flex-end}.popup-hero-overlay .popup-category-badge,.popup-hero-overlay .popup-creator-badge,.popup-topbar .popup-category-badge,.popup-topbar .popup-creator-badge{display:inline-flex;align-items:center;box-sizing:border-box;height:20px;padding:0 8px;border-radius:999px;border:none;background:#fffffff0;color:var(--color-ink);font-family:var(--font-mono);font-size:9px;font-weight:700;line-height:1;letter-spacing:0;box-shadow:0 1px 4px #2a20181a}.popup-creator-badge{flex-direction:row;gap:5px;max-width:min(150px,72%);padding-left:3px;padding-right:8px}.popup-creator-avatar-wrap{position:relative;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%}.popup-creator-avatar-wrap[class*=pat-pulse--]{animation:none}.popup-creator-avatar-wrap.pat-ring--05,.popup-creator-avatar-wrap[class*=pat-ring--]{box-shadow:0 0 0 1px var(--pat-primary, var(--color-coral))}.popup-creator-avatar{display:inline-flex;align-items:center;justify-content:center;width:12px;height:12px;border-radius:50%;background:var(--color-surface);font-size:8px;line-height:1}.popup-creator-avatar--letter{font-family:var(--font-display);font-size:7px;font-weight:600;color:var(--color-ink);background:linear-gradient(135deg,var(--color-sun),var(--color-coral))}.popup-creator-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:96px;text-transform:none;font-family:inherit;font-size:inherit;font-weight:inherit}.popup-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:12px 12px 10px;border-bottom:1px solid var(--border-default)}.popup-topbar-chips{display:flex;flex-direction:column;gap:8px;flex:1 1 auto;min-width:0}.popup-topbar-chips .popup-hero-overlay__top,.popup-topbar-chips .popup-hero-overlay__bottom{position:static}.popup-topbar .popup-creator-badge,.popup-topbar .popup-category-badge{background:var(--color-surface);border:1px solid var(--color-hairline);box-shadow:var(--shadow-paper-sm)}.popup-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.popup-category-badge{padding:3px 9px;background:#ffffff26;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#fff;border:1px solid rgba(255,255,255,.25)}.popup-topbar .popup-category-badge{background:var(--bg-tertiary);color:var(--text-secondary);border-color:var(--border-default)}.popup-rarity-badge{padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;color:#fff;display:inline-flex;align-items:center;gap:3px;opacity:.93}.balloon-popup-close{position:absolute;top:8px;right:8px;z-index:6;pointer-events:auto;width:30px;height:30px;margin:0;padding:0;border:none;border-radius:50%;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:18px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.balloon-popup-close:hover{background:#000000b3}.popup-close-inline{position:static;background:var(--bg-tertiary);color:var(--text-muted);-webkit-backdrop-filter:none;backdrop-filter:none;flex-shrink:0}.popup-close-inline:hover{background:var(--bg-elevated);color:var(--text-primary)}.popup-body{padding:12px 14px 10px}.popup-description{margin:0 0 4px;color:var(--text-primary);font-size:.9rem;line-height:1.45;word-break:break-word}.popup-description__link{color:var(--color-coral, #c95a48);font-weight:600;text-decoration:underline;text-underline-offset:2px}.popup-description__link:hover{color:#9d4331}.popup-date{display:block;font-size:11px;color:var(--text-muted);margin-bottom:12px}.vote-section{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 0;border-top:1px solid var(--border-default);border-bottom:1px solid var(--border-default)}.vote-btn{flex:1;background:var(--bg-tertiary);border:1.5px solid var(--border-default);cursor:pointer;padding:10px 8px;border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.vote-emoji{font-size:22px;line-height:1}.vote-btn:hover{transform:scale(1.06)}.vote-btn.vote-up:hover,.vote-btn.vote-plus:hover{border-color:var(--color-success);box-shadow:0 0 12px #00b89459;background:#00b8941a}.vote-btn.vote-down:hover,.vote-btn.vote-minus:hover{border-color:var(--color-error);box-shadow:0 0 12px #ff6b6b59;background:#ff6b6b1a}.vote-btn.vote-voted-today,.vote-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.vote-display{text-align:center;min-width:54px}.vote-display-centered{min-width:120px}.vote-symbol{font-size:22px;font-weight:900;line-height:1;font-family:var(--font-display)}.vote-display-centered .vote-life-count{display:block;font-weight:800;color:var(--text-primary);font-size:24px;line-height:1.1;font-family:var(--font-display)}.vote-count-label{display:block;font-size:11px;color:var(--text-secondary, #888);margin-top:2px;letter-spacing:.02em}.vote-count{display:block;font-weight:800;color:var(--text-primary);font-size:24px;line-height:1.1;font-family:var(--font-display)}.rarity-progress{margin-top:10px;padding-top:10px}.rarity-progress-label{display:flex;justify-content:space-between;font-size:11px;color:var(--text-secondary);margin-bottom:5px}.rarity-progress-bar{height:5px;background:var(--bg-elevated);border-radius:3px;overflow:hidden}.rarity-progress-fill{height:100%;border-radius:3px;transition:width .4s ease;opacity:.85}.popup-actions{display:flex;gap:8px;margin-top:10px}.popup-action-btn{flex:1;padding:9px 10px;background:var(--bg-tertiary);border:1.5px solid var(--border-default);border-radius:var(--radius-md);font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.popup-action-btn:hover{background:var(--bg-elevated);border-color:var(--color-primary);color:var(--text-primary)}.share-btn:hover{border-color:var(--color-secondary)}.form-submit-row--editing{display:flex;gap:10px}.form-submit-row--editing #balloon-submit-btn{flex:1!important;width:auto!important}#balloon-delete-btn{padding:14px 18px;background:transparent;border:1.5px solid rgba(229,115,115,.45);border-radius:var(--radius-lg);color:#e57373;font-size:15px;font-weight:700;font-family:var(--font-main);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;flex:none}#balloon-delete-btn:hover{background:#c6282826;border-color:#c62828;color:#ef9a9a}#settings-modal{display:none;flex-direction:column;align-items:stretch;max-width:520px;width:min(92vw,520px);max-height:min(88vh,640px);overflow:hidden;padding:0}#settings-modal .settings-sheet{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;max-height:inherit}.settings-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px 10px;border-bottom:1px solid var(--color-hairline)}.settings-header h3{margin:0;flex:1;font-size:1.35rem;font-weight:500;text-align:left;border:none;padding:0;background:none;-webkit-text-fill-color:var(--color-ink);color:var(--color-ink)}.settings-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:12px 16px 8px;scrollbar-width:none}.settings-scroll::-webkit-scrollbar{display:none;width:0;height:0}.settings-content{flex:1 1 auto;min-height:0;padding:var(--space-lg);overflow:visible}.settings-section{margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-lg);transition:all var(--transition-normal)}.settings-section:hover{border-color:var(--color-primary)}.settings-section h4{margin:0 0 10px;color:var(--color-ink);font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding-bottom:6px;border-bottom:1px solid var(--color-hairline);display:block}.settings-hint{margin:0 0 10px;font-size:12px;line-height:1.4;color:var(--color-ink-3)}.settings-volume-row{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:6px 10px;align-items:center}.settings-volume-row label{grid-column:1 / -1}.settings-volume-row input[type=range]{grid-column:1;width:100%;margin:0}.settings-volume-value{grid-column:2;font-family:var(--font-mono);font-size:11px;color:var(--color-ink-3);min-width:2.5rem;text-align:right}.settings-arena-btn{width:100%;padding:12px 16px;border-radius:var(--radius-full);border:1px solid var(--color-hairline);background:var(--color-surface);color:var(--color-ink);font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s ease,transform .12s ease}.settings-arena-btn:hover{background:color-mix(in srgb,var(--color-primary) 8%,var(--color-surface))}.settings-footer{flex-shrink:0;display:flex;gap:10px;padding:12px 16px calc(12px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--color-hairline);background:var(--color-paper)}.settings-footer__primary,.settings-footer__secondary{flex:1;padding:12px 14px;border-radius:var(--radius-full);font-weight:600;font-family:var(--font-body);cursor:pointer;border:1px solid var(--color-hairline)}.settings-footer__primary{background:var(--color-ink);color:var(--color-paper);border-color:var(--color-ink)}.settings-footer__secondary{background:var(--color-surface);color:var(--color-ink-2)}.checkbox-label{display:flex!important;align-items:center;cursor:pointer;margin:0!important;font-weight:400!important;padding:var(--space-sm) 0;transition:all var(--transition-fast);border-radius:var(--radius-md)}.checkbox-label:hover{background:var(--bg-elevated);padding-left:var(--space-sm);margin-left:calc(-1 * var(--space-sm))!important}.checkbox-label input[type=checkbox]{width:20px!important;height:20px!important;margin-right:var(--space-sm)!important;accent-color:var(--color-primary);cursor:pointer}.checkbox-label span{font-size:14px;color:var(--text-secondary)}#settings-modal .settings-section{margin-bottom:14px;padding:14px;background:var(--color-surface);border:1px solid var(--color-hairline);border-radius:var(--radius-md)}#settings-modal .settings-section:hover{border-color:var(--color-hairline)}#settings-modal .form-group label:not(.checkbox-label){display:block;margin-bottom:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--color-ink-3)}#settings-modal select{width:100%}.data-buttons{display:flex;flex-direction:column;gap:var(--space-sm)}#arena-modal{max-width:800px;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);border:2px solid var(--color-accent);max-height:min(92vh,880px)}#arena-modal h3{background:var(--gradient-accent);-webkit-background-clip:unset;-webkit-text-fill-color:white;background-clip:unset;color:#fff;padding:var(--space-lg);font-size:1.6rem;text-shadow:0 2px 4px rgba(0,0,0,.3);flex-shrink:0}.arena-content{flex:1 1 auto;min-height:0;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-lg)}.competition-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);padding:var(--space-lg);background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-default)}.competition-info h4{margin:0 0 var(--space-md) 0;color:var(--text-primary);font-size:1.3rem}.competition-timer{margin-bottom:var(--space-sm);color:var(--text-secondary)}#countdown-timer{font-size:1.2rem;font-weight:700;color:var(--color-accent);margin-left:var(--space-sm)}.competition-stats{display:flex;gap:var(--space-lg);font-size:14px;color:var(--text-muted)}.arena-action-btn{flex:none;background:var(--gradient-xp);color:#fff;border:none;padding:10px 22px;border-radius:9999px;font-size:15px;font-weight:600;cursor:pointer;transition:transform var(--transition-normal),box-shadow var(--transition-normal);box-shadow:var(--shadow-md),0 0 14px #00b89461;white-space:nowrap;flex-shrink:0;align-self:center}.arena-action-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 22px #00b89480}.arena-action-btn:active{transform:translateY(0)}.leaderboard-section h4,.voting-section h4{color:var(--text-primary);margin-bottom:var(--space-md);font-size:1.2rem;padding-bottom:var(--space-sm);border-bottom:2px solid var(--color-accent);display:inline-block}.brands-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:300px;overflow-y:auto;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}#brands-leaderboard.brands-list{flex-direction:row;flex-wrap:wrap;justify-content:center;max-height:400px;gap:var(--space-sm)}#brands-leaderboard.brands-list:empty{display:none!important;padding:0!important;margin:0!important;max-height:0!important;min-height:0!important;overflow:hidden!important;border:none!important;background:transparent!important}.brand-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--transition-normal);cursor:pointer}.brand-item:hover{border-color:var(--color-primary);transform:translateY(-2px)}.brand-item.rank-1{background:var(--gradient-gold);border-color:var(--color-gold);color:var(--bg-primary)}.brand-item.rank-2{background:linear-gradient(135deg,#95a5a6,#7f8c8d);color:#fff}.brand-item.rank-3{background:linear-gradient(135deg,#e67e22,#d35400);color:#fff}.voting-section{margin-bottom:var(--space-xl);padding:var(--space-lg);background:#fd79a81a;border-radius:var(--radius-lg);border:1px solid rgba(253,121,168,.3)}.vote-status{display:flex;justify-content:space-between;font-size:14px;color:var(--text-muted)}.arena-actions{display:flex;gap:var(--space-md);margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--border-default)}.arena-actions button{flex:1;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all var(--transition-normal)}#view-arena-history,#arena-rules{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-default)}#close-arena{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-default)}.filter-content{padding:var(--space-lg)}.category-list{max-height:300px;overflow-y:auto;margin-bottom:var(--space-lg)}.category-item{display:flex;align-items:center;padding:var(--space-sm) 0;border-bottom:1px solid var(--border-muted)}.category-item:last-child{border-bottom:none}.category-item input[type=checkbox]{margin-right:var(--space-sm);width:18px;height:18px;accent-color:var(--color-primary)}.category-item label{flex:1;margin:0;font-weight:400;cursor:pointer;display:flex;align-items:center;justify-content:space-between;color:var(--text-primary)}.category-count{background:var(--bg-elevated);color:var(--text-muted);padding:2px 8px;border-radius:var(--radius-full);font-size:.8rem}.filter-actions{display:flex;gap:var(--space-sm)}.filter-actions button{flex:1}#apply-filter{background:var(--gradient-primary);color:#fff}#reset-filter{background:var(--gradient-xp);color:#fff}#close-filter{background:var(--bg-elevated);color:var(--text-secondary)}.search-content{padding:var(--space-lg)}.search-results{margin-bottom:var(--space-lg);max-height:300px;overflow-y:auto}.search-results h4{color:var(--text-primary);margin-bottom:var(--space-sm)}.results-list{border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-tertiary)}.search-result-item{padding:var(--space-md);border-bottom:1px solid var(--border-muted);cursor:pointer;transition:background var(--transition-fast)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-elevated)}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs)}.result-category{background:var(--gradient-primary);color:#fff;padding:2px 8px;border-radius:var(--radius-full);font-size:.75rem;text-transform:capitalize}.result-votes{color:var(--text-muted);font-size:.85rem}.result-description{color:var(--text-secondary);font-size:.9rem}.result-date{color:var(--text-muted);font-size:.75rem}.no-results{padding:var(--space-lg);text-align:center;color:var(--text-muted);font-style:italic}.search-actions{display:flex;gap:var(--space-sm)}#perform-search{background:var(--gradient-primary);color:#fff}#clear-search{background:var(--gradient-gold);color:var(--bg-primary)}#close-search{background:var(--bg-elevated);color:var(--text-secondary)}.notification{position:fixed;top:calc(env(safe-area-inset-top,0px) + 120px);right:max(14px,env(safe-area-inset-right));left:auto;max-width:min(380px,calc(100vw - 28px));width:max-content;min-width:0;box-sizing:border-box;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);color:#fff;font-weight:500;font-size:13px;line-height:1.35;z-index:3000;opacity:0;pointer-events:none;visibility:hidden;transform:translate(calc(100% + 24px));transition:transform var(--transition-bounce),opacity .35s ease,visibility 0s linear .35s;box-shadow:var(--shadow-xl);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);overflow-wrap:anywhere;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.notification--visible{visibility:visible;opacity:1;pointer-events:auto;transition:transform var(--transition-bounce),opacity .35s ease,visibility 0s;transform:translate(0)}.notification--success{background:var(--color-success);box-shadow:var(--shadow-glow-xp)}.notification--error{background:var(--color-error)}.notification--warning{background:var(--color-warning);color:var(--bg-primary)}.notification--info{background:var(--color-info)}.splash-screen{position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--gradient-dark);display:flex;align-items:center;justify-content:center;z-index:9999;overflow:hidden}.form-text,.help-text{color:var(--text-muted);font-size:12px;margin-top:var(--space-xs);display:block;line-height:1.4}.water-restriction-popup .leaflet-popup-content-wrapper{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff;border-radius:var(--radius-lg);box-shadow:0 8px 25px #ff6b6b66;border:2px solid rgba(255,255,255,.3)}.water-restriction-popup .leaflet-popup-tip{background:#ff6b6b}.restriction-message h4{font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.2)}#arena-editor-modal,#brand-edit-modal{top:0;left:0;width:100%;height:100%;transform:none;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:var(--space-lg);overflow-y:auto;border-radius:0}.arena-editor-content,.brand-edit-content{max-width:800px;margin:var(--space-lg) auto;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-xl)}.arena-section{margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-default)}.arena-section h4{color:var(--text-primary);margin-bottom:var(--space-md);font-size:1.1rem;display:flex;align-items:center;gap:var(--space-sm)}.leaflet-div-icon{background:transparent;border:none}.leaflet-container .leaflet-top.leaflet-left{margin-top:calc(72px + env(safe-area-inset-top,0px));margin-left:max(10px,env(safe-area-inset-left,0px))}.leaflet-control-zoom a{background:var(--glass-bg)!important;color:var(--text-primary)!important;border-color:var(--border-default)!important}.leaflet-control-zoom a:hover{background:var(--bg-elevated)!important}.leaflet-control-attribution{background:var(--glass-bg)!important;color:var(--text-muted)!important}.debug-btn-hidden{display:none!important}@media (max-width: 768px){.leaflet-container .leaflet-control-zoom{display:none!important}#add-balloon-btn{bottom:20px;right:20px;width:56px;height:56px;font-size:24px}.icon-btn{width:44px;height:44px;font-size:18px}.location-btn{bottom:86px!important;right:16px!important}.arena-btn{bottom:141px!important;right:16px!important}.events-btn{bottom:196px!important;right:16px!important}.leaderboard-btn{bottom:251px!important;right:16px!important}.menu-toggle-btn{bottom:306px!important;right:16px!important}.expandable-menu{bottom:306px!important;right:16px!important;--menu-radius: 94px}#settings-modal,#arena-modal,#arena-editor-modal,#balloon-form,#category-filter{top:auto!important;left:0!important;right:0!important;bottom:0!important;transform:none!important;width:100%!important;max-width:100%!important;max-height:88vh!important;border-radius:var(--radius-xl) var(--radius-xl) 0 0!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important}#search-modal{top:auto!important;left:0!important;right:0!important;bottom:0!important;transform:none!important;width:100%!important;max-width:100%!important;max-height:88vh!important;border-radius:var(--radius-xl) var(--radius-xl) 0 0!important;overflow:hidden!important;-webkit-overflow-scrolling:touch!important}#search-modal[aria-hidden=false],#arena-modal[aria-hidden=false]{overflow:hidden!important;display:flex!important;flex-direction:column!important}#arena-modal .arena-content{flex:1 1 auto!important;min-height:0!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important}.settings-actions,.arena-actions{flex-direction:column}.notification{top:calc(env(safe-area-inset-top,0px) + 124px);right:max(12px,env(safe-area-inset-right));left:max(12px,env(safe-area-inset-left));max-width:none;width:auto;cursor:pointer;-webkit-tap-highlight-color:transparent;transform:translateY(-120%);visibility:hidden;opacity:0;pointer-events:none;transition:transform var(--transition-bounce),opacity .35s ease,visibility 0s linear .35s}.notification--visible{visibility:visible;opacity:1;pointer-events:auto;transition:transform var(--transition-bounce),opacity .35s ease,visibility 0s;transform:translateY(0)}.modal{top:auto!important;left:0!important;right:0!important;bottom:0!important;transform:none!important;width:100%!important;max-width:100%!important;max-height:90vh!important;border-radius:var(--radius-lg) var(--radius-lg) 0 0!important;overflow-y:auto;-webkit-overflow-scrolling:touch}.leaflet-popup-content-wrapper{max-width:92vw!important}select,input[type=text],textarea,input[type=file],input[type=number],input[type=datetime-local]{font-size:16px;min-height:44px}}@media (max-width: 480px){.btn-group{flex-direction:column}.popup-topbar{flex-direction:row;flex-wrap:wrap}.game-hud{padding:var(--space-xs) var(--space-sm)}.player-xp-bar{width:50px}.location-btn{bottom:80px!important;right:12px!important}.arena-btn{bottom:130px!important;right:12px!important}.events-btn{bottom:180px!important;right:12px!important}.leaderboard-btn{bottom:230px!important;right:12px!important}.menu-toggle-btn{bottom:280px!important;right:12px!important}.expandable-menu{bottom:280px!important;right:12px!important;--menu-radius: 86px}#add-balloon-btn{bottom:16px;right:12px}}#auth-root.auth-root{flex-shrink:0;max-width:100%;position:relative!important;inset:auto!important;transform:none!important;z-index:auto;pointer-events:auto}.auth-root--embedded{display:none;flex-direction:column;align-items:stretch;gap:8px}.auth-dev-hint{margin:0;max-width:340px;padding:10px 12px;font-size:12px;line-height:1.45;color:#e6edf3;background:#bb4d0059;border:1px solid rgba(255,159,67,.55);border-radius:10px;pointer-events:auto}.auth-dev-hint code{font-size:11px;padding:0 4px;border-radius:4px;background:#00000059}.leaflet-control-zoom{border:none!important;border-radius:14px!important;overflow:hidden;box-shadow:var(--shadow-paper-sm)!important}.leaflet-control-zoom a{background:var(--color-surface)!important;color:var(--color-ink)!important;border-color:var(--color-hairline)!important;font-family:var(--font-body)!important}.leaflet-control-attribution{background:#fefaf0db!important;color:var(--color-ink-3)!important;border-radius:999px 0 0;font-family:var(--font-mono);font-size:10px}#add-balloon-btn,#menu-toggle-btn,#arena-btn,#events-btn,#leaderboard-btn,#expandable-menu{display:none!important}.soft-bottom-nav{position:fixed;left:16px;right:16px;bottom:calc(20px + env(safe-area-inset-bottom,0px));z-index:1500;display:flex;align-items:center;gap:4px;padding:8px;background:var(--color-surface);border-radius:28px;box-shadow:0 6px #3c28140f,0 12px 28px #3c28141a,0 0 0 1px #3c28140f;font-family:var(--font-body);pointer-events:auto}@media (min-width: 769px){.soft-bottom-nav{left:50%;right:auto;width:min(440px,calc(100vw - 32px));transform:translate(-50%)}}.soft-nav-btn{position:relative;flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;border:none;background:transparent;color:var(--color-ink-2);border-radius:18px;font-family:inherit;cursor:pointer;transition:color .18s ease,background .18s ease,transform .12s ease;-webkit-tap-highlight-color:transparent}.soft-nav-btn:hover{color:var(--color-ink)}.soft-nav-btn:active{transform:scale(.96)}.soft-nav-btn.is-active{color:var(--color-ink)}.soft-nav-btn.loading{animation:pulse 1.5s ease-in-out infinite;pointer-events:none}.soft-nav-btn.is-active:after{content:"";position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:5px;height:5px;border-radius:50%;background:var(--color-coral)}.soft-nav-glyph{font-family:var(--font-display);font-size:19px;line-height:1}.soft-nav-label{font-size:10px;font-weight:600;letter-spacing:.03em}.soft-nav-fab{flex:0 0 56px;width:56px;height:56px;margin:0 4px;border:none;border-radius:50%;background:var(--color-coral);color:var(--color-ink);font-family:var(--font-display);font-size:32px;font-weight:500;line-height:1;cursor:pointer;box-shadow:0 4px #c95a48,inset 0 1px #ffffff40;display:flex;align-items:center;justify-content:center;transition:transform .12s ease,box-shadow .12s ease;text-shadow:0 1px 0 rgba(255,255,255,.55),0 2px 3px rgba(157,67,49,.24)}.soft-nav-fab-glyph{display:inline-flex;align-items:center;justify-content:center;color:var(--color-ink);line-height:1}.soft-nav-fab-glyph[hidden]{display:none!important}.soft-nav-fab-glyph--add{font-family:var(--font-display);font-weight:700;font-size:40px;letter-spacing:-.02em;transform:translateY(-2px);-webkit-text-stroke:1px rgba(255,255,255,.6)}.soft-nav-fab-my-dot{display:block;width:22px;height:22px;border-radius:50%;background:var(--color-ink);box-shadow:inset 0 0 0 5px #fffdfa,0 0 0 2px #fff9,0 2px 3px #9d433138}.soft-nav-fab:hover{transform:translateY(-1px)}.soft-nav-fab:active{transform:translateY(2px);box-shadow:0 2px #c95a48,inset 0 1px #ffffff40}.location-btn{bottom:calc(110px + env(safe-area-inset-bottom,0px))!important;right:16px!important}.soft-you-sheet{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1900;display:flex;align-items:flex-end;justify-content:center;pointer-events:none;opacity:0;transition:opacity .22s ease}.soft-you-sheet.is-open{opacity:1;pointer-events:auto}.soft-you-sheet-scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:#1c140c5c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.soft-you-sheet-card{position:relative;width:calc(100% - 24px);max-width:460px;margin-bottom:calc(104px + env(safe-area-inset-bottom,0px));padding:14px;border-radius:22px;background:var(--color-surface);box-shadow:0 6px #3c28140f,0 16px 36px #3c28142e,0 0 0 1px #3c28140f;display:flex;flex-direction:column;gap:6px;transform:translateY(20px);transition:transform .28s cubic-bezier(.34,1.56,.64,1)}.soft-you-sheet.is-open .soft-you-sheet-card{transform:translateY(0)}.soft-you-sheet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.soft-you-sheet-eyebrow{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;color:var(--color-ink-3);text-transform:uppercase}.soft-you-sheet-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--color-paper-light);color:var(--color-ink-2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px #3c281414}.soft-you-item{display:flex;align-items:center;gap:12px;width:100%;padding:11px 14px;background:var(--color-paper-light);border:none;border-radius:16px;cursor:pointer;text-align:left;font-family:var(--font-body);color:var(--color-ink);box-shadow:inset 0 0 0 1px #3c28140f;transition:transform .1s ease,background .15s ease}.soft-you-item:hover{background:var(--color-surface-alt);transform:translate(2px)}.soft-you-item-icon{width:36px;height:36px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;font-family:var(--font-display)}.soft-you-item-icon--coral{background:#ff7e6b2e;color:var(--color-coral)}.soft-you-item-icon--sky{background:#85c5e333;color:#4f95b5}.soft-you-item-icon--sun{background:#f4c95d38;color:#c9972c}.soft-you-item-icon--plum{background:#c89db038;color:#9b6a80}.soft-you-item-icon--sage{background:#a8c9a83d;color:#749d70}.soft-you-item-icon--ink{background:#3c28141a;color:var(--color-ink-2)}.soft-you-item-body{flex:1;min-width:0}.soft-you-item-title{font-size:14px;font-weight:600;color:var(--color-ink);line-height:1.2}.soft-you-item-sub{font-family:var(--font-mono);font-size:9.5px;color:var(--color-ink-3);letter-spacing:.04em;margin-top:2px}.soft-you-item-arrow{color:var(--color-ink-3);font-size:16px;flex-shrink:0}#pin-placement-bar{left:16px;right:16px;bottom:calc(104px + env(safe-area-inset-bottom,0px));border:1px solid var(--color-hairline);border-radius:18px;background:var(--color-sun);box-shadow:0 3px #3c28141a,var(--shadow-md)}.pin-bar-text{color:var(--color-ink)}#pin-bar-cancel,#pin-bar-next,.pin-bar-next-btn{border-radius:14px;box-shadow:var(--shadow-paper-sm)}#pin-bar-cancel{background:var(--color-surface);color:var(--color-ink-2);border-color:var(--color-hairline)}#pin-bar-next,.pin-bar-next-btn{background:var(--color-ink);color:#fff}#balloon-form,#category-filter,#debug-logs,#search-modal,#settings-modal,#arena-modal,#arena-editor-modal,#brand-edit-modal{background:var(--color-paper);border:1px solid var(--color-hairline);border-radius:28px;box-shadow:0 8px #3c28140f,0 20px 50px #3c28142e,0 0 0 1px #3c28140f}#balloon-form:before,#category-filter:before,#debug-logs:before,#search-modal:before,#settings-modal:before,#arena-modal:before{background:#2a201847;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}#balloon-form h3,#category-filter h3,#debug-logs h3,#search-modal h3,#arena-modal h3,#arena-editor-modal h3,#brand-edit-modal h3{padding:18px 20px;background:none;-webkit-text-fill-color:var(--color-ink);color:var(--color-ink);border-color:var(--color-hairline);font-size:24px;font-weight:500;line-height:1.1;text-align:left}#settings-modal h3#settings-title{padding:0;border:none;text-align:left}.balloon-form-header{padding:18px 20px 12px;border-color:var(--color-hairline)}.balloon-form-header h3{font-size:24px!important;font-weight:500!important}.sheet-close-btn,.balloon-popup-close{background:var(--color-surface)!important;color:var(--color-ink-2)!important;border:1px solid var(--color-hairline)!important;border-radius:var(--radius-full)!important;box-shadow:var(--shadow-paper-sm)!important}.image-upload-zone{min-height:236px;margin:16px 20px;border:2px dashed rgba(60,40,20,.16);border-radius:22px;background:repeating-linear-gradient(45deg,transparent,transparent 14px,rgba(60,40,20,.03) 14px,rgba(60,40,20,.03) 16px),var(--color-surface)}.image-upload-zone:hover,.image-upload-zone.drag-over,.image-upload-zone.has-image{border-color:var(--color-coral);background-color:var(--color-surface);box-shadow:0 0 0 4px #ff7e6b24}.image-placeholder{color:var(--color-ink)}.image-placeholder-icon{display:grid;place-items:center;width:56px;height:56px;border-radius:28px;background:var(--color-paper-light);color:var(--color-ink-2)}.image-placeholder-text{color:var(--color-ink);font-size:13px;font-weight:700}.image-placeholder small,.form-hint{color:var(--color-ink-3);font-family:var(--font-mono);font-size:10px;letter-spacing:0}.form-section{padding:8px 20px}.form-section-label,label{color:var(--color-ink-3);font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:0}input[type=file],input[type=text],input[type=number],input[type=datetime-local],select,textarea,.form-section textarea{background:var(--color-surface);border:1.5px solid var(--color-hairline);border-radius:16px;color:var(--color-ink);font-family:var(--font-body);box-shadow:var(--shadow-sm)}input:focus,select:focus,textarea:focus,.form-section textarea:focus{border-color:var(--color-coral);box-shadow:0 0 0 4px #ff7e6b29;background:var(--color-surface)}.chip{padding:8px 12px;border:1px solid var(--color-hairline);border-radius:999px;background:var(--color-surface);color:var(--color-ink);box-shadow:var(--shadow-paper-sm)}.chip:hover,.chip.selected{border-color:transparent;background:var(--chip-accent, var(--color-coral));color:#fff;box-shadow:0 2px #3c281424}.theme-picker-row{display:grid;grid-template-columns:repeat(5,minmax(54px,1fr));gap:8px}.theme-swatch-wrap{padding:10px 6px 8px;border-radius:14px;background:var(--color-surface);box-shadow:var(--shadow-paper-sm)}.theme-swatch{width:30px;height:30px}.theme-swatch-wrap.swatch-equipped,.theme-swatch-wrap:has(.theme-swatch.selected){box-shadow:0 0 0 2px var(--color-coral),var(--shadow-paper-sm)}.form-submit-row{padding:16px 20px 22px!important;gap:10px}.form-submit-row button[type=submit],#balloon-submit-btn,.primary-btn,button[type=submit]{background:var(--color-ink)!important;color:#fff!important;border:none!important;border-radius:18px!important;box-shadow:0 4px #0c0805!important}button[type=button],.secondary-btn{background:var(--color-surface)!important;color:var(--color-ink)!important;border:1px solid var(--color-hairline)!important;box-shadow:var(--shadow-paper-sm)}.danger-btn,#balloon-delete-btn{background:var(--color-coral)!important;color:#fff!important;border:none!important;box-shadow:0 3px #c95a48!important}.custom-popup .leaflet-popup-content-wrapper{border-radius:20px;padding:0;max-width:min(280px,calc(100vw - 24px));overflow:hidden}.leaflet-popup-content{margin:0!important;width:min(280px,calc(100vw - 24px))!important;max-width:calc(100vw - 24px);overflow:hidden}.balloon-popup{width:min(280px,calc(100vw - 24px));min-width:0;max-width:100%;background:var(--color-surface);color:var(--color-ink);font-family:var(--font-body);overflow:hidden}.popup-hero{height:148px;margin:8px 8px 0;border-radius:16px;background:linear-gradient(135deg,var(--color-sun),var(--color-coral));overflow:hidden;max-width:calc(100% - 16px)}.popup-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.08),rgba(255,255,255,.08) 8px,transparent 8px,transparent 16px);pointer-events:none}.popup-hero-img{border-radius:16px;width:100%;height:100%;max-width:100%;object-fit:cover;display:block}.popup-hero .popup-hero-overlay{border-radius:16px;padding:8px 10px}.popup-hero-overlay .popup-category-badge{text-transform:uppercase;padding-left:8px;padding-right:8px}.popup-hero .balloon-popup-close{top:6px;right:6px;width:26px;height:26px;font-size:16px}.popup-topbar{padding:10px 10px 8px}.popup-body{padding:10px 12px 12px}.popup-description{margin:0 0 4px;color:var(--color-ink);font-family:var(--font-display);font-size:18px;font-weight:500;line-height:1.15;letter-spacing:0}.popup-date{display:block;margin-bottom:8px;color:var(--color-ink-3);font-family:var(--font-mono);font-size:9px;letter-spacing:0;text-transform:uppercase}.popup-category-badge{border:none;border-radius:999px;background:#fffffff0;color:var(--color-ink);font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:0}.popup-points-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;background:#fffffff0;color:var(--color-coral);font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.04em;font-variant-numeric:tabular-nums}.popup-points-star{font-family:var(--font-display);font-size:11px;line-height:1}.soft-vote-block{margin:8px 0 2px}.soft-vote-eyebrow{font-family:var(--font-mono);font-size:8px;font-weight:700;letter-spacing:.1em;color:var(--color-ink-3);padding-left:2px;margin-bottom:6px;text-transform:uppercase}.soft-vote-panel{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:16px;background:var(--color-paper-light);box-shadow:inset 0 0 0 1px #3c28140f}.soft-vote-btn{flex:0 0 44px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-hairline);border-radius:50%;background:var(--color-surface);color:var(--color-ink);font-family:var(--font-body);cursor:pointer;box-shadow:0 3px #3c281414;transition:transform .1s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease;-webkit-tap-highlight-color:transparent;padding:0}.soft-vote-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 3px #3c281414,var(--shadow-paper-sm)}.soft-vote-btn:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px #3c28140f}.soft-vote-btn.is-vote-locked{cursor:default;pointer-events:none}.soft-vote-glyph{font-family:var(--font-display);font-size:26px;line-height:1;font-weight:700;letter-spacing:-.02em;color:inherit;-webkit-text-fill-color:currentColor}.soft-vote-btn--up{background:var(--color-coral);border-color:var(--color-coral);color:#4a1812;box-shadow:0 4px #c95a48,inset 0 1px #ffffff38}.soft-vote-btn--up .soft-vote-glyph{color:#4a1812;text-shadow:none}.soft-vote-btn--up.is-active{box-shadow:0 4px #c95a48,inset 0 1px #ffffff47}.soft-vote-panel.is-locked .soft-vote-btn--up:not(.is-active),.soft-vote-btn--up.is-vote-locked:not(.is-active){background:var(--color-surface);border-color:var(--color-hairline);color:var(--color-ink-2);box-shadow:none;opacity:.85}.soft-vote-panel.is-locked .soft-vote-btn--up:not(.is-active) .soft-vote-glyph,.soft-vote-btn--up.is-vote-locked:not(.is-active) .soft-vote-glyph{color:var(--color-ink-2)}.soft-vote-panel.is-locked .soft-vote-btn--up.is-active,.soft-vote-btn--up.is-vote-locked.is-active{background:var(--color-coral);border-color:var(--color-coral);color:#4a1812;opacity:1;box-shadow:0 3px #c95a48}.soft-vote-panel.is-locked .soft-vote-btn--down.is-vote-locked:not(.is-active){opacity:.85}.soft-vote-btn--down{background:var(--color-surface);color:var(--color-ink-2)}.soft-vote-btn--down .soft-vote-glyph{color:var(--color-ink-2)}.soft-vote-btn.is-active.soft-vote-btn--down{background:var(--color-ink-2);border-color:var(--color-ink-2);color:#fff;box-shadow:0 4px 0 var(--color-ink),inset 0 1px #ffffff1a}.soft-vote-btn.is-active.soft-vote-btn--down .soft-vote-glyph{color:#fff}.soft-vote-score{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;text-align:center;min-width:0}.soft-vote-score-num{font-family:var(--font-display);font-size:32px;font-weight:500;line-height:1;letter-spacing:-.04em;color:var(--color-ink);font-variant-numeric:tabular-nums}.soft-vote-score-suffix{font-family:var(--font-mono);font-size:8px;font-weight:700;letter-spacing:.12em;color:var(--color-ink-3);text-transform:uppercase}.soft-vote-locked-note{margin-top:6px;padding-left:2px;font-family:var(--font-mono);font-size:8px;letter-spacing:.04em;color:var(--color-ink-3);text-transform:uppercase;line-height:1.3}.pattern-log__msg .coin-icon-visual--sm{vertical-align:-.14em}.pattern-log{margin-top:10px;padding:8px 10px;border-radius:12px;background:#ffffffb8;border:1px solid rgba(0,0,0,.06)}.pattern-log__title{font-family:var(--font-mono);font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:var(--color-ink-3);margin-bottom:6px}.pattern-log__body{font-size:11px;line-height:1.35;color:var(--color-ink-2);max-height:88px;overflow-y:auto}.pattern-log__entry{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;padding:4px 0;border-bottom:1px solid rgba(0,0,0,.04)}.pattern-log__entry:last-child{border-bottom:none}.pattern-log__delta{font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--color-ink);flex-shrink:0}.pattern-log--loading .pattern-log__body{opacity:.65}.pat-ring-preview--none{border:2px dashed rgba(0,0,0,.15);border-radius:50%;background:transparent}.simple-vote-panel{display:none!important}.popup-actions{gap:6px;margin-top:8px}.popup-action-btn{border-radius:12px!important;padding:8px 10px!important;font-size:12px!important;background:#fff!important;color:var(--color-ink)!important;font-size:13px!important;box-shadow:var(--shadow-paper-sm)!important}.competition-header,.brands-list,.brand-item,.settings-section,.search-form,.search-results,.filter-content,.arena-section,.brand-edit-content,.debug-content{background:var(--color-surface)!important;border:1px solid var(--color-hairline)!important;border-radius:18px!important;box-shadow:var(--shadow-paper-sm)}#arena-modal{max-width:820px;background:var(--color-paper);border:1px solid var(--color-hairline)}#arena-modal h3{background:none;color:var(--color-ink);text-shadow:none}.arena-content,.settings-content,.search-content,.filter-content,.arena-editor-content{padding:16px 20px 22px}.competition-info h4,.leaderboard-section h4,.voting-section h4,.settings-section h4,.search-results h4,.arena-section h4{color:var(--color-ink);font-family:var(--font-display);font-size:20px;font-weight:500;border-color:var(--color-coral)}.competition-timer,.competition-stats,.help-text{color:var(--color-ink-3)!important;font-family:var(--font-mono);letter-spacing:0}#countdown-timer{color:var(--color-coral);font-family:var(--font-display);font-weight:600}.arena-action-btn{background:var(--color-coral)!important;color:#fff!important;box-shadow:0 3px #c95a48!important}.brand-item.rank-1{background:var(--color-sun)!important;color:var(--color-ink)!important}.brand-item.rank-2{background:var(--color-sky)!important;color:var(--color-ink)!important}.brand-item.rank-3{background:var(--color-plum)!important;color:var(--color-ink)!important}.notification{background:var(--color-surface)!important;color:var(--color-ink)!important;border:1px solid var(--color-hairline)!important;border-radius:18px!important;box-shadow:var(--shadow-paper-md)!important}@media (min-width: 769px){.game-hud{background:transparent}}@media (max-width: 768px){.hud-top .soft-search-pill{position:fixed;flex:0 0 0;min-width:0;top:calc(env(safe-area-inset-top,0px) + 76px);left:16px;right:16px;width:auto;max-width:none;z-index:520}.leaderboard-btn:before,.arena-btn:before,.events-btn:before,.menu-toggle-btn:before,#add-balloon-btn:before{left:16px;width:calc(100vw - 32px)}.leaderboard-btn{left:calc(50% - 164px)!important}.arena-btn{left:calc(50% - 98px)!important}.events-btn{left:calc(50% + 44px)!important}.menu-toggle-btn{left:calc(50% + 110px)!important}#settings-modal,#arena-modal,#arena-editor-modal,#balloon-form,#category-filter,#search-modal{max-height:86vh!important;border-radius:28px 28px 0 0!important}}@media (max-width: 420px){.leaderboard-btn{left:calc(50% - 132px)!important}.arena-btn{left:calc(50% - 74px)!important}.events-btn{left:calc(50% + 20px)!important}.menu-toggle-btn{left:calc(50% + 78px)!important}.leaderboard-btn,.arena-btn,.events-btn,.menu-toggle-btn{width:48px!important;height:52px!important}.leaderboard-btn:after,.arena-btn:after,.events-btn:after,.menu-toggle-btn:after{font-size:8px}#add-balloon-btn{width:54px;height:54px}}#balloon-form h3,#category-filter h3,#debug-logs h3,#search-modal h3,#settings-modal h3,#arena-modal h3,#arena-editor-modal h3,#brand-edit-modal h3{background:none!important;-webkit-text-fill-color:var(--color-ink)!important;color:var(--color-ink)!important;font-family:var(--font-display)!important;font-weight:500!important;font-size:24px!important;letter-spacing:-.01em!important;text-align:left!important;border-color:var(--color-hairline)!important}.soft-modal-eyebrow{display:block;font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.14em;color:var(--color-coral);text-transform:uppercase;margin-bottom:4px}input[type=file],input[type=text],input[type=number],input[type=email],input[type=search],input[type=tel],input[type=url],input[type=password],select,textarea{border:1px solid var(--color-hairline)!important;border-radius:14px!important;background:var(--color-paper-light)!important;color:var(--color-ink)!important;font-family:var(--font-body)!important;font-size:14px;padding:11px 14px;box-shadow:inset 0 0 0 1px #3c28140a;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease}input:focus,select:focus,textarea:focus{border-color:var(--color-coral)!important;background:var(--color-surface)!important;box-shadow:0 0 0 3px #ff7e6b2e!important;outline:none}input::placeholder,textarea::placeholder{color:var(--color-ink-3);opacity:1}label{color:var(--color-ink-2)!important;font-family:var(--font-mono);font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}button[type=submit],.primary-btn{background:var(--color-coral)!important;background-image:none!important;color:#fff!important;border:none!important;border-radius:14px!important;font-family:var(--font-body)!important;font-weight:600!important;letter-spacing:-.01em!important;padding:12px 18px!important;box-shadow:0 3px #c95a48,inset 0 1px #ffffff38!important;transition:transform .1s ease,box-shadow .15s ease!important}button[type=submit]:hover,.primary-btn:hover{transform:translateY(-1px)!important;box-shadow:0 4px #c95a48,0 6px 14px #ff7e6b3d,inset 0 1px #ffffff38!important}button[type=submit]:active,.primary-btn:active{transform:translateY(2px)!important;box-shadow:0 1px #c95a48,inset 0 1px #ffffff38!important}button[type=button]:not(.icon-btn):not(.soft-nav-btn):not(.soft-nav-fab):not(.soft-you-item):not(.soft-you-sheet-close):not(.soft-vote-btn):not(.balloon-popup-close):not(.popup-action-btn):not(.shop-item-action):not(.shop-tab):not(.shop-close-btn):not(.balloon-marker *){background:var(--color-surface)!important;background-image:none!important;color:var(--color-ink)!important;border:1px solid var(--color-hairline)!important;border-radius:14px!important;font-family:var(--font-body)!important;font-weight:600!important;padding:11px 16px!important;box-shadow:0 2px #3c28140f!important;transition:transform .1s ease,box-shadow .15s ease,background .15s ease!important}button[type=button]:not(.icon-btn):not(.soft-nav-btn):not(.soft-nav-fab):not(.soft-you-item):not(.soft-you-sheet-close):not(.soft-vote-btn):not(.balloon-popup-close):not(.popup-action-btn):not(.shop-item-action):not(.shop-tab):not(.shop-close-btn):not(.balloon-marker *):hover{background:var(--color-surface-alt)!important;transform:translateY(-1px)!important;box-shadow:0 3px #3c281414!important}.danger-btn{background:#9b6a80!important;background-image:none!important;color:#fff!important;border:none!important;box-shadow:0 3px #6e4358!important}.danger-btn:hover{background:#885c70!important;box-shadow:0 4px #6e4358!important}.form-group{margin-bottom:14px}.settings-section h4,.arena-section h4,.form-section-label,.balloon-form-header h4{font-family:var(--font-mono)!important;font-size:10px!important;font-weight:700!important;letter-spacing:.14em!important;color:var(--color-ink-3)!important;text-transform:uppercase!important;margin:14px 0 6px!important}.form-submit-row{display:flex;gap:10px;padding:14px 20px calc(20px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--color-hairline);background:var(--color-paper-light)}.checkbox-label{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--color-ink);text-transform:none;letter-spacing:0;font-family:var(--font-body)}@media (max-width: 520px){#balloon-form,#category-filter,#search-modal,#settings-modal,#arena-modal,#arena-editor-modal,#brand-edit-modal{top:auto!important;left:0!important;right:0!important;bottom:0!important;transform:none!important;width:100%!important;max-width:100vw!important;max-height:90vh!important;border-radius:28px 28px 0 0!important;margin:0!important}#search-modal{overflow:hidden!important}#balloon-form:after,#category-filter:after,#search-modal:after,#settings-modal:after,#arena-modal:after,#arena-editor-modal:after{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:44px;height:4px;border-radius:2px;background:#3c281429;z-index:10}}.image-upload-zone{margin:16px 20px 8px!important;border:2px dashed rgba(60,40,20,.16)!important;border-radius:22px!important;background:repeating-linear-gradient(45deg,transparent,transparent 14px,rgba(60,40,20,.025) 14px,rgba(60,40,20,.025) 16px),var(--color-paper-light)!important;aspect-ratio:4 / 3;min-height:220px;transition:border-color .2s ease,background .2s ease,transform .1s ease}.image-upload-zone:hover,.image-upload-zone.drag-over{border-color:var(--color-coral)!important;background:var(--color-surface)!important;transform:translateY(-1px)}.image-upload-zone.has-image{border-style:solid!important;border-color:var(--color-hairline)!important;background:var(--color-surface)!important;box-shadow:0 4px #3c28140f,0 0 0 1px #3c28140f}.image-placeholder-icon{font-size:36px!important;color:var(--color-ink-3);filter:grayscale(.3)}.image-placeholder-text{font-family:var(--font-display)!important;font-size:16px!important;font-weight:500!important;color:var(--color-ink-2)!important;letter-spacing:-.01em}.image-placeholder small{font-family:var(--font-mono)!important;font-size:9.5px!important;font-weight:700!important;letter-spacing:.1em!important;color:var(--color-ink-3)!important;text-transform:uppercase;margin-top:4px}.image-preview-remove{background:var(--color-ink)!important;color:#fff!important;width:32px!important;height:32px!important;font-size:12px!important;box-shadow:0 2px #0c0805!important}.image-preview-remove:hover{background:var(--color-ink)!important;transform:scale(1.05)}.form-section{padding:8px 20px 12px!important}.form-section-label{font-family:var(--font-mono)!important;font-size:10px!important;font-weight:700!important;letter-spacing:.14em!important;color:var(--color-coral)!important;text-transform:uppercase!important;margin-bottom:8px!important}.category-chips{gap:6px}.chip{display:inline-flex!important;align-items:center!important;gap:6px!important;padding:9px 14px!important;border-radius:14px!important;border:1px solid var(--color-hairline)!important;background:var(--color-surface)!important;color:var(--color-ink-2)!important;font-family:var(--font-body)!important;font-size:13px!important;font-weight:600!important;cursor:pointer!important;box-shadow:0 2px #3c28140f!important;transition:transform .1s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease!important}.chip:hover{background:var(--color-paper-light)!important;color:var(--color-ink)!important;border-color:var(--color-hairline)!important;transform:translateY(-1px)!important;box-shadow:0 3px #3c281414!important}.chip.selected{border-color:var(--chip-accent, var(--color-coral))!important;background:var(--chip-accent, var(--color-coral))!important;color:#fff!important;box-shadow:0 3px color-mix(in srgb,var(--chip-accent, var(--color-coral)) 70%,#000),inset 0 1px #ffffff38!important}.chip.selected:hover{transform:translateY(-1px)!important}.category-chips .chip{position:relative!important}.category-chips .chip.selected{border-color:var(--chip-accent, var(--color-coral))!important;background:linear-gradient(0deg,#ffffffb8,#ffffffb8),var(--chip-accent, var(--color-coral))!important;color:var(--color-ink)!important;font-weight:800!important;box-shadow:0 0 0 2px #fffdfa,0 0 0 4px color-mix(in srgb,var(--chip-accent, var(--color-coral)) 62%,transparent),0 4px #3c28141a!important}.category-chips .chip.selected:after{content:"";display:inline-block;width:8px;height:8px;flex:0 0 8px;margin-left:2px;border-radius:50%;background:var(--chip-accent, var(--color-coral));box-shadow:0 0 0 2px #fffdfa,0 1px 2px #3c28142e}.form-hint{display:block;margin-top:6px;padding:8px 12px;border-radius:12px;background:#f4c95d2e;color:var(--color-ink-2);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.02em;border:1px solid rgba(201,151,44,.18)}.theme-picker-row{display:flex;gap:8px;flex-wrap:wrap;padding:4px 0}#theme-picker-section{padding-bottom:var(--space-xs)!important}#theme-picker-section .form-section-label{margin-bottom:6px!important}.theme-picker-row--frames{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(132px,1fr))!important;gap:8px!important;align-items:stretch!important;padding:2px 0 0!important}.theme-picker-row--frames .balloon-frame-card{width:100%;min-width:0}.theme-picker-row--frames .theme-swatch-wrap{padding:0!important;border-radius:12px!important;background:transparent!important;box-shadow:none!important}.theme-picker-row--frames .balloon-frame-card__btn.theme-swatch{width:100%!important;height:44px!important;min-height:44px!important;padding:6px 8px!important;border-radius:12px!important;border:1px solid var(--color-hairline)!important;background:var(--color-surface)!important;box-shadow:var(--shadow-paper-sm)!important;display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:flex-start!important;gap:8px!important;overflow:hidden!important;transform:none!important}.theme-picker-row--frames .balloon-frame-card__btn.theme-swatch:hover{border-color:#ff7e6b61!important;box-shadow:0 3px #3c281414!important;transform:translateY(-1px)!important}.theme-picker-row--frames .balloon-frame-card.swatch-equipped .balloon-frame-card__btn.theme-swatch{border-color:#ff7e6bb8!important;box-shadow:0 0 0 2px #ff7e6b29,var(--shadow-paper-sm)!important}.theme-picker-row--frames .balloon-frame-card.swatch-cant-afford .balloon-frame-card__btn.theme-swatch{opacity:.58}.balloon-frame-card__preview{display:block;flex:0 0 22px;width:22px;height:22px;border-radius:50%;border:2px solid #fffdfa;background:var(--bf-color, var(--color-sky));box-shadow:0 0 0 1px rgba(var(--bf-rgb, 127, 181, 214),.42),0 1px 3px #3c28142e;box-sizing:border-box}.bf-preview--halo{box-shadow:0 0 0 1px rgba(var(--bf-rgb, 127, 181, 214),.42),0 0 9px rgba(var(--bf-rgb, 127, 181, 214),.68)}.bf-preview--double_ring{box-shadow:0 0 0 2px #fffdfa,0 0 0 4px rgba(var(--bf-rgb, 127, 181, 214),.74),0 1px 3px #3c28142e}.bf-preview--spotlight{animation:bf-thumb-dot-burn 2.2s ease-in-out infinite}.bf-preview--bounce{animation:bf-thumb-dot-bounce 1.6s ease-in-out infinite}.balloon-frame-card__meta{display:flex;flex:1 1 auto;min-width:0;flex-direction:column;align-items:flex-start;gap:3px}.theme-picker-row--frames .balloon-frame-card__name{width:100%;min-width:0;color:var(--color-ink)!important;font-family:var(--font-body)!important;font-size:12px!important;font-weight:700!important;line-height:1.05!important;text-align:left!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.theme-picker-row--frames .swatch-lbl{position:static!important;min-height:10px;font-family:var(--font-mono)!important;font-size:8.5px!important;line-height:1!important;letter-spacing:.08em;text-transform:uppercase;text-shadow:none!important}.theme-picker-row--frames .swatch-lbl--on{color:var(--color-coral)!important}.theme-picker-row--frames .swatch-lbl--owned{color:var(--color-ink-3)!important}.theme-picker-row--frames .swatch-lbl--price{color:var(--color-ink-2)!important}.theme-picker-row--frames .swatch-check{top:50%!important;right:8px!important;transform:translateY(-50%)!important;color:var(--color-coral)!important;font-size:12px!important;text-shadow:none!important}@media (max-width: 420px){.theme-picker-row--frames{grid-template-columns:repeat(2,minmax(0,1fr))!important}}#category-chips .chip{position:relative!important}#category-chips .chip.selected,#category-chips .chip[aria-pressed=true]{border-color:var(--chip-accent, var(--color-coral))!important;background:linear-gradient(0deg,#ffffffb8,#ffffffb8),var(--chip-accent, var(--color-coral))!important;color:var(--color-ink)!important;font-weight:800!important;box-shadow:0 0 0 2px #fffdfa,0 0 0 4px color-mix(in srgb,var(--chip-accent, var(--color-coral)) 62%,transparent),0 4px #3c28141a!important}#category-chips .chip.selected:after,#category-chips .chip[aria-pressed=true]:after{content:"";display:inline-block;width:8px;height:8px;flex:0 0 8px;margin-left:2px;border-radius:50%;background:var(--chip-accent, var(--color-coral));box-shadow:0 0 0 2px #fffdfa,0 1px 2px #3c28142e}.form-submit-row--editing{justify-content:space-between!important}.form-submit-row--editing #balloon-delete-btn{order:1;flex:0 0 auto!important;min-width:92px}.form-submit-row--editing #balloon-submit-btn{order:2;flex:1 1 auto!important;width:auto!important;min-width:0}#search-modal{width:min(480px,calc(100vw - 32px))!important;background:var(--color-paper)!important;border:1px solid var(--color-hairline)!important;border-radius:28px!important;box-shadow:0 8px #3c28140f,0 20px 50px #3c28142e,0 0 0 1px #3c28140f!important;scrollbar-width:none}#search-modal::-webkit-scrollbar{display:none;width:0;height:0}#search-modal .search-sheet-header{flex-shrink:0;padding:18px 20px 12px;border-bottom:1px solid var(--color-hairline)}#search-modal h3{margin:0!important;padding:0!important;border:none!important;color:var(--color-ink)!important;font-family:var(--font-display)!important;font-size:1.35rem!important;font-weight:500!important;line-height:1.15!important;text-align:left!important;background:none!important;-webkit-text-fill-color:var(--color-ink)!important;text-shadow:none!important}#search-modal .search-content{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;gap:12px;padding:14px 18px 18px!important;overflow:hidden}#search-modal .search-form{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0 0 14px;padding:14px!important;border-radius:18px!important;background:var(--color-surface)!important;border:1px solid var(--color-hairline)!important;box-shadow:var(--shadow-paper-sm)!important}#search-modal .search-form .form-group{min-width:0;margin:0!important}#search-modal .search-form .form-group:first-child{grid-column:1 / -1}#search-modal label{display:block;margin:0 0 6px!important;color:var(--color-ink-3)!important;font-family:var(--font-mono)!important;font-size:10px!important;font-weight:800!important;letter-spacing:.12em!important;line-height:1.1!important;text-transform:uppercase!important}#search-modal input,#search-modal select{width:100%!important;min-height:44px;padding:11px 12px!important;border:1px solid var(--color-hairline)!important;border-radius:14px!important;background:var(--color-paper-light)!important;color:var(--color-ink)!important;font-family:var(--font-body)!important;font-size:14px!important;font-weight:600!important;box-shadow:inset 0 1px #ffffffb3!important}#search-modal input::placeholder{color:var(--color-ink-3);opacity:.72}#search-modal input:focus,#search-modal select:focus{border-color:#3c281438!important;background:var(--color-surface)!important;box-shadow:0 0 0 3px #f4c95d59,inset 0 1px #ffffffd9!important;outline:none!important}#search-modal .search-results{flex:1 1 auto;min-height:0;margin:0!important;padding:12px 14px!important;overflow:hidden;border-radius:var(--radius-lg)!important;background:var(--color-surface)!important;border:1px solid var(--color-hairline)!important;box-shadow:var(--shadow-paper-sm)!important;display:flex;flex-direction:column}#search-modal .search-results h4{margin:0 0 10px!important;color:var(--color-ink)!important;font-family:var(--font-body)!important;font-size:14px!important;font-weight:800!important;line-height:1.2!important}#search-modal .results-list{flex:1 1 auto;min-height:52px;max-height:min(200px,28vh);margin-top:2px;border:1px dashed rgba(60,40,20,.14)!important;border-radius:var(--radius-md)!important;background:var(--color-paper-light)!important;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}#search-modal .results-list::-webkit-scrollbar{display:none;width:0;height:0}#search-modal .search-result-item{padding:12px!important;border-bottom:1px solid var(--color-hairline)!important;background:var(--color-surface)!important}#search-modal .search-result-item:hover{background:var(--color-paper-light)!important}#search-modal .result-description{color:var(--color-ink-2)!important}#search-modal .result-votes,#search-modal .result-date,#search-modal .no-results{color:var(--color-ink-3)!important}#search-modal .search-actions{flex-shrink:0;display:grid!important;grid-template-columns:1fr 1fr 1fr;gap:10px!important;margin-top:2px}#search-modal .search-actions button{min-height:44px;padding:10px 12px!important;border-radius:14px!important;font-family:var(--font-body)!important;font-size:13px!important;font-weight:800!important;box-shadow:var(--shadow-paper-sm)!important}#search-modal #perform-search{background:var(--color-ink)!important;color:#fff!important;border:none!important;box-shadow:0 4px #0c0805!important}#search-modal #clear-search{background:#f4c95d42!important;color:var(--color-ink)!important;border:1px solid rgba(201,151,44,.26)!important}#search-modal #close-search{background:var(--color-surface)!important;color:var(--color-ink-2)!important;border:1px solid var(--color-hairline)!important}@media (max-width: 768px){#search-modal{overflow:hidden!important;max-height:min(88vh,620px)!important}}@media (max-width: 520px){#search-modal .search-form,#search-modal .search-actions{grid-template-columns:1fr}#search-modal .results-list{max-height:min(160px,22vh)}}.soft-search-pill{--search-track-h: 40px;position:fixed;top:calc(env(safe-area-inset-top,0px) + 76px);left:16px;right:16px;z-index:520;display:flex;align-items:center;gap:6px;min-height:calc(var(--search-track-h) + 10px);padding:5px 5px 5px 12px;border:1px solid rgba(60,40,20,.1);border-radius:var(--radius-full);background:#fffdfaf5;box-shadow:0 1px #fffc inset,var(--shadow-paper-sm);pointer-events:auto;box-sizing:border-box}.soft-search-submit{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0!important;background:transparent!important;box-shadow:none!important;cursor:pointer;display:inline-flex!important;align-items:center!important;justify-content:center!important;flex:0 0 34px;width:34px!important;height:34px!important;padding:0!important;border-radius:50%!important;color:var(--color-ink-2)!important}.soft-search-submit:hover{background:var(--color-paper-light)!important;transform:none!important}.soft-search-input{flex:1 1 auto;min-width:0;height:var(--search-track-h);margin:0;padding:0 6px 0 10px!important;border:0!important;border-radius:var(--radius-full)!important;background:color-mix(in srgb,var(--color-paper-light) 55%,var(--color-surface))!important;color:var(--color-ink)!important;font-family:var(--font-body)!important;font-size:14px!important;font-weight:500!important;line-height:var(--search-track-h)!important;outline:none!important;box-shadow:none!important}.soft-search-input::placeholder{color:var(--color-ink-3);opacity:.82}.soft-search-input::-webkit-search-decoration,.soft-search-input::-webkit-search-cancel-button{display:none}.soft-search-clear{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;margin-left:2px;padding:0;border:0;border-radius:50%;background:#3c281424;color:var(--color-surface, #fffdf8);font-size:14px;line-height:1;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:background .15s}.soft-search-clear:hover{background:#3c281461}.soft-search-clear[hidden]{display:none!important}.soft-search-count{flex:0 0 auto;min-width:20px;padding:1px 7px;border-radius:999px;background:var(--color-sun, #f4c95d);color:var(--color-ink, #2c1e0f);font-family:var(--font-mono, monospace);font-size:11px;font-weight:800;text-align:center;line-height:18px;white-space:nowrap}.soft-search-count[hidden]{display:none!important}.soft-search-dots-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:0 0 var(--search-track-h);width:var(--search-track-h);height:var(--search-track-h);margin:0;padding:0;border:1px solid rgba(60,40,20,.06);border-radius:var(--radius-full);background:color-mix(in srgb,var(--color-paper-light) 55%,var(--color-surface));cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s ease,border-color .15s ease;box-shadow:none}.soft-search-dots-btn:hover{background:color-mix(in srgb,var(--color-paper-light) 75%,var(--color-surface));border-color:#3c28141a}.soft-search-dots{display:flex;align-items:center;justify-content:center;gap:5px;line-height:0}.soft-search-dots i{width:7px;height:7px;border-radius:var(--radius-full);background:var(--color-coral);flex-shrink:0}.soft-search-dots i:nth-child(2){background:var(--color-sun)}.soft-search-dots i:nth-child(3){background:var(--color-plum)}.soft-search-dots i:nth-child(4){background:var(--color-sage)}.soft-search-dots.is-no-results i{animation:search-dot-bounce .65s ease-in-out infinite}.soft-search-dots.is-no-results i:nth-child(2){animation-delay:.08s}.soft-search-dots.is-no-results i:nth-child(3){animation-delay:.16s}.soft-search-dots.is-no-results i:nth-child(4){animation-delay:.24s}@keyframes search-dot-bounce{0%,to{transform:translateY(0) scale(1);opacity:.75}45%{transform:translateY(-3px) scale(1.4);opacity:1}}.balloon-marker.search-dim{opacity:.12!important;filter:grayscale(.55)!important;transition:opacity .22s,filter .22s;pointer-events:none!important}.balloon-marker.search-hit{filter:drop-shadow(0 0 9px rgba(244,201,93,.98)) drop-shadow(0 0 3px rgba(244,201,93,1))!important;transition:filter .22s}@media (max-width: 420px){.soft-search-pill{left:12px;right:12px;padding-left:10px}.soft-search-input{padding-left:8px!important}}#shop-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2000;background:var(--color-paper, var(--bg-secondary));border:1px solid var(--color-hairline, var(--border-color));border-radius:var(--radius-lg);padding:0;width:min(96vw,480px);max-height:88vh;display:none;flex-direction:column;box-shadow:0 20px 50px #3c28142e;overflow:hidden}#shop-modal.open{display:flex}.shop-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 10px;background:linear-gradient(135deg,var(--color-coral, var(--color-primary)),var(--color-sky, var(--color-secondary)));flex-shrink:0}.shop-header h3{margin:0;font-size:17px;font-weight:700;color:#fff}.shop-balance{display:flex;gap:8px;align-items:center}.shop-balance-item{display:flex;align-items:center;gap:4px;background:#ffffff2e;border-radius:999px;padding:3px 9px;font-size:12px;font-weight:700;color:#fff}.shop-close-btn{background:#ffffff2e;border:none;border-radius:50%;width:30px;height:30px;min-height:30px;padding:0!important;color:#fff;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:none!important;transition:background .15s ease}.shop-close-btn:hover{background:#ffffff52!important;transform:none!important}.shop-tabs{display:flex;background:var(--color-paper, var(--bg-primary));flex-shrink:0;border-bottom:1px solid var(--color-hairline, var(--border-color))}.shop-tab{flex:1;padding:9px 4px;background:none!important;border:none!important;border-bottom:2px solid transparent!important;border-radius:0!important;color:var(--color-ink-3, var(--text-secondary));font-size:11px;font-weight:700;cursor:pointer;box-shadow:none!important;min-height:0;transition:color .15s ease,border-color .15s ease;text-align:center}.shop-tab.active{color:var(--color-coral, var(--color-primary));border-bottom-color:var(--color-coral, var(--color-primary))!important}.shop-tab:hover:not(.active){color:var(--color-ink, var(--text-primary));transform:none!important}.shop-body{overflow-y:auto;flex:1;padding:12px 14px 14px;-webkit-overflow-scrolling:touch}.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.shop-grid.titles-grid{grid-template-columns:repeat(2,1fr)}.shop-item{background:var(--color-surface, var(--bg-primary));border:1px solid var(--color-hairline, var(--border-color));border-radius:12px;padding:8px 6px 6px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease;position:relative;min-height:0}.shop-item:hover{border-color:color-mix(in srgb,var(--color-coral, #ff7e6b) 40%,var(--color-hairline));transform:none;box-shadow:0 2px 8px #3c28140f}.shop-item.owned{border-color:color-mix(in srgb,var(--color-mint, #00cec9) 35%,var(--color-hairline));background:color-mix(in srgb,var(--color-mint, #00cec9) 6%,var(--color-surface))}.shop-item.equipped{border-color:var(--color-coral, var(--color-primary));background:color-mix(in srgb,var(--color-coral, #ff7e6b) 8%,var(--color-surface));box-shadow:0 0 0 1px color-mix(in srgb,var(--color-coral) 25%,transparent)}.shop-item.cant-afford{opacity:.52}.shop-item-emoji{font-size:26px;line-height:1}.shop-item-color{width:28px;height:28px;border-radius:50%;border:2px solid rgba(60,40,20,.08)}.shop-item-name{font-size:10px;font-weight:600;color:var(--color-ink-2, var(--text-secondary));text-align:center;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shop-item-price{font-size:10px;font-weight:700;color:#9a7b20;display:flex;align-items:center;gap:2px;line-height:1}.shop-item-price.gems{color:var(--color-sky, var(--color-secondary))}.shop-item-badge{position:absolute;top:4px;right:4px;font-size:8px;padding:2px 5px;border-radius:6px;font-weight:700;line-height:1;z-index:1}.badge-owned{background:var(--color-mint, var(--color-secondary));color:#1a3d38}.badge-equip{background:var(--color-coral, var(--color-primary));color:#fff}.shop-item-actions{display:flex;flex-direction:column;gap:3px;width:100%;margin-top:2px}.shop-item-action{width:100%;margin:0;padding:5px 6px!important;min-height:0!important;border-radius:999px!important;border:1px solid transparent!important;font-family:var(--font-mono)!important;font-size:8px!important;font-weight:700!important;letter-spacing:.04em;text-transform:uppercase;line-height:1.15!important;cursor:pointer;box-shadow:none!important;transition:background .12s ease,color .12s ease,border-color .12s ease!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shop-item-action:hover{transform:none!important}.shop-item-action.action-buy{background:var(--color-coral, var(--color-primary))!important;color:#fff!important;border-color:color-mix(in srgb,var(--color-coral) 80%,#000)!important;box-shadow:0 2px color-mix(in srgb,var(--color-coral) 55%,#8a3020)!important}.shop-item-action.action-buy:hover{filter:brightness(1.05);box-shadow:0 2px color-mix(in srgb,var(--color-coral) 55%,#8a3020)!important}.shop-item-action.action-equip{background:var(--color-paper, #fff)!important;color:var(--color-ink, #2a2018)!important;border-color:var(--color-hairline)!important}.shop-item-action.action-equip:hover{background:var(--color-surface-alt, #f5f0e8)!important}.shop-item-action.action-equipped{background:color-mix(in srgb,var(--color-coral, #ff7e6b) 12%,var(--color-paper))!important;color:var(--color-coral, var(--color-primary))!important;border-color:color-mix(in srgb,var(--color-coral) 25%,var(--color-hairline))!important;cursor:default;pointer-events:none}.shop-item-action.action-sell{padding:4px 5px!important;font-size:7px!important;letter-spacing:.02em;background:transparent!important;color:var(--color-ink-3)!important;border:1px dashed var(--color-hairline)!important;box-shadow:none!important}.shop-item-action.action-sell:hover{background:#3c28140a!important;color:var(--color-ink-2)!important}.shop-toast{position:absolute;bottom:14px;left:50%;transform:translate(-50%) translateY(60px);background:var(--color-ink, #2a2018);color:#fff;padding:7px 14px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap;transition:transform .3s ease;pointer-events:none;z-index:10}.shop-toast.visible{transform:translate(-50%) translateY(0)}@media (max-width: 480px){#shop-modal{top:auto;left:0;right:0;bottom:0;transform:none;width:100%;max-height:85vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.shop-grid{gap:7px}}.pat-ring-preview,.pat-ring-marker{display:inline-block;flex-shrink:0;border-radius:50%;box-sizing:border-box;border:2.5px solid #fffdfa;background:transparent;box-shadow:0 0 0 1.5px var(--pat-primary),0 0 8px color-mix(in srgb,var(--pat-primary) 50%,transparent)}.pat-pulse--tremble{animation:pat-tremble .45s ease-in-out infinite}.pat-pulse--wave{animation:pat-wave 4s ease-in-out infinite}.pat-pulse--double{animation:pat-double 2.8s ease-in-out infinite}.pat-pulse--twilight{animation:pat-twilight 10s ease-in-out infinite}.pat-pulse--jitter{animation:pat-jitter .35s steps(2) infinite}@keyframes pat-tremble{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.06);opacity:.88}}@keyframes pat-wave{0%,to{box-shadow:0 0 0 1.5px var(--pat-primary),0 0 6px color-mix(in srgb,var(--pat-primary) 40%,transparent)}50%{box-shadow:0 0 0 3px var(--pat-primary),0 0 12px color-mix(in srgb,var(--pat-primary) 65%,transparent)}}@keyframes pat-double{0%,to{box-shadow:0 0 0 1.5px var(--pat-primary),0 0 0 5px color-mix(in srgb,var(--pat-primary) 35%,transparent)}50%{box-shadow:0 0 0 2.5px var(--pat-primary),0 0 0 7px color-mix(in srgb,var(--pat-primary) 55%,transparent)}}@keyframes pat-twilight{0%,to{opacity:1;filter:brightness(1)}50%{opacity:.35;filter:brightness(.85)}}@keyframes pat-jitter{0%{transform:translate(0) rotate(0)}25%{transform:translate(1px,-1px) rotate(1deg)}50%{transform:translate(-1px,1px) rotate(-1deg)}75%{transform:translate(1px,1px) rotate(.5deg)}}.shop-patterns-intro,.shop-patterns-phase{margin:0 0 10px;padding:8px 10px;border-radius:var(--radius-md, 12px);background:color-mix(in srgb,var(--color-primary) 8%,var(--bg-secondary));border:1px solid var(--border-color);font-size:11px;line-height:1.35;color:var(--text-secondary)}.shop-patterns-phase{margin-top:-4px;font-family:var(--font-mono);font-size:10px;letter-spacing:.03em}.shop-item-preview--ring{display:flex;align-items:center;justify-content:center;width:32px;height:32px;line-height:0}.shop-item-preview--ring .pat-ring-preview{width:32px!important;height:32px!important}.theme-picker-row--patterns{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(132px,1fr))!important;gap:8px!important;align-items:stretch!important;padding:2px 0 0!important}.theme-picker-row--patterns .balloon-frame-card{width:100%;min-width:0}.theme-picker-row--patterns .theme-swatch-wrap{position:relative;padding:0!important;border-radius:12px!important;background:transparent!important;box-shadow:none!important}.theme-picker-row--patterns .balloon-frame-card__btn.theme-swatch{width:100%!important;height:44px!important;min-height:44px!important;padding:6px 8px!important;border-radius:12px!important;border:1px solid var(--color-hairline)!important;background:var(--color-surface)!important;box-shadow:var(--shadow-paper-sm)!important;display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:flex-start!important;gap:8px!important;overflow:hidden!important;transform:none!important}.theme-picker-row--patterns .balloon-frame-card__btn.theme-swatch:hover{border-color:#ff7e6b61!important;box-shadow:0 3px #3c281414!important;transform:translateY(-1px)!important}.theme-picker-row--patterns .balloon-frame-card.swatch-equipped .balloon-frame-card__btn.theme-swatch{border-color:#ff7e6bb8!important;box-shadow:0 0 0 2px #ff7e6b29,var(--shadow-paper-sm)!important}.theme-picker-row--patterns .balloon-frame-card.swatch-cant-afford .balloon-frame-card__btn.theme-swatch{opacity:.58}.theme-picker-row--patterns .pat-ring-slot{display:flex!important;flex:0 0 22px!important;width:22px!important;height:22px!important;min-width:22px!important;min-height:22px!important;padding:0!important;margin:0!important;border:none!important;border-radius:50%!important;background:transparent!important;box-shadow:none!important;align-items:center!important;justify-content:center!important;overflow:visible!important}.theme-picker-row--patterns .pat-ring-slot .pat-ring-preview{width:20px!important;height:20px!important;border-width:2px}.theme-picker-row--patterns .balloon-frame-card__meta{display:flex;flex:1 1 auto;min-width:0;flex-direction:column;align-items:flex-start;gap:3px}.theme-picker-row--patterns .balloon-frame-card__name{width:100%;min-width:0;color:var(--color-ink)!important;font-family:var(--font-body)!important;font-size:11px!important;font-weight:700!important;line-height:1.15!important;text-align:left!important}.theme-picker-row--patterns .swatch-lbl{position:static!important;min-height:10px;font-family:var(--font-mono)!important;font-size:8.5px!important;line-height:1!important;letter-spacing:.08em;text-transform:uppercase;text-shadow:none!important}.theme-picker-row--patterns .swatch-lbl--on{color:var(--color-coral)!important}.theme-picker-row--patterns .swatch-lbl--owned{color:var(--color-ink-3)!important}.theme-picker-row--patterns .swatch-lbl--price{color:var(--color-ink-2)!important}.theme-picker-row--patterns .swatch-check{position:absolute!important;top:50%!important;right:8px!important;transform:translateY(-50%)!important;color:var(--color-coral)!important;font-size:12px!important;text-shadow:none!important}@media (max-width: 420px){.theme-picker-row--patterns{grid-template-columns:repeat(2,minmax(0,1fr))!important}}.balloon-dot-marker.pat-dot-ring{--pat-icon-size: 12px;background:var(--cat-primary, #7fb5d6)!important;border:2px solid var(--pat-primary)!important;box-shadow:0 0 7px color-mix(in srgb,var(--pat-primary) 45%,transparent)!important}.balloon-dot-marker.pat-map-pulse--jitter{animation:pat-map-jump 2.6s cubic-bezier(.42,0,.58,1) infinite}.balloon-marker,.leaflet-div-icon.balloon-marker,.balloon-marker .balloon-wrapper,.balloon-marker .balloon-visual-wrap,.balloon-marker .balloon-pattern-shell,.balloon-marker .balloon-ring-stack{overflow:visible!important}.balloon-pattern-shell{position:relative;display:flex;flex-direction:column;align-items:center;transform-origin:center bottom}.balloon-pattern-shell[class*=pat-ring--]{transition:transform .2s ease}.balloon-head,.balloon-ring-stack{position:relative;display:flex;align-items:center;justify-content:center;line-height:0;border-radius:50%;transform-origin:center center}.balloon-head--standard{filter:drop-shadow(0 2px 6px rgba(40,20,10,.1))}.balloon-head--pattern{filter:drop-shadow(0 2px 6px rgba(40,20,10,.12))}.balloon-glow-svg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:visible}.balloon-head .balloon-cat-ring,.balloon-ring-stack .balloon-cat-ring{position:relative;z-index:1;flex-shrink:0}.balloon-head-standard{position:relative;display:inline-block;line-height:0;border-radius:50%}.balloon-tail-svg{display:block;overflow:visible;flex-shrink:0;position:relative;z-index:6}.balloon-cat-ring{border-radius:50%;padding:var(--cat-ring-w, 2px);background:var(--cat-primary);box-shadow:0 0 0 .5px #fffdfa8c}.balloon-cat-ring .balloon-icon,.balloon-ring-stack .balloon-icon{display:block;box-sizing:border-box;width:var(--pat-icon-size, 48px);height:var(--pat-icon-size, 48px);margin:0;padding:0;border:none;border-radius:50%;overflow:hidden;position:relative;box-shadow:inset 0 0 0 1.5px #fffdfa;filter:none!important;background-color:var(--color-surface, #fefaf0)}.balloon-cat-ring .balloon-icon img,.balloon-ring-stack .balloon-icon img{border-radius:50%}.balloon-icon--patterned{filter:none!important}.balloon-dot-marker.pat-dot-ring.pat-map-pulse--jitter,.balloon-dot-marker.pat-dot-ring.pat-map-pulse--tremble,.balloon-ring-stack[class*=pat-map-pulse--],.balloon-ring-stack[class*=pat-map-pulse--] .balloon-glow-svg{transform-origin:center center}@keyframes pat-map-jump{0%,to{transform:translateY(0)}45%{transform:translateY(calc(var(--pat-icon-size, 48px) * -.05))}65%{transform:translateY(calc(var(--pat-icon-size, 48px) * -.02))}80%{transform:translateY(calc(var(--pat-icon-size, 48px) * -.035))}}@keyframes pat-map-jitter-glow{0%,to{opacity:.82}50%{opacity:.98}}.pat-map-pulse--jitter.balloon-ring-stack,.pat-map-pulse--jitter.balloon-dot-marker{animation:pat-map-jump 2.6s cubic-bezier(.42,0,.58,1) infinite}.pat-map-pulse--jitter.balloon-ring-stack .balloon-glow-svg{animation:pat-map-jitter-glow 2.6s ease-in-out infinite}@keyframes pat-map-tremble{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.pat-map-pulse--tremble.balloon-ring-stack,.pat-map-pulse--tremble.balloon-dot-marker{animation:pat-map-tremble 2.2s ease-in-out infinite}@keyframes pat-map-wave-glow{0%,to{opacity:.84;transform:scale(.98)}50%{opacity:.96;transform:scale(1.04)}}.pat-map-pulse--wave.balloon-ring-stack .balloon-glow-svg{animation:pat-map-wave-glow 4.5s ease-in-out infinite}@keyframes pat-map-double-glow{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.92}}.pat-map-pulse--double.balloon-ring-stack .balloon-glow-svg{animation:pat-map-double-glow 3.8s ease-in-out infinite}@keyframes pat-map-twilight{0%,to{opacity:1;filter:brightness(1)}50%{opacity:.62;filter:brightness(.88)}}.pat-map-pulse--twilight.balloon-ring-stack,.pat-map-pulse--twilight.balloon-dot-marker,.pat-map-pulse--twilight.balloon-ring-stack .balloon-glow-svg{animation:pat-map-twilight 10s ease-in-out infinite}@media (prefers-reduced-motion: reduce){.pat-map-pulse--jitter.balloon-ring-stack,.pat-map-pulse--jitter.balloon-dot-marker,.pat-map-pulse--jitter.balloon-ring-stack .balloon-glow-svg,.pat-map-pulse--tremble.balloon-ring-stack,.pat-map-pulse--tremble.balloon-dot-marker,.pat-map-pulse--twilight.balloon-ring-stack,.pat-map-pulse--twilight.balloon-dot-marker,.pat-map-pulse--twilight.balloon-ring-stack .balloon-glow-svg,.pat-map-pulse--wave.balloon-ring-stack .balloon-glow-svg,.pat-map-pulse--double.balloon-ring-stack .balloon-glow-svg{animation:none!important}}#balloon-form[aria-hidden=false]{display:flex!important;flex-direction:column;overflow:hidden!important;background:var(--color-paper)!important;border:1px solid var(--color-hairline);box-shadow:0 8px #3c28140f,0 20px 50px #3c28142e}#add-balloon-form{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;overflow:hidden;background:var(--color-paper)}.balloon-form-scroll{flex:1 1 auto;min-height:0;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;background:var(--color-paper)}.balloon-form-scroll::-webkit-scrollbar{display:none;width:0;height:0}.balloon-form-header{flex-shrink:0;flex-direction:column;align-items:stretch;gap:0;padding:8px 20px 12px;background:var(--color-paper);border-bottom:1px solid var(--color-hairline)}.balloon-form-header-main{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%}#balloon-form .sheet-handle{width:40px;height:4px;margin:0 auto 8px;padding:0;flex-shrink:0;align-self:center;background:#3c281424!important;border-radius:999px}@media (max-width: 520px){#balloon-form:after{display:none!important;content:none!important}}.balloon-form-scroll .image-upload-zone{background:var(--color-surface)!important;margin:14px 16px 12px;border-color:#3c281424!important}.balloon-form-scroll .image-upload-zone:hover,.balloon-form-scroll .image-upload-zone.has-image{background:var(--color-surface)!important}.balloon-form-scroll .form-section{padding:10px 16px 12px!important;background:transparent}.balloon-form-scroll .form-section+.form-section{border-top:1px solid rgba(60,40,20,.06);padding-top:12px!important}.balloon-form-scroll .form-section-label{margin-bottom:6px!important;color:var(--color-coral)!important}.form-callout{margin:0 0 10px;padding:8px 10px;border-radius:12px;font-family:var(--font-body);font-size:12px;line-height:1.4;color:var(--color-ink-2);background:color-mix(in srgb,var(--color-coral) 6%,var(--color-surface));border:1px solid rgba(60,40,20,.08)}.form-callout--muted{background:var(--color-surface);border-color:var(--color-hairline);color:var(--color-ink-3);font-size:11px}.form-section-desc{margin:0 0 8px;font-size:11px;line-height:1.35;color:var(--color-ink-3);font-family:var(--font-body)}.form-section--description textarea#description{margin-bottom:4px}.balloon-desc-counter{margin:0 0 8px;font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--color-ink-3);text-align:right}.balloon-desc-counter.is-near-limit{color:var(--color-coral);font-weight:700}.image-change-rules{display:block;margin-top:6px;font-size:10px;line-height:1.35;color:var(--color-ink-3);font-family:var(--font-body);max-width:100%}.form-section--rings .theme-picker-row--patterns{margin-top:2px}.theme-picker-row--patterns .balloon-frame-card__meta{gap:2px!important}.theme-picker-row--patterns .balloon-frame-card__name{white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;font-size:11px!important;line-height:1.15!important}.theme-picker-row--patterns .balloon-frame-card__sub{display:block;font-family:var(--font-mono);font-size:8px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--color-ink-3);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#balloon-form .form-submit-row{flex-shrink:0;margin:0;background:var(--color-paper)!important;border-top:1px solid var(--color-hairline);box-shadow:0 -4px 16px #3c28140a}@media (max-width: 520px){#balloon-form[aria-hidden=false]{max-height:92vh!important}}.form-section--pattern-journal{margin-top:4px;padding-top:4px;border-top:1px dashed var(--color-hairline)}.pattern-journal-chart{position:relative;padding:10px 12px 6px;border-radius:var(--radius-md, 12px);background:color-mix(in srgb,var(--color-primary, #6b9fd4) 6%,var(--color-surface));border:1px solid var(--color-hairline);min-height:108px}.pattern-journal-chart--loading{display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--color-ink-3);font-family:var(--font-mono)}.pattern-journal-chart__svg{display:block;width:100%;height:auto;max-height:120px}.pattern-journal-chart__grid{stroke:#3c281414;stroke-width:1;stroke-dasharray:3 4}.pattern-journal-chart__label,.pattern-journal-chart__ylabel{font-family:var(--font-mono);font-size:8px;fill:var(--color-ink-3);letter-spacing:.02em}.pattern-journal-chart__empty{margin:0;font-size:11px;line-height:1.35;color:var(--color-ink-3);text-align:center}.pattern-journal-chart__foot{margin:6px 0 0;font-family:var(--font-mono);font-size:9px;letter-spacing:.04em;text-transform:uppercase;color:var(--color-ink-3);text-align:center}#intro-onboarding-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10060;display:flex;align-items:stretch;justify-content:center;background:radial-gradient(circle at 50% 8%,rgba(255,255,255,.7),transparent 34%),linear-gradient(180deg,#85c5e338,#ff7e6b2e),var(--color-paper, #f1e8d5);font-family:var(--font-body, "Geist", system-ui, sans-serif);color:var(--color-ink, #2a2018);overflow:hidden}.intro-onboarding-shell{position:relative;width:min(100vw,520px);min-height:100%;padding:max(42px,env(safe-area-inset-top,0px)) 24px max(28px,env(safe-area-inset-bottom,0px));display:grid;grid-template-rows:minmax(250px,.95fr) auto auto;gap:22px;box-sizing:border-box}.intro-skip{position:absolute;top:max(18px,env(safe-area-inset-top,0px));right:18px;z-index:2;padding:8px 10px;border:0;background:transparent;color:var(--color-ink-2, #5b4a38);font-family:var(--font-mono, "Geist Mono", monospace);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer}.intro-illustration{display:flex;align-items:center;justify-content:center;min-height:250px;padding-top:30px}.intro-balloon-scene{position:relative;width:min(320px,calc(100vw - 56px));height:270px;display:flex;align-items:center;justify-content:center}.intro-balloon-scene--solo,.intro-balloon-scene--scale{gap:24px}.intro-balloon{position:relative;border-radius:50% 50% 46% 46%;background:radial-gradient(circle at 34% 24%,rgba(255,255,255,.85) 0 10%,transparent 11%),linear-gradient(145deg,#ffffff29,#2a201814),var(--intro-balloon-color, #ff7e6b);box-shadow:inset -10px -16px 26px #2a20181f,0 18px 32px #3c28142e;animation:intro-float 3s ease-in-out infinite}.intro-balloon:after{content:"";position:absolute;left:50%;bottom:-11px;width:18px;height:18px;transform:translate(-50%) rotate(45deg);background:inherit;border-radius:4px}.intro-balloon--lg{width:148px;height:170px}.intro-balloon--md{width:124px;height:142px}.intro-balloon--sm{width:64px;height:74px;opacity:.72}.intro-tone-coral{--intro-balloon-color: var(--color-coral, #ff7e6b)}.intro-tone-sage{--intro-balloon-color: var(--color-sage, #89b783)}.intro-tone-sky{--intro-balloon-color: var(--color-sky, #85c5e3)}@keyframes intro-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.intro-callout,.intro-stat,.intro-vote-panel{background:var(--color-surface, #fefaf0);border:1px solid var(--color-hairline, rgba(60, 40, 20, .1));box-shadow:0 4px #3c281414,0 12px 26px #3c28141f}.intro-callout{position:absolute;padding:7px 12px;border-radius:999px;font-family:var(--font-mono, "Geist Mono", monospace);font-size:11px;font-weight:700;color:var(--color-ink, #2a2018)}.intro-callout--top{top:18px;left:22px}.intro-callout--bottom{right:20px;bottom:24px}.intro-vote-panel{position:absolute;left:50%;bottom:14px;transform:translate(-50%);display:grid;grid-template-columns:52px minmax(70px,1fr) 52px;align-items:center;width:min(240px,calc(100vw - 72px));padding:10px;border-radius:18px;gap:8px}.intro-vote-btn{display:grid;place-items:center;height:52px;border-radius:16px;background:var(--color-paper-light, #f8f1df);font-family:var(--font-display, "Fraunces", Georgia, serif);font-size:30px;font-weight:600;color:var(--color-ink, #2a2018)}.intro-vote-score{text-align:center;font-family:var(--font-display, "Fraunces", Georgia, serif);font-size:34px;font-weight:600;color:var(--color-ink, #2a2018)}.intro-scale-line{width:58px;height:2px;background:var(--color-ink-3, #8a7560);position:relative;opacity:.8}.intro-scale-line:after{content:"";position:absolute;top:-5px;right:-2px;width:11px;height:11px;border-top:2px solid var(--color-ink-3, #8a7560);border-right:2px solid var(--color-ink-3, #8a7560);transform:rotate(45deg)}.intro-copy{text-align:center;align-self:end}.intro-eyebrow{font-family:var(--font-mono, "Geist Mono", monospace);font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--color-coral, #ff7e6b)}.intro-title{margin:12px 0 10px;font-family:var(--font-display, "Fraunces", Georgia, serif);font-size:clamp(34px,8vw,48px);font-weight:500;line-height:1.02;color:var(--color-ink, #2a2018)}.intro-body{max-width:430px;margin:0 auto;font-size:15px;line-height:1.55;color:var(--color-ink-2, #5b4a38)}.intro-stat{display:inline-flex;margin-top:18px;padding:9px 14px;border-radius:999px;font-family:var(--font-mono, "Geist Mono", monospace);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-ink, #2a2018)}.intro-footer{display:grid;grid-template-columns:1fr auto 1.4fr;align-items:center;gap:12px}.intro-back,.intro-next{min-height:52px;border-radius:16px;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer}.intro-back{border:1px solid var(--color-hairline, rgba(60, 40, 20, .1));background:var(--color-surface, #fefaf0);color:var(--color-ink, #2a2018);box-shadow:0 3px #3c281414}.intro-back:disabled{opacity:0;pointer-events:none}.intro-next{border:0;background:var(--color-ink, #2a2018);color:#fff;box-shadow:0 4px #0c0805}.intro-dots{display:flex;align-items:center;justify-content:center;gap:8px}.intro-dot{width:8px;height:8px;border-radius:999px;background:#3c28142e;transition:width .2s ease,background .2s ease}.intro-dot--active{width:28px;background:var(--color-coral, #ff7e6b)}@media (max-width: 420px){.intro-onboarding-shell{padding-left:20px;padding-right:20px;grid-template-rows:minmax(230px,.9fr) auto auto;gap:18px}.intro-illustration{min-height:230px}.intro-footer{grid-template-columns:1fr 1.35fr}.intro-dots{grid-column:1 / -1;grid-row:1}.intro-back,.intro-next{grid-row:2}}.help-onboarding-anchor{position:fixed;bottom:calc(110px + env(safe-area-inset-bottom,0px));left:max(16px,env(safe-area-inset-left,0px));z-index:1600}.help-onboarding-btn{width:44px!important;height:44px!important;font-family:var(--font-display, "Fraunces", Georgia, serif)!important;font-size:20px!important;font-weight:500!important;line-height:1!important;border-radius:50%!important;background:var(--color-surface, #fefaf0)!important;color:var(--color-ink-2, #5b4a38)!important;border:1px solid var(--color-hairline, rgba(60, 40, 20, .1))!important;box-shadow:0 3px #3c281414,0 0 0 1px #3c28140f!important}.help-onboarding-popover{position:absolute;bottom:calc(100% + 10px);left:0;width:min(300px,calc(100vw - 32px));padding:14px 14px 12px;border-radius:18px;background:var(--color-surface, #fefaf0);border:1px solid var(--color-hairline, rgba(60, 40, 20, .1));box-shadow:0 6px #3c28140f,0 14px 32px #3c281426,0 0 0 1px #3c28140f;color:var(--color-ink, #2a2018);opacity:0;transform:translateY(6px);pointer-events:none;transition:opacity .2s ease,transform .2s ease}.help-onboarding-popover--open{opacity:1;transform:translateY(0);pointer-events:auto}.help-onboarding-popover-title{margin:0 0 6px;font-family:var(--font-display, "Fraunces", Georgia, serif);font-size:18px;font-weight:500;letter-spacing:-.01em;color:var(--color-ink, #2a2018)}.help-onboarding-popover-hint{margin:0 0 12px;font-size:12.5px;line-height:1.45;color:var(--color-ink-2, #5b4a38)}.help-onboarding-popover-action{display:flex;flex-direction:column;gap:2px;width:100%;margin-bottom:8px;padding:10px 14px;text-align:left;font-family:inherit;color:var(--color-ink, #2a2018);background:var(--color-paper-light, #f8f1df);border:1px solid var(--color-hairline, rgba(60, 40, 20, .1));border-radius:12px;cursor:pointer;box-shadow:0 2px #3c28140f;transition:transform .1s ease,background .15s ease}.help-onboarding-popover-action:last-child{margin-bottom:0}.help-onboarding-popover-action:hover:not(:disabled){background:var(--color-surface-alt, #fbf3e2);transform:translate(2px)}.help-onboarding-popover-action:disabled{opacity:.42;cursor:not-allowed}.help-popover-action-main{font-size:13px;font-weight:700;line-height:1.3;color:var(--color-ink, #2a2018)}.help-popover-action-sub{font-size:11px;font-weight:400;line-height:1.3;color:var(--color-ink-2, #5b4a38);opacity:.78}@media (max-width: 420px){.help-onboarding-anchor{bottom:calc(110px + env(safe-area-inset-bottom,0px));left:max(12px,env(safe-area-inset-left,0px))}}#onboarding-coach-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10050;font-family:var(--font-body, "Geist", system-ui, sans-serif);pointer-events:none}body.onboarding-active{overflow:hidden;touch-action:none}.onboarding-shades{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:auto}.onboarding-shade{position:absolute;background:#1c140c8c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);pointer-events:auto}.onboarding-spotlight-ring{position:absolute;border-radius:22px;border:2px solid var(--color-coral, #ff7e6b);box-shadow:0 0 0 4px #ffffff8c,0 0 0 5px #ff7e6b4d,0 8px 22px #ff7e6b38;pointer-events:none;animation:onboarding-pulse 2.4s ease-in-out infinite;z-index:1}@keyframes onboarding-pulse{0%,to{box-shadow:0 0 0 4px #ffffff8c,0 0 0 5px #ff7e6b4d,0 8px 22px #ff7e6b38}50%{box-shadow:0 0 0 4px #ffffff8c,0 0 0 8px #ff7e6b66,0 10px 28px #ff7e6b52}}.onboarding-tooltip{position:absolute;z-index:2;max-width:min(360px,calc(100vw - 32px));padding:18px 18px 14px;border-radius:22px;background:var(--color-surface, #fefaf0);border:1px solid var(--color-hairline, rgba(60, 40, 20, .1));box-shadow:0 6px #3c28140f,0 16px 36px #3c28142e,0 0 0 1px #3c28140f;color:var(--color-ink, #2a2018);pointer-events:auto}.onboarding-tooltip-step{font-family:var(--font-mono, "Geist Mono", monospace);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--color-coral, #ff7e6b);margin-bottom:6px}.onboarding-tooltip-title{font-family:var(--font-display, "Fraunces", Georgia, serif);font-size:22px;font-weight:500;letter-spacing:-.01em;margin:0 0 10px;line-height:1.15;color:var(--color-ink, #2a2018)}.onboarding-tooltip-body{margin:0 0 16px;font-size:14px;line-height:1.5;color:var(--color-ink-2, #5b4a38)}.onboarding-tooltip-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:flex-end}.onboarding-btn-primary{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;border-radius:14px;padding:12px 18px;font-family:inherit;font-size:14px;font-weight:600;letter-spacing:-.01em;cursor:pointer;background:var(--color-ink, #2a2018);color:#fff;box-shadow:0 4px #0c0805,inset 0 1px #ffffff1a;transition:transform .1s ease,box-shadow .15s ease}.onboarding-btn-primary:hover{transform:translateY(-1px)}.onboarding-btn-primary:active{transform:translateY(2px);box-shadow:0 2px #0c0805,inset 0 1px #ffffff1a}.onboarding-btn-ghost{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--color-hairline, rgba(60, 40, 20, .1));border-radius:14px;padding:11px 16px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;background:var(--color-paper-light, #f8f1df);color:var(--color-ink, #2a2018);box-shadow:0 2px #3c28140f}.onboarding-btn-ghost:hover{background:var(--color-surface-alt, #fbf3e2)}.onboarding-btn-ghost:active{transform:translateY(1px);box-shadow:0 1px #3c28140f}.onboarding-skip{margin-right:auto;font-family:var(--font-mono, "Geist Mono", monospace);font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-ink-3, #8a7560);background:none;border:none;cursor:pointer;padding:8px 4px}.onboarding-skip:hover{color:var(--color-ink-2, #5b4a38)}
