@import"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Outfit:wght@400;600;700;800&display=swap";:root{--primary: #1a73e8;--primary-hover: #1557b0;--secondary: #e8f0fe;--bg-body: #f9f9f9;--bg-surface: #ffffff;--text-main: #202124;--text-muted: #5f6368;--divider: #dadce0;--error: #d93025;--success: #1e8e3e;--shadow-sm: 0 1px 2px 0 rgba(60, 64, 67, .3), 0 1px 3px 1px rgba(60, 64, 67, .15);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-card: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}[data-theme=Dark]{--primary: #60a5fa;--primary-hover: #3b82f6;--secondary: #334155;--bg-body: #0f172a;--bg-surface: #1e293b;--text-main: #f1f5f9;--text-muted: #94a3b8;--divider: #334155;--error: #f87171;--success: #4ade80;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5);--shadow-card: 0 20px 25px -5px rgba(0, 0, 0, .6), 0 8px 10px -6px rgba(0, 0, 0, .6)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:24px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%;box-shadow:0 1px 3px #0000004d}input:checked+.slider{background-color:var(--primary)}input:checked+.slider:before{transform:translate(20px)}body{margin:0;padding:0;font-family:Roboto,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg-body);color:var(--text-main);-webkit-font-smoothing:antialiased;min-height:100vh}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg-body)}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:5px;border:2px solid var(--bg-body)}::-webkit-scrollbar-thumb:hover{background:#94a3b8}[data-theme=Dark] ::-webkit-scrollbar-thumb{background:#475569}[data-theme=Dark] ::-webkit-scrollbar-thumb:hover{background:#64748b}h1,h2,h3,h4,h5,h6{font-family:Outfit,Inter,sans-serif;line-height:1.2;letter-spacing:-.02em;margin:0 0 8px;color:var(--text-main)}h1{font-size:26px;font-weight:800}h2{font-size:20px;font-weight:700}h3{font-size:17px;font-weight:700}h4{font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}p{line-height:1.65;margin:0 0 12px;color:var(--text-sub, var(--text-main))}.text-muted{color:var(--text-muted)!important}.text-main{color:var(--text-main)!important}.text-primary{color:var(--primary)!important}.text-center{text-align:center}.fw-700{font-weight:700}.fw-800{font-weight:800}.mt-0{margin-top:0}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-0{margin-bottom:0}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.container{max-width:1280px;margin:0 auto!important;padding:0;width:100%;box-sizing:border-box;display:flex;flex-direction:column;align-items:stretch}.card{background:var(--bg-surface);border-radius:8px;box-shadow:0 1px 3px #0000001f;border:1px solid var(--divider);padding:24px;transition:all .2s ease}.card:hover{box-shadow:var(--shadow-sm)}.btn{background-color:var(--primary);color:#fff;padding:.6rem 1.25rem;border-radius:4px;font-weight:500;border:none;cursor:pointer;font-size:.875rem;letter-spacing:.25px;transition:background-color .2s;text-transform:uppercase}.btn:hover{background-color:var(--primary-hover);box-shadow:0 1px 2px #3c40434d}.input-field{width:100%;padding:10px 12px;border:1px solid #dadce0;border-radius:4px;margin-bottom:16px;font-size:1rem;transition:border .2s;background:#f1f3f4;box-sizing:border-box}.input-field:focus{outline:none;background:#fff;border-color:var(--primary);box-shadow:0 0 0 2px #1a73e833}.error-text{color:var(--error);font-size:.875rem;margin-bottom:1rem;display:flex;align-items:center;gap:8px}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:#f0f2f5}.login-card{width:100%;max-width:450px;background:var(--bg-surface);padding:40px;box-shadow:0 2px 4px #0000001a,0 8px 16px #0000001a;border-radius:8px;border:none}.login-title{text-align:center;color:var(--text-main);font-size:24px;font-weight:500;margin-bottom:30px}.toggle-link{text-align:center;color:var(--primary);font-size:14px;margin-top:20px;font-weight:500;cursor:pointer}.toggle-link:hover{text-decoration:underline}.app-header{background-color:var(--bg-surface);border-bottom:1px solid var(--divider);color:var(--text-main);padding:0 16px;height:64px;display:flex;align-items:center;justify-content:space-between;box-shadow:none;position:sticky;top:0;z-index:1000;width:100%;box-sizing:border-box}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:24px;margin-top:20px}.ttr-ai-container,.four-way-container{display:flex;flex-direction:column;height:calc(100dvh - 120px);position:relative;background-color:var(--bg-body);overflow:hidden}@media(max-width:768px){.ttr-ai-container,.four-way-container{height:calc(100dvh - 130px)}}.chat-area{flex:1;overflow-y:auto;padding:24px 24px 100px;display:flex;flex-direction:column;gap:20px;scroll-behavior:smooth}@media(max-width:768px){.chat-area{padding-bottom:180px}}.message-bubble{max-width:85%;padding:14px 18px;border-radius:18px;position:relative;font-size:15px;line-height:1.6;box-shadow:var(--shadow-sm);transition:transform .2s ease}.message-user{align-self:flex-end;background:linear-gradient(135deg,var(--primary) 0%,#7d6cf7 100%);color:#fff;border-bottom-right-radius:4px}.message-ai{align-self:flex-start;background:var(--bg-surface);color:var(--text-main);border:1px solid var(--divider);border-bottom-left-radius:4px}input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px var(--bg-surface) inset!important;-webkit-text-fill-color:var(--text-main)!important}input::-webkit-credentials-auto-fill-button,input::-webkit-contacts-auto-fill-button,input::-webkit-caps-lock-indicator{display:none!important;visibility:hidden!important}.input-area{width:100%;padding:15px 0;position:absolute;bottom:0;left:0;z-index:1000;background:linear-gradient(to top,var(--bg-body) 80%,transparent 100%);display:flex;justify-content:center;align-items:center}@media(max-width:768px){.input-area{position:fixed;bottom:65px;padding:8px 0;background:var(--bg-body);box-shadow:0 -10px 20px #00000008;left:0;right:0;width:100%}.input-controls{width:92%;padding:8px 12px;gap:8px}.chat-input{font-size:16px;min-width:0}.send-button{min-width:40px;min-height:40px;width:40px;height:40px;flex-shrink:0}.icon-button,.voice-button{width:36px;height:36px;min-width:36px;flex-shrink:0;font-size:16px}}.input-controls{display:flex;align-items:center;gap:12px;width:94%;max-width:850px;background:var(--bg-surface);padding:10px 18px;border-radius:35px;box-shadow:var(--shadow-md);border:1px solid var(--divider);transition:all .3s ease}.input-controls:focus-within{border-color:var(--primary);box-shadow:0 12px 40px #0000001f}.chat-input{flex:1;padding:10px 5px;border:none;outline:none;font-size:16px;background:transparent;color:var(--text-main)}.icon-button,.voice-button{background:var(--secondary);border:none;cursor:pointer;font-size:18px;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--text-muted)}.icon-button:hover,.voice-button:hover{background:var(--divider);transform:scale(1.05)}.send-button{background-color:var(--primary);color:#fff!important;border:none;border-radius:50%;width:44px;height:44px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;transition:all .2s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 12px #1a73e84d}.send-button:hover{transform:scale(1.1) rotate(5deg);box-shadow:0 6px 15px #1a73e866}.send-button:disabled{background-color:var(--divider);cursor:not-allowed;opacity:.6;transform:none}input[data-form-type=other]::-webkit-contacts-auto-fill-button,input[data-form-type=other]::-webkit-credentials-auto-fill-button{display:none!important;visibility:hidden!important;pointer-events:none!important}.voice-button.listening{color:red;animation:pulse 1s infinite}.image-preview-container{display:flex;margin-bottom:10px;position:relative;width:fit-content}.image-preview{height:60px;border-radius:8px;border:1px solid #ddd}.remove-image-button{position:absolute;top:-5px;right:-5px;background:red;color:#fff;border:none;border-radius:50%;width:20px;height:20px;cursor:pointer;font-size:12px}.speak-button{background:none;border:none;cursor:pointer;font-size:16px;margin-left:5px;opacity:.6}.speak-button:hover{opacity:1}.message-image{max-width:100%;border-radius:8px;margin-bottom:8px;display:block}.sidebar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2000;display:flex}.sidebar-backdrop{flex:1;background:#08070780}.sidebar-content{width:280px;background:var(--bg-surface);height:100%;padding:20px;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000001a}.markdown-content{font-size:15px;line-height:1.6}.markdown-content p{margin:0 0 10px}.markdown-content p:last-child{margin-bottom:0}.markdown-content ul,.markdown-content ol{margin:5px 0 10px;padding-left:20px}.markdown-content li{margin-bottom:4px}.markdown-content h1,.markdown-content h2,.markdown-content h3{font-size:1.1em;font-weight:700;margin:15px 0 10px}.markdown-content strong{font-weight:700;color:inherit}.markdown-content code{background:var(--divider);color:var(--text-main);padding:2px 4px;border-radius:4px;font-family:monospace;font-size:.9em}.markdown-content pre{background:#2d2d2d;color:#fff;padding:10px;border-radius:8px;overflow-x:auto}.markdown-content pre code{background:transparent;color:#fff;padding:0}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #ff7675b3}70%{transform:scale(1.1);box-shadow:0 0 0 10px #ff767500}to{transform:scale(1);box-shadow:0 0 #ff767500}}.update-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .3s ease}.update-modal{background:var(--bg-surface);color:var(--text-main);padding:30px;border-radius:20px;max-width:90%;width:350px;text-align:center;box-shadow:0 10px 30px #0003;animation:slideUp .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.hide-mobile{display:none!important}.show-mobile{display:flex!important}}@media(min-width:769px){.hide-mobile{display:flex!important}.show-mobile{display:none!important}}:root{--primary: #6c5ce7;--primary-light: #a29bfe;--primary-rgb: 108, 92, 231;--accent: #00b894;--accent-2: #fd79a8;--success: #00b894;--warning: #fdcb6e;--error: #e17055;--bg-body: #f4f5f9;--bg-surface: #ffffff;--bg-subtle: #f8f8ff;--secondary: #f0f0fa;--text-main: #1a1a2e;--text-sub: #3d3d5c;--text-muted: #6b6b8d;--text-placeholder: #9999b3;--divider: #e8e8f0;--border-focus: rgba(108, 92, 231, .4);--shadow-xs: 0 1px 3px rgba(0, 0, 0, .06);--shadow-sm: 0 2px 8px rgba(108, 92, 231, .06), 0 1px 3px rgba(0, 0, 0, .04);--shadow-md: 0 6px 24px rgba(108, 92, 231, .1), 0 2px 8px rgba(0, 0, 0, .05);--shadow-lg: 0 16px 48px rgba(108, 92, 231, .14), 0 4px 16px rgba(0, 0, 0, .06);--radius-xs: 6px;--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--radius-full: 9999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--glass: rgba(255, 255, 255, .88)}[data-theme=Dark]{--primary: #a29bfe;--primary-light: #6c5ce7;--secondary: #1e2140;--accent: #00cec9;--success: #00cec9;--warning: #ffeaa7;--error: #ff7675;--bg-body: #0d0e1a;--bg-surface: #181929;--bg-subtle: #1e2140;--text-main: #f0f0fa;--text-sub: #c8c8e0;--text-muted: #9090b8;--text-placeholder: #606080;--divider: #2a2b45;--border-focus: rgba(162, 155, 254, .4);--shadow-xs: 0 1px 3px rgba(0, 0, 0, .3);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .4);--shadow-md: 0 6px 24px rgba(0, 0, 0, .5);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .6);--glass: rgba(24, 25, 41, .88)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0;font-family:Inter,Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-body);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-y:auto;overflow-x:hidden;min-height:100%;font-size:15px;line-height:1.6;letter-spacing:-.01em}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input::-webkit-credentials-auto-fill-button,input::-webkit-contacts-auto-fill-button{visibility:hidden!important;pointer-events:none!important;display:none!important}input:focus{outline:none}#root{width:100%;margin:0;padding:0;min-height:100vh;position:relative}.card{background:var(--bg-surface);padding:20px;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--divider);transition:box-shadow .2s ease}.card:hover{box-shadow:var(--shadow-md)}.section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0 0 12px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-sub);margin-bottom:6px;letter-spacing:.01em}.form-group{display:flex;flex-direction:column;gap:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:14px;line-height:1;border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none;white-space:nowrap;letter-spacing:.01em}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,#8275ff 100%);color:#fff;box-shadow:0 4px 15px #6c5ce74d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6c5ce766}.btn-primary:active{transform:translateY(0)}.btn-success{background:linear-gradient(135deg,var(--success) 0%,#2ecc71 100%);color:#fff;box-shadow:0 4px 15px #27ae604d}.btn-outline{background:transparent;border:2px solid var(--divider);color:var(--text-muted)}.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:#6c5ce70d}.responsive-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,240px),1fr));gap:20px;margin-top:24px}.app-header{position:sticky;top:0;z-index:1000;background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--divider)}.menu-toggle,.more-toggle{background:none;border:none;color:var(--text-main);padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;z-index:10}.menu-toggle:hover,.more-toggle:hover{background:#0000000d;transform:scale(1.05)}.menu-toggle:active,.more-toggle:active{transform:scale(.95)}.app-header{position:sticky;top:0;z-index:1000;background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);height:60px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--divider);padding:0;width:100%;box-sizing:border-box}.logo{height:36px;width:auto;object-fit:contain;display:block}.brand-text{font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:800;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:0;line-height:1}.sidebar-wrapper{display:block}.layout-wrapper{height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden}.layout-body{display:flex;flex:1;overflow:hidden}.main-content-area{flex:1;overflow-y:auto;position:relative;height:100%;scroll-behavior:smooth}.bottom-nav-wrapper{display:none}@media(max-width:768px){.container{padding:0!important}.sidebar-wrapper{position:fixed;top:60px;left:0;height:calc(100vh - 60px);height:calc(100dvh - 60px);z-index:2000;transition:transform .3s ease;display:block!important}.sidebar-wrapper:not(.open){transform:translate(-100%)}.sidebar-wrapper.open{transform:translate(0)}.menu-toggle{display:flex!important}.app-header{padding:0 16px}.bottom-nav-wrapper{display:flex;position:fixed;bottom:0;left:0;width:100%;background:var(--glass);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-top:1px solid var(--divider);height:62px;z-index:2000;justify-content:space-around;align-items:center;box-shadow:0 -4px 20px #00000014}.page-wrapper{padding:16px 16px 108px}}@media(min-width:769px){.app-header{padding:0 32px;background:var(--bg-surface);border-bottom:1px solid var(--divider)}.bottom-nav-wrapper{display:none!important}.page-wrapper{padding:28px 36px}.sidebar-wrapper{display:block;height:100%;overflow-y:auto;background:var(--bg-surface);border-right:1px solid var(--divider);min-width:220px}.modal-overlay{align-items:center}.modal-card{border-radius:var(--radius-md)}}@media(max-width:768px){.layout-wrapper{height:auto;overflow:visible;display:block}.layout-body{display:block;overflow:visible}.main-content-area{height:auto;overflow:visible}}.image-preview-container{position:relative;width:fit-content}.image-preview{height:80px;border-radius:8px;border:1px solid var(--divider)}.remove-image-button{position:absolute;top:-8px;right:-8px;background:var(--error);color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;box-shadow:0 2px 4px #0003}.input-controls{display:flex;gap:10px;align-items:center}.icon-button{cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;border-radius:50%;background-color:var(--secondary);color:var(--text-muted);min-width:44px;height:44px;border:none;transition:background-color .2s}.icon-button:hover{background-color:var(--divider)}.voice-button{border:none;border-radius:50%;min-width:44px;height:44px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;background-color:var(--secondary);color:var(--text-muted);transition:all .2s ease}.voice-button:hover{background-color:var(--divider)}.voice-button.listening{background-color:#ff7675;color:#fff;animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 0 #ff767566}70%{box-shadow:0 0 0 10px #ff767500}to{box-shadow:0 0 #ff767500}}.chat-input{flex:1;padding:12px 20px;border-radius:22px;border:1px solid var(--divider);background-color:var(--bg-body);color:var(--text-main);outline:none;font-size:16px;transition:border-color .2s}.chat-input:focus{border-color:var(--primary)}.offline-banner{position:fixed;top:0;left:0;width:100%;background-color:#d63031;color:#fff;text-align:center;padding:8px;font-size:14px;font-weight:600;z-index:9999;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.details-header{background-color:var(--primary);color:#fff;padding:20px;text-align:center;font-size:24px;font-weight:700;border-radius:10px 10px 0 0;box-shadow:0 2px 4px #0000001a}.details-card{margin-top:0;border-radius:0 0 10px 10px;border-top:none}.role-status-box{padding:15px;background:var(--secondary);color:var(--text-main);margin-bottom:20px;border-radius:8px;border-left:4px solid var(--primary);display:flex;align-items:center;justify-content:space-between}.change-role-button{padding:6px 12px;font-size:.85rem;cursor:pointer;background:var(--bg-surface);color:var(--text-main);border:1px solid var(--divider);border-radius:4px;transition:all .2s}.change-role-button:hover{background:var(--bg-body);border-color:var(--divider)}.fallback-role-box{margin-bottom:20px;padding:15px;background:#fff3cd;border-radius:8px;border:1px solid #ffeeba;color:#856404}.warning-label{font-weight:700;display:block;margin-bottom:10px}.experience-container{display:flex;gap:10px;margin-bottom:15px}.checkbox-label{display:flex;align-items:center;gap:10px;margin:15px 0;cursor:pointer}.checkbox-label-sm{display:flex;align-items:center;gap:8px;font-size:.9rem;margin:8px 0;color:var(--text-muted);cursor:pointer}.section-header{margin-top:25px;border-top:1px solid var(--divider);padding-top:15px;color:var(--text-main);font-size:1.1rem}.help-text{font-size:.8rem;color:var(--text-muted);margin-bottom:15px}.submit-container{display:flex;justify-content:center;margin-top:30px}.submit-button{width:100%;background-color:#2ecc71;color:#fff;font-size:1.1rem;padding:12px}.submit-button:hover{background-color:#27ae60}.password-wrapper{position:relative;width:100%}.password-toggle{position:absolute;right:15px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.75rem;font-weight:700;padding:5px;z-index:5;outline:none}.password-toggle:hover{color:var(--primary)}.password-wrapper .input-field{padding-right:60px;margin-bottom:1rem}.auth-divider{display:flex;align-items:center;margin:22px 0}.divider-line{flex:1;height:1px;background:var(--divider)}.divider-text{padding:0 15px;color:var(--text-muted);font-size:.9rem;font-weight:500}button.btn.google-btn{width:100%;background-color:var(--bg-surface);color:#db4437;border:1px solid #db4437;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s ease}button.btn.google-btn:hover{background-color:var(--bg-body);box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.full-width{width:100%}.header-left,.header-right{display:flex;align-items:center;gap:12px}.menu-toggle,.action-icon-btn,.more-options-btn{background:none;border:none;cursor:pointer;font-size:20px;color:var(--text-muted);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.menu-toggle:hover,.action-icon-btn:hover,.more-options-btn:hover{background:#0000000d}.header-brand{display:flex;align-items:center;gap:8px;cursor:pointer}.logo{height:28px;width:auto}.brand-text{font-size:1.1rem;font-weight:800;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.profile-avatar-mini{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;cursor:pointer;box-shadow:0 2px 5px #6c5ce733}.header-search-mode{gap:12px}.search-input-wrapper{flex:1;position:relative}.header-search-input{padding:10px 40px 10px 16px;border-radius:20px;background:var(--secondary);border:1px solid transparent}.header-search-input:focus{background:var(--bg-surface)}.search-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;color:var(--text-muted);cursor:pointer}.search-suggestions-dropdown{position:absolute;top:calc(100% + 10px);left:0;right:0;background:var(--bg-surface);border-radius:var(--radius-md);overflow:hidden;z-index:2500}.suggestion-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--divider);transition:background .2s}.suggestion-item:hover{background:var(--secondary)}.suggestion-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.suggestion-name{font-weight:600;font-size:14px}.suggestion-meta{font-size:12px;color:var(--text-muted)}.dropdown-wrapper{position:relative}.menu-overlay{position:fixed;inset:0;z-index:2100}.dropdown-menu{position:absolute;top:48px;right:0;width:220px;background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--divider);z-index:2200;overflow:hidden;animation:fadeIn .2s ease-out}.menu-header{padding:16px;background:var(--secondary);border-bottom:1px solid var(--divider)}.menu-name{font-weight:700;font-size:15px}.menu-role{font-size:12px;color:var(--text-muted);text-transform:capitalize}.menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;border:none;background:none;font-size:14px;color:var(--text-main);cursor:pointer;transition:background .2s;text-align:left}.menu-item:hover{background:var(--secondary)}.menu-divider{height:1px;background:var(--divider);margin:4px 0}.menu-logout{color:var(--error);font-weight:600}.input-field{width:100%;padding:11px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--divider);background:var(--bg-surface);font-size:14px;font-family:inherit;color:var(--text-main);transition:border-color .2s ease,box-shadow .2s ease;outline:none;box-sizing:border-box}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--border-focus)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-wrapper{animation:fadeIn .4s ease-out}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:3px;cursor:pointer;transition:all .2s ease;color:var(--text-muted);position:relative;padding:5px 0}.nav-icon{font-size:21px;transition:transform .2s cubic-bezier(.175,.885,.32,1.275);line-height:1}.nav-label{font-size:10px;font-weight:600;letter-spacing:.02em}.nav-item.active{color:var(--primary)}.nav-item.active .nav-icon{transform:translateY(-4px) scale(1.12)}.nav-item.active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:20px;height:3px;background:var(--primary);border-radius:0 0 4px 4px;box-shadow:0 2px 8px rgba(var(--primary-rgb),.4)}.ai-nav-icon{background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;margin-top:-22px;border:3px solid var(--bg-surface);box-shadow:0 4px 16px rgba(var(--primary-rgb),.4)}.nav-item.active .ai-nav-icon{animation:navPulse 2s infinite}@keyframes navPulse{0%{box-shadow:0 0 #6c5ce766}70%{box-shadow:0 0 0 10px #6c5ce700}to{box-shadow:0 0 #6c5ce700}}.auth-page-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(145deg,#f0f0ff,#f8f8ff,#fff5fd)}.auth-card{width:100%;max-width:400px;padding:48px 36px 40px;text-align:center;animation:fadeIn .5s ease-out;position:relative;border-radius:20px;box-shadow:0 8px 40px #6c5ce71a,0 2px 10px #0000000f}.auth-header{position:absolute;top:16px;right:16px}.auth-logo-section{display:flex;flex-direction:column;align-items:center;gap:0;margin-bottom:24px}.auth-logo{width:96px;height:96px;object-fit:contain;filter:drop-shadow(0 6px 18px rgba(108,92,231,.22));margin-bottom:4px}.auth-title{font-size:1.5rem;font-weight:800;margin:0 0 20px;color:var(--text-main);letter-spacing:-.3px}.auth-form{display:flex;flex-direction:column;gap:14px;text-align:left}.auth-footer{margin-top:24px;font-size:14px;color:var(--text-muted)}.auth-toggle-link{color:var(--primary);font-weight:700;cursor:pointer;text-decoration:none}.error-banner{background:#e74c3c1a;color:var(--error);padding:12px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:20px;border:1px solid rgba(231,76,60,.2)}.spinner-sm{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.pwa-install-btn{margin-top:30px;width:auto!important;font-size:14px!important}@media(max-width:480px){.auth-card{padding:32px 20px 28px;box-shadow:0 4px 20px #0000000f}}.routine-wizard-card{background:linear-gradient(135deg,var(--success) 0%,#2ecc71 100%);padding:24px;border-radius:var(--radius-md);color:#fff;margin-bottom:24px;box-shadow:0 8px 25px #27ae604d;position:relative;overflow:hidden;animation:fadeIn .6s ease-out}.routine-icon-bg{position:absolute;right:-20px;bottom:-20px;font-size:120px;opacity:.15;transform:rotate(-15deg)}.routine-label{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;opacity:.9}.routine-title{margin:0 0 8px;font-size:24px;font-weight:800}.routine-time{margin:0;font-size:15px;opacity:.85}.routine-action-btn{background:#fff!important;color:var(--success)!important;margin-top:20px;box-shadow:0 4px 12px #0000001a!important}.ai-assistant-banner{display:flex;align-items:center;gap:20px;padding:24px;background:var(--bg-surface);border:1px dashed var(--success);margin-bottom:24px}.ai-banner-icon{font-size:44px;background:var(--secondary);width:70px;height:70px;border-radius:50%;display:flex;align-items:center;justify-content:center}.ai-banner-info{flex:1}.ai-banner-title{margin:0;font-size:18px;font-weight:700}.ai-banner-text{margin:4px 0 0;font-size:13px;color:var(--text-muted)}.simple-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.simple-action-card{padding:24px 16px;text-align:center;display:flex;flex-direction:column;gap:12px}.simple-card-icon{font-size:32px}.simple-card-label{font-weight:700;font-size:14px}.modal-overlay{position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:3000;display:flex;align-items:flex-end;justify-content:center;padding:0}.modal-card{width:100%;max-width:480px;border-bottom-left-radius:0;border-bottom-right-radius:0;padding:24px 24px 32px;animation:slideUp .3s cubic-bezier(0,.55,.45,1)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--divider)}.modal-title{margin:0;font-size:1.1rem;font-weight:700;color:var(--text-main)}.modal-close{background:var(--secondary);border:none;width:32px;height:32px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:background .2s}.modal-close:hover{background:var(--divider)}.modal-body{display:flex;flex-direction:column;gap:16px}.form-row{display:flex;gap:12px}.flex-1{flex:1}.modal-footer{margin-top:20px;display:flex;justify-content:flex-end;gap:10px}.simple-mode-footer{margin-top:30px;text-align:center}.tip-text{font-size:12px;color:var(--text-muted)}.mode-toggle-text{font-size:14px;color:var(--text-main)}.mode-switch-link{color:var(--primary);font-weight:700;cursor:pointer}.pulse-btn{animation:btnPulse 2s infinite}@keyframes btnPulse{0%{transform:scale(1)}50%{transform:scale(1.02);box-shadow:0 0 20px #6c5ce733}to{transform:scale(1)}}.dash-greeting-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;background:var(--bg-surface);border:1px solid var(--divider);border-radius:var(--radius-md);padding:20px 24px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.dash-greeting-left{display:flex;align-items:center;gap:16px}.dash-avatar{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--primary) 0%,#8e44ad 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;font-family:Outfit,sans-serif;flex-shrink:0;box-shadow:0 4px 12px #6c5ce740;letter-spacing:-.5px}.dash-welcome-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0 0 2px;line-height:1}.dash-name{font-size:22px;font-weight:800;color:var(--text-main);margin:0;letter-spacing:-.5px;line-height:1.1}.dash-meta{font-size:12px;color:var(--text-muted);margin:4px 0 0;line-height:1.3}.dash-greeting-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.dash-role-pill{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;background:var(--secondary);color:var(--text-sub);border-radius:var(--radius-full);font-size:12px;font-weight:600;border:1px solid var(--divider);white-space:nowrap}.dash-id-pill{display:inline-flex;align-items:center;padding:5px 12px;background:rgba(var(--primary-rgb),.07);color:var(--primary);border-radius:var(--radius-full);font-size:11px;font-weight:700;border:1px solid rgba(var(--primary-rgb),.15);font-family:SF Mono,Fira Code,monospace;white-space:nowrap}[data-theme=Dark] .dash-greeting-bar{background:var(--bg-surface)}.student-hero-vibe{display:none}.student-hero-vibe-legacy{background:linear-gradient(135deg,var(--primary) 0%,#8e44ad 100%);padding:36px 24px 32px;border-radius:var(--radius-md);color:#fff;margin-bottom:20px;position:relative;overflow:hidden;text-align:center}@keyframes floatHero{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.hero-sparkle{position:absolute;top:-20px;right:-20px;font-size:150px;opacity:.1;transform:rotate(15deg)}.student-greeting{font-size:26px;font-weight:800;margin:0 0 6px;letter-spacing:-.5px}.student-subtext{font-size:15px;opacity:.9;margin:0;max-width:80%}.streak-badge-mini{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#fff3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:20px;font-size:13px;font-weight:700;margin-top:15px;border:1px solid rgba(255,255,255,.3)}.student-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:24px}.student-action-card{position:relative;padding:22px 12px;border-radius:var(--radius-md);text-decoration:none;transition:all .25s cubic-bezier(.175,.885,.32,1.275);display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;border:1px solid var(--divider);background:var(--bg-surface);cursor:pointer;box-shadow:0 1px 4px #0000000a}.student-action-card:hover{transform:translateY(-8px);box-shadow:0 10px 25px #0000001a;border-color:var(--primary-light)}.card-vibe-icon{font-size:32px;margin-bottom:2px;transition:transform .3s ease;line-height:1}.student-action-card:hover .card-vibe-icon{transform:scale(1.2) rotate(5deg)}.card-vibe-title{font-weight:800;font-size:15px;margin:0;color:var(--text-main)}.card-vibe-desc{font-size:11px;color:var(--text-muted);line-height:1.4;margin:0}.results-glass-wrapper{background:var(--glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--divider);border-radius:var(--radius-md);padding:24px;margin-top:30px;overflow:hidden;width:100%}.results-table{width:100%;border-collapse:collapse}.results-table th{text-align:left;padding:12px;color:var(--text-muted);font-size:12px;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--divider)}.results-table td{padding:16px 12px;font-size:14px;border-bottom:1px solid rgba(0,0,0,.05)}.status-pill{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase}.status-pass{background:#e6f7ef;color:#2ecc71}.status-fail{background:#feecef;color:#e74c3c}@media(max-width:768px){.container{padding:16px;display:block}.main-content-area{width:100%;max-width:100vw;padding:0;display:flex;flex-direction:column;flex:1}}@media(max-width:480px){.student-hero-vibe{padding:30px 20px}.student-greeting{font-size:24px}}@media(min-width:769px){.modal-overlay{align-items:center}.modal-card{border-radius:var(--radius-md)}}.teacher-hero-card{display:none}.teacher-hero-sparkle{position:absolute;top:-20px;right:-20px;font-size:140px;opacity:.12;transform:rotate(15deg)}.teacher-welcome-title{font-size:22px;font-weight:800;margin:8px 0 6px;letter-spacing:-.5px;line-height:1.2}.teacher-hero-pill{display:inline-flex;background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:6px 14px;border-radius:20px;font-size:13px;font-weight:700;border:1px solid rgba(255,255,255,.3)}.teacher-grid-system{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:24px;justify-content:center;width:100%;max-width:100vw;box-sizing:border-box}.teacher-vibe-card{background:var(--bg-surface);border:1.5px solid var(--divider);border-radius:var(--radius-md);padding:18px 10px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;transition:all .25s cubic-bezier(.175,.885,.32,1.275);cursor:pointer;box-shadow:var(--shadow-xs);width:100%;min-width:0}.teacher-vibe-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--primary-light)}.teacher-vibe-icon{font-size:28px;line-height:1}.teacher-vibe-label{font-size:12px;font-weight:700;color:var(--text-main);line-height:1.3;letter-spacing:.01em}.teacher-classes-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.teacher-class-pill{display:inline-block;background:var(--secondary);color:var(--text-main);padding:6px 14px;border-radius:12px;font-size:12px;font-weight:700;margin:4px;border:1px solid var(--divider)}@media(max-width:768px){.teacher-hero-card,.institution-hero-card{padding:24px 16px;margin-left:0;margin-right:0}.teacher-grid-system{gap:10px;padding:0 4px}.student-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important}.student-action-card{padding:16px 8px!important;min-width:0!important}}@media(min-width:900px){.teacher-grid-system{grid-template-columns:repeat(4,1fr);gap:24px}}@media(max-width:480px){.teacher-hero-card{padding:24px 20px}.teacher-welcome-title{font-size:22px}.teacher-vibe-card{padding:20px 12px}.teacher-vibe-icon{font-size:30px}.teacher-vibe-label{font-size:13px}}.institution-hero-card{display:none}.teacher-action-cluster{padding:12px 16px!important}.institution-hero-sparkle,.institution-name-title,.institution-hero-pill,.institution-meta-desc{display:none}.institution-hero-sparkle{position:absolute;top:-20px;right:-20px;font-size:140px;opacity:.1;transform:rotate(15deg)}.institution-name-title{font-size:24px;font-weight:800;margin:0 0 10px;letter-spacing:-.5px}.institution-hero-pill{display:inline-flex;background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:6px 14px;border-radius:20px;font-size:13px;font-weight:700;border:1px solid rgba(255,255,255,.2)}.institution-meta-desc{font-size:14px;opacity:.9;margin:10px 0 0;font-weight:500}@media(max-width:480px){.institution-hero-card{padding:24px 20px}.institution-name-title{font-size:20px}}.ttr-announcement-wrapper{position:sticky;top:64px;z-index:999;background-color:var(--bg-surface);margin:0;width:100%;box-shadow:0 4px 12px #00000014;overflow:hidden}.announcement-bar{background:linear-gradient(135deg,#2c3e50,#3498db);color:#fff;padding:12px 0;display:flex;align-items:center;cursor:pointer;white-space:nowrap;overflow:hidden;position:relative}.ticker-wrapper{display:flex;white-space:nowrap;width:fit-content;animation:ticker-animation 35s linear infinite;will-change:transform}.ticker-item{padding-right:20vw;font-weight:700;font-size:.95rem;letter-spacing:.5px;flex-shrink:0;display:flex;align-items:center;gap:12px}.announcement-bar:hover .ticker-wrapper{animation-play-state:paused}@keyframes ticker-animation{0%{transform:translate(0)}to{transform:translate(-50%)}}@media(max-width:768px){.ttr-announcement-wrapper{top:60px;margin:0;width:100%}.ticker-item{font-size:.85rem;padding-right:30vw}}
