:root{--bg: #0f1115;--surface: #181b22;--surface-2: #1f242d;--border: #2a313c;--text: #e7eaf0;--text-dim: #9aa4b2;--primary: #4f8cff;--primary-hover: #3a78f0;--accent: #2dd4a7;--danger: #ef4565;--danger-hover: #d83a58;--success: #2dd4a7;--warning: #f5a623;--radius: 10px;--shadow: 0 8px 30px rgba(0, 0, 0, .35);--sidebar-w: 240px;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:var(--radius);padding:10px 16px;font-size:14px;font-weight:600;background:var(--surface-2);color:var(--text);transition:background .15s,border-color .15s,opacity .15s}.btn:hover{background:#272d38}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:transparent;color:var(--danger);border-color:var(--border)}.btn-danger:hover{background:#ef45651f;border-color:var(--danger)}.btn-ghost{background:transparent;border-color:var(--border)}.btn-ghost:hover{background:var(--surface-2)}.btn-sm{padding:6px 12px;font-size:13px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field label{font-size:13px;color:var(--text-dim);font-weight:600}.field .hint{font-size:12px;color:var(--text-dim);font-weight:400}.input,.select{width:100%;padding:11px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;outline:none;transition:border-color .15s}.input:focus,.select:focus{border-color:var(--primary)}.input::placeholder{color:#5c6473}.select{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;padding-right:38px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%239aa4b2' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.alert{padding:11px 14px;border-radius:var(--radius);font-size:14px;margin-bottom:16px}.alert-error{background:#ef45651f;border:1px solid rgba(239,69,101,.35);color:#ff8aa0}.alert-success{background:#2dd4a71f;border:1px solid rgba(45,212,167,.35);color:var(--success)}.alert-warn{background:#f5a6231f;border:1px solid rgba(245,166,35,.35);color:var(--warning)}.login-wrap{min-height:100%;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:var(--shadow)}.login-card h1{font-size:22px;margin:0 0 4px}.login-card .sub{color:var(--text-dim);font-size:14px;margin:0 0 24px}.brand-badge{display:inline-flex;align-items:center;gap:8px;font-weight:800;letter-spacing:.5px;margin-bottom:20px}.brand-badge .dot{width:10px;height:10px;border-radius:50%;background:var(--accent)}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:20px 14px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar .brand{display:flex;align-items:center;gap:10px;font-weight:800;padding:6px 10px 18px}.sidebar .brand .dot{width:10px;height:10px;border-radius:50%;background:var(--accent)}.nav{display:flex;flex-direction:column;gap:4px;flex:1}.nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--text-dim);font-size:14px;font-weight:600}.nav a:hover{background:var(--surface-2);color:var(--text)}.nav a.active{background:#4f8cff24;color:var(--primary)}.sidebar-foot{border-top:1px solid var(--border);padding-top:14px;font-size:13px;color:var(--text-dim)}.sidebar-foot .rest-name{color:var(--text);font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:8px}.sidebar-foot .rest-name img{width:26px;height:26px;border-radius:6px;object-fit:cover}.main{min-width:0}.main-head{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-bottom:1px solid var(--border);position:sticky;top:0;background:#0f1115d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5}.main-head h1{font-size:18px;margin:0}.content{padding:28px;max-width:1000px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 20px}.card .k{color:var(--text-dim);font-size:13px;margin-bottom:8px}.card .v{font-size:26px;font-weight:800}.panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.panel-head h3{margin:0;font-size:16px}.panel-body{padding:20px}.feature-row{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.feature-row:last-child{border-bottom:none}.feature-info .name{font-weight:700;font-size:15px}.feature-info .meta{color:var(--text-dim);font-size:12px;margin-top:4px}.feature-info .meta code{background:var(--surface-2);padding:1px 6px;border-radius:5px}.switch{position:relative;width:46px;height:26px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;transition:.2s}.switch .slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:var(--text-dim);border-radius:50%;transition:.2s}.switch input:checked+.slider{background:#2dd4a740;border-color:var(--accent)}.switch input:checked+.slider:before{transform:translate(20px);background:var(--accent)}.switch input:disabled+.slider{opacity:.5;cursor:not-allowed}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden}table{width:100%;border-collapse:collapse}thead th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim);padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}tbody td{padding:14px 16px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#ffffff05}.cell-actions{display:flex;gap:8px;justify-content:flex-end}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px}.badge-cur{background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim)}.badge-on{background:#2dd4a71f;color:var(--success)}.badge-off{background:#f5a6231f;color:var(--warning)}.badge-role{background:#4f8cff1f;color:var(--primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;padding:24px;z-index:50}.modal{width:100%;max-width:500px;max-height:90vh;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow)}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-head h3{margin:0;font-size:18px}.modal-body{padding:24px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:18px 24px;border-top:1px solid var(--border)}.x-btn{background:transparent;border:none;color:var(--text-dim);font-size:22px;line-height:1;padding:4px 8px;border-radius:8px}.x-btn:hover{background:var(--surface-2);color:var(--text)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.token-box{background:var(--bg);border:1px dashed var(--accent);border-radius:10px;padding:14px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12px;word-break:break-all;color:var(--accent);margin:12px 0}.state{text-align:center;padding:60px 20px;color:var(--text-dim)}.spinner{width:22px;height:22px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;display:inline-block;animation:spin .7s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.page-actions{display:flex;justify-content:flex-end;margin-bottom:18px}.link-cell{background:none;border:none;padding:0;color:var(--text);font-weight:700;font-size:14px;cursor:pointer;font-family:inherit}.link-cell:hover{color:var(--primary);text-decoration:underline}.detail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}.detail-actions{display:flex;gap:8px}.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px 24px}.info-row{display:flex;flex-direction:column;gap:6px}.info-k{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim)}.info-v{font-size:15px;font-weight:600}.phone-input{display:flex;gap:8px}.phone-input .phone-cc{width:98px;flex-shrink:0;padding-left:14px;padding-right:28px;font-weight:700;background-position:right 10px center}.phone-input .phone-num{flex:1;min-width:0;letter-spacing:1px}
