:root{--primary: #22c55e;--primary-dark: #16a34a;--primary-light: #dcfce7;--brand: #0f172a;--brand-light: #1e293b;--background: #f8fafc;--surface: #ffffff;--text-primary: #0f172a;--text-secondary: #64748b;--text-muted: #94a3b8;--border: #e2e8f0;--divider: #f1f5f9;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.4;font-weight:400;color:var(--text-primary);background-color:var(--background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}a{color:inherit;text-decoration:none}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{--sidebar-width: 260px;width:var(--sidebar-width);flex-shrink:0;height:100vh;overflow:hidden;background:var(--brand);color:#cbd5e1;padding:.85rem .75rem;display:flex;flex-direction:column;gap:.65rem;transition:width .2s ease;border-right:1px solid #1e293b}.app-shell.sidebar-collapsed .sidebar{--sidebar-width: 64px;padding-left:.45rem;padding-right:.45rem}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:.35rem;flex-shrink:0}.app-shell.sidebar-collapsed .sidebar-header{flex-direction:column;align-items:center;gap:.5rem}.sidebar-brand{display:flex;align-items:center;gap:.55rem;min-width:0;flex:1}.app-shell.sidebar-collapsed .sidebar-brand{flex:none;justify-content:center}.sidebar-logo{flex-shrink:0;width:32px;height:32px;object-fit:contain;display:block}.app-shell.sidebar-collapsed .sidebar-logo{width:28px;height:28px}.sidebar-brand-text{font-size:.95rem;font-weight:600;color:#f8fafc;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-toggle{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid #475569;border-radius:8px;background:#1e293b;color:#e2e8f0;cursor:pointer}.sidebar button.sidebar-toggle:hover:not(:disabled),.sidebar button.sidebar-toggle:focus-visible{background:#334155;border-color:#94a3b8;color:#f8fafc}.sidebar-nav{display:flex;flex-direction:column;gap:.3rem;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:.15rem}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-thumb{background:#475569;border-radius:999px}.sidebar-link{display:flex;align-items:center;gap:.65rem;padding:.55rem .7rem;border-radius:8px;color:#cbd5e1;text-decoration:none}.sidebar-link-icon{flex-shrink:0}.sidebar-link-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-shell.sidebar-collapsed .sidebar-link{justify-content:center;padding:.6rem;gap:0}.app-shell.sidebar-collapsed .sidebar-link-label{display:none}.sidebar-link:hover{background:var(--brand-light)}.sidebar-link.active{background:var(--primary);color:#fff}.logout-btn{flex-shrink:0;display:flex;align-items:center;justify-content:flex-start;gap:.65rem;width:100%;padding:.55rem .7rem;border:1px solid #475569;border-radius:8px;background:#1e293b;color:#e2e8f0;font:inherit;font-size:.9rem;font-weight:500;cursor:pointer}.sidebar button.logout-btn:hover:not(:disabled),.sidebar button.logout-btn:focus-visible{background:#334155;border-color:#94a3b8;color:#f8fafc}.app-shell.sidebar-collapsed .logout-btn{justify-content:center;padding:.6rem;gap:0}.app-shell.sidebar-collapsed .logout-btn .sidebar-link-label{display:none}.content{flex:1;min-width:0;height:100vh;overflow-y:auto;overflow-x:hidden;padding:1.25rem 1.5rem 2rem}.content>section,.content>*{max-width:1400px}.page-header h2{margin:0;font-size:1.6rem}.page-header p{margin:.35rem 0 1rem;color:var(--text-secondary)}.stat-section{margin-bottom:1.1rem}.stat-section-title{margin:0 0 .25rem;font-size:1.05rem;font-weight:600;color:var(--text-primary)}.stat-section-desc{margin:0 0 .65rem;font-size:.88rem}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.stat-card,.panel{background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:1rem 1.1rem;box-shadow:0 1px 2px #0f172a0a}.panel+.panel{margin-top:.85rem}.panel h3,.panel h4{margin:0 0 .75rem;font-size:1.05rem}.panel-subsection{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--divider)}.panel-form{max-width:42rem}.panel-wide{max-width:none}.stat-label{margin:0;color:var(--text-secondary);font-size:.9rem}.stat-value{margin:.2rem 0 0;font-size:1.45rem;font-weight:700;line-height:1.2}.stat-card{min-height:0}.panel h3{margin-top:0}.panel.error{border-color:#fca5a5;color:#991b1b;background:#fff7f7}.endpoint-list{margin:0;padding-left:1rem;display:grid;gap:.45rem}.toolbar{display:flex;gap:.8rem;justify-content:space-between;align-items:center;margin-bottom:.8rem;flex-wrap:wrap}.text-input{width:100%;padding:.52rem .7rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-primary);font:inherit}.toolbar .text-input{max-width:280px;min-width:160px}textarea.text-input{min-height:5rem;resize:vertical}.text-input:focus{outline:2px solid var(--primary-light);border-color:var(--primary)}.pager{display:flex;align-items:center;gap:.5rem}.table{width:100%;border-collapse:collapse}.table th,.table td{border-bottom:1px solid var(--divider);text-align:left;padding:.55rem .35rem;font-size:.92rem}.row-actions{display:flex;gap:.5rem}button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;border:1px solid #cbd5e1;border-radius:8px;background:#fff;padding:.5rem .85rem;font:inherit;font-size:.9rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:background .15s,border-color .15s,color .15s}button:hover:not(:disabled),.btn:hover:not(:disabled){border-color:var(--primary);background:#f8fafc}.btn-primary{background:var(--primary);border-color:var(--primary-dark);color:#fff;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark);color:#fff}.btn-danger{border-color:#fecaca;color:#b91c1c;background:#fef2f2}.btn-danger:hover:not(:disabled){background:#fee2e2;border-color:#f87171}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--divider);border-color:var(--border)}.active-filter{background:var(--primary-light);border-color:var(--primary);color:var(--primary-dark)}.users-toolbar-panel{margin-bottom:.8rem}.users-list-summary-title{margin-top:.85rem}.users-role-tabs{flex-wrap:wrap}.users-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.6rem}.users-summary-card{border:1px solid var(--border);border-radius:10px;padding:.55rem .65rem;background:#fff;display:grid;gap:.2rem}.summary-label{color:var(--text-secondary);font-size:.78rem}button:disabled{opacity:.5;cursor:not-allowed}.edit-form{display:grid;gap:.85rem;max-width:28rem}.edit-form label{display:grid;gap:.35rem;font-size:.88rem;font-weight:500;color:var(--text-secondary)}.edit-form label>:not(input[type=checkbox]){font-weight:400}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.85rem 1rem;align-items:end}.form-grid .span-2{grid-column:1 / -1}.form-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-top:.25rem}label.checkbox-row,.notif-pref-row{display:flex;align-items:flex-start;gap:.55rem;font-weight:400;cursor:pointer}label.checkbox-row input,.notif-pref-row input{margin-top:.15rem;width:1rem;height:1rem;accent-color:var(--primary)}.muted-text{color:var(--text-muted);font-size:.9rem;margin:0}.error-text{color:var(--error);margin:0 0 .8rem}.success-text{color:var(--success)}.hint-text{margin:0;font-size:.85rem;color:var(--text-secondary, #64748b);line-height:1.4}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:1rem}.auth-card{width:min(460px,100%);background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.1rem}.auth-brand{display:flex;flex-direction:column;align-items:center;gap:.65rem;margin-bottom:.35rem}.auth-logo{object-fit:contain}.auth-card h2{margin:0 0 .3rem;text-align:center}.auth-card p{margin:0 0 .9rem;color:var(--text-secondary)}.badge{display:inline-flex;padding:.15rem .5rem;border-radius:999px;font-size:.78rem;background:var(--divider);color:var(--text-primary)}.badge.pending,.badge.processing{background:#fef3c7;color:#92400e}.badge.completed,.badge.processed,.badge.confirmed,.badge.refunded{background:var(--primary-light);color:var(--primary-dark)}.badge.failed,.badge.rejected,.badge.cancelled{background:#fee2e2;color:#991b1b}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto}.modal-card{width:min(640px,100%);max-height:min(90vh,800px);background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:0;display:flex;flex-direction:column;box-shadow:0 20px 50px #0f172a2e}.modal-card.modal-card-wide{width:min(720px,100%)}.modal-body{padding:0 1.1rem 1.1rem;overflow-y:auto;flex:1}.edit-form-wide{max-width:none;gap:1rem}.notif-prefs-grid{display:grid;gap:.5rem}.notif-pref-row span{display:grid;gap:.1rem}.notif-pref-key{font-size:.75rem;color:var(--text-muted);font-weight:400}.quick-links{display:flex;flex-wrap:wrap;gap:.5rem}.quick-links a{display:inline-flex;padding:.45rem .75rem;border-radius:8px;border:1px solid var(--border);background:#fff;font-size:.9rem}.quick-links a:hover{border-color:var(--primary);background:var(--primary-light)}.section-with-fab{padding-bottom:5.5rem}.fab{position:fixed;right:1.35rem;bottom:1.35rem;z-index:12;display:inline-flex;align-items:center;gap:.45rem;padding:.8rem 1.15rem;border:none;border-radius:999px;background:var(--primary);color:#fff;font-size:.92rem;font-weight:600;cursor:pointer;box-shadow:0 10px 28px #22c55e66;transition:transform .15s,box-shadow .15s,background .15s}.fab:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 14px 32px #22c55e73}.fab:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.fab-icon{display:grid;place-items:center;width:1.35rem;height:1.35rem;border-radius:999px;background:#ffffff38;font-size:1.2rem;line-height:1;font-weight:400}.fab-label{white-space:nowrap}@media (max-width: 600px){.fab-label{display:none}.fab{padding:.85rem;border-radius:999px}}.alert{padding:.65rem .85rem;border-radius:8px;border:1px solid var(--border);margin-bottom:.85rem}.alert-error{border-color:#fecaca;background:#fef2f2;color:#991b1b}.alert-success{border-color:#bbf7d0;background:#f0fdf4;color:#166534}.table-wrap{overflow-x:auto}.detail-tabs{max-width:100%}.user-cell{display:flex;align-items:center;gap:.5rem}.table-avatar{width:28px;height:28px;border-radius:999px;object-fit:cover;border:1px solid var(--border)}.table-avatar-fallback{display:grid;place-items:center;background:var(--primary-light);color:var(--primary-dark);font-size:.75rem;font-weight:700}.empty-cell{text-align:center!important;color:var(--text-secondary);padding:1rem!important}.category-icon-cell{display:flex;align-items:center;gap:.45rem}.category-preview-box{display:flex;align-items:center;gap:.55rem;padding:.5rem;border:1px solid var(--border);border-radius:10px;width:fit-content}.draggable-row{cursor:grab}.draggable-row.dragging{opacity:.6}.draggable-row.drag-over{outline:2px solid var(--primary-light);outline-offset:-2px}.drag-handle-cell{color:var(--text-muted);font-weight:700;letter-spacing:1px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.1rem .75rem;border-bottom:1px solid var(--divider);flex-shrink:0}.modal-header h3{margin:0;font-size:1.15rem}.modal-close{min-width:2rem;min-height:2rem;padding:0;font-size:1.25rem;line-height:1}.toast-stack{position:fixed;right:1rem;bottom:1rem;display:grid;gap:.5rem;z-index:30}.toast{background:var(--surface);border:1px solid var(--border);padding:.65rem .8rem;border-radius:10px;box-shadow:0 8px 24px #0f172a1f}.toast.success{border-color:var(--success)}.toast.error{border-color:var(--error)}@media (max-width: 900px){.app-shell{flex-direction:column;height:auto;min-height:100vh;overflow:visible}.sidebar{width:100%;height:auto;max-height:none;flex-shrink:0}.app-shell.sidebar-collapsed .sidebar{width:100%}.sidebar-nav{flex-direction:row;flex-wrap:wrap;overflow-x:auto;overflow-y:hidden;flex:none;max-height:40vh}.content{height:auto;min-height:0;overflow:visible}.sidebar-link{white-space:nowrap}}
