html,body,#root{background:#ffffff;margin:0;padding:0;height:100%;overscroll-behavior:none}.chat-page{display:flex;flex-direction:column;height:100dvh;background:#ffffff;font-family:Inter,sans-serif;color:#1f2937;overflow:hidden}.chat-header{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#ffffff;height:4rem}.chat-logo{display:flex;align-items:center;gap:.5rem}.chat-logo img{width:36px;height:36px}.chat-logo span{font-weight:600;font-size:1.25rem;color:#152a3a}.chat-actions{display:flex;gap:.5rem}.header-btn{background:#152a3a;color:#fff;font-size:.875rem;font-weight:500;padding:.5rem 1rem;border-radius:9999px;border:none;cursor:pointer}.header-btn:hover{opacity:.85}.chat-container{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;background:#ffffff;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;align-items:center;min-height:0}.chat-messages{width:100%;max-width:700px;padding:2rem 1rem 3rem;display:flex;flex-direction:column;gap:1.5rem}.message{display:inline-block;max-width:85%;padding:.75rem 1rem;font-size:.95rem;line-height:1.5;word-break:break-word;border-radius:1rem;background:#e5e7eb;color:#1f2937}.message.bot{align-self:flex-start;background:#e5e7eb;color:#1f2937;border-top-left-radius:.25rem;margin-left:1.25rem}.message.user{align-self:flex-end;background:#152a3a;color:#fff;border-top-right-radius:.25rem;margin-right:1.25rem}.chat-footer{flex:0 0 auto;display:flex;justify-content:center;align-items:center;padding:.75rem 1rem 1rem;gap:.5rem;position:absolute;bottom:0;width:100%;background:transparent;z-index:30;pointer-events:none}.chat-input{width:100%;max-width:600px;border:1px solid #e5e7eb;border-radius:9999px;padding:.75rem 1.25rem;font-size:16px;background:#ffffff;box-shadow:0 2px 8px #00000014;outline:none;pointer-events:auto}.chat-input:disabled{background:#ffffff;opacity:1;color:#1f2937}.chat-send-btn{background:#152a3a;color:#fff;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border-radius:9999px;border:none;box-shadow:0 2px 8px #00000014;cursor:pointer;pointer-events:auto}.chat-camera{background:#FFF;box-shadow:0 2px 8px #00000014;border-radius:20px;border:none;padding:.6rem 1rem;cursor:pointer;pointer-events:auto}.chat-send-btn:hover{opacity:.85}.chat-send-btn.readonly{background:#f9fafb;color:#152a3a;border:1px solid #e5e7eb;cursor:not-allowed}.premium-button{width:100%;max-width:640px;padding:.75rem 1.5rem;text-align:center;box-shadow:0 2px 8px #00000014}.premium-button:hover{opacity:1!important}.send-icon{width:12px;height:12px}.desktop-actions{display:flex;gap:.5rem}.mobile-menu{display:none;position:relative}.menu-toggle{background:white;color:#152a3a;border:none;font-size:1.5rem;padding:.25rem .5rem;border-radius:.5rem;cursor:pointer}.mobile-dropdown{position:absolute;top:2.5rem;right:0;background:white;box-shadow:0 4px 8px #0000001a;border-radius:.75rem;overflow:hidden;width:160px;z-index:50}.mobile-dropdown button{width:100%;padding:.75rem 1rem;text-align:right;background:white;border:none;font-size:1rem;color:#152a3a;cursor:pointer}.mobile-dropdown button:hover{background:#f1f5f9}@media (max-width: 640px){.chat-wrapper,.chat-page{position:relative}.chat-input{font-size:16px;padding:.65rem 1rem}.chat-send-btn{font-size:.95rem;padding:.65rem 1.25rem}.chat-messages{padding:1.5rem 1rem 2.5rem}.chat-container{padding-top:4rem}.chat-footer{position:fixed}.desktop-actions{display:none}.mobile-menu{display:block}.modal-share-content{margin:0 1rem}}.empty-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;margin-top:10px}.empty-card{background:#ffffff;border:1px solid #e5e7eb;border-radius:1.5rem;padding:2.5rem 2rem;max-width:600px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.empty-logo-title{display:flex;align-items:center;gap:.5rem;justify-content:center}.empty-logo-small{width:32px;height:32px}.empty-brand{font-weight:600;font-size:1.5rem;color:#152a3a}.empty-subtitle{font-size:1rem;color:#4b5563;line-height:1.6}.empty-cta{background:#ffffff;color:#152a3a;font-size:1rem;font-weight:600;padding:.75rem 2rem;border:1px solid #e5e7eb;border-radius:9999px;cursor:pointer;transition:background-color .2s,color .2s,border-color .2s;width:100%;max-width:320px;box-shadow:none}.empty-cta:hover{background-color:#f1f5f9}.logout-icon{width:18px;height:18px}.whoop-logo-wrapper svg{width:48px;height:48px;color:#152a3a}.empty-note{margin-top:1rem;font-size:.85rem;color:#6b7280;text-align:center;font-weight:400;opacity:.5}.typing{display:flex;align-items:center;justify-content:center;gap:4px}.dot{width:6px;height:6px;background-color:#9ca3af;border-radius:50%;animation:typing 2s infinite ease-in-out}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.6}40%{transform:scale(1.2);opacity:1}}.sleep-data-card{background:#ffffff;border:1px solid #e5e7eb;border-radius:1.5rem;padding:2.5rem 2rem;max-width:600px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.sleep-data-header{display:flex;align-items:center;gap:.5rem;justify-content:center}.sleep-data-content p{font-size:1rem;color:#374151;margin:.25rem 0}.sleep-loader{background:#ffffff;border:1px solid #e5e7eb;border-radius:1.5rem;padding:2.5rem 2rem;max-width:600px;width:100%;text-align:center;display:flex;align-items:center;justify-content:center;min-height:280px;box-shadow:0 4px 8px #00000005}.spinner{width:32px;height:32px;border:4px solid #e5e7eb;border-top:4px solid #152a3a;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chat-wrapper{display:flex;height:100dvh}.chat-page{flex:1;display:flex;flex-direction:column;background:#ffffff;overflow:hidden;position:relative}.chat-header-left{display:flex;align-items:center;gap:.75rem}.sidebar-wrapper{width:260px;min-width:260px;max-width:260px;background:#f9fafb;height:100vh;transition:all .4s cubic-bezier(.25,.8,.25,1);overflow:hidden;display:flex;flex-direction:column}.sidebar-wrapper.collapsed{width:0;min-width:0;max-width:0}.mobile-header{height:4rem;background:white;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e5e7eb;padding:1rem;z-index:10;position:fixed;top:0;left:0;right:0}.mobile-logo{display:flex;align-items:center;gap:.5rem}.mobile-menu-btn,.mobile-new-chat-btn{background:none;border:none;cursor:pointer;padding:.25rem}.mobile-sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:#f9fafb;display:flex;flex-direction:column;transform:translate(-100%);transition:transform .3s ease;z-index:100}.mobile-sidebar.open{transform:translate(0)}.mobile-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#152a3a;opacity:.1;z-index:50}.modal-share-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.25);display:flex;justify-content:center;align-items:center;z-index:100}.modal-share-content{background:#ffffff;border:1px solid #e5e7eb;border-radius:1.5rem;padding:2.5rem 2rem;max-width:600px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.25rem;box-shadow:0 4px 16px #0000000d}.modal-share-content h3{font-size:1.25rem;font-weight:600;color:#152a3a}.modal-share-input{width:100%;max-width:460px;padding:.75rem 1rem;font-size:1rem;border:1px solid #e5e7eb;border-radius:9999px;text-align:center;color:#1f2937;background:#ffffff}.modal-share-buttons{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.modal-share-copy-btn,.modal-share-close-btn{background:#ffffff;color:#152a3a;font-size:1rem;font-weight:600;padding:.75rem 2rem;border:1px solid #e5e7eb;border-radius:9999px;cursor:pointer;transition:background-color .2s ease}.modal-share-copy-btn:hover,.modal-share-close-btn:hover{background-color:#f1f5f9}.share-socials{display:flex;justify-content:center;gap:2rem;margin-top:2rem}.share-icon-wrapper{display:flex;flex-direction:column;align-items:center;color:#374151;text-decoration:none;font-size:.8rem}.share-icon{width:36px;height:36px;border-radius:9999px;background-color:#f3f4f6;padding:8px;box-shadow:0 1px 2px #0000000d;margin-bottom:.25rem}.message-dropdown{position:absolute;right:0;top:100%;background:white;border:1px solid #e5e7eb;box-shadow:0 2px 10px #0000000d;border-radius:.5rem;z-index:10;padding:.5rem;display:flex;flex-direction:column;gap:.25rem}@media (max-width: 640px){.message-action-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.2);backdrop-filter:blur(5px);display:flex;justify-content:flex-start;align-items:center;z-index:10000!important;padding-left:1.25rem}.message-action-overlay.user{justify-content:flex-end;padding-right:1.25rem;padding-left:0}.action-container{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;width:100%}.message.highlighted{max-width:80%;padding:1rem 1.5rem;background:#e5e7eb;color:#1f2937;font-size:.95rem;line-height:1.5;font-family:Inter,sans-serif;white-space:pre-wrap;word-break:break-word;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:manipulation;margin-left:0rem;align-self:flex-start;border-radius:.25rem 1rem 1rem;max-height:300px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.message.highlighted::-webkit-scrollbar{width:6px}.message.highlighted::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:4px}.message.highlighted.user{background:#152a3a!important;color:#fff;align-self:flex-end;margin-left:auto;margin-right:1.25rem;border-top-right-radius:.25rem;border-top-left-radius:1rem}.message-dropdown.centered{display:flex;flex-direction:column;gap:.5rem}.message-action-overlay.user .message-dropdown.centered{align-items:flex-end;margin-left:auto;margin-right:1.25rem}.message-dropdown button{background:white;border:1px solid #e5e7eb;border-radius:0rem;padding:.5rem 1.25rem;font-size:.95rem;cursor:pointer}.message-dropdown button:hover{background:#f3f4f6}.message-action-overlay .message-dropdown.centered{position:static!important;margin-top:.75rem;width:65%;max-width:20rem;background:#fff;border-radius:.5rem;box-shadow:0 4px 12px #0000001a;padding:0;overflow:hidden;border:1px solid #e5e7eb}.message-action-overlay .message-dropdown.centered button{background:white;border:none;padding:.75rem 1rem;font-size:1rem;cursor:pointer;text-align:left;display:flex;justify-content:space-between;align-items:center;width:100%;border-bottom:1px solid #e5e7eb;transition:background .15s;color:#4b5563}.message-action-overlay .message-dropdown.centered button:last-child{border-bottom:none}.message-action-overlay .message-dropdown.centered button:hover{background:#f9fafb}.message:active{background-color:#e5e7ebb3}.message.user:active{background-color:#152a3ad9;color:#fff}.message-pressed{background-color:#e5e7ebb3}.message-pressed.user{background-color:#152a3ad9;color:#fff}.message{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:manipulation}}audio{width:100%;margin:0 auto;display:block}.audio-container{width:100%;display:flex;justify-content:center;padding:10px;margin-bottom:1rem}.dropdown-caret{transition:transform .2s ease}.dropdown-caret.open{transform:rotate(180deg)}.sidebar{width:260px;background:#f9fafb;height:100dvh;display:flex;flex-direction:column;transition:width .3s ease}.sidebar.collapsed{width:60px;background:#f9fafb;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;align-items:center}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1rem 0rem}.collapse-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;position:relative;margin-top:3px}.sidebar.collapsed .collapse-btn{top:18px;transition:top .3s ease}.new-chat-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;margin-top:3px}.chat-list{flex:1;overflow-y:auto;padding:.5rem 0;margin-top:1rem}.chat-item{padding:.005rem 1.25rem;cursor:pointer;color:#374151;font-size:.9rem}.chat-item p{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-item:hover{background:#e5e7eb}.chat-item.active{background:#dbeafe;font-weight:600}.loading-chats{padding:1rem;font-size:.85rem;color:#9ca3af}.today-label{font-weight:700;padding:.75rem 1.25rem;font-size:.8rem;display:block}.yesterday-label{font-weight:700;padding:.75rem 1.25rem;font-size:.8rem;margin-top:1rem!important;display:block}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid #e5e7eb}.settings-btn{background:none;border:none;color:#6b7280;font-size:.95rem;cursor:pointer;width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem 0}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.4);z-index:1000;display:flex;justify-content:center;align-items:center}.modal-settings{background:white;border-radius:.75rem;padding:1rem;width:320px;max-width:90vw;box-shadow:0 10px 25px #0000001a;min-height:300px}.modal-tabs{display:flex;justify-content:space-around;margin-bottom:1rem;border-bottom:1px solid #e5e7eb}.modal-tab{background:none;border:none;font-weight:500;font-size:.9rem;padding:.5rem;cursor:pointer;color:#6b7280;border-bottom:2px solid transparent}.modal-tab.active{border-bottom:2px solid #152a3a;color:#1f2937}.modal-content{min-height:80px}.header-logout-btn{background:white;color:#152a3a;border:1px solid #e5e7eb;font-size:.875rem;font-weight:500;padding:.5rem 1rem;border-radius:9999px;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:background-color .2s,color .2s}.header-logout-btn:hover{background-color:#f1f5f9}.logout-text{display:inline-block}*,*:before,*:after{box-sizing:border-box}:root{--primary: #152a3a;--text: #111827;--text-muted: #6b7280;--border: #e5e7eb;--bg: #ffffff}html,body{margin:0;padding:0;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--text);background:var(--bg)}.min-h-screen{min-height:100vh}.auth-page{display:flex;flex-direction:column}@media screen and (max-width: 640px){.auth-page{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;overflow:hidden}}.auth-nav{display:flex;align-items:center;padding:1rem 1.5rem}.auth-nav img{width:1.5rem;height:1.5rem;margin-right:.5rem}.auth-nav .brand{font-size:1.25rem;font-weight:600;color:var(--primary)}.auth-container{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:4rem 1rem 0}.auth-box{width:100%;max-width:360px;padding:1.5rem;background:transparent;border:none;box-shadow:none}.auth-box h1{margin-top:0;margin-bottom:2rem;font-size:1.875rem;font-weight:500;text-align:center}.auth-box input[type=email]{width:100%;padding:.75rem 1rem;font-size:1rem;border:1px solid var(--border);border-radius:.375rem;margin-bottom:1rem;color:var(--text)}.auth-box input[type=email]:focus{outline:none;box-shadow:0 0 0 3px #152a3a33}.auth-box .btn-primary{width:100%;padding:.75rem;font-size:1rem;font-weight:500;color:#fff;background:var(--primary);border:none;border-radius:.375rem;cursor:pointer;transition:background .2s;margin-bottom:.25rem}.auth-box .btn-primary:disabled{background:var(--border);cursor:not-allowed}.auth-box .btn-primary:hover:not(:disabled){background:#0e1c2c}.auth-box .text-muted{text-align:center;font-size:.875rem;color:var(--text-muted);margin-top:1.25rem;margin-bottom:.5rem}.auth-box .text-muted a{color:var(--primary);text-decoration:none}.auth-box .text-muted a:hover{text-decoration:underline}.auth-box .divider{display:flex;align-items:center;margin:2rem 0}.auth-box .divider:before,.auth-box .divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-box .divider span{margin:0 .75rem;font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.auth-box .social-btn{width:100%;display:flex;align-items:center;justify-content:center;padding:.75rem;font-size:1rem;font-weight:400;color:var(--text-muted);border:1px solid var(--border);border-radius:.375rem;background:var(--bg);cursor:pointer;transition:background .15s;margin-bottom:1rem;gap:10px}.auth-box .social-btn:hover{background:#f9fafb}.auth-box .social-btn img{width:1.25rem;height:1.25rem;margin-right:.75rem}.auth-box .footer{text-align:center;font-size:.75rem;color:var(--text-muted);margin-top:1rem}.auth-box .footer a{color:var(--text-muted);text-decoration:none;margin:0 .25rem}.auth-box .footer a:hover{text-decoration:underline}.response-container{min-height:1.25rem;margin-bottom:1rem}.response-msg{margin:0;font-size:.875rem;color:#152a3a;text-align:center;font-weight:600}.response-msg.error{color:#dc2626}.subheading{margin-top:.5rem;margin-bottom:1.5rem;font-size:1rem;color:var(--text-muted);text-align:center}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;padding:.75rem;font-size:1rem;font-weight:400;color:var(--text-muted);border:1px solid var(--border);border-radius:.375rem;background:var(--bg);cursor:pointer;transition:background .15s;margin-bottom:1rem;gap:10px}.btn-google:hover{background-color:#f5f5f5}.google-icon{width:20px;height:20px}.auth-divider{display:flex;align-items:center;margin:1.5rem 0;text-align:center;color:#aaa;font-size:.9rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid #ddd;margin:0 10px}
