*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html{-webkit-text-size-adjust:100%;touch-action:manipulation;height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;min-height:-webkit-fill-available;height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none;position:fixed;width:100%;overflow:hidden}#root{min-height:100vh;min-height:-webkit-fill-available;height:100%;display:flex;align-items:center;justify-content:center}.loading-container{display:flex;align-items:center;justify-content:center;min-height:100vh}.loading-spinner{width:50px;height:50px;border:5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.access-denied{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.access-denied-container{background:#fff;border-radius:30px;padding:60px 40px;text-align:center;max-width:500px;box-shadow:0 20px 60px #0000004d}.denied-icon{font-size:80px;margin-bottom:20px}.access-denied-container h1{color:#e74c3c;font-size:32px;margin-bottom:20px}.access-denied-container p{color:#555;font-size:18px;line-height:1.6;margin-bottom:10px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-container{background:#fff;border-radius:30px;padding:50px 40px;max-width:450px;width:100%;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:40px}.robot-icon{font-size:60px;margin-bottom:15px}.login-header h1{color:#667eea;font-size:28px;margin-bottom:10px}.login-header p{color:#888;font-size:16px}.form-group{margin-bottom:25px}.form-group label{display:block;color:#555;font-weight:600;margin-bottom:8px;font-size:14px}.form-group input{width:100%;padding:15px;border:2px solid #e0e0e0;border-radius:15px;font-size:16px;transition:all .3s;-webkit-appearance:none}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-btn{width:100%;padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:15px;font-size:18px;font-weight:600;cursor:pointer;transition:transform .2s;-webkit-appearance:none;touch-action:manipulation}.login-btn:hover{transform:translateY(-2px)}.login-btn:active{transform:translateY(0)}.error-message{margin-top:15px;padding:12px;background:#fee;color:#c33;border-radius:10px;font-size:14px;text-align:center}.chat-page{width:100%;height:100vh;height:-webkit-fill-available;display:flex;flex-direction:column;background:#f5f7fa;position:fixed;top:0;left:0;right:0;bottom:0}#root:has(.chat-page){display:block}.chat-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 20px;padding-top:max(12px,env(safe-area-inset-top));padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));box-shadow:0 2px 10px #0000001a;flex-shrink:0;z-index:100}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.header-left{display:flex;align-items:center;gap:15px}.sidebar-toggle{background:#fff3;border:2px solid white;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:20px;color:#fff}.sidebar-toggle:hover{background:#ffffff4d;transform:scale(1.05)}.chat-header .robot-icon{font-size:28px;margin-bottom:0}.chat-header h1{font-size:20px}.header-right{display:flex;align-items:center;gap:15px}.avatar-button{background:#fff3;border:2px solid white;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease}.avatar-button:hover{background:#ffffff4d;transform:scale(1.1)}.current-avatar{font-size:22px}.avatar-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.avatar-picker{background:#fff;border-radius:20px;padding:30px;max-width:500px;max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.avatar-picker h3{margin:0 0 20px;font-size:24px;color:#667eea;text-align:center}.avatar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:10px;margin-bottom:20px}.avatar-option{background:#f5f5f5;border:3px solid transparent;border-radius:12px;width:60px;height:60px;font-size:32px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.avatar-option:hover{background:#e0e0e0;transform:scale(1.1)}.avatar-option.selected{border-color:#667eea;background:#e8ebff;transform:scale(1.1)}.close-picker{width:100%;background:#667eea;color:#fff;border:none;padding:12px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:background .3s ease}.close-picker:hover{background:#5568d3}.theme-button,.password-button{background:#fff3;border:2px solid white;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:20px}.theme-button:hover,.password-button:hover{background:#ffffff4d;transform:scale(1.1)}.theme-customizer{background:#fff;border-radius:20px;padding:30px;max-width:600px;max-height:85vh;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease}.theme-customizer h3{margin:0 0 25px;font-size:26px;color:#667eea;text-align:center}.theme-customizer h4{margin:20px 0 15px;font-size:18px;color:#333;font-weight:600}.preset-section{margin-bottom:30px}.preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.preset-option{border:3px solid transparent;border-radius:12px;padding:30px 15px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.preset-option:hover{transform:scale(1.05);border-color:#667eea;box-shadow:0 4px 12px #00000026}.preset-name{display:block;color:#fff;font-weight:600;font-size:14px;text-transform:capitalize;text-shadow:1px 1px 3px rgba(0,0,0,.3)}.custom-colors-section{border-top:2px solid #e0e0e0;padding-top:20px}.color-controls{display:grid;grid-template-columns:1fr;gap:15px}.color-control{display:flex;align-items:center;gap:12px;padding:12px;background:#f8f8f8;border-radius:10px}.color-control label{flex:1;font-weight:500;color:#333;font-size:14px}.color-control input[type=color]{width:60px;height:40px;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:all .2s ease}.color-control input[type=color]:hover{border-color:#667eea;transform:scale(1.05)}.color-value{font-size:12px;color:#666;font-family:monospace;min-width:70px;text-align:right}.username-display{font-size:14px;font-weight:500}.logout-btn{background:#fff3;color:#fff;border:2px solid white;padding:6px 16px;border-radius:20px;font-size:13px;cursor:pointer;transition:all .3s}.logout-btn:hover{background:#fff;color:#667eea}.main-content{display:flex;flex:1;min-height:0;overflow:hidden;position:relative}.chat-sidebar{width:280px;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000000d;transition:width .3s ease,padding .3s ease,border .3s ease;overflow:hidden}.chat-sidebar.desktop-only.hidden{width:0;padding:0;border:none;min-width:0}.chat-list-mobile-overlay{display:none}.chat-list-mobile-page{display:flex;flex-direction:column;height:100%}.mobile-page-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid rgba(0,0,0,.1)}.mobile-page-header h2{margin:0;font-size:22px;font-weight:600}.close-mobile-page{background:transparent;border:none;font-size:24px;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease}.close-mobile-page:hover{background:#0000001a}.new-chat-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:15px 20px;margin:15px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px}.new-chat-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.chat-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 10px 10px}.chat-item{padding:12px 15px;margin-bottom:8px;border-radius:10px;cursor:pointer;transition:all .2s ease;background:#f8f8f8;display:flex;align-items:center;justify-content:space-between}.chat-item:hover{background:#e8ebff}.chat-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.chat-title{flex:1;font-weight:500;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-title-input{flex:1;background:#fff;border:2px solid #667eea;border-radius:6px;padding:6px 10px;font-size:14px;font-weight:500;outline:none}.chat-actions{display:flex;gap:5px;opacity:0;transition:opacity .2s ease}.chat-item:hover .chat-actions,.chat-item.active .chat-actions{opacity:1}.chat-action-btn{background:#0000001a;border:none;border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:14px}.chat-action-btn:hover{background:#0003;transform:scale(1.1)}.chat-item.active .chat-action-btn{background:#fff3}.chat-item.active .chat-action-btn:hover{background:#ffffff4d}.chat-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;position:relative}.safety-banner{background:linear-gradient(135deg,#ffeaa7,#fdcb6e);padding:15px 30px;padding-left:max(30px,env(safe-area-inset-left));padding-right:max(30px,env(safe-area-inset-right));display:flex;align-items:center;gap:15px;box-shadow:0 2px 10px #0000000d;flex-shrink:0}.safety-icon{font-size:24px}.safety-banner p{color:#2d3436;font-size:14px;font-weight:500;margin:0}.chat-container{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:30px;max-width:1200px;width:100%;margin:0}.messages-area{display:flex;flex-direction:column;gap:20px}.message{display:flex;gap:12px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{flex-direction:row-reverse}.message-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.message.ai .message-avatar{background:linear-gradient(135deg,#667eea,#764ba2)}.message.user .message-avatar{background:linear-gradient(135deg,#f093fb,#f5576c)}.message-content{max-width:70%;padding:15px 20px;border-radius:20px;line-height:1.5;font-size:15px}.message.ai .message-content{background:#fff;color:#2d3436;border-bottom-left-radius:5px;box-shadow:0 2px 10px #0000000d}.message.user .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:5px}.message-timestamp{font-size:11px;opacity:.7;margin-top:5px}.typing-indicator{display:flex;gap:5px;padding:5px 0}.typing-dot{width:8px;height:8px;border-radius:50%;background:#667eea;animation:typing 1.4s infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.input-container{background:#fff;padding:20px 30px;padding-left:max(30px,env(safe-area-inset-left));padding-right:max(30px,env(safe-area-inset-right));padding-bottom:max(20px,env(safe-area-inset-bottom));box-shadow:0 -2px 10px #0000000d;flex-shrink:0;z-index:100}.chat-form{display:flex;gap:15px;max-width:1200px;margin:0 auto}.message-input{flex:1;padding:15px 20px;border:2px solid #e0e0e0;border-radius:25px;font-size:16px;transition:all .3s;-webkit-appearance:none}.message-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.message-input:disabled{opacity:.6;cursor:not-allowed}.send-btn{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s;font-size:20px;-webkit-appearance:none;touch-action:manipulation}.send-btn:hover{transform:scale(1.1)}.send-btn:active{transform:scale(.95)}.send-btn:disabled{opacity:.5;cursor:not-allowed;transform:scale(1)}@media (max-width: 768px){.chat-header{padding:10px 15px;padding-top:max(10px,env(safe-area-inset-top));padding-left:max(15px,env(safe-area-inset-left));padding-right:max(15px,env(safe-area-inset-right))}.header-content{gap:10px}.header-left{gap:8px}.chat-header h1{font-size:18px;display:none}.chat-header .robot-icon{font-size:24px}.sidebar-toggle{width:32px;height:32px;font-size:18px}.avatar-button,.theme-button,.password-button{width:32px;height:32px}.current-avatar,.theme-button,.password-button{font-size:18px}.username-display{font-size:12px}.logout-btn{padding:5px 12px;font-size:12px}.main-content{flex:1;min-height:0}.chat-sidebar.desktop-only{display:none}.chat-list-mobile-overlay{display:flex;position:fixed;top:0;left:0;right:0;bottom:0;z-index:200;background:#00000080;animation:fadeIn .2s ease;padding-top:calc(44px + env(safe-area-inset-top))}.chat-list-mobile-page{width:100%;height:100%;animation:slideUp .3s ease}.safety-banner{padding:10px 15px;padding-left:max(15px,env(safe-area-inset-left));padding-right:max(15px,env(safe-area-inset-right));gap:8px}.safety-banner p{font-size:11px}.chat-container{padding:15px 12px;padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right));max-width:100%}.message-content{max-width:85%;font-size:14px}.input-container{padding:12px 15px;padding-left:max(15px,env(safe-area-inset-left));padding-right:max(15px,env(safe-area-inset-right));padding-bottom:max(12px,env(safe-area-inset-bottom))}.message-input{font-size:14px;padding:12px 18px}.send-btn{width:45px;height:45px}}.markdown-content{line-height:1.6}.markdown-content p{margin:0 0 12px}.markdown-content p:last-child{margin-bottom:0}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{margin:16px 0 8px;font-weight:600;line-height:1.3}.markdown-content h1{font-size:1.8em}.markdown-content h2{font-size:1.5em}.markdown-content h3{font-size:1.3em}.markdown-content h4{font-size:1.1em}.markdown-content code{background:#0000001a;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:.9em}.markdown-content pre{background:#0000001a;padding:12px;border-radius:6px;overflow-x:auto;margin:12px 0}.markdown-content pre code{background:none;padding:0}.markdown-content ul,.markdown-content ol{margin:8px 0;padding-left:24px}.markdown-content li{margin:4px 0}.markdown-content blockquote{border-left:4px solid rgba(0,0,0,.2);padding-left:12px;margin:12px 0;opacity:.9}.markdown-content a{color:inherit;text-decoration:underline;opacity:.9}.markdown-content a:hover{opacity:1}.markdown-content strong{font-weight:600}.markdown-content em{font-style:italic}.markdown-content hr{border:none;border-top:2px solid rgba(0,0,0,.1);margin:16px 0}.markdown-content table{border-collapse:collapse;width:100%;margin:12px 0}.markdown-content table th,.markdown-content table td{border:1px solid rgba(0,0,0,.2);padding:8px;text-align:left}.markdown-content table th{background:#0000001a;font-weight:600}.user-management-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}.user-management-modal{background:#fff;border-radius:12px;width:100%;max-width:900px;max-height:90vh;box-shadow:0 10px 40px #0003;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;flex-shrink:0}.modal-content{padding:25px;overflow-y:auto;flex:1;min-height:0}.loading-state{text-align:center;padding:40px;color:#6c757d;font-size:16px}.users-list h3{font-size:18px;font-weight:600;margin-bottom:15px;color:#2c3e50}.user-card{background:#f8f9fa;border-radius:12px;padding:20px;margin-bottom:15px;display:flex;justify-content:space-between;align-items:center;gap:20px;border:2px solid transparent;transition:all .2s ease}.user-card:hover{border-color:#2c3e50;transform:translate(3px)}.user-card.parent{background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.user-info{flex:1}.user-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.user-name{font-size:18px;font-weight:600;color:#2c3e50;text-transform:capitalize}.role-badge{font-size:12px;font-weight:600;padding:4px 12px;border-radius:12px;text-transform:uppercase}.role-badge.parent{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff}.role-badge.child{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.user-details{display:flex;flex-direction:column;gap:6px}.detail{display:flex;gap:8px;font-size:13px}.detail-label{color:#6c757d;font-weight:500}.detail-value{color:#2c3e50}.change-password-btn{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.change-password-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2c3e504d}.tab-buttons{display:flex;gap:10px;margin-bottom:25px;border-bottom:2px solid #e0e0e0}.tab-button{flex:1;padding:12px 20px;background:none;border:none;border-bottom:3px solid transparent;font-size:15px;font-weight:600;color:#6c757d;cursor:pointer;transition:all .2s ease}.tab-button:hover{color:#2c3e50}.tab-button.active{color:#2c3e50;border-bottom-color:#2c3e50}.password-change-panel,.assignments-panel,.create-user-panel{margin-top:25px;padding-top:25px;border-top:2px solid #e0e0e0}.password-change-panel h3,.assignments-panel h3,.create-user-panel h3{font-size:18px;font-weight:600;margin-bottom:20px;color:#2c3e50}.panel-description{color:#6c757d;margin-bottom:20px;line-height:1.5}.assignments-list{display:flex;flex-direction:column;gap:12px}.assignment-card{background:#f8f9fa;border-radius:12px;padding:16px;display:flex;justify-content:space-between;align-items:center;gap:15px;border:2px solid transparent;transition:all .2s ease}.assignment-card.assigned{background:#e8f5e9;border-color:#4caf50}.assignment-card:hover{transform:translate(3px)}.assignment-info{flex:1;display:flex;align-items:center;gap:12px}.child-name{font-size:16px;font-weight:600;color:#2c3e50;text-transform:capitalize}.assignment-status{font-size:13px;font-weight:600;padding:4px 10px;border-radius:12px}.assignment-status.active{background:#4caf50;color:#fff}.assignment-status.inactive{background:#e0e0e0;color:#6c757d}.toggle-assignment-btn{padding:8px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.toggle-assignment-btn.add{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff}.toggle-assignment-btn.add:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2c3e504d}.toggle-assignment-btn.remove{background:#f44336;color:#fff}.toggle-assignment-btn.remove:hover{background:#d32f2f;transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}.form-group input[type=text],.form-group select{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;transition:all .2s ease;font-family:inherit}.form-group input[type=text]:focus,.form-group select:focus{outline:none;border-color:#2c3e50;box-shadow:0 0 0 3px #2c3e501a}.form-group input[type=text]:disabled,.form-group select:disabled{background:#f5f5f5;cursor:not-allowed}.password-input-wrapper input:focus{outline:none;border-color:#2c3e50;box-shadow:0 0 0 3px #2c3e501a}.success-message{background:#efe;border:1px solid #cfc;color:#3c3;padding:12px;border-radius:8px;font-size:14px;margin-bottom:20px}.submit-button{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff}.submit-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #2c3e504d}@media (max-width: 768px){.user-management-modal{max-width:100%;border-radius:0;min-height:100vh}.modal-header{padding:15px 20px}.modal-header h2{font-size:20px}.modal-content{padding:20px}.user-card{flex-direction:column;align-items:stretch}.change-password-btn{width:100%}.button-group{flex-direction:column-reverse}.cancel-button,.submit-button{width:100%}.user-header{flex-wrap:wrap}.detail{flex-direction:column;gap:2px}}.parent-dashboard{height:100vh;height:-webkit-fill-available;background:#f8f9fa;display:flex;flex-direction:column;overflow:hidden;position:fixed;top:0;left:0;right:0;bottom:0}.parent-header{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;padding:12px 20px;padding-top:max(12px,env(safe-area-inset-top));padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));box-shadow:0 2px 10px #0000001a;flex-shrink:0}.parent-header .header-content{display:flex;justify-content:space-between;align-items:center;width:100%}.parent-header .header-left{display:flex;align-items:center;gap:15px}.parent-header .header-right{display:flex;align-items:center;gap:12px}.parent-icon{font-size:28px}.parent-header h1{font-size:20px;font-weight:600;margin:0}.user-management-btn,.logout-btn{background:#fff3;color:#fff;border:2px solid white;padding:6px 16px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:13px;-webkit-appearance:none;touch-action:manipulation}.user-management-btn:hover,.logout-btn:hover{background:#fff;color:#2c3e50}.dashboard-content{display:flex;flex:1;width:100%;gap:20px;padding:20px;padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));padding-bottom:max(20px,env(safe-area-inset-bottom));overflow:hidden;min-height:0}.dashboard-sidebar{width:350px;min-width:350px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;overflow:hidden;height:100%}.filter-section{padding:20px;border-bottom:1px solid #e0e0e0;flex-shrink:0}.filter-section label{display:block;font-weight:600;margin-bottom:8px;color:#2c3e50}.kid-filter{width:100%;padding:10px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#fff;-webkit-appearance:none}.kid-filter:hover{border-color:#2c3e50}.kid-filter:focus{outline:none;border-color:#2c3e50;box-shadow:0 0 0 3px #2c3e501a}.toggle-conversations-btn{display:none;width:100%;margin-top:10px;padding:10px 12px;background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;touch-action:manipulation}.toggle-conversations-btn:active{transform:scale(.98)}.chats-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:15px;min-height:0;display:flex;flex-direction:column}.chats-list h3{font-size:16px;font-weight:600;margin-bottom:15px;color:#2c3e50}.chat-card{padding:15px;margin-bottom:10px;border-radius:8px;background:#f8f9fa;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.chat-card:hover{background:#e9ecef;transform:translate(3px)}.chat-card.active{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;border-color:#2c3e50}.chat-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.kid-name{font-weight:600;text-transform:capitalize;font-size:14px}.chat-card.active .kid-name{color:gold}.chat-time{font-size:12px;opacity:.7}.chat-card-title{font-size:14px;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.messages-panel{flex:1;min-width:600px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;overflow:hidden;height:100%;min-height:0}.panel-header{padding:20px 25px;border-bottom:2px solid #e0e0e0;background:#f8f9fa;flex-shrink:0}.panel-header h2{font-size:20px;font-weight:600;margin:0 0 10px;color:#2c3e50}.chat-info{display:flex;gap:15px;align-items:center;font-size:14px;color:#6c757d;margin:0}.kid-badge{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;padding:4px 12px;border-radius:12px;font-weight:600;text-transform:capitalize;font-size:12px}.messages-container{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px 25px;min-height:0}.message-item{margin-bottom:20px;padding:15px;border-radius:10px;background:#f8f9fa}.message-item.user{background:#e3f2fd;border-left:4px solid #2196f3}.message-item.ai{background:#f3e5f5;border-left:4px solid #9c27b0}.message-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:13px}.message-avatar{font-size:20px}.message-sender{font-weight:600;color:#2c3e50;text-transform:capitalize}.message-time{margin-left:auto;color:#6c757d;font-size:12px}.message-text{color:#2c3e50;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.no-selection{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#6c757d;min-height:0}.no-selection-icon{font-size:64px;margin-bottom:15px;opacity:.5}.no-selection p{font-size:16px}.loading-text,.empty-text{text-align:center;color:#6c757d;padding:20px;font-style:italic}@media (max-width: 768px){.parent-header{padding:10px 15px;padding-top:max(10px,env(safe-area-inset-top));padding-left:max(15px,env(safe-area-inset-left));padding-right:max(15px,env(safe-area-inset-right))}.parent-icon{font-size:24px}.parent-header h1{font-size:18px}.user-management-btn,.logout-btn{padding:5px 12px;font-size:11px}.dashboard-content{flex-direction:column;padding:0;gap:0}.dashboard-sidebar{width:100%;min-width:100%;max-width:100%;height:auto;max-height:none;flex-shrink:0;border-radius:0}.filter-section{padding:15px}.toggle-conversations-btn{display:block}.chats-list{padding:0;max-height:0;overflow:hidden;transition:max-height .3s ease}.chats-list h3{display:none}.dashboard-sidebar[data-mobile-view=true] .chats-list{max-height:400px;padding:10px}.dashboard-sidebar[data-mobile-view=true] .chats-list h3{display:block}.chat-card{padding:12px}.messages-panel{flex:1;min-width:0;min-height:400px;border-radius:0}.panel-header{padding:15px 20px}.panel-header h2{font-size:18px}.messages-container{padding:15px 20px}.message-item{padding:12px}.no-selection{padding:20px}.no-selection-icon{font-size:48px}.no-selection p{font-size:14px}}@media (max-width: 480px){.parent-header .header-left{gap:10px}.parent-icon{font-size:24px}.parent-header h1{font-size:16px}.logout-btn{padding:5px 12px;font-size:11px}.chat-info{flex-direction:column;align-items:flex-start;gap:5px}.message-header{flex-wrap:wrap}.message-time{margin-left:0;width:100%}}.password-settings-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}.password-settings-modal{background:#fff;border-radius:12px;width:100%;max-width:500px;box-shadow:0 10px 40px #0003;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-header h2{margin:0;font-size:22px;font-weight:600}.close-button{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease}.close-button:hover{background:#fff3}.password-form{padding:25px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;margin-bottom:8px;color:#2c3e50;font-size:14px}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{width:100%;padding:12px 45px 12px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;transition:all .2s ease;font-family:inherit}.password-input-wrapper input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.password-input-wrapper input:disabled{background:#f5f5f5;cursor:not-allowed}.toggle-password{position:absolute;right:8px;background:none;border:none;cursor:pointer;padding:8px;font-size:18px;opacity:.6;transition:opacity .2s ease}.toggle-password:hover{opacity:1}.password-strength{margin-top:8px;display:flex;align-items:center;gap:10px}.strength-bar{height:4px;border-radius:2px;transition:all .3s ease}.password-strength span{font-size:12px;font-weight:600}.hint{margin-top:6px;font-size:12px;color:#6c757d;margin-bottom:0}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:12px;border-radius:8px;font-size:14px;margin-bottom:20px}.button-group{display:flex;gap:12px;margin-top:25px}.cancel-button,.submit-button{flex:1;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.cancel-button{background:#f5f5f5;color:#666}.cancel-button:hover:not(:disabled){background:#e0e0e0}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.submit-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.cancel-button:disabled,.submit-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 600px){.password-settings-modal{max-width:100%;border-radius:0;min-height:100vh}.modal-header{padding:15px 20px}.modal-header h2{font-size:20px}.password-form{padding:20px}.button-group{flex-direction:column-reverse}.cancel-button,.submit-button{width:100%}}
