:root{--bg: #f4f6f8;--surface: #ffffff;--border: #e2e6ea;--text: #1f2933;--muted: #6b7280;--primary: #7c3aed;--primary-hover: #6d28d9;--primary-soft: #ede9fe;--primary-grad: linear-gradient(135deg, #7c3aed 0%, #6366f1 100%);--danger: #dc2626;--danger-hover: #b91c1c;--success: #059669;--radius: 8px;--auth-purple: #7c3aed;--auth-grad: linear-gradient(135deg, #7c3aed 0%, #6366f1 100%);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text)}*{box-sizing:border-box}body{margin:0;background:var(--bg)}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}input,select{font:inherit}.app-shell{display:grid;grid-template-columns:232px 1fr;min-height:100vh}.sidebar{background:#111827;color:#e5e7eb;display:flex;flex-direction:column;padding:20px 14px;gap:4px}.sidebar .brand{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;padding:6px 10px 16px;letter-spacing:.5px}.sidebar .brand .brand-logo{width:26px;height:26px;object-fit:contain}.topbar-brand{display:flex;align-items:center;gap:8px}.topbar-brand .topbar-logo{width:24px;height:24px;object-fit:contain}.sidebar nav a{display:block;padding:9px 12px;border-radius:var(--radius);color:#cbd5e1;font-size:14px}.sidebar nav a:hover{background:#1f2937;color:#fff}.sidebar nav a.active{background:var(--primary);color:#fff}.sidebar .spacer{flex:1}.sidebar .user-box{border-top:1px solid #1f2937;padding-top:14px;font-size:12px;color:#9ca3af}.sidebar .user-box .email{color:#e5e7eb;word-break:break-all}.role-badge{display:inline-block;padding:3px 10px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:11px;font-weight:600;text-transform:capitalize;letter-spacing:.3px}.role-badge.role-superadmin{background:#ede9fe;color:#6d28d9}.role-badge.role-organiser{background:#dbeafe;color:#1d4ed8}.role-badge.role-volunteer{background:#dcfce7;color:#15803d}.main{display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 28px;background:var(--surface);border-bottom:1px solid var(--border)}.topbar h1{font-size:20px;margin:0}.content{padding:28px}.btn{background:var(--primary-grad);color:#fff;border:none;border-radius:var(--radius);padding:9px 16px;font-size:14px;font-weight:500}.btn:hover{filter:brightness(1.05)}.btn.secondary{background:#fff;color:var(--text);border:1px solid var(--border);filter:none}.btn.secondary:hover{background:#f9fafb;filter:none}.btn.danger{background:var(--danger)}.btn.danger:hover{background:var(--danger-hover);filter:none}.btn.small{padding:5px 10px;font-size:13px}.btn:disabled{opacity:.6;cursor:not-allowed}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}table{width:100%;border-collapse:collapse;font-size:14px}th,td{text-align:left;padding:11px 16px;border-bottom:1px solid var(--border)}th{background:#f9fafb;font-weight:600;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.4px}tbody tr:last-child td{border-bottom:none}.status-pill{display:inline-flex;align-items:center;padding:3px 11px;border-radius:999px;background:#eef2ff;color:#4338ca;font-size:12px;font-weight:600;text-transform:capitalize}.status-pill:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;margin-right:7px}.status-pill.green{background:#dcfce7;color:#15803d}.status-pill.blue{background:#dbeafe;color:#1d4ed8}.status-pill.red{background:#fee2e2;color:#b91c1c}.status-pill.gray{background:#f1f5f9;color:#64748b}.avatar{flex:none;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;color:#fff}.avatar.c0{background:#8b5cf6}.avatar.c1{background:#10b981}.avatar.c2{background:#f59e0b}.avatar.c3{background:#3b82f6}.avatar.c4{background:#ec4899}.avatar.c5{background:#ef4444}.name-cell{display:flex;align-items:center;gap:12px}.name-main{font-weight:600;color:var(--text)}.name-sub{font-size:12px;color:var(--muted)}.cell-icon{display:inline-flex;align-items:center;gap:8px}.cell-icon svg{flex:none;color:var(--primary)}.tag-chips{display:flex;flex-wrap:wrap;gap:6px}.tag-chip{background:var(--primary-soft);color:var(--primary-hover);border-radius:999px;padding:3px 10px;font-size:12px;font-weight:600}.kebab{position:relative;display:inline-block}.kebab-btn{background:none;border:none;padding:6px;border-radius:8px;color:var(--muted);display:grid;place-items:center}.kebab-btn:hover{background:#f1f5f9;color:var(--text)}.kebab-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30}.kebab-menu{position:absolute;right:0;top:calc(100% + 4px);z-index:31;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 30px #0000001f;min-width:140px;padding:6px;display:flex;flex-direction:column;text-align:left}.kebab-item{background:none;border:none;text-align:left;padding:8px 12px;border-radius:8px;font-size:14px;color:var(--text)}.kebab-item:hover{background:var(--primary-soft)}.kebab-item.danger{color:var(--danger)}.kebab-item.danger:hover{background:#fef2f2}.pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-top:1px solid var(--border);font-size:13px;color:var(--muted);flex-wrap:wrap}.page-controls{display:flex;gap:6px;align-items:center}.page-btn{min-width:34px;height:34px;padding:0 8px;border:1px solid var(--border);background:#fff;border-radius:8px;color:var(--text);display:grid;place-items:center;font-size:13px}.page-btn:hover:not(:disabled){background:#f9fafb}.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.page-btn:disabled{opacity:.45;cursor:not-allowed}.row-actions{display:flex;gap:6px;justify-content:flex-end}.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}.muted{color:var(--muted)}.empty,.loading{padding:40px;text-align:center;color:var(--muted)}.error-banner{background:#fef2f2;border:1px solid #fecaca;color:var(--danger);padding:10px 14px;border-radius:var(--radius);font-size:14px;margin-bottom:16px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:13px;font-weight:500;color:var(--muted)}.field input,.field select{padding:9px 11px;border:1px solid var(--border);border-radius:var(--radius);background:#fff}.field input:focus,.field select:focus{outline:none;border-color:var(--primary)}.tenant-select select{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius);background:#fff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.modal{background:var(--surface);border-radius:12px;width:100%;max-width:440px;padding:24px;box-shadow:0 20px 40px #0003}.modal h2{margin:0 0 18px;font-size:18px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;justify-content:flex-end;z-index:60}.drawer{background:var(--surface);width:100%;max-width:420px;height:100%;display:flex;flex-direction:column;box-shadow:-20px 0 40px #0003}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border, #e2e8f0)}.drawer-header h2{margin:0;font-size:18px}.drawer-close{background:none;border:none;font-size:24px;line-height:1;cursor:pointer;color:var(--muted, #64748b)}.drawer-body{padding:16px 20px;overflow-y:auto;flex:1}.drawer-footer{padding:14px 20px;border-top:1px solid var(--border, #e2e8f0);display:flex;justify-content:flex-end}.detail-row{display:flex;flex-direction:column;gap:2px;padding:8px 0;border-bottom:1px solid var(--border, #eef2f7)}.detail-label{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted, #64748b)}.detail-value{font-size:14px;word-break:break-word;white-space:pre-wrap}.clickable-row{cursor:pointer}.clickable-row:hover{background:var(--row-hover, #f8fafc)}.cell-truncate{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.link-button{background:none;border:none;color:var(--primary);cursor:pointer;padding:8px 0 0;font-size:14px;text-align:center;width:100%}.link-button:hover{text-decoration:underline}.auth-page{--auth-purple: #7c3aed;--auth-grad: linear-gradient(135deg, #7c3aed 0%, #6366f1 100%);min-height:100vh;display:grid;grid-template-columns:1.05fr 1fr;background:#fff;color:#1f2937}.auth-marketing{position:relative;padding:52px 60px;background:linear-gradient(160deg,#faf8ff,#f1eefe 55%,#eaecfe);display:flex;flex-direction:column;gap:26px;overflow:hidden}.auth-brand{display:flex;align-items:center;gap:12px}.auth-brand .name{font-size:26px;font-weight:800;letter-spacing:-.5px;line-height:1.05}.auth-brand .name span{display:block;font-size:11px;font-weight:600;letter-spacing:6px;color:var(--auth-purple);margin-top:2px}.auth-headline{font-size:34px;line-height:1.18;font-weight:800;letter-spacing:-1px;margin:0 0 14px}.auth-headline .accent{color:var(--auth-purple)}.auth-tagline{margin:0;color:#5b6472;font-size:15px;max-width:420px;line-height:1.6}.auth-features{display:flex;flex-direction:column;gap:18px}.auth-feature{display:flex;gap:14px;align-items:flex-start}.auth-feature .ic{flex:none;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#fff;background:var(--auth-grad);box-shadow:0 6px 14px #7c3aed47}.auth-feature h3{margin:0 0 2px;font-size:15px;font-weight:700}.auth-feature p{margin:0;font-size:13px;color:#6b7280;line-height:1.5}.auth-appcard{margin-top:auto;background:#fff;border:1px solid #ece9f8;border-radius:16px;padding:16px 18px;display:flex;gap:14px;align-items:center;box-shadow:0 10px 30px #503ca014}.auth-appcard .appicon{flex:none;width:46px;height:46px;border-radius:12px;background:var(--auth-grad);display:grid;place-items:center;color:#fff}.auth-appcard h4{margin:0 0 3px;font-size:14px;font-weight:700}.auth-appcard p{margin:0 0 8px;font-size:12px;color:#6b7280;line-height:1.45}.auth-badges{display:flex;gap:8px}.auth-badge{display:inline-flex;align-items:center;gap:6px;background:#111827;color:#fff;border-radius:8px;padding:5px 10px;font-size:11px;font-weight:600}.auth-security{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid #ece9f8;border-radius:14px;padding:14px 16px}.auth-security .ic{flex:none;width:40px;height:40px;border-radius:10px;background:#ede9fe;color:var(--auth-purple);display:grid;place-items:center}.auth-security h4{margin:0 0 2px;font-size:13px;font-weight:700}.auth-security p{margin:0;font-size:12px;color:#6b7280;line-height:1.45}.auth-form-side{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;background:linear-gradient(180deg,#fbfbff,#f4f5fd)}.auth-card{width:100%;max-width:420px;background:#fff;border:1px solid #eef0f6;border-radius:22px;padding:40px 36px;box-shadow:0 20px 50px #281e5a14}.auth-logo-circle{width:84px;height:84px;border-radius:50%;margin:0 auto 18px;display:grid;place-items:center;background:radial-gradient(circle at 50% 38%,#f3f0ff,#fff 70%);border:1px solid #efeafe}.auth-card h2{text-align:center;margin:0 0 4px;font-size:24px;font-weight:800}.auth-card .sub{text-align:center;margin:0 0 26px;color:#7c8595;font-size:14px}.auth-label{display:block;font-size:13px;font-weight:600;margin:0 0 7px;color:#374151}.auth-input{position:relative;margin-bottom:18px}.auth-input .ic{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#9aa1ad;pointer-events:none;display:grid;place-items:center}.auth-input input{width:100%;height:48px;padding:0 44px;border:1px solid #e3e7ef;border-radius:12px;font-size:14px;color:var(--text);background:#fbfbfd;box-sizing:border-box}.auth-input input::placeholder{color:#aab0bb}.auth-input input:focus{outline:none;border-color:var(--auth-purple);box-shadow:0 0 0 3px #7c3aed1f;background:#fff}.auth-input .toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:#9aa1ad;cursor:pointer;padding:8px;display:grid;place-items:center}.auth-input .toggle:hover{color:var(--auth-purple)}.auth-pw-head{display:flex;align-items:center;justify-content:space-between}.auth-pw-head .auth-label{margin-bottom:7px}.auth-link{background:none;border:none;color:var(--auth-purple);font-size:13px;font-weight:600;cursor:pointer;padding:0}.auth-link:hover{text-decoration:underline}.auth-remember{display:flex;align-items:center;gap:8px;font-size:14px;color:#4b5563;cursor:pointer;-webkit-user-select:none;user-select:none;margin-bottom:18px}.auth-remember input{width:16px;height:16px;accent-color:var(--auth-purple);cursor:pointer}.auth-submit{width:100%;height:50px;border:none;border-radius:12px;background:var(--auth-grad);color:#fff;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 12px 24px #6366f14d;transition:filter .15s,transform .05s}.auth-submit:hover{filter:brightness(1.05)}.auth-submit:active{transform:translateY(1px)}.auth-submit:disabled{opacity:.65;cursor:default;box-shadow:none}.auth-foot{text-align:center;margin:22px 0 0;font-size:14px;color:#7c8595}.auth-foot b{color:var(--auth-purple);font-weight:700}.auth-note{color:#5b6472;font-size:13px;line-height:1.6;margin:0 0 18px}.auth-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:10px;padding:10px 12px;font-size:13px;margin-bottom:16px}.auth-copyright{display:flex;align-items:center;gap:6px;margin-top:26px;font-size:12px;color:#9aa1ad;text-align:center}@media (max-width: 920px){.auth-page{grid-template-columns:1fr}.auth-marketing{display:none}.auth-form-side{min-height:100vh}}.dash{display:flex;flex-direction:column;gap:20px}.dash-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.dash-title{margin:0 0 4px;font-size:26px;font-weight:800;letter-spacing:-.5px}.dash-sub{margin:0;color:var(--muted);font-size:14px}.dash-tenant-chip{flex:none;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:8px 14px;font-size:13px;font-weight:600;color:var(--text)}.dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.dash-stat{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 20px}.dash-stat-ic{flex:none;width:46px;height:46px;border-radius:12px;display:grid;place-items:center}.dash-stat-ic.purple{background:#ede9fe;color:#7c3aed}.dash-stat-ic.green{background:#dcfce7;color:#16a34a}.dash-stat-ic.blue{background:#dbeafe;color:#2563eb}.dash-stat-ic.orange{background:#ffedd5;color:#ea580c}.dash-stat-num{font-size:28px;font-weight:800;line-height:1.1}.dash-stat-lbl{font-size:13px;font-weight:600;color:var(--text);margin-top:2px}.dash-stat-cap{font-size:12px;color:var(--muted);margin-top:2px}.dash-cta{display:flex;align-items:center;gap:18px;background:linear-gradient(120deg,#f5f3ff,#eef2ff);border:1px solid #e9e6fb;border-radius:16px;padding:22px 24px}.dash-cta-ic{flex:none;width:56px;height:56px;border-radius:50%;display:grid;place-items:center;color:#fff;background:var(--primary-grad);box-shadow:0 8px 18px #7c3aed4d}.dash-cta-text{flex:1}.dash-cta-text h2{margin:0 0 4px;font-size:18px;font-weight:700}.dash-cta-text p{margin:0;font-size:14px;color:var(--muted);max-width:520px}.dash-cta .btn{flex:none}.dash-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;align-items:start}.dash-panel{padding:20px}.dash-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.dash-panel-head h3{display:flex;align-items:center;gap:8px;margin:0;font-size:16px;font-weight:700}.dash-panel-head h3 svg{color:var(--primary)}.dash-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 16px;text-align:center;color:var(--muted)}.dash-empty svg{color:#c4b5fd}.dash-empty p{margin:0;font-size:13px}.dash-quick-sub{margin:0 0 12px;font-size:13px;color:var(--muted)}.dash-quick-row{display:flex;gap:8px;margin-bottom:14px}.dash-quick-code{flex:none;border:1px solid var(--border);border-radius:10px;padding:0 10px;background:#fbfbfd;font-size:14px;height:44px}.dash-quick-input{flex:1;min-width:0;border:1px solid var(--border);border-radius:10px;padding:0 14px;height:44px;font-size:14px;background:#fbfbfd}.dash-quick-input:focus,.dash-quick-code:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #7c3aed1f;background:#fff}.dash-quick-call,.dash-quick-dialer{width:100%;height:46px;display:flex;align-items:center;justify-content:center;gap:8px}.dash-quick-or{text-align:center;color:var(--muted);font-size:12px;margin:12px 0;position:relative}.dash-quick-or:before,.dash-quick-or:after{content:"";position:absolute;top:50%;width:calc(50% - 18px);height:1px;background:var(--border)}.dash-quick-or:before{left:0}.dash-quick-or:after{right:0}.dash-quick-dialer{color:var(--primary);border-color:#ddd6fe}.dash-foot{display:flex;align-items:center;gap:14px;background:linear-gradient(120deg,#f5f3ff,#eef2ff);border:1px solid #e9e6fb;border-radius:14px;padding:16px 20px}.dash-foot-ic{flex:none;width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:#ede9fe;color:var(--primary)}.dash-foot strong{font-size:14px}.dash-foot p{margin:2px 0 0;font-size:13px;color:var(--muted)}.status-pill.amber{background:#fef3c7;color:#b45309}.trial-banner{margin-bottom:16px;padding:10px 14px;border-radius:var(--radius);background:#fef3c7;color:#92400e;border:1px solid #fcd34d;font-size:14px}.trial-banner.urgent{background:#fee2e2;color:#991b1b;border-color:#fca5a5}.sub-blocked{display:flex;justify-content:center;padding-top:48px}.sub-blocked-card{max-width:520px;text-align:center;padding:32px}.sub-blocked-card h2{margin-top:0}.notif-stack{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.notif-banner{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 14px;border-radius:var(--radius);background:var(--primary-soft);border:1px solid #ddd6fe;color:#4c1d95}.notif-body{display:flex;flex-direction:column;gap:2px;font-size:14px}.notif-link{font-size:13px;color:var(--primary);word-break:break-all}.link-btn{background:none;border:none;padding:0;font:inherit;color:var(--primary);cursor:pointer;text-decoration:underline}.notif-link-btn{align-self:flex-start;margin-top:2px;padding:4px 10px;border-radius:6px;background:var(--primary);color:#fff;font-size:13px;font-weight:600;text-decoration:none}.notif-link-btn:hover{background:var(--primary-hover)}.notif-date{font-size:12px;color:var(--muted)}.notif-dismiss{border:none;background:transparent;cursor:pointer;font-size:20px;line-height:1;color:inherit;opacity:.6}.notif-dismiss:hover{opacity:1}
