@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--green-50:#f0fdf4;--green-100:#dcfce7;--green-200:#bbf7d0;--green-400:#4ade80;--green-500:#22c55e;--green-600:#16a34a;--green-700:#15803d;--emerald-400:#34d399;--emerald-500:#10b981;--emerald-600:#059669;--teal-400:#2dd4bf;--teal-500:#14b8a6;--orange-400:#fb923c;--orange-500:#f97316;--purple-400:#a78bfa;--purple-500:#8b5cf6;--purple-600:#7c3aed;--pink-400:#f472b6;--pink-500:#ec4899;--yellow-400:#facc15;--yellow-500:#eab308;--red-400:#f87171;--red-500:#ef4444;--bg-base:#0a0f1e;--bg-surface:#111827;--bg-card:#1a2236;--bg-input:#1e2d45;--bg-hover:#243352;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-accent:#34d399;--border-subtle:#ffffff12;--border-active:#34d3994d;--brand:#34d399;--brand-dark:#059669;--brand-light:#6ee7b7;--brand-glow:#34d39926;--gradient-brand:linear-gradient(135deg, #34d399 0%, #10b981 50%, #059669 100%);--gradient-hero:linear-gradient(135deg, #0a0f1e 0%, #0d1f35 50%, #0a0f1e 100%);--gradient-card:linear-gradient(145deg, #1a2236, #111827);--gradient-purple:linear-gradient(135deg, #7c3aed, #6d28d9);--gradient-orange:linear-gradient(135deg, #f97316, #ea580c);--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--sp-12:48px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-2xl:24px;--r-full:9999px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--shadow-brand:0 4px 20px #34d39933;--shadow-glow:0 0 30px #34d39926;--tr-fast:.15s ease;--tr-normal:.25s ease;--tr-slow:.4s ease;--bottom-nav-h:72px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;height:100%;font-size:16px}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100%;font-family:Inter,system-ui,-apple-system,sans-serif;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,textarea,select{outline:none;font-family:inherit}img{max-width:100%;display:block}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:var(--r-full)}.app-layout{flex-direction:column;max-width:480px;min-height:100vh;margin:0 auto;display:flex;position:relative}.page{padding-bottom:calc(var(--bottom-nav-h) + 16px);flex:1;overflow-y:auto}.page-header{z-index:50;-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);padding:var(--sp-4) var(--sp-5);justify-content:space-between;align-items:center;gap:var(--sp-3);background:#0a0f1ee6;display:flex;position:sticky;top:0}.page-title{color:var(--text-primary);align-items:center;gap:var(--sp-2);font-family:Outfit,sans-serif;font-size:1.25rem;font-weight:700;display:flex}.page-content{padding:var(--sp-4) var(--sp-5)}.bottom-nav{width:100%;max-width:480px;height:var(--bottom-nav-h);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-subtle);z-index:100;padding:0 var(--sp-2);background:#111827f2;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{padding:var(--sp-2) var(--sp-3);border-radius:var(--r-md);color:var(--text-muted);transition:all var(--tr-normal);background:0 0;flex-direction:column;flex:1;align-items:center;gap:4px;display:flex;position:relative}.nav-item.active{color:var(--brand)}.nav-item.active .nav-icon{background:var(--brand-glow);color:var(--brand)}.nav-item:hover{color:var(--text-secondary)}.nav-icon{border-radius:var(--r-md);width:36px;height:36px;transition:all var(--tr-normal);justify-content:center;align-items:center;display:flex}.nav-label{letter-spacing:.02em;font-size:.65rem;font-weight:600}.nav-badge{background:var(--brand);color:#000;border-radius:var(--r-full);justify-content:center;align-items:center;width:16px;height:16px;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:2px;right:8px}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:var(--sp-5);transition:all var(--tr-normal);position:relative;overflow:hidden}.card-glow{box-shadow:var(--shadow-brand);border-color:var(--border-active)}.card:before{content:"";background:linear-gradient(90deg,#0000,#34d3994d,#0000);height:1px;position:absolute;top:0;left:0;right:0}.btn{justify-content:center;align-items:center;gap:var(--sp-2);border-radius:var(--r-full);transition:all var(--tr-normal);white-space:nowrap;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--gradient-brand);color:#000;box-shadow:var(--shadow-brand)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #34d39959}.btn-primary:active{transform:scale(.97)}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-subtle)}.btn-secondary:hover{background:var(--bg-hover);border-color:#ffffff26}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{color:var(--red-400);background:#ef444426;border:1px solid #ef444433}.btn-danger:hover{background:#ef444440}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-icon{border-radius:var(--r-md);width:40px;height:40px;padding:0}.btn-lg{border-radius:var(--r-xl);padding:.875rem 2rem;font-size:1rem}.btn-sm{padding:.375rem .875rem;font-size:.75rem}.input{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--r-md);width:100%;padding:.75rem var(--sp-4);color:var(--text-primary);transition:all var(--tr-normal);font-size:.9rem}.input:focus{border-color:var(--border-active);background:var(--bg-hover);box-shadow:0 0 0 3px #34d3991a}.input::placeholder{color:var(--text-muted)}.label{color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase;margin-bottom:var(--sp-2);font-size:.8rem;font-weight:600;display:block}.badge{border-radius:var(--r-full);letter-spacing:.05em;align-items:center;gap:4px;padding:2px 10px;font-size:.7rem;font-weight:700;display:inline-flex}.badge-green{color:var(--emerald-400);background:#34d39926;border:1px solid #34d39933}.badge-orange{color:var(--orange-400);background:#f9731626;border:1px solid #f9731633}.badge-purple{color:var(--purple-400);background:#8b5cf626;border:1px solid #8b5cf633}.chip{align-items:center;gap:var(--sp-1);border-radius:var(--r-full);background:var(--bg-input);color:var(--text-secondary);border:1px solid var(--border-subtle);white-space:nowrap;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.avatar{border-radius:var(--r-full);border:2px solid #0000;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;display:flex;position:relative}.avatar-sm{width:32px;height:32px;font-size:.9rem}.avatar-lg{width:64px;height:64px;font-size:2rem}.divider{background:var(--border-subtle);height:1px;margin:var(--sp-4) 0}.spinner{border:2px solid #34d39933;border-top-color:var(--brand);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{justify-content:center;align-items:center;gap:var(--sp-4);flex-direction:column;min-height:100vh;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fadeIn{animation:fadeIn var(--tr-normal) both}.animate-slideUp{animation:.4s both slideUp}.animate-pulse{animation:2s infinite pulse}.animate-bounce{animation:1s infinite bounce}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.empty-state{text-align:center;padding:var(--sp-10) var(--sp-6);justify-content:center;align-items:center;gap:var(--sp-3);flex-direction:column;display:flex}.empty-icon{opacity:.4;font-size:3rem;animation:2s infinite bounce}.empty-state h3{color:var(--text-secondary);font-size:1.1rem;font-weight:700}.empty-state p{color:var(--text-muted);max-width:240px;font-size:.875rem;line-height:1.6}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000b3;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--bg-card);border-radius:var(--r-2xl) var(--r-2xl) 0 0;border-top:1px solid var(--border-subtle);width:100%;max-width:480px;padding:var(--sp-6);max-height:80vh;animation:.3s slideUp;overflow-y:auto}.modal-handle{background:var(--border-subtle);border-radius:var(--r-full);width:40px;height:4px;margin:0 auto var(--sp-5)}.modal-title{margin-bottom:var(--sp-5);text-align:center;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:700}.react-hot-toast{background:var(--bg-card)!important;color:var(--text-primary)!important;border:1px solid var(--border-subtle)!important;border-radius:var(--r-md)!important;font-size:.875rem!important}.progress-bar{background:var(--bg-input);border-radius:var(--r-full);width:100%;height:6px;overflow:hidden}.progress-fill{border-radius:var(--r-full);background:var(--gradient-brand);height:100%;transition:width var(--tr-slow)}.total-pill{z-index:40;margin:var(--sp-4) var(--sp-5);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-active);border-radius:var(--r-xl);padding:var(--sp-3) var(--sp-5);box-shadow:var(--shadow-brand);background:#1a2236f2;justify-content:space-between;align-items:center;display:flex;position:sticky;top:70px}.category-header{align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-5);background:var(--bg-surface);color:var(--text-secondary);letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--border-subtle);font-size:.8rem;font-weight:700;display:flex}.list-item-row{align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border-subtle);background:var(--bg-surface);transition:background var(--tr-fast);display:flex;position:relative}.list-item-row:active{background:var(--bg-hover)}.list-item-row.checked{opacity:.5}.list-item-row.checked .item-name{color:var(--text-muted);text-decoration:line-through}.checkbox{border-radius:var(--r-sm);border:2px solid var(--border-subtle);width:24px;height:24px;transition:all var(--tr-normal);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.checkbox.checked{background:var(--brand);border-color:var(--brand)}.chat-bubble{max-width:80%;padding:var(--sp-3) var(--sp-4);border-radius:var(--r-xl);font-size:.9rem;line-height:1.5;animation:.2s fadeIn;position:relative}.chat-bubble-mine{border-bottom-right-radius:var(--sp-1);background:linear-gradient(135deg,#34d39933,#10b98126);border:1px solid #34d39933;margin-left:auto}.chat-bubble-other{background:var(--bg-card);border:1px solid var(--border-subtle);border-bottom-left-radius:var(--sp-1)}.score-card{background:var(--gradient-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:var(--sp-5);text-align:center;position:relative;overflow:hidden}.score-value{background:var(--gradient-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Outfit,sans-serif;font-size:2.5rem;font-weight:800}.onboarding-page{min-height:100vh;padding:var(--sp-6);background:var(--gradient-hero);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.hero-emoji{margin-bottom:var(--sp-5);font-size:5rem;animation:2s infinite bounce}.hero-title{margin-bottom:var(--sp-3);background:var(--gradient-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Outfit,sans-serif;font-size:2.2rem;font-weight:800;line-height:1.2}.hero-subtitle{color:var(--text-secondary);max-width:300px;margin-bottom:var(--sp-8);font-size:1rem;line-height:1.7}.emoji-picker{gap:var(--sp-3);margin-bottom:var(--sp-5);flex-wrap:wrap;justify-content:center;display:flex}.emoji-option{background:var(--bg-card);border:2px solid var(--border-subtle);border-radius:var(--r-lg);cursor:pointer;width:52px;height:52px;transition:all var(--tr-normal);justify-content:center;align-items:center;font-size:1.5rem;display:flex}.emoji-option:hover,.emoji-option.selected{border-color:var(--brand);background:var(--brand-glow);transform:scale(1.1)}.color-picker{gap:var(--sp-3);margin-bottom:var(--sp-5);justify-content:center;display:flex}.color-dot{border-radius:var(--r-full);cursor:pointer;width:36px;height:36px;transition:all var(--tr-normal);border:3px solid #0000}.color-dot.selected{border-color:#fff;transform:scale(1.15)}.recording-dot{background:var(--red-400);border-radius:50%;width:10px;height:10px;animation:1s infinite pulse}.stat-grid{gap:var(--sp-3);grid-template-columns:1fr 1fr;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:var(--sp-4);text-align:center}.stat-value{color:var(--brand);font-family:Outfit,sans-serif;font-size:1.6rem;font-weight:800}.stat-label{color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;font-size:.72rem;font-weight:600}.achievement-card{align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-lg);animation:.3s fadeIn;display:flex}.achievement-icon{border-radius:var(--r-md);background:#34d3991a;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.4rem;display:flex}@supports (padding:env(safe-area-inset-bottom)){.bottom-nav{padding-bottom:env(safe-area-inset-bottom);height:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom))}.page{padding-bottom:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom) + 16px)}}.scanner-container{aspect-ratio:1;border-radius:var(--r-xl);background:#000;width:100%;position:relative;overflow:hidden}.scanner-frame{border:2px solid var(--brand);border-radius:var(--r-md);z-index:10;pointer-events:none;position:absolute;inset:20%}.scanner-line{background:linear-gradient(90deg, transparent, var(--brand), transparent);height:2px;animation:2s ease-in-out infinite scan;position:absolute;left:0;right:0}@keyframes scan{0%{top:20%}50%{top:80%}to{top:20%}}.generate-btn{width:100%;padding:var(--sp-5);border-radius:var(--r-xl);background:var(--gradient-brand);color:#000;justify-content:center;align-items:center;gap:var(--sp-3);box-shadow:var(--shadow-brand);transition:all var(--tr-normal);font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:700;display:flex}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #34d39959}.generate-btn:disabled{opacity:.6;cursor:not-allowed}
