:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--success-500: #22c55e;--warning-500: #f59e0b;--danger-500: #ef4444;--info-500: #06b6d4;--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;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans SC,Microsoft YaHei,sans-serif;line-height:1.6;color:var(--gray-800);background-color:var(--gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh;display:flex;flex-direction:column}a{color:var(--primary-600);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-700)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;line-height:1.5;border-radius:.375rem;cursor:pointer;transition:all .15s ease-in-out;text-decoration:none;border:1px solid transparent;position:relative;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.btn-primary{background:linear-gradient(180deg,#3b82f6,#2563eb);border-color:#2563eb;color:#fff;box-shadow:inset 0 1px #fff3,0 1px 2px #0000000d,0 0 0 1px #0000000d;text-shadow:0 1px 0 rgba(0,0,0,.1)}.btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#2563eb,#1d4ed8);border-color:#1d4ed8;box-shadow:inset 0 1px #ffffff1a,0 2px 4px #0000001a;transform:translateY(-.5px)}.btn-primary:active:not(:disabled){background:#1d4ed8;box-shadow:inset 0 2px 4px #0000001a;transform:translateY(0)}.btn-secondary{background:#fff;color:#374151;border-color:#d1d5db;box-shadow:0 1px 2px #0000000d}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af;color:#111827}.btn-secondary:active:not(:disabled){background:#f3f4f6;box-shadow:inset 0 1px 2px #0000000d}.btn-success{background:linear-gradient(180deg,#10b981,#059669);border-color:#059669;color:#fff;box-shadow:inset 0 1px #fff3,0 1px 2px #0000000d;text-shadow:0 1px 0 rgba(0,0,0,.1)}.btn-success:hover:not(:disabled){background:linear-gradient(180deg,#059669,#047857);transform:translateY(-.5px)}.btn-danger{background:linear-gradient(180deg,#ef4444,#dc2626);border-color:#dc2626;color:#fff;box-shadow:inset 0 1px #fff3,0 1px 2px #0000000d;text-shadow:0 1px 0 rgba(0,0,0,.1)}.btn-danger:hover:not(:disabled){background:linear-gradient(180deg,#dc2626,#b91c1c);transform:translateY(-.5px)}.form-group{margin-bottom:1.25rem;position:relative}.form-label{display:block;margin-bottom:.375rem;font-size:.8125rem;font-weight:500;color:#374151;letter-spacing:.01em}.form-input,.form-select,.form-textarea{display:block;width:100%;padding:.5rem .75rem;font-size:.875rem;line-height:1.5;color:#1f2937;background-color:#fff;background-clip:padding-box;border:1px solid #d1d5db;border-radius:.375rem;box-shadow:0 1px 2px #0000000d;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:#9ca3af}.form-input:focus,.form-select:focus,.form-textarea:focus{color:#212529;background-color:#fff;border-color:#3b82f6;outline:0;box-shadow:0 0 0 3px #3b82f626}.form-input::placeholder{color:#9ca3af;opacity:1}.form-select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:16px 12px;padding-right:2.25rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input::placeholder{color:var(--gray-400)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M2.5 4.5l3.5 3.5 3.5-3.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.card-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--gray-200);background:linear-gradient(135deg,var(--gray-50),white)}.card-title{font-size:1.125rem;font-weight:600;color:var(--gray-800)}.card-body{padding:var(--spacing-lg)}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:.875rem}.table th,.table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--gray-200)}.table th{background:var(--gray-50);font-weight:600;color:var(--gray-700);white-space:nowrap}.table tbody tr:hover{background:var(--gray-50)}.badge{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:.75rem;font-weight:500;border-radius:var(--radius-full)}.badge-primary{background:var(--primary-100);color:var(--primary-700)}.badge-success{background:#dcfce7;color:#15803d}.badge-warning{background:#fef3c7;color:#b45309}.badge-danger{background:#fee2e2;color:#dc2626}.badge-info{background:#cffafe;color:#0891b2}.flex{display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.text-center{text-align:center}.text-right{text-align:right}.w-full{width:100%}.h-full{height:100%}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-gray-500{color:var(--gray-500)}.text-gray-600{color:var(--gray-600)}.text-gray-700{color:var(--gray-700)}.text-primary{color:var(--primary-600)}.text-success{color:var(--success-500)}.text-warning{color:var(--warning-500)}.text-danger{color:var(--danger-500)}.loading-spinner{width:2rem;height:2rem;border:3px solid var(--gray-200);border-top-color:var(--primary-600);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-enter-active,.page-leave-active{transition:opacity .3s,transform .3s}.page-enter-from,.page-leave-to{opacity:0;transform:translateY(10px)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a8a,#3b82f6,#60a5fa);padding:var(--spacing-lg)}.login-container{width:100%;max-width:420px;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--spacing-2xl);animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-logo{width:64px;height:64px;margin:0 auto var(--spacing-md);background:linear-gradient(135deg,var(--primary-600),var(--primary-800));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff}.login-title{font-size:1.5rem;font-weight:700;color:var(--gray-800);margin-bottom:var(--spacing-xs)}.login-subtitle{font-size:.875rem;color:var(--gray-500)}.login-form{margin-bottom:var(--spacing-lg)}.login-error{background:#fee2e2;color:#dc2626;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem;margin-bottom:var(--spacing-md)}.login-footer{text-align:center;font-size:.75rem;color:var(--gray-400)}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:linear-gradient(180deg,#1e3a8a,#1e40af);color:#fff;display:flex;flex-direction:column;flex-shrink:0;position:fixed;left:0;top:0;bottom:0;z-index:100}.sidebar-header{padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{width:40px;height:40px;background:#ffffff1a;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.sidebar-brand .brand-text{font-size:.9rem;font-weight:600}.sidebar-nav{flex:1;padding:var(--spacing-md);overflow-y:auto}.nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs);border-radius:var(--radius-md);color:#fffc;transition:all var(--transition-fast);text-decoration:none}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#ffffff26;color:#fff}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between}.user-info{display:flex;align-items:center;gap:var(--spacing-sm)}.user-avatar{width:36px;height:36px;background:#fff3;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:600}.user-details{display:flex;flex-direction:column}.user-name{font-size:.875rem;font-weight:500}.user-role{font-size:.75rem;opacity:.7}.logout-btn{background:#ffffff1a;border:none;padding:var(--spacing-sm);border-radius:var(--radius-md);color:#fffc;cursor:pointer;transition:all var(--transition-fast)}.logout-btn:hover{background:#fff3;color:#fff}.main-content{flex:1;margin-left:260px;padding:var(--spacing-xl);background:var(--gray-50);min-height:100vh}.loading-overlay{display:flex;align-items:center;justify-content:center;min-height:300px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl)}.page-title{font-size:1.75rem;font-weight:700;color:var(--gray-800);margin-bottom:var(--spacing-xs)}.page-subtitle{font-size:.875rem;color:var(--gray-500)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);box-shadow:var(--shadow-md);transition:all var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.stat-primary .stat-icon{background:var(--primary-100);color:var(--primary-600)}.stat-success .stat-icon{background:#dcfce7;color:#16a34a}.stat-warning .stat-icon{background:#fef3c7;color:#d97706}.stat-info .stat-icon{background:#cffafe;color:#0891b2}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;color:var(--gray-800)}.stat-label{font-size:.875rem;color:var(--gray-500)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--spacing-lg)}.progress-bar{width:120px;height:20px;background:var(--gray-200);border-radius:var(--radius-full);position:relative;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-600));border-radius:var(--radius-full);transition:width var(--transition-normal)}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:500;color:var(--gray-700)}.chart-placeholder{padding:var(--spacing-md)}.chart-item{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.chart-label{width:80px;font-size:.875rem;color:var(--gray-600)}.chart-bar-container{flex:1;height:24px;background:var(--gray-100);border-radius:var(--radius-sm);overflow:hidden}.chart-bar{height:100%;background:linear-gradient(90deg,var(--primary-400),var(--primary-600));transition:width var(--transition-normal)}.chart-value{width:40px;text-align:right;font-weight:600;color:var(--gray-700)}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--spacing-lg)}.settings-item{display:flex;justify-content:space-between;padding:var(--spacing-md) 0;border-bottom:1px solid var(--gray-100)}.settings-label{font-size:.875rem;color:var(--gray-600)}.settings-value{font-size:.875rem;font-weight:500;color:var(--gray-800)}.error-message{text-align:center;padding:var(--spacing-xl);color:var(--danger-500)}.btn-sm{padding:.25rem .5rem;font-size:.75rem}@media(max-width:768px){.sidebar{width:100%;position:relative}.main-content{margin-left:0}.dashboard-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}.nav-group{margin-bottom:var(--spacing-md)}.nav-group-title{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);color:#fff9;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.nav-sub-item{padding-left:calc(var(--spacing-md) + 28px)!important;font-size:.875rem}.nav-sub-item:before{content:"•";margin-right:var(--spacing-sm);opacity:.5}.breadcrumb{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);font-size:.875rem;color:var(--gray-500)}.breadcrumb a{color:var(--primary-600);text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.breadcrumb span{color:var(--gray-400)}.org-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-lg)}.org-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);box-shadow:var(--shadow-md);cursor:pointer;transition:all var(--transition-fast);border:2px solid transparent}.org-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--primary-200)}.org-card-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:var(--primary-50);border-radius:var(--radius-lg)}.org-card-content{flex:1}.org-card-title{font-size:1rem;font-weight:600;color:var(--gray-800);margin-bottom:var(--spacing-xs)}.org-card-subtitle{font-size:.875rem;color:var(--gray-500);margin-bottom:var(--spacing-xs)}.org-card-info{display:flex;gap:var(--spacing-md);font-size:.75rem;color:var(--gray-400)}.org-card-arrow{font-size:1.5rem;color:var(--gray-300);transition:all var(--transition-fast)}.org-card:hover .org-card-arrow{color:var(--primary-500);transform:translate(4px)}.phases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.phase-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);transition:all var(--transition-fast)}.phase-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.phase-icon{font-size:2rem;margin-bottom:var(--spacing-sm)}.phase-title{font-size:1.125rem;font-weight:600;color:var(--gray-800);margin-bottom:var(--spacing-md)}.phase-items{display:flex;flex-direction:column;gap:var(--spacing-xs)}.phase-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0;font-size:.875rem;border-bottom:1px solid var(--gray-100)}.phase-item:last-child{border-bottom:none}.phase-item-name{color:var(--gray-600)}.phase-item-count{background:var(--primary-100);color:var(--primary-700);padding:.125rem .5rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.quick-links{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.quick-link{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-lg);background:var(--gray-50);border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition-fast)}.quick-link:hover{background:var(--primary-50);transform:translateY(-2px)}.quick-link-icon{font-size:2rem;margin-bottom:var(--spacing-sm)}.quick-link span{font-size:.875rem;color:var(--gray-700);font-weight:500}.phase-detail-cards{display:flex;flex-direction:column;gap:var(--spacing-lg)}.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.info-item{display:flex;flex-direction:column;padding:.875rem;background:linear-gradient(135deg,#f8fafc,#fff);border-radius:.5rem;border-left:3px solid var(--primary-400);transition:all .15s ease}.info-item:hover{background:#f1f5f9;border-left-color:var(--primary-600)}.info-item label{font-size:.6875rem;text-transform:uppercase;font-weight:600;color:var(--gray-500);margin-bottom:.375rem;letter-spacing:.03em}.info-item span{font-size:.875rem;color:var(--gray-800);font-weight:500;word-break:break-all}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mt-2{margin-top:var(--spacing-sm)}code{background:var(--gray-100);padding:.125rem .375rem;border-radius:var(--radius-sm);font-family:SF Mono,Consolas,Liberation Mono,monospace;font-size:.8125rem;color:var(--primary-700)}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--gray-500)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}.card-header{display:flex;justify-content:space-between;align-items:center}.card-link{font-size:.875rem;color:var(--primary-600);text-decoration:none}.card-link:hover{text-decoration:underline}.page-header-left{flex:1}.page-header-right{display:flex;gap:var(--spacing-sm)}.badge-secondary{background:var(--gray-200);color:var(--gray-700)}.tabs{display:flex;gap:.5rem;background:#3b82f60d;padding:.5rem;border-radius:.75rem;margin-bottom:1.5rem;overflow-x:auto;border:1px solid rgba(59,130,246,.1)}.tab-item{flex:1;min-width:max-content;padding:.625rem 1.25rem;font-weight:500;font-size:.875rem;color:var(--gray-600);background:transparent;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.tab-item:hover{background:#3b82f61a;color:var(--primary-600)}.tab-item.active{background:#fff;color:var(--primary-700);box-shadow:0 2px 8px #00000014;font-weight:600}.table tbody tr.child-row{background:var(--gray-50)}.table tbody tr.child-row:hover{background:var(--gray-100)}.tree-toggle{display:inline-block;width:16px;font-size:.75rem;color:var(--gray-400);margin-right:4px;cursor:pointer}.tree-spacer{display:inline-block;width:20px}.badge-sm{padding:.125rem .375rem;font-size:.625rem}.badge-blue{background:var(--primary-100);color:var(--primary-700)}.badge-gray{background:var(--gray-200);color:var(--gray-600)}.modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg);animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-overlay.hidden{display:none}.modal-content{background:#fff;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:640px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideIn .25s ease}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#f8fafc,#fff)}.modal-header h3,.modal-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--gray-800)}.modal-close{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:.5rem;font-size:1.25rem;color:var(--gray-500);cursor:pointer;transition:all .15s ease;line-height:1}.modal-close:hover{background:var(--gray-200);color:var(--gray-700)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.btn-add,.btn-save{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;box-shadow:0 4px 10px #10b9814d;justify-content:center;display:inline-flex;align-items:center}.btn-add:hover,.btn-save:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 6px 14px #10b98166}.btn-edit{background:#eff6ff;color:#3b82f6;border:1px solid #bfdbfe;box-shadow:0 1px 2px #0000000d;transition:all .2s ease;justify-content:center;display:inline-flex;align-items:center}.btn-edit:hover{background:#3b82f6;color:#fff;border-color:#3b82f6;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.btn-delete{background:#fef2f2;color:#ef4444;border:1px solid #fecaca;box-shadow:0 1px 2px #0000000d;transition:all .2s ease;justify-content:center;display:inline-flex;align-items:center}.btn-delete:hover{background:#ef4444;color:#fff;border-color:#ef4444;box-shadow:0 4px 12px #ef44444d;transform:translateY(-1px)}.btn-reset{background:#f3f4f6;color:#4b5563;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0000000d;transition:all .2s ease;justify-content:center;display:inline-flex;align-items:center}.btn-reset:hover{background:#6b7280;color:#fff;border-color:#6b7280;box-shadow:0 4px 12px #6b72804d;transform:translateY(-1px)}.flex-1{flex:1 1 0%}.min-w-0{min-width:0}.flex-shrink-0{flex-shrink:0}.flex-col{flex-direction:column}.gap-6{gap:1.5rem}.pl-4{padding-left:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.border-l{border-left-width:1px}.w-20{width:5rem}.mr-1{margin-right:.25rem}.w-4{width:1rem}.h-4{height:1rem}.gap-2{gap:.5rem}.table{border-radius:.5rem;overflow:hidden}.table thead th{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-600);padding:.875rem 1rem;font-weight:600}.table tbody tr{transition:background .15s ease}.table tbody tr:nth-child(2n){background:#fafafa}.table tbody tr:hover{background:#3b82f60a}.table td{padding:.875rem 1rem;vertical-align:middle}.table td .btn{padding:.25rem .625rem;font-size:.6875rem}.inline-phase-form{background:linear-gradient(135deg,#f8fafc,#fff);border:1px solid var(--gray-200);border-radius:.75rem;padding:1.5rem}.inline-phase-form .form-group{margin-bottom:0}.inline-phase-form .form-label{font-size:.6875rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.375rem}.inline-phase-form .form-input,.inline-phase-form .form-select{font-size:.8125rem;padding:.5rem .75rem;border-radius:.375rem;height:2.25rem}.card-header .card-title{display:flex;align-items:center;gap:.5rem}.card-header .card-title:before{content:"";width:4px;height:1.125rem;background:linear-gradient(180deg,var(--primary-500),var(--primary-600));border-radius:2px}.data-tabs{display:flex;gap:.5rem;background:#3b82f60d;padding:.5rem;border-radius:.75rem;margin-bottom:1.5rem;overflow-x:auto;border:1px solid rgba(59,130,246,.1)}.data-tab{flex:1;min-width:max-content;padding:.625rem 1.25rem;font-weight:500;font-size:.875rem;color:var(--gray-600);background:transparent;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.data-tab:hover{background:#3b82f61a;color:var(--primary-600)}.data-tab.active{background:#fff;color:var(--primary-700);box-shadow:0 2px 8px #00000014;font-weight:600}.data-tab-content{display:none}.data-tab-content.active{display:block}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.radio-group{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.radio-item{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:.875rem;color:var(--gray-700)}.radio-item input[type=radio]{width:18px;height:18px;accent-color:var(--primary-600);cursor:pointer}.search-row{display:flex;gap:var(--spacing-md)}.search-row .form-input{flex:1}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-md)}.data-table{width:100%;border-collapse:collapse;font-size:.875rem;background:#fff;border-radius:.5rem;overflow:hidden;box-shadow:0 1px 3px #0000000d}.data-table thead{background:linear-gradient(to right,#f8fafc,#f1f5f9)}.data-table th{padding:.875rem 1rem;text-align:left;font-weight:600;font-size:.8125rem;color:var(--gray-700);white-space:nowrap;border-bottom:2px solid #e2e8f0;text-transform:uppercase;letter-spacing:.025em}.data-table td{padding:.75rem 1rem;border-bottom:1px solid #f1f5f9;color:var(--gray-600);vertical-align:middle}.data-table tbody tr{transition:all .15s ease}.data-table tbody tr:hover{background:linear-gradient(to right,#f8fafc,transparent)}.data-table tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;line-height:1.4}.status-badge.success{background:linear-gradient(135deg,#dcfce7,#d1fae5);color:#166534;border:1px solid rgba(22,163,74,.2)}.status-badge.error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;border:1px solid rgba(239,68,68,.2)}.status-badge.warning{background:linear-gradient(135deg,#fef9c3,#fef08a);color:#854d0e;border:1px solid rgba(234,179,8,.2)}.status-badge.pending{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#475569;border:1px solid rgba(100,116,139,.2)}.status-badge.info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border:1px solid rgba(59,130,246,.2)}.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--gray-500)}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.6}.empty-state p{font-size:.9375rem;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:linear-gradient(135deg,#f8fafc,#fff);border:1px solid rgba(59,130,246,.1);border-radius:.75rem;padding:1.25rem;text-align:center;transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014;border-color:#3b82f633}.stat-label{display:block;font-size:.75rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--gray-800)}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:1rem;box-shadow:0 20px 40px #0003;max-width:480px;width:90%;max-height:80vh;overflow:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h3{font-size:1.125rem;font-weight:600;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--gray-400);cursor:pointer;padding:.25rem;line-height:1;transition:color .2s}.modal-close:hover{color:var(--gray-600)}.modal-body{padding:1.5rem}.progress-bar{height:.5rem;background:#e2e8f0;border-radius:9999px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-400));border-radius:9999px;transition:width .3s ease}.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--gray-800);color:#fff;padding:1rem 1.5rem;border-radius:.75rem;box-shadow:0 10px 25px #0003;z-index:1100;transform:translateY(100px);opacity:0;transition:all .3s ease}.toast.show{transform:translateY(0);opacity:1}.toast.success{background:linear-gradient(135deg,#22c55e,#16a34a)}.toast.error{background:linear-gradient(135deg,#ef4444,#dc2626)}.batch-id{font-family:Consolas,Monaco,monospace;font-size:.75rem;color:var(--gray-600);background:#f1f5f9;padding:.25rem .5rem;border-radius:.25rem}.action-btns{display:flex;gap:.5rem;flex-wrap:wrap}.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none}.btn-success:hover{background:linear-gradient(135deg,#16a34a,#15803d);transform:translateY(-1px)}.pagination{display:flex;gap:.5rem;align-items:center;justify-content:flex-end;margin-top:1rem;font-size:.875rem}.pagination span{color:var(--gray-600)}.bi-cockpit{position:fixed;inset:0;background:linear-gradient(135deg,#0a0e27,#0d1b3e,#0a1628 60%,#071020);color:#c0d0e0;font-family:PingFang SC,Microsoft YaHei,-apple-system,sans-serif;display:flex;flex-direction:column;overflow:hidden;z-index:9999}.bi-header{display:flex;align-items:center;justify-content:space-between;padding:10px 24px;background:linear-gradient(180deg,#0a1432f2,#0a1432b3);border-bottom:1px solid rgba(66,165,245,.15);flex-shrink:0;position:relative}.bi-header:after{content:"";position:absolute;bottom:-1px;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,rgba(66,165,245,.6),transparent)}.bi-header-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none;z-index:1}.bi-header-side{display:flex;align-items:center;gap:12px;z-index:2}.bi-header-left{display:flex;align-items:center;gap:16px}.bi-back-btn{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:#8fa8c8;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.bi-back-btn:hover{background:#42a5f533;color:#fff;border-color:#42a5f566}.bi-title{font-size:22px;font-weight:700;color:#e0ecff;margin:0;letter-spacing:4px;text-shadow:0 0 20px rgba(66,165,245,.3);background:linear-gradient(90deg,#e0ecff,#42a5f5,#e0ecff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}.bi-subtitle{font-size:12px;color:#5a7a9a;font-family:Consolas,monospace;margin-top:2px}.bi-weather-carousel{transition:opacity .3s ease;min-width:200px}.bi-weather-item{display:flex;align-items:center;gap:8px;padding:5px 14px;background:#42a5f50f;border:1px solid rgba(66,165,245,.12);border-radius:20px;font-size:12px;color:#c0d0e0;white-space:nowrap}.bi-weather-icon{font-size:18px}.bi-weather-name{font-weight:600;color:#e0ecff}.bi-weather-temp{font-weight:700;color:#ffc107;font-family:DIN Alternate,Consolas,monospace;font-size:14px}.bi-weather-desc{color:#8fa8c8}.bi-weather-detail{color:#5a7a9a;font-size:11px}.bi-weather-text{color:#5a7a9a;font-size:12px}.bi-capsules{display:flex;gap:12px}.bi-capsule{display:flex;align-items:baseline;gap:4px;padding:4px 12px;background:#42a5f50f;border:1px solid rgba(66,165,245,.12);border-radius:24px;transition:all .3s}.bi-capsule:hover{background:#42a5f51f;border-color:#42a5f540;transform:translateY(-1px)}.bi-capsule-label{font-size:11px;color:#6a8aaa;font-weight:500}.bi-capsule-value{font-size:18px;font-weight:800;color:#42a5f5;font-family:DIN Alternate,Consolas,monospace;text-shadow:0 0 15px rgba(66,165,245,.4)}.bi-capsule-unit{font-size:10px;color:#5a7a9a}.bi-header-right{display:flex;align-items:center;gap:12px}.bi-select{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#c0d0e0;padding:6px 12px;border-radius:8px;font-size:13px;cursor:pointer;transition:all .2s}.bi-select:hover,.bi-select:focus{border-color:#42a5f566;background:#42a5f51a;outline:none}.bi-select option{background:#0d1b3e;color:#c0d0e0}.bi-body{flex:1;display:grid;grid-template-columns:1fr 1.6fr 1fr;gap:12px;padding:12px 16px;overflow:hidden}.bi-panel{display:flex;flex-direction:column;gap:12px;overflow:hidden}.bi-chart-card{flex:1;background:#101c38bf;border:1px solid rgba(66,165,245,.1);border-radius:10px;display:flex;flex-direction:column;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color .3s;min-height:0}.bi-chart-card:hover{border-color:#42a5f540}.bi-chart-card-map{flex:1.5}.bi-chart-title{padding:10px 16px;font-size:13px;font-weight:600;color:#d0e0f0;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(66,165,245,.08);flex-shrink:0;position:relative}.bi-chart-title:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:linear-gradient(180deg,#42a5f5,#1565c0);border-radius:2px}.bi-chart-dot{width:6px;height:6px;background:#42a5f5;border-radius:50%;box-shadow:0 0 8px #42a5f599;animation:biPulse 2s infinite}@keyframes biPulse{0%,to{opacity:1;box-shadow:0 0 8px #42a5f599}50%{opacity:.5;box-shadow:0 0 16px #42a5f5e6}}.bi-chart-body{flex:1;min-height:0;padding:4px}.bi-map-legend{margin-left:auto;display:flex;gap:12px;align-items:center}.bi-legend-item{display:flex;align-items:center;gap:4px;font-size:11px;color:#8fa8c8}.bi-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.bi-dot-green{background:#66bb6a;box-shadow:0 0 6px #66bb6a80}.bi-dot-yellow{background:#ffa726;box-shadow:0 0 6px #ffa72680}.bi-dot-red{background:#f44336;box-shadow:0 0 6px #f4433680;animation:biAlertPulse 1s infinite}.bi-dot-blue{background:#42a5f5;box-shadow:0 0 6px #42a5f580}@keyframes biAlertPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}.bi-ranking-list{padding:8px 12px!important;display:flex;flex-direction:column;gap:6px;overflow-y:auto}.bi-rank-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#ffffff05;border-radius:6px;transition:all .3s;animation:biSlideIn .5s ease-out both}@keyframes biSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.bi-rank-item:hover{background:#42a5f514}.bi-rank-pos{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:12px;font-weight:700;color:#8fa8c8;background:#ffffff0d;flex-shrink:0}.bi-rank-top{background:linear-gradient(135deg,#ffa726,#ff7043);color:#fff;box-shadow:0 2px 8px #ffa7264d}.bi-rank-info{flex:1;min-width:0}.bi-rank-name{font-size:12px;color:#d0e0f0;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bi-rank-bar-bg{height:5px;background:#ffffff0f;border-radius:3px;overflow:hidden}.bi-rank-bar{height:100%;border-radius:3px;transition:width 1s ease-out}.bi-rank-score{font-size:15px;font-weight:700;font-family:DIN Alternate,Consolas,monospace;flex-shrink:0;min-width:40px;text-align:right}@media(max-width:1200px){.bi-body{grid-template-columns:1fr 1.2fr 1fr;gap:8px;padding:8px}.bi-capsules{gap:12px}.bi-capsule-value{font-size:18px}.bi-title{font-size:16px;letter-spacing:1px}}@media(max-width:768px){.bi-body{grid-template-columns:1fr;overflow-y:auto}.bi-header{flex-wrap:wrap;gap:8px;padding:8px 12px}.bi-capsules{flex-wrap:wrap;gap:8px}.bi-chart-card{min-height:250px}}.ms-tl-today-line{animation:msTodayBreathe 2.4s ease-in-out infinite}.ms-tl-today-label{animation:msTodayLabelBreathe 2.4s ease-in-out infinite}@keyframes msTodayBreathe{0%,to{opacity:1;border-left-color:#f06292}50%{opacity:.3;border-left-color:#f48fb1}}@keyframes msTodayLabelBreathe{0%,to{opacity:1}50%{opacity:.35}}.ms-tl-breathe-red{animation:msOverdueBreathe 1.6s ease-in-out infinite}@keyframes msOverdueBreathe{0%,to{opacity:1;box-shadow:0 0 4px #f4433699}50%{opacity:.45;box-shadow:0 0 10px #f44336e6}}
