/* BookSignal — Admin Panel */
*{box-sizing:border-box;margin:0;padding:0}
body{background:#0f172a;color:#e2e8f0;font-family:Inter,system-ui,sans-serif;font-size:14px;min-height:100vh}

/* Topbar */
.admin-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#1e293b;border-bottom:1px solid rgba(255,255,255,.08)}
.admin-brand{font-size:18px;color:#f8fafc;font-weight:400}
.admin-brand b{font-weight:700}
.admin-badge{font-size:11px;background:#6366f1;color:#fff;padding:2px 8px;border-radius:4px;margin-left:8px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.admin-topright{display:flex;align-items:center;gap:16px}
.admin-back{color:#94a3b8;text-decoration:none;font-size:13px}
.admin-back:hover{color:#fff}

/* Loading / denied */
.admin-loading,.admin-denied{text-align:center;padding:80px 20px;color:#94a3b8;font-size:16px}
.admin-denied a{color:#6366f1}

/* Layout */
.admin-wrap{max-width:1400px;margin:0 auto;padding:24px}

/* Tabs */
.admin-tabs{display:flex;gap:4px;margin-bottom:20px}
.admin-tabs button{background:none;border:none;color:#94a3b8;font-size:14px;font-family:inherit;padding:8px 20px;cursor:pointer;border-radius:6px;font-weight:500}
.admin-tabs button.active{background:#334155;color:#f8fafc}
.admin-tabs button:hover:not(.active){color:#cbd5e1}

/* Panel */
.admin-panel{animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* Filters */
.admin-filters{display:flex;gap:12px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.admin-filters input,.admin-filters select{background:#1e293b;border:1px solid rgba(255,255,255,.12);color:#e2e8f0;padding:8px 12px;border-radius:6px;font-size:13px;font-family:inherit}
.admin-filters input{min-width:220px}
.admin-filters input::placeholder{color:#64748b}
.admin-filters input:focus,.admin-filters select:focus{outline:none;border-color:#6366f1}
.admin-filters input:-webkit-autofill,.admin-filters input:-webkit-autofill:hover,.admin-filters input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 30px #1e293b inset!important;-webkit-text-fill-color:#e2e8f0!important;caret-color:#e2e8f0}

/* Count */
.admin-count{color:#64748b;font-size:12px;margin-bottom:10px}

/* Table */
.admin-table{width:100%;border-collapse:collapse;background:#1e293b;border-radius:8px;overflow:hidden}
.admin-table thead{background:#334155}
.admin-table th{text-align:left;padding:10px 12px;font-weight:600;font-size:12px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.admin-table td{padding:9px 12px;border-top:1px solid rgba(255,255,255,.05);font-size:13px}
.admin-table tbody tr:hover{background:rgba(255,255,255,.03)}
.sortable{cursor:pointer;user-select:none}
.sortable:hover{color:#cbd5e1}
.empty-row{text-align:center;color:#64748b;padding:24px!important}

/* Plan badges */
.plan-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}
.plan-badge.free{background:rgba(100,116,139,.2);color:#94a3b8}
.plan-badge.standard{background:rgba(59,130,246,.15);color:#60a5fa}
.plan-badge.premium{background:rgba(168,85,247,.15);color:#c084fc}
.plan-badge.unlimited{background:rgba(234,179,8,.15);color:#facc15}

/* Event badges */
.event-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}
.event-badge.payment{background:rgba(34,197,94,.15);color:#4ade80}
.event-badge.refund{background:rgba(239,68,68,.15);color:#f87171}
.event-badge.cancelled{background:rgba(249,115,22,.15);color:#fb923c}
.event-badge.rebill_fail{background:rgba(239,68,68,.1);color:#fca5a5}

/* Toggle button */
.toggle-btn{border:none;padding:3px 10px;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit}
.toggle-btn.on{background:rgba(34,197,94,.15);color:#4ade80}
.toggle-btn.off{background:rgba(239,68,68,.12);color:#f87171}
.toggle-btn:hover{filter:brightness(1.2)}

/* Link button */
.btn-link{background:none;border:none;color:#6366f1;cursor:pointer;font-family:inherit;font-size:13px;text-decoration:underline}
.btn-link:hover{color:#818cf8}

/* Table bar (count left, show dropdown right) */
.admin-table-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}

/* Filter label */
.filter-label{color:#94a3b8;font-size:13px;display:inline-flex;align-items:center;gap:8px}
.filter-right{margin-left:auto}

/* Small button */
.btn-sm{background:#334155;border:none;color:#e2e8f0;padding:8px 16px;border-radius:6px;font-size:13px;font-family:inherit;cursor:pointer}
.btn-sm:hover{background:#475569}

/* Inline select in table */
.admin-table select{background:#0f172a;border:1px solid rgba(255,255,255,.1);color:#e2e8f0;padding:4px 8px;border-radius:4px;font-size:12px;font-family:inherit;cursor:pointer}
.admin-table select:focus{outline:none;border-color:#6366f1}

/* User orders panel (inline below users table) */
.user-orders-panel{margin-top:16px;padding:16px;background:#1a2332;border:1px solid rgba(99,102,241,.2);border-radius:8px}
.user-orders-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.user-orders-header h3{font-size:14px;font-weight:600;color:#c084fc}
.compact td,.compact th{padding:7px 10px;font-size:12px}
.muted{color:#64748b}
.text-danger{color:#f87171;font-weight:600}
.text-admin{color:#6366f1;font-weight:600}

/* Add User button */
.btn-add{background:#6366f1;border:none;color:#fff;padding:7px 14px;border-radius:6px;font-size:13px;font-family:inherit;cursor:pointer;font-weight:600}
.btn-add:hover{background:#818cf8}

/* Add User form */
.add-user-form{background:#1a2332;border:1px solid rgba(99,102,241,.2);border-radius:8px;padding:16px;margin-bottom:14px;animation:fadeIn .15s ease}
.add-user-fields{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.add-user-fields input,.add-user-fields select{background:#0f172a;border:1px solid rgba(255,255,255,.12);color:#e2e8f0;padding:8px 12px;border-radius:6px;font-size:13px;font-family:inherit}
.add-user-fields input::placeholder{color:#64748b}
.add-user-fields input:focus,.add-user-fields select:focus{outline:none;border-color:#6366f1}
.add-user-fields input[type="email"]{min-width:200px}
/* Password field with eye toggle */
.pw-field{position:relative;display:inline-flex}
.pw-field input{min-width:240px;padding-right:36px}
.pw-toggle{position:absolute;right:2px;top:2px;bottom:2px;width:32px;background:none;border:none;cursor:pointer;color:#64748b;font-size:14px;display:flex;align-items:center;justify-content:center;border-radius:0 5px 5px 0}
.pw-toggle:hover{color:#e2e8f0}
.pw-toggle.visible{color:#6366f1}
.btn-create{background:#22c55e;border:none;color:#fff;padding:8px 18px;border-radius:6px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;min-width:110px;display:flex;align-items:center;justify-content:center}
.btn-create:hover{background:#16a34a}
.btn-create:disabled{opacity:.6;cursor:not-allowed}
.add-user-error{color:#f87171;font-size:13px;margin-top:8px}

/* Delete button in table */
.btn-delete{background:none;border:none;color:#64748b;font-size:18px;cursor:pointer;padding:2px 8px;border-radius:4px;line-height:1}
.btn-delete:hover{color:#f87171;background:rgba(239,68,68,.1)}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}
.modal-box{background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:28px 32px;max-width:420px;width:90%}
.modal-box h3{font-size:16px;color:#f8fafc;margin-bottom:12px}
.modal-box p{font-size:14px;color:#cbd5e1;line-height:1.5;margin-bottom:8px}
.modal-warn{color:#f87171;font-size:12px;margin-bottom:20px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end}
.btn-danger{background:#dc2626;border:none;color:#fff;padding:8px 20px;border-radius:6px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;min-width:90px;display:flex;align-items:center;justify-content:center}
.btn-danger:hover{background:#ef4444}
.btn-danger:disabled{opacity:.6;cursor:not-allowed}

/* Spinner */
.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Responsive */
@media(max-width:768px){
  .admin-wrap{padding:12px}
  .admin-filters{flex-direction:column}
  .admin-filters input{min-width:0;width:100%}
  .admin-table{font-size:12px}
  .admin-table th,.admin-table td{padding:6px 8px}
}
