.pwa-toast[data-v-fe7b281a]{position:fixed;bottom:20px;right:20px;z-index:10000;background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026;padding:16px 20px;display:flex;align-items:center;gap:16px;max-width:380px;border-left:4px solid #4f46e5;animation:slideIn-fe7b281a .3s ease-out}@keyframes slideIn-fe7b281a{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.pwa-message span[data-v-fe7b281a]{font-weight:600;font-size:14px;color:#1e293b}.pwa-message p[data-v-fe7b281a]{margin:4px 0 0;font-size:13px;color:#64748b}.pwa-buttons[data-v-fe7b281a]{display:flex;gap:8px;flex-shrink:0}.pwa-btn[data-v-fe7b281a]{border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.pwa-btn-update[data-v-fe7b281a]{background:#4f46e5;color:#fff}.pwa-btn-update[data-v-fe7b281a]:hover{background:#4338ca}.pwa-btn-close[data-v-fe7b281a]{background:#f1f5f9;color:#475569}.pwa-btn-close[data-v-fe7b281a]:hover{background:#e2e8f0}@media(max-width:480px){.pwa-toast[data-v-fe7b281a]{left:12px;right:12px;bottom:12px;max-width:none;flex-direction:column;gap:12px}.pwa-buttons[data-v-fe7b281a]{width:100%;justify-content:flex-end}}.mochi-svg[data-v-7ebcfec3]{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.mochi-tail[data-v-7ebcfec3]{animation:tailWag-7ebcfec3 2s ease-in-out infinite;transform-origin:90px 80px}@keyframes tailWag-7ebcfec3{0%,to{transform:rotate(0)}25%{transform:rotate(8deg)}75%{transform:rotate(-8deg)}}.mochi-eye-l[data-v-7ebcfec3],.mochi-eye-r[data-v-7ebcfec3]{animation:eyeBlink-7ebcfec3 4s ease-in-out infinite}@keyframes eyeBlink-7ebcfec3{0%,90%,to{ry:5.5}95%{ry:.5}}.mochi-wave[data-v-7ebcfec3]{animation:pawWave-7ebcfec3 1.5s ease-in-out infinite;transform-origin:85px 70px}@keyframes pawWave-7ebcfec3{0%,to{transform:rotate(0)}50%{transform:rotate(-20deg)}}.mochi-talking[data-v-7ebcfec3]{animation:talkBounce-7ebcfec3 .4s ease-in-out infinite alternate}@keyframes talkBounce-7ebcfec3{0%{transform:translateY(0)}to{transform:translateY(-2px)}}.mochi-float[data-v-7ebcfec3]{position:fixed;bottom:24px;right:24px;z-index:9998;cursor:pointer;transition:transform .3s}.mochi-float[data-v-7ebcfec3]:hover{transform:scale(1.1)}.mochi-float-svg[data-v-7ebcfec3]{filter:drop-shadow(0 4px 12px rgba(139,90,43,.25))}.mochi-bounce[data-v-7ebcfec3]{animation:mochiIdle-7ebcfec3 3s ease-in-out infinite}@keyframes mochiIdle-7ebcfec3{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.mochi-float-bubble[data-v-7ebcfec3]{position:absolute;bottom:72px;right:0;background:#fff;border-radius:16px;padding:8px 14px;font-size:.8rem;color:#4a3728;box-shadow:0 4px 16px #0000001f;white-space:nowrap;animation:bubblePop-7ebcfec3 .3s ease-out;font-weight:500}.mochi-bubble-tail[data-v-7ebcfec3]{position:absolute;bottom:-6px;right:20px;width:12px;height:12px;background:#fff;transform:rotate(45deg);box-shadow:2px 2px 4px #0000000d}@keyframes bubblePop-7ebcfec3{0%{opacity:0;transform:scale(.8) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.mochi-mobile-banner[data-v-7ebcfec3]{position:fixed;bottom:70px;left:12px;right:12px;z-index:9998;animation:bannerSlideUp-7ebcfec3 .5s ease-out}.mochi-banner-inner[data-v-7ebcfec3]{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#fef3c7,#fff7ed);border:1px solid #f59e0b33;border-radius:16px;padding:12px 16px;box-shadow:0 8px 32px #8b5a2b26}.mochi-banner-cat[data-v-7ebcfec3]{flex-shrink:0;cursor:pointer}.mochi-banner-text[data-v-7ebcfec3]{flex:1;display:flex;flex-direction:column;gap:2px}.mochi-banner-text strong[data-v-7ebcfec3]{font-size:.85rem;color:#78350f}.mochi-banner-text span[data-v-7ebcfec3]{font-size:.75rem;color:#92400e}.mochi-banner-close[data-v-7ebcfec3]{background:none;border:none;font-size:1.1rem;color:#b45309;cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.mochi-banner-close[data-v-7ebcfec3]:hover{background:#b453091a}@keyframes bannerSlideUp-7ebcfec3{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mochi-chat[data-v-7ebcfec3]{position:fixed;bottom:24px;right:24px;z-index:9999;width:380px;height:540px;max-height:80vh;background:#fffbf5;border-radius:20px;box-shadow:0 12px 48px #78350f2e;display:flex;flex-direction:column;overflow:hidden;border:1px solid #f5deb3}.mochi-chat-mobile[data-v-7ebcfec3]{inset:0;width:100%;height:100%;max-height:100vh;border-radius:0}.mochi-chat-enter-active[data-v-7ebcfec3]{animation:chatOpen-7ebcfec3 .35s ease-out}.mochi-chat-leave-active[data-v-7ebcfec3]{animation:chatOpen-7ebcfec3 .25s ease-in reverse}@keyframes chatOpen-7ebcfec3{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.mochi-chat-header[data-v-7ebcfec3]{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(135deg,#92400e,#b45309);color:#fff}.mochi-chat-header-left[data-v-7ebcfec3]{display:flex;align-items:center;gap:10px}.mochi-chat-header-left strong[data-v-7ebcfec3]{font-size:.95rem;display:block}.mochi-status[data-v-7ebcfec3]{font-size:.72rem;opacity:.85}.mochi-header-cat[data-v-7ebcfec3]{filter:drop-shadow(0 1px 3px rgba(0,0,0,.2))}.mochi-chat-close[data-v-7ebcfec3]{background:#ffffff26;border:none;color:#fff;width:32px;height:32px;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.mochi-chat-close[data-v-7ebcfec3]:hover{background:#ffffff4d}.mochi-chat-body[data-v-7ebcfec3]{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;scroll-behavior:smooth}.mochi-chat-body[data-v-7ebcfec3]::-webkit-scrollbar{width:4px}.mochi-chat-body[data-v-7ebcfec3]::-webkit-scrollbar-thumb{background:#d4bc96;border-radius:4px}.mochi-welcome[data-v-7ebcfec3]{text-align:center;padding:12px 0}.mochi-welcome h3[data-v-7ebcfec3]{margin:12px 0 6px;color:#78350f;font-size:1.1rem}.mochi-welcome p[data-v-7ebcfec3]{color:#92400e;font-size:.82rem;line-height:1.5;margin:0 0 16px}.mochi-welcome-cat[data-v-7ebcfec3]{margin:0 auto;display:block}.mochi-suggestions[data-v-7ebcfec3]{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 8px}.mochi-suggestion-btn[data-v-7ebcfec3]{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid #f5deb3;border-radius:12px;background:#fff;cursor:pointer;font-size:.78rem;color:#78350f;transition:all .2s;text-align:left}.mochi-suggestion-btn[data-v-7ebcfec3]:hover{background:#fef3c7;border-color:#f59e0b;transform:translateY(-1px);box-shadow:0 2px 8px #f59e0b26}.mochi-sug-icon[data-v-7ebcfec3]{font-size:1.1rem}.mochi-msg[data-v-7ebcfec3]{display:flex;gap:8px;animation:msgIn-7ebcfec3 .3s ease-out}.mochi-msg-user[data-v-7ebcfec3]{flex-direction:row-reverse}.mochi-msg-avatar[data-v-7ebcfec3]{width:28px;height:28px;border-radius:50%;background:#fef3c7;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}.mochi-msg-bubble[data-v-7ebcfec3]{max-width:78%;padding:10px 14px;border-radius:16px;font-size:.82rem;line-height:1.55;word-break:break-word}.mochi-msg-bot .mochi-msg-bubble[data-v-7ebcfec3]{background:#fff;color:#3d2b1f;border:1px solid #f5deb3;border-bottom-left-radius:4px}.mochi-msg-user .mochi-msg-bubble[data-v-7ebcfec3]{background:linear-gradient(135deg,#92400e,#b45309);color:#fff;border-bottom-right-radius:4px}.mochi-msg-bubble[data-v-7ebcfec3] code{background:#78350f14;padding:1px 5px;border-radius:4px;font-size:.8rem;color:#78350f}.mochi-msg-bubble[data-v-7ebcfec3] strong{color:#78350f}.mochi-msg-user .mochi-msg-bubble[data-v-7ebcfec3] strong{color:#fde68a}.mochi-msg-user .mochi-msg-bubble[data-v-7ebcfec3] code{background:#ffffff26;color:#fde68a}@keyframes msgIn-7ebcfec3{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mochi-typing[data-v-7ebcfec3]{display:flex;gap:4px;align-items:center;padding:12px 16px}.mochi-dot[data-v-7ebcfec3]{width:7px;height:7px;border-radius:50%;background:#c4a882;animation:dotBounce-7ebcfec3 1.2s ease-in-out infinite}.mochi-dot[data-v-7ebcfec3]:nth-child(2){animation-delay:.2s}.mochi-dot[data-v-7ebcfec3]:nth-child(3){animation-delay:.4s}@keyframes dotBounce-7ebcfec3{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-6px);opacity:1}}.mochi-quick-chips[data-v-7ebcfec3]{display:flex;gap:6px;padding:8px 16px;overflow-x:auto;border-top:1px solid #f5deb3}.mochi-quick-chips[data-v-7ebcfec3]::-webkit-scrollbar{display:none}.mochi-chip[data-v-7ebcfec3]{white-space:nowrap;padding:5px 10px;border-radius:20px;border:1px solid #f5deb3;background:#fff;font-size:.7rem;color:#92400e;cursor:pointer;transition:all .2s;flex-shrink:0}.mochi-chip[data-v-7ebcfec3]:hover{background:#fef3c7;border-color:#f59e0b}.mochi-chat-input[data-v-7ebcfec3]{display:flex;gap:8px;padding:12px 16px;border-top:1px solid #f5deb3;background:#fff}.mochi-chat-input input[data-v-7ebcfec3]{flex:1;padding:10px 14px;border:1px solid #f5deb3;border-radius:24px;font-size:.82rem;outline:none;background:#fffbf5;color:#3d2b1f;transition:border-color .2s}.mochi-chat-input input[data-v-7ebcfec3]:focus{border-color:#f59e0b}.mochi-chat-input input[data-v-7ebcfec3]::placeholder{color:#c4a882}.mochi-send[data-v-7ebcfec3]{width:40px;height:40px;border-radius:50%;border:none;background:linear-gradient(135deg,#92400e,#b45309);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.mochi-send[data-v-7ebcfec3]:hover:not(:disabled){transform:scale(1.05);box-shadow:0 2px 8px #b453094d}.mochi-send[data-v-7ebcfec3]:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.mochi-chat-input[data-v-7ebcfec3]{padding-bottom:max(12px,env(safe-area-inset-bottom))}.mochi-chat-header[data-v-7ebcfec3]{padding-top:max(12px,env(safe-area-inset-top))}}:root{--primary: #4f46e5;--primary-light: #818cf8;--primary-dark: #3730a3;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--bg: #f8fafc;--bg-card: #ffffff;--text: #1e293b;--text-secondary: #64748b;--border: #e2e8f0;--radius: 12px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05);--navbar-h: 60px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}.navbar{display:flex;align-items:center;padding:0 1rem;height:var(--navbar-h);background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(226,232,240,.6);position:sticky;top:0;z-index:100;gap:.5rem}.nav-brand{display:flex;align-items:center;flex-shrink:0}.brand{display:flex;align-items:center;gap:.5rem;text-decoration:none}.brand-logo{display:flex;align-items:center;flex-shrink:0}.brand-name{font-weight:800;font-size:1.05rem;color:var(--text);letter-spacing:-.02em}.brand-accent{color:var(--primary)}.nav-links{display:flex;align-items:center;flex:1;margin-left:.75rem;overflow-x:auto;scrollbar-width:none}.nav-links::-webkit-scrollbar{display:none}.nav-links-inner{display:flex;align-items:center;gap:2px}.nl{display:flex;align-items:center;gap:.3rem;padding:.4rem .6rem;text-decoration:none;color:var(--text-secondary);border-radius:10px;font-weight:500;font-size:.82rem;transition:all .15s;white-space:nowrap;position:relative;border:none;background:none;cursor:pointer}.nl:hover{background:#f1f5f9;color:var(--text)}.nl.router-link-active{background:var(--primary);color:#fff;font-weight:600;box-shadow:0 2px 8px #4f46e540}.nl-icon{font-size:.95rem;line-height:1}.nl-party.router-link-active{background:#7c3aed;box-shadow:0 2px 8px #7c3aed4d}.nl-admin{color:var(--warning)!important}.nl-admin.router-link-active{background:#f59e0b!important;color:#fff!important;box-shadow:0 2px 8px #f59e0b4d!important}.nl-lang-btn{width:100%;font-family:inherit;font-size:1rem}.nav-group{display:flex;align-items:center;gap:2px}.nav-group-label{display:none}.nav-divider{width:1px;height:20px;background:var(--border);margin:0 .2rem;opacity:.6}.dd-menu{position:absolute;min-width:200px;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 12px 40px #0000001f,0 0 0 1px #00000008;padding:.35rem;z-index:200}.dd-item{display:flex;align-items:center;gap:.5rem;padding:.55rem .85rem;text-decoration:none;color:var(--text);border-radius:10px;font-size:.9rem;cursor:pointer;border:none;background:none;width:100%;font-weight:500;transition:background .1s}.dd-item:hover{background:#f1f5f9}.dd-danger{color:var(--danger)}.dd-danger:hover{background:#fef2f2}.dd-sep{height:1px;background:var(--border);margin:.3rem .5rem}.dd-enter-active,.dd-leave-active{transition:all .15s ease}.dd-enter-from,.dd-leave-to{opacity:0;transform:translateY(-4px) scale(.97)}.nav-actions{display:flex;align-items:center;gap:.35rem;margin-left:auto;flex-shrink:0}.nav-action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid transparent;cursor:pointer;color:var(--text-secondary);text-decoration:none;background:none;transition:all .15s;position:relative}.nav-action-btn:hover{background:#f1f5f9;color:var(--text)}.notif-dot{position:absolute;top:2px;right:2px;background:#ef4444;color:#fff;font-size:.55rem;font-weight:700;min-width:15px;height:15px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid white;line-height:1}.user-dd{position:relative;cursor:pointer}.nav-avatar{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;overflow:hidden;border:2px solid var(--border);transition:all .15s}.nav-avatar:hover{border-color:var(--primary);box-shadow:0 0 0 2px #4f46e526}.nav-avatar img{width:100%;height:100%;object-fit:cover}.dd-user{right:0;top:calc(100% + 4px);min-width:260px}.dd-user-header{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem .75rem}.dd-user-avatar{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.1rem;overflow:hidden;flex-shrink:0}.dd-user-avatar img{width:100%;height:100%;object-fit:cover}.dd-user-name{font-weight:700;font-size:.95rem}.dd-user-email{font-size:.78rem;color:var(--text-secondary)}.hamburger{display:none;background:none;border:none;cursor:pointer;width:36px;height:36px;position:relative;padding:0;border-radius:10px;transition:background .15s;flex-shrink:0}.hamburger:hover{background:#f1f5f9}.hamburger span,.hamburger span:before,.hamburger span:after{display:block;background:var(--text);height:2px;width:18px;border-radius:2px;transition:all .3s;position:absolute;left:9px}.hamburger span{top:17px}.hamburger span:before{content:"";top:-6px}.hamburger span:after{content:"";top:6px}.hamburger span.open{background:transparent}.hamburger span.open:before{top:0;transform:rotate(45deg)}.hamburger span.open:after{top:0;transform:rotate(-45deg)}.mobile-overlay{display:none}.fade-enter-active,.fade-leave-active{transition:opacity .2s ease}.fade-enter-from,.fade-leave-to{opacity:0}.desktop-only{display:flex}.mob-only,.mobile-tab-bar{display:none}.main-content{max-width:1200px;margin:0 auto;padding:2rem}.main-content.no-nav{padding-top:0}@media(max-width:900px){.hamburger{display:flex;align-items:center;justify-content:center}.brand-name{font-size:.95rem}.nav-links{position:fixed;top:var(--navbar-h);left:0;right:0;bottom:0;flex-direction:column;background:#fff;padding:.75rem;margin-left:0;overflow-y:auto;transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);z-index:90}.nav-links.open{transform:translate(0)}.nav-links-inner{flex-direction:column;align-items:stretch;gap:2px;width:100%}.nl{padding:.85rem 1rem;font-size:1rem;border-radius:12px}.nav-group{flex-direction:column;gap:2px}.nav-group-label{display:block;padding:.6rem 1rem .2rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);opacity:.7}.nav-divider{display:none}.desktop-only{display:none!important}.mob-only{display:block}.mobile-overlay{display:block;position:fixed;top:var(--navbar-h);left:0;right:0;bottom:0;background:#00000040;z-index:80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.main-content{padding:1rem;padding-bottom:calc(1rem + 70px)}.mobile-tab-bar{display:flex;position:fixed;bottom:0;left:0;right:0;height:64px;background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(226,232,240,.7);z-index:100;align-items:center;justify-content:space-around;padding:0 .25rem;padding-bottom:env(safe-area-inset-bottom,0)}.tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:var(--text-secondary);font-size:.65rem;font-weight:500;gap:2px;padding:.4rem .5rem;border-radius:10px;transition:all .15s;min-width:48px}.tab-item:hover{color:var(--text)}.tab-item.router-link-active{color:var(--primary);font-weight:700}.tab-icon{font-size:1.25rem;line-height:1}.tab-label{line-height:1}.tab-center{position:relative;margin-top:-20px}.tab-icon-center{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:1.5rem;line-height:1;box-shadow:0 4px 15px #6366f166;border:3px solid white;transition:transform .2s}.tab-center:hover .tab-icon-center{transform:scale(1.05)}.tab-center.router-link-active .tab-icon-center{box-shadow:0 4px 20px #6366f199}}@media(max-width:480px){:root{--navbar-h: 52px}.navbar{padding:0 .5rem;gap:.25rem}.nav-actions{gap:.2rem}.nav-action-btn{width:32px;height:32px}.nav-avatar{width:30px;height:30px;border-radius:8px;font-size:.75rem}.hamburger{width:32px;height:32px}.hamburger span,.hamburger span:before,.hamburger span:after{width:16px;left:8px}.hamburger span{top:15px}.brand-name{font-size:.88rem}.dd-user{right:-.5rem;min-width:240px}.main-content{padding:.75rem;padding-bottom:calc(.75rem + 70px)}.nl{padding:.75rem .85rem;font-size:.95rem}.mobile-tab-bar{height:58px}.tab-item{font-size:.6rem;padding:.3rem .35rem}.tab-icon{font-size:1.1rem}.tab-icon-center{width:46px;height:46px;font-size:1.3rem}.tab-center{margin-top:-16px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-outline:hover:not(:disabled){background:#f1f5f9}.btn-sm{padding:.4rem .8rem;font-size:.85rem}.btn-lg{padding:1rem 2rem;font-size:1.1rem}.btn-record{width:80px;height:80px;border-radius:50%;background:var(--danger);color:#fff;font-size:2rem;border:4px solid white;box-shadow:0 0 0 4px var(--danger)}.btn-record.recording{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 4px var(--danger)}50%{box-shadow:0 0 0 8px #ef444466}}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:1.5rem;box-shadow:var(--shadow)}.card-title{font-size:1.1rem;font-weight:600}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.form-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:.95rem;transition:border-color .2s;background:#fff}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.score-circle{width:100px;height:100px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;font-size:1.5rem;border:4px solid}.score-excellent{border-color:var(--success);color:var(--success)}.score-good{border-color:#3b82f6;color:#3b82f6}.score-fair{border-color:var(--warning);color:var(--warning)}.score-poor{border-color:var(--danger);color:var(--danger)}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.8rem;font-weight:600}.badge-beginner{background:#dbeafe;color:#1d4ed8}.badge-intermediate{background:#fef3c7;color:#92400e}.badge-advanced{background:#fce7f3;color:#9d174d}.text-center{text-align:center}.text-secondary{color:var(--text-secondary)}.text-danger{color:var(--danger)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.grid{display:grid;gap:1rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.alert{padding:1rem 1.25rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}@media(max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.flex.justify-between{flex-wrap:wrap;gap:.5rem}}@media(max-width:480px){.card{padding:1rem}.btn{padding:.6rem 1.2rem;font-size:.9rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.btn-record{width:65px;height:65px;font-size:1.6rem}.score-circle{width:80px;height:80px;font-size:1.25rem}h1{font-size:1.4rem!important}}.pwa-install-overlay{position:fixed;inset:0;z-index:99999;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:flex-end;justify-content:center;padding:1rem;animation:pwaFadeIn .3s ease-out}@keyframes pwaFadeIn{0%{opacity:0}to{opacity:1}}.pwa-install-card{background:#fff;border-radius:24px 24px 16px 16px;padding:2rem 1.5rem 1.5rem;max-width:420px;width:100%;text-align:center;animation:pwaSlideUp .4s ease-out;box-shadow:0 -8px 40px #0003}@keyframes pwaSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pwa-install-icon{margin-bottom:1rem}.pwa-install-icon svg{width:64px;height:64px;border-radius:16px;box-shadow:0 4px 16px #6366f14d}.pwa-install-title{font-size:1.4rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.pwa-install-desc{font-size:.9rem;color:#64748b;line-height:1.5;margin-bottom:1.5rem}.pwa-install-btn{width:100%;padding:.9rem;font-size:1.05rem;font-weight:600;border-radius:12px;margin-bottom:1rem;animation:pwaGlow 2s ease-in-out infinite}@keyframes pwaGlow{0%,to{box-shadow:0 2px 8px #4f46e54d}50%{box-shadow:0 4px 20px #4f46e580}}.pwa-ios-guide{text-align:left;margin-bottom:1rem}.pwa-ios-step{display:flex;align-items:center;gap:.6rem;padding:.6rem 0;font-size:.9rem;color:#334155;border-bottom:1px solid #f1f5f9}.pwa-ios-step:last-child{border-bottom:none}.pwa-ios-num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#4f46e5;color:#fff;font-size:.75rem;font-weight:700;flex-shrink:0}.pwa-ios-icon{display:inline-flex;color:#3b82f6;vertical-align:middle}.pwa-install-skip{background:none;border:none;color:#94a3b8;font-size:.85rem;cursor:pointer;padding:.5rem 1rem;text-decoration:underline;text-underline-offset:2px}.pwa-install-skip:hover{color:#64748b}
