.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-box{background:#fff;padding:40px;border-radius:8px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-box h1{margin:0 0 8px;font-size:24px;color:#333;text-align:center}.login-box h2{margin:0 0 32px;font-size:18px;color:#666;text-align:center;font-weight:400}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:4px;font-size:14px;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:4px;margin-bottom:20px;font-size:14px;border:1px solid #fcc}.login-button{width:100%;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:500;cursor:pointer;transition:transform .2s}.login-button:hover:not(:disabled){transform:translateY(-2px)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}:root{--primary: #6366f1;--primary-light: #818cf8;--primary-dark: #4f46e5;--primary-bg: rgba(99, 102, 241, .1);--secondary: #06b6d4;--secondary-light: #22d3ee;--secondary-dark: #0891b2;--success: #10b981;--success-bg: rgba(16, 185, 129, .1);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .1);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .1);--info: #3b82f6;--info-bg: rgba(59, 130, 246, .1);--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-tertiary: #e2e8f0;--surface: #ffffff;--surface-hover: #f8fafc;--border: #e2e8f0;--border-light: #f1f5f9;--text-primary: #1e293b;--text-secondary: #64748b;--text-tertiary: #94a3b8;--text-inverse: #ffffff;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(99, 102, 241, .3);--glass-bg: rgba(255, 255, 255, .8);--glass-border: rgba(255, 255, 255, .3);--glass-blur: blur(12px);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,-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:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);min-height:100vh;color:var(--text-primary);line-height:1.6}.glass-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.glass-card:hover{box-shadow:var(--shadow-lg)}.glass-card-elevated{box-shadow:var(--shadow-xl)}.container{max-width:1400px;margin:0 auto;padding:var(--space-lg)}.card{background:var(--surface);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--space-lg);border:1px solid var(--border-light);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg)}.card h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm)}.header{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--text-inverse);padding:var(--space-lg) var(--space-xl);margin-bottom:var(--space-lg);border-radius:var(--radius-xl);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-lg),var(--shadow-glow);position:relative;overflow:hidden}.header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}.header h1{font-size:1.5rem;font-weight:700;margin-bottom:4px;position:relative}.header-subtitle{font-size:.875rem;opacity:.9}.header-actions{display:flex;align-items:center;gap:var(--space-sm)}.button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);background:var(--primary);color:var(--text-inverse);border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:500;transition:all var(--transition-fast);white-space:nowrap;position:relative;overflow:hidden}.button:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(rgba(255,255,255,.2),transparent);opacity:0;transition:opacity var(--transition-fast)}.button:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.button:hover:after{opacity:1}.button:active{transform:translateY(0)}.button:disabled{background:var(--text-tertiary);cursor:not-allowed;transform:none;box-shadow:none}.button-primary{background:linear-gradient(135deg,var(--success) 0%,#059669 100%)}.button-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.button-secondary:hover{background:var(--border);color:var(--text-primary)}.button-danger{background:linear-gradient(135deg,var(--danger) 0%,#dc2626 100%)}.button-success{background:linear-gradient(135deg,var(--success) 0%,#059669 100%);color:#fff}.button-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.button-ghost:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border)}.button-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md)}.button-sm{padding:var(--space-xs) var(--space-sm);font-size:.75rem}.button-lg{padding:var(--space-md) var(--space-xl);font-size:1rem}.logout-button{background:#ffffff26;color:var(--text-inverse);border:1px solid rgba(255,255,255,.2);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:500;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.logout-button:hover{background:#ffffff40;border-color:#fff6}.settings-button{background:#ffffff26;color:var(--text-inverse);border:1px solid rgba(255,255,255,.2);padding:var(--space-sm);border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.settings-button:hover{background:#ffffff40;transform:rotate(90deg)}.input,.select{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius-md);font-size:.9375rem;color:var(--text-primary);background:var(--surface);transition:all var(--transition-fast)}.input:hover,.select:hover{border-color:var(--primary-light)}.input:focus,.select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.input::placeholder{color:var(--text-tertiary)}.input:disabled,.select:disabled{background:var(--bg-secondary);color:var(--text-tertiary);cursor:not-allowed}.label{display:block;margin-bottom:var(--space-sm);font-weight:600;color:var(--text-primary);font-size:.875rem}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:18px;padding-right:44px}.table-container{overflow-x:auto;border-radius:var(--radius-md)}.table{width:100%;border-collapse:separate;border-spacing:0}.table th,.table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border-light)}.table th{background:var(--bg-secondary);font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;position:sticky;top:0;z-index:10}.table th:first-child{border-top-left-radius:var(--radius-md)}.table th:last-child{border-top-right-radius:var(--radius-md)}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--bg-secondary)}.table tbody tr.selected{background:var(--primary-bg)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.status-pending{background:var(--warning-bg);color:var(--warning)}.status-ready{background:var(--info-bg);color:var(--info)}.status-posting{background:var(--primary-bg);color:var(--primary);animation:pulse-badge 1.5s ease-in-out infinite}.status-posted{background:var(--success-bg);color:var(--success)}.status-error{background:var(--danger-bg);color:var(--danger)}.status-skipped{background:var(--bg-tertiary);color:var(--text-secondary)}.status-queued{background:#fef3cd;color:#856404}.status-duplicate{background:#e2e8f0;color:#64748b}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.6}}.status-online{color:var(--success)}.status-offline{color:var(--danger)}.status-tailscale{color:var(--warning)}.status-unknown{color:var(--text-tertiary)}.upload-section{border:2px dashed var(--primary-light);background:linear-gradient(135deg,var(--primary-bg) 0%,rgba(99,102,241,.05) 100%);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-normal)}.upload-section:hover{border-color:var(--primary);background:linear-gradient(135deg,rgba(99,102,241,.15) 0%,var(--primary-bg) 100%)}.upload-section.drag-over{border-color:var(--primary);background:var(--primary-bg);transform:scale(1.01)}.upload-section h3{color:var(--text-primary);margin-bottom:var(--space-sm);font-size:1.125rem;font-weight:600}.upload-context{background:var(--surface);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:.875rem;color:var(--text-secondary);border:1px solid var(--border-light)}.styled-file-input{display:block;width:100%;padding:16px;font-size:.9375rem;color:var(--text-primary);background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.styled-file-input:hover{border-color:var(--primary-light)}.styled-file-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.styled-file-input::file-selector-button{padding:10px 20px;margin-right:16px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--text-inverse);border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:all var(--transition-fast)}.styled-file-input::file-selector-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.toast{position:fixed;top:20px;right:20px;background:var(--surface);color:var(--text-primary);padding:16px 24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:1000;animation:toast-in .3s ease-out;display:flex;align-items:center;gap:12px;border-left:4px solid var(--primary);max-width:400px}.toast.success{border-left-color:var(--success)}.toast.error{border-left-color:var(--danger)}.toast.warning{border-left-color:var(--warning)}@keyframes toast-in{0%{transform:translate(100%) scale(.9);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--bg-secondary) 50%,var(--bg-tertiary) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{display:flex;flex-direction:column;gap:8px}.skeleton-card{padding:var(--space-lg);margin-bottom:var(--space-lg)}.skeleton-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.skeleton-card-body{display:flex;flex-direction:column;gap:var(--space-md)}.skeleton-config{padding:var(--space-lg);margin-bottom:var(--space-lg)}.skeleton-section{margin-bottom:var(--space-lg)}.skeleton-section:last-child{margin-bottom:0}.skeleton-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-top:var(--space-md)}.skeleton-flex{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.skeleton-table{padding:var(--space-lg)}.skeleton-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.skeleton-table-actions{display:flex;gap:var(--space-sm)}.skeleton-table-badges{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg)}.skeleton-table-body{display:flex;flex-direction:column;gap:var(--space-md)}.skeleton-table-row{display:grid;grid-template-columns:30px 80px 100px 1fr 100px 180px 90px;gap:var(--space-md);align-items:center;padding:var(--space-sm) 0;border-bottom:1px solid var(--border-light)}.skeleton-dashboard{display:flex;flex-direction:column;gap:var(--space-lg)}.skeleton-header{padding:var(--space-lg) var(--space-xl);display:flex;justify-content:space-between;align-items:center}.skeleton-header-left{display:flex;flex-direction:column;gap:var(--space-sm)}.skeleton-header-right{display:flex;gap:var(--space-sm)}.skeleton-breadcrumb{padding:var(--space-sm) 0}.skeleton-upload{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.skeleton-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}.skeleton-stat-card{padding:var(--space-md);display:flex;align-items:center;gap:var(--space-md)}.loading-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#fffc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.loading-overlay-content{padding:var(--space-xl);display:flex;flex-direction:column;align-items:center;gap:var(--space-md);font-weight:500;color:var(--text-secondary)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--text-secondary);gap:var(--space-md)}.progress-indicator{display:flex;align-items:center;gap:var(--space-xs)}.progress-step{display:flex;align-items:center;gap:var(--space-sm)}.progress-step-dot{width:28px;height:28px;border-radius:50%;background:var(--bg-tertiary);color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;transition:all var(--transition-normal)}.progress-step.completed .progress-step-dot{background:var(--success);color:#fff}.progress-step.active .progress-step-dot{background:var(--primary);color:#fff;box-shadow:0 0 0 4px var(--primary-bg)}.progress-step-label{font-size:.875rem;color:var(--text-tertiary);transition:color var(--transition-normal)}.progress-step.completed .progress-step-label,.progress-step.active .progress-step-label{color:var(--text-primary)}.progress-step-line{width:40px;height:2px;background:var(--border);margin:0 var(--space-sm)}.progress-step.completed+.progress-step .progress-step-line,.progress-step.completed .progress-step-line{background:var(--success)}.error{background:var(--danger-bg);border:1px solid var(--danger);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);color:var(--danger);margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm)}.warning-banner{background:var(--warning-bg);border:1px solid var(--warning);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);color:#92400e;margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm)}.breadcrumb{padding:var(--space-sm) 0;margin-bottom:var(--space-md)}.breadcrumb-list{list-style:none;display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-xs)}.breadcrumb-item{display:flex;align-items:center;font-size:.875rem}.breadcrumb-separator{color:var(--text-tertiary);margin:0 var(--space-sm)}.breadcrumb-link{color:var(--primary);cursor:pointer;transition:color var(--transition-fast);font-weight:500}.breadcrumb-link:hover{color:var(--primary-dark)}.breadcrumb-current{color:var(--text-primary);font-weight:600}.config-section{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--surface) 100%);padding:var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);border:1px solid var(--border-light)}.config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.config-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-weight:600}.config-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.config-item{display:flex;flex-direction:column;gap:var(--space-xs)}.config-item-label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.025em}.config-item-value{font-weight:600;color:var(--text-primary);font-size:1rem}.config-item-value.not-set{color:var(--danger)}.ledgers-info{background:var(--surface);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.ledgers-info.fetching{background:var(--warning-bg);border-color:var(--warning)}.ledgers-count{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-secondary)}.ledgers-count strong{color:var(--text-primary)}.filter-panel{background:var(--bg-secondary);padding:var(--space-lg);border-radius:var(--radius-md);margin-bottom:var(--space-lg);display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-md);align-items:end;animation:slide-down .2s ease-out}@keyframes slide-down{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filter-group{display:flex;flex-direction:column;gap:var(--space-xs)}.filter-label{font-size:.75rem;color:var(--text-secondary);font-weight:500}.filter-input{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;background:var(--surface);transition:all var(--transition-fast)}.filter-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg)}.bulk-actions{background:linear-gradient(135deg,var(--primary-bg) 0%,rgba(99,102,241,.05) 100%);border:1px solid var(--primary-light);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-lg);flex-wrap:wrap;animation:slide-down .2s ease-out}.bulk-actions-count{font-weight:600;color:var(--primary-dark);display:flex;align-items:center;gap:var(--space-sm)}.bulk-actions-controls{display:flex;gap:var(--space-sm);align-items:center;flex:1;min-width:300px}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.metric-card{background:var(--surface);padding:var(--space-lg);border-radius:var(--radius-lg);border:1px solid var(--border-light);display:flex;align-items:center;gap:var(--space-md);transition:all var(--transition-normal)}.metric-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-md)}.metric-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem}.metric-icon.pending{background:var(--warning-bg);color:var(--warning)}.metric-icon.ready{background:var(--info-bg);color:var(--info)}.metric-icon.posted{background:var(--success-bg);color:var(--success)}.metric-icon.error{background:var(--danger-bg);color:var(--danger)}.metric-content{flex:1}.metric-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:4px}.metric-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.metrics-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-lg)}.metrics-bar .metric-card{cursor:pointer;flex-direction:column;padding:var(--space-md);text-align:center;border:2px solid transparent;transition:all var(--transition-fast)}.metrics-bar .metric-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.metrics-bar .metric-card.active{border-color:var(--metric-color);box-shadow:0 0 0 3px #6366f126}.metric-card-count{font-size:1.75rem;font-weight:700;line-height:1;margin-bottom:4px}.metric-card-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.last-updated{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:.75rem;color:var(--text-tertiary);background:var(--bg-secondary);padding:4px 10px;border-radius:var(--radius-full)}.last-updated.stale{color:var(--warning);background:var(--warning-bg)}.last-updated:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.sidebar{width:280px;background:linear-gradient(180deg,#1e293b,#0f172a);color:var(--text-inverse);height:100vh;position:fixed;left:0;top:0;overflow-y:auto;transition:width var(--transition-normal);z-index:100;box-shadow:var(--shadow-xl)}.sidebar-collapsed{width:60px}.sidebar-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-lg);background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-toggle{background:#ffffff1a;border:none;color:#fff;cursor:pointer;padding:var(--space-sm);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.sidebar-toggle:hover{background:#fff3}.sidebar-title{font-weight:600;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-company-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);cursor:pointer;transition:all var(--transition-fast);font-size:.875rem;border-left:3px solid transparent}.sidebar-company-header:hover{background:#ffffff0d}.sidebar-company-header.selected{background:#6366f133;border-left-color:var(--primary)}.sidebar-bank{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg) var(--space-sm) var(--space-2xl);cursor:pointer;font-size:.8125rem;transition:all var(--transition-fast);color:#ffffffb3}.sidebar-bank:hover{background:#ffffff0d;color:#fff}.sidebar-bank.selected{background:#6366f126;color:#fff}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;animation:fade-in .2s ease-out}.settings-drawer{position:fixed;right:0;top:0;width:420px;max-width:90vw;height:100vh;background:var(--bg-primary);z-index:201;display:flex;flex-direction:column;box-shadow:-8px 0 32px #0000004d;animation:slide-in-right .3s ease-out}@keyframes slide-in-right{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--border);background:var(--surface)}.drawer-header h2{display:flex;align-items:center;gap:var(--space-sm);margin:0;font-size:1.125rem}.drawer-close-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.drawer-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.drawer-content{flex:1;overflow-y:auto;padding:var(--space-lg)}.drawer-content .card{box-shadow:none;border:1px solid var(--border)}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:var(--space-sm) var(--space-md);padding-bottom:max(var(--space-sm),env(safe-area-inset-bottom));z-index:100;justify-content:space-around}.mobile-nav-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-sm) var(--space-md);background:transparent;border:none;color:var(--text-secondary);font-size:.6875rem;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);min-width:64px}.mobile-nav-btn:hover,.mobile-nav-btn.active{background:var(--primary-bg);color:var(--primary)}.mobile-nav-btn svg{width:24px;height:24px}.sidebar.mobile-open{position:fixed;left:0;top:0;z-index:250;animation:slide-in-left .3s ease-out}.sidebar-mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:249}@media screen and (max-width: 1024px){.container{padding:var(--space-md)}.header{flex-direction:column;gap:var(--space-md);text-align:center;padding:var(--space-md)}.config-grid,.skeleton-grid{grid-template-columns:1fr}.skeleton-table-row{grid-template-columns:30px 1fr 80px}}@media screen and (max-width: 768px){:root{--space-lg: 16px;--space-xl: 24px}.header h1{font-size:1.25rem}.card{padding:var(--space-md);border-radius:var(--radius-md)}.table th,.table td{padding:10px 12px;font-size:.8125rem}.metrics-grid{grid-template-columns:repeat(2,1fr)}.filter-panel{grid-template-columns:1fr}.bulk-actions{flex-direction:column;align-items:stretch}.bulk-actions-controls{min-width:auto}.skeleton-stats{grid-template-columns:repeat(2,1fr)}.dashboard-layout{grid-template-columns:1fr}.dashboard-layout .sidebar{display:none}.dashboard-layout .sidebar.mobile-open{display:flex;width:280px}.mobile-nav{display:flex}.dashboard-main{padding-bottom:80px}.settings-drawer{width:100%;max-width:100%}.metrics-bar{grid-template-columns:repeat(2,1fr)}.header-actions{flex-wrap:wrap;justify-content:center}}@media screen and (max-width: 480px){.header{padding:var(--space-md);border-radius:var(--radius-md)}.metrics-grid{grid-template-columns:1fr}.metrics-bar{grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}.metrics-bar .metric-card{padding:var(--space-sm)}.metric-card-count{font-size:1.25rem}.skeleton-stats{grid-template-columns:1fr}.progress-indicator{flex-direction:column;align-items:flex-start}.progress-step-line{width:2px;height:20px;margin:var(--space-xs) 0 var(--space-xs) 13px}}@media (hover: none) and (pointer: coarse){.button{min-height:44px;min-width:44px}.input,.select{min-height:48px;font-size:16px}input[type=checkbox]{width:22px;height:22px}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fade-in .3s ease-out}.animate-slide-up{animation:slide-up .4s ease-out}.animate-scale-in{animation:scale-in .3s ease-out}.stagger-children>*{opacity:0;animation:slide-up .4s ease-out forwards}.stagger-children>*:nth-child(1){animation-delay:0ms}.stagger-children>*:nth-child(2){animation-delay:50ms}.stagger-children>*:nth-child(3){animation-delay:.1s}.stagger-children>*:nth-child(4){animation-delay:.15s}.stagger-children>*:nth-child(5){animation-delay:.2s}input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border:2px solid var(--border);border-radius:4px;background:var(--surface);cursor:pointer;transition:all var(--transition-fast);position:relative}input[type=checkbox]:hover{border-color:var(--primary)}input[type=checkbox]:checked{background:var(--primary);border-color:var(--primary)}input[type=checkbox]:checked:after{content:"";position:absolute;left:5px;top:2px;width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 3px var(--primary-bg)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.dashboard-layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh;width:100%}.dashboard-layout.sidebar-collapsed{grid-template-columns:60px 1fr}.dashboard-layout .sidebar{position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid var(--border)}.dashboard-main{padding:var(--space-lg);overflow-y:auto;min-height:100vh;background:var(--bg)}.sidebar-bank-badge{background:var(--warning);color:#fff;padding:2px 8px;border-radius:10px;font-size:.75rem;font-weight:600;margin-left:auto}.sidebar-bank-badge.zero{background:var(--text-tertiary);opacity:.5}.feature-flag-toggle{position:fixed;bottom:20px;right:20px;background:#6366f1;border:none;border-radius:8px;padding:12px 20px;font-size:.875rem;font-weight:600;cursor:pointer;z-index:99999;display:flex;align-items:center;gap:10px;box-shadow:0 4px 12px #6366f166;color:#fff;transition:all .2s ease}.feature-flag-toggle:hover{background:#4f46e5;transform:translateY(-2px);box-shadow:0 6px 16px #6366f180}.feature-flag-toggle svg{stroke:#fff}@media (max-width: 768px){.dashboard-layout{grid-template-columns:1fr}.dashboard-layout .sidebar{display:none}.dashboard-layout .sidebar.mobile-open{display:block;position:fixed;top:0;right:0;bottom:0;left:0;width:320px;z-index:300;animation:slide-in-left .2s ease-out}.dashboard-main{padding:var(--space-md)}}@keyframes slide-in-left{0%{transform:translate(-100%)}to{transform:translate(0)}}.header-bar-v2{display:flex;align-items:center;gap:16px;padding:12px 24px;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-dropdown-group{display:flex;align-items:center}.header-select-v2{padding:8px 32px 8px 12px;border:1px solid var(--border);border-radius:6px;background:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;min-width:180px;font-size:.9rem;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;transition:border-color .15s,box-shadow .15s}.header-select-v2:hover{border-color:var(--primary)}.header-select-v2:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.header-select-v2:disabled{background-color:var(--bg-secondary);cursor:not-allowed;opacity:.6}.header-spacer{flex:1}.header-ledger-info-v2{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.85rem}.header-ledger-count{font-weight:500}.header-sync-time-v2{color:var(--text-muted)}.header-refresh-btn-v2{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:var(--bg-secondary);border-radius:6px;cursor:pointer;color:var(--text-secondary);transition:all .15s}.header-refresh-btn-v2:hover{background:var(--bg-tertiary);color:var(--primary)}.header-refresh-btn-v2:disabled{cursor:wait;opacity:.7}.header-tally-status-v2{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:500}.header-tally-status-v2.connected{background:#10b9811a;color:#10b981}.header-tally-status-v2.offline{background:#ef44441a;color:#ef4444}.status-dot-v2{width:8px;height:8px;border-radius:50%;background:currentColor}.header-tally-status-v2.connected .status-dot-v2{animation:pulse-dot 2s ease-in-out infinite}.sidebar-v2{width:260px;height:100vh;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px;position:sticky;top:0;transition:width .2s ease;overflow-y:auto;overflow-x:hidden}.sidebar-v2.collapsed{width:70px;padding:16px 8px}.sidebar-collapse-toggle{position:absolute;right:-12px;top:20px;width:24px;height:24px;border-radius:50%;background:#fff;border:1px solid var(--border);cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text-muted);transition:all .15s}.sidebar-collapse-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-user{text-align:center;margin-bottom:24px;padding-top:8px}.sidebar-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#818cf8);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.2rem;margin:0 auto 12px;box-shadow:0 4px 12px #6366f14d}.sidebar-v2.collapsed .sidebar-avatar{width:40px;height:40px;font-size:.9rem}.sidebar-user-name{font-weight:600;font-size:1rem;color:var(--text-primary)}.sidebar-user-email{color:var(--text-muted);font-size:.85rem;word-break:break-all}.sidebar-info{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s;color:var(--text-primary)}.sidebar-item:hover{background:var(--bg-secondary)}.sidebar-v2.collapsed .sidebar-item{justify-content:center;padding:10px}.sidebar-icon{font-size:1.1rem;flex-shrink:0;width:24px;text-align:center}.sidebar-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.sidebar-value{font-weight:500;font-size:.9rem}.sidebar-value.credit{color:#10b981;font-weight:600}.sidebar-install-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:var(--primary);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:.9rem;margin-bottom:16px;transition:all .15s}.sidebar-install-btn:hover{background:var(--primary-hover);transform:translateY(-1px)}.sidebar-v2.collapsed .sidebar-install-btn{padding:12px}.sidebar-v2.collapsed .sidebar-install-btn span:last-child{display:none}.sidebar-settings{border-top:1px solid var(--border);padding-top:16px;margin-top:auto}.sidebar-settings-header{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s}.sidebar-settings-header:hover{background:var(--bg-secondary)}.sidebar-chevron{margin-left:auto;color:var(--text-muted);transition:transform .2s}.sidebar-settings-items{margin-top:8px;padding-left:8px}.sidebar-port-input{width:70px;padding:4px 8px;border:1px solid var(--border);border-radius:4px;margin-left:auto;font-size:.85rem}.sidebar-toggle-badge{margin-left:auto;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;background:var(--primary);color:#fff}.sidebar-signout{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;color:#ef4444;margin-top:16px;transition:background .15s}.sidebar-signout:hover{background:#ef44441a}.sidebar-v2.collapsed .sidebar-signout{justify-content:center}.status-tabs{display:flex;gap:0;padding:0;background:#fff;border-bottom:1px solid #e5e7eb;margin-bottom:16px}.status-tab{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;height:48px;min-height:48px;border:none;border-bottom:2px solid transparent;background:transparent;cursor:pointer;font-weight:500;font-size:.9rem;color:#6b7280;transition:all .15s ease;white-space:nowrap}.status-tab:hover{background:#f9fafb;color:#374151}.status-tab.active{background:transparent;border-bottom-color:#3b82f6;color:#3b82f6}.status-tab-icon{display:flex;align-items:center;font-size:1rem}.status-tab-label{font-weight:500}.status-tab-count{background:#f3f4f6;padding:2px 10px;border-radius:12px;font-size:.8rem;font-weight:600;color:#6b7280;min-width:24px;text-align:center}.status-tab.active .status-tab-count{background:#dbeafe;color:#3b82f6}.logs-modal{max-width:600px;max-height:70vh}.logs-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.log-entry{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--bg-secondary);border-radius:8px;font-size:.9rem}.log-time{color:var(--text-muted);font-size:.8rem;white-space:nowrap}.log-message{flex:1}.log-entry.log-upload{border-left:3px solid var(--primary)}.log-entry.log-post{border-left:3px solid #10b981}.log-entry.log-error{border-left:3px solid #ef4444}@media (max-width: 1024px){.header-bar-v2{flex-wrap:wrap;gap:12px}.header-select-v2{min-width:150px}.header-spacer{display:none}.header-ledger-info-v2{margin-left:auto}}@media (max-width: 768px){.header-bar-v2{padding:12px 16px}.header-select-v2{min-width:120px;font-size:.85rem}.header-ledger-info-v2{display:none}.sidebar-v2{position:fixed;left:0;top:0;z-index:300;transform:translate(-100%);transition:transform .2s ease}.sidebar-v2.mobile-open{transform:translate(0)}}.dashboard-v2{display:grid;grid-template-columns:auto 1fr;min-height:100vh;background:var(--bg-primary)}.dashboard-v2-main{display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden}.dashboard-v2-content{flex:1;padding:24px;overflow-y:auto}.transaction-review-section{background:#fff;border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);margin-top:24px}.section-title-v2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:16px;display:flex;align-items:center;gap:8px}.clickable-row{cursor:pointer;transition:background .15s ease}.clickable-row:hover{background:var(--bg-secondary)!important}.clickable-row.selected{background:#6366f114!important}@media (max-width: 1024px){.dashboard-v2{grid-template-columns:1fr}.dashboard-v2-content,.transaction-review-section{padding:16px}}@media (max-width: 768px){.dashboard-v2{grid-template-columns:1fr}.dashboard-v2-content{padding:12px}.status-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.status-tab{padding:12px 16px;height:44px;min-height:44px;font-size:.85rem}.status-tab-label{display:none}}.sidebar-v2{width:280px;height:100vh;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 16px;position:sticky;top:0;transition:width .2s ease;overflow-y:auto}.sidebar-v2.collapsed{width:72px;padding:20px 8px}.sidebar-collapse-toggle-v2{position:absolute;right:-12px;top:24px;width:24px;height:24px;border-radius:50%;background:#fff;border:1px solid var(--border);cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:all .15s}.sidebar-collapse-toggle-v2:hover{background:var(--bg-secondary)}.sidebar-user-v2{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.sidebar-avatar-v2{width:56px;height:56px;min-width:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.2rem;box-shadow:0 4px 12px #6366f14d}.sidebar-v2.collapsed .sidebar-avatar-v2{width:44px;height:44px;font-size:1rem}.sidebar-user-name-v2{font-weight:600;font-size:1rem;color:var(--text-primary);margin-bottom:4px}.sidebar-user-email-v2{color:var(--text-tertiary);font-size:.8rem;word-break:break-all}.sidebar-user-info{flex:1;text-align:left}.sidebar-user-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.sidebar-user-expand{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-tertiary);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s}.sidebar-user-expand:hover{background:var(--bg-secondary);color:var(--primary)}.sidebar-live-indicator{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:4px 10px;background:#6366f11a;border-radius:12px;font-size:11px}.live-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:livePulse 2s infinite}.live-text{color:#6366f1;font-weight:600}.live-time{color:var(--text-tertiary)}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.sidebar-user-details{background:var(--bg-secondary);border-radius:8px;padding:12px;margin-bottom:16px;display:flex;flex-direction:column;gap:8px}.sidebar-detail-row{display:flex;align-items:center;gap:10px;font-size:.8rem;color:var(--text-secondary)}.sidebar-detail-row svg{flex-shrink:0;color:var(--text-tertiary)}.sidebar-detail-row span{word-break:break-all}.sidebar-info-v2{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.sidebar-item-v2{display:flex;align-items:center;gap:12px;padding:12px 14px;min-height:48px;border-radius:10px;cursor:pointer;transition:all .15s;color:var(--text-primary);font-size:.9rem}.sidebar-item-v2:hover{background:var(--bg-secondary)}.sidebar-item-v2.copied,.sidebar-item-v2.credit-balance:hover{background:#10b9811a}.sidebar-item-v2.low-balance{background:#ef44440d}.sidebar-item-v2.low-balance:hover{background:#ef44441a}.sidebar-v2.collapsed .sidebar-item-v2{justify-content:center;padding:10px}.sidebar-icon-v2{flex-shrink:0;width:20px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.sidebar-item-content{flex:1;min-width:0}.sidebar-label-v2{font-size:.7rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.sidebar-value-v2{font-weight:500;font-size:.9rem}.sidebar-value-v2.credit{color:#10b981;font-weight:600}.sidebar-value-v2.credit.low{color:#ef4444}.low-balance-warning{margin-left:4px;color:#ef4444;font-weight:700}.sidebar-item-text{font-size:.9rem}.sidebar-install-btn-v2{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 18px;min-height:50px;background:var(--primary);color:#fff;border:none;border-radius:10px;cursor:pointer;font-weight:600;font-size:.95rem;margin-bottom:16px;transition:all .15s;width:100%}.sidebar-install-btn-v2:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.sidebar-install-btn-v2:disabled{opacity:.7;cursor:wait}.sidebar-spacer{flex:1}.sidebar-settings-v2{border-top:1px solid var(--border);padding-top:16px}.sidebar-settings-header-v2{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s;color:var(--text-primary)}.sidebar-settings-header-v2:hover,.sidebar-settings-header-v2.open{background:var(--bg-secondary)}.sidebar-chevron-v2{margin-left:auto;color:var(--text-tertiary);transition:transform .2s}.sidebar-settings-items-v2{margin-top:8px;padding-left:12px}.sidebar-item-v2.nested{padding:8px 12px;font-size:.85rem}.sidebar-item-v2.port-item{display:flex;gap:8px}.sidebar-port-input-v2{width:70px;padding:4px 8px;border:1px solid var(--border);border-radius:4px;margin-left:auto;font-size:.85rem}.sidebar-port-input-v2:focus{outline:none;border-color:var(--primary)}.sidebar-layout-badge{margin-left:auto;padding:2px 8px;border-radius:4px;font-size:.65rem;font-weight:600;text-transform:uppercase}.sidebar-layout-badge.new{background:var(--primary);color:#fff}.sidebar-layout-badge.classic{background:var(--bg-tertiary);color:var(--text-secondary)}.sidebar-whatsapp-v2{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;color:#25d366;text-decoration:none;transition:background .15s;margin-bottom:8px}.sidebar-whatsapp-v2:hover{background:#25d3661a}.sidebar-whatsapp-v2 .whatsapp-icon{color:#25d366}.sidebar-v2.collapsed .sidebar-whatsapp-v2{justify-content:center}.sidebar-signout-v2{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;color:#ef4444;margin-top:16px;transition:background .15s}.sidebar-signout-v2:hover{background:#ef44441a}.sidebar-v2.collapsed .sidebar-signout-v2{justify-content:center}.logs-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;animation:fade-in .2s ease}.logs-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:600px;max-height:80vh;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:1001;display:flex;flex-direction:column;animation:slide-up .2s ease}.logs-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.logs-modal-header h2{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.logs-modal-close{background:none;border:none;cursor:pointer;padding:8px;border-radius:8px;color:var(--text-secondary);transition:all .15s}.logs-modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.logs-modal-body{flex:1;overflow-y:auto;padding:16px 24px}.logs-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:var(--text-tertiary);gap:12px}.logs-loading .spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.logs-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:var(--text-tertiary);text-align:center}.logs-empty svg{opacity:.3;margin-bottom:16px}.logs-empty p{font-size:1rem;margin-bottom:4px;color:var(--text-secondary)}.logs-empty span{font-size:.85rem}.logs-list{display:flex;flex-direction:column;gap:8px}.log-entry{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:8px;background:var(--bg-secondary);transition:background .15s}.log-entry:hover{background:var(--bg-tertiary)}.log-icon{flex-shrink:0;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#fff}.log-content{flex:1;min-width:0}.log-message{font-size:.9rem;color:var(--text-primary);margin-bottom:2px}.log-details{font-size:.8rem;color:var(--text-tertiary)}.log-time{flex-shrink:0;font-size:.75rem;color:var(--text-tertiary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1100;display:flex;align-items:center;justify-content:center;animation:fade-in .2s ease}.modal-content{background:#fff;border-radius:12px;padding:24px;width:90%;max-width:400px;box-shadow:0 20px 60px #0000004d;animation:slide-up .2s ease}.modal-content h3{margin:0 0 8px;font-size:1.25rem;font-weight:600;color:#111827}.modal-description{margin:0 0 16px;font-size:.9rem;color:#6b7280}.modal-input{width:100%;padding:12px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;margin-bottom:20px;box-sizing:border-box}.modal-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.modal-btn{padding:10px 20px;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s}.modal-btn-secondary{background:#f3f4f6;border:1px solid #d1d5db;color:#374151}.modal-btn-secondary:hover{background:#e5e7eb}.modal-btn-primary{background:#3b82f6;border:none;color:#fff}.modal-btn-primary:hover{background:#2563eb}.modal-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.log-error .log-icon{background:#ef44441a;color:#ef4444}.log-success .log-icon{background:#10b9811a;color:#10b981}.log-info .log-icon{background:#6366f11a;color:var(--primary)}.log-warning .log-icon{background:#f59e0b1a;color:#f59e0b}.log-default .log-icon{background:var(--bg-tertiary);color:var(--text-secondary)}@keyframes slide-up{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.status-badges-row{display:flex;flex-direction:row;gap:12px;margin:16px 0;align-items:stretch}.status-pill{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 16px;height:36px;line-height:36px;border-radius:18px;font-size:.8rem;font-weight:600;border:1.5px solid;cursor:pointer;transition:all .15s ease;white-space:nowrap;box-sizing:border-box}.status-pill:hover{transform:translateY(-1px);box-shadow:0 2px 6px #0000001f}.status-pill .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;display:inline-block}.status-pill.pending{background:#fffbeb;border-color:#fbbf24;color:#92400e}.status-pill.pending .dot{background:#f59e0b}.status-pill.pending.active{background:#fbbf24;border-color:#f59e0b;color:#78350f}.status-pill.pending.active .dot{background:#78350f}.status-pill.ready{background:#ecfdf5;border-color:#34d399;color:#065f46}.status-pill.ready .dot{background:#10b981}.status-pill.ready.active{background:#34d399;border-color:#10b981;color:#064e3b}.status-pill.ready.active .dot{background:#064e3b}.status-pill.error{background:#fef2f2;border-color:#f87171;color:#991b1b}.status-pill.error .dot{background:#ef4444}.status-pill.error.active{background:#f87171;border-color:#ef4444;color:#7f1d1d}.status-pill.error.active .dot{background:#7f1d1d}
