:root{--color-primary: #2563EB;--color-primary-hover: #1D4ED8;--color-primary-light: #DBEAFE;--color-white: #FFFFFF;--color-gray-50: #F9FAFB;--color-gray-100: #F3F4F6;--color-gray-200: #E5E7EB;--color-gray-300: #D1D5DB;--color-gray-400: #9CA3AF;--color-gray-500: #6B7280;--color-gray-600: #4B5563;--color-gray-700: #374151;--color-gray-800: #1F2937;--color-gray-900: #111827;--color-success: #10B981;--color-success-light: #D1FAE5;--color-warning: #F59E0B;--color-warning-light: #FEF3C7;--color-danger: #EF4444;--color-info: #3B82F6;--color-dark-bg: #1E293B;--color-dark-bg-secondary: #0F172A;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--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);--transition-fast: .15s ease-in-out;--transition-base: .2s ease-in-out;--transition-slow: .3s ease-in-out;--sidebar-width: 240px;--header-height: 64px}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.5;color:var(--color-gray-900);background-color:var(--color-gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:1.2;color:var(--color-gray-900)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--spacing-4)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}.app-container{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);background-color:var(--color-gray-50);transition:margin-left var(--transition-base)}.content-wrapper{padding:var(--spacing-8);max-width:1400px;margin:0 auto}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width);height:100vh;background-color:var(--color-white);border-right:1px solid var(--color-gray-200);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition-base)}.sidebar-header{padding:var(--spacing-6);border-bottom:1px solid var(--color-gray-200)}.logo{display:flex;align-items:center;gap:var(--spacing-3)}.logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary),#3B82F6);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-white);font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.logo-text{display:flex;flex-direction:column}.logo-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-gray-900);line-height:1}.logo-subtitle{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:2px}.sidebar-nav{flex:1;padding:var(--spacing-4);overflow-y:auto}.nav-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);margin-bottom:var(--spacing-2);border-radius:var(--radius-md);color:var(--color-gray-700);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.nav-item:hover{background-color:var(--color-gray-100);color:var(--color-gray-900)}.nav-item.active{background-color:var(--color-primary-light);color:var(--color-primary)}.nav-item-icon{font-size:var(--font-size-lg)}.sidebar-footer{padding:var(--spacing-4);border-top:1px solid var(--color-gray-200)}.user-profile{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background-color:var(--color-gray-50);border-radius:var(--radius-md);margin-bottom:var(--spacing-3);min-width:0}.user-profile:hover{background-color:var(--color-gray-100)}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:var(--color-white);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);flex-shrink:0}.user-info{flex:1;min-width:0;overflow:hidden}.user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:var(--font-size-xs);color:var(--color-gray-600);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-6);border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:var(--color-white);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px);color:#fff}.btn-secondary{background-color:var(--color-white);color:var(--color-gray-700);border:1px solid var(--color-gray-300)}.btn-secondary:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-gray-400)}.btn-icon{padding:var(--spacing-2);width:36px;height:36px}.btn-sm{padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-sm)}.form-group{margin-bottom:var(--spacing-6)}.form-label{display:block;margin-bottom:var(--spacing-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.form-input{width:100%;padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-gray-900);background-color:var(--color-white);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-input::placeholder{color:var(--color-gray-400)}.form-input.error{border-color:var(--color-danger)}.form-helper{margin-top:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-gray-500)}.form-error{margin-top:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-danger)}.input-group{position:relative}.input-icon{position:absolute;right:var(--spacing-4);top:50%;transform:translateY(-50%);color:var(--color-gray-400);cursor:pointer;transition:color var(--transition-fast)}.input-icon:hover{color:var(--color-gray-600)}.checkbox-wrapper{display:flex;align-items:flex-start;gap:var(--spacing-3)}.checkbox{width:18px;height:18px;margin-top:2px;cursor:pointer;accent-color:var(--color-primary)}.checkbox-label{font-size:var(--font-size-sm);color:var(--color-gray-700);cursor:pointer;-webkit-user-select:none;user-select:none}.card{background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200);transition:box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md)}.card-header{padding:var(--spacing-6);border-bottom:1px solid var(--color-gray-200)}.card-body{padding:var(--spacing-6)}.card-footer{padding:var(--spacing-6);border-top:1px solid var(--color-gray-200);background-color:var(--color-gray-50);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-6);margin-bottom:var(--spacing-8)}.stat-card{background-color:var(--color-white);border-radius:var(--radius-lg);padding:var(--spacing-6);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200);transition:all var(--transition-fast)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-4)}.stat-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-600)}.stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl)}.stat-icon.primary{background-color:var(--color-primary-light);color:var(--color-primary)}.stat-icon.success{background-color:var(--color-success-light);color:var(--color-success)}.stat-icon.warning{background-color:var(--color-warning-light);color:var(--color-warning)}.stat-value{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);line-height:1}.table-container{background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200);overflow:hidden}.table{width:100%;border-collapse:collapse}.table thead{background-color:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200)}.table th{padding:var(--spacing-4) var(--spacing-6);text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-gray-600);text-transform:uppercase;letter-spacing:.05em}.table td{padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--color-gray-200);font-size:var(--font-size-sm);color:var(--color-gray-700)}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--color-gray-50)}.table tbody tr:last-child td{border-bottom:none}.table-app-name{display:flex;align-items:center;gap:var(--spacing-3)}.table-app-icon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);color:var(--color-white)}.table-app-icon.blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.table-app-icon.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.table-app-icon.green{background:linear-gradient(135deg,#10b981,#059669)}.table-app-icon.orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.table-actions{display:flex;gap:var(--spacing-2)}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4);gap:var(--spacing-4)}.table-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin:0;padding:0;line-height:1.5}.table-count{font-size:var(--font-size-sm);color:var(--color-gray-600);font-weight:var(--font-weight-medium);line-height:1.5;white-space:nowrap;padding:0;margin:0}.table-pagination{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-gray-200);background-color:var(--color-gray-50)}.pagination-info{font-size:var(--font-size-sm);color:var(--color-gray-600)}.pagination-buttons{display:flex;gap:var(--spacing-2)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:capitalize}.badge.success{background-color:var(--color-success-light);color:#065f46}.badge.warning{background-color:var(--color-warning-light);color:#92400e}.badge.danger{background-color:#fee2e2;color:#991b1b}.alert{display:flex;gap:var(--spacing-4);padding:var(--spacing-4) var(--spacing-6);border-radius:var(--radius-lg);margin-bottom:var(--spacing-6)}.alert-icon{flex-shrink:0;width:20px;height:20px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm)}.alert-content{flex:1}.alert-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-1)}.alert-message{font-size:var(--font-size-sm);line-height:1.5}.alert.warning{background-color:var(--color-warning-light);border:1px solid #FCD34D}.alert.warning .alert-icon{background-color:var(--color-warning);color:var(--color-white)}.alert.warning .alert-title{color:#92400e}.alert.warning .alert-message{color:#78350f}.tag-input-wrapper{display:flex;flex-wrap:wrap;gap:var(--spacing-2);padding:var(--spacing-2);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);background-color:var(--color-white);transition:all var(--transition-fast)}.tag-input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.tag{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-1) var(--spacing-3);background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.tag-remove{cursor:pointer;display:flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:var(--radius-full);transition:background-color var(--transition-fast)}.tag-remove:hover{background-color:var(--color-primary);color:var(--color-white)}.tag-input{flex:1;min-width:150px;border:none;outline:none;padding:var(--spacing-2);font-family:var(--font-family);font-size:var(--font-size-sm)}.page-header{margin-bottom:var(--spacing-8)}.page-header-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2)}.page-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin:0}.page-description{font-size:var(--font-size-base);color:var(--color-gray-600);margin:0}.breadcrumb{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-4);font-size:var(--font-size-sm)}.breadcrumb-item{color:var(--color-gray-500)}.breadcrumb-item.active{color:var(--color-gray-900);font-weight:var(--font-weight-medium)}.breadcrumb-separator{color:var(--color-gray-400)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-gray-50) 0%,var(--color-gray-100) 100%);padding:var(--spacing-8)}.auth-card{width:100%;max-width:440px;background-color:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--spacing-10)}.auth-header{text-align:center;margin-bottom:var(--spacing-8)}.auth-logo{width:48px;height:48px;margin:0 auto var(--spacing-4);background:linear-gradient(135deg,var(--color-primary),#3B82F6);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--color-white);font-weight:var(--font-weight-bold);font-size:var(--font-size-2xl)}.auth-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--spacing-2)}.auth-subtitle{font-size:var(--font-size-base);color:var(--color-gray-600);line-height:1.5}.auth-footer{margin-top:var(--spacing-8);padding-top:var(--spacing-6);border-top:1px solid var(--color-gray-200);text-align:center}.auth-links{display:flex;justify-content:center;gap:var(--spacing-6);margin-bottom:var(--spacing-4)}.auth-link{font-size:var(--font-size-sm);color:var(--color-gray-600)}.auth-copyright{font-size:var(--font-size-xs);color:var(--color-gray-500)}.auth-top-link{text-align:right;margin-bottom:var(--spacing-6);font-size:var(--font-size-sm)}.help-card{background:linear-gradient(135deg,var(--color-dark-bg-secondary),var(--color-dark-bg));border-radius:var(--radius-lg);padding:var(--spacing-8);color:var(--color-white);margin-top:var(--spacing-8)}.help-card-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-3);color:var(--color-white)}.help-card-description{font-size:var(--font-size-base);color:var(--color-gray-300);margin-bottom:var(--spacing-6);line-height:1.6}.help-card .btn{background-color:var(--color-white);color:var(--color-gray-900)}.help-card .btn:hover{background-color:var(--color-gray-100)}.screen{display:none}.screen.active{display:block}.auth-screen.active{display:flex}@media(max-width:768px){:root{--sidebar-width: 0px}.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.main-content{margin-left:0}.content-wrapper{padding:var(--spacing-4)}.page-header-top{flex-direction:column;gap:var(--spacing-4)}.stats-grid{grid-template-columns:1fr}.table-container{overflow-x:auto}.auth-card{padding:var(--spacing-6)}}.hidden{display:none!important}.text-center{text-align:center}.mt-4{margin-top:var(--spacing-4)}.mb-4{margin-bottom:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mb-6{margin-bottom:var(--spacing-6)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-base) ease-out}.doc-tabs{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-6);border-bottom:2px solid var(--color-gray-200);padding-bottom:0}.doc-tab{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-5);background:transparent;border:none;border-bottom:3px solid transparent;color:var(--color-gray-600);font-weight:var(--font-weight-medium);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-fast);margin-bottom:-2px;position:relative}.doc-tab:hover{color:var(--color-primary);background-color:var(--color-gray-50)}.doc-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:var(--font-weight-semibold)}.doc-container{background-color:var(--color-white);border-radius:var(--radius-lg);padding:var(--spacing-8);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200)}.doc-content{max-width:900px}.doc-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--spacing-6)}.doc-section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--spacing-4);margin-top:var(--spacing-2);padding-bottom:var(--spacing-2);border-bottom:2px solid var(--color-gray-200)}.doc-list{list-style:none;padding-left:var(--spacing-6);margin:var(--spacing-4) 0}.doc-list-item{position:relative;padding:var(--spacing-2) 0 var(--spacing-2) var(--spacing-6);margin-bottom:var(--spacing-2);font-size:var(--font-size-base);color:var(--color-gray-700);line-height:1.7}.doc-list-item:before{content:"•";position:absolute;left:0;color:var(--color-primary);font-weight:700;font-size:1.2em}.code-block{margin:var(--spacing-4) 0;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-gray-200)}.code-header{background-color:var(--color-gray-800);padding:var(--spacing-3) var(--spacing-4);display:flex;justify-content:space-between;align-items:center}.code-language{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-gray-300);text-transform:uppercase;letter-spacing:.05em}.code-content{background-color:var(--color-gray-900);padding:var(--spacing-6);overflow-x:auto;margin:0}.code-content code{font-family:Courier New,monospace;font-size:var(--font-size-sm);color:#e5e7eb;line-height:1.6}.api-base-url{padding:var(--spacing-4);background-color:var(--color-gray-50);border-radius:var(--radius-md);margin-bottom:var(--spacing-6);font-size:var(--font-size-sm)}.api-base-url code{background-color:var(--color-white);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-family:Courier New,monospace;color:var(--color-primary)}.api-endpoint{padding:var(--spacing-6);margin-bottom:var(--spacing-6);background-color:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200)}.api-endpoint-header{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-3);flex-wrap:wrap}.api-method{padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em}.api-method.get{background-color:#dbeafe;color:#1e40af}.api-method.post{background-color:#d1fae5;color:#065f46}.api-method.put{background-color:#fef3c7;color:#92400e}.api-method.delete{background-color:#fee2e2;color:#991b1b}.api-path{font-family:Courier New,monospace;font-size:var(--font-size-sm);color:var(--color-gray-700);background-color:var(--color-white);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm)}.api-auth-badge{padding:var(--spacing-1) var(--spacing-2);background-color:var(--color-warning-light);color:#92400e;border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.api-description{color:var(--color-gray-700);margin-bottom:var(--spacing-4);font-size:var(--font-size-base)}.api-params{margin-top:var(--spacing-4)}.api-params strong{display:block;margin-bottom:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-gray-900)}.api-code{background-color:var(--color-gray-900);padding:var(--spacing-4);border-radius:var(--radius-md);overflow-x:auto;margin:0}.api-code code{font-family:Courier New,monospace;font-size:var(--font-size-sm);color:#e5e7eb;line-height:1.6}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background-color:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:var(--spacing-6);border-bottom:1px solid var(--color-gray-200);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin:0}.modal-close{background:none;border:none;font-size:var(--font-size-2xl);color:var(--color-gray-400);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--color-gray-100);color:var(--color-gray-600)}.modal-body{padding:var(--spacing-6)}.modal-footer{padding:var(--spacing-6);border-top:1px solid var(--color-gray-200);display:flex;justify-content:flex-end;gap:var(--spacing-3)}.browse-apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-6);margin-bottom:var(--spacing-8)}.browse-app-card{background-color:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);display:flex;flex-direction:column}.browse-app-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.browse-app-header{padding:var(--spacing-6);border-bottom:1px solid var(--color-gray-200);display:flex;gap:var(--spacing-4);align-items:flex-start}.browse-app-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl);flex-shrink:0}.browse-app-icon.blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.browse-app-icon.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.browse-app-icon.green{background:linear-gradient(135deg,#10b981,#059669)}.browse-app-icon.orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.browse-app-info{flex:1;min-width:0}.browse-app-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--spacing-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.browse-app-owner{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:0;display:flex;align-items:center;gap:var(--spacing-2)}.browse-app-body{padding:var(--spacing-6);flex:1;display:flex;flex-direction:column;gap:var(--spacing-4)}.browse-app-detail{display:flex;flex-direction:column;gap:var(--spacing-1)}.detail-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-gray-600);text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:var(--font-size-sm);color:var(--color-gray-700);word-break:break-all}.browse-app-roles{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.browse-app-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-gray-200);background-color:var(--color-gray-50);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-3);max-width:400px}.toast{background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-4);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3);border-left:4px solid;animation:slideInRight .3s ease-out;min-width:300px}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left-color:var(--color-success)}.toast-error{border-left-color:var(--color-danger)}.toast-warning{border-left-color:var(--color-warning)}.toast-info{border-left-color:var(--color-primary)}.toast-content{display:flex;align-items:center;gap:var(--spacing-3);flex:1}.toast-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);flex-shrink:0}.toast-success .toast-icon{background-color:var(--color-success-light);color:var(--color-success)}.toast-error .toast-icon{background-color:var(--color-danger-light);color:var(--color-danger)}.toast-warning .toast-icon{background-color:var(--color-warning-light);color:var(--color-warning)}.toast-info .toast-icon{background-color:var(--color-primary-light);color:var(--color-primary)}.toast-message{font-size:var(--font-size-sm);color:var(--color-gray-700);line-height:1.5}.toast-close{background:none;border:none;font-size:var(--font-size-2xl);color:var(--color-gray-400);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast);flex-shrink:0}.toast-close:hover{background-color:var(--color-gray-100);color:var(--color-gray-600)}.credentials-modal{max-width:600px}.credentials-section{display:flex;flex-direction:column;gap:var(--spacing-6);margin-bottom:var(--spacing-6)}.credential-item{display:flex;flex-direction:column;gap:var(--spacing-2)}.credential-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);text-transform:uppercase;letter-spacing:.05em}.credential-value-container{display:flex;gap:var(--spacing-2);align-items:center}.credential-value{flex:1;padding:var(--spacing-3) var(--spacing-4);background-color:var(--color-gray-900);color:#e5e7eb;border-radius:var(--radius-md);font-family:Courier New,monospace;font-size:var(--font-size-sm);word-break:break-all;border:1px solid var(--color-gray-700)}.credential-value.secret{background:linear-gradient(135deg,#1f2937,#111827);border-color:var(--color-warning)}.copy-success{font-size:var(--font-size-xs);color:var(--color-success);font-weight:var(--font-weight-semibold);animation:fadeIn .2s ease-in}.credentials-info{padding:var(--spacing-4);background-color:var(--color-gray-50);border-radius:var(--radius-md);border:1px solid var(--color-gray-200)}.credentials-info p{margin:var(--spacing-2) 0;font-size:var(--font-size-sm);color:var(--color-gray-700)}.credentials-info strong{color:var(--color-gray-900);margin-right:var(--spacing-2)}.oauth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-gray-100);padding:var(--spacing-6)}.oauth-card{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:420px;width:100%;overflow:hidden}.oauth-header{text-align:center;padding:var(--spacing-8) var(--spacing-6) var(--spacing-6);background:var(--color-white);border-bottom:1px solid var(--color-gray-100)}.oauth-error .oauth-card{background:var(--color-white);border:1px solid var(--color-gray-200);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.oauth-icon-wrapper{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:var(--radius-xl);color:var(--color-white);margin-bottom:var(--spacing-4)}.oauth-header h1{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--spacing-3)}.oauth-app-info{margin-top:var(--spacing-4);padding:var(--spacing-3);background-color:var(--color-gray-50);border-radius:var(--radius-md)}.oauth-app-label{font-size:var(--font-size-xs);color:var(--color-gray-600);margin:0 0 var(--spacing-1);text-transform:uppercase;font-weight:var(--font-weight-semibold);letter-spacing:.5px}.oauth-app-name{font-size:var(--font-size-base);color:var(--color-gray-900);font-weight:var(--font-weight-semibold);margin:0}.oauth-app-info-text{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:0}.oauth-form{padding:var(--spacing-6)}.oauth-submit-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-2)}.btn-spinner{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.oauth-footer{padding:var(--spacing-5) var(--spacing-6);background-color:var(--color-gray-50);border-top:1px solid var(--color-gray-100);text-align:center}.oauth-footer-text{margin:0;font-size:var(--font-size-sm);color:var(--color-gray-600)}.oauth-link{color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-semibold);transition:color var(--transition-fast)}.oauth-link:hover{color:var(--color-primary-dark);text-decoration:underline}.oauth-consent-notice{margin-top:var(--spacing-4);padding:var(--spacing-3);background-color:#eef2ff;border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.oauth-consent-notice p{font-size:var(--font-size-xs);color:var(--color-gray-700);margin:0;line-height:1.5}.oauth-loader{padding:var(--spacing-10) var(--spacing-6);text-align:center}.oauth-spinner{color:var(--color-primary);animation:spin 1s linear infinite;margin:0 auto var(--spacing-4)}.oauth-loader p{color:var(--color-gray-600);font-size:var(--font-size-sm);margin:0}.oauth-error{padding:var(--spacing-8) var(--spacing-6);text-align:center}.error-icon-svg{color:var(--color-danger);margin:0 auto var(--spacing-4)}.oauth-error h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-danger);margin-bottom:var(--spacing-3)}.oauth-error .error-message{font-size:var(--font-size-base);color:var(--color-gray-700);margin-bottom:var(--spacing-6)}.error-details{background-color:var(--color-gray-50);border-radius:var(--radius-md);padding:var(--spacing-4);text-align:left;margin-top:var(--spacing-4);border:1px solid var(--color-gray-200)}.error-details p{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin-bottom:var(--spacing-2)}.error-details ul{list-style:disc;padding-left:var(--spacing-5);margin:0}.error-details li{font-size:var(--font-size-sm);color:var(--color-gray-600);margin-bottom:var(--spacing-1)}.doc-tabs{display:flex;gap:var(--spacing-2);border-bottom:2px solid var(--color-gray-200);margin-bottom:var(--spacing-6);flex-wrap:wrap}.doc-tab{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-500);transition:color .15s,border-color .15s}.doc-tab:hover{color:var(--color-primary)}.doc-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.doc-container{max-width:720px}.doc-content{padding-bottom:var(--spacing-10)}.doc-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--spacing-3)}.doc-intro{font-size:var(--font-size-base);color:var(--color-gray-600);line-height:1.7;margin-bottom:var(--spacing-8)}.doc-section{margin-bottom:var(--spacing-8)}.doc-section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-2);border-bottom:1px solid var(--color-gray-100)}.doc-steps-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-3);counter-reset:step-counter}.doc-step-item{display:flex;align-items:flex-start;gap:var(--spacing-3);font-size:var(--font-size-base);color:var(--color-gray-700);line-height:1.6;counter-increment:step-counter}.doc-step-item:before{content:counter(step-counter);display:flex;align-items:center;justify-content:center;min-width:26px;height:26px;background-color:var(--color-primary-light);color:var(--color-primary);border-radius:50%;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);margin-top:2px;flex-shrink:0}
