.admin-layout{display:flex;min-height:100vh;background:var(--bg-primary);transition:background .3s ease}.admin-sidebar{width:260px;background-color:var(--sidebar-bg);color:var(--text-primary);transition:width .3s ease,background-color .3s ease,color .3s ease;display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:1000;overflow:hidden;border-right:1px solid var(--border-color);box-shadow:2px 0 8px var(--shadow)}html[data-theme=light] .admin-sidebar{border-right:1px solid var(--border-color)}.admin-sidebar.closed{width:80px}.sidebar-header{padding:1.5rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color)}.sidebar-logo{height:32px;width:auto;-o-object-fit:contain;object-fit:contain;display:block}.sidebar-logo-mini{height:32px;width:32px;-o-object-fit:contain;object-fit:contain;display:block}.admin-sidebar.closed .sidebar-logo,.admin-sidebar.open .sidebar-logo-mini{display:none}.sidebar-title{font-size:1.25rem;font-weight:600;margin:0;white-space:nowrap;overflow:hidden}.admin-sidebar.closed .sidebar-title{display:none}.sidebar-toggle{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background-color .2s,color .3s ease}.sidebar-toggle:hover{background-color:var(--bg-hover)}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:var(--text-primary);text-decoration:none;transition:all .2s,background-color .3s ease,color .3s ease;white-space:nowrap}.nav-item:hover{background-color:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background-color:var(--bg-active);color:var(--text-primary);border-left:3px solid var(--text-primary)}.admin-sidebar.closed .nav-item span{display:none}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color);margin-top:auto}.user-info{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;color:var(--text-primary);font-size:.875rem;margin-bottom:.5rem;transition:color .3s ease}.user-info-button{width:100%;background:none;border:none;cursor:pointer;text-align:left;border-radius:.375rem;padding:.5rem .75rem;margin:0 0 .5rem;transition:background-color .2s,color .3s ease;color:var(--text-primary)}.user-info-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.theme-toggle-button{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;background:none;border:none;color:var(--text-primary);cursor:pointer;border-radius:.25rem;transition:background-color .2s,color .3s ease;font-size:.875rem;margin-bottom:.5rem}.theme-toggle-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.admin-sidebar.closed .theme-toggle-button span{display:none}.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-button{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;background:none;border:none;color:var(--text-primary);cursor:pointer;border-radius:.25rem;transition:background-color .2s,color .3s ease;font-size:.875rem}.logout-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.admin-sidebar.closed .logout-button span,.admin-sidebar.closed .user-info{display:none}.profile-modal{max-width:560px}.profile-section-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;transition:color .3s ease}.profile-divider{height:1px;background:var(--border-color);margin:1.25rem 0;transition:background .3s ease}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.modal-content{background:var(--modal-bg);border-radius:.5rem;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px var(--shadow);border:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);transition:border-color .3s ease}.form-group{margin-bottom:1.25rem}.form-group input:disabled{background:var(--bg-hover);color:var(--text-secondary)}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.75rem;padding-top:1.25rem;border-top:1px solid var(--border-color);transition:border-color .3s ease}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.admin-main{flex:1;margin-left:260px;transition:margin-left .3s ease;background:var(--bg-primary);transition:margin-left .3s ease,background .3s ease}.admin-sidebar.closed~.admin-main{margin-left:80px}.admin-content{padding:2rem;max-width:1400px;margin:0 auto;background:transparent}@media (max-width: 768px){.admin-sidebar{width:80px}.admin-sidebar.open{width:260px}.admin-main{margin-left:80px}.admin-sidebar.open~.admin-main{margin-left:260px}}.login-container{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden}.login-left{position:relative;background:linear-gradient(180deg,#1a1b26,#343541);display:flex;align-items:center;justify-content:center;padding:3rem;overflow:hidden}.login-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.tech-grid{position:absolute;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:50px 50px;opacity:.5}.tech-lines{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden}.tech-line{position:absolute;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);opacity:.3;animation:techLineMove 20s linear infinite}.tech-line-1{width:200px;height:1px;top:20%;left:-200px;animation-delay:0s}.tech-line-2{width:300px;height:1px;top:50%;left:-300px;animation-delay:5s}.tech-line-3{width:250px;height:1px;top:80%;left:-250px;animation-delay:10s}@keyframes techLineMove{0%{transform:translate(0)}to{transform:translate(calc(100vw + 300px))}}.tech-particles{position:absolute;top:0;left:0;width:100%;height:100%}.tech-particle{position:absolute;width:2px;height:2px;background:#ffffff80;border-radius:50%;animation:particleFloat 4s ease-in-out infinite;box-shadow:0 0 4px #ffffff80}@keyframes particleFloat{0%,to{transform:translateY(0) translate(0);opacity:.3}50%{transform:translateY(-20px) translate(10px);opacity:.8}}.login-left-content{position:relative;z-index:1;max-width:500px;color:#ececf1}.login-left-logo{display:inline-block;margin-bottom:3rem}.login-left-logo-img{height:48px;width:auto;-o-object-fit:contain;object-fit:contain;display:block}.login-left-title{font-size:3rem;font-weight:700;color:#fff;margin:0 0 1.5rem;letter-spacing:0;line-height:1.3}.login-left-subtitle{font-size:1.5rem;font-weight:600;color:#ececf1;margin:0 0 1.5rem;letter-spacing:0;line-height:1.4}.login-left-description{font-size:1.125rem;color:#a0a0a0;line-height:1.7;letter-spacing:0;margin:0}.login-right{background:#fff;display:flex;align-items:center;justify-content:center;padding:3rem}.login-box{width:100%;max-width:400px}.login-header{margin-bottom:2rem}.login-welcome{font-size:1.875rem;font-weight:700;color:#1a1b26;margin:0 0 .75rem;letter-spacing:0;line-height:1.4}.login-welcome-hint{font-size:.938rem;color:#6b7280;margin:0;letter-spacing:0;line-height:1.6}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.login-form .form-group label{font-size:.875rem;font-weight:500;color:#374151!important;margin-bottom:.5rem}.login-form .form-group input{border:1.5px solid #9ca3af!important;background-color:#fff!important;box-sizing:border-box;height:50px;width:100%;border-radius:8px;padding:16px;color:#374151!important;font-size:.938rem;transition:all .2s ease}.login-form .form-group input::-moz-placeholder{color:#9ca3af!important}.login-form .form-group input::placeholder{color:#9ca3af!important}.form-group input::-moz-placeholder{color:#9ca3af}.form-group input::placeholder{color:#9ca3af}.form-group input:focus{outline:none;border-color:#1a1b26;box-shadow:0 0 0 3px #1a1b2633}.error-message{padding:.75rem;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:.5rem;font-size:.875rem;text-align:center;letter-spacing:0}.login-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%}.hero-button{padding:.875rem 1.75rem;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;letter-spacing:0}.hero-button-primary{background:#1a1b26;color:#fff}.hero-button-primary:hover:not(:disabled){background:#2d2e3a;transform:translateY(-1px)}.hero-button-primary:active:not(:disabled){transform:translateY(0)}.hero-button-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{margin-top:1.5rem;text-align:center}.login-hint{font-size:.875rem;color:#6b7280;margin:0}.login-secondary-button{padding:.75rem;background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.login-secondary-button:hover:not(:disabled){background:#e5e7eb}.login-secondary-button:disabled{opacity:.6;cursor:not-allowed}.twofa-title{font-size:1rem;font-weight:600;color:#111827;text-align:center}.twofa-setup{padding:.75rem;border:1px solid #e5e7eb;background:#f9fafb;border-radius:.75rem;font-size:.85rem;color:#374151}.twofa-setup-line+.twofa-setup-line{margin-top:.5rem}.twofa-label{font-weight:600}.twofa-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.8rem;word-break:break-all}@media (max-width: 1024px){.login-container{grid-template-columns:1fr}.login-left{min-height:40vh;padding:2rem}.login-left-title{font-size:2rem}.login-left-subtitle{font-size:1.25rem}.login-left-description{font-size:1rem}}@media (max-width: 768px){.login-left{padding:1.5rem;min-height:30vh}.login-right{padding:2rem 1.5rem}.login-left-title{font-size:1.75rem}.login-left-subtitle{font-size:1.125rem}.login-left-description{font-size:.938rem}.login-welcome{font-size:1.5rem}}@media (max-width: 480px){.login-left{padding:1.5rem;min-height:25vh}.login-right{padding:1.5rem}.login-left-logo-img{height:36px}.login-left-title{font-size:1.5rem;margin-bottom:1rem}.login-left-subtitle{font-size:1rem;margin-bottom:1rem}.login-left-description{font-size:.875rem}}.page-title{font-size:2rem;font-weight:600;margin-bottom:2rem;color:var(--text-primary);transition:color .3s ease}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--bg-secondary);border-radius:.5rem;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px var(--shadow);transition:transform .2s,box-shadow .2s,background .3s ease;border:1px solid var(--border-color)}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.stat-icon{width:3rem;height:3rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-blue .stat-icon{background-color:#dbeafe;color:#3b82f6}.stat-green .stat-icon{background-color:#d1fae5;color:#10b981}.stat-purple .stat-icon{background-color:#e9d5ff;color:#8b5cf6}.stat-orange .stat-icon{background-color:#fed7aa;color:#f97316}.stat-content{flex:1}.stat-value{font-size:1.875rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem;transition:color .3s ease}.dashboard-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1.15fr);gap:1.5rem;margin-bottom:2rem;align-items:flex-start}.dashboard-grid-main,.dashboard-grid-side{display:flex;flex-direction:column;gap:1.25rem}.chart-section{background:var(--bg-secondary);border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px var(--shadow);border:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.chart-section h3{font-size:1.1rem;font-weight:600;margin-bottom:1.5rem;color:var(--text-primary)}.chart-wrapper{width:100%;height:300px}.chart-section-side .chart-wrapper{height:auto}.side-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.side-card-subtitle{font-size:.8rem;color:var(--text-secondary);margin-top:.2rem}.side-card-kpi{font-size:1.25rem;font-weight:700;color:#10b981;white-space:nowrap}.payment-systems-list{display:flex;flex-direction:column;gap:.75rem}.payment-system-item{padding:.7rem .85rem;border-radius:.5rem;background:var(--bg-hover);border:1px solid var(--border-color)}.payment-system-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.35rem}.payment-system-main{display:flex;flex-direction:column;gap:.12rem}.payment-system-name{font-size:.9rem;font-weight:500;color:var(--text-primary)}.payment-system-amount{font-size:.85rem;color:var(--text-secondary)}.payment-system-percent{font-size:.9rem;font-weight:600;color:#10b981;white-space:nowrap}.payment-system-bar{position:relative;width:100%;height:6px;border-radius:999px;background:#94a3b840;overflow:hidden}.payment-system-bar-inner{height:100%;border-radius:999px;transition:width .3s ease}.payment-system-bar-0{background:linear-gradient(90deg,#22c55e,#16a34a)}.payment-system-bar-1{background:linear-gradient(90deg,#3b82f6,#2563eb)}.payment-system-bar-2{background:linear-gradient(90deg,#f97316,#ea580c)}.payment-system-bar-3{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.payment-system-bar-4{background:linear-gradient(90deg,#ec4899,#db2777)}.dashboard-content{display:grid;gap:1.5rem}@media (max-width: 1024px){.dashboard-grid{grid-template-columns:minmax(0,1fr)}.dashboard-grid-side{order:-1}}.dashboard-section{background:var(--bg-secondary);border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px var(--shadow);border:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.dashboard-section h2{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary);transition:color .3s ease}.dashboard-section-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.dashboard-section-header h2{margin-bottom:0}.dashboard-alert{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1.25rem}.dashboard-alert-text{font-size:.9rem}.btn-retry,.btn-refresh{border:1px solid var(--border-color);background:var(--bg-secondary);padding:.45rem .75rem;border-radius:.5rem;cursor:pointer;font-size:.875rem;color:var(--text-primary);transition:background .3s ease,color .3s ease,border-color .3s ease}.btn-retry:disabled,.btn-refresh:disabled{opacity:.6;cursor:not-allowed}.empty-state{padding:3rem;text-align:center;color:#9ca3af}.activity-list{display:flex;flex-direction:column;gap:.75rem}.activity-item{display:grid;grid-template-columns:32px 1fr auto;gap:.75rem;align-items:center;padding:.75rem;border:1px solid var(--border-color);border-radius:.5rem;background:var(--bg-hover);transition:background .3s ease,border-color .3s ease}.activity-icon{width:32px;height:32px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;background:var(--bg-active);color:var(--text-primary);transition:background .3s ease,color .3s ease}.activity-main{min-width:0}.activity-title-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.activity-title{font-weight:600;color:var(--text-primary);font-size:.95rem;transition:color .3s ease}.activity-detail{color:var(--text-secondary);font-size:.875rem;margin-top:.15rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .3s ease}.activity-time{color:var(--text-secondary);font-size:.8rem;white-space:nowrap;transition:color .3s ease}.badge{display:inline-flex;align-items:center;padding:.1rem .5rem;border-radius:999px;font-size:.75rem;border:1px solid var(--border-color);color:var(--text-primary);background:var(--bg-secondary);flex-shrink:0;transition:background .3s ease,color .3s ease,border-color .3s ease}.badge-user{background:#dbeafe;border-color:#bfdbfe;color:#1d4ed8}.badge-recharge{background:#d1fae5;border-color:#a7f3d0;color:#047857}.badge-call{background:#ede9fe;border-color:#ddd6fe;color:#6d28d9}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.model-config-tip{font-size:.875rem;line-height:1.5;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;padding:.75rem 1rem;margin-bottom:1rem;transition:color .3s ease,background .3s ease,border-color .3s ease}.model-config-tip code{font-size:.85em;padding:.1rem .35rem;border-radius:.25rem;background:var(--bg-hover);color:var(--text-primary)}.platform-filter{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.platform-filter-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;cursor:pointer;transition:color .2s,background .2s,border-color .2s}.platform-filter-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.platform-filter-btn.active{color:#fff;background:#3b82f6;border-color:#3b82f6}.platform-filter-count{font-size:.75rem;opacity:.9}.model-config-sections{display:flex;flex-direction:column;gap:2rem}.platform-section{margin:0}.platform-section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--border-color);display:flex;align-items:center;gap:.5rem;transition:color .3s ease,border-color .3s ease}.platform-section-count{font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:color .3s ease}.model-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.btn-primary{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background-color:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:#2563eb}.loading{text-align:center;padding:3rem;color:var(--text-secondary);transition:color .3s ease}.models-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.model-card{background:var(--bg-secondary);border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px var(--shadow);transition:transform .2s,box-shadow .2s,background .3s ease;display:flex;flex-direction:column;border:1px solid var(--border-color)}.model-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.model-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.model-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem;transition:color .3s ease}.platform-badge{display:inline-block;padding:.25rem .75rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.model-card-body{flex:1;margin-bottom:1rem}.model-info{display:flex;flex-direction:column;gap:.75rem}.info-item{display:flex;gap:.5rem}.info-label{font-size:.875rem;color:var(--text-secondary);min-width:80px;transition:color .3s ease}.info-value{font-size:.875rem;color:var(--text-primary);flex:1;transition:color .3s ease}.model-card-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid var(--border-color);transition:border-color .3s ease}.btn-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;background-color:var(--bg-hover);color:var(--text-primary);border:none;border-radius:.25rem;cursor:pointer;transition:all .2s,background-color .3s ease,color .3s ease}.btn-icon:hover{background-color:var(--bg-active);color:var(--text-primary)}.btn-icon.btn-danger:hover{background-color:#fee2e2;color:#dc2626}.empty-state{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:var(--text-secondary);transition:color .3s ease}.empty-state p{margin-bottom:1.5rem;font-size:1.125rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.modal-content{background:var(--modal-bg);border-radius:.5rem;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px var(--shadow);border:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color);transition:border-color .3s ease}.modal-header h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;transition:color .3s ease}.modal-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background-color .2s,color .3s ease}.modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.model-form{padding:1.5rem}.form-section{margin-bottom:2rem}.form-section:last-of-type{margin-bottom:0}.form-section-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.5rem;transition:color .3s ease,border-color .3s ease}.form-section-title.platform-gcp{border-bottom-color:#ea580c59;color:#c2410c}.form-section-title.platform-azure{border-bottom-color:#2563eb59;color:#1d4ed8}.form-section-title.billing{border-bottom-color:#22c55e59;color:#15803d}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem;transition:color .3s ease}.form-group input,.form-group select{width:100%;padding:.625rem .75rem;border:1px solid var(--border-color);border-radius:.375rem;font-size:.875rem;transition:border-color .2s,box-shadow .2s,background .3s ease,color .3s ease;background:var(--bg-secondary);color:var(--text-primary)}.model-form input[type=number],.form-group input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.model-form input[type=number]::-webkit-outer-spinner-button,.model-form input[type=number]::-webkit-inner-spinner-button,.form-group input[type=number]::-webkit-outer-spinner-button,.form-group input[type=number]::-webkit-inner-spinner-button{-webkit-appearance:none;margin:0}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--border-hover);box-shadow:0 0 0 3px var(--bg-hover)}.form-group input::-moz-placeholder,.form-group select::-moz-placeholder{color:var(--text-secondary)}.form-group input::placeholder,.form-group select::placeholder{color:var(--text-secondary)}.form-group input.error,.form-group select.error{border-color:#ef4444}.error-message{display:block;font-size:.75rem;color:#ef4444;margin-top:.25rem}.form-hint{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:.25rem;transition:color .3s ease}.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto;cursor:pointer}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color);transition:border-color .3s ease}.btn-secondary{padding:.625rem 1.25rem;background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s,color .3s ease,border-color .3s ease}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.model-config-edit-page{max-width:720px;margin:0 auto}.model-config-edit-page .page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.model-config-edit-page .btn-back{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;cursor:pointer;transition:color .2s,background .2s,border-color .2s}.model-config-edit-page .btn-back:hover{color:var(--text-primary);background:var(--bg-hover);border-color:var(--border-hover)}.model-config-edit-page .page-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;transition:color .3s ease}.model-form-page-wrap{background:var(--modal-bg);border-radius:.5rem;border:1px solid var(--border-color);overflow:hidden;transition:background .3s ease,border-color .3s ease}.model-form-page-wrap .model-form{padding:1.5rem}.model-form-page-wrap .form-actions{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.toolbar{margin-bottom:1.5rem;display:flex;gap:1rem;align-items:center}.search-box{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;flex:1;max-width:400px;transition:background .3s ease,border-color .3s ease}.search-box input{flex:1;border:none;outline:none;font-size:.875rem;background:transparent;color:var(--text-primary);transition:color .3s ease}.search-box input::-moz-placeholder{color:var(--text-secondary)}.search-box input::placeholder{color:var(--text-secondary)}.search-box svg{color:var(--text-secondary);transition:color .3s ease}.table-container{background:var(--bg-secondary);border-radius:.5rem;overflow:hidden;box-shadow:0 1px 3px var(--shadow);border:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.data-table{width:100%;border-collapse:collapse}.data-table thead{background-color:var(--bg-hover);transition:background-color .3s ease}.data-table th{padding:.75rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-color);transition:color .3s ease,border-color .3s ease}.data-table td{padding:.75rem 1rem;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-color);transition:color .3s ease,border-color .3s ease}.data-table tbody tr:hover{background-color:var(--bg-hover);transition:background-color .3s ease}.balance{font-weight:600;color:#10b981}.balance-cell{display:flex;flex-direction:column;gap:2px;line-height:1.15}.balance-usd{white-space:nowrap}.balance-points{font-size:.75rem;font-weight:500;color:var(--text-secondary);white-space:nowrap;transition:color .3s ease}.membership-cell{min-width:140px}.membership-info{display:flex;flex-direction:column;gap:2px;font-size:.8125rem;line-height:1.25}.membership-plan{display:flex;align-items:center;gap:.375rem;flex-wrap:wrap}.membership-badge{display:inline-block;padding:.2rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.membership-badge.member{background-color:#dbeafe;color:#1e40af}.membership-badge.free{background-color:var(--bg-hover);color:var(--text-secondary)}.membership-billing{font-size:.7rem;color:var(--text-secondary)}.membership-expiry,.membership-points{font-size:.75rem;color:var(--text-secondary)}.btn-icon.btn-activate-membership{color:var(--text-secondary)}.btn-icon.btn-activate-membership:hover{color:#1e40af;background-color:#dbeafe}.membership-info.membership-expired .membership-expiry{color:#b91c1c}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.status-badge.enabled{background-color:#d1fae5;color:#065f46}.status-badge.disabled{background-color:#fee2e2;color:#991b1b}.table-actions{display:flex;gap:.5rem}.empty-row{text-align:center;padding:3rem;color:var(--text-secondary);transition:color .3s ease}.delete-confirm-modal{max-width:420px}.delete-confirm-modal .delete-confirm-body{padding:1.25rem 1.5rem}.delete-confirm-modal .delete-confirm-warning{margin:0 0 .75rem;font-size:.9375rem;color:var(--text-primary);line-height:1.5}.delete-confirm-modal .delete-confirm-hint{margin:0 0 .5rem;font-size:.875rem;color:var(--text-secondary)}.delete-confirm-modal .form-input{width:100%;padding:.625rem .75rem;border:1px solid var(--border-color);border-radius:.375rem;font-size:.875rem;background:var(--bg-secondary);color:var(--text-primary);margin-top:.25rem}.delete-confirm-modal .form-input:focus{outline:none;border-color:var(--border-hover)}.delete-confirm-modal .form-input.error{border-color:#ef4444}.delete-confirm-modal .delete-code-inputs{display:flex;gap:.5rem;justify-content:center;margin-top:.75rem}.delete-confirm-modal .delete-code-input{width:2.75rem;height:2.75rem;text-align:center;font-size:1.25rem;font-weight:600;letter-spacing:.1em;border:2px solid var(--border-color);border-radius:.5rem;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .2s,background .3s ease,color .3s ease}.delete-confirm-modal .delete-code-input:focus{outline:none;border-color:var(--border-hover, #3b82f6);box-shadow:0 0 0 3px #3b82f633}.delete-confirm-modal .delete-code-input.error{border-color:#ef4444}.delete-confirm-modal .delete-confirm-error{margin:.5rem 0 0;font-size:.875rem;color:#dc2626}.activate-membership-modal{max-width:420px}.activate-membership-modal .activate-membership-body{padding:1.25rem 1.5rem}.activate-membership-modal .activate-membership-desc{margin:0 0 1rem;font-size:.875rem;color:var(--text-primary);line-height:1.5}.activate-membership-modal .activate-membership-hint{margin:.75rem 0 .5rem;font-size:.875rem;color:var(--text-secondary)}.activate-membership-modal .activate-membership-error{margin:.5rem 0 0;font-size:.875rem;color:#dc2626}.activate-membership-modal .form-group{margin-bottom:1rem}.activate-membership-modal .form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.375rem}.activate-membership-modal .form-input{width:100%;padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-secondary);color:var(--text-primary)}.activate-membership-modal .activate-code-inputs{display:flex;gap:.5rem;justify-content:center;margin-top:.5rem}.activate-membership-modal .activate-code-input{width:2.75rem;height:2.75rem;text-align:center;font-size:1.25rem;font-weight:600;letter-spacing:.1em;border:2px solid var(--border-color);border-radius:.5rem;background:var(--bg-secondary);color:var(--text-primary)}.activate-membership-modal .activate-code-input:focus{outline:none;border-color:var(--border-hover, #3b82f6)}.activate-membership-modal .activate-code-input.error{border-color:#ef4444}.activate-membership-modal .form-actions,.delete-confirm-modal .form-actions{padding:1rem 1.5rem 1.25rem}.delete-confirm-modal .btn-danger{padding:.625rem 1.25rem;background-color:#dc2626;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.delete-confirm-modal .btn-danger:hover:not(:disabled){background-color:#b91c1c}.delete-confirm-modal .btn-danger:disabled{opacity:.5;cursor:not-allowed}.recharge-management .toolbar{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.75rem}.recharge-management .toolbar-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1rem}.recharge-management .search-box{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;min-width:260px;max-width:400px;transition:background .3s ease,border-color .3s ease}.recharge-management .search-box input{flex:1;border:none;outline:none;font-size:.875rem;background:transparent;color:var(--text-primary)}.recharge-management .search-box input::-moz-placeholder{color:var(--text-secondary)}.recharge-management .search-box input::placeholder{color:var(--text-secondary)}.recharge-management .search-box svg{color:var(--text-secondary);flex-shrink:0}.recharge-management .filters{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.75rem 1rem}.recharge-management .filter-group{display:flex;flex-direction:column;gap:.25rem}.recharge-management .filter-label{font-size:.75rem;color:var(--text-secondary);font-weight:500}.recharge-management .filter-select,.recharge-management .filter-input{padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-secondary);color:var(--text-primary);min-width:120px;transition:border-color .2s,background .3s ease,color .3s ease}.recharge-management .filter-select:focus,.recharge-management .filter-input:focus{outline:none;border-color:var(--border-hover, #3b82f6)}.recharge-management .filter-date{min-width:140px}.recharge-management .btn-reset-filters{padding:.5rem .75rem;font-size:.8125rem;color:var(--text-secondary);background:transparent;border:1px solid var(--border-color);border-radius:.375rem;cursor:pointer;transition:color .2s,border-color .2s,background .2s}.recharge-management .btn-reset-filters:hover{color:var(--text-primary);background:var(--bg-hover);border-color:var(--text-secondary)}.stats-bar{display:flex;gap:2rem;margin-bottom:1.5rem;padding:1rem 1.5rem;background:var(--bg-secondary);border-radius:.5rem;box-shadow:0 1px 3px var(--shadow);border:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.stat-item{display:flex;align-items:center;gap:.5rem}.stat-label{font-size:.875rem;color:var(--text-secondary);transition:color .3s ease}.stat-value{font-size:1.125rem;font-weight:600;color:var(--text-primary);transition:color .3s ease}.amount{font-weight:600}.amount.positive{color:#10b981}.form-group textarea{width:100%;padding:.625rem .75rem;border:1px solid var(--border-color);border-radius:.375rem;font-size:.875rem;font-family:inherit;resize:vertical;transition:border-color .2s,box-shadow .2s,background .3s ease,color .3s ease;background:var(--bg-secondary);color:var(--text-primary)}.form-group textarea:focus{outline:none;border-color:var(--border-hover);box-shadow:0 0 0 3px var(--bg-hover)}.form-group textarea::-moz-placeholder{color:var(--text-secondary)}.form-group textarea::placeholder{color:var(--text-secondary)}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:500;text-align:center}.status-success{background-color:#d1fae5;color:#065f46}.status-pending{background-color:#fef3c7;color:#92400e}.status-failed{background-color:#fee2e2;color:#991b1b}.status-canceled{background-color:#e5e7eb;color:#374151}.status-unknown{background-color:#f3f4f6;color:#6b7280}.stat-hint{font-size:.75rem;color:var(--text-secondary);margin-left:.5rem;font-weight:400}.membership-recharge-records .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.membership-recharge-records .page-title{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.membership-recharge-records .stats-bar{display:flex;gap:2rem;margin-bottom:1.5rem;padding:1rem 1.5rem;background:var(--bg-secondary);border-radius:.5rem;box-shadow:0 1px 3px var(--shadow);border:1px solid var(--border-color)}.membership-recharge-records .stat-item{display:flex;align-items:center;gap:.5rem}.membership-recharge-records .stat-label{font-size:.875rem;color:var(--text-secondary)}.membership-recharge-records .stat-value{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.membership-recharge-records .stat-hint{font-size:.75rem;color:var(--text-secondary);margin-left:.5rem;font-weight:400}.membership-recharge-records .toolbar{margin-bottom:1.5rem}.membership-recharge-records .search-box{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;max-width:400px}.membership-recharge-records .search-box input{flex:1;border:none;outline:none;font-size:.875rem;background:transparent;color:var(--text-primary)}.membership-recharge-records .search-box input::-moz-placeholder{color:var(--text-secondary)}.membership-recharge-records .search-box input::placeholder{color:var(--text-secondary)}.membership-recharge-records .table-container{background:var(--bg-secondary);border-radius:.5rem;overflow:hidden;box-shadow:0 1px 3px var(--shadow);border:1px solid var(--border-color)}.membership-recharge-records .data-table{width:100%;border-collapse:collapse}.membership-recharge-records .data-table thead{background-color:var(--bg-hover)}.membership-recharge-records .data-table th{padding:.75rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.membership-recharge-records .data-table td{padding:.75rem 1rem;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.membership-recharge-records .data-table tbody tr{cursor:pointer;transition:background-color .2s}.membership-recharge-records .data-table tbody tr:hover,.membership-recharge-records .data-table tbody tr.row-expanded{background-color:var(--bg-hover)}.membership-recharge-records .expand-cell{color:var(--text-secondary);width:36px;padding-left:.75rem!important}.membership-recharge-records .plan-badge{display:inline-block;padding:.2rem .5rem;border-radius:.25rem;font-size:.8125rem;font-weight:500;background-color:#dbeafe;color:#1e40af}.membership-recharge-records .amount{font-weight:600;color:#10b981}.membership-recharge-records .detail-row td{padding:0;border-bottom:1px solid var(--border-color);background:var(--bg-primary);vertical-align:top}.membership-recharge-records .detail-panel{padding:1rem 1.5rem 1rem 3rem}.membership-recharge-records .detail-panel h4{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:var(--text-secondary)}.membership-recharge-records .detail-grid{display:grid;grid-template-columns:140px 1fr;gap:.5rem 1.5rem;font-size:.8125rem;margin:0}.membership-recharge-records .detail-grid dt{margin:0;color:var(--text-secondary);font-weight:500}.membership-recharge-records .detail-grid dd{margin:0;color:var(--text-primary);word-break:break-all}.membership-recharge-records .detail-grid dd.mono{font-family:ui-monospace,monospace;font-size:.75rem}.membership-recharge-records .empty-row{text-align:center;padding:3rem;color:var(--text-secondary);cursor:default}.membership-recharge-records .loading{text-align:center;padding:3rem;color:var(--text-secondary)}.membership-recharge-records .status-badge{display:inline-block;padding:.25rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:500}.membership-recharge-records .status-success{background-color:#d1fae5;color:#065f46}.membership-recharge-records .status-pending{background-color:#fef3c7;color:#92400e}.membership-recharge-records .status-failed{background-color:#fee2e2;color:#991b1b}.membership-recharge-records .status-canceled{background-color:#e5e7eb;color:#374151}.membership-recharge-records .status-unknown{background-color:#f3f4f6;color:#6b7280}.workflow-templates .page-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem}.workflow-templates .page-title{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.workflow-templates .page-subtitle{margin:0;font-size:.875rem;color:var(--text-secondary)}.workflow-templates .toolbar{margin-bottom:1.5rem}.workflow-templates .search-box{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;max-width:420px}.workflow-templates .search-box input{flex:1;border:none;outline:none;font-size:.875rem;background:transparent;color:var(--text-primary)}.workflow-templates .search-box input::-moz-placeholder{color:var(--text-secondary)}.workflow-templates .search-box input::placeholder{color:var(--text-secondary)}.workflow-templates .table-container{background:var(--bg-secondary);border-radius:.5rem;overflow:hidden;box-shadow:0 1px 3px var(--shadow);border:1px solid var(--border-color)}.workflow-templates .data-table{width:100%;border-collapse:collapse}.workflow-templates .data-table thead{background-color:var(--bg-hover)}.workflow-templates .data-table th{padding:.75rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.workflow-templates .data-table td{padding:.75rem 1rem;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.workflow-templates .user-cell{display:flex;flex-direction:column;gap:.15rem}.workflow-templates .user-name{font-weight:500}.workflow-templates .user-id{font-size:.75rem;color:var(--text-secondary)}.workflow-templates .action-buttons{display:flex;gap:.5rem}.workflow-templates .action-button{padding:.25rem .6rem;font-size:.8125rem;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:background-color .15s,color .15s,border-color .15s,opacity .15s}.workflow-templates .action-button.secondary{background:var(--bg-primary)}.workflow-templates .action-button:hover{background:var(--bg-hover)}.workflow-templates .data-table tbody tr:hover{background-color:var(--bg-hover)}.workflow-templates .empty-row,.workflow-templates .loading{text-align:center;padding:3rem;color:var(--text-secondary)}.workflow-templates .pagination{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;margin-top:.75rem}.workflow-templates .pagination-button{padding:.4rem .9rem;font-size:.8125rem;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:background-color .15s,color .15s,border-color .15s,opacity .15s}.workflow-templates .pagination-button:hover:not(:disabled){background:var(--bg-hover)}.workflow-templates .pagination-button:disabled{opacity:.5;cursor:not-allowed}.workflow-templates .pagination-info{font-size:.8125rem;color:var(--text-secondary)}.admin-workflow-viewer .page-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem}.admin-workflow-viewer .page-header-top{display:flex;align-items:center;gap:.75rem}.admin-workflow-viewer .page-title{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.admin-workflow-viewer .back-button{padding:.35rem .8rem;font-size:.8125rem;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:background-color .15s,color .15s,border-color .15s}.admin-workflow-viewer .back-button:hover{background:var(--bg-hover)}.admin-workflow-viewer .page-subtitle{margin:0;font-size:.875rem;color:var(--text-secondary)}.admin-workflow-viewer .loading,.admin-workflow-viewer .error{margin-top:1rem;padding:1rem 1.25rem;border-radius:.5rem;font-size:.875rem}.admin-workflow-viewer .loading{background:var(--bg-secondary);color:var(--text-secondary)}.admin-workflow-viewer .error{background:#fee2e2;color:#991b1b}.admin-workflow-viewer .workflow-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.5rem 1.5rem;padding:1rem 1.25rem;margin-top:1rem;margin-bottom:1.5rem;border-radius:.5rem;background:var(--bg-secondary);border:1px solid var(--border-color)}.admin-workflow-viewer .meta-item{display:flex;gap:.25rem;font-size:.875rem}.admin-workflow-viewer .meta-label{color:var(--text-secondary)}.admin-workflow-viewer .meta-value{color:var(--text-primary);font-weight:500}.admin-workflow-viewer .workflow-section{margin-top:1.5rem}.admin-workflow-viewer .section-title{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.admin-workflow-viewer .empty-hint{padding:.75rem 1rem;border-radius:.5rem;background:var(--bg-secondary);color:var(--text-secondary);font-size:.875rem}.admin-workflow-viewer .field-label{color:var(--text-secondary)}.admin-workflow-viewer .field-value{color:var(--text-primary)}.admin-workflow-viewer .field-value.small-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.75rem;word-break:break-all}.admin-workflow-viewer .connections-list{display:flex;flex-direction:column;gap:.35rem}.admin-workflow-viewer .connection-item{font-size:.8125rem;padding:.25rem .5rem;border-radius:.375rem;background:var(--bg-secondary)}.admin-workflow-viewer .connection-label{color:var(--text-primary)}.admin-workflow-viewer .json-viewer{margin:0;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:.5rem;border:1px solid var(--border-color);font-size:.8125rem;white-space:pre-wrap;word-break:break-all}.admin-workflow-viewer .viewer-canvas{position:relative;margin-top:1rem;border-radius:.75rem;border:1px solid var(--border-color);background:var(--bg-primary);overflow:hidden;min-height:520px}.admin-workflow-viewer .viewer-canvas-panning{cursor:grabbing}.admin-workflow-viewer .viewer-canvas:not(.viewer-canvas-panning){cursor:grab}.admin-workflow-viewer .viewer-canvas-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(to right,rgba(148,163,184,.15) 1px,transparent 1px),linear-gradient(to bottom,rgba(148,163,184,.15) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}.admin-workflow-viewer .viewer-canvas-inner{position:relative;width:100%;height:520px}.admin-workflow-viewer .viewer-connections{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.admin-workflow-viewer .viewer-nodes{position:absolute;top:0;right:0;bottom:0;left:0}.admin-workflow-viewer .viewer-node{position:absolute;border-radius:.75rem;border:1px solid var(--border-color);background:var(--bg-secondary);box-shadow:0 8px 20px #0f172a40;overflow:hidden}.admin-workflow-viewer .viewer-node-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid var(--border-color);background:linear-gradient(to right,#3b82f61f,#0ea5e91f)}.admin-workflow-viewer .viewer-node-title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.admin-workflow-viewer .viewer-node-kind{font-size:.7rem;padding:.1rem .5rem;border-radius:999px;background:#0f172a1a;color:var(--text-secondary)}.admin-workflow-viewer .viewer-node-body{padding:.5rem .75rem .75rem;display:flex;flex-direction:column;gap:.25rem}.admin-workflow-viewer .viewer-node-field{font-size:.8rem}.admin-workflow-viewer .template-section{margin-top:1.5rem;padding:1rem 1.25rem;border-radius:.75rem;border:1px solid var(--border-color);background:var(--bg-secondary)}.admin-workflow-viewer .template-section-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.admin-workflow-viewer .template-section-actions{display:flex;align-items:center;gap:.75rem}.admin-workflow-viewer .template-save-button{padding:.4rem .9rem;font-size:.8125rem;border-radius:999px;border:none;background:linear-gradient(135deg,#3b82f6,#06b6d4);color:#fff;cursor:pointer;box-shadow:0 4px 10px #2563eb59;transition:transform .15s,box-shadow .15s,opacity .15s}.admin-workflow-viewer .template-save-button:hover{transform:translateY(-1px);box-shadow:0 6px 16px #2563eb73}.admin-workflow-viewer .template-toggle{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-secondary);cursor:pointer}.admin-workflow-viewer .template-toggle input{display:none}.admin-workflow-viewer .template-toggle-slider{position:relative;width:34px;height:18px;border-radius:999px;background:#4b5563;transition:background-color .15s}.admin-workflow-viewer .template-toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#f9fafb;transition:transform .15s}.admin-workflow-viewer .template-toggle input:checked+.template-toggle-slider{background:#22c55e}.admin-workflow-viewer .template-toggle input:checked+.template-toggle-slider:before{transform:translate(16px)}.admin-workflow-viewer .template-toggle-label{white-space:nowrap}.admin-workflow-viewer .template-form{display:flex;flex-direction:column;gap:.75rem}.admin-workflow-viewer .template-field{display:flex;flex-direction:column;gap:.25rem}.admin-workflow-viewer .template-label{font-size:.8125rem;color:var(--text-secondary)}.admin-workflow-viewer .template-input,.admin-workflow-viewer .template-textarea,.admin-workflow-viewer .template-select{font-size:.875rem;padding:.4rem .6rem;border-radius:.5rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary)}.admin-workflow-viewer .template-textarea{resize:vertical;min-height:72px}.admin-workflow-viewer .template-row{display:flex;flex-wrap:wrap;gap:.75rem}.admin-workflow-viewer .tag-options{display:flex;align-items:center;gap:.75rem;margin-top:.15rem}.admin-workflow-viewer .tag-option{display:inline-flex;align-items:center;gap:.25rem;font-size:.8125rem;color:var(--text-primary)}.admin-workflow-viewer .template-field-type{min-width:200px}.admin-workflow-viewer .template-image-row{display:flex;align-items:center;gap:.75rem;margin-top:.25rem}.admin-workflow-viewer .template-upload-button{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:.4rem .9rem;font-size:.8125rem;border-radius:999px;border:1px dashed var(--border-color);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;overflow:hidden}.admin-workflow-viewer .template-upload-button input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.admin-workflow-viewer .template-image-preview{width:120px;height:72px;border-radius:.5rem;overflow:hidden;border:1px solid var(--border-color);background:var(--bg-primary)}.admin-workflow-viewer .template-image-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.admin-workflow-viewer .template-hint{margin:.35rem 0 0;font-size:.75rem;color:var(--text-secondary)}.system-config{width:100%}.tabs{display:flex;gap:.5rem;margin:.75rem 0 1rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem;transition:border-color .3s ease}.tab-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:999px;padding:.4rem .9rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .15s,border-color .15s,color .3s ease}.tab-btn:hover{background:var(--bg-hover)}.tab-btn.active{background:var(--bg-active);border-color:var(--border-hover);color:var(--text-primary)}.page-title-row{display:flex;align-items:center;gap:.5rem}.page-actions{display:flex;align-items:center;gap:.75rem}.btn-secondary{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s,color .3s ease,border-color .3s ease}.btn-secondary:hover{background-color:var(--bg-hover)}.btn-secondary:disabled,.btn-primary:disabled{opacity:.7;cursor:not-allowed}.config-card{background:var(--bg-secondary);border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px var(--shadow);border:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.section-title{margin:0 0 1rem;font-size:1.1rem;color:var(--text-primary);transition:color .3s ease}.section-subtitle{margin:0 0 1rem;font-size:.95rem;color:var(--text-primary);transition:color .3s ease}.section-divider{height:1px;background:var(--border-color);margin:1.25rem 0;transition:background .3s ease}.config-desc{font-size:.875rem;color:var(--text-secondary);line-height:1.6;transition:color .3s ease}.config-desc ul{margin:0;padding-left:1.25rem}.config-desc li{margin-bottom:.5rem}.config-desc li:last-child{margin-bottom:0}.config-desc code{font-size:.8em;padding:.15rem .35rem;border-radius:.25rem;background:var(--bg-hover);color:var(--text-primary);transition:background .3s ease,color .3s ease}.form-row{display:grid;grid-template-columns:160px 1fr;gap:1rem;align-items:start;margin-bottom:1rem}.form-label{font-size:.875rem;color:var(--text-primary);font-weight:600;padding-top:.55rem;transition:color .3s ease}.form-input{width:100%;padding:.625rem .75rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;outline:none;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .2s,box-shadow .2s,background .3s ease,color .3s ease}.form-input:focus{border-color:var(--border-hover);box-shadow:0 0 0 2px var(--bg-hover)}.form-input::-moz-placeholder{color:var(--text-secondary)}.form-input::placeholder{color:var(--text-secondary)}.form-help{display:flex;flex-direction:column;gap:.5rem}.muted{font-size:.8rem;color:var(--text-secondary);transition:color .3s ease}.form-actions{display:flex;justify-content:flex-end;margin-top:.75rem}.form-inline{display:flex;align-items:center;gap:.5rem;padding-top:.55rem}.form-inline input[type=checkbox]{width:16px;height:16px;accent-color:#3b82f6}.notice{padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem}.notice-success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}.notice-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.notice-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.form-label{padding-top:0}.page-actions{flex-wrap:wrap;justify-content:flex-end}}.app-container{min-height:100vh;background:var(--bg-primary);transition:background .3s ease}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.block{display:block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.min-h-screen{min-height:100vh}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.items-center{align-items:center}.justify-center{justify-content:center}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.border{border-width:1px}.bg-blue-100{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-indigo-100{--tw-bg-opacity: 1;background-color:rgb(224 231 255 / var(--tw-bg-opacity, 1))}.bg-orange-100{--tw-bg-opacity: 1;background-color:rgb(255 237 213 / var(--tw-bg-opacity, 1))}.bg-pink-100{--tw-bg-opacity: 1;background-color:rgb(252 231 243 / var(--tw-bg-opacity, 1))}.bg-purple-100{--tw-bg-opacity: 1;background-color:rgb(243 232 255 / var(--tw-bg-opacity, 1))}.bg-teal-100{--tw-bg-opacity: 1;background-color:rgb(204 251 241 / var(--tw-bg-opacity, 1))}.bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.text-blue-800{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.text-indigo-800{--tw-text-opacity: 1;color:rgb(55 48 163 / var(--tw-text-opacity, 1))}.text-orange-800{--tw-text-opacity: 1;color:rgb(154 52 18 / var(--tw-text-opacity, 1))}.text-pink-800{--tw-text-opacity: 1;color:rgb(157 23 77 / var(--tw-text-opacity, 1))}.text-purple-800{--tw-text-opacity: 1;color:rgb(107 33 168 / var(--tw-text-opacity, 1))}.text-teal-800{--tw-text-opacity: 1;color:rgb(17 94 89 / var(--tw-text-opacity, 1))}.text-yellow-800{--tw-text-opacity: 1;color:rgb(133 77 14 / var(--tw-text-opacity, 1))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}*{margin:0;padding:0;box-sizing:border-box}html{height:100%}html[data-theme=dark]{--bg-primary: linear-gradient(180deg, #1a1b26 0%, #343541 100%);--bg-secondary: rgba(255, 255, 255, .05);--bg-hover: rgba(255, 255, 255, .1);--bg-active: rgba(255, 255, 255, .15);--text-primary: #ececf1;--text-secondary: #a0a0a0;--border-color: rgba(255, 255, 255, .1);--border-hover: rgba(255, 255, 255, .2);--shadow: rgba(0, 0, 0, .3);--modal-bg: rgba(26, 27, 38, .95);--sidebar-bg: #1a1b26;--scrollbar-thumb: rgba(255, 255, 255, .1);--scrollbar-thumb-hover: rgba(255, 255, 255, .15)}html[data-theme=light]{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-hover: #f9fafb;--bg-active: #f3f4f6;--text-primary: #111827;--text-secondary: #4b5563;--border-color: #e5e7eb;--border-hover: #d1d5db;--shadow: rgba(0, 0, 0, .1);--modal-bg: #ffffff;--sidebar-bg: #ffffff;--scrollbar-thumb: rgba(0, 0, 0, .2);--scrollbar-thumb-hover: rgba(0, 0, 0, .3)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-y:auto;overflow-x:hidden;letter-spacing:0;transition:background .3s ease,color .3s ease}#root{min-height:100vh;width:100%}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}.admin-layout input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.admin-layout input[type=number]::-webkit-outer-spinner-button,.admin-layout input[type=number]::-webkit-inner-spinner-button{-webkit-appearance:none;margin:0}
