:root{--c-primary: #2563eb;--c-primary-dark: #1d4ed8;--c-primary-light: #dbeafe;--c-cyan: #009d98;--c-cyan-dark: #007c78;--c-cyan-light: #d4f1ef;--c-accent: #f59e0b;--c-accent-dark: #d97706;--c-accent-light: #fef3c7;--c-bg: #f1f5fb;--c-surface: #ffffff;--c-text: #0f172a;--c-muted: #64748b;--c-border: #e2e8f0;--c-success: #16a34a;--c-danger: #dc2626;--radius: 18px;--radius-sm: 12px;--shadow-sm: 0 2px 8px rgba(15, 23, 42, .05);--shadow: 0 6px 24px rgba(15, 23, 42, .07);--shadow-lg: 0 18px 48px rgba(15, 23, 42, .12);--font-size-base: 18px;--gradient-brand: linear-gradient(135deg, #009d98 0%, #22c1c3 55%, #2563eb 100%);--gradient-soft: radial-gradient(1200px 500px at 10% -10%, #d4f1ef 0%, transparent 60%), radial-gradient(1000px 600px at 110% 10%, #dbeafe 0%, transparent 55%), linear-gradient(180deg, #f8fafc 0%, #eef2f8 100%)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:var(--font-size-base);color:var(--c-text);background:var(--gradient-soft);background-attachment:fixed;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3{letter-spacing:-.01em}button,input,textarea,select{font:inherit;color:inherit}button{cursor:pointer;min-height:56px;padding:0 24px;border:none;border-radius:var(--radius);background:var(--gradient-brand);background-size:180% 180%;background-position:0% 50%;color:#fff;font-weight:600;font-size:1.05rem;box-shadow:0 8px 20px #2563eb2e;transition:background-position .4s ease,transform .15s ease,box-shadow .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:10px}button:hover:not(:disabled){background-position:100% 50%;transform:translateY(-1px);box-shadow:0 12px 28px #2563eb3d}button:active:not(:disabled){transform:translateY(0)}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:var(--c-surface);color:var(--c-primary-dark);border:2px solid var(--c-primary-light);box-shadow:none}button.secondary:hover:not(:disabled){background:var(--c-primary-light)}button.danger{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 8px 20px #dc262633}input[type=text],input[type=email],input[type=password],input[type=date],input[type=number],textarea,select{width:100%;padding:14px 16px;border:2px solid var(--c-border);border-radius:12px;background:var(--c-surface);font-size:1rem;transition:border-color .15s}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--c-primary)}label{display:block;margin-bottom:6px;color:var(--c-muted);font-size:.95rem;font-weight:500}.app-shell{min-height:100vh;padding:24px;max-width:900px;margin:0 auto}.card{background:var(--c-surface);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);margin-bottom:20px;border:1px solid rgba(226,232,240,.5);animation:fadeInUp .45s ease both}.card.glass{background:#ffffffd1;backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);border:1px solid rgba(255,255,255,.6);box-shadow:var(--shadow-lg)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.card h1,.card h2,.card h3{margin-top:0}.header{display:flex;justify-content:space-between;align-items:center;padding:16px 0 24px}.header h1{margin:0;font-size:1.6rem;color:var(--c-primary-dark)}.header .logout{background:transparent;color:var(--c-muted);min-height:auto;padding:8px 16px;border:1px solid var(--c-border)}.stack{display:flex;flex-direction:column;gap:16px}.row{display:flex;gap:16px;flex-wrap:wrap}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.muted{color:var(--c-muted)}.error{background:#fee2e2;color:var(--c-danger);padding:12px 16px;border-radius:12px;margin-bottom:16px}.success{background:#dcfce7;color:var(--c-success);padding:12px 16px;border-radius:12px;margin-bottom:16px}.patient-card{background:var(--c-primary-light);border:2px solid var(--c-primary);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:transform .15s}.patient-card:hover{transform:translateY(-2px)}.patient-card h3{margin:0;font-size:1.3rem}.patient-card .avatar-chip{width:86px;height:86px;display:flex;align-items:center;justify-content:center;background:transparent;flex-shrink:0}.pinpad{max-width:320px;margin:0 auto}.pinpad .dots{display:flex;justify-content:center;gap:14px;margin-bottom:28px}.pinpad .dot{width:24px;height:24px;border-radius:50%;border:3px solid var(--c-primary);background:var(--c-surface)}.pinpad .dot.filled{background:var(--c-primary)}.pinpad .keys{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.pinpad .keys button{height:70px;font-size:1.6rem;background:var(--c-surface);color:var(--c-primary-dark);border:2px solid var(--c-border)}.pinpad .keys button:hover{background:var(--c-primary-light)}.mood-scale{display:flex;justify-content:space-between;gap:8px;margin:12px 0}.mood-scale button{flex:1;height:72px;font-size:2rem;background:var(--c-surface);border:2px solid var(--c-border);border-radius:var(--radius);transition:all .15s}.mood-scale button.selected{background:var(--c-accent-light);border-color:var(--c-accent);transform:scale(1.05)}.energy-scale{display:flex;gap:8px}.energy-scale button{flex:1;height:56px;background:var(--c-surface);color:var(--c-text);border:2px solid var(--c-border);font-size:1.2rem;font-weight:700}.energy-scale button.selected{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.question-card{background:var(--c-surface);padding:28px;border-radius:var(--radius);box-shadow:var(--shadow)}.question-card .question-text{font-size:1.3rem;line-height:1.5;margin-bottom:24px}.choices{display:flex;flex-direction:column;gap:12px}.choices button{background:var(--c-surface);color:var(--c-text);border:2px solid var(--c-border);min-height:64px;text-align:left;padding:0 24px;font-size:1.1rem}.choices button:hover:not(:disabled){background:var(--c-primary-light);border-color:var(--c-primary)}.choices button.correct{background:#dcfce7;border-color:var(--c-success);color:var(--c-success)}.choices button.wrong{background:#fee2e2;border-color:var(--c-danger);color:var(--c-danger)}.avatar-container{display:flex;justify-content:center;padding:20px}.avatar-preview{display:flex;justify-content:center;align-items:center;padding:12px 0 20px;background:transparent}.avatar-detail{display:flex;flex-direction:column;align-items:center;gap:10px;padding:4px 0}.avatar-detail .avatar-name{margin:8px 0 2px;font-size:1rem;color:#475569;font-weight:500}.avatar-name-badge{display:flex;align-items:center;gap:8px;margin:4px 0 2px}.avatar-name-badge .avatar-name-label{font-size:1.15rem;font-weight:600;color:#1e293b;letter-spacing:-.01em}.avatar-sex-tag{display:inline-flex;align-items:center;justify-content:center;padding:3px 6px;border-radius:12px}.avatar-sex-tag.male{background:#dbeafe;color:#2563eb}.avatar-sex-tag.female{background:#fce7f3;color:#db2777}.avatar-name-field .avatar-name-input-wrap{display:flex;align-items:center;border:2px solid #e2e8f0;border-radius:14px;overflow:hidden;background:#f8fafc;transition:border-color .2s}.avatar-name-field .avatar-name-input-wrap:focus-within{border-color:var(--c-primary);background:#fff}.avatar-name-field .avatar-name-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;color:var(--c-primary);flex-shrink:0}.avatar-name-field .avatar-name-input{flex:1;border:none;outline:none;background:transparent;padding:10px 14px;font-size:1rem;font-weight:500;color:#1e293b;margin:0;border-radius:0}.voice-picker{display:flex;flex-direction:column;gap:8px}.voice-option{display:flex;align-items:center;gap:0;padding:0;border:2px solid #e2e8f0;border-radius:12px;background:#f8fafc;cursor:pointer;transition:border-color .15s,background .15s;text-align:left;width:100%;overflow:hidden}.voice-option:hover{background:#f1f5f9}.voice-option.selected{border-color:var(--c-primary);background:var(--c-primary-light)}.voice-option .voice-preview{display:flex;align-items:center;justify-content:center;width:46px;min-height:52px;flex-shrink:0;color:var(--c-primary);cursor:pointer;transition:background .15s;border-right:1px solid #e2e8f0}.voice-option .voice-preview:hover{background:#dbeafe}.voice-option.selected .voice-preview{border-right-color:#bfdbfe}.voice-option .voice-text{flex:1;padding:8px 14px;display:flex;flex-direction:column;justify-content:center;gap:1px}.voice-option .voice-name{font-weight:600;font-size:.92rem;color:#1e293b;line-height:1.3}.voice-option .voice-desc{font-size:.8rem;color:#64748b;line-height:1.3}.question-text-row{display:flex;align-items:flex-start;gap:8px}.voice-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:2px solid #e2e8f0;background:#f8fafc;color:#94a3b8;cursor:pointer;flex-shrink:0;transition:all .2s;padding:0;min-width:0}.voice-toggle:hover{border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}.voice-toggle.active{border-color:var(--c-primary);background:var(--c-primary);color:#fff}.voice-answer-toggle{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:10px 18px;border-radius:12px;border:2px solid #e2e8f0;background:#f8fafc;color:#64748b;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s}.voice-answer-toggle:hover{border-color:var(--c-cyan);color:var(--c-cyan)}.voice-answer-toggle.active{border-color:var(--c-cyan);background:var(--c-cyan-light);color:var(--c-cyan-dark)}.voice-answer-toggle.listening{border-color:var(--c-danger, #dc2626);background:#fef2f2;color:var(--c-danger, #dc2626);animation:pulse-border 1.5s ease infinite}@keyframes pulse-border{0%,to{box-shadow:0 0 #dc26264d}50%{box-shadow:0 0 0 6px #dc262600}}.patient-weather-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:4px;font-size:.9rem;color:#64748b}.patient-weather-row .weather-icon-label{font-size:1.3rem;line-height:1}.patient-weather-row .weather-info{display:inline-flex;align-items:center;gap:5px}.patient-weather-row .weather-divider{color:#cbd5e1}.patient-weather-row .weather-temp{font-weight:600;color:#475569}.games-tab-bar{display:flex;gap:10px;background:#f1f5f9;border-radius:14px;padding:4px;margin-bottom:16px}.games-tab{flex:1;padding:10px 0;border:none;background:transparent;border-radius:11px;font-size:.95rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s;min-width:0}.games-tab.active{background:#fff;color:#1e293b;box-shadow:0 2px 8px #00000014}.games-cat-scroll{display:flex;gap:6px;padding:0 0 12px;margin:0}.games-cat-chip{display:flex;align-items:center;justify-content:center;gap:4px;flex:1;padding:8px 4px;border:2px solid #e2e8f0;border-radius:12px;background:#fff;font-size:.7rem;font-weight:600;color:#475569;cursor:pointer;white-space:nowrap;transition:all .2s;min-width:0}.games-cat-chip:hover{border-color:var(--chip-color);color:var(--chip-color)}.games-cat-chip.active{background:var(--chip-gradient);border-color:transparent;color:#fff;box-shadow:0 4px 12px #00000026}.games-cat-chip-emoji{font-size:.9rem;line-height:1}.games-cat-banner{display:flex;align-items:center;gap:14px;padding:16px 20px;border-radius:16px;color:#fff;margin-bottom:16px;box-shadow:0 8px 24px #0000001f}.games-cat-banner-emoji{font-size:2.2rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.games-cat-banner-title{margin:0;font-size:1.25rem;font-weight:700;letter-spacing:-.01em}.games-cat-banner-sub{margin:2px 0 0;font-size:.82rem;opacity:.85;font-weight:500}.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.game-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:20px 14px 16px;background:#fff;border-radius:16px;border:1px solid #e2e8f0;text-decoration:none;color:inherit;transition:all .25s;position:relative;overflow:hidden;cursor:pointer}.game-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--card-accent);border-radius:16px 16px 0 0}.game-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px #0000001a;border-color:var(--card-accent)}.game-card-emoji{font-size:2.4rem;line-height:1;margin-bottom:10px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.08))}.game-card-name{font-weight:700;font-size:.9rem;color:#1e293b;margin-bottom:4px;letter-spacing:-.01em}.game-card-desc{font-size:.78rem;color:#64748b;line-height:1.35;margin-bottom:12px;flex:1}.game-card-play{font-size:.78rem;font-weight:700;color:var(--card-accent);letter-spacing:.02em;transition:letter-spacing .2s}.game-card:hover .game-card-play{letter-spacing:.08em}.game-card-best{display:block;font-size:.72rem;font-weight:700;color:#f59e0b;margin-top:4px;letter-spacing:.01em}@media (max-width: 400px){.games-grid{grid-template-columns:repeat(2,1fr);gap:10px}.game-card{padding:16px 10px 14px}}.action-tile.cyan{background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff;border-color:transparent;box-shadow:0 14px 30px #06b6d438}.action-tile.cyan .action-sub{color:#ffffffe0}.action-tile.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-color:transparent;box-shadow:0 14px 30px #8b5cf638}.action-tile.purple .action-sub{color:#ffffffe0}.chat-shell{display:flex;flex-direction:column;height:100dvh;max-height:100dvh;padding-bottom:0!important}.chat-avatar-row{display:flex;justify-content:center;padding:8px 0;flex-shrink:0}.chat-messages{flex:1;overflow-y:auto;padding:8px 16px 16px;display:flex;flex-direction:column;gap:10px}.chat-bubble{max-width:82%;padding:10px 14px;border-radius:16px;font-size:.95rem;line-height:1.5;word-break:break-word}.chat-bubble p{margin:0}.chat-bubble.user{align-self:flex-end;background:var(--c-primary);color:#fff;border-bottom-right-radius:4px}.chat-bubble.assistant{align-self:flex-start;background:#f1f5f9;color:#1e293b;border-bottom-left-radius:4px}.chat-bubble-name{display:block;font-size:.75rem;font-weight:600;color:var(--c-cyan-dark);margin-bottom:2px}.chat-typing{display:flex;gap:4px;padding:4px 0}.chat-typing span{width:8px;height:8px;border-radius:50%;background:#94a3b8;animation:chat-dot 1.2s ease-in-out infinite}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes chat-dot{0%,60%,to{transform:scale(.6);opacity:.4}30%{transform:scale(1);opacity:1}}.chat-input-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-top:1px solid var(--c-border);background:var(--c-surface);flex-shrink:0}.chat-text-input{flex:1;border:2px solid #e2e8f0;border-radius:24px;padding:10px 16px;font-size:.95rem;outline:none;transition:border-color .2s;margin:0}.chat-text-input:focus{border-color:var(--c-primary)}.chat-mic-btn{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:2px solid #e2e8f0;background:#f8fafc;color:#64748b;cursor:pointer;flex-shrink:0;padding:0;min-width:0;transition:all .2s}.chat-mic-btn:hover{border-color:var(--c-cyan);color:var(--c-cyan)}.chat-mic-btn.listening{border-color:#dc2626;background:#fef2f2;color:#dc2626;animation:pulse-border 1.5s ease infinite}.chat-send-btn{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:none;background:var(--c-primary);color:#fff;cursor:pointer;flex-shrink:0;padding:0;min-width:0;transition:background .2s}.chat-send-btn:hover:not(:disabled){background:var(--c-primary-dark)}.chat-send-btn:disabled{background:#cbd5e1;cursor:default}.selected-patient{border-color:var(--c-primary)!important;background:var(--c-primary-light)!important;color:var(--c-primary-dark)!important}.info-banner{display:flex;align-items:flex-start;gap:10px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:10px 14px;font-size:.85rem;color:#1e40af;line-height:1.5}.info-banner svg{flex-shrink:0;margin-top:2px}.patient-identity{display:flex;align-items:flex-start;gap:18px;flex-wrap:wrap}.patient-illustration{flex-shrink:0;display:flex;align-items:center;justify-content:center}.patient-info{flex:1;min-width:220px}.patient-title-row{display:flex;align-items:center;gap:8px}.patient-title{margin:0 0 8px;font-size:1.4rem;font-weight:600;color:#0f172a}.patient-age{color:#64748b;font-weight:400;font-size:1.05rem}.patient-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:6px;color:#475569;font-size:.9rem}.patient-field{display:inline-flex;align-items:center;gap:6px}.photo-preview-wrap{display:flex;justify-content:center;margin-top:12px}.photo-preview{max-width:200px;max-height:200px;object-fit:contain;background:transparent;border:none;border-radius:12px}.avatar-svg{width:160px;height:160px;animation:breathing 3s ease-in-out infinite}.avatar-svg.speaking{animation:speaking .5s ease-in-out infinite}@keyframes breathing{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}@keyframes speaking{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.bar-chart{display:flex;flex-direction:column;gap:8px}.bar-row{display:flex;align-items:center;gap:12px}.bar-row .label{width:120px;font-size:.95rem;color:var(--c-muted)}.bar-row .bar{flex:1;height:20px;background:var(--c-border);border-radius:10px;overflow:hidden}.bar-row .bar .fill{height:100%;background:linear-gradient(90deg,var(--c-primary),var(--c-accent));border-radius:10px}.bar-row .val{width:50px;text-align:right;font-weight:600}.big{font-size:3rem;font-weight:700;color:var(--c-primary-dark)}.centered{text-align:center}nav.links{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px}nav.links a{color:var(--c-primary);text-decoration:none;font-weight:600}a.button-link{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:56px;padding:0 24px;background:var(--c-primary);color:#fff;border-radius:var(--radius);text-decoration:none;font-weight:600;transition:background .15s,transform .15s}a.button-link:hover{background:var(--c-primary-dark);transform:translateY(-1px)}a.button-link.outline{background:transparent;color:var(--c-primary);border:2px solid var(--c-primary)}a.button-link.outline:hover{background:var(--c-primary-light)}a.button-link.cyan{background:var(--c-cyan)}a.button-link.cyan:hover{background:var(--c-cyan-dark)}a.button-link svg,button svg{flex-shrink:0}.landing-hero{text-align:center;padding:40px 24px 24px}.landing-hero h1{font-size:3.2rem;color:var(--c-cyan);margin:0 0 8px;letter-spacing:-1px;font-weight:800}.landing-hero .slogan{color:var(--c-muted);font-size:1.2rem;margin:0 0 8px;font-style:italic}.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:16px}@media (max-width: 700px){.two-cols{grid-template-columns:1fr}.landing-hero h1{font-size:2.4rem}}.role-card{background:var(--c-surface);border-radius:var(--radius);padding:32px 24px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px;transition:transform .2s,box-shadow .2s;border:2px solid transparent}.role-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px #0000001a;border-color:var(--c-cyan-light)}.role-card .illustration{width:160px;height:160px;display:flex;align-items:center;justify-content:center}.role-card h2{margin:0;font-size:1.4rem;color:var(--c-cyan-dark)}.role-card .role-desc{color:var(--c-muted);font-size:.95rem;min-height:40px;margin:0}.role-card .role-actions{display:flex;flex-direction:column;gap:10px;width:100%}.role-card .role-actions .button-link{width:100%}.auth-header{text-align:center;margin-bottom:24px}.auth-header h1{margin:8px 0 4px;font-size:1.8rem;background:var(--gradient-brand);-webkit-background-clip:text;background-clip:text;color:transparent}.auth-icon{width:64px;height:64px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--c-cyan-light);color:var(--c-cyan-dark);margin-bottom:6px}.auth-illustration{display:flex;justify-content:center;margin-bottom:4px}.profile-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media (max-width: 560px){.profile-picker{grid-template-columns:1fr}}.profile-option{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 16px;min-height:72px;background:var(--c-surface);color:var(--c-text);border:2px solid var(--c-border);border-radius:var(--radius-sm);box-shadow:none;text-align:left}.profile-option:hover:not(:disabled){background:var(--c-primary-light);border-color:var(--c-primary-light);transform:none;box-shadow:var(--shadow-sm)}.profile-option.selected{border-color:var(--c-primary);background:var(--c-primary-light);color:var(--c-primary-dark);box-shadow:0 4px 14px #2563eb24}.profile-option .profile-label{font-weight:700;font-size:1rem}.profile-option .profile-desc{font-size:.82rem;color:var(--c-muted);font-weight:500;line-height:1.2}.profile-option.selected .profile-desc{color:var(--c-primary-dark);opacity:.8}.consent-row{display:flex;align-items:center;gap:12px;margin-top:4px;font-size:1rem;color:var(--c-text);cursor:pointer;font-weight:500}.consent-row input[type=checkbox]{width:24px;height:24px;flex-shrink:0;accent-color:var(--c-primary);cursor:pointer}.inline-link{background:none;border:none;padding:0;min-height:auto;box-shadow:none;color:var(--c-primary);font-weight:600;text-decoration:underline;text-underline-offset:3px;cursor:pointer;font-size:inherit;display:inline}.inline-link:hover:not(:disabled){color:var(--c-primary-dark);background:none;transform:none;box-shadow:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--c-surface);border-radius:var(--radius);max-width:640px;width:100%;max-height:92vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden;animation:fadeInUp .3s ease}.modal-header{padding:24px 28px 12px;border-bottom:1px solid var(--c-border)}.modal-header h2{margin:0 0 4px;font-size:1.4rem;background:var(--gradient-brand);-webkit-background-clip:text;background-clip:text;color:transparent}.modal-header p{margin:0;font-size:.85rem}.modal-body{padding:20px 28px;overflow-y:auto;line-height:1.6;color:var(--c-text);font-size:.98rem}.modal-body h3{margin:20px 0 6px;font-size:1.05rem;color:var(--c-primary-dark)}.modal-body p{margin:0 0 8px}.modal-footer{padding:16px 28px 22px;border-top:1px solid var(--c-border);display:flex;gap:12px;justify-content:space-between;background:var(--c-bg)}.modal-footer button{min-width:140px}@media (max-width: 560px){.modal-footer{flex-direction:column-reverse}.modal-footer button{width:100%}}.back-link{background:transparent;color:var(--c-muted);border:1px solid var(--c-border);min-height:42px;padding:0 18px;font-size:.95rem;font-weight:500;box-shadow:none;margin-bottom:16px}.back-link:hover:not(:disabled){background:var(--c-surface);color:var(--c-primary-dark);border-color:var(--c-primary-light);transform:none;box-shadow:var(--shadow-sm)}.totp-input{text-align:center;letter-spacing:.6em;font-size:2rem;font-weight:700;padding:16px;background:var(--c-bg)!important;border:2px dashed var(--c-primary-light)!important}.totp-input:focus{border-color:var(--c-primary)!important;background:var(--c-surface)!important}.qr-wrap{display:flex;justify-content:center;padding:20px;background:var(--c-surface);border-radius:var(--radius-sm);border:2px dashed var(--c-border);margin-bottom:16px}.secret-box{display:flex;align-items:center;gap:12px;background:var(--c-bg);padding:12px 16px;border-radius:var(--radius-sm);border:1px solid var(--c-border)}.secret-box code{flex:1;font-family:JetBrains Mono,Menlo,monospace;font-size:.95rem;word-break:break-all;color:var(--c-primary-dark)}.secret-box button{min-height:40px;padding:0 14px;font-size:.9rem}.feature-row{display:flex;align-items:center;gap:16px}.feature-icon-wrap{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--c-primary-light);color:var(--c-primary-dark);flex-shrink:0}.status-chip{padding:6px 14px;border-radius:999px;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.status-chip.on{background:#dcfce7;color:var(--c-success)}.status-chip.off{background:#f1f5f9;color:var(--c-muted)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:20px}.stat-card{background:var(--c-surface);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow-sm);border:1px solid rgba(226,232,240,.6);display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:-30px;right:-30px;width:110px;height:110px;border-radius:50%;background:var(--c-primary-light);opacity:.6;z-index:0}.stat-card.cyan:before{background:var(--c-cyan-light)}.stat-card.amber:before{background:var(--c-accent-light)}.stat-card .stat-label{color:var(--c-muted);font-size:.9rem;position:relative;z-index:1}.stat-card .stat-value{font-size:2.1rem;font-weight:800;color:var(--c-primary-dark);position:relative;z-index:1;line-height:1.1}.stat-card.cyan .stat-value{color:var(--c-cyan-dark)}.stat-card.amber .stat-value{color:var(--c-accent-dark)}.progress{height:10px;background:var(--c-border);border-radius:999px;overflow:hidden;margin-bottom:24px}.progress .progress-fill{height:100%;background:var(--gradient-brand);border-radius:999px;transition:width .4s cubic-bezier(.4,0,.2,1)}.welcome-banner{background:var(--gradient-brand);color:#fff;border-radius:var(--radius);padding:28px 32px;box-shadow:var(--shadow-lg);margin-bottom:24px;position:relative;overflow:hidden;animation:fadeInUp .5s ease both}.welcome-banner h2{margin:0 0 6px;font-size:1.6rem;color:#fff}.welcome-banner p{margin:0;opacity:.92}.welcome-banner:after{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle at center,rgba(255,255,255,.25),transparent 70%)}.line-chart-wrap{background:var(--c-bg);border-radius:var(--radius-sm);padding:16px;border:1px solid var(--c-border)}.line-chart{width:100%;height:180px}.action-tile{display:flex;align-items:center;gap:18px;padding:22px 24px;border-radius:var(--radius);background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--shadow-sm);color:var(--c-text);text-decoration:none;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;min-height:80px}.action-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--c-primary-light)}.action-tile.primary{background:var(--gradient-brand);color:#fff;border-color:transparent;box-shadow:0 14px 30px #2563eb38}.action-tile.primary .action-sub{color:#ffffffd9}.action-tile.amber{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;border-color:transparent;box-shadow:0 14px 30px #f59e0b38}.action-tile.amber .action-sub{color:#ffffffe6}.action-tile .action-emoji{font-size:2.2rem;flex-shrink:0}.action-tile .action-title{font-size:1.15rem;font-weight:700;line-height:1.2}.action-tile .action-sub{font-size:.9rem;color:var(--c-muted);margin-top:2px}.brand-mark{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:1.1rem;color:var(--c-cyan-dark)}.brand-mark .dot{width:14px;height:14px;border-radius:50%;background:var(--gradient-brand);box-shadow:0 0 0 4px #009d982e}.landing-hero h1{background:var(--gradient-brand);-webkit-background-clip:text;background-clip:text;color:transparent}.landing-logo{display:block;margin:0 auto 12px;max-width:180px;width:45%;height:auto}.patient-card{background:linear-gradient(135deg,#fff,#eff6ff);border:1px solid var(--c-primary-light);transition:transform .18s,box-shadow .18s}.patient-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.button-link.btn-amber{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:1px solid #fcd34d;box-shadow:0 2px 8px #d977061f}.button-link.btn-amber:hover{background:linear-gradient(135deg,#fde68a,#fcd34d);transform:translateY(-1px);box-shadow:0 4px 12px #d977062e}.button-link.btn-sage{background:linear-gradient(135deg,#ecfdf5,#d1fae5);color:#065f46;border:1px solid #a7f3d0;box-shadow:0 2px 8px #0596691a}.button-link.btn-sage:hover{background:linear-gradient(135deg,#d1fae5,#a7f3d0);transform:translateY(-1px);box-shadow:0 4px 12px #05966926}.patient-card-wrap{position:relative;display:flex;align-items:stretch}.patient-archive-btn{position:absolute;top:12px;right:12px;width:28px;height:28px;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;outline:none;box-shadow:none;color:#94a3b8;opacity:.7;cursor:pointer;z-index:3;transition:color .15s,transform .15s,opacity .15s}.patient-archive-btn:hover{color:#dc2626;opacity:1;transform:scale(1.1)}.patient-archive-btn:focus,.patient-archive-btn:focus-visible,.patient-archive-btn:active{outline:none;border:none;box-shadow:none;background:transparent}.patient-card.archived{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;display:flex;align-items:center;gap:16px;padding:14px 18px;opacity:.92}.patient-card.archived:hover{transform:none;box-shadow:none}.header h1,.big{background:var(--gradient-brand);-webkit-background-clip:text;background-clip:text;color:transparent}.settings-tabs{display:flex;gap:8px;margin:8px 0 16px;flex-wrap:wrap}.settings-tabs .tab{flex:1;min-width:110px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border-radius:12px;background:#f1f5f9;border:1px solid transparent;color:#334155;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.settings-tabs .tab:hover{background:#e2e8f0}.settings-tabs .tab.active{background:linear-gradient(135deg,#e0f2fe,#d4f1ef);border-color:var(--c-primary-light, #7dd3fc);color:var(--c-primary-dark, #0369a1)}.password-checklist{list-style:none;padding:0;margin:8px 0 0;font-size:.85rem}.password-checklist li{display:inline-flex;align-items:center;gap:6px;padding:3px 0;width:100%;color:#94a3b8}.password-checklist li.ok{color:#16a34a}.password-checklist li.ko{color:#ef4444}.oauth-divider{display:flex;align-items:center;text-align:center;margin:18px 0 10px;color:#94a3b8;font-size:.85rem}.oauth-divider:before,.oauth-divider:after{content:"";flex:1;border-bottom:1px solid #e2e8f0}.oauth-divider span{padding:0 12px}.oauth-google-wrap{display:flex;justify-content:center;margin-top:6px}.kind-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin-top:6px}.kind-option{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border-radius:12px;background:#f8fafc;border:2px solid transparent;cursor:pointer;transition:all .15s;text-align:center}.kind-option:hover{background:#f1f5f9}.kind-option.selected{background:linear-gradient(135deg,#e0f2fe,#d4f1ef);border-color:var(--c-primary, #06b6d4)}.kind-icon{font-size:1.8rem}.kind-label{font-size:.78rem;font-weight:500;color:#334155}.switch{position:relative;display:inline-block;width:46px;height:26px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#cbd5e1;border-radius:26px;cursor:pointer;transition:background .2s}.switch .slider:before{content:"";position:absolute;height:20px;width:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.switch input:checked+.slider{background:var(--c-primary, #06b6d4)}.switch input:checked+.slider:before{transform:translate(20px)}.tracking-card textarea{width:100%}textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e2e8f0;font-family:inherit;font-size:.95rem;resize:vertical}select{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e2e8f0;font-family:inherit;font-size:.95rem;background:#fff}.avatar-wrap{position:relative;display:inline-block;overflow:visible;cursor:pointer;transition:transform .25s ease}.avatar-wrap:hover{transform:translateY(-2px)}.avatar-wrap:hover .avatar-ground-shadow{transform:scaleX(1.05) scaleY(1.05);opacity:1}.avatar-img{position:relative;width:100%;height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;animation:avatar-idle 6s ease-in-out infinite,avatar-enter .55s ease-out;transform-origin:50% 90%;will-change:transform,opacity;background:transparent;z-index:2}@keyframes avatar-enter{0%{opacity:0;transform:translateY(6px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.avatar-img.reacting{animation:avatar-react .7s cubic-bezier(.34,1.56,.64,1)}.avatar-ground-shadow{position:absolute;left:18%;right:18%;bottom:4%;height:8%;border-radius:50%;background:radial-gradient(ellipse at center,#0f172a38,#0f172a00 70%);pointer-events:none;z-index:1;animation:avatar-ground 6s ease-in-out infinite}@keyframes avatar-ground{0%,to{transform:scaleX(1) scaleY(1);opacity:.85}50%{transform:scaleX(.95) scaleY(.92);opacity:.6}}@keyframes avatar-react{0%{transform:translateY(0) scale(1) rotate(0)}30%{transform:translateY(-14px) scale(1.08) rotate(-3deg)}60%{transform:translateY(-4px) scale(1.03) rotate(2deg)}to{transform:translateY(0) scale(1) rotate(0)}}.avatar-img.speaking{animation:avatar-speak .9s ease-in-out infinite}.avatar-img.avatar-state-sleeping{animation:avatar-breathe 4.5s ease-in-out infinite}.avatar-img.avatar-state-eating{animation:avatar-munch 1.2s ease-in-out infinite;transform-origin:50% 85%}@keyframes avatar-idle{0%{transform:translateY(0) rotate(0) scale(1)}20%{transform:translateY(-2px) rotate(-.6deg) scale(1.005)}40%{transform:translateY(-3px) rotate(0) scale(1.01)}60%{transform:translateY(-2px) rotate(.6deg) scale(1.005)}80%{transform:translateY(0) rotate(0) scale(1)}to{transform:translateY(0) rotate(0) scale(1)}}@keyframes avatar-speak{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-2px) scale(1.04)}}@keyframes avatar-breathe{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1.02) translateY(-1px)}}@keyframes avatar-munch{0%,to{transform:translateY(0) scale(1)}25%{transform:translateY(-1px) scale(1.015)}50%{transform:translateY(0) scale(.99)}75%{transform:translateY(-1px) scale(1.015)}}.ambient-overlay{position:absolute;top:-10%;right:-10%;bottom:-10%;left:-10%;border-radius:50%;pointer-events:none;z-index:1;mix-blend-mode:multiply;opacity:.55;transition:background 1.6s ease,opacity 1.6s ease}.ambient-overlay.ambient-dawn{background:radial-gradient(circle at 50% 40%,#fef3c7 0%,#fed7aa 45%,transparent 75%)}.ambient-overlay.ambient-day{background:radial-gradient(circle at 50% 40%,#fefce8 0%,#fef9c3 50%,transparent 80%);opacity:.25}.ambient-overlay.ambient-dusk{background:radial-gradient(circle at 50% 40%,#fbcfe8 0%,#c4b5fd 50%,transparent 80%)}.ambient-overlay.ambient-night{background:radial-gradient(circle at 50% 40%,#1e3a8a 0%,#0f172a 55%,transparent 85%);mix-blend-mode:normal;opacity:.22}.avatar-wrap.ambient-night .avatar-img{filter:brightness(.88) contrast(.95) saturate(.85);transition:filter 1.6s ease}.avatar-wrap.ambient-dawn .avatar-img,.avatar-wrap.ambient-dusk .avatar-img{filter:saturate(1.05);transition:filter 1.6s ease}.mood-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:3;overflow:visible}.mood-particles .particle{position:absolute;bottom:10%;font-size:.9rem;opacity:0;animation:particle-float 6s ease-in-out infinite;filter:drop-shadow(0 1px 2px rgba(251,191,36,.35));will-change:transform,opacity}.season-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:3;overflow:visible}.season-particles .season-piece{position:absolute;top:-8%;opacity:0;display:inline-block;will-change:transform,opacity}.season-spring .season-piece{animation:season-drift 9s linear infinite}.season-summer .season-piece{animation:season-flutter 10s ease-in-out infinite}.season-autumn .season-piece{animation:season-fall 10s ease-in infinite}.season-winter .season-piece{animation:season-snow 11s linear infinite}@keyframes season-drift{0%{transform:translateY(0) translate(0) rotate(0);opacity:0}10%{opacity:.85}50%{transform:translateY(60%) translate(14px) rotate(180deg)}90%{opacity:.6}to{transform:translateY(120%) translate(-6px) rotate(360deg);opacity:0}}@keyframes season-flutter{0%{transform:translateY(0) translate(0) rotate(-8deg);opacity:0}10%{opacity:.9}30%{transform:translateY(20%) translate(18px) rotate(6deg)}60%{transform:translateY(55%) translate(-12px) rotate(-6deg)}90%{opacity:.7}to{transform:translateY(110%) translate(8px) rotate(4deg);opacity:0}}@keyframes season-fall{0%{transform:translateY(0) rotate(0);opacity:0}10%{opacity:.9}50%{transform:translateY(60%) rotate(180deg)}90%{opacity:.7}to{transform:translateY(120%) rotate(380deg);opacity:0}}@keyframes season-snow{0%{transform:translateY(0) translate(0) rotate(0);opacity:0}10%{opacity:.95}50%{transform:translateY(60%) translate(10px) rotate(180deg)}to{transform:translateY(115%) translate(-4px) rotate(360deg);opacity:0}}@keyframes particle-float{0%{transform:translateY(0) scale(.7);opacity:0}15%{transform:translateY(-10px) scale(1);opacity:.9}70%{transform:translateY(-70px) scale(1.1);opacity:.7}to{transform:translateY(-110px) scale(.6);opacity:0}}.weather-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:4}.weather-overlay .weather-drops{animation:drops-fall 1.3s linear infinite}.weather-overlay .weather-snow{animation:snow-fall 3s ease-in-out infinite}@keyframes drops-fall{0%{transform:translateY(-8px);opacity:0}20%{opacity:1}to{transform:translateY(12px);opacity:0}}@keyframes snow-fall{0%{transform:translateY(-6px);opacity:.4}50%{transform:translateY(6px);opacity:1}to{transform:translateY(16px);opacity:.3}}button.btn-compact,.btn-compact{padding:6px 12px;font-size:.85rem;min-height:0}.spinner{width:36px;height:36px;border:3px solid #e2e8f0;border-top-color:var(--c-primary, #06b6d4);border-radius:50%;margin:0 auto;animation:spinner-rotate .9s linear infinite}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;margin:0;background:transparent;border:none;outline:none;box-shadow:none;color:#64748b;cursor:pointer;opacity:.75;transition:opacity .15s,color .15s,transform .15s}.icon-btn:hover{opacity:1;color:#0369a1;transform:scale(1.08)}.icon-btn:focus,.icon-btn:focus-visible,.icon-btn:active{outline:none;border:none;box-shadow:none}.btn-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spinner-rotate .8s linear infinite;flex-shrink:0}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.city-suggest{list-style:none;padding:0;margin:4px 0 0;background:#fff;border:1px solid #e2e8f0;border-radius:10px;max-height:220px;overflow-y:auto;box-shadow:0 6px 20px #0f172a0f;position:absolute;left:0;right:0;z-index:10}.city-suggest li{border-bottom:1px solid #f1f5f9}.city-suggest li:last-child{border-bottom:none}.city-suggest button{width:100%;text-align:left;background:transparent;border:none;padding:10px 14px;cursor:pointer;color:#334155;font-size:.9rem;display:block}.city-suggest button:hover{background:#f8fafc}.period-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.period-option{padding:14px 8px;border-radius:12px;background:#f8fafc;border:2px solid transparent;cursor:pointer;font-weight:500;color:#334155;transition:all .15s}.period-option:hover{background:#f1f5f9}.period-option.selected{background:linear-gradient(135deg,#e0f2fe,#d4f1ef);border-color:var(--c-primary, #06b6d4);color:var(--c-primary-dark, #0369a1)}
