@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #4f46e5;--primary-hover: #4338ca;--primary-light: #eef2ff;--primary-50: #e0e7ff;--bg: #f8fafc;--bg-alt: #f1f5f9;--surface: #ffffff;--text: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--text-light: #94a3b8;--border: #e2e8f0;--border-light: #f1f5f9;--border-hover: #cbd5e1;--danger: #ef4444;--danger-hover: #dc2626;--danger-light: #fef2f2;--success: #10b981;--success-hover: #059669;--success-light: #ecfdf5;--warning: #f59e0b;--warning-light: #fffbeb;--radius: 12px;--radius-sm: 8px;--radius-xs: 6px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-focus: 0 0 0 3px rgba(79, 70, 229, .15);--transition: .2s cubic-bezier(.4, 0, .2, 1)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--primary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--primary-hover)}button{cursor:pointer;border:none;border-radius:var(--radius-sm);padding:.5rem 1.125rem;font-size:.8125rem;font-weight:500;font-family:inherit;transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:.375rem;line-height:1.5}button:disabled{opacity:.55;cursor:not-allowed;transform:none!important;box-shadow:none!important}button.primary{background:var(--primary);color:#fff;box-shadow:0 1px 2px #4f46e54d}button.primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 12px #4f46e54d;transform:translateY(-1px)}button.primary:active:not(:disabled){transform:translateY(0)}button.danger{background:var(--danger);color:#fff;box-shadow:0 1px 2px #ef44444d}button.danger:hover:not(:disabled){background:var(--danger-hover);box-shadow:0 4px 12px #ef444440}button.secondary{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border);box-shadow:var(--shadow-xs)}button.secondary:hover:not(:disabled){background:var(--bg-alt);border-color:var(--border-hover);box-shadow:var(--shadow)}button.ghost{background:transparent;color:var(--text-muted);padding:.375rem .625rem}button.ghost:hover:not(:disabled){background:var(--bg-alt);color:var(--text)}input,select,textarea{border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5625rem .875rem;font-size:.8125rem;width:100%;outline:none;transition:all var(--transition);background:var(--surface);color:var(--text);font-family:inherit;line-height:1.5}input:hover:not(:focus),select:hover:not(:focus),textarea:hover:not(:focus){border-color:var(--border-hover)}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:var(--shadow-focus)}input::placeholder,textarea::placeholder{color:var(--text-light)}textarea{resize:vertical;min-height:60px}select{cursor:pointer}input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);transition:box-shadow var(--transition)}.card-header{display:flex;align-items:center;gap:.625rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border-light)}.card-header h2{font-size:1rem;font-weight:600;color:var(--text);flex:1}.card-header .card-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.card-header .card-desc{font-size:.75rem;color:var(--text-muted);font-weight:400}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.75rem}.page-title{font-size:1.5rem;font-weight:700;color:var(--text);letter-spacing:-.025em}.page-subtitle{font-size:.875rem;color:var(--text-muted);margin-top:.25rem;font-weight:400}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.8125rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;font-weight:500;line-height:1.4}.alert:before{font-size:1rem;flex-shrink:0}.alert-success{background:var(--success-light);color:#065f46;border:1px solid #a7f3d0}.alert-success:before{content:"✓";color:var(--success)}.alert-error{background:var(--danger-light);color:#991b1b;border:1px solid #fecaca}.alert-error:before{content:"!";color:var(--danger);font-weight:700}.alert-warning{background:var(--warning-light);color:#92400e;border:1px solid #fde68a}.alert-warning:before{content:"⚠"}.form-label{display:block;margin-bottom:.375rem;font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column}.form-help{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.form-actions{display:flex;gap:.625rem;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border-light)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:.8125rem}table thead th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0}table tbody td{padding:.75rem 1rem;border-bottom:1px solid var(--border-light);color:var(--text-secondary)}table tbody tr:last-child td{border-bottom:none}table tbody tr{transition:background var(--transition)}table tbody tr:hover{background:var(--bg)}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.1875rem .625rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;white-space:nowrap;letter-spacing:.01em}.badge:before{content:"";width:6px;height:6px;border-radius:50%;flex-shrink:0}.badge-pending{background:#fef3c7;color:#92400e}.badge-pending:before{background:#f59e0b}.badge-accepted{background:#d1fae5;color:#065f46}.badge-accepted:before{background:#10b981}.badge-refused{background:#fee2e2;color:#991b1b}.badge-refused:before{background:#ef4444}.badge-admin{background:var(--primary-light);color:var(--primary)}.badge-admin:before{background:var(--primary)}.badge-user{background:var(--bg-alt);color:var(--text-muted)}.badge-user:before{background:var(--text-light)}.mono{font-family:SF Mono,Fira Code,Cascadia Code,JetBrains Mono,Menlo,monospace;font-size:.75rem;letter-spacing:-.01em}.dots-btn{background:none;border:1px solid transparent;width:32px;height:32px;padding:0;border-radius:var(--radius-xs);font-size:1.125rem;line-height:1;color:var(--text-light);cursor:pointer;transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center}.dots-btn:hover{background:var(--bg-alt);border-color:var(--border);color:var(--text)}.dots-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);min-width:180px;z-index:10000;padding:.375rem;animation:dropIn .15s ease}.dots-dropdown button{display:flex;width:100%;text-align:left;padding:.5rem .75rem;font-size:.8125rem;border-radius:var(--radius-xs);background:none;color:var(--text-secondary);white-space:nowrap;gap:.5rem}.dots-dropdown button:hover{background:var(--bg-alt);color:var(--text)}.dots-dropdown button.text-danger{color:var(--danger)}.dots-dropdown button.text-danger:hover{background:var(--danger-light);color:var(--danger-hover)}.dots-dropdown .separator{height:1px;background:var(--border-light);margin:.375rem 0}@keyframes dropIn{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--text-muted)}.empty-state p{font-size:.875rem;line-height:1.6}.skeleton{background:linear-gradient(90deg,var(--bg-alt) 25%,var(--border-light) 50%,var(--bg-alt) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-xs);height:1rem}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.search-bar{display:flex;gap:.5rem;margin-bottom:1.25rem}.search-bar input{flex:1}.filter-bar{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:flex-end}.filter-bar>div{min-width:160px}.table-footer{padding:.75rem 1rem;font-size:.75rem;color:var(--text-muted);background:var(--bg);border-top:1px solid var(--border-light);border-radius:0 0 var(--radius) var(--radius)}.status-indicator{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500}.status-indicator .status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-connected{background:var(--success-light);border:1px solid #a7f3d0}.status-connected .status-dot{background:var(--success)}.status-disconnected{background:var(--danger-light);border:1px solid #fecaca}.status-disconnected .status-dot{background:var(--danger);animation:none}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);transition:all var(--transition)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card .stat-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.stat-card .stat-value{font-size:1.75rem;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1.2}.stat-card .stat-sub{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}@media(max-width:768px){.form-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.filter-bar{flex-direction:column}.stat-grid{grid-template-columns:1fr 1fr}}@media(max-width:480px){.stat-grid{grid-template-columns:1fr}}
