.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);padding:var(--spacing-4)}.login-container{width:100%;max-width:420px}.login-card{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--spacing-10);text-align:center;animation:slideUp var(--transition-normal)}.login-header{margin-bottom:var(--spacing-8)}.login-header svg{margin-bottom:var(--spacing-6)}.login-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--spacing-2)}.login-header p{color:var(--text-secondary);font-size:var(--font-size-base)}.login-error{background:#ef44441a;border:1px solid var(--accent-error);border-radius:var(--radius-md);padding:var(--spacing-3) var(--spacing-4);margin-bottom:var(--spacing-4);color:var(--accent-error);font-size:var(--font-size-sm)}.login-button{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-6);background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.login-button:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--brand-green);box-shadow:var(--shadow-md)}.login-button:disabled{opacity:.7;cursor:not-allowed}.button-spinner{animation:spin 1s linear infinite}.login-footer{margin-top:var(--spacing-8);padding-top:var(--spacing-6);border-top:1px solid var(--border-light)}.login-footer p{color:var(--text-tertiary);font-size:var(--font-size-sm)}@media(max-width:480px){.login-card{padding:var(--spacing-6)}.login-header h1{font-size:var(--font-size-xl)}}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:transparent;border:1px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.user-menu-trigger:hover{background:var(--bg-tertiary);border-color:var(--border-light)}.user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--brand-green);display:flex;align-items:center;justify-content:center;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar span{color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.user-avatar.large{width:48px;height:48px}.user-avatar.large span{font-size:var(--font-size-lg)}.user-menu-trigger .user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary)}.chevron{color:var(--text-secondary);transition:transform var(--transition-fast)}.chevron.open{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:calc(100% + var(--spacing-2));right:0;width:280px;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);animation:slideDown var(--transition-fast)}.user-menu-header{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4)}.user-info{display:flex;flex-direction:column;min-width:0}.user-info .user-name{font-weight:var(--font-weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info .user-email{font-size:var(--font-size-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-divider{height:1px;background:var(--border-light);margin:0}.user-menu-item{display:flex;align-items:center;gap:var(--spacing-3);width:100%;padding:var(--spacing-3) var(--spacing-4);background:transparent;border:none;font-size:var(--font-size-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.user-menu-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.user-menu-item:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg)}@media(max-width:640px){.user-menu-trigger .user-name{display:none}.user-menu-dropdown{width:260px}}.theme-toggle{display:flex;align-items:center;background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:var(--spacing-1);gap:var(--spacing-1)}.theme-toggle-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.theme-toggle-button:hover{color:var(--text-primary);background:var(--bg-elevated)}.theme-toggle-button.active{background:var(--bg-elevated);color:var(--brand-green);box-shadow:var(--shadow-sm)}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--bg-primary);border-bottom:1px solid var(--border-light);z-index:var(--z-sticky)}.header-content{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:1400px;margin:0 auto;padding:0 var(--spacing-6)}.header-left{display:flex;align-items:center}.header-right{display:flex;align-items:center;gap:var(--spacing-4)}@media(max-width:640px){.header-content{padding:0 var(--spacing-4)}.header-right{gap:var(--spacing-2)}}.app-card{display:flex;align-items:flex-start;gap:var(--spacing-4);padding:var(--spacing-5);background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden}.app-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--app-color, var(--brand-green));transform:scaleX(0);transition:transform var(--transition-normal)}.app-card:hover{border-color:var(--brand-green);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.app-card:hover:before{transform:scaleX(1)}.app-card:focus-visible{outline:2px solid var(--brand-green);outline-offset:2px}.app-card-icon{flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--brand-green-subtle);border-radius:var(--radius-lg);color:var(--app-color, var(--brand-green));transition:all var(--transition-normal)}.app-card:hover .app-card-icon{background:var(--app-color, var(--brand-green));color:#fff}.app-card-content{flex:1;min-width:0}.app-card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--spacing-1)}.app-card-description{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:var(--line-height-relaxed)}.app-card-arrow{flex-shrink:0;color:var(--text-tertiary);opacity:0;transform:translate(-4px,4px);transition:all var(--transition-fast)}.app-card:hover .app-card-arrow{opacity:1;transform:translate(0);color:var(--brand-green)}@media(max-width:640px){.app-card{padding:var(--spacing-4)}.app-card-icon{width:44px;height:44px}.app-card-icon svg{width:22px;height:22px}.app-card-title{font-size:var(--font-size-base)}.app-card-arrow{display:none}}.app-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-5)}.app-grid-loading,.app-grid-error,.app-grid-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-3);padding:var(--spacing-16) var(--spacing-4);text-align:center}.app-grid-loading p,.app-grid-empty p{color:var(--text-secondary)}.app-grid-loading .loading-spinner{color:var(--brand-green);animation:spin 1s linear infinite}.app-grid-error,.app-grid-error p{color:var(--accent-error)}@media(max-width:480px){.app-grid{grid-template-columns:1fr;gap:var(--spacing-4)}}.dashboard{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-secondary)}.main-content{flex:1;padding:var(--spacing-8);padding-top:calc(var(--header-height) + var(--spacing-8))}.content-container{max-width:1200px;margin:0 auto}.welcome-section{text-align:center;margin-bottom:var(--spacing-12)}.welcome-section h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--spacing-2)}.welcome-section p{font-size:var(--font-size-lg);color:var(--text-secondary)}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-4);background:var(--bg-secondary)}.loading-screen p{color:var(--text-secondary);font-size:var(--font-size-lg)}.loading-spinner{color:var(--brand-green);animation:spin 1s linear infinite}@media(max-width:768px){.main-content{padding:var(--spacing-4);padding-top:calc(var(--header-height) + var(--spacing-4))}.welcome-section{margin-bottom:var(--spacing-8)}.welcome-section h1{font-size:var(--font-size-2xl)}.welcome-section p{font-size:var(--font-size-base)}}:root{--brand-green: #01D49B;--brand-green-light: #33DFAF;--brand-green-dark: #00B584;--brand-green-subtle: rgba(1, 212, 155, .08);--brand-green-muted: rgba(1, 212, 155, .15);--brand-purple: #12003F;--brand-purple-light: #2A1A5E;--brand-purple-dark: #0A0025;--text-primary: #1A1A2E;--text-secondary: #64748B;--text-tertiary: #94A3B8;--text-inverse: #FFFFFF;--bg-primary: #FFFFFF;--bg-secondary: #F8FAFC;--bg-tertiary: #F1F5F9;--bg-elevated: #FFFFFF;--bg-chat: #FAFBFC;--border-light: #E2E8F0;--border-medium: #CBD5E1;--border-focus: var(--brand-green);--accent-success: #10B981;--accent-warning: #F59E0B;--accent-error: #EF4444;--accent-info: #3B82F6;--user-bubble-bg: linear-gradient(135deg, var(--brand-green) 0%, var(--brand-green-dark) 100%);--user-bubble-text: #FFFFFF;--assistant-bubble-bg: #FFFFFF;--assistant-bubble-border: var(--border-light);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 10px 10px -5px rgba(0, 0, 0, .03);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .04);--shadow-focus: 0 0 0 3px rgba(1, 212, 155, .2);--shadow-card: 0 2px 8px rgba(0, 0, 0, .06), 0 0 1px rgba(0, 0, 0, .08);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--spacing-0: 0;--spacing-1: 4px;--spacing-2: 8px;--spacing-3: 12px;--spacing-4: 16px;--spacing-5: 20px;--spacing-6: 24px;--spacing-8: 32px;--spacing-10: 40px;--spacing-12: 48px;--spacing-16: 64px;--spacing-xs: var(--spacing-1);--spacing-sm: var(--spacing-2);--spacing-md: var(--spacing-4);--spacing-lg: var(--spacing-6);--spacing-xl: var(--spacing-8);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--drawer-width: 280px;--header-height: 64px;--input-height: 56px;--max-content-width: 900px;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-popover: 400;--z-tooltip: 500}[data-theme=dark]{--brand-green: #01D49B;--brand-green-light: #33DFAF;--brand-green-dark: #00B584;--brand-green-subtle: rgba(1, 212, 155, .12);--brand-green-muted: rgba(1, 212, 155, .2);--brand-purple: #E8E0FF;--brand-purple-light: #F5F0FF;--brand-purple-dark: #C8B8FF;--text-primary: #F5F5F5;--text-secondary: #A3A3A3;--text-tertiary: #737373;--text-inverse: #1A1A2E;--bg-primary: #0F0F0F;--bg-secondary: #1A1A1A;--bg-tertiary: #262626;--bg-elevated: #1F1F1F;--bg-chat: #141414;--border-light: #333333;--border-medium: #404040;--border-focus: var(--brand-green);--accent-success: #10B981;--accent-warning: #F59E0B;--accent-error: #EF4444;--accent-info: #3B82F6;--user-bubble-bg: linear-gradient(135deg, var(--brand-green) 0%, var(--brand-green-dark) 100%);--user-bubble-text: #FFFFFF;--assistant-bubble-bg: #1F1F1F;--assistant-bubble-border: var(--border-light);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4), 0 10px 10px -5px rgba(0, 0, 0, .2);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .3);--shadow-focus: 0 0 0 3px rgba(1, 212, 155, .3);--shadow-card: 0 2px 8px rgba(0, 0, 0, .4), 0 0 1px rgba(0, 0, 0, .5)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-secondary);color:var(--text-primary);font-size:var(--font-size-base);line-height:var(--line-height-normal)}code,pre{font-family:JetBrains Mono,Fira Code,SF Mono,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:transparent;border-radius:var(--radius-full);border:2px solid transparent;background-clip:padding-box;transition:background var(--transition-fast)}*:hover::-webkit-scrollbar-thumb{background:var(--border-medium)}*:hover::-webkit-scrollbar-thumb:hover{background:var(--brand-green)}*{scrollbar-width:thin;scrollbar-color:transparent transparent}*:hover{scrollbar-color:var(--border-medium) transparent}::selection{background:var(--brand-green-muted);color:var(--text-primary)}*:focus{outline:none}*:focus-visible{outline:2px solid var(--brand-green);outline-offset:2px;box-shadow:var(--shadow-focus)}a{color:var(--brand-green-dark);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--brand-green)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;transition:all var(--transition-fast)}button:disabled{opacity:.5;cursor:not-allowed}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight)}input,textarea,select{font-family:inherit;font-size:inherit}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-small{font-size:var(--font-size-sm)}.text-tiny{font-size:var(--font-size-xs)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fadeIn{animation:fadeIn var(--transition-normal)}.animate-slideUp{animation:slideUp var(--transition-normal)}.animate-slideDown{animation:slideDown var(--transition-normal)}.animate-pulse{animation:pulse 2s infinite}.animate-spin{animation:spin 1s linear infinite}.animate-bounce{animation:bounce 1s ease-in-out infinite}#root{min-height:100vh;display:flex;flex-direction:column}
