body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;color:#333;background-color:#fff}#root{min-height:100vh}.notification-container{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;pointer-events:none;display:flex;flex-direction:column;gap:var(--space-3);max-width:400px;width:100%;padding:0 var(--space-4)}.notification{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);border:1px solid rgba(255,255,255,.2);pointer-events:auto;animation:slideInDown .3s ease-out;transition:all var(--transition-normal);max-width:100%;min-width:320px}.notification:hover{transform:translateY(-2px);box-shadow:0 25px 50px #00000026}.notification-content{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4)}.notification-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;margin-top:2px}.notification-text{flex:1;min-width:0}.notification-title{font-size:var(--text-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1);line-height:1.4}.notification-message{font-size:var(--text-sm);line-height:1.4;word-wrap:break-word}.notification-close{flex-shrink:0;background:none;border:none;cursor:pointer;padding:var(--space-1);border-radius:var(--radius-md);color:var(--text-muted);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;margin-top:2px}.notification-close:hover{background:#0000000d;color:var(--text-secondary)}.notification-close:focus{outline:none;background:#0000001a;color:var(--text-primary)}.notification-error{border-left:4px solid #ef4444}.notification-error .notification-icon{color:#ef4444}.notification-error .notification-title{color:#dc2626}.notification-error .notification-message{color:var(--text-secondary)}.notification-success{border-left:4px solid #10b981}.notification-success .notification-icon{color:#10b981}.notification-success .notification-title{color:#059669}.notification-success .notification-message{color:var(--text-secondary)}.notification-warning{border-left:4px solid #f59e0b}.notification-warning .notification-icon{color:#f59e0b}.notification-warning .notification-title{color:#d97706}.notification-warning .notification-message{color:var(--text-secondary)}.notification-info{border-left:4px solid var(--primary-blue)}.notification-info .notification-icon{color:var(--primary-blue)}.notification-info .notification-title{color:var(--primary-blue-hover)}.notification-info .notification-message{color:var(--text-secondary)}@keyframes slideInDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideOutUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}.notification-exit{animation:slideOutUp .2s ease-in forwards}@media (max-width: 480px){.notification-container{top:10px;padding:0 var(--space-3);max-width:calc(100vw - 24px)}.notification{min-width:unset;width:100%}.notification-content{padding:var(--space-3)}.notification-title,.notification-message{font-size:var(--text-xs)}}@media (prefers-reduced-motion: reduce){.notification,.notification-exit{animation:none}.notification,.notification-close{transition:none}}@media (prefers-contrast: high){.notification{border:2px solid;-webkit-backdrop-filter:none;backdrop-filter:none;background:var(--white)}.notification-error{border-color:#ef4444}.notification-success{border-color:#10b981}.notification-warning{border-color:#f59e0b}.notification-info{border-color:var(--primary-blue)}}:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--primary-blue: #667eea;--primary-purple: #764ba2;--primary-blue-hover: #5a67d8;--white: #ffffff;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--text-primary: #1a202c;--text-secondary: #718096;--text-muted: #a0aec0;--border-light: #e2e8f0;--border-focus: var(--primary-blue);--bg-primary: var(--white);--bg-secondary: var(--gray-50);--bg-card: rgba(255, 255, 255, .95);--bg-overlay: rgba(0, 0, 0, .05);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 36px;--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;--space-16: 64px;--space-20: 80px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-primary: 0 4px 12px rgba(102, 126, 234, .3);--shadow-primary-hover: 0 6px 16px rgba(102, 126, 234, .4);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;line-height:1.5;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-weight:var(--font-weight-normal);color:var(--text-primary);background-color:var(--bg-secondary);line-height:1.6}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-4xl{font-size:var(--text-4xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:1.2;letter-spacing:-.025em;margin-bottom:var(--space-4)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{margin-bottom:var(--space-4);color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-3) var(--space-6);border:none;border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:var(--font-weight-semibold);letter-spacing:.025em;cursor:pointer;transition:all var(--transition-normal);text-decoration:none;gap:var(--space-2)}.btn:focus{outline:none;box-shadow:0 0 0 3px #667eea33}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-primary-hover)}.btn-secondary{background:var(--white);color:var(--text-primary);border:2px solid var(--border-light)}.btn-secondary:hover:not(:disabled){border-color:var(--primary-blue);color:var(--primary-blue)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-overlay);color:var(--text-primary)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-lg);height:48px}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);background-color:var(--white);transition:all var(--transition-normal)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted);font-weight:var(--font-weight-normal)}.form-textarea{min-height:120px;resize:vertical}.card{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.2);transition:all var(--transition-slow);overflow:hidden}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}.card-header{padding:var(--space-6);border-bottom:1px solid var(--border-light)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-6);border-top:1px solid var(--border-light);background:var(--bg-secondary)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-5)}.container-sm{max-width:640px}.container-md{max-width:768px}.container-lg{max-width:1024px}.container-xl{max-width:1280px}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.m-0{margin:0}.m-2{margin:var(--space-2)}.m-4{margin:var(--space-4)}.m-6{margin:var(--space-6)}.m-8{margin:var(--space-8)}.mt-0{margin-top:0}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-0{margin-bottom:0}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.p-0{padding:0}.p-2{padding:var(--space-2)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.app{min-height:100vh;background:var(--bg-secondary)}.nav{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.nav-container{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto}.nav-brand{font-size:var(--text-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);text-decoration:none;letter-spacing:-.5px}.nav-links{display:flex;gap:var(--space-6);list-style:none}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:var(--font-weight-medium);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);transition:all var(--transition-normal)}.nav-link:hover,.nav-link.active{color:var(--primary-blue);background:#667eea1a}.main-content{padding:var(--space-8);max-width:1200px;margin:0 auto;min-height:calc(100vh - 80px)}.page-title{font-size:var(--text-4xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.page-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin:0}@media (max-width: 768px){.container{padding:0 var(--space-4)}.nav{padding:var(--space-3) var(--space-4)}.nav-links{gap:var(--space-4)}.main-content{padding:var(--space-6) var(--space-4)}.page-title{font-size:var(--text-3xl)}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}}@media (max-width: 480px){.card-header,.card-body,.card-footer{padding:var(--space-4)}.btn{padding:var(--space-3) var(--space-5)}.page-title{font-size:var(--text-2xl)}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.login-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 20px 40px #0000001a;padding:48px;width:100%;max-width:440px;border:1px solid rgba(255,255,255,.2);transition:transform .3s ease,box-shadow .3s ease}.login-card:hover{transform:translateY(-5px);box-shadow:0 25px 50px #00000026}.login-header{text-align:center;margin-bottom:40px}.logo-section{margin-bottom:24px}.logo-placeholder{display:inline-flex;align-items:center;justify-content:center;width:90px;height:60px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;margin-bottom:16px}.logo-text{font-size:18px;font-weight:700;color:#fff;letter-spacing:-.5px}.login-title{font-size:32px;font-weight:700;color:#1a202c;margin:0 0 8px;letter-spacing:-.5px}.login-subtitle{font-size:16px;color:#718096;margin:0;font-weight:400}.login-form{width:100%}.form-group{margin-bottom:24px}.form-label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px;letter-spacing:.025em}.input-wrapper{position:relative;display:flex;align-items:center}.form-input{width:100%;height:48px;padding:12px 48px 12px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:16px;color:#1a202c;background-color:#fff;transition:all .2s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input::placeholder{color:#a0aec0;font-weight:400}.input-icon{position:absolute;right:16px;color:#a0aec0;pointer-events:none}.password-toggle{position:absolute;right:16px;background:none;border:none;color:#a0aec0;cursor:pointer;padding:4px;border-radius:4px;transition:color .2s ease;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:#667eea}.password-toggle:focus{outline:none;color:#667eea}.login-button{width:100%;height:48px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;letter-spacing:.025em;box-shadow:0 4px 12px #667eea4d;margin-top:32px}.login-button:hover{transform:translateY(-1px);box-shadow:0 6px 16px #667eea66}.login-button:active{transform:translateY(0);box-shadow:0 2px 8px #667eea4d}.login-button:focus{outline:none;box-shadow:0 0 0 3px #667eea33,0 4px 12px #667eea4d}@media (max-width: 768px){.login-container{padding:16px}.login-card{padding:32px 24px;border-radius:16px}.login-title{font-size:28px}}@media (max-width: 480px){.login-card{padding:24px 20px}.login-title{font-size:24px}.form-input{height:44px;font-size:16px}}.navbar{position:fixed;top:0;left:0;right:0;height:64px;background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm);z-index:1000;transition:all var(--transition-normal)}.navbar-container{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 var(--space-6);max-width:100%}.navbar-left{display:flex;align-items:center;gap:var(--space-4)}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-normal)}.menu-toggle:hover{background:var(--bg-overlay);color:var(--text-primary)}.menu-icon{width:24px;height:24px;transition:transform var(--transition-normal)}.menu-icon.open{transform:rotate(90deg)}.brand{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;color:inherit}.brand-logo{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--primary-gradient);border-radius:var(--radius-lg);box-shadow:var(--shadow-primary)}.brand-text{font-size:var(--text-sm);font-weight:var(--font-weight-bold);color:var(--white);letter-spacing:-.5px}.brand-name{font-size:var(--text-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:-.5px}.navbar-right{display:flex;align-items:center;gap:var(--space-4)}.logout-button{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:2px solid var(--border-light);background:var(--white);color:var(--text-primary);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal)}.logout-button:hover{border-color:var(--primary-blue);color:var(--primary-blue);transform:translateY(-1px);box-shadow:var(--shadow-md)}.logout-icon{width:16px;height:16px}@media (min-width: 1024px){.menu-toggle{display:none}}@media (max-width: 768px){.navbar-container{padding:0 var(--space-4)}.menu-toggle{display:flex}.brand-name{display:none}.logout-button{padding:var(--space-2)}.logout-button span{display:none}}@media (max-width: 480px){.navbar-container{padding:0 var(--space-3)}.brand-logo{width:36px;height:36px}.brand-text{font-size:var(--text-xs)}}.sidebar{position:fixed;top:64px;left:0;width:280px;height:calc(100vh - 64px);background:var(--bg-card);border-right:1px solid var(--border-light);box-shadow:var(--shadow-lg);z-index:900;overflow:hidden;transform:translate(-100%);transition:transform var(--transition-normal)}.sidebar.open{transform:translate(0)}.sidebar-content{height:100%;padding:var(--space-6) 0;overflow-y:auto;overflow-x:hidden}.sidebar-content::-webkit-scrollbar{width:4px}.sidebar-content::-webkit-scrollbar-track{background:transparent}.sidebar-content::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:2px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.sidebar-header{padding:0 var(--space-6) var(--space-4) var(--space-6);border-bottom:1px solid var(--border-light);margin-bottom:var(--space-4)}.sidebar-title{font-size:var(--text-lg);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0}.sidebar-nav{padding:0}.sidebar-group{margin-bottom:var(--space-6)}.sidebar-group-title{padding:0 var(--space-6);font-size:var(--text-xs);font-weight:var(--font-weight-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.sidebar-group-items{display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-item{display:block;text-decoration:none;color:inherit;padding:0 var(--space-6);transition:all var(--transition-normal);position:relative}.sidebar-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary-blue);transform:scaleY(0);transition:transform var(--transition-normal)}.sidebar-item.active:before{transform:scaleY(1)}.sidebar-item-content{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);transition:all var(--transition-normal);position:relative}.sidebar-item:hover .sidebar-item-content{background:var(--bg-overlay);transform:translate(4px)}.sidebar-item.active .sidebar-item-content{background:#667eea1a;color:var(--primary-blue)}.sidebar-item-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--text-secondary);transition:color var(--transition-normal)}.sidebar-item-icon svg{width:100%;height:100%}.sidebar-item.active .sidebar-item-icon{color:var(--primary-blue)}.sidebar-item-text{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);transition:color var(--transition-normal);flex:1}.sidebar-item.active .sidebar-item-text{color:var(--primary-blue);font-weight:var(--font-weight-semibold)}.sidebar-item-badge{background:var(--primary-blue);color:var(--white);font-size:var(--text-xs);font-weight:var(--font-weight-bold);padding:2px var(--space-2);border-radius:var(--radius-sm);min-width:20px;text-align:center;line-height:1.2}.sidebar-overlay{position:fixed;inset:64px 0 0;background:#00000080;z-index:850;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (min-width: 1024px){.sidebar{position:fixed;top:64px;left:0;transform:translate(0);height:calc(100vh - 64px);z-index:auto}.sidebar-overlay{display:none}}@media (max-width: 1023px){.sidebar{width:100%;max-width:320px}}@media (max-width: 768px){.sidebar{max-width:280px}.sidebar-content{padding:var(--space-4) 0}.sidebar-header{padding:0 var(--space-4) var(--space-3) var(--space-4)}.sidebar-group-title,.sidebar-item{padding:0 var(--space-4)}}@media (max-width: 480px){.sidebar{max-width:260px}}.main-layout{min-height:100vh;background:var(--bg-secondary)}.layout-container{display:flex;padding-top:64px;min-height:calc(100vh - 64px)}.main-content{flex:1;background:var(--bg-secondary);transition:all var(--transition-normal);min-height:calc(100vh - 64px);overflow-x:hidden;width:100%}.content-wrapper{padding:var(--space-8);max-width:1400px;margin:0 auto;width:100%}@media (min-width: 1024px){.layout-container{padding-left:0}.main-content{margin-left:280px;width:calc(100% - 280px)}}@media (max-width: 1023px){.main-content.sidebar-open{transform:translate(0)}}@media (max-width: 768px){.content-wrapper{padding:var(--space-6) var(--space-4)}}@media (max-width: 480px){.content-wrapper{padding:var(--space-4) var(--space-3)}}.page-container{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.2);overflow:hidden;margin-bottom:var(--space-8)}.page-header{padding:var(--space-8) var(--space-8) var(--space-6) var(--space-8);border-bottom:1px solid var(--border-light);background:var(--bg-card)}.page-body{padding:var(--space-8)}.page-title{font-size:var(--text-4xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 var(--space-2) 0;letter-spacing:-.025em}.page-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin:0;font-weight:var(--font-weight-normal)}@media (max-width: 768px){.page-header{padding:var(--space-6) var(--space-6) var(--space-4) var(--space-6)}.page-body{padding:var(--space-6)}.page-title{font-size:var(--text-3xl)}.page-subtitle{font-size:var(--text-base)}}@media (max-width: 480px){.page-header,.page-body{padding:var(--space-4)}.page-title{font-size:var(--text-2xl)}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16);color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-light);border-top:3px solid var(--primary-blue);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--space-4)}.pipeline-controls{display:flex;align-items:end;gap:var(--space-6);padding:var(--space-6);background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.2);margin-bottom:var(--space-8)}.control-group{flex:1;max-width:300px}.control-group:last-child{max-width:none;margin-left:auto}.language-toggle{display:flex;background:var(--gray-100);border-radius:var(--radius-lg);padding:2px}.toggle-btn{flex:1;padding:var(--space-2) var(--space-4);border:none;background:transparent;color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-weight-medium);border-radius:calc(var(--radius-lg) - 2px);cursor:pointer;transition:all var(--transition-normal)}.toggle-btn.active{background:var(--white);color:var(--text-primary);box-shadow:var(--shadow-sm)}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.status-info{display:flex;flex-direction:column;gap:var(--space-1);font-size:var(--text-sm);color:var(--text-secondary)}.status-item{display:flex;align-items:center;gap:var(--space-2)}.status-item.updating{color:var(--primary-blue);font-weight:var(--font-weight-semibold)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16);text-align:center;background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-light)}.empty-icon{font-size:4rem;margin-bottom:var(--space-4);opacity:.6}.empty-state h3{font-size:var(--text-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.empty-state p{font-size:var(--text-base);color:var(--text-secondary);margin:0;max-width:400px}.function-config{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.2);overflow:hidden}.function-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6) var(--space-8);border-bottom:1px solid var(--border-light);background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-purple) 100%);color:var(--white)}.function-title{font-size:var(--text-2xl);font-weight:var(--font-weight-bold);margin:0;letter-spacing:-.025em}.function-language{background:#fff3;color:var(--white);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-weight-semibold);text-transform:capitalize}.config-sections{padding:var(--space-8)}.section-header{margin-bottom:var(--space-6)}.section-title{font-size:var(--text-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 var(--space-2) 0;letter-spacing:-.025em}.section-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0}.model-config-section{margin-bottom:var(--space-12)}.model-config-form{background:var(--gray-50);border-radius:var(--radius-lg);padding:var(--space-6);border:1px solid var(--border-light)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-6);margin-bottom:var(--space-8)}.form-group{display:flex;flex-direction:column}.form-input,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);background-color:var(--white);transition:all var(--transition-normal)}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #667eea1a}.form-input:disabled,.form-textarea:disabled{background-color:var(--gray-100);color:var(--text-muted);cursor:not-allowed}.form-textarea{resize:vertical;min-height:120px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;line-height:1.5}.form-range{width:100%;height:6px;background:var(--gray-200);border-radius:3px;outline:none;appearance:none;-webkit-appearance:none;margin:var(--space-2) 0}.form-range::-webkit-slider-thumb{appearance:none;width:18px;height:18px;background:var(--primary-blue);border-radius:50%;cursor:pointer;transition:all var(--transition-normal)}.form-range::-webkit-slider-thumb:hover{background:var(--primary-blue-hover);transform:scale(1.1)}.form-range::-moz-range-thumb{width:18px;height:18px;background:var(--primary-blue);border-radius:50%;cursor:pointer;border:none}.range-labels{display:flex;justify-content:space-between;font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-1)}.form-help{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.form-actions{display:flex;gap:var(--space-3);justify-content:flex-start;padding-top:var(--space-4);border-top:1px solid var(--border-light)}.prompts-section{margin-top:var(--space-8)}.prompts-list{display:flex;flex-direction:column;gap:var(--space-4)}.prompt-item{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-normal)}.prompt-item:hover{border-color:var(--primary-blue);box-shadow:var(--shadow-sm)}.prompt-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--gray-50);border-bottom:1px solid var(--border-light)}.prompt-meta{display:flex;align-items:center;gap:var(--space-3)}.prompt-index{font-weight:var(--font-weight-bold);color:var(--text-secondary);font-size:var(--text-sm);min-width:30px}.prompt-role{padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em}.prompt-role.role-system{background:#fef3c7;color:#92400e}.prompt-role.role-user{background:#dbeafe;color:#1e40af}.prompt-role.role-assistant{background:#dcfce7;color:#166534}.prompt-role.role-default{background:var(--gray-200);color:var(--gray-700)}.prompt-updated{font-size:var(--text-xs);color:var(--text-secondary)}.prompt-actions{display:flex;gap:var(--space-2)}.btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--white);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-normal);font-size:var(--text-sm)}.btn-icon:hover:not(:disabled){border-color:var(--primary-blue);color:var(--primary-blue);background:var(--primary-blue);color:var(--white)}.btn-icon:disabled{opacity:.4;cursor:not-allowed;background:var(--gray-100)}.prompt-content{padding:var(--space-6)}.prompt-text{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:var(--text-sm);line-height:1.6;color:var(--text-primary);background:var(--gray-50);padding:var(--space-4);border-radius:var(--radius-md);white-space:pre-wrap;word-wrap:break-word;margin:0;border:1px solid var(--border-light)}.prompt-edit-form{padding:var(--space-6);background:var(--gray-50);border-top:1px solid var(--border-light)}.prompt-edit-form .form-group{margin-bottom:var(--space-4)}.prompt-edit-form .form-group:last-of-type{margin-bottom:var(--space-6)}@media (max-width: 768px){.pipeline-controls{flex-direction:column;align-items:stretch;gap:var(--space-4)}.control-group{max-width:none}.control-group:last-child{margin-left:0}.form-grid{grid-template-columns:1fr;gap:var(--space-4)}.function-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.function-title{font-size:var(--text-xl)}.prompt-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.prompt-meta{flex-wrap:wrap}.form-actions{flex-direction:column}.config-sections{padding:var(--space-6)}}@media (max-width: 480px){.config-sections,.model-config-form{padding:var(--space-4)}.empty-state{padding:var(--space-8)}.empty-icon{font-size:3rem}}.page-container{min-height:100vh;background:var(--bg-secondary)}.page-header{margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-light)}.page-body{display:flex;flex-direction:column;gap:var(--space-6)}.logging-controls{display:flex;align-items:end;gap:var(--space-6);padding:var(--space-6);background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.2)}.control-group{flex:1;max-width:400px}.control-actions{display:flex;gap:var(--space-3);align-items:center}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--space-2);letter-spacing:.025em}.form-select{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--text-primary);background-color:var(--white);transition:all var(--transition-normal);background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right var(--space-3) center;background-repeat:no-repeat;background-size:16px 12px;padding-right:var(--space-10)}.form-select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #667eea1a}.form-select:disabled{background-color:var(--gray-100);color:var(--text-muted);cursor:not-allowed}.status-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-6);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-light);font-size:var(--text-sm)}.status-info,.status-controls{display:flex;gap:var(--space-4);align-items:center}.connection-status{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-weight-medium);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md)}.status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}.status-connected .status-dot{background-color:#10b981}.status-connecting .status-dot{background-color:#f59e0b}.status-disconnected .status-dot{background-color:var(--gray-400);animation:none}.status-error .status-dot{background-color:#ef4444}.status-connected{color:#065f46;background:#10b9811a}.status-connecting{color:#92400e;background:#f59e0b1a}.status-disconnected{color:var(--text-muted);background:var(--gray-100)}.status-error{color:#991b1b;background:#ef44441a}.logger-info{color:var(--text-secondary)}.logs-count{color:var(--text-muted);font-size:var(--text-xs);padding:var(--space-1) var(--space-2);background:var(--gray-100);border-radius:var(--radius-sm)}.auto-scroll-toggle{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--text-sm);color:var(--text-secondary)}.auto-scroll-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-blue)}.logs-container{flex:1;background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.2);overflow:hidden;height:60vh;min-height:400px}.logs-viewport{height:100%;overflow-y:auto;padding:0}.logs-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-style:italic;font-size:var(--text-lg)}.logs-list{padding:var(--space-4)}.log-entry{display:grid;grid-template-columns:180px 80px 1fr 120px;gap:var(--space-4);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-light);font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:var(--text-sm);line-height:1.4;transition:background-color var(--transition-fast);align-items:start}.log-entry:hover{background-color:var(--bg-overlay)}.log-entry:last-child{border-bottom:none}.log-timestamp{color:var(--text-muted);font-size:var(--text-xs);white-space:nowrap}.log-level{font-weight:var(--font-weight-bold);text-align:center;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);white-space:nowrap}.log-message{color:var(--text-primary);word-break:break-word;line-height:1.5}.log-logger{color:var(--text-muted);font-size:var(--text-xs);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.log-level-debug .log-level{color:#6b7280;background:#6b72801a}.log-level-info .log-level{color:#0ea5e9;background:#0ea5e91a}.log-level-warning .log-level{color:#f59e0b;background:#f59e0b1a}.log-level-error .log-level{color:#ef4444;background:#ef44441a}.log-level-critical .log-level{color:#dc2626;background:#dc262633;border:1px solid rgba(220,38,38,.3)}.log-level-critical{background:#dc26260d;border-left:4px solid #dc2626;padding-left:var(--space-3)}.log-level-error{border-left:3px solid #ef4444;padding-left:calc(var(--space-4) - 3px)}.log-level-warning{border-left:2px solid #f59e0b;padding-left:calc(var(--space-4) - 2px)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.log-entry{animation:fadeIn .2s ease-out}.logs-viewport::-webkit-scrollbar{width:8px}.logs-viewport::-webkit-scrollbar-track{background:var(--gray-100)}.logs-viewport::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-sm)}.logs-viewport::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}@media (max-width: 1024px){.log-entry{grid-template-columns:160px 70px 1fr 100px;gap:var(--space-3);font-size:var(--text-xs)}.log-timestamp{font-size:11px}}@media (max-width: 768px){.logging-controls{flex-direction:column;align-items:stretch;gap:var(--space-4)}.control-actions{justify-content:center;flex-wrap:wrap}.status-bar{flex-direction:column;gap:var(--space-3);align-items:stretch}.status-info{justify-content:center;flex-wrap:wrap}.status-controls{justify-content:center}.logs-container{height:50vh}.log-entry{grid-template-columns:1fr;gap:var(--space-2);padding:var(--space-3)}.log-timestamp,.log-level,.log-logger{font-size:11px}.log-level{display:inline-block;width:auto;text-align:left}}@media (max-width: 480px){.page-header{text-align:center}.logging-controls{padding:var(--space-4)}.control-actions .btn{flex:1;min-width:0}.logs-container{height:45vh;min-height:300px}}:root{--info-bg: #e1f5fe;--info-border: #81d4fa;--info-text: #01579b}.demo-form{margin-bottom:var(--space-8)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-6);margin-bottom:var(--space-6)}.form-group{margin-bottom:var(--space-6)}.form-group label{display:block;font-weight:var(--font-weight-medium);color:var(--text-primary);margin-bottom:var(--space-2);font-size:var(--text-sm)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-primary);background:var(--white);transition:all var(--transition-normal);font-family:var(--font-family)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #667eea1a}.form-textarea{resize:vertical;min-height:100px}.form-textarea.large{min-height:400px}.form-help{display:block;margin-top:var(--space-1);font-size:var(--text-xs);color:var(--text-secondary)}.checkbox-group{display:flex;align-items:center;margin-bottom:0}.checkbox-label{display:flex;align-items:center;cursor:pointer;margin-bottom:0!important;font-weight:var(--font-weight-normal)!important}.form-checkbox{width:auto!important;margin-right:var(--space-2);margin-bottom:0}.textarea-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.word-count{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-weight-medium)}.file-upload-area{border:2px dashed var(--border-light);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center;transition:all var(--transition-normal);cursor:pointer;background:var(--gray-50)}.file-upload-area:hover{border-color:var(--primary-blue);background:#667eea0d}.file-input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer}.file-upload-content{position:relative}.file-placeholder{color:var(--text-secondary)}.upload-icon{font-size:var(--text-2xl);display:block;margin-bottom:var(--space-2)}.file-selected{display:flex;align-items:center;justify-content:center;gap:var(--space-2);color:var(--text-primary);font-weight:var(--font-weight-medium)}.file-icon{font-size:var(--text-lg)}.file-size{color:var(--text-secondary);font-weight:var(--font-weight-normal)}.file-format-info{background:var(--gray-50);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-6)}.file-format-info h4{margin:0 0 var(--space-3) 0;color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-weight-semibold)}.code-block{background:var(--gray-800);color:var(--white);padding:var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);overflow-x:auto;margin:var(--space-3) 0;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,monospace;line-height:1.4}.file-preview{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-6)}.file-preview h4{margin:0 0 var(--space-3) 0;color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-weight-semibold)}.preview-table{display:grid;gap:var(--space-1)}.preview-header{display:grid;grid-template-columns:2fr 3fr 1fr;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--gray-100);border-radius:var(--radius-sm);font-weight:var(--font-weight-semibold);font-size:var(--text-sm);color:var(--text-primary)}.preview-row{display:grid;grid-template-columns:2fr 3fr 1fr;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-light);font-size:var(--text-sm);align-items:center}.preview-row:last-child{border-bottom:none}.preview-title{font-weight:var(--font-weight-medium);color:var(--text-primary)}.preview-url{color:var(--text-secondary);word-break:break-all}.preview-status{padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-weight:var(--font-weight-semibold);text-align:center;font-size:var(--text-xs)}.status-200{background:#d1fae5;color:#065f46}.status-404{background:#fee2e2;color:#991b1b}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-3) var(--space-6);border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-weight-medium);text-decoration:none;cursor:pointer;transition:all var(--transition-normal);font-family:var(--font-family);gap:var(--space-2)}.btn-primary{background:var(--primary-gradient);color:var(--white);box-shadow:var(--shadow-primary)}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-primary-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:var(--white);color:var(--text-primary);border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--gray-50);box-shadow:var(--shadow-md)}.btn-small{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.btn.loading:after{content:"";width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite;margin-left:var(--space-2)}.form-actions{display:flex;justify-content:flex-start;padding-top:var(--space-6);border-top:1px solid var(--border-light);margin-top:var(--space-6)}.demo-response{padding:var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-6);border-left:4px solid}.demo-response.success{background-color:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}.demo-response.error{background-color:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.demo-response.info{background-color:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}.demo-response pre{background:#0000000d;padding:1rem;border-radius:4px;font-family:Courier New,monospace;font-size:.875rem;overflow-x:auto;white-space:pre-wrap;margin:.5rem 0 0}.session-actions{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.1)}.demo-response h3{margin:0 0 var(--space-2) 0;font-size:var(--text-lg);font-weight:var(--font-weight-semibold)}.demo-response p{margin:0 0 var(--space-1) 0;font-size:var(--text-sm)}.demo-response p:last-child{margin-bottom:0}.demo-info{background:var(--gray-50);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-6);margin-top:var(--space-8)}.demo-info h3{margin:0 0 var(--space-4) 0;color:var(--text-primary);font-size:var(--text-xl);font-weight:var(--font-weight-semibold)}.demo-info h4{margin:var(--space-4) 0 var(--space-2) 0;color:var(--text-primary);font-size:var(--text-lg);font-weight:var(--font-weight-medium)}.demo-info p{margin:0 0 var(--space-3) 0;color:var(--text-secondary);line-height:1.6}.demo-info ul{margin:0 0 var(--space-4) 0;padding-left:var(--space-6);color:var(--text-secondary)}.demo-info li{margin-bottom:var(--space-1);line-height:1.5}.demo-tip{background:#667eea1a;border:1px solid rgba(102,126,234,.2);border-radius:var(--radius-md);padding:var(--space-4);margin-top:var(--space-4)}.demo-tip h4{margin:0 0 var(--space-2) 0;color:var(--primary-blue);font-size:var(--text-base);font-weight:var(--font-weight-semibold)}.demo-tip p{margin:0;color:var(--text-primary);font-size:var(--text-sm)}.demo-tip ul{margin:var(--space-2) 0 0 0;color:var(--text-primary)}.demo-features{margin-top:var(--space-4)}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-top:var(--space-3)}.feature-item{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--space-3)}.feature-item strong{display:block;color:var(--text-primary);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1);font-size:var(--text-sm)}.feature-item p{margin:0;font-size:var(--text-xs);color:var(--text-secondary);line-height:1.4}@media (max-width: 768px){.form-row{grid-template-columns:1fr;gap:var(--space-4)}.textarea-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.preview-header,.preview-row{grid-template-columns:1fr;gap:var(--space-2)}.preview-header span,.preview-row span{padding:var(--space-1) 0}.feature-grid{grid-template-columns:1fr}.demo-info{padding:var(--space-4)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
