.toast-container{position:fixed;top:calc(20px + env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;width:calc(100% - 32px);max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:14px;background:#fff;box-shadow:0 4px 20px #00000026;animation:toastSlideIn .4s cubic-bezier(.34,1.56,.64,1);pointer-events:auto;cursor:pointer;transition:transform .2s ease,opacity .2s ease}.toast:hover{transform:scale(1.02)}.toast:active{transform:scale(.98)}.toast-exit{animation:toastSlideOut .3s ease forwards}.toast-animated{animation:toastSlideIn .4s cubic-bezier(.34,1.56,.64,1),toastPulse .3s ease .4s}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(.95)}}@keyframes toastPulse{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}.toast-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:1px solid #10B981}.toast-success .toast-icon{color:#059669;background:#10b98133}.toast-success .toast-message{color:#065f46}.toast-error{background:linear-gradient(135deg,#fee2e2,#fecaca);border:1px solid #EF4444}.toast-error .toast-icon{color:#dc2626;background:#ef444433}.toast-error .toast-message{color:#991b1b}.toast-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #3B82F6}.toast-info .toast-icon{color:#2563eb;background:#3b82f633}.toast-info .toast-message{color:#1e40af}.toast-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #F59E0B}.toast-warning .toast-icon{color:#d97706;background:#f59e0b33}.toast-warning .toast-message{color:#92400e}.toast-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.toast-message{font-size:14px;font-weight:500;line-height:1.4;flex:1}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9998;overflow:hidden}.confetti-particle{position:absolute;top:-20px;border-radius:2px;animation:confettiFall 3s ease-out forwards}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}[data-theme=dark] .toast-success{background:linear-gradient(135deg,#064e3b,#065f46);border-color:#10b981}[data-theme=dark] .toast-success .toast-icon{background:#10b9814d;color:#34d399}[data-theme=dark] .toast-success .toast-message{color:#a7f3d0}[data-theme=dark] .toast-error{background:linear-gradient(135deg,#7f1d1d,#991b1b);border-color:#ef4444}[data-theme=dark] .toast-error .toast-icon{background:#ef44444d;color:#f87171}[data-theme=dark] .toast-error .toast-message{color:#fecaca}[data-theme=dark] .toast-info{background:linear-gradient(135deg,#1e3a8a,#1e40af);border-color:#3b82f6}[data-theme=dark] .toast-info .toast-icon{background:#3b82f64d;color:#60a5fa}[data-theme=dark] .toast-info .toast-message{color:#bfdbfe}[data-theme=dark] .toast-warning{background:linear-gradient(135deg,#78350f,#92400e);border-color:#f59e0b}[data-theme=dark] .toast-warning .toast-icon{background:#f59e0b4d;color:#fbbf24}[data-theme=dark] .toast-warning .toast-message{color:#fde68a}@media (max-width: 380px){.toast{padding:12px 14px;gap:10px}.toast-icon{width:24px;height:24px;font-size:12px}.toast-message{font-size:13px}}@media (prefers-reduced-motion: reduce){.toast,.toast-animated{animation:none}.toast-exit{animation:none;opacity:0}.confetti-particle{animation:none;display:none}}.onboarding-flow{height:100%;max-height:100%;background:var(--heiwa-cream, #FAF9F6);display:flex;flex-direction:column;overflow:hidden}.onboarding-progress{height:4px;background:var(--heiwa-sage-20, #E1EBE3);flex-shrink:0}.progress-fill{height:100%;background:linear-gradient(90deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);border-radius:0 2px 2px 0;transition:width .4s ease}.onboarding-content{flex:1;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:24px 20px;padding-bottom:calc(24px + env(safe-area-inset-bottom,20px));max-width:480px;margin:0 auto;width:100%;box-sizing:border-box}.onboarding-step{display:flex;flex-direction:column;animation:fadeIn .3s ease;flex:1;min-height:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.step-header{margin-bottom:24px;flex-shrink:0}.step-header.centered{text-align:center}.step-indicator{display:inline-block;font-size:12px;font-weight:600;color:var(--heiwa-sage, #7C9A82);background:var(--heiwa-sage-10, #F0F5F1);padding:5px 10px;border-radius:16px;margin-bottom:12px}.step-header h2{font-size:24px;font-weight:700;color:var(--heiwa-text-primary, #1F2937);margin:0;line-height:1.3}.step-subtitle{font-size:15px;color:var(--heiwa-text-secondary, #6B7280);margin:8px 0 0}.onboarding-step.philosophy{align-items:center;text-align:center;padding-top:20px;justify-content:center}.step-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;margin-bottom:24px;flex-shrink:0}.step-icon.large{width:100px;height:100px}.step-icon svg{width:100%;height:100%;color:var(--heiwa-sage, #7C9A82);filter:drop-shadow(0 4px 12px rgba(124,154,130,.25))}.onboarding-step.philosophy h1{font-size:32px;font-weight:700;color:var(--heiwa-text-primary, #1F2937);margin:0 0 24px}.philosophy-text{margin-bottom:32px;max-width:320px}.philosophy-main{font-size:18px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);margin:0 0 8px}.philosophy-sub{font-size:16px;line-height:1.5;color:var(--heiwa-text-secondary, #6B7280);margin:0}.philosophy-sub strong{color:var(--heiwa-sage, #7C9A82)}.philosophy-features{display:flex;flex-direction:column;gap:12px;margin-bottom:32px;width:100%;max-width:280px}.philosophy-feature{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000a}.philosophy-feature .feature-icon{width:24px;height:24px;flex-shrink:0}.philosophy-feature .feature-icon svg{width:24px;height:24px;color:var(--heiwa-sage, #7C9A82)}.philosophy-feature span:last-child{font-size:14px;font-weight:500;color:var(--heiwa-text-primary, #1F2937)}.objective-step .step-header{text-align:center}.objective-step{display:flex;flex-direction:column}.objective-input-wrapper{position:relative;margin-bottom:16px;flex-shrink:0}.objective-input-wrapper textarea{width:100%;min-height:120px;padding:16px 16px 32px;font-size:16px;font-family:inherit;line-height:1.5;color:var(--heiwa-text-primary, #1F2937);background:#fff;border:2px solid var(--heiwa-border, #E5E7EB);border-radius:16px;resize:none;transition:all .2s ease;box-sizing:border-box}.objective-input-wrapper textarea:focus{outline:none;border-color:var(--heiwa-sage, #7C9A82);box-shadow:0 0 0 4px #7c9a821a}.objective-input-wrapper textarea::placeholder{color:var(--heiwa-text-muted, #9CA3AF)}.objective-input-wrapper textarea:disabled{opacity:.7;cursor:not-allowed}.char-count{position:absolute;bottom:10px;right:12px;font-size:11px;color:var(--heiwa-text-muted, #9CA3AF)}.objective-error{padding:10px 14px;margin-bottom:16px;background:#ef44441a;border-radius:8px;color:#dc2626;font-size:13px;flex-shrink:0}.objective-examples{margin-bottom:20px;flex-shrink:0}.examples-title{font-size:13px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);margin-bottom:10px}.examples-chips{display:flex;flex-wrap:wrap;gap:8px}.example-chip{padding:8px 14px;background:#fff;border:1px solid var(--heiwa-border, #E5E7EB);border-radius:20px;font-size:13px;color:var(--heiwa-text-secondary, #6B7280);cursor:pointer;transition:all .2s ease}.example-chip:hover{border-color:var(--heiwa-sage, #7C9A82);background:var(--heiwa-sage-10, #F0F5F1);color:var(--heiwa-sage-dark, #5A7D5A)}.example-chip:disabled{opacity:.5;cursor:not-allowed}.btn-analyze{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 24px;margin-bottom:24px;background:#fff;border:2px solid var(--heiwa-sage, #7C9A82);border-radius:14px;font-size:15px;font-weight:600;color:var(--heiwa-sage, #7C9A82);cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-analyze:hover:not(:disabled){background:var(--heiwa-sage-10, #F0F5F1)}.btn-analyze:disabled{opacity:.7;cursor:not-allowed}.btn-analyze svg{width:20px;height:20px}.loading-dots{display:inline-flex;gap:4px}.loading-dots span{width:6px;height:6px;background:currentColor;border-radius:50%;animation:dot-blink 1.4s infinite both}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-blink{0%,80%,to{opacity:.3}40%{opacity:1}}.objective-result{display:flex;flex-direction:column;gap:16px;flex:1;min-height:0;overflow-y:auto}.result-header{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:12px;color:var(--heiwa-sage-dark, #5A7D5A);font-weight:600;flex-shrink:0}.result-header .result-icon{width:20px;height:20px}.result-header .result-icon svg{width:20px;height:20px}.result-quote{padding:16px;background:#fff;border-radius:12px;border-left:4px solid var(--heiwa-sage, #7C9A82);flex-shrink:0}.result-quote p{margin:0;font-size:15px;font-style:italic;color:var(--heiwa-text-primary, #1F2937);line-height:1.5}.result-summary{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 8px #0000000a;flex-shrink:0}.result-details{display:flex;flex-direction:column;gap:10px}.detail-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:10px}.detail-icon{width:20px;height:20px;flex-shrink:0}.detail-icon svg{width:20px;height:20px;color:var(--heiwa-sage, #7C9A82)}.detail-value{font-size:14px;font-weight:600;color:var(--heiwa-text-primary, #1F2937)}.result-ai-summary{margin:12px 0 0;padding-top:12px;border-top:1px solid var(--heiwa-border, #E5E7EB);font-size:14px;color:var(--heiwa-text-secondary, #6B7280);line-height:1.5}.btn-edit{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;background:transparent;border:1px solid var(--heiwa-border, #E5E7EB);border-radius:12px;font-size:14px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-edit:hover{border-color:var(--heiwa-sage, #7C9A82);color:var(--heiwa-sage-dark, #5A7D5A)}.btn-edit svg{width:16px;height:16px}.basic-info{display:flex;flex-direction:column}.form-fields{display:flex;flex-direction:column;gap:20px;flex:1;min-height:0;overflow-y:auto;padding-bottom:8px}.form-field{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.form-field label{font-size:14px;font-weight:600;color:var(--heiwa-text-primary, #1F2937)}.form-field label .optional{font-weight:400;color:var(--heiwa-text-muted, #9CA3AF)}.form-field input{padding:14px 16px;border:2px solid var(--heiwa-border, #E5E7EB);border-radius:12px;font-size:16px;background:#fff;transition:all .2s ease;width:100%;box-sizing:border-box}.form-field input:focus{outline:none;border-color:var(--heiwa-sage, #7C9A82);box-shadow:0 0 0 4px #7c9a821a}.form-field input::placeholder{color:var(--heiwa-text-muted, #9CA3AF)}.field-hint{font-size:12px;color:var(--heiwa-text-muted, #9CA3AF);margin:0}.input-with-unit{position:relative}.input-with-unit input{padding-right:48px}.input-with-unit .unit{position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:14px;font-weight:500;color:var(--heiwa-text-muted, #9CA3AF)}.gender-options{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.gender-btn{padding:14px 12px;border:2px solid var(--heiwa-border, #E5E7EB);border-radius:12px;background:#fff;font-size:14px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);cursor:pointer;transition:all .2s ease}.gender-btn:hover{border-color:var(--heiwa-sage, #7C9A82);background:var(--heiwa-sage-10, #F0F5F1)}.gender-btn.selected{border-color:var(--heiwa-sage, #7C9A82);background:var(--heiwa-sage, #7C9A82);color:#fff}.recap{text-align:center;display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto}.recap-avatar{width:80px;height:80px;margin:0 auto 16px;background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #7c9a824d;flex-shrink:0}.recap-avatar svg{width:40px;height:40px;color:#fff}.recap-card{background:#fff;border-radius:20px;padding:20px;margin-bottom:20px;box-shadow:0 4px 16px #0000000f;text-align:left;flex-shrink:0}.recap-objective{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--heiwa-border, #E5E7EB)}.recap-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--heiwa-text-muted, #9CA3AF);margin-bottom:8px}.recap-text{font-size:16px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);margin:0;line-height:1.4}.recap-details{display:flex;flex-direction:column;gap:10px}.recap-detail{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--heiwa-text-secondary, #6B7280)}.recap-detail-icon{width:18px;height:18px;flex-shrink:0}.recap-detail-icon svg{width:18px;height:18px;color:var(--heiwa-sage, #7C9A82)}.recap-adaptations{background:var(--heiwa-sage-10, #F0F5F1);border-radius:16px;padding:20px;margin-bottom:20px;text-align:left;flex-shrink:0}.recap-adaptations h3{font-size:14px;font-weight:600;color:var(--heiwa-sage-dark, #5A7D5A);margin:0 0 12px}.adaptations-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.adaptations-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--heiwa-text-primary, #1F2937)}.adaptation-check{width:18px;height:18px;flex-shrink:0;margin-top:1px}.adaptation-check svg{width:18px;height:18px;color:var(--heiwa-sage, #7C9A82)}.recap-cta{margin-bottom:24px;flex-shrink:0}.recap-cta-text{font-size:14px;color:var(--heiwa-text-secondary, #6B7280);line-height:1.5;margin:0}.step-actions{display:flex;gap:12px;margin-top:auto;padding-top:24px;flex-shrink:0;background:var(--heiwa-cream, #FAF9F6)}.step-actions.centered{justify-content:center}.step-actions.final{flex-direction:column}.btn-primary{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 24px;background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);border:none;border-radius:14px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #7c9a824d}.btn-primary.large{padding:18px 32px;font-size:17px}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #7c9a8266}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.btn-icon svg{width:18px;height:18px}.btn-secondary{flex:1;padding:16px 20px;background:#fff;border:2px solid var(--heiwa-border, #E5E7EB);border-radius:14px;color:var(--heiwa-text-primary, #1F2937);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:var(--heiwa-sage-10, #F0F5F1);border-color:var(--heiwa-sage, #7C9A82)}[data-theme=dark] .onboarding-flow{background:#111827}[data-theme=dark] .onboarding-progress{background:#374151}[data-theme=dark] .step-header h2,[data-theme=dark] .onboarding-step.philosophy h1,[data-theme=dark] .philosophy-main{color:#f9fafb}[data-theme=dark] .philosophy-text p,[data-theme=dark] .step-subtitle{color:#9ca3af}[data-theme=dark] .philosophy-feature,[data-theme=dark] .objective-input-wrapper textarea,[data-theme=dark] .form-field input,[data-theme=dark] .result-quote,[data-theme=dark] .result-summary,[data-theme=dark] .recap-card{background:#1f2937;border-color:#374151;color:#f9fafb}[data-theme=dark] .objective-input-wrapper textarea:focus,[data-theme=dark] .form-field input:focus{border-color:#4a7c64;box-shadow:0 0 0 4px #4a7c6433}[data-theme=dark] .example-chip,[data-theme=dark] .gender-btn{background:#1f2937;border-color:#374151;color:#9ca3af}[data-theme=dark] .example-chip:hover,[data-theme=dark] .gender-btn:hover{background:#7c9a8226;border-color:#4a7c64;color:#86efac}[data-theme=dark] .gender-btn.selected{background:var(--heiwa-sage, #7C9A82);color:#fff}[data-theme=dark] .result-header,[data-theme=dark] .detail-row,[data-theme=dark] .recap-adaptations{background:#7c9a8226}[data-theme=dark] .btn-secondary{background:#1f2937;border-color:#374151;color:#e5e7eb}[data-theme=dark] .btn-edit{border-color:#374151;color:#9ca3af}[data-theme=dark] .recap-text,[data-theme=dark] .adaptations-list li,[data-theme=dark] .form-field label{color:#e5e7eb}[data-theme=dark] .step-actions{background:#111827}@media (max-width: 480px){.onboarding-content{padding:20px 16px;padding-bottom:calc(20px + env(safe-area-inset-bottom,20px))}.onboarding-step.philosophy h1{font-size:28px}.philosophy-main{font-size:17px}.step-header h2{font-size:22px}.philosophy-features{max-width:100%}}@media (max-width: 360px){.gender-options{grid-template-columns:1fr;gap:8px}.examples-chips{flex-direction:column}.example-chip{width:100%;text-align:center}}@media (prefers-reduced-motion: reduce){.onboarding-step{animation:none}.progress-fill{transition:none}}.btn-primary:focus-visible,.btn-secondary:focus-visible,.btn-analyze:focus-visible,.btn-edit:focus-visible,.gender-btn:focus-visible,.example-chip:focus-visible{outline:2px solid var(--heiwa-sage, #7C9A82);outline-offset:2px}.detected-constraints{display:flex;flex-direction:column;gap:4px;padding:12px 14px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:10px;margin-bottom:10px}.detected-label{font-size:12px;font-weight:600;color:var(--heiwa-sage-dark, #5A7D5A)}.detected-value{font-size:14px;color:var(--heiwa-text-primary, #1F2937)}.auth-screen.heiwa{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,var(--heiwa-cream, #FAF9F6) 0%,#F0F5F1 100%);padding:20px}.splash-container{width:100%;max-width:400px;min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;padding:60px 24px 40px;text-align:center}.splash-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.splash-logo{width:120px;height:120px;display:flex;align-items:center;justify-content:center;margin-bottom:24px}.heiwa-leaf-icon{color:var(--heiwa-sage, #7C9A82);filter:drop-shadow(0 4px 12px rgba(124,154,130,.3));animation:gentleFloat 4s ease-in-out infinite}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.splash-title{font-size:48px;font-weight:700;color:var(--heiwa-sage-dark, #5A7D5A);margin:0 0 12px;letter-spacing:-1px}.splash-tagline{font-size:18px;color:var(--heiwa-text-secondary, #6B7280);margin:0;font-weight:500}.splash-actions{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}.btn-splash-primary{width:100%;padding:18px 32px;background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);border:none;border-radius:16px;color:#fff;font-size:17px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #7c9a824d}.btn-splash-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #7c9a8266}.btn-splash-primary:active{transform:translateY(0)}.btn-splash-secondary{background:none;border:none;color:var(--heiwa-sage, #7C9A82);font-size:15px;font-weight:600;cursor:pointer;padding:12px;transition:color .2s}.btn-splash-secondary:hover{color:var(--heiwa-sage-dark, #5A7D5A)}.splash-version{font-size:13px;color:var(--heiwa-text-muted, #9CA3AF);margin:0}.auth-container{width:100%;max-width:400px;padding:24px}.auth-header{display:flex;align-items:center;gap:16px;margin-bottom:40px}.auth-back-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--heiwa-sage-20, #E1EBE3);border-radius:12px;cursor:pointer;transition:all .2s}.auth-back-btn svg{width:20px;height:20px;color:var(--heiwa-sage, #7C9A82)}.auth-back-btn:hover{background:var(--heiwa-sage-10, #F0F5F1);border-color:var(--heiwa-sage, #7C9A82)}.auth-logo-small{display:flex;align-items:center;gap:8px}.auth-logo-small svg{width:32px;height:32px;color:var(--heiwa-sage, #7C9A82)}.auth-logo-small span{font-size:20px;font-weight:700;color:var(--heiwa-sage-dark, #5A7D5A)}.auth-title-section{margin-bottom:32px}.auth-title-section h1{font-size:28px;font-weight:700;color:var(--heiwa-text-primary, #1F2937);margin:0 0 8px}.auth-title-section p{font-size:15px;color:var(--heiwa-text-secondary, #6B7280);margin:0}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:14px;margin-bottom:28px}.auth-tab{padding:12px 16px;background:transparent;border:none;border-radius:10px;font-size:15px;font-weight:600;color:var(--heiwa-text-secondary, #6B7280);cursor:pointer;transition:all .2s ease}.auth-tab.active{background:#fff;color:var(--heiwa-sage-dark, #5A7D5A);box-shadow:0 2px 8px #00000014}.auth-tab:disabled{opacity:.5;cursor:not-allowed}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-form .form-group{display:flex;flex-direction:column;gap:8px}.auth-form .form-group label{font-size:14px;font-weight:600;color:var(--heiwa-text-primary, #1F2937)}.auth-form .form-group input{padding:16px;border:2px solid var(--heiwa-sage-20, #E1EBE3);border-radius:14px;font-size:16px;background:#fff;transition:all .2s ease}.auth-form .form-group input:focus{outline:none;border-color:var(--heiwa-sage, #7C9A82);box-shadow:0 0 0 4px #7c9a821a}.auth-form .form-group input::placeholder{color:var(--heiwa-text-muted, #9CA3AF)}.auth-form .form-group input:disabled{background:#f9fafb;cursor:not-allowed}.forgot-password-btn{align-self:flex-end;background:none;border:none;color:var(--heiwa-sage, #7C9A82);font-size:14px;font-weight:600;cursor:pointer;padding:0;margin-top:-8px}.forgot-password-btn:hover{color:var(--heiwa-sage-dark, #5A7D5A);text-decoration:underline}.forgot-password-btn:disabled{opacity:.5;cursor:not-allowed}.auth-submit-btn{padding:18px;background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);border:none;border-radius:14px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px;display:flex;align-items:center;justify-content:center;min-height:56px;box-shadow:0 4px 12px #7c9a8240}.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #7c9a8259}.auth-submit-btn:active:not(:disabled){transform:translateY(0)}.auth-submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.spinner{width:22px;height:22px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.auth-footer-text{text-align:center;margin-top:32px;font-size:15px;color:var(--heiwa-text-secondary, #6B7280)}.auth-switch-btn{background:none;border:none;color:var(--heiwa-sage, #7C9A82);font-weight:600;cursor:pointer;padding:0}.auth-switch-btn:hover{color:var(--heiwa-sage-dark, #5A7D5A);text-decoration:underline}[data-theme=dark] .auth-screen.heiwa{background:linear-gradient(180deg,#111827,#1f2937)}[data-theme=dark] .splash-title{color:var(--heiwa-sage-light, #9CADA4)}[data-theme=dark] .splash-tagline{color:#9ca3af}[data-theme=dark] .auth-back-btn{background:#1f2937;border-color:#374151}[data-theme=dark] .auth-back-btn:hover{background:#374151}[data-theme=dark] .auth-logo-small span{color:var(--heiwa-sage-light, #9CADA4)}[data-theme=dark] .auth-title-section h1{color:#f9fafb}[data-theme=dark] .auth-title-section p{color:#9ca3af}[data-theme=dark] .auth-tabs{background:#1f2937}[data-theme=dark] .auth-tab{color:#9ca3af}[data-theme=dark] .auth-tab.active{background:#374151;color:var(--heiwa-sage-light, #9CADA4)}[data-theme=dark] .auth-form .form-group label{color:#e5e7eb}[data-theme=dark] .auth-form .form-group input{background:#1f2937;border-color:#374151;color:#f3f4f6}[data-theme=dark] .auth-form .form-group input:focus{border-color:var(--heiwa-sage, #7C9A82);box-shadow:0 0 0 4px #7c9a8226}[data-theme=dark] .auth-footer-text{color:#9ca3af}@media (max-width: 480px){.splash-container{padding:40px 20px 32px}.splash-logo{width:100px;height:100px}.splash-title{font-size:40px}.splash-tagline{font-size:16px}.auth-container{padding:20px}.auth-title-section h1{font-size:24px}.btn-splash-primary{padding:16px 28px;font-size:16px}}@media (max-width: 380px){.splash-title{font-size:36px}.auth-tabs{gap:2px}.auth-tab{padding:10px 12px;font-size:14px}}@media (prefers-reduced-motion: reduce){.heiwa-leaf-icon{animation:none}.spinner{animation:none;border:3px solid white}}.auth-back-btn:focus-visible,.auth-tab:focus-visible,.auth-submit-btn:focus-visible,.btn-splash-primary:focus-visible{outline:2px solid var(--heiwa-sage, #7C9A82);outline-offset:2px}.admin-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:20px}.admin-login-card{background:#1e1e2e;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.admin-login-header{text-align:center;margin-bottom:32px}.admin-logo{font-size:48px;display:block;margin-bottom:16px}.admin-login-header h1{color:#fff;font-size:24px;margin:0 0 8px}.admin-login-header p{color:#888;margin:0;font-size:14px}.admin-login form{display:flex;flex-direction:column;gap:16px}.admin-login input{background:#2a2a3e;border:1px solid #3a3a4e;border-radius:8px;padding:14px 16px;color:#fff;font-size:16px;outline:none;transition:border-color .2s}.admin-login input:focus{border-color:#6366f1}.admin-login button{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;padding:14px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .2s}.admin-login button:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.admin-login button:disabled{opacity:.5;cursor:not-allowed}.admin-error{color:#f87171;text-align:center;margin-top:16px;font-size:14px}.admin-loading,.admin-error-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#1a1a2e;color:#fff;gap:16px}.admin-spinner{width:40px;height:40px;border:3px solid #3a3a4e;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite}.admin-error-screen button{background:#6366f1;border:none;border-radius:8px;padding:12px 24px;color:#fff;cursor:pointer}.admin-dashboard{min-height:100vh;background:#1a1a2e;color:#fff;padding-bottom:40px}.admin-header{background:#1e1e2e;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #2a2a3e;position:sticky;top:0;z-index:100}.admin-header-left{display:flex;align-items:center;gap:12px}.admin-header-left .admin-logo{font-size:28px}.admin-header h1{font-size:20px;margin:0;font-weight:600}.admin-header-right{display:flex;gap:12px}.admin-btn{padding:8px 16px;border-radius:8px;border:none;font-size:14px;cursor:pointer;transition:all .2s}.admin-btn.refresh{background:#2a2a3e;color:#fff}.admin-btn.refresh:hover{background:#3a3a4e}.admin-btn.logout{background:transparent;color:#888;border:1px solid #3a3a4e}.admin-btn.logout:hover{color:#f87171;border-color:#f87171}.admin-section{padding:24px;max-width:1200px;margin:0 auto}.admin-section h2{font-size:18px;margin:0 0 20px;color:#ccc;font-weight:500}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px}.kpi-card{background:#1e1e2e;border-radius:12px;padding:20px;text-align:center;border:1px solid #2a2a3e;transition:transform .2s,border-color .2s}.kpi-card:hover{transform:translateY(-2px);border-color:#3a3a4e}.kpi-card.highlight{background:linear-gradient(135deg,#1e3a5f,#1e1e2e);border-color:#3b82f6}.kpi-card.wide{grid-column:span 2}.kpi-value{font-size:32px;font-weight:700;color:#fff;margin-bottom:8px}.kpi-card.highlight .kpi-value{color:#60a5fa}.kpi-label{font-size:13px;color:#888}.events-grid{display:flex;flex-wrap:wrap;gap:12px}.event-badge{background:#1e1e2e;border:1px solid #2a2a3e;border-radius:20px;padding:8px 16px;display:flex;align-items:center;gap:8px}.event-type{color:#888;font-size:13px;text-transform:capitalize}.event-count{background:#6366f1;color:#fff;font-size:12px;font-weight:600;padding:2px 8px;border-radius:10px}.table-container{overflow-x:auto;border-radius:12px;border:1px solid #2a2a3e}.admin-table{width:100%;border-collapse:collapse;background:#1e1e2e;font-size:14px}.admin-table th,.admin-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #2a2a3e}.admin-table th{background:#252535;color:#888;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#252535}.admin-table tr.recent td{background:#6366f11a}.admin-table .user-id{font-family:monospace;color:#888}.admin-empty{color:#666;text-align:center;padding:40px;background:#1e1e2e;border-radius:12px;border:1px dashed #2a2a3e}.admin-footer{text-align:center;padding:24px;color:#666;font-size:12px}@media (max-width: 768px){.admin-header{flex-direction:column;gap:12px;padding:12px 16px}.admin-header h1{font-size:16px}.admin-section{padding:16px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.kpi-card.wide{grid-column:span 2}.kpi-value{font-size:24px}.admin-table{font-size:12px}.admin-table th,.admin-table td{padding:10px 12px}}@media (max-width: 480px){.kpi-grid{grid-template-columns:1fr 1fr}.admin-header-right{width:100%;justify-content:center}}.phone-container-mobile{width:100vw;height:100vh;height:-webkit-fill-available;display:flex;flex-direction:column;background-color:var(--bg-secondary, #F9FAFB);overflow:hidden;position:fixed;top:0;left:0;right:0;bottom:0;padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0);padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0);box-sizing:border-box}.phone-container-mobile>*{min-height:0}.phone-simulator{display:flex;justify-content:center;align-items:center;padding:var(--spacing-xl, 32px);min-height:100vh;background:linear-gradient(135deg,#5b6fbf,#8b5cf6)}.phone-frame{width:430px;max-width:100%;height:932px;max-height:95vh;background-color:var(--bg-card, #FFFFFF);border-radius:40px;box-shadow:0 0 0 12px #00000014,0 0 0 14px #5b6fbf33,0 25px 50px -12px #00000040;overflow:hidden;display:flex;flex-direction:column;position:relative;animation:phoneAppear .3s ease-out}.phone-notch{position:absolute;top:0;left:50%;transform:translate(-50%);width:180px;height:30px;background-color:var(--bg-card, #FFFFFF);border-bottom-left-radius:20px;border-bottom-right-radius:20px;z-index:100;display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm, 8px);box-shadow:0 2px 4px #0000001a}.notch-speaker{width:60px;height:6px;background-color:var(--gray-300, #D1D5DB);border-radius:9999px}.notch-camera{width:12px;height:12px;background-color:var(--gray-400, #9CA3AF);border-radius:50%;border:2px solid var(--gray-300, #D1D5DB)}.phone-status-bar{height:44px;padding:0 var(--spacing-md, 16px);padding-top:8px;display:flex;justify-content:space-between;align-items:center;color:var(--text-primary, #1F2937);font-size:12px;font-weight:600;background-color:var(--bg-card, #FFFFFF);z-index:50;flex-shrink:0}.status-left,.status-right{display:flex;align-items:center;gap:var(--spacing-xs, 4px)}.status-time{font-weight:600;font-size:14px}.status-icon{font-size:14px}.phone-screen{flex:1;overflow-y:auto;overflow-x:hidden;background-color:var(--bg-secondary, #F9FAFB);position:relative;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch}.phone-home-indicator{height:34px;display:flex;justify-content:center;align-items:center;background-color:var(--bg-card, #FFFFFF);flex-shrink:0}.phone-home-indicator:before{content:"";width:140px;height:5px;background-color:var(--gray-400, #9CA3AF);border-radius:9999px;opacity:.4}[data-theme=dark] .phone-container-mobile{background-color:var(--gray-900, #111827)}[data-theme=dark] .phone-simulator{background:linear-gradient(135deg,#3d4a7a,#5a3d7a)}[data-theme=dark] .phone-frame{background-color:var(--gray-900, #111827);box-shadow:0 0 0 12px #0006,0 0 0 14px #5b6fbf4d,0 25px 50px -12px #00000080}[data-theme=dark] .phone-notch{background-color:var(--gray-900, #111827)}[data-theme=dark] .phone-status-bar{background-color:var(--gray-900, #111827);color:var(--gray-100, #F3F4F6)}[data-theme=dark] .phone-screen{background-color:var(--gray-800, #1F2937)}[data-theme=dark] .phone-home-indicator{background-color:var(--gray-900, #111827)}[data-theme=dark] .notch-speaker{background-color:var(--gray-700, #374151)}[data-theme=dark] .notch-camera{background-color:var(--gray-600, #4B5563);border-color:var(--gray-700, #374151)}[data-theme=dark] .phone-home-indicator:before{background-color:var(--gray-600, #4B5563)}@keyframes phoneAppear{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion: reduce){.phone-frame{animation:none}}.objective-screen{min-height:100%;background:var(--heiwa-cream, #FAF9F6);padding-bottom:calc(100px + env(safe-area-inset-bottom))}.objective-header{padding:20px;padding-top:calc(20px + env(safe-area-inset-top));background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);color:#fff}.objective-header-content{display:flex;flex-direction:column;gap:4px}.objective-label{font-size:12px;font-weight:500;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.objective-header h1{font-size:24px;font-weight:700;margin:0}.objective-hero{margin:20px 16px;padding:24px;background:#fff;border-radius:20px;box-shadow:0 4px 16px #0000000f;text-align:center}.objective-icon{width:48px;height:48px;margin:0 auto 16px;padding:12px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:50%;display:flex;align-items:center;justify-content:center}.objective-icon svg{width:24px;height:24px;stroke:var(--heiwa-sage, #7C9A82)}.objective-text{font-size:18px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);line-height:1.5;margin:0 0 20px;font-style:normal}.objective-edit-hint{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:var(--heiwa-sage-10, #F0F5F1);border:none;border-radius:20px;font-size:13px;font-weight:500;color:var(--heiwa-sage-dark, #5A7D5A);cursor:pointer;transition:all .2s ease}.objective-edit-hint:hover{background:var(--heiwa-sage-20, #E1EBE3)}.edit-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.edit-icon svg{width:16px;height:16px;stroke:var(--heiwa-sage, #7C9A82)}.section-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--heiwa-text-secondary, #6B7280);margin:0 0 16px;text-transform:uppercase;letter-spacing:.5px}.section-icon svg{width:18px;height:18px;stroke:var(--heiwa-sage, #7C9A82)}.objective-progress{margin:0 16px 20px;padding:20px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000a}.progress-visual{margin-bottom:20px}.progress-bar-container{position:relative;height:12px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:6px;overflow:visible;margin-bottom:8px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);border-radius:6px;transition:width .5s ease}.progress-marker{position:absolute;top:-4px;width:20px;height:20px;background:#fff;border:3px solid var(--heiwa-sage-dark, #5A7D5A);border-radius:50%;transform:translate(-50%);box-shadow:0 2px 6px #00000026;transition:left .5s ease}.progress-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--heiwa-text-muted, #9CA3AF)}.progress-current{font-weight:600;color:var(--heiwa-sage-dark, #5A7D5A)}.progress-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.progress-stat{text-align:center;padding:12px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:12px}.progress-stat.highlight{background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%)}.progress-stat.highlight .stat-value,.progress-stat.highlight .stat-label{color:#fff}.stat-value{display:block;font-size:18px;font-weight:700;color:var(--heiwa-sage-dark, #5A7D5A);margin-bottom:4px}.stat-label{font-size:11px;color:var(--heiwa-text-muted, #9CA3AF);text-transform:uppercase;letter-spacing:.3px}.objective-timeline{margin:0 16px 20px;padding:20px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000a}.timeline-list{display:flex;flex-direction:column;gap:12px}.timeline-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--heiwa-cream, #FAF9F6);border-radius:12px;transition:transform .2s ease}.timeline-item:hover{transform:translate(4px)}.timeline-icon{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000000d}.timeline-icon svg{width:20px;height:20px;stroke:currentColor}.timeline-content{flex:1;display:flex;justify-content:space-between;align-items:center;gap:8px}.timeline-text{font-size:14px;font-weight:500;color:var(--heiwa-text-primary, #1F2937)}.timeline-date{font-size:12px;color:var(--heiwa-text-muted, #9CA3AF);white-space:nowrap}.objective-insights{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:0 16px 20px}.insight-card{padding:16px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000a}.insight-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.insight-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.insight-card.working .insight-icon svg{width:18px;height:18px;stroke:#10b981}.insight-card.blocking .insight-icon svg{width:18px;height:18px;stroke:#f59e0b}.insight-header h3{font-size:13px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);margin:0}.insight-list{list-style:none;padding:0;margin:0}.insight-list li{font-size:13px;color:var(--heiwa-text-secondary, #6B7280);padding:6px 0;border-bottom:1px solid rgba(0,0,0,.05)}.insight-list li:last-child{border-bottom:none}.insight-card.working .insight-list li:before{content:"✓ ";color:#10b981;font-weight:600}.insight-card.blocking .insight-list li:before{content:"→ ";color:#f59e0b;font-weight:600}.objective-coach-tip{display:flex;align-items:flex-start;gap:12px;margin:0 16px 20px;padding:16px;background:linear-gradient(135deg,var(--heiwa-sage-10, #F0F5F1) 0%,#E8F0EA 100%);border-radius:16px;border-left:4px solid var(--heiwa-sage, #7C9A82)}.coach-tip-icon{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.coach-tip-icon svg{width:24px;height:24px;stroke:var(--heiwa-sage, #7C9A82)}.coach-tip-content p{font-size:14px;color:var(--heiwa-text-secondary, #6B7280);line-height:1.5;margin:0}.objective-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 32px;min-height:100vh}.objective-empty .empty-icon{width:80px;height:80px;margin-bottom:24px;padding:20px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:50%;display:flex;align-items:center;justify-content:center}.objective-empty .empty-icon svg{width:40px;height:40px;stroke:var(--heiwa-sage, #7C9A82)}.objective-empty h2{font-size:22px;font-weight:700;color:var(--heiwa-text-primary, #1F2937);margin:0 0 12px}.objective-empty p{font-size:15px;color:var(--heiwa-text-secondary, #6B7280);margin:0 0 24px;max-width:280px}.empty-hint{display:flex;align-items:center;gap:10px;padding:14px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f}.hint-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.hint-icon svg{width:20px;height:20px;stroke:var(--heiwa-sage, #7C9A82)}.empty-hint span:last-child{font-size:14px;color:var(--heiwa-text-secondary, #6B7280)}[data-theme=dark] .objective-screen{background:#111827}[data-theme=dark] .objective-hero,[data-theme=dark] .objective-progress,[data-theme=dark] .objective-timeline,[data-theme=dark] .insight-card{background:#1f2937}[data-theme=dark] .objective-text{color:#f9fafb}[data-theme=dark] .objective-edit-hint{background:#7c9a8233;color:#86efac}[data-theme=dark] .progress-bar-container{background:#7c9a8233}[data-theme=dark] .progress-stat{background:#7c9a8226}[data-theme=dark] .progress-stat.highlight{background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%)}[data-theme=dark] .progress-marker{background:#1f2937;border-color:#86efac}[data-theme=dark] .timeline-item{background:#ffffff0d}[data-theme=dark] .timeline-icon{background:#374151}[data-theme=dark] .timeline-text{color:#f9fafb}[data-theme=dark] .section-title,[data-theme=dark] .insight-header h3{color:#d1d5db}[data-theme=dark] .insight-list li{color:#9ca3af;border-color:#ffffff1a}[data-theme=dark] .objective-coach-tip{background:#7c9a8226;border-color:#4a7c64}[data-theme=dark] .objective-empty .empty-icon{background:#7c9a8233}[data-theme=dark] .objective-empty h2{color:#f9fafb}[data-theme=dark] .empty-hint{background:#1f2937}@media (max-width: 360px){.objective-insights{grid-template-columns:1fr}.progress-stats{gap:8px}.stat-value{font-size:16px}.timeline-content{flex-direction:column;align-items:flex-start;gap:4px}}.wellness-score-section{padding:0 16px;margin-top:-30px;position:relative;z-index:10}.wellness-score-card{background:#fff;border-radius:20px;box-shadow:0 8px 30px #0000001a;padding:24px;overflow:hidden}.wellness-main{display:flex;align-items:center;gap:24px;margin-bottom:20px}.circular-score{position:relative;flex-shrink:0}.circular-score svg{display:block}.score-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.score-number{font-size:36px;font-weight:700;color:var(--heiwa-text-primary, #1F2937);line-height:1}.score-max{font-size:14px;color:var(--heiwa-text-secondary, #6B7280);font-weight:500}.wellness-info{flex:1;display:flex;flex-direction:column;gap:8px}.wellness-info h2{font-size:18px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);margin:0}.star-rating{display:flex;gap:4px}.star{width:20px;height:20px;color:#e5e7eb;transition:color .2s}.star.filled{color:#f59e0b}.star svg{width:100%;height:100%}.wellness-status{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;width:fit-content}.wellness-status.excellent,.wellness-status.very-good{background:#d1fae5;color:#065f46}.wellness-status.good{background:#e0f2f1;color:#00695c}.wellness-status.fair{background:#fef3c7;color:#92400e}.wellness-status.starting,.wellness-status.beginning{background:#ede9fe;color:#5b21b6}.wellness-status.info{background:#e0e7ff;color:#3730a3}.streak-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:20px;font-size:12px;font-weight:600;color:#92400e;width:fit-content}.streak-icon{width:14px;height:14px}.streak-icon svg{width:100%;height:100%;stroke:#f97316}.wellness-breakdown{display:flex;flex-direction:column;gap:12px;padding-top:16px;border-top:1px solid var(--heiwa-border, #E5E7EB)}.breakdown-item{display:flex;flex-direction:column;gap:6px}.breakdown-header{display:flex;align-items:center;gap:8px}.breakdown-icon{width:18px;height:18px;flex-shrink:0}.breakdown-icon svg{width:100%;height:100%;stroke:var(--heiwa-text-secondary, #6B7280)}.breakdown-label{flex:1;font-size:13px;font-weight:500;color:var(--heiwa-text-primary, #1F2937)}.breakdown-score{font-size:12px;font-weight:600;color:var(--heiwa-text-secondary, #6B7280)}.breakdown-bar{height:6px;background:var(--heiwa-border, #E5E7EB);border-radius:3px;overflow:hidden}.breakdown-fill{height:100%;border-radius:3px;transition:width .5s ease-out}.weight-trend-insight{display:flex;align-items:flex-start;gap:10px;margin-top:16px;padding:12px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:12px}.trend-icon{width:18px;height:18px;flex-shrink:0}.trend-icon svg{width:100%;height:100%;stroke:var(--heiwa-sage, #7C9A82)}.weight-trend-insight p{margin:0;font-size:13px;color:var(--heiwa-text-primary, #1F2937);line-height:1.5}.training-load-section{padding:0 16px;margin:16px 0}.training-load-card{display:flex;align-items:center;gap:16px;padding:16px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000a;border-left:4px solid var(--heiwa-sage, #7C9A82)}.training-load-card.healthy{border-left-color:#10b981}.training-load-card.warning{border-left-color:#f59e0b}.training-load-card.alert{border-left-color:#ef4444}.training-load-card.low{border-left-color:#6b7280}.load-ratio{text-align:center;min-width:60px}.ratio-value{font-size:24px;font-weight:700;color:var(--heiwa-text-primary, #1F2937)}.ratio-label{font-size:10px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);text-transform:uppercase;letter-spacing:.5px}.load-status{flex:1}.status-text{font-size:14px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);display:block;margin-bottom:4px}.status-recommendation{font-size:12px;color:var(--heiwa-text-secondary, #6B7280);margin:0;line-height:1.4}[data-theme=dark] .wellness-score-card,[data-theme=dark] .training-load-card{background:var(--heiwa-dark-card, #1E2A1E)}[data-theme=dark] .score-number,[data-theme=dark] .breakdown-label,[data-theme=dark] .wellness-info h2,[data-theme=dark] .weight-trend-insight p,[data-theme=dark] .ratio-value,[data-theme=dark] .status-text{color:var(--heiwa-dark-text, #E5E7EB)}[data-theme=dark] .wellness-breakdown{border-top-color:var(--heiwa-dark-border, #374137)}[data-theme=dark] .breakdown-bar{background:var(--heiwa-dark-border, #374137)}[data-theme=dark] .weight-trend-insight{background:var(--heiwa-dark-hover, #2A3A2A)}[data-theme=dark] .star:not(.filled){color:var(--heiwa-dark-border, #374137)}.objective-meta{display:flex;flex-direction:column;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--heiwa-border, #E5E7EB)}.meta-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--heiwa-text-secondary, #6B7280)}.meta-icon{width:16px;height:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.meta-icon svg{width:16px;height:16px;stroke:var(--heiwa-sage, #7C9A82)}.meta-item.deadline{color:var(--heiwa-sage-dark, #5A7D5A);font-weight:500}.days-remaining{font-size:12px;color:var(--heiwa-text-muted, #9CA3AF);margin-left:4px}.meta-item.constraints{font-style:italic}.personalized-badge{display:inline-flex;align-items:center;gap:6px;margin-top:16px;padding:6px 12px;background:linear-gradient(135deg,var(--heiwa-sage-10, #F0F5F1) 0%,#E8F0EA 100%);border-radius:20px;font-size:11px;font-weight:600;color:var(--heiwa-sage-dark, #5A7D5A);text-transform:uppercase;letter-spacing:.5px}.badge-icon{width:14px;height:14px;display:flex;align-items:center;justify-content:center}.badge-icon svg{width:14px;height:14px;stroke:var(--heiwa-sage, #7C9A82)}[data-theme=dark] .objective-meta{border-top-color:var(--heiwa-dark-border, #374137)}[data-theme=dark] .meta-item.deadline{color:#86efac}[data-theme=dark] .personalized-badge{background:#7c9a8233;color:#86efac}[data-theme=dark] .days-remaining{color:#6b7280}.objective-card{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;overflow:hidden}.objective-card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,var(--heiwa-sage-10, #F0F5F1) 0%,#E8F0EA 100%);border-bottom:1px solid var(--heiwa-border, #E5E7EB)}.objective-type-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:#fff;border-radius:20px;box-shadow:0 2px 8px #0000000f}.type-emoji{font-size:16px}.type-label{font-size:13px;font-weight:600;color:var(--type-color, var(--heiwa-sage-dark, #5A7D5A))}.btn-edit-objective{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #00000014}.btn-edit-objective:hover{transform:scale(1.1);box-shadow:0 4px 12px #0000001f}.btn-edit-objective svg{width:18px;height:18px;stroke:var(--heiwa-text-secondary, #6B7280)}.objective-quote{padding:24px 20px;font-size:17px;font-weight:500;font-style:italic;color:var(--heiwa-text-primary, #1F2937);line-height:1.6;text-align:center;margin:0;border:none;background:none}.objective-details{display:flex;flex-wrap:wrap;gap:10px;padding:0 20px 16px;justify-content:center}.detail-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--heiwa-cream, #FAF9F6);border-radius:20px;font-size:13px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280)}.chip-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.chip-icon svg{width:16px;height:16px;stroke:var(--heiwa-sage, #7C9A82)}.chip-emoji{font-size:14px}.detail-chip.target{background:linear-gradient(135deg,var(--heiwa-sage-10, #F0F5F1) 0%,#E8F0EA 100%);color:var(--heiwa-sage-dark, #5A7D5A);font-weight:600}.detail-chip.deadline{background:#fef3c7;color:#92400e}.detail-chip.deadline .chip-icon svg{stroke:#f59e0b}.days-badge{padding:2px 8px;background:#f59e0b;color:#fff;border-radius:10px;font-size:11px;font-weight:700;margin-left:4px}.detail-chip.tone{background:#ede9fe;color:#5b21b6}.objective-constraints{padding:12px 20px;margin:0 20px 16px;background:var(--heiwa-cream, #FAF9F6);border-radius:12px;font-size:13px}.constraints-label{font-weight:600;color:var(--heiwa-text-secondary, #6B7280);margin-right:6px}.constraints-text{color:var(--heiwa-text-primary, #1F2937);font-style:italic}.personalized-indicator{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);font-size:12px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px}.indicator-icon{width:14px;height:14px;display:flex;align-items:center;justify-content:center}.indicator-icon svg{width:14px;height:14px;stroke:#fff}.edit-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.edit-modal{background:#fff;border-radius:20px;padding:24px;max-width:340px;width:100%;text-align:center;animation:slideUp .3s ease}.edit-modal h3{font-size:18px;font-weight:700;color:var(--heiwa-text-primary, #1F2937);margin:0 0 12px}.edit-modal-hint{padding:12px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:12px;font-style:italic;color:var(--heiwa-sage-dark, #5A7D5A)!important}.btn-close-modal{margin-top:20px;padding:14px 32px;background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);border:none;border-radius:12px;font-size:15px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease}.btn-close-modal:hover{transform:translateY(-2px);box-shadow:0 6px 16px #7c9a824d}[data-theme=dark] .objective-card{background:#1f2937}[data-theme=dark] .objective-card-header{background:#7c9a8226;border-color:#374151}[data-theme=dark] .objective-type-badge{background:#374151}[data-theme=dark] .type-label{color:#86efac}[data-theme=dark] .btn-edit-objective{background:#374151}[data-theme=dark] .btn-edit-objective svg{stroke:#9ca3af}[data-theme=dark] .objective-quote{color:#f9fafb}[data-theme=dark] .detail-chip{background:#374151;color:#d1d5db}[data-theme=dark] .detail-chip.target{background:#7c9a8233;color:#86efac}[data-theme=dark] .detail-chip.deadline{background:#f59e0b33;color:#fcd34d}[data-theme=dark] .detail-chip.tone{background:#8b5cf633;color:#c4b5fd}[data-theme=dark] .objective-constraints{background:#374151}[data-theme=dark] .constraints-text{color:#d1d5db}[data-theme=dark] .personalized-indicator{background:linear-gradient(135deg,#4a7c64,#3d6854)}@media (max-width: 360px){.objective-card-header{padding:12px 16px}.objective-quote{padding:20px 16px;font-size:15px}.objective-details{padding:0 16px 12px;gap:8px}.detail-chip{padding:6px 12px;font-size:12px}.objective-constraints{margin:0 16px 12px;padding:10px}.edit-modal{padding:20px}}.objective-section{padding:0 16px;margin:20px 0}.objective-card.zen{background:#fff;border-radius:20px;box-shadow:0 2px 16px #0000000f;overflow:hidden}.objective-card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--heiwa-border, #E5E7EB)}.objective-type{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px}.btn-edit-zen{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--heiwa-border, #E5E7EB);border-radius:8px;cursor:pointer;transition:all .2s ease}.btn-edit-zen:hover{background:var(--heiwa-sage-10, #F0F5F1);border-color:var(--heiwa-sage, #7C9A82)}.btn-edit-zen svg{width:16px;height:16px;stroke:var(--heiwa-text-muted, #9CA3AF)}.btn-edit-zen:hover svg{stroke:var(--heiwa-sage-dark, #5A7D5A)}.objective-quote-zen{padding:24px 20px;margin:0;font-size:18px;font-weight:500;color:var(--heiwa-text-primary, #1F2937);line-height:1.6;text-align:center}.objective-details-zen{display:flex;flex-wrap:wrap;gap:8px;padding:0 20px 20px;justify-content:center}.detail-zen{padding:6px 14px;background:var(--heiwa-cream, #FAF9F6);border-radius:20px;font-size:13px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280)}.detail-zen.deadline{color:var(--heiwa-sage-dark, #5A7D5A)}.detail-zen .days-count{display:inline-block;margin-left:6px;padding:2px 8px;background:var(--heiwa-sage, #7C9A82);color:#fff;border-radius:10px;font-size:11px;font-weight:600}.detail-zen.tone{background:var(--heiwa-sage-10, #F0F5F1);color:var(--heiwa-sage-dark, #5A7D5A)}.objective-constraints-zen{margin:0 20px 16px;padding:12px 16px;background:var(--heiwa-cream, #FAF9F6);border-radius:12px;font-size:13px;font-style:italic;color:var(--heiwa-text-secondary, #6B7280);text-align:center}.objective-footer-zen{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;background:var(--heiwa-sage-10, #F0F5F1);font-size:11px;font-weight:500;color:var(--heiwa-sage-dark, #5A7D5A);text-transform:uppercase;letter-spacing:.5px}.footer-icon{width:14px;height:14px;display:flex;align-items:center;justify-content:center}.footer-icon svg{width:14px;height:14px;stroke:var(--heiwa-sage, #7C9A82)}.edit-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.edit-modal{background:#fff;border-radius:20px;padding:28px 24px;max-width:320px;width:100%;text-align:center;animation:slideUp .3s ease}.edit-modal h3{font-size:18px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);margin:0 0 12px}.edit-modal p{font-size:14px;color:var(--heiwa-text-secondary, #6B7280);margin:0 0 12px;line-height:1.5}.edit-modal-hint{padding:12px 16px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:12px;font-style:italic;color:var(--heiwa-sage-dark, #5A7D5A)!important;font-size:13px!important}.btn-close-modal{margin-top:20px;padding:12px 32px;background:var(--heiwa-sage, #7C9A82);border:none;border-radius:12px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease}.btn-close-modal:hover{background:var(--heiwa-sage-dark, #5A7D5A)}[data-theme=dark] .objective-card.zen{background:#1f2937;box-shadow:0 2px 16px #0003}[data-theme=dark] .objective-card-header,[data-theme=dark] .btn-edit-zen{border-color:#374151}[data-theme=dark] .btn-edit-zen:hover{background:#7c9a8226;border-color:#4a7c64}[data-theme=dark] .objective-quote-zen{color:#f9fafb}[data-theme=dark] .detail-zen{background:#374151;color:#d1d5db}[data-theme=dark] .detail-zen.deadline{color:#86efac}[data-theme=dark] .detail-zen .days-count{background:#4a7c64}[data-theme=dark] .detail-zen.tone{background:#7c9a8233;color:#86efac}[data-theme=dark] .objective-constraints-zen{background:#374151;color:#9ca3af}[data-theme=dark] .objective-footer-zen{background:#7c9a8226;color:#86efac}[data-theme=dark] .edit-modal{background:#1f2937}[data-theme=dark] .edit-modal h3{color:#f9fafb}[data-theme=dark] .edit-modal p{color:#9ca3af}[data-theme=dark] .edit-modal-hint{background:#7c9a8226;color:#86efac!important}@media (max-width: 360px){.objective-quote-zen{padding:20px 16px;font-size:16px}.objective-details-zen{padding:0 16px 16px;gap:6px}.detail-zen{padding:5px 12px;font-size:12px}.objective-constraints-zen{margin:0 16px 12px;padding:10px 14px;font-size:12px}.edit-modal{padding:24px 20px}}.progress-bar-fill.warning{background:linear-gradient(90deg,#f59e0b,#d97706)}.progress-labels .progress-current.warning{color:#d97706;font-weight:700}.progress-stat.warning-stat{background:#fef3c7;border:1px solid #F59E0B}.progress-stat.warning-stat .stat-value{color:#d97706}.progress-stat.warning-stat .stat-label{color:#92400e}.progress-stat.highlight.warning-highlight{background:linear-gradient(135deg,#f59e0b,#d97706)}[data-theme=dark] .progress-labels .progress-current.warning{color:#fcd34d}[data-theme=dark] .progress-stat.warning-stat{background:#f59e0b33;border-color:#f59e0b66}[data-theme=dark] .progress-stat.warning-stat .stat-value{color:#fcd34d}[data-theme=dark] .progress-stat.warning-stat .stat-label{color:#fbbf24}@media (max-width: 360px){.progress-stat.warning-stat .stat-value{font-size:15px}}.objective-card-v5{margin:0 16px;padding:20px;background:#fff;border-radius:20px;box-shadow:0 2px 16px #0000000f}.objective-card-v5 .objective-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.objective-card-v5 .objective-type{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px}.objective-card-v5 .objective-quote{font-size:17px;font-weight:500;color:var(--heiwa-text-primary, #1F2937);line-height:1.5;margin:0 0 16px;text-align:center}.objective-card-v5 .objective-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.objective-card-v5 .tag{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--heiwa-cream, #FAF9F6);border-radius:20px;font-size:12px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280)}.objective-card-v5 .tag.target{background:var(--heiwa-sage-10, #E8F5E9);color:var(--heiwa-sage-dark, #5A7D5A);font-weight:600}.objective-card-v5 .tag.deadline{background:var(--heiwa-sage-10, #F0F5F1);color:var(--heiwa-sage-dark, #5A7D5A)}.objective-card-v5 .tag.tone{background:#8b5cf61a;color:#7c3aed}.objective-card-v5 .tag-icon{width:14px;height:14px;display:flex;align-items:center;justify-content:center}.objective-card-v5 .tag-icon svg{width:12px;height:12px}.objective-card-v5 .objective-constraints{margin:16px 0 0;padding:12px;background:var(--heiwa-cream, #FAF9F6);border-radius:12px;font-size:13px;font-style:italic;color:var(--heiwa-text-secondary, #6B7280);text-align:center}.objective-timeline-section{margin:20px 16px;padding:20px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000a}.double-progress{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.progress-row{display:flex;align-items:center;gap:12px}.progress-row .progress-label{width:60px;font-size:12px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);text-transform:uppercase;letter-spacing:.3px}.progress-bar-wrapper{flex:1;display:flex;align-items:center;gap:10px}.progress-bar-bg{flex:1;height:10px;background:var(--heiwa-border, #E5E7EB);border-radius:5px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:5px;transition:width .5s ease}.progress-bar-fill.time{background:linear-gradient(90deg,#9ca3af,#6b7280)}.progress-bar-fill.value{background:linear-gradient(90deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%)}.progress-row .progress-percent{width:40px;font-size:13px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);text-align:right}.timeline-details{display:flex;justify-content:space-between;margin-bottom:16px;font-size:13px;color:var(--heiwa-text-secondary, #6B7280)}.timeline-week{font-weight:500}.timeline-value{font-weight:600;color:var(--heiwa-sage-dark, #5A7D5A)}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:12px;font-size:13px;font-weight:600}.status-badge .status-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center}.status-badge .status-icon svg{width:16px;height:16px}.status-badge .status-label{flex:1}.status-badge .status-diff{padding:2px 8px;background:#ffffff80;border-radius:8px;font-size:11px}.status-badge.ahead{background:#d1fae5;color:#059669}.status-badge.on_track{background:#e8f5e9;color:#5a7d5a}.status-badge.slightly_behind{background:#fef3c7;color:#d97706}.status-badge.behind{background:#fee2e2;color:#dc2626}.status-badge.unknown{background:#f3f4f6;color:#6b7280}.objective-this-week{margin:20px 16px;padding:20px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000a}.this-week-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.week-card{position:relative;display:flex;flex-direction:column;align-items:center;padding:16px 8px;background:var(--heiwa-cream, #FAF9F6);border-radius:12px;text-align:center;transition:all .2s ease}.week-card.achieved{background:var(--heiwa-sage-10, #E8F5E9);border:1px solid var(--heiwa-sage, #7C9A82)}.week-card.pending{background:#fff7ed;border:1px solid #FDBA74}.week-card-value{font-size:22px;font-weight:700;color:var(--heiwa-text-primary, #1F2937);line-height:1.2}.week-card-value small{font-size:12px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);margin-left:2px}.week-card-label{font-size:11px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);text-transform:uppercase;letter-spacing:.3px;margin-top:4px}.week-card-target{font-size:11px;color:var(--heiwa-text-muted, #9CA3AF);margin-top:2px}.week-card-check{position:absolute;top:8px;right:8px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:var(--heiwa-sage, #7C9A82);border-radius:50%}.week-card-check svg{width:12px;height:12px;stroke:#fff;stroke-width:3}.objective-milestones{margin:20px 16px;padding:20px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000a}.milestones-timeline{display:flex;flex-direction:column;gap:0;position:relative}.milestone{display:flex;align-items:center;gap:12px;padding:12px 0;position:relative}.milestone-marker{width:28px;height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--heiwa-cream, #FAF9F6);border-radius:50%;z-index:1}.milestone-marker svg{width:16px;height:16px;stroke:var(--heiwa-text-muted, #9CA3AF)}.milestone.reached .milestone-marker{background:var(--heiwa-sage-10, #E8F5E9)}.milestone.reached .milestone-marker svg{stroke:var(--heiwa-sage, #7C9A82)}.milestone.current .milestone-marker{background:var(--heiwa-sage, #7C9A82);box-shadow:0 0 0 4px #7c9a8233}.milestone.current .milestone-marker svg{stroke:#fff}.milestone.final .milestone-marker{background:#fef3c7}.milestone.final .milestone-marker svg{stroke:#f59e0b;fill:#f59e0b}.milestone-content{flex:1;display:flex;align-items:center;gap:8px}.milestone-label{font-size:14px;font-weight:500;color:var(--heiwa-text-primary, #1F2937)}.milestone.reached .milestone-label{color:var(--heiwa-sage-dark, #5A7D5A)}.milestone-week{font-size:11px;padding:2px 8px;background:var(--heiwa-cream, #FAF9F6);border-radius:10px;color:var(--heiwa-text-muted, #9CA3AF)}.milestone-current-indicator{font-size:11px;font-weight:600;color:var(--heiwa-sage, #7C9A82);white-space:nowrap}.milestone-line{position:absolute;left:13px;top:40px;width:2px;height:calc(100% - 16px);background:var(--heiwa-border, #E5E7EB);z-index:0}.milestone.reached .milestone-line{background:var(--heiwa-sage, #7C9A82)}.objective-progress-simple{margin:20px 16px;padding:20px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000a}.objective-progress-simple .progress-bar-container{height:12px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:6px;overflow:hidden;margin-bottom:12px}.objective-progress-simple .progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);border-radius:6px;transition:width .5s ease}.progress-stats-simple{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--heiwa-text-secondary, #6B7280)}.progress-percent-badge{padding:4px 12px;background:var(--heiwa-sage, #7C9A82);color:#fff;border-radius:12px;font-weight:600}[data-theme=dark] .objective-card-v5{background:#1f2937}[data-theme=dark] .objective-card-v5 .objective-quote{color:#f9fafb}[data-theme=dark] .objective-card-v5 .tag{background:#374151;color:#d1d5db}[data-theme=dark] .objective-card-v5 .tag.target{background:#7c9a8233;color:#86efac}[data-theme=dark] .objective-timeline-section,[data-theme=dark] .objective-this-week,[data-theme=dark] .objective-milestones,[data-theme=dark] .objective-progress-simple{background:#1f2937}[data-theme=dark] .progress-bar-bg{background:#374151}[data-theme=dark] .progress-row .progress-label{color:#9ca3af}[data-theme=dark] .progress-row .progress-percent{color:#f9fafb}[data-theme=dark] .week-card{background:#374151}[data-theme=dark] .week-card.achieved{background:#7c9a8233;border-color:#4a7c64}[data-theme=dark] .week-card-value{color:#f9fafb}[data-theme=dark] .milestone-marker{background:#374151}[data-theme=dark] .milestone-label{color:#f9fafb}[data-theme=dark] .milestone.reached .milestone-marker{background:#7c9a824d}[data-theme=dark] .milestone.current .milestone-marker{background:#4a7c64}[data-theme=dark] .milestone-line{background:#374151}[data-theme=dark] .status-badge.ahead{background:#10b98133;color:#6ee7b7}[data-theme=dark] .status-badge.on_track{background:#7c9a8233;color:#86efac}[data-theme=dark] .status-badge.slightly_behind{background:#f59e0b33;color:#fcd34d}[data-theme=dark] .status-badge.behind{background:#ef444433;color:#fca5a5}@media (max-width: 360px){.this-week-cards{gap:8px}.week-card{padding:12px 6px}.week-card-value{font-size:18px}.week-card-label{font-size:10px}.milestone-label{font-size:13px}.milestone-current-indicator{font-size:10px}.objective-card-v5 .objective-quote{font-size:15px}.objective-card-v5 .tag{padding:5px 10px;font-size:11px}}.breakdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease-out}.breakdown-sheet{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:500px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out;box-shadow:0 -4px 20px #00000026}.breakdown-content{padding:20px;display:flex;flex-direction:column;gap:20px;overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1}@keyframes slideUp{0%{transform:translateY(100%);opacity:.5}to{transform:translateY(0);opacity:1}}.breakdown-header{position:sticky;top:0;background:#fff;padding:12px 20px 16px;border-bottom:1px solid #F0F0F0;display:flex;align-items:center;justify-content:center;z-index:10}.breakdown-handle{position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;background:#d1d5db;border-radius:2px}.breakdown-header h2{font-size:17px;font-weight:600;color:#1f2937;margin:0}.breakdown-close{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:32px;height:32px;border:none;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.breakdown-close:hover{background:#e5e7eb}.breakdown-close svg{width:18px;height:18px;stroke:#6b7280}.breakdown-content{padding:20px;display:flex;flex-direction:column;gap:20px}.breakdown-warning{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#fef3c7;border-radius:12px;border:1px solid #FDE68A}.warning-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.warning-icon svg{width:20px;height:20px;stroke:#d97706}.warning-text strong{display:block;font-size:14px;font-weight:600;color:#92400e;margin-bottom:2px}.warning-text p{font-size:13px;color:#a16207;margin:0}.breakdown-section{background:#f9fafb;border-radius:16px;padding:16px}.breakdown-section h3{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin:0 0 14px}.section-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.section-icon svg{width:18px;height:18px;stroke:#7c9a82}.breakdown-steps{display:flex;flex-direction:column;gap:8px}.breakdown-step{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 12px;background:#fff;border-radius:10px}.step-label{display:flex;flex-direction:column;gap:2px}.step-label span:first-child{font-size:14px;font-weight:500;color:#374151}.step-info{font-size:12px;color:#9ca3af;font-weight:400!important}.step-value{font-size:14px;font-weight:600;color:#374151;white-space:nowrap}.breakdown-step.operator{background:transparent;padding:6px 12px}.breakdown-step.operator .step-value{color:#7c9a82}.breakdown-step.subtotal{border-top:1px dashed #E5E7EB;margin-top:4px;padding-top:12px}.breakdown-step.subtotal .step-value{color:#4b5563}.breakdown-step.total{background:linear-gradient(135deg,#7c9a82,#5a7d5a);margin-top:8px;padding:14px 12px}.breakdown-step.total .step-label{flex-direction:row;align-items:center;gap:8px}.breakdown-step.total .step-label span{color:#fff;font-weight:600}.total-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.total-icon svg{width:18px;height:18px;stroke:#fff}.breakdown-step.total .step-value{font-size:18px;font-weight:700;color:#fff}.breakdown-today{display:flex;flex-direction:column;gap:8px}.today-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#fff;border-radius:10px}.today-label{font-size:14px;color:#6b7280}.today-value{font-size:14px;font-weight:600;color:#374151}.today-value.consumed{color:#374151}.today-value.burned{color:#7c9a82}.today-row.remaining{background:#f0f5f1;border:1px solid #D4E5D7}.today-row.remaining .today-label{font-weight:600;color:#374151}.today-row.remaining .today-value{font-size:16px;color:#5a7d5a}.today-row.remaining .today-value.over{color:#dc2626}.breakdown-section.cta{background:transparent;padding:0}.breakdown-cta{display:flex;align-items:center;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#f0f5f1,#e8f0e9);border-radius:12px;border:1px solid #D4E5D7}.cta-icon{flex-shrink:0;width:40px;height:40px;background:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center}.cta-icon svg{width:20px;height:20px;stroke:#7c9a82}.cta-text{flex:1}.cta-text strong{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:2px}.cta-text p{font-size:12px;color:#6b7280;margin:0}.cta-button{flex-shrink:0;width:40px;height:40px;background:#7c9a82;border:none;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.cta-button:hover{background:#5a7d5a}.cta-button svg{width:18px;height:18px;stroke:#fff}.breakdown-complete{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#d1fae5;border-radius:10px;border:1px solid #A7F3D0}.complete-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.complete-icon svg{width:18px;height:18px;stroke:#059669}.breakdown-complete span{font-size:13px;font-weight:500;color:#047857}@media (max-width: 480px){.breakdown-sheet{max-height:90vh;border-radius:16px 16px 0 0}.breakdown-content{padding:16px;gap:16px}.breakdown-section{padding:14px}}@media (prefers-color-scheme: dark){.breakdown-sheet{background:#1f2937}.breakdown-header{background:#1f2937;border-bottom-color:#374151}.breakdown-header h2{color:#f9fafb}.breakdown-handle{background:#4b5563}.breakdown-close{background:#374151}.breakdown-close:hover{background:#4b5563}.breakdown-close svg{stroke:#9ca3af}.breakdown-section{background:#111827}.breakdown-section h3{color:#9ca3af}.breakdown-step{background:#1f2937}.step-label span:first-child,.step-value{color:#f3f4f6}.today-row{background:#1f2937}.today-label{color:#9ca3af}.today-value{color:#f3f4f6}.today-row.remaining{background:#1a2e1e;border-color:#2d4a32}.today-row.remaining .today-label{color:#f3f4f6}}.breakdown-sheet{display:flex;flex-direction:column}.breakdown-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.dojo-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,#0a0a1a,#000);z-index:9999;display:flex;align-items:center;justify-content:center;animation:dojoFadeIn .5s ease-out}@keyframes dojoFadeIn{0%{opacity:0}to{opacity:1}}.dojo-container{width:100%;height:100%;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center}.dojo-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.particle{position:absolute;font-size:16px;top:-20px;left:var(--x);animation:particleFall var(--duration) linear var(--delay) infinite;opacity:.7}@keyframes particleFall{0%{transform:translateY(-20px) rotate(0);opacity:0}10%{opacity:.7}90%{opacity:.7}to{transform:translateY(100vh) rotate(360deg);opacity:0}}.dojo-badge-container{display:flex;flex-direction:column;align-items:center;animation:badgeAppear .8s cubic-bezier(.34,1.56,.64,1) forwards;position:relative}@keyframes badgeAppear{0%{transform:scale(0) rotate(-180deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.badge-glow{position:absolute;width:250px;height:250px;background:radial-gradient(circle,rgba(139,92,246,.4) 0%,transparent 70%);border-radius:50%;animation:glowPulse 2s ease-in-out infinite}@keyframes glowPulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.2);opacity:.8}}.dojo-badge{width:160px;height:160px;position:relative;display:flex;align-items:center;justify-content:center}.badge-border{position:absolute;top:0;right:0;bottom:0;left:0;border:4px solid;border-image:linear-gradient(135deg,gold,orange,gold) 1;border-radius:50%;animation:borderSpin 4s linear infinite}@keyframes borderSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.badge-inner{width:130px;height:130px;background:linear-gradient(135deg,#1a1a2e,#0f0f1a);border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid #FFD700;box-shadow:0 0 30px #ffd70066,inset 0 0 20px #ffd7001a}.badge-icon{width:70px;height:70px;color:gold;filter:drop-shadow(0 0 15px rgba(255,215,0,.6))}.badge-ribbon{position:absolute;bottom:-10px;background:linear-gradient(135deg,gold,orange);padding:8px 24px;border-radius:4px;box-shadow:0 4px 15px #ffa50080}.badge-ribbon span{font-family:Georgia,serif;font-weight:700;font-size:14px;color:#1a1a2e;letter-spacing:3px;text-transform:uppercase}.badge-subtitle{margin-top:35px;color:#c0c0e0;font-size:20px;animation:subtitleFade .5s ease-out .5s forwards;opacity:0}@keyframes subtitleFade{to{opacity:1}}.badge-sparkles{position:absolute;width:220px;height:220px;pointer-events:none}.sparkle{position:absolute;color:gold;font-size:20px;animation:sparklePop 1.5s ease-out infinite}.sparkle.s1{top:0;left:50%;animation-delay:0s}.sparkle.s2{top:50%;right:0;animation-delay:.3s}.sparkle.s3{bottom:0;left:50%;animation-delay:.6s}.sparkle.s4{top:50%;left:0;animation-delay:.9s}@keyframes sparklePop{0%,to{transform:scale(0);opacity:0}50%{transform:scale(1.5);opacity:1}}.dojo-credits-wrapper{width:100%;height:100%;display:flex;justify-content:center;overflow:hidden;position:relative}.dojo-credits{position:absolute;top:100%;left:0;right:0;padding:0 30px;animation:creditsScroll 45s linear forwards}@keyframes creditsScroll{0%{top:100%}to{top:-280%}}.credits-section{text-align:center;margin-bottom:60px;color:gold}.credits-section.title{margin-bottom:80px}.credits-logo{display:inline-block;width:80px;height:80px;color:#4ade80;margin-bottom:20px;filter:drop-shadow(0 0 25px rgba(74,222,128,.6))}.credits-section h1{font-family:Georgia,serif;font-size:56px;letter-spacing:12px;margin:0;text-shadow:0 0 40px rgba(255,215,0,.6)}.credits-version{color:#999;font-size:18px;margin-top:12px;letter-spacing:4px}.credits-subtitle{color:#b0b0d0;font-style:italic;margin-top:15px;font-size:22px}.credits-section h2{font-size:26px;letter-spacing:6px;margin-bottom:30px;color:gold;text-shadow:0 0 15px rgba(255,215,0,.4)}.credit-item{display:flex;flex-direction:column;align-items:center;margin-bottom:35px}.credit-icon{width:50px;height:50px;color:#888;margin-bottom:12px}.credit-icon.heart{color:#ef4444;animation:heartBeat 1.5s ease-in-out infinite}@keyframes heartBeat{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.credit-icon.coffee{color:#d97706}.credit-icon.bug{color:#22c55e}.credit-name{font-size:28px;color:gold;font-weight:700;margin-bottom:8px}.credit-role{font-size:18px;color:#a0a0c0;font-style:italic;line-height:1.8}.credit-item.special{background:#ffd7000f;padding:25px 30px;border-radius:12px;border:1px solid rgba(255,215,0,.15);margin-bottom:25px}.casting-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 40px;max-width:450px;margin:0 auto;text-align:left;font-size:18px}.casting-grid span:nth-child(odd){color:gold;text-align:right;font-weight:700}.casting-grid span:nth-child(2n){color:#a0a0c0;font-style:italic}.credits-section.disclaimer{margin-top:50px;margin-bottom:80px}.bug-disclaimer{display:flex;flex-direction:column;align-items:center;padding:35px;border:2px dashed rgba(34,197,94,.4);border-radius:16px;background:#22c55e14}.big-bug{width:70px;height:70px;color:#22c55e;margin-bottom:15px;animation:bugWiggle .5s ease-in-out infinite}@keyframes bugWiggle{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.bug-disclaimer h3{font-size:22px;color:#22c55e;letter-spacing:4px;margin:0 0 12px}.bug-disclaimer p{color:#a0a0c0;margin:5px 0;font-size:18px}.bug-disclaimer p.small{font-size:14px;color:#666;margin-top:12px}.credits-section.final{margin-top:60px;margin-bottom:50px}.credits-section.final p{font-size:24px;color:#b0b0d0}.final-leaf{display:inline-block;width:60px;height:60px;color:#4ade80;margin:30px 0;animation:leafFloat 3s ease-in-out infinite}@keyframes leafFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(5deg)}}.final-text{font-size:28px!important;color:#4ade80!important;font-weight:700}.credits-section.footer{margin-top:80px;opacity:.7}.credits-section.footer p{color:#888;font-size:18px}.discovery-date{font-size:22px!important;color:#aaa!important;margin-top:12px}.dojo-close{position:fixed;bottom:40px;left:50%;transform:translate(-50%);background:#ffffff1a;border:1px solid rgba(255,255,255,.25);color:#c0c0e0;padding:14px 35px;border-radius:30px;font-size:16px;cursor:pointer;transition:all .3s ease;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dojo-close:hover{background:#fff3;color:gold;border-color:#ffd70066}@media (max-width: 480px){.credits-section h1{font-size:42px;letter-spacing:8px}.credits-section h2{font-size:22px}.credit-name{font-size:24px}.credit-role{font-size:16px}.casting-grid{grid-template-columns:1fr;text-align:center!important;gap:8px}.casting-grid span{text-align:center!important}.casting-grid span:nth-child(odd){margin-top:15px}.dojo-badge{width:140px;height:140px}.badge-inner{width:115px;height:115px}.badge-icon{width:60px;height:60px}.dojo-credits{padding:0 20px}}.coach-screen-unified{display:flex;flex-direction:column;height:100%;background:var(--heiwa-cream, #FAF9F6);overflow:hidden;padding-bottom:calc(130px + env(safe-area-inset-bottom,0))}.coach-header-unified{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0));background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);color:#fff;flex-shrink:0}.coach-header-left{display:flex;align-items:center;gap:12px}.coach-avatar-small{width:40px;height:40px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center}.coach-avatar-small svg{width:24px;height:24px;stroke:#fff}.coach-header-info{display:flex;flex-direction:column;gap:2px}.coach-header-info h1{font-size:16px;font-weight:600;margin:0;line-height:1.2}.coach-header-info .coach-status-dot{display:inline-block;width:8px;height:8px;background:#4ade80;border-radius:50%;margin-right:6px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.coach-header-info .coach-status-text{font-size:12px;opacity:.9}.coach-header-actions{display:flex;gap:8px}.coach-action-btn{width:36px;height:36px;border-radius:50%;background:#ffffff26;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.coach-action-btn:hover{background:#ffffff40;transform:scale(1.05)}.coach-action-btn:active{transform:scale(.95)}.coach-action-btn svg{width:18px;height:18px;stroke:#fff}.coach-clear-btn svg{width:20px;height:20px}.notification-banner{position:relative;margin:12px 16px;padding:16px;border-radius:16px;background:linear-gradient(135deg,#7c9a82,#6b8a72);color:#fff;box-shadow:0 4px 20px #7c9a824d;animation:slideDown .4s cubic-bezier(.34,1.56,.64,1);overflow:hidden;flex-shrink:0}.notification-banner:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);pointer-events:none}.notification-greeting{background:linear-gradient(135deg,#7c9a82,#5b8a6a)}.notification-reminder{background:linear-gradient(135deg,#e8a87c,#d4956a)}.notification-celebration{background:linear-gradient(135deg,#8b9dc3,#7a8cb3)}.notification-nudge{background:linear-gradient(135deg,#9cada4,#8cbc94)}.notification-support{background:linear-gradient(135deg,#b8a9c9,#a899b9)}.notification-recap{background:linear-gradient(135deg,#6b8a9c,#5a7a8c)}.notification-content{display:flex;align-items:flex-start;gap:12px;padding-right:60px}.notification-icon{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.notification-icon svg{width:28px;height:28px;stroke:currentColor;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.notification-message{margin:0;font-size:15px;line-height:1.5;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.1)}.notification-actions{position:absolute;top:12px;right:12px;display:flex;gap:8px}.notification-btn{width:32px;height:32px;border-radius:50%;border:none;background:#fff3;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.notification-btn:hover{background:#ffffff4d;transform:scale(1.1)}.notification-btn:active{transform:scale(.95)}.notification-btn svg{width:16px;height:16px;stroke:currentColor}.notification-dots{display:flex;justify-content:center;gap:6px;margin-top:12px}.notification-dot{width:6px;height:6px;border-radius:50%;background:#fff6;transition:all .3s ease}.notification-dot.active{width:18px;border-radius:3px;background:#ffffffe6}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.notification-banner.animating-out{animation:slideOut .3s ease forwards}@keyframes slideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100px)}}.day-summary-card{margin:12px 16px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000f;overflow:hidden;cursor:pointer;transition:all .3s ease;flex-shrink:0}.day-summary-card:hover{box-shadow:0 4px 12px #0000001a}.day-summary-card.collapsed{margin:8px 16px}.day-summary-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid rgba(0,0,0,.05)}.day-summary-card.collapsed .day-summary-header{border-bottom:none}.day-summary-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--heiwa-sage, #7C9A82)}.day-summary-toggle{font-size:10px;color:#9ca3af;transition:transform .3s}.day-summary-content{padding:12px 16px 16px;animation:slideDownContent .3s ease;cursor:pointer;transition:background .2s}.day-summary-content:hover{background:#7c9a820d}.day-summary-content:active{background:#7c9a821a}@keyframes slideDownContent{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.day-summary-main{text-align:center;margin-bottom:12px}.day-summary-calories{display:flex;align-items:baseline;justify-content:center;gap:4px}.day-summary-calories .cal-value{font-size:32px;font-weight:700;color:#1f2937}.day-summary-calories .cal-separator,.day-summary-calories .cal-target{font-size:20px;color:#9ca3af}.day-summary-calories .cal-unit{font-size:14px;color:#9ca3af;margin-left:4px}.day-summary-percentage{font-size:14px;font-weight:500;margin-top:4px}.day-summary-stats{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.stat-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:20px;font-size:13px;color:#374151}.stat-pill .stat-icon{display:flex;align-items:center;justify-content:center}.stat-pill .stat-icon svg{width:14px;height:14px;stroke:var(--heiwa-sage, #7C9A82)}.day-summary-hint{display:flex;justify-content:center;padding-top:8px;margin-top:8px;border-top:1px dashed #E5E7EB}.day-summary-hint span{font-size:12px;color:#7c9a82;font-weight:500}.coach-messages{flex:1;overflow-y:auto;padding:16px 16px 24px;display:flex;flex-direction:column;gap:12px;-webkit-overflow-scrolling:touch}.coach-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;color:#6b7280}.coach-empty-state .empty-icon{width:48px;height:48px;margin-bottom:16px;opacity:.4}.coach-empty-state .empty-icon svg{width:48px;height:48px;stroke:currentColor}.coach-empty-state p{font-size:15px;line-height:1.5;max-width:280px}.coach-message{display:flex;flex-direction:column;max-width:85%;animation:fadeInUp .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.coach-message.user{align-self:flex-end;align-items:flex-end}.coach-message.assistant{align-self:flex-start;align-items:flex-start}.coach-message.proactive .coach-bubble{border-left:3px solid var(--heiwa-sage, #7C9A82);background:linear-gradient(90deg,#f0f5f1,#fff)}.photo-indicator{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#7c9a8226;border-radius:6px;margin-right:8px;flex-shrink:0}.photo-indicator svg{width:14px;height:14px;stroke:#7c9a82}.coach-bubble{padding:12px 16px;border-radius:18px;font-size:15px;line-height:1.5;word-wrap:break-word}.coach-message.user .coach-bubble{background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);color:#fff;border-bottom-right-radius:6px}.coach-message.assistant .coach-bubble{background:#fff;color:#1f2937;border-bottom-left-radius:6px;box-shadow:0 1px 4px #00000014}.coach-bubble p{margin:0 0 8px}.coach-bubble p:last-child{margin-bottom:0}.coach-bubble ul,.coach-bubble ol{margin:8px 0;padding-left:20px}.coach-bubble li{margin-bottom:4px}.coach-bubble strong{font-weight:600}.coach-message-time{font-size:11px;color:#9ca3af;margin-top:4px;padding:0 4px}.coach-bubble.typing{display:flex;gap:4px;padding:16px 20px}.coach-bubble.typing span{width:8px;height:8px;background:var(--heiwa-sage, #7C9A82);border-radius:50%;animation:typing 1.4s infinite both}.coach-bubble.typing span:nth-child(2){animation-delay:.2s}.coach-bubble.typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.coach-bubble.typing .loading-text{font-size:13px;color:var(--heiwa-sage, #7C9A82);font-weight:500;animation:fadeInOut 2s ease-in-out infinite;margin-left:8px;white-space:nowrap}@keyframes fadeInOut{0%,to{opacity:.6}50%{opacity:1}}.coach-message.profile-request .coach-bubble{background:linear-gradient(135deg,#f0f5f1,#e8f0e9);border:1px solid #D4E5D7}.extracted-data-card{margin-top:8px;padding:12px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86EFAC;border-radius:14px;animation:fadeInUp .3s ease}.extracted-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.extracted-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.extracted-icon svg{width:18px;height:18px;stroke:#16a34a}.extracted-label{font-size:12px;font-weight:600;color:#16a34a;text-transform:uppercase;letter-spacing:.3px}.extracted-summary{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px}.extracted-main{font-size:15px;font-weight:600;color:#1f2937}.extracted-detail{font-size:13px;color:#374151;padding:2px 8px;background:#ffffffb3;border-radius:10px}.extracted-actions{display:flex;gap:8px;margin-top:12px}.save-data-btn,.dismiss-data-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border:none;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.save-data-btn{background:#16a34a;color:#fff}.save-data-btn:hover{background:#15803d;transform:translateY(-1px)}.save-data-btn:active{transform:translateY(0)}.save-data-btn svg,.dismiss-data-btn svg{width:16px;height:16px}.dismiss-data-btn{background:#f3f4f6;color:#6b7280}.dismiss-data-btn:hover{background:#e5e7eb;color:#4b5563}.data-saved-badge{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:6px 12px;background:#f0fdf4;border:1px solid #86EFAC;border-radius:20px;font-size:12px;font-weight:500;color:#16a34a}.data-saved-badge .badge-icon{display:flex;align-items:center}.data-saved-badge svg{width:14px;height:14px;stroke:#16a34a}.data-dismissed-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#f3f4f6;border-radius:20px;font-size:13px;color:#9ca3af;margin-top:8px}.data-dismissed-badge .badge-icon{display:flex;align-items:center;justify-content:center}.data-dismissed-badge svg{width:14px;height:14px}.extracted-data-card.context-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}.extracted-data-card.context-card .extracted-icon{color:#d97706}.extracted-data-card.context-card .extracted-label{color:#92400e}.context-item{display:flex;flex-direction:column;gap:2px;padding:4px 0}.context-item:not(:last-child){border-bottom:1px solid rgba(217,119,6,.2);margin-bottom:4px}.context-category{font-size:11px;font-weight:600;color:#92400e;text-transform:uppercase;letter-spacing:.5px}.coach-quick-actions{display:flex;gap:8px;padding:12px 16px;overflow-x:auto;flex-shrink:0;-webkit-overflow-scrolling:touch}.coach-quick-actions::-webkit-scrollbar{display:none}.quick-action-pill{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border:1px solid #E5E7EB;border-radius:24px;font-size:14px;color:#374151;cursor:pointer;white-space:nowrap;transition:all .2s;flex-shrink:0}.quick-action-pill:hover{background:var(--heiwa-sage-10, #F0F5F1);border-color:var(--heiwa-sage, #7C9A82)}.quick-action-pill:active{transform:scale(.97)}.qa-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px}.qa-icon svg{width:18px;height:18px;stroke:var(--heiwa-sage, #7C9A82)}.qa-label{font-weight:500}.coach-image-preview{position:relative;display:inline-block;margin:0 16px 8px;border-radius:12px;overflow:hidden;background:#f3f4f6;border:2px solid var(--heiwa-sage, #7C9A82);box-shadow:0 2px 8px #0000001a;animation:fadeInScale .2s ease}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.coach-image-preview.compact{width:80px;height:80px}.coach-image-preview.compact img{width:100%;height:100%;object-fit:cover;display:block}.coach-image-preview .remove-preview{position:absolute;top:-6px;right:-6px;width:22px;height:22px;border-radius:50%;background:#ef4444;color:#fff;border:2px solid white;font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #0003;line-height:1}.coach-image-preview .remove-preview:hover{background:#dc2626;transform:scale(1.1)}.coach-image-preview .remove-preview:active{transform:scale(.95)}.coach-input-bar{position:fixed;bottom:calc(60px + env(safe-area-inset-bottom,0));left:0;right:0;display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fff;border-top:1px solid #E5E7EB;z-index:100}.input-action-btn{width:44px;height:44px;border-radius:50%;background:var(--heiwa-sage-10, #F0F5F1);border:none;color:var(--heiwa-sage, #7C9A82);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.input-action-btn:hover{background:var(--heiwa-sage-20, #E0EBE2)}.input-action-btn:disabled{opacity:.5;cursor:not-allowed}.input-action-btn svg{width:22px;height:22px;stroke:var(--heiwa-sage, #7C9A82)}.coach-text-input{flex:1;height:44px;padding:0 16px;border:1px solid #E5E7EB;border-radius:22px;font-size:15px;background:#f9fafb;outline:none;transition:all .2s}.coach-text-input:focus{border-color:var(--heiwa-sage, #7C9A82);background:#fff}.coach-text-input::placeholder{color:#9ca3af}.input-send-btn{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.input-send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #7c9a8266}.input-send-btn:active:not(:disabled){transform:scale(.95)}.input-send-btn:disabled{opacity:.5;cursor:not-allowed}.input-send-btn svg{width:20px;height:20px;stroke:#fff}.clear-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.clear-confirm-modal{background:#fff;border-radius:16px;padding:24px;max-width:320px;width:100%;text-align:center;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.clear-confirm-modal h3{margin:0 0 12px;font-size:18px;font-weight:600;color:#1f2937}.clear-confirm-modal p{margin:0 0 24px;font-size:14px;color:#6b7280;line-height:1.5}.clear-confirm-actions{display:flex;gap:12px}.clear-confirm-cancel,.clear-confirm-ok{flex:1;padding:12px 16px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.clear-confirm-cancel{background:#f3f4f6;color:#4b5563}.clear-confirm-cancel:hover{background:#e5e7eb}.clear-confirm-ok{background:linear-gradient(135deg,#7c9a82,#5a7d5a);color:#fff}.clear-confirm-ok:hover{transform:translateY(-1px);box-shadow:0 4px 12px #7c9a8266}.clear-confirm-ok:active{transform:translateY(0)}.photo-loading-indicator{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 24px;background:linear-gradient(135deg,#f8faf8,#e8ede9);border-radius:16px;min-width:180px}.photo-loading-spinner{position:relative;width:48px;height:48px;display:flex;align-items:center;justify-content:center}.spinner-ring{position:absolute;top:0;right:0;bottom:0;left:0;border:3px solid rgba(124,154,130,.2);border-top-color:#7c9a82;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-icon{display:flex;align-items:center;justify-content:center}.spinner-icon svg{width:20px;height:20px;stroke:#7c9a82}.photo-loading-text{font-size:13px;color:#5a7d5a;font-weight:500;text-align:center;min-height:18px;animation:pulse 2s ease-in-out infinite}[data-theme=dark] .coach-screen-unified{background:#111827}[data-theme=dark] .day-summary-card{background:#1f2937}[data-theme=dark] .day-summary-calories .cal-value{color:#f9fafb}[data-theme=dark] .stat-pill{background:#7c9a8226;color:#d1d5db}[data-theme=dark] .coach-message.assistant .coach-bubble{background:#1f2937;color:#f3f4f6}[data-theme=dark] .coach-message.proactive .coach-bubble{background:linear-gradient(90deg,#7c9a8226,#1f2937)}[data-theme=dark] .coach-empty-state{color:#9ca3af}[data-theme=dark] .quick-action-pill{background:#1f2937;border-color:#374151;color:#d1d5db}[data-theme=dark] .quick-action-pill:hover{background:#7c9a8233;border-color:var(--heiwa-sage)}[data-theme=dark] .coach-input-bar{background:#1f2937;border-color:#374151}[data-theme=dark] .coach-text-input{background:#111827;border-color:#374151;color:#f3f4f6}[data-theme=dark] .coach-text-input:focus{background:#1f2937}[data-theme=dark] .input-action-btn{background:#7c9a8226}[data-theme=dark] .notification-banner{box-shadow:0 4px 20px #0006}[data-theme=dark] .notification-greeting{background:linear-gradient(135deg,#5b7a62,#4a6952)}[data-theme=dark] .notification-reminder{background:linear-gradient(135deg,#c8886c,#b4785c)}[data-theme=dark] .notification-celebration{background:linear-gradient(135deg,#6b7da3,#5a6c93)}[data-theme=dark] .notification-nudge{background:linear-gradient(135deg,#7c9d84,#6c8d74)}[data-theme=dark] .notification-support{background:linear-gradient(135deg,#9889a9,#887999)}[data-theme=dark] .notification-recap{background:linear-gradient(135deg,#4b6a7c,#3a5a6c)}[data-theme=dark] .extracted-data-card{background:linear-gradient(135deg,#10b98126,#10b9811a);border-color:#10b9814d}[data-theme=dark] .extracted-main{color:#f9fafb}[data-theme=dark] .extracted-detail{background:#0000004d;color:#d1d5db}[data-theme=dark] .data-saved-badge{background:#10b98126;border-color:#10b9814d}[data-theme=dark] .extracted-data-card.context-card{background:linear-gradient(135deg,#451a03,#78350f);border-color:#d97706}[data-theme=dark] .extracted-data-card.context-card .extracted-icon,[data-theme=dark] .extracted-data-card.context-card .extracted-label,[data-theme=dark] .context-category{color:#fbbf24}[data-theme=dark] .extracted-data-card.context-card .extracted-main{color:#fef3c7}[data-theme=dark] .coach-bubble.typing .loading-text{color:#86efac}[data-theme=dark] .clear-confirm-modal{background:#1f2937}[data-theme=dark] .clear-confirm-modal h3{color:#f9fafb}[data-theme=dark] .clear-confirm-modal p{color:#9ca3af}[data-theme=dark] .clear-confirm-cancel{background:#374151;color:#d1d5db}[data-theme=dark] .clear-confirm-cancel:hover{background:#4b5563}[data-theme=dark] .coach-image-preview{background:#374151;border-color:var(--heiwa-sage, #7C9A82)}@media (max-width: 380px){.day-summary-calories .cal-value{font-size:28px}.day-summary-calories .cal-target{font-size:18px}.stat-pill{font-size:12px;padding:5px 10px}.quick-action-pill{padding:8px 12px;font-size:13px}.coach-bubble{font-size:14px}.notification-banner{margin:8px 12px;padding:14px}.notification-icon svg{width:24px;height:24px}.notification-message{font-size:14px}.notification-content{padding-right:50px}.notification-btn{width:28px;height:28px}.coach-image-preview.compact{width:64px;height:64px}}@media (prefers-reduced-motion: reduce){.notification-banner,.notification-banner.animating-out,.notification-dot,.coach-message,.day-summary-content,.extracted-data-card,.coach-image-preview{animation:none;transition:none}}.notification-btn:focus-visible,.input-action-btn:focus-visible,.input-send-btn:focus-visible,.quick-action-pill:focus-visible,.save-data-btn:focus-visible,.coach-action-btn:focus-visible{outline:2px solid var(--heiwa-sage, #7C9A82);outline-offset:2px}.coach-text-input:focus-visible{outline:none;border-color:var(--heiwa-sage, #7C9A82);box-shadow:0 0 0 3px #7c9a8233}.photo-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:1rem}.photo-menu{background:var(--bg-primary, #fff);border-radius:16px;width:100%;max-width:400px;overflow:hidden}.photo-menu button{width:100%;padding:1rem;border:none;background:transparent;font-size:1rem;cursor:pointer;border-bottom:1px solid var(--border-color, #eee)}.photo-menu button:active{background:var(--bg-secondary, #f5f5f5)}.photo-menu button.cancel{color:#ef4444;border-bottom:none}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s ease;padding-bottom:calc(60px + env(safe-area-inset-bottom))}.modal-container{background:#fff;border-radius:24px 24px 0 0;width:100%;max-width:500px;max-height:calc(90vh - 60px);overflow-y:auto;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid #F3F4F6;position:sticky;top:0;background:#fff;z-index:10}.modal-header h2{font-size:18px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);margin:0}.modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease}.modal-close svg{width:20px;height:20px;stroke:var(--heiwa-text-secondary, #6B7280)}.modal-close:hover{background:#e5e7eb}.modal-content{padding:20px 20px 24px}.input-mode-toggle{display:flex;gap:8px;background:#f3f4f6;padding:4px;border-radius:12px;margin-bottom:20px}.mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:transparent;border:none;border-radius:10px;font-size:14px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);cursor:pointer;transition:all .2s ease}.mode-btn.active{background:#fff;color:var(--heiwa-text-primary, #1F2937);box-shadow:0 2px 4px #0000001a}.mode-btn .mode-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.mode-btn .mode-icon svg{width:18px;height:18px}.mode-btn.active .mode-icon svg{stroke:var(--heiwa-sage, #7C9A82)}.image-uploader{margin-bottom:20px}.upload-btn{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px 20px;background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:2px dashed #D1D5DB;border-radius:16px;cursor:pointer;transition:all .2s ease}.upload-btn:hover{border-color:var(--heiwa-sage, #7C9A82);background:linear-gradient(135deg,#f0f5f1,#e8ede9)}.upload-btn:disabled{opacity:.5;cursor:not-allowed}.upload-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000001a}.upload-icon svg{width:24px;height:24px;stroke:var(--heiwa-sage, #7C9A82)}.upload-text{font-size:15px;font-weight:500;color:var(--heiwa-text-primary, #1F2937)}.upload-hint{font-size:13px;color:var(--heiwa-text-muted, #9CA3AF)}.image-preview{position:relative;border-radius:16px;overflow:hidden}.image-preview img{width:100%;max-height:300px;object-fit:contain;background:#f3f4f6}.change-image-btn{position:absolute;bottom:12px;right:12px;padding:8px 16px;background:#fffffff2;border:none;border-radius:20px;font-size:13px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);cursor:pointer;box-shadow:0 2px 8px #00000026;transition:all .2s ease}.change-image-btn:hover{background:#fff;color:var(--heiwa-text-primary, #1F2937)}.image-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-spinner{width:32px;height:32px;display:flex;align-items:center;justify-content:center}.loading-spinner svg{width:32px;height:32px;stroke:var(--heiwa-sage, #7C9A82)}.spin{animation:spin 1s linear infinite}.image-loading-overlay span:last-child{font-size:14px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280)}.extracted-data{margin-top:16px;padding:16px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86EFAC;border-radius:16px}.extracted-data h4{font-size:13px;font-weight:600;color:#166534;margin:0 0 12px;text-transform:uppercase;letter-spacing:.3px}.extracted-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.extracted-item{display:flex;flex-direction:column;padding:10px 12px;background:#fff;border-radius:10px}.extracted-item.main{grid-column:span 2;flex-direction:row;align-items:center;justify-content:space-between;background:#166534;color:#fff}.extracted-item .label{font-size:11px;color:var(--heiwa-text-muted, #9CA3AF);text-transform:uppercase;letter-spacing:.2px}.extracted-item.main .label{color:#fffc;font-size:13px}.extracted-item .value{font-size:15px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);margin-top:2px}.extracted-item.main .value{color:#fff;font-size:20px}.input-section{margin-bottom:24px}.input-section label{display:block;font-size:13px;font-weight:600;color:var(--heiwa-text-secondary, #6B7280);margin-bottom:10px;text-transform:uppercase;letter-spacing:.3px}.input-section textarea{width:100%;padding:12px 16px;border:1px solid #E5E7EB;border-radius:12px;font-size:15px;font-family:inherit;resize:none;transition:border-color .2s ease}.input-section textarea:focus{outline:none;border-color:var(--heiwa-sage, #7C9A82)}.modal-save-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;background:var(--heiwa-sage, #7C9A82);border:none;border-radius:14px;font-size:16px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;margin-top:16px}.modal-save-btn:hover:not(:disabled){background:var(--heiwa-sage-dark, #5A7D5A);transform:translateY(-1px)}.modal-save-btn:disabled{opacity:.5;cursor:not-allowed}.modal-save-btn span{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.modal-save-btn svg{width:20px;height:20px;stroke:#fff}.accent-blue .modal-save-btn{background:#3b82f6}.accent-blue .modal-save-btn:hover:not(:disabled){background:#2563eb}.accent-purple .modal-save-btn{background:#a855f7}.accent-purple .modal-save-btn:hover:not(:disabled){background:#9333ea}.accent-pink .modal-save-btn{background:#ec4899}.accent-pink .modal-save-btn:hover:not(:disabled){background:#db2777}.accent-orange .modal-save-btn{background:#f97316}.accent-orange .modal-save-btn:hover:not(:disabled){background:#ea580c}.accent-green .modal-save-btn{background:#22c55e}.accent-green .modal-save-btn:hover:not(:disabled){background:#16a34a}.quick-values{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.quick-value{padding:8px 16px;background:#f3f4f6;border:1px solid transparent;border-radius:20px;font-size:13px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);cursor:pointer;transition:all .2s ease}.quick-value:hover{background:#e5e7eb}.quick-value.active{background:var(--heiwa-sage-10, #F0F5F1);border-color:var(--heiwa-sage, #7C9A82);color:var(--heiwa-sage-dark, #5A7D5A)}.weight-modal{text-align:center}.weight-input-group{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:20px}.weight-adjust{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border:none;border-radius:50%;font-size:24px;color:var(--heiwa-text-secondary, #6B7280);cursor:pointer;transition:all .2s ease}.weight-adjust:hover{background:#e5e7eb;color:var(--heiwa-text-primary, #1F2937)}.weight-display{display:flex;align-items:baseline;gap:4px}.weight-display input{width:100px;font-size:48px;font-weight:700;text-align:center;border:none;background:none;color:var(--heiwa-text-primary, #1F2937)}.weight-display input:focus{outline:none}.weight-display input::placeholder{color:#d1d5db}.weight-display .weight-unit{font-size:20px;color:var(--heiwa-text-muted, #9CA3AF)}.sleep-modal .duration-input-group,.activity-modal .duration-input-group{display:flex;align-items:center;justify-content:center;gap:16px}.adjust-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border:none;border-radius:50%;font-size:20px;color:var(--heiwa-text-secondary, #6B7280);cursor:pointer;transition:all .2s ease}.adjust-btn:hover{background:#e5e7eb}.duration-display{display:flex;align-items:baseline;gap:4px}.duration-display input{width:60px;font-size:32px;font-weight:700;text-align:center;border:none;background:none;color:var(--heiwa-text-primary, #1F2937)}.duration-display input:focus{outline:none}.duration-display span{font-size:16px;color:var(--heiwa-text-muted, #9CA3AF)}.quality-slider{padding:8px 0}.quality-slider input[type=range]{width:100%;height:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(90deg,#fca5a5,#fcd34d,#86efac);border-radius:4px;outline:none}.quality-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;background:#fff;border:3px solid #A855F7;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #00000026}.quality-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:var(--heiwa-text-muted, #9CA3AF)}.quality-value{font-weight:600;color:#a855f7}.times-row{display:flex;gap:16px}.time-input{flex:1}.time-input input[type=time]{width:100%;padding:12px 16px;border:1px solid #E5E7EB;border-radius:12px;font-size:16px;font-family:inherit}.time-input input[type=time]:focus{outline:none;border-color:#a855f7}.mood-options{display:flex;justify-content:space-between;gap:8px;margin-bottom:24px}.mood-option-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;background:#f9fafb;border:2px solid transparent;border-radius:16px;cursor:pointer;transition:all .2s ease}.mood-option-btn:hover{background:#f3f4f6;transform:translateY(-2px)}.mood-option-btn.selected{background:#fdf2f8;border-color:#ec4899}.mood-option-btn .mood-emoji{font-size:32px}.mood-option-btn .mood-label{font-size:11px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280)}.mood-option-btn.selected .mood-label{color:#ec4899}.activity-types{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:24px}.activity-type-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:#fff7ed;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease}.activity-type-btn:hover{background:#ffedd5;transform:translateY(-2px)}.activity-type-btn.selected{border-color:#f97316;background:#fed7aa}.activity-type-btn .activity-icon{font-size:24px}.activity-type-btn .activity-label{font-size:10px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280)}.activity-type-btn.selected .activity-label{color:#c2410c}.calories-input{display:flex;align-items:center;gap:8px}.calories-input input{flex:1;padding:12px 16px;border:1px solid #E5E7EB;border-radius:12px;font-size:16px;font-family:inherit}.calories-input input:focus{outline:none;border-color:#f97316}.calories-input span{font-size:14px;color:var(--heiwa-text-muted, #9CA3AF)}.photo-mode{text-align:left}[data-theme=dark] .modal-container{background:#1f2937}[data-theme=dark] .modal-header{border-color:#ffffff1a;background:#1f2937}[data-theme=dark] .modal-header h2,[data-theme=dark] .weight-display input,[data-theme=dark] .duration-display input{color:#f9fafb}[data-theme=dark] .modal-close,[data-theme=dark] .input-mode-toggle{background:#374151}[data-theme=dark] .mode-btn.active{background:#4b5563;color:#f9fafb}[data-theme=dark] .upload-btn{background:linear-gradient(135deg,#374151,#1f2937);border-color:#4b5563}[data-theme=dark] .upload-text{color:#f9fafb}[data-theme=dark] .upload-icon{background:#4b5563}[data-theme=dark] .quick-value,[data-theme=dark] .weight-adjust,[data-theme=dark] .adjust-btn{background:#374151;color:#9ca3af}[data-theme=dark] .quick-value.active{background:#7c9a8233;border-color:var(--heiwa-sage, #7C9A82);color:var(--heiwa-sage, #7C9A82)}[data-theme=dark] .mood-option-btn,[data-theme=dark] .activity-type-btn{background:#374151}[data-theme=dark] .mood-option-btn.selected{background:#ec489933}[data-theme=dark] .activity-type-btn.selected{background:#f9731633}[data-theme=dark] .input-section textarea,[data-theme=dark] .time-input input,[data-theme=dark] .calories-input input{background:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=dark] .extracted-data{background:linear-gradient(135deg,#16653433,#22c55e1a);border-color:#86efac4d}[data-theme=dark] .extracted-data h4{color:#86efac}[data-theme=dark] .extracted-item{background:#374151}[data-theme=dark] .extracted-item .value{color:#f9fafb}@media (min-width: 500px){.modal-container{border-radius:24px;margin:auto;max-height:85vh}.modal-overlay{align-items:center;padding:20px}}@media (max-width: 360px){.activity-types{grid-template-columns:repeat(3,1fr)}.mood-option-btn .mood-emoji{font-size:28px}.weight-display input{font-size:40px;width:90px}.extracted-grid{grid-template-columns:1fr}.extracted-item.main{grid-column:span 1}}.data-screen{min-height:100%;background:var(--heiwa-cream, #FAF9F6);padding-bottom:calc(80px + env(safe-area-inset-bottom))}.data-header{padding:20px 16px;padding-top:calc(20px + env(safe-area-inset-top));background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);color:#fff}.data-header h1{font-size:24px;font-weight:700;margin:0 0 4px}.data-subtitle{font-size:14px;opacity:.9;margin:0}.data-time-filters{display:flex;gap:8px;padding:16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.data-time-filters::-webkit-scrollbar{display:none}.time-filter{padding:8px 16px;background:#fff;border:1px solid rgba(124,154,130,.2);border-radius:20px;font-size:13px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);cursor:pointer;white-space:nowrap;transition:all .2s ease}.time-filter.active{background:var(--heiwa-sage, #7C9A82);border-color:var(--heiwa-sage, #7C9A82);color:#fff}.time-filter:hover:not(.active){border-color:var(--heiwa-sage, #7C9A82);color:var(--heiwa-sage-dark, #5A7D5A)}.data-quick-add{display:flex;gap:8px;padding:0 16px 16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.data-quick-add::-webkit-scrollbar{display:none}.quick-add-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 16px;background:#fff;border:1px dashed rgba(124,154,130,.3);border-radius:12px;font-size:11px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);cursor:pointer;white-space:nowrap;transition:all .2s ease;min-width:70px}.quick-add-btn:hover{border-color:var(--heiwa-sage, #7C9A82);border-style:solid;background:var(--heiwa-sage-10, #F0F5F1)}.quick-add-btn .qa-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.quick-add-btn .qa-icon svg{width:20px;height:20px;stroke:var(--heiwa-sage, #7C9A82)}.data-sections{padding:0 16px;display:flex;flex-direction:column;gap:12px}.data-section{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #0000000a}.data-section-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px;background:none;border:none;cursor:pointer;transition:background .2s ease}.data-section-header:hover{background:#00000005}.section-header-left{display:flex;align-items:center;gap:12px}.section-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center}.section-icon svg{width:20px;height:20px}.accent-blue .section-icon{background:#eff6ff}.accent-blue .section-icon svg{stroke:#3b82f6}.accent-green .section-icon{background:#f0fdf4}.accent-green .section-icon svg{stroke:#22c55e}.accent-orange .section-icon{background:#fff7ed}.accent-orange .section-icon svg{stroke:#f97316}.accent-purple .section-icon{background:#faf5ff}.accent-purple .section-icon svg{stroke:#a855f7}.accent-pink .section-icon{background:#fdf2f8}.accent-pink .section-icon svg{stroke:#ec4899}.accent-red .section-icon{background:#fef2f2}.accent-red .section-icon svg{stroke:#ef4444}.accent-sage .section-icon{background:var(--heiwa-sage-10, #F0F5F1)}.accent-sage .section-icon svg{stroke:var(--heiwa-sage, #7C9A82)}.data-section-header h3{font-size:15px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);margin:0}.section-count{padding:2px 8px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:10px;font-size:12px;font-weight:600;color:var(--heiwa-sage-dark, #5A7D5A)}.section-toggle{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.section-toggle svg{width:18px;height:18px;stroke:var(--heiwa-text-muted, #9CA3AF)}.data-section-content{padding:0 16px 16px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.weight-data .weight-main{display:flex;align-items:baseline;gap:4px;margin-bottom:16px}.weight-value{font-size:36px;font-weight:700;color:var(--heiwa-text-primary, #1F2937)}.weight-unit{font-size:18px;color:var(--heiwa-text-muted, #9CA3AF)}.weight-change{margin-left:12px;padding:4px 10px;border-radius:12px;font-size:13px;font-weight:600}.weight-change.positive{background:#d1fae5;color:#059669}.weight-change.negative{background:#fee2e2;color:#dc2626}.update-data-btn{display:block;width:100%;padding:10px;margin-top:12px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:10px;font-size:13px;font-weight:500;color:var(--heiwa-text-secondary, #6B7280);cursor:pointer;transition:all .2s ease;text-align:center}.update-data-btn:hover{background:#f3f4f6;border-color:var(--heiwa-sage, #7C9A82);color:var(--heiwa-sage-dark, #5A7D5A)}.body-composition{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.composition-item{display:flex;align-items:center;gap:12px}.comp-label{width:60px;font-size:13px;color:var(--heiwa-text-secondary, #6B7280)}.comp-bar{flex:1;height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden}.comp-fill{height:100%;border-radius:4px;transition:width .5s ease}.comp-fill.muscle{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.comp-fill.fat{background:linear-gradient(90deg,#f97316,#fb923c)}.comp-fill.water{background:linear-gradient(90deg,#06b6d4,#22d3ee)}.comp-value{width:50px;font-size:13px;font-weight:600;color:var(--heiwa-text-primary, #1F2937);text-align:right}.weight-extras{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding-top:12px;border-top:1px solid #F3F4F6}.extra-item{text-align:center;padding:8px;background:#f9fafb;border-radius:8px}.extra-label{display:block;font-size:10px;color:var(--heiwa-text-muted, #9CA3AF);margin-bottom:4px}.extra-value{display:block;font-size:14px;font-weight:600;color:var(--heiwa-text-primary, #1F2937)}.nutrition-summary{margin-bottom:16px}.calories-display{display:flex;align-items:baseline;gap:4px;margin-bottom:12px}.cal-consumed{font-size:32px;font-weight:700;color:var(--heiwa-text-primary, #1F2937)}.cal-separator,.cal-target{font-size:20px;color:var(--heiwa-text-muted, #9CA3AF)}.cal-unit{font-size:14px;color:var(--heiwa-text-muted, #9CA3AF);margin-left:4px}.cal-period{font-size:12px;color:var(--heiwa-text-muted, #9CA3AF);margin-left:8px;font-style:italic}.macros-row{display:flex;gap:12px}.macro-item{flex:1;text-align:center;padding:10px;background:#f9fafb;border-radius:10px}.macro-value{display:block;font-size:16px;font-weight:700;color:var(--heiwa-text-primary, #1F2937)}.macro-label{display:block;font-size:11px;color:var(--heiwa-text-muted, #9CA3AF);margin-top:2px}.meals-list h4{font-size:12px;font-weight:600;color:var(--heiwa-text-secondary, #6B7280);margin:0 0 8px;text-transform:uppercase;letter-spacing:.3px}.meal-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #F3F4F6}.meal-item:last-child{border-bottom:none}.meal-time{font-size:12px;color:var(--heiwa-text-muted, #9CA3AF);width:50px}.meal-desc{flex:1;font-size:14px;color:var(--heiwa-text-primary, #1F2937)}.meal-cal{font-size:13px;font-weight:600;color:var(--heiwa-sage-dark, #5A7D5A)}.activity-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.activity-stat{text-align:center;padding:12px;background:#fff7ed;border-radius:12px}.stat-big{display:block;font-size:24px;font-weight:700;color:#f97316}.stat-label{display:block;font-size:11px;color:var(--heiwa-text-muted, #9CA3AF);margin-top:4px}.activity-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #F3F4F6}.activity-item:last-child{border-bottom:none}.activity-type{flex:1;font-size:14px;color:var(--heiwa-text-primary, #1F2937)}.activity-duration{font-size:13px;color:var(--heiwa-text-secondary, #6B7280)}.activity-burned{font-size:13px;font-weight:600;color:#f97316}.sleep-data .sleep-main{display:flex;align-items:baseline;gap:16px;margin-bottom:12px}.sleep-duration{font-size:32px;font-weight:700;color:#a855f7}.sleep-quality{font-size:14px;color:var(--heiwa-text-secondary, #6B7280)}.sleep-details{display:flex;gap:16px;font-size:13px;color:var(--heiwa-text-muted, #9CA3AF)}.sleep-times{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--heiwa-text-secondary, #6B7280);margin-bottom:12px}.sleep-quality-avg{font-size:14px;color:var(--heiwa-text-secondary, #6B7280)}.mood-data{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.mood-emoji{font-size:40px}.mood-label{font-size:16px;font-weight:500;color:var(--heiwa-text-primary, #1F2937)}.mood-notes{width:100%;margin:8px 0 0;padding:10px;background:#f9fafb;border-radius:8px;font-size:13px;font-style:italic;color:var(--heiwa-text-secondary, #6B7280)}.mood-picker{display:flex;gap:12px;justify-content:center;margin-top:12px}.mood-option{font-size:28px;padding:8px;background:none;border:2px solid transparent;border-radius:50%;cursor:pointer;transition:all .2s ease}.mood-option:hover{transform:scale(1.2);border-color:var(--heiwa-sage, #7C9A82)}.health-placeholder{font-size:14px;color:var(--heiwa-text-muted, #9CA3AF);text-align:center;padding:20px;font-style:italic}.section-empty{text-align:center;padding:16px}.section-empty p{font-size:14px;color:var(--heiwa-text-muted, #9CA3AF);margin:0 0 12px}.add-data-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:var(--heiwa-sage-10, #F0F5F1);border:none;border-radius:20px;font-size:13px;font-weight:500;color:var(--heiwa-sage-dark, #5A7D5A);cursor:pointer;transition:all .2s ease}.add-data-btn:hover{background:var(--heiwa-sage-20, #E1EBE3)}.add-data-btn span{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.add-data-btn svg{width:16px;height:16px;stroke:var(--heiwa-sage, #7C9A82)}[data-theme=dark] .data-screen{background:#111827}[data-theme=dark] .time-filter{background:#1f2937;border-color:#7c9a8233;color:#9ca3af}[data-theme=dark] .time-filter.active{background:var(--heiwa-sage, #7C9A82);color:#fff}[data-theme=dark] .quick-add-btn{background:#1f2937;border-color:#7c9a824d}[data-theme=dark] .data-section{background:#1f2937}[data-theme=dark] .data-section-header h3,[data-theme=dark] .weight-value,[data-theme=dark] .cal-consumed,[data-theme=dark] .comp-value,[data-theme=dark] .extra-value,[data-theme=dark] .macro-value,[data-theme=dark] .meal-desc,[data-theme=dark] .activity-type,[data-theme=dark] .mood-label{color:#f9fafb}[data-theme=dark] .comp-bar,[data-theme=dark] .macro-item,[data-theme=dark] .activity-stat,[data-theme=dark] .extra-item{background:#ffffff0d}[data-theme=dark] .meal-item,[data-theme=dark] .activity-item{border-color:#ffffff1a}@media (max-width: 360px){.weight-extras,.activity-summary{grid-template-columns:repeat(2,1fr)}.activity-summary .activity-stat:last-child{grid-column:1 / -1}}.meal-item,.activity-item{position:relative}.delete-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s ease;color:#9ca3af}.meal-item:hover .delete-btn,.activity-item:hover .delete-btn{opacity:1}.delete-btn:hover{background:#ef44441a;color:#ef4444}.delete-btn svg{width:16px;height:16px}.delete-btn.confirm{opacity:1;background:#ef4444;color:#fff;animation:pulse-delete .5s ease infinite alternate}.meal-item.confirm-delete,.activity-item.confirm-delete{background:#ef44440d;border-color:#ef44444d}@keyframes pulse-delete{0%{transform:translateY(-50%) scale(1)}to{transform:translateY(-50%) scale(1.1)}}.meal-item,.activity-item{padding-right:44px!important}@media (max-width: 768px){.delete-btn{opacity:.5}.meal-item:hover .delete-btn,.activity-item:hover .delete-btn{opacity:1}}[data-theme=dark] .delete-btn{color:#6b7280}[data-theme=dark] .delete-btn:hover{background:#ef444433;color:#f87171}[data-theme=dark] .delete-btn.confirm{background:#dc2626;color:#fff}[data-theme=dark] .meal-item.confirm-delete,[data-theme=dark] .activity-item.confirm-delete{background:#ef44441a}.chart-container{margin-top:16px;padding:8px 0}.legend-item .dot.blue{background:#5b6fbf}.legend-item .dot.blue.dashed{border-color:#5b6fbf}.weight-section{padding:8px 0}.weight-stats-row{display:flex;align-items:center;gap:16px;margin-bottom:16px}.weight-stat{display:flex;flex-direction:column;align-items:center}.weight-stat.main{display:flex;flex-direction:row;align-items:baseline;gap:4px}.weight-stat.main .stat-value{font-size:32px;font-weight:700;color:var(--heiwa-text-primary, #1F2937)}.weight-stat.main .stat-unit{font-size:16px;color:var(--heiwa-text-secondary, #6B7280)}.weight-stat.change{display:flex;flex-direction:row;align-items:center;gap:4px;padding:6px 12px;border-radius:20px;font-size:14px;font-weight:600}.weight-stat.change.positive{background:#10b9811a;color:#10b981}.weight-stat.change.negative{background:#ef44441a;color:#ef4444}.weight-stat.change .stat-icon{width:16px;height:16px}.weight-stat.change .stat-icon svg{width:100%;height:100%}.weight-stat.target{margin-left:auto;text-align:right}.weight-stat.target .stat-label{font-size:11px;color:var(--heiwa-text-secondary, #6B7280)}.weight-stat.target .stat-value{font-size:16px;font-weight:600;color:#10b981}.weight-insight{margin-top:16px;padding:12px 16px;border-radius:12px;font-size:13px;line-height:1.5}.nutrition-section{padding:8px 0}.nutrition-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.nutrition-stat{text-align:center}.nutrition-stat .stat-big{display:block;font-size:24px;font-weight:700;color:var(--heiwa-text-primary, #1F2937)}.nutrition-stat .stat-label{font-size:11px;color:var(--heiwa-text-secondary, #6B7280)}.nutrition-stat.highlight .stat-big{color:#f59e0b}.activity-section{padding:8px 0}.activity-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.activity-stat{text-align:center}.activity-stat .stat-big{display:block;font-size:24px;font-weight:700;color:var(--heiwa-text-primary, #1F2937)}.activity-stat .stat-label{font-size:11px;color:var(--heiwa-text-secondary, #6B7280)}.training-load-mini{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:12px;margin-bottom:16px}.training-load-mini.healthy{background:#10b9811a}.training-load-mini.warning{background:#f59e0b1a}.training-load-mini.alert{background:#ef44441a}.training-load-mini.low{background:#6b72801a}.load-info{display:flex;align-items:baseline;gap:8px}.training-load-mini.healthy .load-value{color:#10b981}.training-load-mini.warning .load-value{color:#f59e0b}.training-load-mini.alert .load-value{color:#ef4444}.load-status{font-size:12px;font-weight:500}.training-load-mini.healthy .load-status{color:#065f46}.training-load-mini.warning .load-status{color:#92400e}.training-load-mini.alert .load-status{color:#991b1b}.wellbeing-section{padding:8px 0}.wellbeing-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.wellbeing-card{display:flex;align-items:center;gap:12px;padding:16px;background:#7c9a820d;border-radius:12px}.wellbeing-icon{width:32px;height:32px;color:var(--heiwa-sage, #7C9A82)}.wellbeing-icon svg{width:100%;height:100%}.wellbeing-data{display:flex;flex-direction:column}.wellbeing-value{font-size:20px;font-weight:600}.wellbeing-label{font-size:11px;color:var(--heiwa-text-secondary, #6B7280)}.quick-mood{text-align:center;padding:16px;background:#7c9a820d;border-radius:12px}.quick-mood-label{display:block;font-size:13px;color:var(--heiwa-text-secondary, #6B7280);margin-bottom:12px}.mood-picker{display:flex;justify-content:center;gap:12px}.mood-option{font-size:28px;background:none;border:none;cursor:pointer;transition:transform .2s;padding:4px}.mood-option:hover{transform:scale(1.2)}.correlation-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff;border-radius:12px;border:1px solid var(--heiwa-border, #E5E7EB)}.correlation-item.positive{border-left:3px solid #10B981}.correlation-item.neutral{border-left:3px solid #6B7280}.correlation-insight{margin-top:16px;padding:12px 16px;background:#5b6fbf1a;border-radius:12px}.correlation-insight p{margin:0;font-size:13px;color:#3730a3;line-height:1.5}[data-theme=dark] .chart-container{background:var(--heiwa-dark-card, #1E2A1E);border-radius:12px;padding:12px}[data-theme=dark] .weight-insight,[data-theme=dark] .training-load-mini,[data-theme=dark] .wellbeing-card,[data-theme=dark] .quick-mood{background:var(--heiwa-dark-hover, #2A3A2A)}[data-theme=dark] .correlation-item{background:var(--heiwa-dark-card, #1E2A1E);border-color:var(--heiwa-dark-border, #374137)}[data-theme=dark] .correlation-insight{background:#5b6fbf33}[data-theme=dark] .weight-stat.main .stat-value,[data-theme=dark] .nutrition-stat .stat-big,[data-theme=dark] .activity-stat .stat-big,[data-theme=dark] .wellbeing-value,[data-theme=dark] .correlation-title{color:var(--heiwa-dark-text, #E5E7EB)}.chart-container{margin:16px 0;padding:8px 0}.chart-empty{text-align:center;padding:24px 16px;color:var(--heiwa-text-secondary, #6B7280)}.chart-empty p{margin:0;font-size:14px}.chart-hint{font-size:12px!important;margin-top:8px!important;opacity:.7}.chart-legend{display:flex;justify-content:center;gap:16px;margin-top:12px;font-size:11px;color:var(--heiwa-text-secondary, #6B7280)}.legend-item{display:flex;align-items:center;gap:6px}.legend-item .dot{width:10px;height:10px;border-radius:50%}.legend-item .dot.sage{background:var(--heiwa-sage, #7C9A82)}.legend-item .dot.green{background:#10b981}.legend-item .dot.dashed{border:2px dashed;background:transparent}.legend-item .dot.green.dashed{border-color:#10b981}.weight-insight{margin:16px 0;padding:12px 16px;border-radius:12px;font-size:13px;line-height:1.5}.weight-insight p{margin:0}.weight-insight.healthy,.weight-insight.stable{background:#10b9811a;color:#065f46}.weight-insight.warning{background:#f59e0b1a;color:#92400e}.weight-insight.alert{background:#ef44441a;color:#991b1b}.weight-insight.info{background:#7c9a821a;color:var(--heiwa-sage-dark, #5A7D5A)}.training-load-card{padding:14px 16px;border-radius:12px;margin:16px 0;border-left:4px solid}.training-load-card.healthy{background:#10b9811a;border-color:#10b981}.training-load-card.warning{background:#f59e0b1a;border-color:#f59e0b}.training-load-card.alert{background:#ef44441a;border-color:#ef4444}.training-load-card.info,.training-load-card.low{background:#6b72801a;border-color:#6b7280}.load-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.load-label{font-size:12px;color:var(--heiwa-text-secondary, #6B7280)}.load-value{font-size:20px;font-weight:700}.training-load-card.healthy .load-value{color:#10b981}.training-load-card.warning .load-value{color:#f59e0b}.training-load-card.alert .load-value{color:#ef4444}.load-status{font-size:13px;font-weight:500}.correlations-empty{text-align:center;padding:24px 16px;color:var(--heiwa-text-secondary, #6B7280)}.correlations-empty p{margin:0;font-size:14px}.correlations-empty .hint{font-size:12px;margin-top:8px;opacity:.7}.correlations-list{display:flex;flex-direction:column;gap:12px}.correlation-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#f9fafb;border-radius:12px;border-left:3px solid}.correlation-item.positive{border-color:#10b981}.correlation-item.neutral{border-color:#6b7280}.correlation-item.negative{border-color:#f59e0b}.correlation-icon{font-size:20px}.correlation-content{flex:1}.correlation-title{display:block;font-size:14px;font-weight:600;color:var(--heiwa-text-primary, #1F2937)}.correlation-desc{display:block;font-size:12px;color:var(--heiwa-text-secondary, #6B7280);margin-top:2px}.correlation-strength{font-size:14px;font-weight:600;color:var(--heiwa-sage, #7C9A82)}.section-badge{padding:2px 8px;background:#d1fae5;border-radius:10px;font-size:12px;font-weight:600;color:#065f46}[data-theme=dark] .chart-container{background:#ffffff05;border-radius:12px;padding:12px}[data-theme=dark] .weight-insight,[data-theme=dark] .training-load-card,[data-theme=dark] .correlation-item{background:#ffffff0d}[data-theme=dark] .correlation-title{color:#f9fafb}.today-timeline{padding:8px 0}.timeline-empty{text-align:center;padding:40px 20px;color:#6b7280}.timeline-empty-icon{width:48px;height:48px;margin:0 auto 16px;border-radius:50%;background:linear-gradient(135deg,#e8ede9,#d4ddd6);position:relative}.timeline-empty-icon:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid #9CA3AF;border-radius:50%}.timeline-empty-icon:after{content:"";position:absolute;top:12px;left:50%;transform:translate(-50%);width:2px;height:12px;background:#9ca3af;border-radius:1px}.timeline-empty p{font-size:15px;font-weight:500;margin:0 0 4px}.timeline-empty-hint{font-size:13px;color:#9ca3af}.timeline-item{display:grid;grid-template-columns:50px 32px 1fr;gap:12px;min-height:80px;position:relative}.timeline-time{display:flex;align-items:flex-start;justify-content:flex-end;padding-top:12px}.timeline-time span{font-size:12px;font-weight:600;color:#6b7280;font-variant-numeric:tabular-nums}.timeline-marker{display:flex;flex-direction:column;align-items:center;position:relative}.timeline-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:2}.timeline-sleep .timeline-dot{background:linear-gradient(135deg,#818cf8,#6366f1);box-shadow:0 4px 12px #6366f14d}.timeline-sleep .timeline-dot:before{content:"";width:14px;height:14px;border-radius:50%;background:transparent;border:2px solid rgba(255,255,255,.9);clip-path:polygon(100% 0%,100% 100%,50% 100%,50% 50%,0% 50%,0% 0%)}.timeline-weight .timeline-dot{background:linear-gradient(135deg,#60a5fa,#3b82f6);box-shadow:0 4px 12px #3b82f64d}.timeline-weight .timeline-dot:before{content:"";width:12px;height:12px;background:#fff;border-radius:50%;opacity:.9}.timeline-meal .timeline-dot{background:linear-gradient(135deg,#7c9a82,#5a7d5a);box-shadow:0 4px 12px #7c9a824d}.timeline-meal .timeline-dot:before{content:"";width:10px;height:10px;background:#fff;border-radius:2px;opacity:.9}.timeline-activity .timeline-dot{background:linear-gradient(135deg,#fb923c,#f97316);box-shadow:0 4px 12px #f973164d}.timeline-activity .timeline-dot:before{content:"";width:14px;height:2px;background:#fff;position:relative}.timeline-activity .timeline-dot:after{content:"";position:absolute;width:8px;height:8px;border-top:2px solid white;border-right:2px solid white;transform:rotate(45deg) translate(-2px)}.timeline-mood .timeline-dot{background:linear-gradient(135deg,#f472b6,#ec4899);box-shadow:0 4px 12px #ec48994d}.timeline-mood .timeline-dot:before{content:"";width:10px;height:10px;background:#fff;border-radius:50%;opacity:.9}.timeline-line{width:2px;flex:1;background:linear-gradient(180deg,#d1d5db,#e5e7eb);margin-top:4px;border-radius:1px}.timeline-content{padding:8px 0 16px}.timeline-card{background:#fff;border-radius:12px;padding:12px 14px;box-shadow:0 1px 3px #0000000f;border:1px solid #F3F4F6;transition:all .2s ease}.timeline-card:hover{box-shadow:0 4px 12px #00000014}.timeline-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.timeline-card-title{font-size:14px;font-weight:600;color:#1f2937}.timeline-card-meta{font-size:11px;color:#9ca3af;font-weight:500}.timeline-card-body{color:#4b5563}.timeline-delete-btn{width:28px;height:28px;border-radius:6px;border:none;background:#f3f4f6;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:relative}.timeline-delete-btn:before{content:"";width:12px;height:2px;background:#9ca3af;border-radius:1px;transform:rotate(45deg);position:absolute}.timeline-delete-btn:after{content:"";width:12px;height:2px;background:#9ca3af;border-radius:1px;transform:rotate(-45deg);position:absolute}.timeline-delete-btn:hover{background:#fee2e2}.timeline-delete-btn:hover:before,.timeline-delete-btn:hover:after{background:#ef4444}.timeline-delete-btn.confirm{background:#ef4444}.timeline-delete-btn.confirm:before{width:6px;height:10px;border-right:2px solid white;border-bottom:2px solid white;background:transparent;transform:rotate(45deg) translate(-1px,-1px)}.timeline-delete-btn.confirm:after{display:none}.timeline-card.confirm-delete{border-color:#fecaca;background:#fef2f2}.sleep-card{border-left:3px solid #6366F1}.timeline-stat-row{display:flex;gap:24px}.timeline-stat{display:flex;flex-direction:column}.timeline-stat .stat-value{font-size:18px;font-weight:700;color:#1f2937}.timeline-stat .stat-label{font-size:11px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.weight-card{border-left:3px solid #3B82F6}.weight-main-value{display:flex;align-items:baseline;gap:4px}.weight-main-value .weight-number{font-size:24px;font-weight:700;color:#1f2937}.weight-main-value .weight-unit{font-size:14px;color:#6b7280;font-weight:500}.weight-composition{display:flex;gap:16px;margin-top:8px;font-size:12px;color:#6b7280}.meal-card{border-left:3px solid #7C9A82}.meal-description{font-size:13px;color:#4b5563;margin:0 0 8px;line-height:1.4}.meal-stats{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.meal-calories{font-size:14px;font-weight:600;color:#7c9a82;background:#7c9a821a;padding:4px 10px;border-radius:20px}.meal-macro{font-size:11px;color:#6b7280;background:#f3f4f6;padding:3px 8px;border-radius:12px}.activity-card{border-left:3px solid #F97316}.activity-stats{display:flex;gap:16px}.activity-duration{font-size:14px;font-weight:600;color:#1f2937}.activity-burned{font-size:14px;font-weight:600;color:#10b981}.mood-card{border-left:3px solid #EC4899}.mood-display{display:flex;align-items:center;gap:12px}.mood-indicator{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center}.mood-indicator.level-1{background:linear-gradient(135deg,#fca5a5,#ef4444)}.mood-indicator.level-2{background:linear-gradient(135deg,#fdba74,#f97316)}.mood-indicator.level-3{background:linear-gradient(135deg,#d1d5db,#9ca3af)}.mood-indicator.level-4{background:linear-gradient(135deg,#86efac,#22c55e)}.mood-indicator.level-5{background:linear-gradient(135deg,#6ee7b7,#10b981)}.mood-level{font-size:12px;font-weight:700;color:#fff}.mood-label-text{font-size:14px;font-weight:500;color:#1f2937}.mood-notes{font-size:12px;color:#6b7280;margin:8px 0 0;font-style:italic}.timeline-summary{display:flex;justify-content:space-around;align-items:center;background:linear-gradient(135deg,#f8faf8,#f0f4f1);border-radius:16px;padding:16px;margin-top:8px;border:1px solid rgba(124,154,130,.15)}.summary-stat{display:flex;flex-direction:column;align-items:center;text-align:center}.summary-value{font-size:20px;font-weight:700;color:#1f2937}.summary-value.negative{color:#10b981}.summary-value.total{color:#7c9a82}.summary-label{font-size:10px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.summary-divider{width:1px;height:32px;background:#7c9a8233}.health-indicators{padding:8px 0}.health-intro{text-align:center;margin-bottom:20px}.health-intro p{font-size:13px;color:#6b7280;margin:0}.health-intro strong{color:#1f2937}.health-empty{text-align:center;padding:32px 20px;color:#6b7280}.health-empty p{font-size:14px;margin:0 0 4px}.health-empty-hint{font-size:12px;color:#9ca3af}.health-indicator{background:#fff;border-radius:12px;padding:14px 16px;margin-bottom:12px;border:1px solid #F3F4F6;transition:all .2s ease}.health-indicator:hover{box-shadow:0 4px 12px #0000000f}.health-indicator.good{border-left:3px solid #10B981}.health-indicator.warning{border-left:3px solid #F59E0B}.indicator-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.indicator-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.health-indicator:nth-child(2) .indicator-icon{background:linear-gradient(135deg,#fecaca,#fca5a5)}.health-indicator:nth-child(2) .indicator-icon:before{content:"";width:18px;height:14px;background:linear-gradient(135deg,#dc2626,#b91c1c);border-radius:40% 60% 50% 50%}.health-indicator:nth-child(3) .indicator-icon{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.health-indicator:nth-child(3) .indicator-icon:before{content:"";width:16px;height:16px;background:linear-gradient(135deg,#10b981,#059669);border-radius:80% 0;transform:rotate(45deg)}.health-indicator:nth-child(4) .indicator-icon{background:linear-gradient(135deg,#fef3c7,#fde68a)}.health-indicator:nth-child(4) .indicator-icon:before{content:"";width:18px;height:6px;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:20px 20px 4px 4px}.health-indicator:nth-child(4) .indicator-icon:after{content:"";position:absolute;width:18px;height:5px;background:linear-gradient(135deg,#d97706,#b45309);border-radius:4px 4px 20px 20px;margin-top:14px}.health-indicator:nth-child(5) .indicator-icon{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.health-indicator:nth-child(5) .indicator-icon:before{content:"";width:12px;height:16px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%/30% 30% 70% 70%}.indicator-info{flex:1;min-width:0}.indicator-label{display:block;font-size:14px;font-weight:600;color:#1f2937;margin-bottom:2px}.indicator-recommendation{display:block;font-size:11px;color:#6b7280}.health-indicator.good .indicator-recommendation{color:#10b981}.health-indicator.warning .indicator-recommendation{color:#f59e0b}.indicator-value{display:flex;align-items:baseline;gap:2px;flex-shrink:0}.value-current{font-size:20px;font-weight:700;color:#1f2937}.value-separator{font-size:14px;color:#9ca3af;margin:0 2px}.value-limit{font-size:14px;color:#9ca3af;font-weight:500}.value-unit{font-size:10px;color:#9ca3af;margin-left:4px}.indicator-bar{height:6px;background:#f3f4f6;border-radius:3px;overflow:hidden;position:relative}.indicator-fill{height:100%;border-radius:3px;transition:width .5s ease}.health-indicator.good .indicator-fill{background:linear-gradient(90deg,#10b981,#34d399)}.health-indicator.warning .indicator-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.indicator-bar.inverse .indicator-fill{background:linear-gradient(90deg,#10b981,#34d399)}.indicator-limit-marker{position:absolute;top:-2px;width:2px;height:10px;background:#6b7280;border-radius:1px;transform:translate(-50%)}.health-score{display:flex;flex-direction:column;align-items:center;padding:24px 16px;margin-top:8px;background:linear-gradient(135deg,#f8faf8,#e8ede9);border-radius:16px;border:1px solid rgba(124,154,130,.2)}.score-circle{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#7c9a82,#5a7d5a);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #7c9a824d;position:relative}.score-circle:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;background:#fff}.score-value{position:relative;z-index:1;font-size:22px;font-weight:700;color:#1f2937}.score-label{margin-top:12px;font-size:13px;color:#6b7280;font-weight:500}@media (max-width: 380px){.timeline-item{grid-template-columns:40px 28px 1fr;gap:8px}.timeline-time span{font-size:11px}.timeline-dot{width:28px;height:28px}.timeline-summary{padding:12px}.summary-value{font-size:16px}.indicator-header{flex-wrap:wrap}.indicator-value{margin-left:auto}}.heiwa-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background:#fff;border-top:1px solid rgba(45,90,71,.1);padding-bottom:env(safe-area-inset-bottom);z-index:100}.nav-indicator{position:absolute;top:0;left:0;width:33.333%;height:3px;background:var(--heiwa-gradient-sage, linear-gradient(90deg, #2d5a47 0%, #4a7c64 100%));border-radius:0 0 3px 3px;transition:transform .3s cubic-bezier(.4,0,.2,1)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:12px 8px;min-height:60px;background:none;border:none;cursor:pointer;transition:all .2s ease;position:relative;-webkit-tap-highlight-color:transparent}.nav-item:active{transform:scale(.95)}.nav-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.nav-icon svg{width:24px;height:24px;stroke:#9ca3af;transition:all .2s ease}.nav-item.active .nav-icon svg{stroke:var(--heiwa-sage, #2d5a47)}.nav-label{font-size:11px;font-weight:500;color:#9ca3af;transition:all .2s ease}.nav-item.active .nav-label{font-weight:600;color:var(--heiwa-sage, #2d5a47)}.nav-item:hover:not(.active) .nav-icon svg{stroke:var(--heiwa-sage-light, #4a7c64)}.nav-item:hover:not(.active) .nav-label{color:var(--heiwa-sage-light, #4a7c64)}[data-theme=dark] .heiwa-nav{background:#1e1e1e;border-color:#4a7c6433}[data-theme=dark] .nav-icon svg{stroke:#6b7280}[data-theme=dark] .nav-item.active .nav-icon svg{stroke:#86efac}[data-theme=dark] .nav-label{color:#6b7280}[data-theme=dark] .nav-item.active .nav-label{color:#86efac}[data-theme=dark] .nav-indicator{background:linear-gradient(90deg,#4a7c64,#86efac)}@media (min-width: 769px){.heiwa-nav{position:absolute;border-radius:0 0 32px 32px}}@media (prefers-reduced-motion: reduce){.nav-indicator{transition:none}.nav-item,.nav-icon,.nav-icon svg,.nav-label{transition:none}}.settings-button{position:fixed;top:calc(12px + env(safe-area-inset-top,0));right:12px;width:40px;height:40px;border-radius:50%;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(45,90,71,.1);box-shadow:0 2px 8px #00000014;cursor:pointer;z-index:200;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.settings-button:hover{background:#fff;box-shadow:0 4px 12px #0000001f;transform:scale(1.05)}.settings-button:active{transform:scale(.95)}.settings-button svg{width:20px;height:20px;stroke:var(--heiwa-sage, #2d5a47);transition:transform .3s ease}[data-theme=dark] .settings-button{background:#1f2937e6;border-color:#86efac33}[data-theme=dark] .settings-button:hover{background:#1f2937}[data-theme=dark] .settings-button svg{stroke:#86efac}@media (min-width: 769px){.settings-button{position:absolute;top:16px;right:16px}}@media (prefers-reduced-motion: reduce){.settings-button,.settings-button svg{transition:none}}.settings-button:focus-visible{outline:2px solid var(--heiwa-sage, #2d5a47);outline-offset:2px}.memory-panel{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;max-width:100vw;box-sizing:border-box;background:var(--heiwa-cream, #FAF9F6);z-index:1000;display:flex;flex-direction:column;overflow:hidden}.memory-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0));background:linear-gradient(135deg,var(--heiwa-sage, #7C9A82) 0%,var(--heiwa-sage-dark, #5A7D5A) 100%);color:#fff;flex-shrink:0}.memory-header-left{display:flex;align-items:center;gap:12px}.memory-back{width:36px;height:36px;border-radius:50%;background:#ffffff26;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.memory-back:hover{background:#ffffff40}.memory-back svg{width:20px;height:20px}.memory-header h2{font-size:18px;font-weight:600;margin:0}.memory-edit-toggle{padding:8px 16px;border-radius:20px;background:#ffffff26;border:none;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.memory-edit-toggle:hover{background:#ffffff40}.memory-edit-toggle.active{background:#fff;color:var(--heiwa-sage, #7C9A82)}.memory-tabs{display:flex;gap:4px;padding:12px 16px;background:#fff;border-bottom:1px solid #E5E7EB;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-shrink:0;max-width:100%;box-sizing:border-box}.memory-tabs::-webkit-scrollbar{display:none}.memory-tab{display:flex;align-items:center;gap:6px;padding:10px 14px;border-radius:20px;background:transparent;border:1px solid #E5E7EB;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;white-space:nowrap;transition:all .2s;flex-shrink:0}.memory-tab .tab-icon{display:flex;align-items:center;justify-content:center}.memory-tab .tab-icon svg{width:16px;height:16px;stroke:currentColor}.memory-tab:hover{background:var(--heiwa-sage-10, #F0F5F1);border-color:var(--heiwa-sage, #7C9A82)}.memory-tab.active{background:var(--heiwa-sage, #7C9A82);border-color:var(--heiwa-sage, #7C9A82);color:#fff}.memory-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px;-webkit-overflow-scrolling:touch;max-width:100%;box-sizing:border-box}.memory-section{display:flex;flex-direction:column;gap:16px}.memory-category{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 8px #0000000f;max-width:100%;box-sizing:border-box;overflow:hidden}.memory-category h4{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:600;color:#1f2937;margin:0 0 12px}.category-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.category-icon svg{width:20px;height:20px;stroke:var(--heiwa-sage, #7C9A82)}.category-icon-warning svg{stroke:#f59e0b}.category-hint{font-size:12px;color:#9ca3af;margin:8px 0 0;font-style:italic}.memory-items{display:flex;flex-wrap:wrap;gap:8px;max-width:100%}.memory-item{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:20px;font-size:14px;color:#374151;max-width:100%;box-sizing:border-box}.item-text{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-remove{width:20px;height:20px;border-radius:50%;background:#ef44441a;border:none;color:#ef4444;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.item-remove:hover{background:#ef4444;color:#fff}.trigger-item{justify-content:space-between}.trigger-confidence{font-size:11px;color:var(--heiwa-sage, #7C9A82);font-weight:600;background:#7c9a8226;padding:2px 6px;border-radius:10px}.memory-empty-inline{padding:16px;text-align:center;color:#9ca3af;font-size:14px;background:#f9fafb;border-radius:12px;border:1px dashed #E5E7EB}.constraint-category .memory-item{background:#fef3c7;color:#92400e}.constraint-category .memory-items{gap:10px}.objective-category{background:linear-gradient(135deg,var(--heiwa-sage-10, #F0F5F1) 0%,#E8F0E9 100%);border:1px solid var(--heiwa-sage-20, rgba(124, 154, 130, .2))}.objective-display{padding:12px;background:#fff;border-radius:12px}.objective-text{font-size:15px;color:#1f2937;margin:0 0 10px;line-height:1.5}.objective-parsed{display:flex;flex-wrap:wrap;gap:8px}.parsed-tag{font-size:12px;padding:4px 10px;background:var(--heiwa-sage-10, #F0F5F1);border-radius:12px;color:var(--heiwa-sage-dark, #5A7D5A);font-weight:500}.add-item-btn{padding:8px 16px;margin-top:12px;border-radius:20px;background:transparent;border:1px dashed #D1D5DB;color:#6b7280;font-size:13px;cursor:pointer;transition:all .2s}.add-item-btn:hover{border-color:var(--heiwa-sage, #7C9A82);color:var(--heiwa-sage, #7C9A82);background:var(--heiwa-sage-10, #F0F5F1)}.add-item-form{display:flex;gap:8px;margin-top:12px}.add-item-form input{flex:1;min-width:0;padding:10px 14px;border:1px solid #D1D5DB;border-radius:20px;font-size:14px;outline:none;transition:border-color .2s}.add-item-form input:focus{border-color:var(--heiwa-sage, #7C9A82)}.add-confirm,.add-cancel{width:36px;height:36px;border-radius:50%;border:none;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.add-confirm{background:var(--heiwa-sage, #7C9A82);color:#fff}.add-confirm:hover{background:var(--heiwa-sage-dark, #5A7D5A)}.add-cancel{background:#f3f4f6;color:#6b7280}.add-cancel:hover{background:#e5e7eb}.style-options{margin-bottom:20px}.style-options:last-child{margin-bottom:0}.style-options label{display:block;font-size:13px;font-weight:500;color:#6b7280;margin-bottom:10px}.style-buttons{display:flex;flex-wrap:wrap;gap:8px}.style-btn{padding:10px 16px;border-radius:20px;background:#fff;border:1px solid #E5E7EB;font-size:13px;color:#374151;cursor:pointer;transition:all .2s}.style-btn:hover{border-color:var(--heiwa-sage, #7C9A82);background:var(--heiwa-sage-10, #F0F5F1)}.style-btn.active{background:var(--heiwa-sage, #7C9A82);border-color:var(--heiwa-sage, #7C9A82);color:#fff}.stats-category{background:linear-gradient(135deg,var(--heiwa-sage-10, #F0F5F1) 0%,#E8F0E9 100%)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-value{font-size:28px;font-weight:700;color:var(--heiwa-sage-dark, #5A7D5A)}.stat-label{font-size:12px;color:#6b7280;margin-top:4px}.sources-category{background:#f9fafb}.sources-category h4{font-size:13px;color:#6b7280}.sources-list{display:flex;flex-direction:column;gap:10px}.source-item{display:flex;align-items:center;gap:10px;font-size:13px;color:#6b7280}.source-dot{width:8px;height:8px;border-radius:50%;background:#d1d5db;flex-shrink:0}.source-dot.active{background:#10b981}.memory-footer{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0));background:#fff;border-top:1px solid #E5E7EB;flex-shrink:0}.memory-reset{width:100%;padding:14px;border-radius:12px;background:#fee2e2;border:none;color:#dc2626;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.memory-reset:hover{background:#fecaca}.memory-loading{display:flex;align-items:center;justify-content:center;height:100%;color:#9ca3af;font-size:16px}[data-theme=dark] .memory-panel{background:#111827}[data-theme=dark] .memory-tabs{background:#1f2937;border-color:#374151}[data-theme=dark] .memory-tab{border-color:#374151;color:#9ca3af}[data-theme=dark] .memory-tab.active{background:var(--heiwa-sage, #7C9A82);color:#fff}[data-theme=dark] .memory-category{background:#1f2937}[data-theme=dark] .memory-category h4{color:#f3f4f6}[data-theme=dark] .category-icon svg{stroke:#86efac}[data-theme=dark] .memory-item{background:#7c9a8226;color:#d1d5db}[data-theme=dark] .constraint-category .memory-item{background:#f59e0b33;color:#fcd34d}[data-theme=dark] .memory-empty-inline{background:#1f2937;border-color:#374151;color:#6b7280}[data-theme=dark] .add-item-btn{border-color:#4b5563;color:#9ca3af}[data-theme=dark] .add-item-form input{background:#111827;border-color:#374151;color:#f3f4f6}[data-theme=dark] .objective-category{background:linear-gradient(135deg,#7c9a8233,#7c9a821a);border-color:#7c9a824d}[data-theme=dark] .objective-display{background:#1f2937}[data-theme=dark] .objective-text{color:#f3f4f6}[data-theme=dark] .parsed-tag{background:#7c9a8233;color:#86efac}[data-theme=dark] .style-btn{background:#1f2937;border-color:#374151;color:#d1d5db}[data-theme=dark] .stats-category{background:linear-gradient(135deg,#7c9a8233,#7c9a821a)}[data-theme=dark] .stat-value{color:#86efac}[data-theme=dark] .sources-category{background:#1f2937}[data-theme=dark] .memory-footer{background:#1f2937;border-color:#374151}@media (max-width: 380px){.memory-tab{padding:8px 10px}.memory-tab .tab-label{display:none}.memory-tab .tab-icon svg{width:20px;height:20px}.stats-grid{gap:12px}.stat-value{font-size:24px}.style-btn{padding:8px 12px;font-size:12px}.item-text{max-width:140px}}.profile-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:var(--z-modal, 500);animation:fadeIn .2s ease-out}.profile-modal{background:var(--bg-card, #ffffff);border-radius:24px 24px 0 0;width:100%;max-width:500px;max-height:calc(100vh - env(safe-area-inset-top,20px) - 20px);display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.profile-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;padding-top:calc(16px + env(safe-area-inset-top,20px));border-bottom:1px solid var(--border-light, #e8e4dd);background:var(--bg-card, #ffffff);flex-shrink:0}.profile-modal-header h2{font-size:18px;font-weight:700;color:var(--text-primary, #1a1a1a);margin:0}.profile-header-actions{display:flex;align-items:center;gap:8px}.profile-edit-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-secondary, #f7f5f2);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.profile-edit-btn svg{width:18px;height:18px;stroke:var(--text-soft, #6b6b6b)}.profile-edit-btn:hover{background:var(--heiwa-sage-10, rgba(45, 90, 71, .1))}.profile-edit-btn:hover svg{stroke:var(--heiwa-sage, #2d5a47)}.profile-cancel-btn,.profile-save-btn{padding:8px 14px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.profile-cancel-btn{background:transparent;border:1px solid var(--border-light, #e8e4dd);color:var(--text-soft, #6b6b6b)}.profile-cancel-btn:hover{background:var(--bg-secondary, #f7f5f2)}.profile-save-btn{background:var(--heiwa-sage, #2d5a47);border:none;color:#fff}.profile-save-btn:hover{background:var(--heiwa-sage-dark, #1e3d30)}.profile-save-btn:disabled,.profile-cancel-btn:disabled{opacity:.5;cursor:not-allowed}.profile-modal-close{width:36px;height:36px;border-radius:50%;background:var(--bg-secondary, #f7f5f2);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.profile-modal-close svg{width:20px;height:20px;stroke:var(--text-soft, #6b6b6b)}.profile-modal-close:hover{background:var(--heiwa-sage-10, rgba(45, 90, 71, .1))}.profile-modal-close:hover svg{stroke:var(--heiwa-sage, #2d5a47)}.profile-modal-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px;padding-bottom:calc(24px + env(safe-area-inset-bottom,20px))}.profile-completion-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #F59E0B;border-radius:12px;margin-bottom:20px}.completion-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.completion-icon svg{width:20px;height:20px;stroke:#d97706}.completion-content{flex:1;display:flex;flex-direction:column;gap:2px}.completion-text{font-size:14px;font-weight:600;color:#92400e}.completion-hint{font-size:12px;color:#b45309}.completion-action{padding:6px 12px;background:#f59e0b;border:none;border-radius:6px;font-size:12px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;white-space:nowrap}.completion-action:hover{background:#d97706}.profile-user-info{display:flex;align-items:center;gap:16px;margin-bottom:24px}.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#2d5a47,#4a7c64);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;flex-shrink:0}.profile-name-container{flex:1;min-width:0}.profile-name{font-size:20px;font-weight:700;color:var(--text-primary, #1a1a1a);margin:0 0 4px}.profile-name-input{width:100%;padding:10px 14px;border:2px solid var(--heiwa-sage, #2d5a47);border-radius:10px;font-size:18px;font-weight:600;color:var(--text-primary, #1a1a1a);background:var(--bg-card, #ffffff)}.profile-name-input:focus{outline:none;box-shadow:0 0 0 3px var(--heiwa-sage-20, rgba(45, 90, 71, .2))}.profile-goal{font-size:14px;color:var(--text-soft, #6b6b6b);margin:0}.profile-section{margin-bottom:24px}.profile-section-title{font-size:11px;font-weight:600;color:var(--text-muted, #8a8a8a);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.profile-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.profile-form-grid.three-cols{grid-template-columns:repeat(3,1fr)}.profile-form-grid.two-cols{grid-template-columns:1fr 1fr}.profile-form-field{display:flex;flex-direction:column;gap:6px}.profile-form-field.full-width{grid-column:1 / -1}.profile-form-field label{font-size:12px;font-weight:500;color:var(--text-soft, #6b6b6b)}.profile-form-field input,.profile-form-field select{padding:10px 12px;border:1px solid var(--border-light, #e8e4dd);border-radius:10px;font-size:15px;color:var(--text-primary, #1a1a1a);background:var(--bg-card, #ffffff);transition:all .2s ease}.profile-form-field input:focus,.profile-form-field select:focus{outline:none;border-color:var(--heiwa-sage, #2d5a47);box-shadow:0 0 0 3px var(--heiwa-sage-20, rgba(45, 90, 71, .2))}.input-with-unit{position:relative;display:flex;align-items:center}.input-with-unit input{flex:1;padding-right:40px}.input-with-unit .unit{position:absolute;right:12px;font-size:14px;color:var(--text-muted, #8a8a8a);pointer-events:none}.profile-gender-options{display:flex;gap:8px}.gender-option{flex:1;padding:10px;border:1px solid var(--border-light, #e8e4dd);border-radius:10px;background:var(--bg-card, #ffffff);font-size:14px;font-weight:600;color:var(--text-soft, #6b6b6b);cursor:pointer;transition:all .2s ease}.gender-option:hover{border-color:var(--heiwa-sage-40, rgba(45, 90, 71, .4))}.gender-option.selected{background:var(--heiwa-sage, #2d5a47);border-color:var(--heiwa-sage, #2d5a47);color:#fff}.profile-memory-btn{display:flex;align-items:center;gap:14px;width:100%;padding:14px 16px;background:var(--bg-secondary, #f7f5f2);border:1px solid var(--border-light, #e8e4dd);border-radius:14px;cursor:pointer;transition:all .2s ease;text-align:left}.profile-memory-btn:hover{background:var(--heiwa-sage-10, rgba(45, 90, 71, .1));border-color:var(--heiwa-sage-20, rgba(45, 90, 71, .2))}.memory-btn-icon{flex-shrink:0;width:40px;height:40px;background:linear-gradient(135deg,#2d5a47,#4a7c64);border-radius:10px;display:flex;align-items:center;justify-content:center}.memory-btn-icon svg{width:22px;height:22px;stroke:#fff}.memory-btn-content{flex:1;display:flex;flex-direction:column;gap:2px}.memory-btn-title{font-size:15px;font-weight:600;color:var(--text-primary, #1a1a1a)}.memory-btn-subtitle{font-size:13px;color:var(--text-soft, #6b6b6b)}.memory-btn-arrow{flex-shrink:0;width:20px;height:20px}.memory-btn-arrow svg{width:20px;height:20px;stroke:var(--text-muted, #8a8a8a)}.profile-measures{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.profile-measures.two-cols{grid-template-columns:1fr 1fr}.profile-measure{background:var(--bg-secondary, #f7f5f2);border-radius:14px;padding:14px 10px;text-align:center;transition:all .2s ease}.profile-measure.empty{border:2px dashed var(--border-light, #e8e4dd);background:transparent}.profile-measure.empty .profile-measure-value{color:var(--text-muted, #8a8a8a)}.profile-measure-value{display:block;font-size:17px;font-weight:700;color:var(--heiwa-sage, #2d5a47);margin-bottom:4px}.profile-measure-label{display:block;font-size:11px;color:var(--text-muted, #8a8a8a)}.profile-calories{display:flex;align-items:baseline;gap:8px;background:var(--heiwa-sage-10, rgba(45, 90, 71, .1));border-radius:14px;padding:16px}.profile-calories-value{font-size:28px;font-weight:700;color:var(--heiwa-sage, #2d5a47)}.profile-calories-unit{font-size:14px;color:var(--text-soft, #6b6b6b)}.profile-calories-hint{font-size:12px;color:var(--text-muted, #8a8a8a);margin:8px 0 0}.profile-logout-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px;background:transparent;border:1px solid var(--heiwa-error, #c27a6e);border-radius:12px;font-size:15px;font-weight:600;color:var(--heiwa-error, #c27a6e);cursor:pointer;transition:all .2s ease}.profile-logout-btn svg{width:18px;height:18px}.profile-logout-btn:hover{background:var(--heiwa-error-light, #fae8e6)}[data-theme=dark] .profile-modal{background:var(--bg-card, #1e1e1e)}[data-theme=dark] .profile-modal-header{background:var(--bg-card, #1e1e1e);border-color:var(--border-light, #2a2a2a)}[data-theme=dark] .profile-modal-close,[data-theme=dark] .profile-edit-btn{background:var(--bg-secondary, #1a1a1a)}[data-theme=dark] .profile-name-input,[data-theme=dark] .profile-form-field input,[data-theme=dark] .profile-form-field select,[data-theme=dark] .gender-option{background:var(--bg-secondary, #1a1a1a);border-color:var(--border-light, #2a2a2a);color:var(--text-primary, #f5f5f5)}[data-theme=dark] .profile-completion-banner{background:linear-gradient(135deg,#422006,#713f12);border-color:#d97706}[data-theme=dark] .completion-text{color:#fde68a}[data-theme=dark] .completion-hint{color:#fcd34d}[data-theme=dark] .completion-icon svg{stroke:#fbbf24}[data-theme=dark] .profile-memory-btn,[data-theme=dark] .profile-measure{background:var(--bg-secondary, #1a1a1a);border-color:var(--border-light, #2a2a2a)}[data-theme=dark] .profile-measure.empty{background:transparent}[data-theme=dark] .memory-btn-title,[data-theme=dark] .profile-name{color:var(--text-primary, #f5f5f5)}[data-theme=dark] .profile-measure-value{color:var(--heiwa-sage-light, #4a7c64)}[data-theme=dark] .profile-calories{background:#2d5a4733}[data-theme=dark] .profile-calories-value{color:var(--heiwa-sage-light, #4a7c64)}[data-theme=dark] .profile-logout-btn:hover{background:#c27a6e26}@media (max-width: 360px){.profile-form-grid.three-cols{grid-template-columns:repeat(2,1fr)}.profile-form-grid.three-cols .profile-form-field:last-child{grid-column:1 / -1}.profile-measures{grid-template-columns:repeat(2,1fr)}.profile-measures .profile-measure:last-child{grid-column:1 / -1}}.profile-section-title{display:flex;align-items:center;gap:8px}.alpha-badge{font-size:9px;font-weight:800;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;padding:3px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.profile-setting-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg-secondary, #f7f5f2);border:1px solid var(--border-light, #e8e4dd);border-radius:14px;transition:all .2s ease}.profile-setting-item:hover{background:var(--heiwa-sage-10, rgba(45, 90, 71, .05))}.setting-item-left{display:flex;align-items:center;gap:14px}.setting-item-visual{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.setting-visual-dark{background:linear-gradient(135deg,#4f46e5,#7c3aed)}.dark-mode-icon{width:18px;height:18px;background:transparent;border-radius:50%;box-shadow:inset -6px -2px #fff}.setting-item-text{display:flex;flex-direction:column;gap:2px}.setting-item-label{font-size:15px;font-weight:600;color:var(--text-primary, #1a1a1a)}.setting-item-desc{font-size:12px;color:var(--text-soft, #6b6b6b)}.toggle-switch{position:relative;width:52px;height:28px;background:#d1d5db;border:none;border-radius:14px;cursor:pointer;transition:all .3s ease;flex-shrink:0}.toggle-switch:hover{background:#9ca3af}.toggle-switch.active{background:linear-gradient(135deg,#7c9a82,#5a7d5a)}.toggle-switch.active:hover{background:linear-gradient(135deg,#6b8b71,#4a6d4a)}.toggle-slider{position:absolute;top:3px;left:3px;width:22px;height:22px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.68,-.55,.265,1.55);box-shadow:0 2px 4px #0003}.toggle-switch.active .toggle-slider{transform:translate(24px)}.feedback-intro{font-size:13px;color:var(--text-soft, #6b6b6b);margin:0 0 12px}.feedback-buttons{display:flex;gap:10px}.feedback-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px 12px;border-radius:14px;border:2px solid;background:#fff;cursor:pointer;transition:all .2s ease;font-size:13px;font-weight:600}.feedback-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.feedback-btn:active{transform:translateY(0)}.feedback-btn-bug{border-color:#dc262640;color:#dc2626}.feedback-btn-bug:hover{background:#dc26260d;border-color:#dc2626}.feedback-btn-idea{border-color:#2d5a4740;color:#2d5a47}.feedback-btn-idea:hover{background:#2d5a470d;border-color:#2d5a47}.feedback-btn-visual{width:36px;height:36px;border-radius:10px;position:relative}.bug-visual{background:linear-gradient(135deg,#fee2e2,#fecaca)}.bug-visual:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:12px;background:#dc2626;border-radius:50%}.bug-visual:after{content:"";position:absolute;top:6px;left:50%;transform:translate(-50%);width:12px;height:6px;border-top:2px solid #DC2626;border-left:2px solid #DC2626;border-right:2px solid #DC2626;border-radius:6px 6px 0 0}.idea-visual{background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.idea-visual:before{content:"";position:absolute;top:7px;left:50%;transform:translate(-50%);width:14px;height:14px;background:#2d5a47;border-radius:50% 50% 40% 40%}.idea-visual:after{content:"";position:absolute;bottom:7px;left:50%;transform:translate(-50%);width:8px;height:5px;background:#2d5a47;border-radius:0 0 3px 3px}[data-theme=dark] .profile-setting-item{background:var(--bg-secondary, #1a1a1a);border-color:var(--border-light, #2a2a2a)}[data-theme=dark] .profile-setting-item:hover{background:#2d5a4726}[data-theme=dark] .setting-item-label{color:var(--text-primary, #f5f5f5)}[data-theme=dark] .setting-item-desc{color:var(--text-soft, #a0a0a0)}[data-theme=dark] .toggle-switch{background:#4b5563}[data-theme=dark] .toggle-switch:hover{background:#6b7280}[data-theme=dark] .feedback-intro{color:var(--text-soft, #a0a0a0)}[data-theme=dark] .feedback-btn{background:var(--bg-secondary, #1a1a1a)}[data-theme=dark] .feedback-btn-bug{border-color:#dc26264d}[data-theme=dark] .feedback-btn-bug:hover{background:#dc26261a}[data-theme=dark] .feedback-btn-idea{border-color:#4a7c644d;color:#4a7c64}[data-theme=dark] .feedback-btn-idea:hover{background:#2d5a471a}[data-theme=dark] .bug-visual{background:linear-gradient(135deg,#dc262633,#dc26264d)}[data-theme=dark] .idea-visual{background:linear-gradient(135deg,#2d5a4733,#2d5a474d)}[data-theme=dark] .idea-visual:before,[data-theme=dark] .idea-visual:after{background:#4a7c64}@media (max-width: 360px){.feedback-buttons{flex-direction:column}.feedback-btn{flex-direction:row;justify-content:center;padding:12px 16px}.feedback-btn-visual{width:32px;height:32px}}.main-layout{display:flex;flex-direction:column;height:100%;width:100%;position:relative;overflow:hidden;background:var(--heiwa-cream, #FAF9F6)}.main-layout-content{flex:1;position:relative;overflow:hidden;padding-bottom:calc(60px + env(safe-area-inset-bottom,0))}.main-layout-screen{position:absolute;top:0;left:0;right:0;bottom:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;opacity:1;transform:translate(0);transition:opacity .2s ease,transform .2s ease}.main-layout-screen.transitioning.transition-left{opacity:0;transform:translate(-30px)}.main-layout-screen.transitioning.transition-right{opacity:0;transform:translate(30px)}.main-layout-screen:not(.transitioning){animation:screenEnter .25s ease forwards}@keyframes screenEnter{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.screen-indicators{position:absolute;bottom:calc(70px + env(safe-area-inset-bottom,0));left:50%;transform:translate(-50%);display:flex;gap:6px;z-index:50;padding:8px 12px;background:#fffc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;box-shadow:0 2px 8px #00000014}.screen-dot{width:6px;height:6px;border-radius:50%;background:#2d5a4733;transition:all .3s ease}.screen-dot.active{width:20px;border-radius:3px;background:var(--heiwa-sage, #2d5a47)}[data-theme=dark] .main-layout{background:#111827}[data-theme=dark] .screen-indicators{background:#1f2937cc}[data-theme=dark] .screen-dot{background:#86efac33}[data-theme=dark] .screen-dot.active{background:#86efac}@media (min-width: 769px){.main-layout-content{padding-bottom:80px}}@media (prefers-reduced-motion: reduce){.main-layout-screen{transition:none}.main-layout-screen:not(.transitioning){animation:none}.screen-dot{transition:none}}.main-layout:focus-visible{outline:2px solid var(--heiwa-sage, #2d5a47);outline-offset:-2px}:root{--heiwa-sage: #2d5a47;--heiwa-sage-light: #4a7c64;--heiwa-sage-lighter: #6b9b82;--heiwa-sage-dark: #1e3d30;--heiwa-sage-darker: #152a21;--heiwa-sage-10: rgba(45, 90, 71, .1);--heiwa-sage-20: rgba(45, 90, 71, .2);--heiwa-sage-30: rgba(45, 90, 71, .3);--heiwa-cream: #fafaf8;--heiwa-cream-warm: #f7f5f2;--heiwa-cream-dark: #f0ede8;--heiwa-sand: #e8e4dd;--heiwa-stone: #d4cfc6;--heiwa-text: #1a1a1a;--heiwa-text-secondary: #4a4a4a;--heiwa-text-soft: #6b6b6b;--heiwa-text-muted: #8a8a8a;--heiwa-text-light: #a8a8a8;--heiwa-gold: #c4a574;--heiwa-gold-light: #d4bc94;--heiwa-terracotta: #c27a6e;--heiwa-terracotta-light: #d9a094;--heiwa-ocean: #5a8a9a;--heiwa-ocean-light: #7aa8b8;--heiwa-success: #4a7c64;--heiwa-success-light: #e8f2ed;--heiwa-warning: #d4a574;--heiwa-warning-light: #faf3e8;--heiwa-error: #c27a6e;--heiwa-error-light: #fae8e6;--heiwa-info: #5a8a9a;--heiwa-info-light: #e8f2f5;--heiwa-gradient-sage: linear-gradient(135deg, #2d5a47 0%, #4a7c64 100%);--heiwa-gradient-sage-soft: linear-gradient(135deg, rgba(45, 90, 71, .1) 0%, rgba(74, 124, 100, .1) 100%);--heiwa-gradient-warm: linear-gradient(180deg, #fafaf8 0%, #f7f5f2 100%);--heiwa-gradient-card: linear-gradient(180deg, #ffffff 0%, #fafaf8 100%);--heiwa-gradient-gold: linear-gradient(135deg, #c4a574 0%, #d4bc94 100%);--heiwa-gradient-coach: linear-gradient(135deg, #2d5a47 0%, #4a7c64 50%, #6b9b82 100%);--space-2xs: 4px;--space-xs: 8px;--space-sm: 12px;--space-md: 16px;--space-lg: 20px;--space-xl: 24px;--space-2xl: 32px;--space-3xl: 40px;--space-4xl: 48px;--space-5xl: 64px;--font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", "Segoe UI", sans-serif;--font-family-mono: "SF Mono", "Fira Code", "Consolas", monospace;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 28px;--text-4xl: 32px;--text-5xl: 40px;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 1.75;--tracking-tight: -.02em;--tracking-normal: 0;--tracking-wide: .02em;--tracking-wider: .04em;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-3xl: 32px;--radius-full: 9999px;--border-thin: 1px;--border-medium: 2px;--border-thick: 3px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .02);--shadow-md: 0 4px 8px rgba(0, 0, 0, .04), 0 2px 4px rgba(0, 0, 0, .02);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .06), 0 4px 8px rgba(0, 0, 0, .02);--shadow-xl: 0 16px 32px rgba(0, 0, 0, .08), 0 8px 16px rgba(0, 0, 0, .02);--shadow-sage: 0 4px 12px rgba(45, 90, 71, .15);--shadow-sage-lg: 0 8px 24px rgba(45, 90, 71, .2);--shadow-gold: 0 4px 12px rgba(196, 165, 116, .2);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-slower: .4s cubic-bezier(.4, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-overlay: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800;--nav-height: 72px;--header-height: 56px;--btn-height-sm: 36px;--btn-height-md: 44px;--btn-height-lg: 52px;--input-height: 48px;--input-radius: var(--radius-lg);--card-radius: var(--radius-xl);--card-padding: var(--space-lg);--avatar-coach-sm: 40px;--avatar-coach-md: 56px;--avatar-coach-lg: 72px;--bg-primary: var(--heiwa-cream);--bg-secondary: var(--heiwa-cream-warm);--bg-card: #ffffff;--bg-card-hover: var(--heiwa-cream);--bg-input: #ffffff;--bg-input-focus: #ffffff;--text-primary: var(--heiwa-text);--text-secondary: var(--heiwa-text-secondary);--text-tertiary: var(--heiwa-text-soft);--text-muted: var(--heiwa-text-muted);--text-inverse: #ffffff;--border-light: var(--heiwa-sand);--border-medium: var(--heiwa-stone);--border-focus: var(--heiwa-sage);--accent-primary: var(--heiwa-sage);--accent-secondary: var(--heiwa-sage-light)}[data-theme=dark]{--bg-primary: #141414;--bg-secondary: #1a1a1a;--bg-card: #1e1e1e;--bg-card-hover: #252525;--bg-input: #1e1e1e;--bg-input-focus: #252525;--text-primary: #f5f5f5;--text-secondary: #d4d4d4;--text-tertiary: #a3a3a3;--text-muted: #737373;--text-inverse: #1a1a1a;--border-light: #2a2a2a;--border-medium: #3a3a3a;--border-focus: var(--heiwa-sage-light);--accent-primary: var(--heiwa-sage-light);--accent-secondary: var(--heiwa-sage-lighter);--heiwa-sage-10: rgba(74, 124, 100, .15);--heiwa-sage-20: rgba(74, 124, 100, .25);--heiwa-sage-30: rgba(74, 124, 100, .35);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .2);--shadow-md: 0 4px 8px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .3);--shadow-sage: 0 4px 12px rgba(74, 124, 100, .2)}.heiwa-title-xl{font-size:var(--text-4xl);font-weight:var(--font-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--text-primary)}.heiwa-title-lg{font-size:var(--text-2xl);font-weight:var(--font-bold);line-height:var(--leading-tight);color:var(--text-primary)}.heiwa-title-md{font-size:var(--text-xl);font-weight:var(--font-semibold);line-height:var(--leading-snug);color:var(--text-primary)}.heiwa-title-sm{font-size:var(--text-lg);font-weight:var(--font-semibold);line-height:var(--leading-snug);color:var(--text-primary)}.heiwa-body{font-size:var(--text-base);font-weight:var(--font-normal);line-height:var(--leading-relaxed);color:var(--text-secondary)}.heiwa-body-sm{font-size:var(--text-sm);font-weight:var(--font-normal);line-height:var(--leading-normal);color:var(--text-tertiary)}.heiwa-caption{font-size:var(--text-xs);font-weight:var(--font-medium);line-height:var(--leading-normal);color:var(--text-muted);letter-spacing:var(--tracking-wide)}.heiwa-label{font-size:var(--text-xs);font-weight:var(--font-semibold);line-height:var(--leading-normal);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--text-muted)}.heiwa-card{background:var(--bg-card);border-radius:var(--card-radius);padding:var(--card-padding);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);transition:all var(--transition-normal)}.heiwa-card:hover{box-shadow:var(--shadow-md)}.heiwa-card-elevated{background:var(--bg-card);border-radius:var(--card-radius);padding:var(--card-padding);box-shadow:var(--shadow-md);border:none}.heiwa-card-accent{background:var(--heiwa-gradient-sage-soft);border-radius:var(--card-radius);padding:var(--card-padding);border:1px solid var(--heiwa-sage-20)}.heiwa-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);height:var(--btn-height-md);padding:0 var(--space-lg);font-size:var(--text-base);font-weight:var(--font-semibold);border-radius:var(--radius-lg);border:none;cursor:pointer;transition:all var(--transition-normal);-webkit-tap-highlight-color:transparent}.heiwa-btn:active{transform:scale(.98)}.heiwa-btn-primary{background:var(--heiwa-gradient-sage);color:var(--text-inverse);box-shadow:var(--shadow-sage)}.heiwa-btn-primary:hover{box-shadow:var(--shadow-sage-lg);transform:translateY(-1px)}.heiwa-btn-secondary{background:var(--bg-card);color:var(--accent-primary);border:2px solid var(--border-light)}.heiwa-btn-secondary:hover{border-color:var(--accent-primary);background:var(--heiwa-sage-10)}.heiwa-btn-ghost{background:transparent;color:var(--text-secondary)}.heiwa-btn-ghost:hover{background:var(--heiwa-sage-10);color:var(--accent-primary)}.heiwa-btn-sm{height:var(--btn-height-sm);padding:0 var(--space-md);font-size:var(--text-sm);border-radius:var(--radius-md)}.heiwa-btn-lg{height:var(--btn-height-lg);padding:0 var(--space-xl);font-size:var(--text-lg);border-radius:var(--radius-xl)}.heiwa-btn-icon{width:var(--btn-height-md);height:var(--btn-height-md);padding:0;border-radius:var(--radius-full)}.heiwa-input{width:100%;height:var(--input-height);padding:0 var(--space-md);font-size:var(--text-base);font-family:var(--font-family);color:var(--text-primary);background:var(--bg-input);border:2px solid var(--border-light);border-radius:var(--input-radius);transition:all var(--transition-normal);outline:none}.heiwa-input::placeholder{color:var(--text-muted)}.heiwa-input:focus{border-color:var(--accent-primary);background:var(--bg-input-focus);box-shadow:0 0 0 4px var(--heiwa-sage-10)}.heiwa-input-error{border-color:var(--heiwa-error)}.heiwa-input-error:focus{box-shadow:0 0 0 4px #c27a6e1a}.heiwa-badge{display:inline-flex;align-items:center;gap:var(--space-2xs);padding:var(--space-2xs) var(--space-sm);font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--radius-full);background:var(--heiwa-sage-10);color:var(--accent-primary)}.heiwa-badge-success{background:var(--heiwa-success-light);color:var(--heiwa-success)}.heiwa-badge-warning{background:var(--heiwa-warning-light);color:var(--heiwa-warning)}.heiwa-badge-error{background:var(--heiwa-error-light);color:var(--heiwa-error)}.heiwa-coach-avatar{width:var(--avatar-coach-md);height:var(--avatar-coach-md);border-radius:var(--radius-full);background:var(--heiwa-gradient-coach);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sage)}.heiwa-coach-avatar svg{width:60%;height:60%;color:#fff}.heiwa-coach-avatar-sm{width:var(--avatar-coach-sm);height:var(--avatar-coach-sm)}.heiwa-coach-avatar-lg{width:var(--avatar-coach-lg);height:var(--avatar-coach-lg)}.heiwa-bubble{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-xl);font-size:var(--text-base);line-height:var(--leading-relaxed);max-width:85%}.heiwa-bubble-user{background:var(--heiwa-text);color:#fff;border-bottom-right-radius:var(--radius-sm);margin-left:auto}.heiwa-bubble-coach{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-light);border-bottom-left-radius:var(--radius-sm)}.heiwa-gauge{position:relative;width:160px;height:160px}.heiwa-gauge-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.heiwa-gauge-number{font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:1}.heiwa-gauge-unit{font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--text-muted)}.text-sage{color:var(--accent-primary)}.text-success{color:var(--heiwa-success)}.text-warning{color:var(--heiwa-warning)}.text-error{color:var(--heiwa-error)}.bg-sage{background:var(--heiwa-sage)}.bg-sage-soft{background:var(--heiwa-sage-10)}.bg-success-soft{background:var(--heiwa-success-light)}.bg-warning-soft{background:var(--heiwa-warning-light)}.bg-error-soft{background:var(--heiwa-error-light)}.p-xs{padding:var(--space-xs)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.p-xl{padding:var(--space-xl)}.m-xs{margin:var(--space-xs)}.m-sm{margin:var(--space-sm)}.m-md{margin:var(--space-md)}.m-lg{margin:var(--space-lg)}.m-xl{margin:var(--space-xl)}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.flex{display:flex}.flex-col{flex-direction:column}.flex-center{align-items:center;justify-content:center}.flex-between{justify-content:space-between}.flex-1{flex:1}.safe-top{padding-top:env(safe-area-inset-top)}.safe-bottom{padding-bottom:env(safe-area-inset-bottom)}.safe-left{padding-left:env(safe-area-inset-left)}.safe-right{padding-right:env(safe-area-inset-right)}.safe-all{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:focus-visible{outline:3px solid var(--accent-primary);outline-offset:2px}@media print{:root{--bg-primary: white;--bg-card: white;--shadow-sm: none;--shadow-md: none}}:root{--primary-color: var(--heiwa-sage);--primary-light: var(--heiwa-sage-light);--primary-dark: var(--heiwa-sage-dark);--primary-gradient: var(--heiwa-gradient-sage);--accent-color: var(--heiwa-gold);--success-color: var(--heiwa-success);--warning-color: var(--heiwa-warning);--error-color: var(--heiwa-error);--background-color: var(--heiwa-cream);--card-background: var(--bg-card);--surface-color: var(--bg-secondary)}:root{--spacing-2xs: var(--space-2xs);--spacing-xs: var(--space-xs);--spacing-sm: var(--space-sm);--spacing-md: var(--space-md);--spacing-lg: var(--space-lg);--spacing-xl: var(--space-xl);--spacing-2xl: var(--space-2xl);--gray-50: #fafafa;--gray-100: #f4f4f5;--gray-200: #e4e4e7;--gray-300: #d4d4d8;--gray-400: #a1a1aa;--gray-500: #71717a;--gray-600: #52525b;--gray-700: #3f3f46;--gray-800: #27272a;--gray-900: #18181b;--wellsense-blue: var(--heiwa-sage);--wellsense-teal: var(--heiwa-sage-dark);--wellsense-purple: var(--heiwa-sage-light);--wellsense-violet: var(--heiwa-gold);--gradient-primary: var(--heiwa-gradient-sage);--primary-gradient: var(--heiwa-gradient-sage);--primary-color: var(--heiwa-sage);--primary-light: var(--heiwa-sage-light);--primary-dark: var(--heiwa-sage-dark);--accent-color: var(--heiwa-gold);--success-color: var(--heiwa-success);--warning-color: var(--heiwa-warning);--error-color: var(--heiwa-error);--info-color: var(--heiwa-info);--font-size-xs: var(--text-xs);--font-size-sm: var(--text-sm);--font-size-base: var(--text-base);--font-size-lg: var(--text-lg);--font-size-xl: var(--text-xl);--font-size-2xl: var(--text-2xl);--font-size-3xl: var(--text-3xl);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--bg-card: var(--heiwa-cream);--bg-primary: var(--heiwa-cream);--bg-secondary: var(--heiwa-cream-warm);--background-color: var(--heiwa-cream);--text-primary: var(--heiwa-text);--text-secondary: var(--heiwa-text-secondary);--text-muted: var(--heiwa-text-muted)}[data-theme=dark]{--gray-50: #18181b;--gray-100: #27272a;--gray-200: #3f3f46;--gray-300: #52525b;--gray-400: #71717a;--gray-500: #a1a1aa;--gray-600: #d4d4d8;--gray-700: #e4e4e7;--gray-800: #f4f4f5;--gray-900: #fafafa}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-system);font-size:var(--font-size-md);color:var(--text-primary);background-color:var(--bg-secondary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none}.app-container{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-secondary);transition:background-color .3s cubic-bezier(.4,0,.2,1)}.app-header{background-color:var(--bg-card);padding:var(--spacing-md) var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);border-bottom:1px solid var(--border-light)}.app-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-bold);color:var(--text-primary)}.app-main{flex:1;padding:var(--spacing-xl);display:flex;justify-content:center;align-items:center}.welcome-message{background-color:var(--bg-card);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);max-width:600px;width:100%;text-align:center;animation:welcomeAppear .6s cubic-bezier(.34,1.56,.64,1)}@keyframes welcomeAppear{0%{opacity:0;transform:scale(.9) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}.welcome-message h2{font-size:var(--font-size-3xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--spacing-md)}.welcome-message p{font-size:var(--font-size-lg);color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.connection-info{background-color:var(--bg-secondary);padding:var(--spacing-lg);border-radius:var(--radius-md);margin:var(--spacing-xl) 0}.info-item{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-light);transition:all .2s ease}.info-item:hover{padding-left:var(--spacing-xs);background-color:var(--bg-tertiary);border-radius:var(--radius-sm)}.info-item:last-child{border-bottom:none}.info-item .label{font-weight:var(--font-semibold);color:var(--text-secondary)}.info-item .value{color:var(--text-primary);font-family:monospace}button{font-family:var(--font-system);font-size:var(--font-size-md);font-weight:var(--font-semibold);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-tap-highlight-color:transparent}button:active{transform:scale(.97)}.theme-toggle-btn{background-color:var(--bg-secondary);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-xl);border-radius:var(--radius-full);position:relative;overflow:hidden}.theme-toggle-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#667eea33;transform:translate(-50%,-50%);transition:width .4s,height .4s}.theme-toggle-btn:hover:before{width:200%;height:200%}.theme-toggle-btn:hover{background-color:var(--bg-tertiary);transform:scale(1.1) rotate(15deg)}.theme-toggle-btn:active{transform:scale(.95) rotate(-15deg)}.test-api-btn{background-color:var(--color-primary);color:var(--text-inverse);padding:var(--spacing-md) var(--spacing-xl);width:100%;margin-top:var(--spacing-lg);position:relative;overflow:hidden}.test-api-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.test-api-btn:hover:before{width:300px;height:300px}.test-api-btn:hover{background-color:var(--color-primary-hover);transform:translateY(-3px);box-shadow:0 10px 25px #667eea66}.test-api-btn:active{transform:translateY(-1px);box-shadow:0 5px 15px #667eea4d}.app-footer{background-color:var(--bg-card);padding:var(--spacing-md);text-align:center;color:var(--text-tertiary);font-size:var(--font-size-sm);border-top:1px solid var(--border-light)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.animate-slide-up{animation:slideInUp .4s ease-out}.app-inner-header{background-color:var(--bg-card);padding:var(--spacing-md);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-light)}.app-inner-header h1{font-size:var(--font-size-xl);font-weight:var(--font-bold);color:var(--text-primary)}.app-inner-main{padding:0;flex:1;overflow:hidden;display:flex;flex-direction:column}.welcome-card{background-color:var(--bg-card);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);text-align:center;animation:fadeIn .4s ease-out}.welcome-card h2{font-size:var(--font-size-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--spacing-sm)}.welcome-card p{font-size:var(--font-size-md);color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.home-screen{padding:var(--spacing-lg);overflow-y:auto;height:100%}.meals-screen,.activities-screen,.weight-screen,.profile-screen{width:100%;height:100%;overflow-y:auto;overflow-x:hidden;box-sizing:border-box}.meals-screen::-webkit-scrollbar,.activities-screen::-webkit-scrollbar,.weight-screen::-webkit-scrollbar,.profile-screen::-webkit-scrollbar,.home-screen::-webkit-scrollbar{width:6px}.meals-screen::-webkit-scrollbar-track,.activities-screen::-webkit-scrollbar-track,.weight-screen::-webkit-scrollbar-track,.profile-screen::-webkit-scrollbar-track,.home-screen::-webkit-scrollbar-track{background:transparent}.meals-screen::-webkit-scrollbar-thumb,.activities-screen::-webkit-scrollbar-thumb,.weight-screen::-webkit-scrollbar-thumb,.profile-screen::-webkit-scrollbar-thumb,.home-screen::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px;transition:background .2s ease}.meals-screen::-webkit-scrollbar-thumb:hover,.activities-screen::-webkit-scrollbar-thumb:hover,.weight-screen::-webkit-scrollbar-thumb:hover,.profile-screen::-webkit-scrollbar-thumb:hover,.home-screen::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}@media (max-width: 480px){.app-main{padding:var(--spacing-md)}.welcome-message{padding:var(--spacing-xl)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.welcome-message,.theme-toggle-btn,.test-api-btn,button{animation:none!important}}[data-theme=dark]{transition:background-color .3s ease,color .3s ease}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}@media (hover: none) and (pointer: coarse){button{min-height:44px;min-width:44px}button:hover{transform:none}button:active{transform:scale(.97);opacity:.8}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#0003;border-radius:10px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#0000004d;background-clip:padding-box}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#fff3;background-clip:padding-box}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#ffffff4d;background-clip:padding-box}*{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}[data-theme=dark] *{scrollbar-color:rgba(255,255,255,.2) transparent}:root{--heiwa-sage: #7C9A82;--heiwa-sage-dark: #5A7D5A;--heiwa-sage-light: #9CADA4;--heiwa-sage-10: #F0F5F1;--heiwa-sage-20: #E1EBE3;--heiwa-cream: #FAF9F6;--heiwa-cream-dark: #F5F4F1;--heiwa-gradient: linear-gradient(135deg, var(--heiwa-sage) 0%, var(--heiwa-sage-dark) 100%);--heiwa-gradient-warm: linear-gradient(180deg, var(--heiwa-cream) 0%, #FFFFFF 100%);--heiwa-text-primary: #1F2937;--heiwa-text-secondary: #6B7280;--heiwa-text-muted: #9CA3AF;--heiwa-success: #7C9A82;--heiwa-warning: #E8A87C;--heiwa-error: #E57373;--heiwa-info: #8B9DC3;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;--bg-primary: var(--heiwa-cream);--bg-secondary: #FFFFFF;--text-primary: var(--heiwa-text-primary);--text-soft: var(--heiwa-text-secondary);--text-muted: var(--heiwa-text-muted);--border-light: rgba(124, 154, 130, .1);--border-medium: rgba(124, 154, 130, .2);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-lg: 18px;--text-xl: 24px;--text-2xl: 32px}[data-theme=dark]{--heiwa-cream: #111827;--heiwa-cream-dark: #1F2937;--heiwa-sage-10: rgba(124, 154, 130, .15);--heiwa-sage-20: rgba(124, 154, 130, .25);--heiwa-text-primary: #F9FAFB;--heiwa-text-secondary: #D1D5DB;--heiwa-text-muted: #9CA3AF;--bg-primary: #111827;--bg-secondary: #1F2937;--text-primary: #F9FAFB;--text-soft: #D1D5DB;--text-muted: #9CA3AF;--border-light: rgba(124, 154, 130, .15);--border-medium: rgba(124, 154, 130, .25);--heiwa-gradient-warm: linear-gradient(180deg, #111827 0%, #1F2937 100%)}html{height:100%;height:-webkit-fill-available}body{margin:0;padding:0;min-height:100%;min-height:-webkit-fill-available;overscroll-behavior:none;font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;min-height:-webkit-fill-available}.app-container{width:100%;min-height:100vh;min-height:-webkit-fill-available;display:flex;justify-content:center;align-items:center;background:var(--bg-secondary)}.app-inner-main{flex:1;overflow:hidden;background-color:var(--bg-primary);position:relative;display:flex;flex-direction:column}.screen-wrapper{width:100%;height:100%;overflow-y:auto;overflow-x:hidden;box-sizing:border-box;-webkit-overflow-scrolling:touch}.screen-enter{animation:screenEnter .2s cubic-bezier(.4,0,.2,1) forwards}@keyframes screenEnter{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.screen-exit{animation:screenExit .2s cubic-bezier(.4,0,.6,1) forwards}@keyframes screenExit{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-16px)}}.heiwa-loading{display:flex;align-items:center;justify-content:center;height:100%;background:var(--heiwa-gradient-warm)}.heiwa-loading-fullscreen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--heiwa-gradient-warm);gap:var(--space-md)}.heiwa-loading-spinner{width:40px;height:40px;border:3px solid var(--heiwa-sage-20);border-top-color:var(--heiwa-sage);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.heiwa-loading-text{font-size:var(--text-sm);color:var(--text-soft);margin:0}@media (max-width: 768px){.screen-wrapper{padding-bottom:calc(88px + env(safe-area-inset-bottom))}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--border-light)}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--border-medium)}*{scrollbar-width:thin;scrollbar-color:var(--border-medium) transparent}[data-theme=dark] *{scrollbar-color:var(--border-light) transparent}.app-container,.phone-container-mobile{overscroll-behavior:none}input,select,textarea{font-size:16px}*{-webkit-tap-highlight-color:var(--heiwa-sage-10)}button{-webkit-appearance:none;-moz-appearance:none;appearance:none}body,#root,.app-container{overflow-x:hidden}[data-theme=dark] .app-inner-main{background-color:var(--bg-primary)}[data-theme=dark] .heiwa-loading,[data-theme=dark] .heiwa-loading-fullscreen{background:linear-gradient(180deg,#141414,#1a1a1a)}@media (prefers-reduced-motion: reduce){.screen-enter,.screen-exit{animation:none!important}.heiwa-loading-spinner{animation-duration:2s}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-slide-up{animation:slideUp .3s ease-out}.animate-slide-down{animation:slideDown .3s ease-out}.animate-scale-in{animation:scaleIn .3s ease-out}.bg-heiwa-sage{background-color:var(--heiwa-sage)}.bg-heiwa-sage-10{background-color:var(--heiwa-sage-10)}.bg-heiwa-gradient{background:var(--heiwa-gradient)}.text-heiwa-sage{color:var(--heiwa-sage)}.text-heiwa-sage-dark{color:var(--heiwa-sage-dark)}.border-heiwa{border-color:var(--heiwa-sage)}.border-heiwa-light{border-color:var(--heiwa-sage-20)}.btn-heiwa{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;background:var(--heiwa-gradient);color:#fff;font-size:var(--text-sm);font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #7c9a8240}.btn-heiwa:hover{transform:translateY(-2px);box-shadow:0 6px 16px #7c9a8259}.btn-heiwa:active{transform:translateY(0)}.btn-heiwa:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-heiwa-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;background:var(--heiwa-sage-10);color:var(--heiwa-sage-dark);font-size:var(--text-sm);font-weight:600;border:1px solid var(--heiwa-sage-20);border-radius:12px;cursor:pointer;transition:all .2s ease}.btn-heiwa-secondary:hover{background:var(--heiwa-sage-20);border-color:var(--heiwa-sage)}.card-heiwa{background:#fff;border:1px solid rgba(124,154,130,.15);border-radius:20px;padding:20px;box-shadow:0 4px 12px #0000000a}[data-theme=dark] .card-heiwa{background:var(--bg-secondary);border-color:#7c9a8233}.badge-heiwa{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--heiwa-sage-10);color:var(--heiwa-sage-dark);font-size:var(--text-xs);font-weight:600;border-radius:20px}[data-theme=dark] .badge-heiwa{background:var(--heiwa-sage-20)}.chat-header{background:var(--heiwa-gradient-sage, linear-gradient(135deg, #2d5a47 0%, #4a7c64 100%))!important}.chat-avatar{background:#ffffff26!important;color:#fff!important}.message.user .bubble{background:var(--heiwa-gradient-sage, linear-gradient(135deg, #2d5a47 0%, #4a7c64 100%))!important;color:#fff!important}.send-btn:not(:disabled){background:var(--heiwa-gradient-sage, linear-gradient(135deg, #2d5a47 0%, #4a7c64 100%))!important;color:#fff!important}.send-btn:not(:disabled):hover{box-shadow:0 4px 12px #2d5a474d!important}.daily-score-new svg #gaugeGradient stop:first-child{stop-color:#2d5a47!important}.daily-score-new svg #gaugeGradient stop:last-child{stop-color:#4a7c64!important}.score-gauge circle[stroke="url(#gaugeGradient)"]{filter:hue-rotate(80deg) saturate(.8)!important}.insight-banner,.coach-daily-message{background:linear-gradient(135deg,#f0f7f4,#e0efe8)!important;border-color:#2d5a4733!important}.insight-banner .coach-daily-label,.coach-daily-label{color:var(--heiwa-sage, #2d5a47)!important;background:#2d5a471a!important}.insight-banner .coach-daily-icon,.coach-daily-icon{color:var(--heiwa-sage, #2d5a47)!important}.insight-avatar,.coach-avatar{background:var(--heiwa-gradient-sage, linear-gradient(135deg, #2d5a47 0%, #4a7c64 100%))!important;border-color:#2d5a4733!important}.calorie-card.active,.activity-add-btn{background:var(--heiwa-gradient-sage, linear-gradient(135deg, #2d5a47 0%, #4a7c64 100%))!important}.activity-add-btn:hover{box-shadow:0 4px 12px #2d5a474d!important}.quick-action-btn:hover{border-color:var(--heiwa-sage, #2d5a47)!important;background:#2d5a470d!important}.quick-action-btn:hover .action-icon-svg,.score-status,a,.link{color:var(--heiwa-sage, #2d5a47)!important}.activity-label{color:var(--heiwa-sage-dark, #1e3d30)!important}.section-icon,.activity-item-icon{color:var(--heiwa-sage, #2d5a47)!important}.activity-item-title{color:var(--heiwa-sage-dark, #1e3d30)!important}.modal-overlay{background:#2d5a474d!important}.phone-notch:before{background:var(--heiwa-sage, #2d5a47)!important}.phone-frame,.phone-container:before{background:var(--heiwa-gradient-sage)!important}.toast.success{background:var(--heiwa-sage, #2d5a47)!important;border-color:var(--heiwa-sage-light, #4a7c64)!important}.onboarding-progress-fill,.onboarding-btn-primary{background:var(--heiwa-gradient-sage)!important}::-webkit-scrollbar-thumb{background:var(--heiwa-sage-30, rgba(45, 90, 71, .3))!important}::-webkit-scrollbar-thumb:hover{background:var(--heiwa-sage, #2d5a47)!important}[data-theme=dark] .chat-header,[data-theme=dark] .message.user .bubble{background:linear-gradient(135deg,#1e3d30,#2d5a47)!important}[data-theme=dark] .insight-banner,[data-theme=dark] .coach-daily-message{background:linear-gradient(135deg,#2d5a4726,#4a7c641a)!important}[data-theme=dark] .calorie-card.active{background:linear-gradient(135deg,#1e3d30,#2d5a47)!important}@media (hover: none) and (pointer: coarse){button,a,input[type=button],input[type=submit],.clickable{min-width:44px;min-height:44px;touch-action:manipulation}*{touch-action:pan-y}img{-webkit-touch-callout:none}}@media (max-width: 768px){*{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}body{overscroll-behavior:none;-webkit-overflow-scrolling:auto}.scrollable{overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}}@media (max-width: 768px){input,textarea,select{font-size:16px!important}input[type=number],input[inputmode=numeric]{-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0}}@media (max-width: 768px){.nav-bar{position:fixed;bottom:0;left:0;right:0;z-index:1000;padding-bottom:env(safe-area-inset-bottom)}.app-inner-main{padding-bottom:calc(60px + env(safe-area-inset-bottom))}}.swipeable{touch-action:pan-y;-webkit-user-select:none;user-select:none}.pull-to-refresh{position:relative;overflow:hidden}.pull-to-refresh-indicator{position:absolute;top:-60px;left:50%;transform:translate(-50%);width:40px;height:40px;transition:transform .3s ease}.pull-to-refresh.pulling .pull-to-refresh-indicator{transform:translate(-50%) translateY(60px)}@media (max-width: 768px){.modal-content{max-height:95vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.modal-overlay{align-items:flex-end}}@media (hover: none) and (pointer: coarse){button:active,a:active,.clickable:active{background-color:#667eea1a}*{-webkit-tap-highlight-color:transparent}}@supports (-webkit-touch-callout: none){.app-container{min-height:-webkit-fill-available}}@media (max-width: 768px){.nav-bar,.modal-content,.interactive-card{transform:translateZ(0);will-change:transform}.shadow-lg{box-shadow:0 4px 12px #0000001a!important}.shadow-md{box-shadow:0 2px 8px #00000014!important}}@media (max-width: 768px) and (orientation: landscape){.nav-bar{display:flex;flex-direction:row;height:50px}.nav-item{flex-direction:row;gap:var(--spacing-xs)}.nav-label{font-size:10px}}
