.account-list-page{min-height:100vh;padding:20px;max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--color-gray-300)}.page-header h1{font-size:24px;font-weight:600;color:var(--color-gray-900)}.header-actions{display:flex;align-items:center;gap:16px}.username{color:var(--color-gray-600);font-size:14px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--color-gray-600)}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-gray-300);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.login-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.login-prompt h1{font-size:28px;margin-bottom:16px;color:var(--color-gray-900)}.login-prompt p{color:var(--color-gray-600);margin-bottom:24px}.error-banner{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#fef2f2;border:1px solid var(--color-error);border-radius:4px;margin-bottom:16px;color:var(--color-error)}.btn-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--color-error);padding:0 4px}.filter-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:16px}.search-input{flex:1;max-width:400px;padding:8px 12px;border:1px solid var(--color-gray-300);border-radius:4px;font-size:14px;outline:none;transition:border-color .2s}.search-input:focus{border-color:var(--color-primary)}.account-count{color:var(--color-gray-600);font-size:14px}.empty-state{text-align:center;padding:60px 20px;color:var(--color-gray-600)}.account-table{width:100%;border-collapse:collapse;background-color:var(--color-white)}.account-table th,.account-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--color-gray-200)}.account-table th{font-weight:600;color:var(--color-gray-600);font-size:12px;text-transform:uppercase;letter-spacing:.5px;background-color:var(--color-gray-100)}.account-table tbody tr:hover{background-color:var(--color-gray-100)}.account-id{font-family:monospace;font-size:13px}.account-name{font-weight:500}.saml-profile{color:var(--color-gray-600);font-size:13px}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.status-active{background-color:#dcfce7;color:var(--color-success)}.status-inactive{background-color:var(--color-gray-200);color:var(--color-gray-600)}.btn{padding:8px 16px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-secondary:hover{background-color:var(--color-gray-300)}.btn-sm{padding:6px 12px;font-size:13px}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:12px}.filter-bar{flex-direction:column;align-items:stretch}.search-input{max-width:none}.account-table{font-size:13px}.account-table th,.account-table td{padding:8px 12px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background-color:var(--color-gray-100)}.login-container{width:100%;max-width:440px}.back-link{display:inline-block;background:none;border:none;color:var(--color-primary);font-size:14px;cursor:pointer;padding:0;margin-bottom:16px}.back-link:hover{text-decoration:underline}.login-card{background-color:var(--color-white);border-radius:8px;padding:32px;box-shadow:0 1px 3px #0000001a}.login-card h1{font-size:24px;font-weight:600;margin-bottom:24px;color:var(--color-gray-900)}.account-info{background-color:var(--color-gray-100);border-radius:4px;padding:16px;margin-bottom:24px}.info-row{display:flex;justify-content:space-between;padding:4px 0}.info-row .label{color:var(--color-gray-600);font-size:13px}.info-row .value{font-weight:500;color:var(--color-gray-900)}.info-row .account-id{font-family:monospace;font-size:13px}.error-message{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#fef2f2;border:1px solid var(--color-error);border-radius:4px;margin-bottom:20px;color:var(--color-error);font-size:14px}.error-message .btn-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--color-error);padding:0 4px;line-height:1}.error-state{text-align:center;padding:40px 20px}.error-state h2{font-size:20px;margin-bottom:12px;color:var(--color-gray-900)}.error-state p{color:var(--color-gray-600);margin-bottom:24px}.form-group{margin-bottom:24px}.form-group label{display:block;font-weight:500;margin-bottom:8px;color:var(--color-gray-900)}.otp-input{width:100%;padding:12px 16px;border:1px solid var(--color-gray-300);border-radius:4px;font-size:18px;letter-spacing:4px;text-align:center;outline:none;transition:border-color .2s}.otp-input:focus{border-color:var(--color-primary)}.otp-input:disabled{background-color:var(--color-gray-100);cursor:not-allowed}.help-text{font-size:13px;color:var(--color-gray-600);margin-top:8px}.form-actions{display:flex;gap:12px;justify-content:flex-end}.btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;display:inline-flex;align-items:center;gap:8px}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:disabled{background-color:var(--color-gray-300);cursor:not-allowed}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.help-section{margin-top:24px;padding:16px;background-color:var(--color-white);border-radius:8px;box-shadow:0 1px 3px #0000001a}.help-section h3{font-size:14px;font-weight:600;margin-bottom:12px;color:var(--color-gray-900)}.help-section ul{list-style:none;padding:0}.help-section li{font-size:13px;color:var(--color-gray-600);padding:4px 0 4px 16px;position:relative}.help-section li:before{content:"•";position:absolute;left:0;color:var(--color-gray-300)}@media (max-width: 480px){.login-card{padding:24px}.form-actions{flex-direction:column-reverse}.btn{width:100%;justify-content:center}}:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--secondary-gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--success-gradient: linear-gradient(135deg, #11998e 0%, #38ef7d 100%);--warning-gradient: linear-gradient(135deg, #f2994a 0%, #f2c94c 100%);--danger-gradient: linear-gradient(135deg, #eb3349 0%, #f45c43 100%);--dark-bg: #1a1a2e;--card-shadow: 0 10px 40px rgba(0, 0, 0, .1);--card-hover-shadow: 0 20px 60px rgba(0, 0, 0, .15)}.dashboard-page{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#f5f7fa,#e4e8ec)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:20px 32px;background:var(--dark-bg);box-shadow:0 4px 20px #00000026}.header-left h1{font-size:24px;font-weight:700;color:#fff;margin:0;letter-spacing:-.5px}.header-right{display:flex;align-items:center;gap:20px}.session-timer{display:flex;align-items:center;gap:10px;padding:10px 18px;background:#ffffff1a;border-radius:12px;font-size:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.session-timer.expiring{background:#f5576c33;border-color:#f5576c4d;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.timer-label{color:#ffffffb3;font-weight:500}.timer-value{font-family:SF Mono,Monaco,Inconsolata,monospace;font-weight:700;color:#fff;font-size:16px}.context-bar{display:flex;gap:32px;padding:16px 32px;background:linear-gradient(90deg,#16213e,#1a1a2e);border-bottom:1px solid rgba(255,255,255,.05)}.context-item{display:flex;align-items:center;gap:10px;font-size:14px}.context-item.target{padding-left:32px;border-left:2px solid rgba(255,255,255,.1)}.context-label{color:#ffffff80;font-weight:500}.context-value{font-family:SF Mono,Monaco,monospace;font-weight:600;color:#4ade80;background:#4ade801a;padding:4px 10px;border-radius:6px}.context-profile,.context-role{color:#ffffff80;font-size:13px;font-style:italic}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#666}.loading-spinner{width:48px;height:48px;border:4px solid #e1e5eb;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.dashboard-content{flex:1;padding:32px;max-width:1400px;margin:0 auto;width:100%}.quick-actions-section{margin-bottom:32px}.quick-actions-section h2{font-size:20px;font-weight:700;margin-bottom:20px;color:var(--dark-bg);display:flex;align-items:center;gap:10px}.quick-actions-section h2:before{content:"⚡";font-size:24px}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}.action-card{background:#fff;border-radius:20px;padding:28px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--card-shadow);border:1px solid rgba(0,0,0,.05);position:relative;overflow:hidden}.action-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--primary-gradient);opacity:0;transition:opacity .3s}.action-card:hover{transform:translateY(-8px);box-shadow:var(--card-hover-shadow)}.action-card:hover:before{opacity:1}.action-card:first-child:before{background:var(--success-gradient)}.action-card:last-child:before{background:var(--primary-gradient)}.action-card .action-icon{font-size:48px;margin-bottom:16px;display:inline-block;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.action-card h3{font-size:18px;font-weight:700;color:var(--dark-bg);margin-bottom:10px}.action-card p{font-size:14px;color:#666;line-height:1.6;margin:0}.switch-role-section,.resources-section{background:#fff;border-radius:20px;padding:32px;margin-bottom:24px;box-shadow:var(--card-shadow);border:1px solid rgba(0,0,0,.05)}.switch-role-section h2,.resources-section h2{font-size:20px;font-weight:700;margin-bottom:8px;color:var(--dark-bg)}.section-description{color:#666;font-size:14px;margin-bottom:24px;line-height:1.6}.error-message{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#fff5f5,#fed7d7);border:1px solid #feb2b2;border-radius:12px;margin-bottom:24px;color:#c53030;font-size:14px;font-weight:500}.error-message .btn-close{background:none;border:none;font-size:20px;cursor:pointer;color:#c53030;padding:0 4px;line-height:1;opacity:.7;transition:opacity .2s}.error-message .btn-close:hover{opacity:1}.switch-role-form .form-row{display:flex;gap:20px;align-items:flex-end}.switch-role-form .form-group{flex:1;position:relative}.switch-role-form label{display:block;font-weight:600;margin-bottom:10px;color:var(--dark-bg);font-size:14px}.switch-role-form input{width:100%;padding:14px 16px;border:2px solid #e1e5eb;border-radius:12px;font-size:15px;outline:none;transition:all .2s;background:#f8fafc}.switch-role-form input:focus{border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a}.switch-role-form input:disabled{background:#f1f5f9;cursor:not-allowed;opacity:.7}.switch-role-form input::placeholder{color:#a0aec0}.char-count{position:absolute;right:16px;bottom:14px;font-size:12px;color:#a0aec0;font-weight:500}.btn{padding:14px 28px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;gap:10px;white-space:nowrap}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 15px #667eea66}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{background:#cbd5e0;box-shadow:none;cursor:not-allowed}.btn-secondary{background:#f1f5f9;color:var(--dark-bg);border:2px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background:#e2e8f0;border-color:#cbd5e0}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.resources-ready,.resources-prompt{padding:32px;text-align:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px;border:2px dashed #e2e8f0}.resources-ready p,.resources-prompt p{margin-bottom:16px;color:#64748b;font-size:15px}.resources-ready strong{color:var(--dark-bg);font-weight:700}.resources-ready .hint{font-size:13px;color:#94a3b8}@media (max-width: 768px){.dashboard-header{flex-direction:column;gap:16px;align-items:flex-start;padding:16px 20px}.context-bar{flex-direction:column;gap:12px;padding:16px 20px}.context-item.target{padding-left:0;border-left:none;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.dashboard-content{padding:20px}.switch-role-form .form-row{flex-direction:column}.switch-role-form .btn{width:100%;justify-content:center}.action-cards{grid-template-columns:1fr}}:root{--sidebar-width: 280px;--sidebar-collapsed-width: 60px;--header-height: 64px;--primary-color: #6366f1;--primary-hover: #4f46e5;--danger-color: #ef4444;--danger-hover: #dc2626;--success-color: #10b981;--warning-color: #f59e0b;--bg-dark: #0f172a;--bg-sidebar: #1e293b;--bg-main: #f1f5f9;--bg-card: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--text-light: #94a3b8;--border-color: #e2e8f0;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--transition: all .2s ease}.resource-page{min-height:100vh;background:var(--bg-main);display:flex;flex-direction:column}.resource-header{height:var(--header-height);background:var(--bg-dark);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-md)}.resource-header .header-left{display:flex;align-items:center;gap:24px}.resource-header .back-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:#fff;font-size:14px;cursor:pointer;transition:var(--transition)}.resource-header .back-btn:hover{background:#ffffff26;border-color:#fff3}.resource-header .back-icon{font-size:18px}.resource-header .header-title{display:flex;align-items:center;gap:16px}.resource-header .header-title h1{margin:0;font-size:20px;font-weight:600;color:#fff}.resource-header .account-badge{display:flex;align-items:center;gap:8px}.resource-header .account-id{font-family:SF Mono,Monaco,Consolas,monospace;font-size:13px;color:#94a3b8;background:#ffffff0d;padding:4px 10px;border-radius:var(--radius-sm)}.resource-header .account-type{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:4px 10px;border-radius:20px}.resource-header .account-type.payer{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.resource-header .account-type.target{background:linear-gradient(135deg,#10b981,#34d399);color:#fff}.resource-header .header-right{display:flex;align-items:center;gap:16px}.resource-header .session-indicator{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#10b98126;border-radius:var(--radius-md);color:#10b981;font-size:14px;font-weight:600}.resource-header .session-indicator.warning{background:#f59e0b26;color:#f59e0b;animation:pulse 2s infinite}.resource-header .session-icon{font-size:16px}.resource-header .session-time{font-family:SF Mono,Monaco,monospace}.resource-header .logout-btn{padding:8px 16px;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:#fff;font-size:14px;cursor:pointer;transition:var(--transition)}.resource-header .logout-btn:hover{background:#ef444433;border-color:#ef444466;color:#fca5a5}.resource-layout{display:flex;flex:1;overflow:hidden}.resource-sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);display:flex;flex-direction:column;transition:width .3s ease;overflow:hidden}.resource-sidebar.collapsed{width:var(--sidebar-collapsed-width)}.resource-sidebar .sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.05)}.resource-sidebar .sidebar-header h2{margin:0;font-size:14px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.resource-sidebar.collapsed .sidebar-header h2{display:none}.resource-sidebar .collapse-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:none;border-radius:var(--radius-sm);color:#94a3b8;cursor:pointer;transition:var(--transition)}.resource-sidebar .collapse-btn:hover{background:#ffffff1a;color:#fff}.resource-sidebar .sidebar-loading{display:flex;align-items:center;justify-content:center;padding:40px}.category-nav{flex:1;overflow-y:auto;padding:12px 8px}.category-nav::-webkit-scrollbar{width:6px}.category-nav::-webkit-scrollbar-track{background:transparent}.category-nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.category-section{margin-bottom:4px}.category-header{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);color:#cbd5e1}.category-header:hover{background:#ffffff0d}.category-header.active{background:#6366f126;color:#a5b4fc}.category-icon{font-size:20px;flex-shrink:0}.category-name{flex:1;font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-count{font-size:12px;color:#64748b;background:#ffffff0d;padding:2px 8px;border-radius:10px}.expand-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#64748b;font-size:10px;cursor:pointer;transition:transform .2s}.expand-btn.collapsed{transform:rotate(-90deg)}.resource-type-list{padding:4px 0 8px 44px}.resource-type-item{padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);color:#94a3b8;font-size:13px;margin-bottom:2px}.resource-type-item:hover{background:#ffffff0d;color:#cbd5e1}.resource-type-item.active{background:var(--primary-color);color:#fff}.type-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.resource-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.region-bar{display:flex;align-items:center;gap:20px;padding:16px 24px;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.region-select-group{display:flex;align-items:center;gap:10px}.region-select-group label{font-size:14px;font-weight:500;color:var(--text-secondary)}.region-select{padding:10px 14px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;background:var(--bg-card);min-width:260px;cursor:pointer;transition:var(--transition)}.region-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.region-select:disabled{background:#f8fafc;color:var(--text-light);cursor:not-allowed}.scan-all-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.scan-all-toggle input{display:none}.toggle-slider{width:44px;height:24px;background:#cbd5e1;border-radius:12px;position:relative;transition:var(--transition)}.toggle-slider:after{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:2px;left:2px;transition:var(--transition);box-shadow:var(--shadow-sm)}.scan-all-toggle input:checked+.toggle-slider{background:var(--primary-color)}.scan-all-toggle input:checked+.toggle-slider:after{transform:translate(20px)}.toggle-label{font-size:14px;font-weight:500;color:var(--text-secondary)}.refresh-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);cursor:pointer;transition:var(--transition);margin-left:auto}.refresh-btn:hover:not(:disabled){border-color:var(--primary-color);color:var(--primary-color)}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.refresh-icon{font-size:16px;transition:transform .3s}.refresh-icon.spinning{animation:spin 1s linear infinite}.error-alert{display:flex;align-items:center;gap:12px;padding:14px 24px;background:linear-gradient(135deg,#fef2f2,#fee2e2);border-bottom:1px solid #fecaca;color:#dc2626}.error-icon{font-size:18px}.error-text{flex:1;font-size:14px;font-weight:500}.error-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:20px;color:inherit;cursor:pointer;opacity:.7;transition:opacity .2s}.error-close:hover{opacity:1}.content-area{flex:1;overflow-y:auto;padding:24px}.welcome-panel{text-align:center;padding:60px 40px;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.welcome-icon{font-size:64px;margin-bottom:20px}.welcome-panel h2{margin:0 0 12px;font-size:24px;font-weight:600;color:var(--text-primary)}.welcome-panel>p{margin:0 0 32px;font-size:15px;color:var(--text-secondary)}.quick-select{max-width:600px;margin:0 auto;text-align:left}.quick-select h3{margin:0 0 16px;font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.quick-select-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.quick-select-btn{padding:14px 16px;background:#f8fafc;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);cursor:pointer;transition:var(--transition);text-align:center}.quick-select-btn:hover{border-color:var(--primary-color);background:#f0f4ff;color:var(--primary-color)}.resource-panel{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.panel-title{display:flex;align-items:center;gap:12px}.panel-title h2{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.resource-count{font-size:13px;color:var(--text-light);background:#f1f5f9;padding:4px 12px;border-radius:20px}.loading-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;color:var(--text-secondary)}.loading-panel p{margin:16px 0 0;font-size:14px}.empty-panel{text-align:center;padding:80px 40px}.empty-icon{font-size:48px;margin-bottom:16px}.empty-panel h3{margin:0 0 8px;font-size:18px;font-weight:600;color:var(--text-primary)}.empty-panel p{margin:0;font-size:14px;color:var(--text-secondary)}.resource-table-container{overflow-x:auto}.resource-table{width:100%;border-collapse:collapse}.resource-table th,.resource-table td{padding:14px 20px;text-align:left;border-bottom:1px solid var(--border-color)}.resource-table th{background:#f8fafc;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.resource-table tbody tr{transition:background .15s}.resource-table tbody tr:hover{background:#f8fafc}.resource-table tbody tr:last-child td{border-bottom:none}.cell-name .resource-name{font-weight:500;color:var(--text-primary);margin-bottom:2px}.cell-name .resource-id{font-size:12px;color:var(--text-light);font-family:SF Mono,Monaco,monospace}.cell-region,.cell-date{font-size:13px;color:var(--text-secondary)}.status-pill{display:inline-block;padding:5px 12px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.status-pill.status-running,.status-pill.status-available,.status-pill.status-active{background:#d1fae5;color:#065f46}.status-pill.status-stopped,.status-pill.status-inactive{background:#fef3c7;color:#92400e}.status-pill.status-terminated,.status-pill.status-deleted{background:#fee2e2;color:#991b1b}.status-pill.status-pending,.status-pill.status-creating{background:#e0e7ff;color:#3730a3}.status-pill.status-unknown{background:#f1f5f9;color:#64748b}.action-btn{padding:6px 14px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:var(--transition);border:none}.action-btn.danger{background:#fef2f2;color:var(--danger-color);border:1px solid #fecaca}.action-btn.danger:hover{background:var(--danger-color);color:#fff;border-color:var(--danger-color)}.loading-spinner-small{width:24px;height:24px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner-medium{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner-large{width:56px;height:56px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.loading-fullscreen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:var(--text-secondary)}.loading-fullscreen p{margin:20px 0 0;font-size:15px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-dialog{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.modal-body{padding:20px 24px}.modal-body>p{margin:0 0 20px;font-size:14px;color:var(--text-secondary);line-height:1.5}.resource-details{background:#f8fafc;border-radius:var(--radius-md);padding:16px;border:1px solid var(--border-color)}.detail-row{display:flex;margin-bottom:10px}.detail-row:last-child{margin-bottom:0}.detail-label{width:70px;font-size:13px;color:var(--text-secondary);font-weight:500}.detail-value{flex:1;font-size:13px;color:var(--text-primary)}.detail-value.code{font-family:SF Mono,Monaco,monospace;font-size:12px}.modal-error{margin-top:16px;padding:12px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);color:var(--danger-color);font-size:13px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border-color);background:#f8fafc;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.modal-btn{padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);border:none}.modal-btn.secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.modal-btn.secondary:hover:not(:disabled){background:#f1f5f9}.modal-btn.danger{background:var(--danger-color);color:#fff}.modal-btn.danger:hover:not(:disabled){background:var(--danger-hover)}.modal-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 1024px){.resource-sidebar{width:var(--sidebar-collapsed-width)}.resource-sidebar .sidebar-header h2,.resource-sidebar .category-name,.resource-sidebar .category-count,.resource-sidebar .expand-btn,.resource-sidebar .resource-type-list{display:none}.category-header{justify-content:center;padding:14px}.category-icon{font-size:22px}}@media (max-width: 768px){.resource-header{height:auto;flex-wrap:wrap;gap:12px;padding:12px 16px}.resource-header .header-left{flex-wrap:wrap;gap:12px}.resource-header .header-title{flex-direction:column;align-items:flex-start;gap:8px}.region-bar{flex-wrap:wrap;gap:12px;padding:12px 16px}.region-select{min-width:100%}.content-area{padding:16px}.quick-select-grid{grid-template-columns:repeat(2,1fr)}.resource-table{font-size:13px}.resource-table th,.resource-table td{padding:12px 14px}}:root{--color-primary: #0073bb;--color-primary-hover: #005a92;--color-primary-light: rgba(0, 115, 187, .1);--color-success: #1d8102;--color-warning: #ff9900;--color-error: #d13212;--color-gray-50: #fafafa;--color-gray-100: #f2f3f3;--color-gray-200: #e9ebed;--color-gray-300: #d5dbdb;--color-gray-400: #aab7b8;--color-gray-500: #879596;--color-gray-600: #687078;--color-gray-700: #545b64;--color-gray-800: #232f3e;--color-gray-900: #16191f;--color-white: #ffffff;--color-background: var(--color-gray-100);--color-surface: var(--color-white);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--font-mono: "SF Mono", "Monaco", "Inconsolata", "Fira Mono", "Droid Sans Mono", monospace;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .15);--header-height: 56px;--sidebar-width: 260px;--sidebar-collapsed-width: 60px;--task-panel-width: 320px}@media (prefers-color-scheme: dark){:root{--color-gray-50: #0d1117;--color-gray-100: #161b22;--color-gray-200: #21262d;--color-gray-300: #30363d;--color-gray-400: #484f58;--color-gray-500: #6e7681;--color-gray-600: #8b949e;--color-gray-700: #b1bac4;--color-gray-800: #c9d1d9;--color-gray-900: #f0f6fc;--color-white: #0d1117;--color-background: var(--color-gray-100);--color-surface: var(--color-gray-200);--color-primary: #58a6ff;--color-primary-hover: #79b8ff;--color-primary-light: rgba(88, 166, 255, .15);--color-success: #3fb950;--color-warning: #d29922;--color-error: #f85149}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:14px;line-height:1.5;color:var(--color-gray-900);background-color:var(--color-background)}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-gray-900)}h1{font-size:24px}h2{font-size:20px}h3{font-size:16px}h4{font-size:14px}p{margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}code,pre{font-family:var(--font-mono);font-size:13px}code{background-color:var(--color-gray-100);padding:2px 6px;border-radius:var(--radius-sm)}pre{background-color:var(--color-gray-100);padding:var(--spacing-md);border-radius:var(--radius-md);overflow-x:auto}.app-layout{display:flex;flex-direction:column;min-height:100vh}.main-content{display:flex;flex:1;overflow:hidden}.content-area{flex:1;overflow:auto;padding:var(--spacing-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:8px 16px;font-size:13px;font-weight:500;line-height:1;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:4px 10px;font-size:12px}.btn-lg{padding:12px 24px;font-size:14px}.btn-primary{background-color:var(--color-primary);color:var(--color-white)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-secondary{background-color:var(--color-gray-200);color:var(--color-gray-900)}.btn-secondary:hover:not(:disabled){background-color:var(--color-gray-300)}.btn-danger{background-color:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#b82a0e}.btn-warning{background-color:var(--color-warning);color:var(--color-gray-900)}.btn-warning:hover:not(:disabled){background-color:#e68a00}.btn-ghost{background-color:transparent;color:var(--color-gray-600)}.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100);color:var(--color-gray-900)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],select,textarea{width:100%;padding:8px 12px;font-size:14px;font-family:inherit;color:var(--color-gray-900);background-color:var(--color-surface);border:1px solid var(--color-gray-300);border-radius:var(--radius-sm);transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}input:disabled,select:disabled,textarea:disabled{background-color:var(--color-gray-100);cursor:not-allowed}input[type=checkbox],input[type=radio]{width:16px;height:16px;cursor:pointer}label{display:block;margin-bottom:var(--spacing-xs);font-size:13px;font-weight:500;color:var(--color-gray-700)}.form-group{margin-bottom:var(--spacing-md)}.form-row{display:flex;gap:var(--spacing-md);align-items:flex-end}table{width:100%;border-collapse:collapse;font-size:13px}th,td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--color-gray-200)}th{font-weight:600;color:var(--color-gray-600);background-color:var(--color-gray-100);position:sticky;top:0;z-index:1}tbody tr:hover{background-color:var(--color-gray-50)}tbody tr.selected{background-color:var(--color-primary-light)}.status-badge{display:inline-block;padding:3px 8px;font-size:11px;font-weight:500;border-radius:var(--radius-full);text-transform:capitalize}.status-running,.status-available,.status-active{background-color:#1d810226;color:var(--color-success)}.status-pending,.status-creating,.status-modifying{background-color:#ff990026;color:var(--color-warning)}.status-stopped,.status-stopping,.status-terminated{background-color:var(--color-gray-200);color:var(--color-gray-600)}.status-error,.status-failed,.status-deleting{background-color:#d1321226;color:var(--color-error)}.loading-spinner{width:20px;height:20px;border:2px solid var(--color-gray-300);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner-sm{width:14px;height:14px}.loading-spinner-lg{width:32px;height:32px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md);color:var(--color-gray-600)}.error-banner{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:#d132121a;border:1px solid var(--color-error);border-radius:var(--radius-sm);color:var(--color-error);font-size:13px}.error-message{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:#d132121a;border-radius:var(--radius-sm);color:var(--color-error);font-size:13px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--color-gray-600);text-align:center}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-gray-600)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.font-mono{font-family:var(--font-mono)}.font-bold{font-weight:600}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}@media (max-width: 1280px){:root{--sidebar-width: 200px;--task-panel-width: 280px}.hide-on-small{display:none}}@media (max-width: 1024px){.sidebar{position:fixed;left:0;top:var(--header-height);bottom:0;z-index:50;transform:translate(-100%);transition:transform .2s}.sidebar.open{transform:translate(0)}.task-panel{position:fixed;right:0;top:var(--header-height);bottom:0;z-index:50;transform:translate(100%);transition:transform .2s}.task-panel.open{transform:translate(0)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:var(--color-gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background-color:var(--color-gray-400)}*{scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.animate-fade-in{animation:fadeIn .2s ease-out}.animate-slide-in{animation:slideIn .2s ease-out}.animate-pulse{animation:pulse 1s ease-in-out infinite}
