:root{--primary: #646cff;--primary-dark: #535bf2;--background: #ffffff;--foreground: #213547;--card: #f9f9f9;--border: #e0e0e0;--muted: #888888;--muted-foreground: #666666;--accent: #e8e8ff;--radius: 12px;--shadow: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .12)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--background);color:var(--foreground);line-height:1.5}.app-layout{display:flex;min-height:100vh}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:60px;background:var(--background);border-bottom:1px solid var(--border);padding:0 20px;align-items:center;justify-content:space-between;z-index:100}.mobile-header h1{font-size:18px;font-weight:600}.menu-toggle{background:none;border:none;cursor:pointer;padding:8px;color:var(--foreground)}.sidebar{width:260px;background:var(--card);border-right:1px solid var(--border);padding:24px 0;position:fixed;height:100vh;overflow-y:auto;z-index:90}.sidebar-header{padding:0 24px 24px;border-bottom:1px solid var(--border);margin-bottom:16px}.sidebar-header h2{font-size:20px;font-weight:700;color:var(--primary)}.nav-list{list-style:none;padding:0 12px}.nav-list li{margin-bottom:4px}.nav-link{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius);color:var(--muted-foreground);text-decoration:none;transition:all .2s ease;font-size:15px;font-weight:500}.nav-link:hover{background:var(--accent);color:var(--primary)}.nav-link.active{background:var(--primary);color:#fff}.main-content{flex:1;margin-left:260px;padding:40px;min-height:100vh}.page{max-width:800px;margin:0 auto}.page h1{font-size:32px;font-weight:700;margin-bottom:24px}.hero{text-align:center;padding:60px 0}.hero-label{display:inline-block;font-size:13px;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:16px}.hero h1{font-size:48px;font-weight:700;line-height:1.1;margin-bottom:16px}.hero p{font-size:18px;color:var(--muted-foreground);max-width:500px;margin:0 auto 32px}.search-box{display:flex;gap:12px;max-width:600px;margin:0 auto}.search-box input{flex:1;height:56px;padding:0 20px;border:2px solid var(--border);border-radius:var(--radius);font-size:16px;transition:border-color .2s;background:var(--background)}.search-box input:focus{outline:none;border-color:var(--primary)}.search-box button{width:56px;height:56px;background:var(--primary);border:none;border-radius:var(--radius);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.search-box button:hover:not(:disabled){background:var(--primary-dark)}.search-box button:disabled{opacity:.6;cursor:not-allowed}.section{margin-top:48px}.section-title{font-size:14px;font-weight:600;color:var(--muted-foreground);text-transform:uppercase;letter-spacing:.8px;margin-bottom:16px}.teacher-list{display:flex;flex-direction:column;gap:12px}.teacher-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:inherit;transition:all .2s ease}.teacher-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-2px)}.teacher-avatar{width:56px;height:56px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:var(--primary);flex-shrink:0}.teacher-info{flex:1}.teacher-info h3{font-size:17px;font-weight:600;margin-bottom:4px}.teacher-info p{font-size:14px;color:var(--muted-foreground);margin-bottom:4px}.subjects{font-size:13px;color:var(--muted)}.arrow{color:var(--muted);font-size:20px}.sessions-list{display:flex;flex-direction:column;gap:16px}.session-card{padding:20px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:all .2s ease}.session-card:hover{box-shadow:var(--shadow)}.session-card.upcoming{border-left:4px solid var(--primary)}.session-card.completed{border-left:4px solid var(--muted);opacity:.8}.session-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.session-header h3{font-size:17px;font-weight:600}.badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase}.badge.upcoming{background:var(--accent);color:var(--primary)}.badge.completed{background:#e8e8e8;color:var(--muted-foreground)}.subject{color:var(--muted-foreground);margin-bottom:12px}.session-footer{display:flex;gap:16px;font-size:14px;color:var(--muted)}.calendar-placeholder{text-align:center;padding:80px 40px;background:var(--card);border:2px dashed var(--border);border-radius:var(--radius)}.calendar-placeholder .icon{color:var(--muted);margin-bottom:16px}.calendar-placeholder p{font-size:16px;color:var(--foreground);margin-bottom:8px}.subtext{font-size:14px;color:var(--muted-foreground)}.recordings-list{display:flex;flex-direction:column;gap:16px}.recording-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:all .2s ease}.recording-card:hover{box-shadow:var(--shadow)}.recording-thumbnail{width:80px;height:56px;background:#1a1a2e;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.recording-info{flex:1}.recording-info h3{font-size:15px;font-weight:600;margin-bottom:4px}.recording-info p{font-size:14px;color:var(--muted-foreground);margin-bottom:4px}.meta{font-size:13px;color:var(--muted)}.play-btn{width:40px;height:40px;background:var(--primary);border:none;border-radius:50%;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.play-btn:hover{background:var(--primary-dark)}.messages-list{display:flex;flex-direction:column;gap:12px}.message-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s ease}.message-card:hover{border-color:var(--primary);box-shadow:var(--shadow)}.message-avatar{width:48px;height:48px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;color:var(--primary);flex-shrink:0}.message-info{flex:1}.message-info h3{font-size:15px;font-weight:600;margin-bottom:4px}.message-info p{font-size:14px;color:var(--muted-foreground);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-meta{text-align:right}.message-meta .time{font-size:13px;color:var(--muted);display:block;margin-bottom:4px}.unread{display:inline-block;min-width:20px;height:20px;padding:0 6px;background:var(--primary);color:#fff;border-radius:10px;font-size:12px;font-weight:600;line-height:20px;text-align:center}.profile-card{text-align:center;padding:40px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px}.profile-avatar{width:80px;height:80px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;margin:0 auto 16px}.profile-card h2{font-size:24px;font-weight:600;margin-bottom:4px}.profile-card p{color:var(--muted-foreground)}.menu-list{display:flex;flex-direction:column;gap:8px}.menu-item{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:var(--foreground);font-weight:500;transition:all .2s ease}.menu-item:hover{border-color:var(--primary);box-shadow:var(--shadow)}.overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:80}@media(max-width:768px){.mobile-header{display:flex}.sidebar{transform:translate(-100%);transition:transform .3s ease}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:80px 20px 20px}.overlay{display:block}.hero h1{font-size:32px}.search-box{flex-direction:column}.search-box button{width:100%;height:48px}}.mascot-container{position:fixed;bottom:30px;right:30px;z-index:1000;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px}.mascot-small{--mascot-size: 60px;--shadow-size: 40px}.mascot-medium{--mascot-size: 100px;--shadow-size: 60px}.mascot-large{--mascot-size: 140px;--shadow-size: 80px}.mascot-avatar{width:var(--mascot-size);height:var(--mascot-size);position:relative;animation:mascot-float 3s ease-in-out infinite;transition:transform .3s ease}.mascot-avatar:hover{transform:scale(1.1)}@keyframes mascot-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes mascot-bounce{0%,to{transform:translateY(0) scale(1)}25%{transform:translateY(-20px) scale(1.1,.9)}50%{transform:translateY(-10px) scale(.95,1.05)}75%{transform:translateY(-15px) scale(1.05,.95)}}@keyframes mascot-wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}@keyframes mascot-entrance{0%{opacity:0;transform:scale(0) translateY(50px)}50%{transform:scale(1.2) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.mascot-animating{animation:mascot-bounce .6s ease!important}.mascot-hovered{animation:mascot-wiggle .5s ease infinite}.mascot-svg{width:100%;height:100%;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}.mascot-head{fill:#8b5cf6;transition:fill .3s ease}.mascot-body{fill:#7c3aed}.mascot-ear-left,.mascot-ear-right{fill:#8b5cf6}.mascot-ear-inner{fill:#a78bfa}.mascot-eye{fill:#1f2937;transition:transform .15s ease;transform-origin:center}.mascot-eye.blink{transform:scaleY(.1)}.mascot-eye-shine{fill:#fff}.mascot-cheek{fill:#f472b6;opacity:.6}.mascot-nose{fill:#1f2937}.mascot-mouth{fill:none;stroke:#1f2937;stroke-width:3;stroke-linecap:round}.mascot-hand,.mascot-happy .mascot-head{fill:#8b5cf6}.mascot-excited .mascot-head{fill:#a855f7}.mascot-excited .mascot-ear-left,.mascot-excited .mascot-ear-right{animation:ear-wiggle .3s ease infinite}@keyframes ear-wiggle{0%,to{transform:rotate(-20deg)}50%{transform:rotate(-25deg)}}.mascot-excited .mascot-ear-right{animation:ear-wiggle-right .3s ease infinite}@keyframes ear-wiggle-right{0%,to{transform:rotate(20deg)}50%{transform:rotate(25deg)}}.mascot-calm .mascot-head{fill:#7c3aed}.mascot-surprised .mascot-head{fill:#a78bfa}.mascot-shadow{width:var(--shadow-size);height:12px;background:#0000001a;border-radius:50%;animation:shadow-pulse 3s ease-in-out infinite;filter:blur(2px)}@keyframes shadow-pulse{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(.8);opacity:.2}}.mascot-tooltip{position:absolute;bottom:100%;right:0;margin-bottom:15px;animation:tooltip-bounce .5s ease}@keyframes tooltip-bounce{0%{opacity:0;transform:translateY(10px) scale(.9)}50%{transform:translateY(-5px) scale(1.02)}to{opacity:1;transform:translateY(0) scale(1)}}.tooltip-bubble{background:#fff;padding:12px 18px;border-radius:16px;box-shadow:0 4px 20px #00000026;font-size:14px;font-weight:500;color:#374151;white-space:nowrap;position:relative;border:2px solid #E5E7EB}.tooltip-arrow{position:absolute;bottom:-8px;right:30px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid white}.tooltip-arrow:before{content:"";position:absolute;top:-10px;left:-10px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-top:10px solid #E5E7EB;z-index:-1}.mascot-page-home .mascot-head{fill:#8b5cf6}.mascot-page-sessions .mascot-head{fill:#ec4899}.mascot-page-calendar .mascot-head{fill:#3b82f6}.mascot-page-messages .mascot-head{fill:#10b981}.mascot-container{animation:mascot-entrance .6s ease-out}@media(max-width:768px){.mascot-container{bottom:20px;right:20px}.mascot-medium{--mascot-size: 80px;--shadow-size: 50px}.mascot-large{--mascot-size: 100px;--shadow-size: 60px}.tooltip-bubble{font-size:13px;padding:10px 14px}}@media(prefers-reduced-motion:reduce){.mascot-avatar,.mascot-shadow,.mascot-container{animation:none}.mascot-ear-left,.mascot-ear-right{animation:none!important}}.mascot-chat-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:flex-end;justify-content:flex-end;padding:100px 30px 140px;z-index:9999;animation:fade-in .3s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.mascot-chat-container{width:380px;max-width:calc(100vw - 40px);height:500px;max-height:calc(100vh - 200px);background:#fff;border-radius:20px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;overflow:hidden;animation:slide-up .3s ease}@keyframes slide-up{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.mascot-chat-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.mascot-chat-title{display:flex;align-items:center;gap:12px}.mascot-chat-avatar{width:40px;height:40px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:pulse-avatar 2s ease-in-out infinite}@keyframes pulse-avatar{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.mascot-chat-title h3{font-size:16px;font-weight:600;margin:0}.mascot-chat-title .status{font-size:12px;opacity:.8;display:flex;align-items:center;gap:4px}.mascot-chat-title .status:before{content:"";width:6px;height:6px;background:#10b981;border-radius:50%;animation:blink-status 2s ease-in-out infinite}@keyframes blink-status{0%,to{opacity:1}50%{opacity:.5}}.close-btn{background:none;border:none;color:#fff;cursor:pointer;padding:4px;border-radius:8px;transition:background .2s}.close-btn:hover{background:#fff3}.mascot-chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px;background:#f9fafb}.message{display:flex;align-items:flex-end;gap:8px;max-width:85%;animation:message-in .3s ease}@keyframes message-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{align-self:flex-end;flex-direction:row-reverse}.mascot-avatar-small{width:28px;height:28px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.message-bubble{padding:12px 16px;border-radius:16px;font-size:14px;line-height:1.5;word-wrap:break-word}.message.mascot .message-bubble{background:#fff;color:#1f2937;border-bottom-left-radius:4px;box-shadow:0 2px 8px #00000014}.message.user .message-bubble{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-bottom-right-radius:4px}.typing-indicator{display:flex;gap:4px;padding:12px 16px;background:#fff;border-radius:16px 16px 16px 4px;box-shadow:0 2px 8px #00000014}.typing-indicator span{width:8px;height:8px;background:#8b5cf6;border-radius:50%;animation:typing-bounce 1.4s ease-in-out infinite}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-10px)}}.quick-actions{display:flex;flex-wrap:wrap;gap:8px;padding:12px 20px;background:#f9fafb;border-top:1px solid #E5E7EB}.quick-action-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#fff;border:1px solid #E5E7EB;border-radius:20px;font-size:12px;color:#6b7280;cursor:pointer;transition:all .2s}.quick-action-btn:hover{background:#8b5cf6;color:#fff;border-color:#8b5cf6}.mascot-chat-input{display:flex;gap:8px;padding:12px 16px;background:#fff;border-top:1px solid #E5E7EB}.mascot-chat-input input{flex:1;padding:10px 14px;border:1px solid #E5E7EB;border-radius:20px;font-size:14px;outline:none;transition:border-color .2s}.mascot-chat-input input:focus{border-color:#8b5cf6}.send-btn{width:40px;height:40px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,opacity .2s}.send-btn:hover:not(:disabled){transform:scale(1.1)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.mascot-chat-messages::-webkit-scrollbar{width:6px}.mascot-chat-messages::-webkit-scrollbar-track{background:transparent}.mascot-chat-messages::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.mascot-chat-messages::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media(max-width:480px){.mascot-chat-overlay{padding:0;align-items:flex-end}.mascot-chat-container{width:100%;max-width:100%;height:80vh;max-height:80vh;border-radius:20px 20px 0 0}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
