@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--bg:#f5f5f5;--bg-card:#fff;--sidebar:#111827;--text:#111827;--text-dim:#6b7280;--text-light:#9ca3af;--primary:#2563eb;--primary-h:#1d4ed8;--primary-bg:#eff6ff;--success:#059669;--success-bg:#ecfdf5;--danger:#dc2626;--danger-bg:#fef2f2;--warning:#d97706;--warning-bg:#fffbeb;--purple:#7c3aed;--purple-bg:#f5f3ff;--cyan:#0891b2;--cyan-bg:#ecfeff;--border:#e5e7eb;--font:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--radius:8px;--radius-lg:12px;--sidebar-w:250px;--header-h:56px;--shadow:0 1px 3px #0000000f;--shadow-md:0 4px 12px #0000000f;--transition:.15s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}img,svg{max-width:100%;display:block}input,textarea,select,button{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.login-page{background:#f0f2f5;justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow-md);padding:2.5rem 2rem}.login-logo{border-radius:var(--radius);background:var(--primary);justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 1.25rem;display:flex}.login-logo span{color:#fff;font-size:1.2rem;font-weight:900}.login-card h2{color:var(--text);text-align:center;margin-bottom:.25rem;font-size:1.25rem;font-weight:700}.login-card>p{color:var(--text-dim);text-align:center;margin-bottom:1.75rem;font-size:.82rem}.login-alert-error{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius);border:1px solid #dc262626;align-items:center;gap:.4rem;margin-bottom:1rem;padding:.6rem .85rem;font-size:.8rem;font-weight:500;display:flex}.login-form-fields{flex-direction:column;gap:.85rem;margin-bottom:1.25rem;display:flex}.login-field label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.35rem;font-size:.72rem;font-weight:600;display:block}.login-input-wrap{align-items:center;display:flex;position:relative}.login-input-icon{width:16px;height:16px;color:var(--text-light);pointer-events:none;z-index:1;transition:color .2s;position:absolute;left:12px}.login-input-wrap:focus-within .login-input-icon{color:var(--primary)}.login-input-wrap input{border:1.5px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:var(--bg);transition:var(--transition);padding:.65rem 2.5rem;font-size:.85rem}.login-input-wrap input::placeholder{color:var(--text-light)}.login-input-wrap input:focus{border-color:var(--primary);background:var(--bg-card);box-shadow:0 0 0 3px var(--primary-bg);outline:none}.login-eye-btn{cursor:pointer;color:var(--text-light);background:0 0;border:none;align-items:center;padding:.15rem;font-size:.9rem;transition:color .2s;display:flex;position:absolute;right:10px}.login-eye-btn:hover{color:var(--text)}.login-submit-btn{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;width:100%;transition:var(--transition);border:none;padding:.7rem;font-size:.85rem;font-weight:700}.login-submit-btn:hover{background:var(--primary-h)}.login-submit-btn:active{transform:scale(.98)}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-spinner-wrap{justify-content:center;align-items:center;gap:.45rem;display:flex}.login-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-footer-note{text-align:center;border-top:1px solid var(--border);color:var(--text-light);margin-top:1.25rem;padding-top:1rem;font-size:.72rem}@media (width<=480px){.login-page{padding:1rem}.login-card{padding:2rem 1.5rem}}.admin-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--sidebar);color:#fff;z-index:1000;flex-direction:column;height:100vh;transition:transform .3s;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-header{border-bottom:1px solid #ffffff0f;flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.sidebar-brand{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.sidebar-logo{object-fit:contain;border-radius:var(--radius);background:#fff;flex-shrink:0;width:34px;height:34px;padding:3px}.sidebar-logo-placeholder{background:var(--primary);border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.sidebar-logo-placeholder span{color:#fff;font-size:.75rem;font-weight:800}.sidebar-brand-text h2{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:700;overflow:hidden}.sidebar-close-btn{color:#fff6;width:28px;height:28px;transition:var(--transition);background:#ffffff0f;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-left:.5rem;display:flex}.sidebar-close-btn:hover{color:#fff;background:#ffffff1f}.sidebar-nav{flex:1;padding:.75rem;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:99px}.nav-group{margin-bottom:.5rem}.nav-link{color:#ffffff80;border-radius:var(--radius);transition:var(--transition);align-items:center;gap:.65rem;margin-bottom:2px;padding:.55rem .75rem;font-size:.82rem;font-weight:500;display:flex;position:relative}.nav-link:hover{color:#ffffffd9;background:#ffffff0f}.nav-link.active{color:#93c5fd;background:#2563eb2e;font-weight:600}.nav-link.active:before{content:"";background:var(--primary);border-radius:0 3px 3px 0;width:3px;height:55%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.nav-icon svg{width:16px;height:16px}.nav-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.nav-arrow{opacity:0;width:14px;height:14px;transition:var(--transition);flex-shrink:0}.nav-link:hover .nav-arrow,.nav-link.active .nav-arrow{opacity:.4}.nav-accordion-trigger{cursor:pointer;text-align:left;background:0 0;border:none;width:100%;font-family:inherit}.nav-accordion-arrow{opacity:.4;width:14px;height:14px;transition:transform .2s ease, opacity var(--transition);flex-shrink:0}.nav-accordion-trigger:hover .nav-accordion-arrow{opacity:.7}.nav-accordion-arrow.rotated{transform:rotate(180deg)}.nav-accordion-body{animation:.2s accordionOpen;overflow:hidden}@keyframes accordionOpen{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.nav-sub-link{padding-left:2rem!important}.nav-sub-link:before{left:1.25rem!important}.sidebar-footer{background:#0000001f;border-top:1px solid #ffffff0f;flex-shrink:0;padding:.85rem 1rem}.sidebar-user{color:inherit;cursor:pointer;transition:var(--transition);align-items:center;gap:.65rem;margin-bottom:.75rem;text-decoration:none;display:flex}.sidebar-user:hover{opacity:.8}.sidebar-user-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.7rem;font-weight:800;display:flex}.sidebar-user-avatar-img{object-fit:cover;border-radius:50%;flex-shrink:0;width:34px;height:34px}.sidebar-user-info{min-width:0}.sidebar-user-name{color:#ffffffd9;white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;font-weight:600;overflow:hidden}.sidebar-user-email{color:#ffffff4d;white-space:nowrap;text-overflow:ellipsis;font-size:.65rem;display:block;overflow:hidden}.btn-logout{color:#ffffff80;border-radius:var(--radius);width:100%;transition:var(--transition);background:#ffffff0a;border:1px solid #ffffff14;justify-content:center;align-items:center;gap:.4rem;padding:.5rem;font-family:inherit;font-size:.78rem;font-weight:600;text-decoration:none;display:flex}.btn-logout:hover{color:#fca5a5;background:#ef44441f;border-color:#ef444440}.btn-logout svg{width:14px;height:14px}.btn-view-site{color:#ffffff80;border-radius:var(--radius);width:100%;transition:var(--transition);background:#ffffff0a;border:1px solid #ffffff14;justify-content:center;align-items:center;gap:.4rem;margin-bottom:.5rem;padding:.5rem;font-family:inherit;font-size:.78rem;font-weight:600;text-decoration:none;display:flex}.btn-view-site:hover{color:#93c5fd;background:#2563eb1f;border-color:#2563eb40}.btn-view-site svg{width:14px;height:14px}.sidebar-overlay{z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:none;position:fixed;inset:0}.admin-content{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;transition:margin-left .3s;display:flex}.admin-header{background:var(--bg-card);height:var(--header-h);border-bottom:1px solid var(--border);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 1.5rem;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:.85rem;min-width:0;display:flex}.header-page-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.header-breadcrumb{color:var(--text-light);white-space:nowrap;text-overflow:ellipsis;font-size:.68rem;display:block;overflow:hidden}.menu-toggle{background:var(--bg);border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius);width:36px;height:36px;transition:var(--transition);flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:none}.menu-toggle:hover{background:var(--border);color:var(--text)}.header-right{flex-shrink:0;align-items:center;gap:.6rem;display:flex}.header-icon-btn{background:var(--bg);border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius);width:36px;height:36px;transition:var(--transition);justify-content:center;align-items:center;font-size:.95rem;display:flex}.header-icon-btn:hover{background:var(--border);color:var(--text)}.notif-dot{background:var(--danger);border:2px solid var(--bg-card);border-radius:50%;width:7px;height:7px;position:absolute;top:6px;right:6px}.header-icon-btn{position:relative}.header-user{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:inherit;transition:var(--transition);align-items:center;gap:.5rem;padding:.3rem .65rem .3rem .35rem;text-decoration:none;display:flex}.header-user:hover{background:var(--primary-bg);border-color:var(--primary)}.header-user-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.62rem;font-weight:800;display:flex}.header-user-avatar-img{object-fit:cover;border-radius:50%;flex-shrink:0;width:28px;height:28px}.header-user-name{color:var(--text);font-size:.75rem;font-weight:600;line-height:1.2}.header-user-role{color:var(--text-light);font-size:.62rem}.header-logout-btn{background:var(--bg);border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius);width:36px;height:36px;transition:var(--transition);justify-content:center;align-items:center;font-size:.95rem;display:flex}.header-logout-btn:hover{background:var(--danger-bg);color:var(--danger);border-color:#ef444433}.admin-main{background:var(--bg);flex:1;padding:1.5rem}.admin-footer{border-top:1px solid var(--border);background:var(--bg-card);text-align:center;flex-shrink:0;padding:.85rem 1.5rem}.admin-footer p{color:var(--text-light);margin:0;font-size:.72rem}.admin-footer a{color:var(--primary);text-decoration:none}.admin-footer a:hover{text-decoration:underline}@media (width<=1024px){.sidebar{transform:translateX(calc(-1 * var(--sidebar-w)))}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.admin-content{margin-left:0!important}.menu-toggle{display:flex}.admin-main{padding:1.25rem}.header-user-info{display:none}}@media (width<=768px){.admin-header{padding:0 1rem}.header-page-name{font-size:.88rem}.header-breadcrumb{display:none}.admin-main{padding:1rem}.header-user{display:none}}@media (width<=480px){.header-icon-btn{display:none}.admin-main{padding:.75rem}.sidebar{width:250px}.admin-header{padding:0 .75rem}}.nav-cm-wrapper{position:relative}.nav-cm-trigger{cursor:pointer;text-align:left;background:0 0;border:none;width:100%;font-family:inherit}.nav-cm-arrow{transition:transform .2s!important}.nav-cm-arrow.rotated{transform:rotate(90deg)}.nav-cm-flyout{left:var(--sidebar-w);z-index:1100;border-radius:0 var(--radius-lg) var(--radius-lg) 0;background:#1a2235;border:1px solid #ffffff14;border-left:none;min-width:240px;animation:.15s flyoutIn;position:fixed;top:auto;overflow:hidden;box-shadow:8px 4px 24px #00000059}@keyframes flyoutIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.nav-cm-flyout-header{color:#ffffff40;text-transform:uppercase;letter-spacing:1.5px;border-bottom:1px solid #ffffff0f;padding:.75rem 1rem .5rem;font-size:.6rem;font-weight:700}.nav-cm-flyout-grid{grid-template-columns:1fr 1fr;gap:2px;padding:.5rem;display:grid}.nav-cm-item{color:#ffffff80;border-radius:var(--radius);transition:var(--transition);white-space:nowrap;align-items:center;gap:.55rem;padding:.55rem .75rem;font-size:.78rem;font-weight:500;text-decoration:none;display:flex}.nav-cm-item:hover{color:#ffffffe6;background:#ffffff12}.nav-cm-item.active{color:#93c5fd;background:#2563eb33}.nav-cm-item-icon{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:flex}.nav-cm-item-icon svg{width:13px;height:13px}@media (width<=1024px){.nav-cm-flyout{border-radius:var(--radius);min-width:unset;box-shadow:none;background:#ffffff08;border:none;border-left:2px solid #2563eb4d;margin:2px 0 2px .75rem;position:static}.nav-cm-flyout-grid{grid-template-columns:1fr}.nav-cm-flyout-header{display:none}}.btn{border-radius:var(--radius);transition:var(--transition);white-space:nowrap;cursor:pointer;border:none;justify-content:center;align-items:center;gap:.45rem;padding:.5rem 1.1rem;font-size:.82rem;font-weight:600;display:inline-flex}.btn svg{width:14px;height:14px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-h)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #ef444426}.btn-danger:hover{background:var(--danger);color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:.35rem .75rem;font-size:.75rem}.btn-icon{border-radius:var(--radius);width:32px;height:32px;transition:var(--transition);border:none;justify-content:center;align-items:center;display:inline-flex}.btn-icon svg{width:14px;height:14px}.btn-edit{background:var(--primary-bg);color:var(--primary)}.btn-edit:hover{background:var(--primary);color:#fff}.btn-delete{background:var(--danger-bg);color:var(--danger)}.btn-delete:hover{background:var(--danger);color:#fff}.alert{border-radius:var(--radius);align-items:center;gap:.45rem;margin-bottom:1rem;padding:.7rem 1rem;font-size:.82rem;font-weight:500;display:flex}.alert-success{background:var(--success-bg);color:var(--success);border:1px solid #05966926}.alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid #dc262626}.alert-warning{background:var(--warning-bg);color:var(--warning);border:1px solid #d9770626}.status-badge{text-transform:capitalize;border-radius:99px;align-items:center;padding:.2rem .6rem;font-size:.7rem;font-weight:600;display:inline-flex}.status-success{background:var(--success-bg);color:var(--success)}.status-pending{background:var(--warning-bg);color:var(--warning)}.status-failed{background:var(--danger-bg);color:var(--danger)}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.6rem;margin-bottom:1.5rem;display:flex}.page-title{color:var(--text);font-size:1.3rem;font-weight:700}.loading{color:var(--text-light);justify-content:center;align-items:center;gap:.6rem;padding:3rem 1.5rem;font-size:.82rem;font-weight:500;display:flex}.loading:before{content:"";border:2.5px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}.empty{color:var(--text-light);background:var(--bg-card);border-radius:var(--radius-lg);border:2px dashed var(--border);flex-direction:column;justify-content:center;align-items:center;padding:4rem 1.5rem;font-size:.82rem;font-weight:500;display:flex}.loading-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.profile-form{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;padding:1.5rem;display:grid}.profile-avatar-section{grid-column:1/-1}.profile-avatar-wrapper{align-items:center;gap:1rem;padding:.75rem 0;display:flex}.profile-avatar{object-fit:cover;border:3px solid var(--border);border-radius:50%;width:72px;height:72px}.profile-avatar-placeholder{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:1.3rem;font-weight:800;display:flex}.profile-avatar-actions{align-items:center;gap:.5rem;display:flex}.form-hint{color:var(--text-light);grid-column:1/-1;margin:-.5rem 0 .25rem;font-size:.75rem}.input-with-toggle{align-items:center;gap:.35rem;display:flex}.input-with-toggle input{flex:1}.input-with-toggle .btn-icon{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text-light);background:0 0;align-items:center;padding:.4rem .55rem;display:flex}.btn-outline{color:var(--text);border:1px solid var(--border);background:0 0}.btn-outline:hover{background:var(--bg)}.btn-danger-outline{color:var(--danger);background:0 0;border:1px solid #dc262640}.btn-danger-outline:hover{background:var(--danger-bg)}.btn-xs{padding:.2rem .5rem;font-size:.68rem}.btn-icon-only{justify-content:center;align-items:center;width:32px;height:32px;padding:0;display:inline-flex}.alert-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #dc262626}.page-subtitle{color:var(--text-dim);margin-top:.2rem;font-size:.8rem}.settings-grid{flex-direction:column;gap:1.25rem;display:flex}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.card-title{color:var(--text);align-items:center;gap:.4rem;font-size:.9rem;font-weight:700;display:flex}.card-title svg{width:15px;height:15px;color:var(--primary)}.card-body{padding:1.25rem}.form-group{flex-direction:column;gap:.35rem;margin-bottom:.85rem;display:flex}.form-label{color:var(--text);font-size:.78rem;font-weight:600}.form-control{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--bg-card);transition:var(--transition);font-size:.82rem;font-family:var(--font);width:100%;padding:.5rem .75rem}.form-control:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb14}.form-control-sm{padding:.35rem .65rem;font-size:.78rem}.form-hint{color:var(--text-light);font-size:.72rem}.form-hint code{background:var(--bg);border-radius:3px;padding:.1rem .3rem;font-size:.7rem}.form-row{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.85rem;margin-bottom:.85rem;display:grid}.form-row-with-delete{grid-template-columns:1fr 1fr auto;align-items:end;gap:.75rem;margin-bottom:.75rem;display:grid}.form-section-title{color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:.4rem;margin:1.25rem 0 .75rem;font-size:.75rem;font-weight:700;display:flex}.form-section-title svg{width:13px;height:13px}.preview-box{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.5rem;padding:.75rem 1rem;display:flex}.preview-label{color:var(--text-dim);text-transform:uppercase;font-size:.7rem;font-weight:700}.preview-text{color:var(--text);font-size:.8rem}.empty-state{color:var(--text-light);background:var(--bg-card);border-radius:var(--radius-lg);border:2px dashed var(--border);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 1.5rem;display:flex}.empty-state svg{opacity:.3}.empty-state-sm{color:var(--text-light);padding:.5rem 0;font-size:.8rem}.filter-bar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.search-box{flex:1;min-width:200px;position:relative}.search-box .search-icon{color:var(--text-light);pointer-events:none;width:14px;height:14px;position:absolute;top:50%;left:.65rem;transform:translateY(-50%)}.search-box .form-control{padding-left:2rem}.table-wrapper{overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:.82rem}.table th{text-align:left;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap;padding:.65rem 1rem;font-size:.7rem;font-weight:700}.table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:.75rem 1rem}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--bg)}.text-center{text-align:center}.text-dim{color:var(--text-dim)}.text-sm{font-size:.78rem}.user-cell{align-items:center;gap:.65rem;display:flex}.user-avatar-sm{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.72rem;font-weight:800;display:flex}.user-name{color:var(--text);font-size:.82rem;font-weight:600}.user-email{color:var(--text-dim);font-size:.72rem}.badge-you{background:var(--primary-bg);color:var(--primary);border-radius:99px;margin-left:.3rem;padding:.1rem .4rem;font-size:.62rem;font-weight:700;display:inline-block}.role-badge{border-radius:99px;padding:.2rem .6rem;font-size:.7rem;font-weight:700;display:inline-block}.badge{border-radius:99px;align-items:center;gap:.2rem;padding:.15rem .5rem;font-size:.65rem;font-weight:700;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.toggle-btn{cursor:pointer;border-radius:var(--radius);transition:var(--transition);background:0 0;border:none;align-items:center;gap:.3rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.toggle-btn.active{color:var(--success)}.toggle-btn.inactive{color:var(--text-light)}.toggle-btn:disabled{opacity:.4;cursor:not-allowed}.action-btns{align-items:center;gap:.4rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:2000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg-card);border-radius:var(--radius-lg);flex-direction:column;width:100%;max-width:520px;max-height:90vh;display:flex;box-shadow:0 20px 60px #0003}.modal-lg{max-width:720px}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.1rem 1.5rem;display:flex}.modal-header h2{color:var(--text);font-size:1rem;font-weight:700}.modal-close{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:30px;height:30px;color:var(--text-dim);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--danger-bg);color:var(--danger)}.modal-body{flex:1;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;gap:.6rem;padding:1rem 1.5rem;display:flex}.template-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.template-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);flex-direction:column;gap:.6rem;padding:1.25rem;display:flex}.template-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary)}.template-inactive{opacity:.6}.template-card-header{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.template-type-badge{border-radius:99px;padding:.2rem .6rem;font-size:.68rem;font-weight:700}.template-name{color:var(--text);font-size:.9rem;font-weight:700}.template-meta{color:var(--text-dim);font-size:.75rem}.template-colors{align-items:center;gap:.4rem;display:flex}.color-dot{border:1px solid #0000001a;border-radius:50%;width:14px;height:14px}.template-font{color:var(--text-dim);margin-left:.25rem;font-size:.7rem}.template-actions{flex-wrap:wrap;align-items:center;gap:.4rem;margin-top:.25rem;display:flex}.color-input-row{align-items:center;gap:.5rem;display:flex}.color-picker{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;flex-shrink:0;width:36px;height:36px;padding:2px}.checkbox-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem;margin-bottom:.85rem;display:grid}.checkbox-label{color:var(--text);cursor:pointer;align-items:center;gap:.4rem;font-size:.8rem;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer}.perm-count{background:var(--primary-bg);color:var(--primary);border-radius:99px;margin-left:auto;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.perm-groups{flex-direction:column;gap:.75rem;display:flex}.perm-group{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem}.perm-group-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.perm-resource{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:.72rem;font-weight:700}.perm-keys{flex-wrap:wrap;gap:.35rem;display:flex}.perm-key-btn{border:1px solid var(--border);background:var(--bg-card);color:var(--text-dim);cursor:pointer;transition:var(--transition);border-radius:99px;align-items:center;gap:.25rem;padding:.25rem .6rem;font-size:.72rem;font-weight:600;display:inline-flex}.perm-key-btn:hover{border-color:var(--primary);color:var(--primary)}.perm-key-btn.selected{background:var(--primary-bg);color:var(--primary);border-color:var(--primary)}.perm-key-btn.from-role{color:#166534;cursor:default;opacity:.85;background:#f0fdf4;border-color:#86efac}.perm-key-btn.from-role.selected{color:#166534;background:#dcfce7;border-color:#22c55e}.nav-group-label{color:var(--text-light);text-transform:uppercase;letter-spacing:1px;padding:.75rem 1rem .35rem;font-size:.65rem;font-weight:700;display:block}.footer-links{margin-top:.25rem}.footer-links a{color:var(--primary);text-decoration:none}.footer-links a:hover{text-decoration:underline}.dash-page{flex-direction:column;gap:1.25rem;display:flex}.dash-hero{background:linear-gradient(135deg,#0f172a 0%,#1e3a8a 45%,#2563eb 100%);border-radius:16px;justify-content:space-between;align-items:center;gap:1.5rem;min-height:140px;padding:2rem 2.25rem;display:flex;position:relative;overflow:hidden}.dash-hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#6366f140 0%,#0000 70%);border-radius:50%;width:260px;height:260px;position:absolute;top:-60px;right:120px}.dash-hero:after{content:"";pointer-events:none;background:radial-gradient(circle,#3b82f633 0%,#0000 70%);border-radius:50%;width:300px;height:300px;position:absolute;bottom:-80px;right:-40px}.dash-hero-dots{pointer-events:none;background-image:radial-gradient(#ffffff0f 1px,#0000 1px);background-size:24px 24px;position:absolute;inset:0}.dash-hero-left{z-index:1;position:relative}.dash-hero-greeting{color:#ffffff80;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:.4rem;font-size:.72rem;font-weight:600}.dash-hero-name{color:#fff;margin-bottom:.5rem;font-size:1.6rem;font-weight:800;line-height:1.15}.dash-hero-name span{background:linear-gradient(90deg,#93c5fd,#c4b5fd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.dash-hero-sub{color:#ffffff8c;max-width:420px;font-size:.82rem}.dash-hero-role-row{flex-wrap:wrap;align-items:center;gap:.65rem;margin-bottom:.6rem;display:flex}.dash-hero-role-badge{letter-spacing:.3px;border-radius:99px;align-items:center;padding:.2rem .7rem;font-size:.7rem;font-weight:700;display:inline-flex}.dash-hero-email{color:#fff6;font-size:.72rem}.dash-hero-right{z-index:1;flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.75rem;display:flex;position:relative}.dash-clock{text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #ffffff1f;border-radius:12px;padding:.85rem 1.35rem}.dash-clock-time{color:#fff;letter-spacing:-.5px;font-size:1.65rem;font-weight:800;line-height:1}.dash-clock-date{color:#ffffff80;text-transform:uppercase;letter-spacing:.8px;margin-top:.25rem;font-size:.68rem}.dash-hero-org{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:99px;align-items:center;gap:.5rem;padding:.35rem .85rem;display:flex}.dash-hero-org-dot{background:#4ade80;border-radius:50%;width:7px;height:7px;animation:2s infinite pulse-dot;box-shadow:0 0 6px #4ade80}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.dash-hero-org span{color:#fff9;font-size:.72rem;font-weight:600}.dash-stats{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}@media (width>=1280px){.dash-stats{grid-template-columns:repeat(4,1fr)}}.dash-stat-card{background:var(--bg-card);border:1px solid var(--border);color:inherit;border-radius:14px;flex-direction:column;gap:.85rem;padding:1.35rem 1.4rem;text-decoration:none;transition:all .2s;display:flex;position:relative;overflow:hidden}.dash-stat-card:before{content:"";background:var(--sc,var(--primary));transform-origin:0;border-radius:14px 14px 0 0;height:3px;transition:transform .3s;position:absolute;top:0;left:0;right:0;transform:scaleX(.3)}.dash-stat-card:hover{border-color:#0000;transform:translateY(-3px);box-shadow:0 8px 24px #00000014}.dash-stat-card:hover:before{transform:scaleX(1)}.dash-stat-top{justify-content:space-between;align-items:center;display:flex}.dash-stat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.dash-stat-icon svg{width:19px;height:19px}.dash-stat-change{border-radius:99px;padding:.2rem .5rem;font-size:.68rem;font-weight:700}.dash-stat-change.up{color:#059669;background:#ecfdf5}.dash-stat-change.neutral{background:var(--bg);color:var(--text-dim)}.dash-stat-value{color:var(--text);font-variant-numeric:tabular-nums;margin-bottom:.3rem;font-size:1.75rem;font-weight:800;line-height:1}.dash-stat-label{color:var(--text-dim);font-size:.75rem;font-weight:500}.dash-qa-title{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:.75rem;font-size:.72rem;font-weight:700}.dash-qa-grid{grid-template-columns:repeat(9,1fr);gap:.75rem;display:grid}.dash-qa-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-dim);text-align:center;cursor:pointer;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:.55rem;padding:1rem .5rem;font-size:.7rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.dash-qa-btn:hover{color:var(--text);border-color:var(--qa-color,var(--primary));background:var(--qa-bg,var(--primary-bg));transform:translateY(-3px);box-shadow:0 6px 20px #00000014}.dash-qa-icon{border-radius:9px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.dash-qa-icon svg{width:16px;height:16px}.dash-qa-btn:hover .dash-qa-icon{background:var(--qa-color,var(--primary))!important}.dash-qa-btn:hover .dash-qa-icon svg{color:#fff!important}.dash-main-grid{grid-template-columns:1fr 360px;gap:1.25rem;display:grid}.dash-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;flex-direction:column;display:flex;overflow:hidden}.dash-panel-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.35rem;display:flex}.dash-panel-title{color:var(--text);align-items:center;gap:.5rem;font-size:.88rem;font-weight:700;display:flex}.dash-panel-title svg{width:15px;height:15px;color:var(--primary)}.dash-panel-badge{background:var(--primary-bg);color:var(--primary);border-radius:99px;padding:.15rem .5rem;font-size:.65rem;font-weight:700}.dash-panel-link{color:var(--primary);border-radius:var(--radius);transition:var(--transition);align-items:center;gap:.25rem;padding:.3rem .65rem;font-size:.75rem;font-weight:600;text-decoration:none;display:flex}.dash-panel-link:hover{background:var(--primary-bg)}.dash-table-wrap{flex:1;overflow-x:auto}.dash-table{border-collapse:collapse;width:100%}.dash-table th{text-align:left;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px;background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap;padding:.6rem 1.25rem;font-size:.65rem;font-weight:700}.dash-table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:.85rem 1.25rem;font-size:.8rem}.dash-table tr:last-child td{border-bottom:none}.dash-table tbody tr{transition:var(--transition)}.dash-table tbody tr:hover td{background:var(--bg)}.dash-donor-cell{align-items:center;gap:.65rem;display:flex}.dash-donor-av{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.65rem;font-weight:800;display:flex}.dash-donor-name{color:var(--text);font-size:.8rem;font-weight:600}.dash-donor-email{color:var(--text-dim);font-size:.68rem}.dash-amount{color:#059669;font-size:.85rem;font-weight:700}.dash-purpose{color:var(--text-dim);font-size:.73rem}.dash-status{text-transform:capitalize;border-radius:99px;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.68rem;font-weight:700;display:inline-flex}.dash-status:before{content:"●";font-size:.45rem}.dash-status.success{color:#059669;background:#ecfdf5}.dash-status.pending{color:#d97706;background:#fffbeb}.dash-status.failed{color:#dc2626;background:#fef2f2}.dash-date{color:var(--text-dim);white-space:nowrap;font-size:.7rem}.dash-empty{text-align:center;color:var(--text-light);padding:3rem 1.25rem;font-size:.8rem}.dash-msgs{flex:1;overflow-y:auto}.dash-msg-item{border-bottom:1px solid var(--border);transition:var(--transition);cursor:pointer;align-items:flex-start;gap:.75rem;padding:.9rem 1.25rem;display:flex}.dash-msg-item:last-child{border-bottom:none}.dash-msg-item:hover{background:var(--bg)}.dash-msg-item.unread{background:#fafbff}.dash-msg-av{background:linear-gradient(135deg, var(--primary), #7c3aed);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.72rem;font-weight:800;display:flex}.dash-msg-body{flex:1;min-width:0}.dash-msg-row{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.dash-msg-name{color:var(--text);font-size:.8rem;font-weight:600}.dash-msg-time{color:var(--text-light);flex-shrink:0;font-size:.65rem}.dash-msg-text{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;margin-top:.2rem;font-size:.72rem;overflow:hidden}.dash-unread-badge{background:var(--primary);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:.35rem}.dash-bottom-grid{grid-template-columns:1fr 1fr 300px;gap:1.25rem;display:grid}.dash-content-item{border-bottom:1px solid var(--border);transition:var(--transition);align-items:center;gap:.85rem;padding:.8rem 1.25rem;display:flex}.dash-content-item:last-child{border-bottom:none}.dash-content-item:hover{background:var(--bg)}.dash-content-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.dash-content-icon svg{width:13px;height:13px}.dash-content-label{color:var(--text);flex:1;font-size:.78rem;font-weight:500}.dash-content-bar-wrap{background:var(--border);border-radius:99px;width:70px;height:4px;overflow:hidden}.dash-content-bar{border-radius:99px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.dash-content-count{color:var(--text);text-align:right;min-width:24px;font-size:.82rem;font-weight:700}.dash-status-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.75rem 1.25rem;font-size:.78rem;display:flex}.dash-status-item:last-child{border-bottom:none}.dash-status-key{color:var(--text-dim);font-weight:500}.dash-status-val{color:var(--text);font-weight:600}.dash-status-online{color:#059669;align-items:center;gap:.35rem;font-size:.75rem;font-weight:600;display:inline-flex}.dash-status-online:before{content:"";background:#4ade80;border-radius:50%;width:6px;height:6px;animation:2s infinite pulse-dot;box-shadow:0 0 5px #4ade80}.dash-activity-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:.75rem;padding:.8rem 1.25rem;display:flex}.dash-activity-item:last-child{border-bottom:none}.dash-activity-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:.35rem}.dash-activity-text{color:var(--text-dim);font-size:.75rem;line-height:1.5}.dash-activity-text strong{color:var(--text);font-weight:600}.dash-activity-time{color:var(--text-light);margin-top:.15rem;font-size:.65rem}@media (width<=1280px){.dash-qa-grid{grid-template-columns:repeat(5,1fr)}.dash-bottom-grid{grid-template-columns:1fr 1fr}.dash-bottom-grid>:last-child{grid-column:1/-1}}@media (width<=1100px){.dash-stats{grid-template-columns:repeat(4,1fr)}.dash-main-grid{grid-template-columns:1fr}.dash-qa-grid{grid-template-columns:repeat(5,1fr)}}@media (width<=768px){.dash-hero{min-height:unset;padding:1.35rem 1.5rem}.dash-hero-right{display:none}.dash-hero-name{font-size:1.25rem}.dash-stats{grid-template-columns:repeat(2,1fr)}.dash-qa-grid{grid-template-columns:repeat(4,1fr)}.dash-bottom-grid{grid-template-columns:1fr}.dash-stat-value{font-size:1.5rem}}@media (width<=540px){.dash-hero{padding:1.1rem 1.25rem}.dash-hero-name{font-size:1.1rem}.dash-stats{grid-template-columns:1fr 1fr;gap:.75rem}.dash-stat-card{padding:1rem}.dash-stat-value{font-size:1.3rem}.dash-qa-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.dash-qa-btn{padding:.75rem .4rem;font-size:.65rem}.dash-qa-icon{width:30px;height:30px}}@media (width<=380px){.dash-stats{grid-template-columns:1fr}.dash-qa-grid{grid-template-columns:repeat(3,1fr)}}.crud-form,.site-settings-form{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;margin-bottom:1.5rem;padding:1.5rem;display:grid}.form-group{flex-direction:column;gap:.35rem;display:flex}.form-group.full{grid-column:1/-1}.form-group label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:.72rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);transition:var(--transition);padding:.6rem .75rem;font-size:.85rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);background:var(--bg-card);box-shadow:0 0 0 3px var(--primary-bg);outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-light)}.form-actions{border-top:1px solid var(--border);flex-wrap:wrap;grid-column:1/-1;gap:.6rem;padding-top:.85rem;display:flex}.section-title{border-top:1px solid var(--border);color:var(--text);grid-column:1/-1;align-items:center;gap:.5rem;margin-top:.35rem;padding-top:1rem;font-size:.88rem;font-weight:700;display:flex}.section-title:first-child{border-top:none;margin-top:0;padding-top:0}.section-title svg{width:16px;height:16px;color:var(--primary)}.form-sub{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);grid-column:1/-1;align-items:center;gap:.5rem;padding:.75rem;display:flex}.form-sub input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);flex:1;padding:.5rem .65rem;font-size:.82rem}.form-sub input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg);outline:none}.policies-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.policy-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.25rem}.policy-card h3{margin-bottom:.25rem;font-size:.95rem;font-weight:700}.policy-card p{color:var(--text-dim);margin-bottom:.85rem;font-size:.78rem}.policy-card textarea{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;min-height:140px;color:var(--text);resize:vertical;padding:.75rem;font-size:.82rem}.policy-card textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg);background:var(--bg-card);outline:none}.image-upload-wrapper{width:100%}.image-upload-btn{background:var(--bg);color:var(--text);border:1px dashed var(--border);border-radius:var(--radius);cursor:pointer;transition:var(--transition);align-items:center;gap:.45rem;padding:.5rem .85rem;font-size:.82rem;font-weight:500;display:inline-flex}.image-upload-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}.image-upload-btn:disabled{opacity:.5;cursor:not-allowed}.image-upload-btn svg{width:14px;height:14px}.image-preview{object-fit:cover;border:1px solid var(--border);border-radius:6px;width:45px;height:45px}.image-upload-error{color:var(--danger);margin-top:.25rem;font-size:.75rem}.file-upload-wrapper{width:100%}@media (width<=768px){.crud-form,.site-settings-form{grid-template-columns:1fr;padding:1.15rem}.policies-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions button{width:100%}}@media (width<=480px){.crud-form,.site-settings-form{gap:.85rem;padding:1rem}}.table-container{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden}.table-scroll-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;min-width:450px}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.82rem}.data-table th:last-child,.data-table td:last-child{text-align:right}.data-table thead th{background:var(--bg);color:var(--text-dim);text-transform:uppercase;letter-spacing:.7px;border-bottom:2px solid var(--border);font-size:.68rem;font-weight:600;position:sticky;top:0}.data-table tbody tr{transition:var(--transition)}.data-table tbody tr:hover{background:var(--primary-bg)}.data-table tbody tr:last-child td{border-bottom:none}.data-table .actions{justify-content:flex-end;align-items:center;gap:.35rem;display:flex}.donation-table{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto}@media (width<=1024px){.table-container{overflow-x:auto}.data-table th,.data-table td{padding:.65rem .8rem;font-size:.78rem}}@media (width<=768px){.data-table th,.data-table td{padding:.55rem .65rem;font-size:.75rem}.data-table .actions{gap:.25rem}.btn-icon{width:28px;height:28px}}@media (width<=480px){.data-table th,.data-table td{padding:.45rem .55rem;font-size:.72rem}.table-container{border-radius:var(--radius)}.btn-icon{width:26px;height:26px}.data-table{min-width:380px}}.hide-mobile{display:table-cell}@media (width<=768px){.hide-mobile{display:none!important}}.dm-page{flex-direction:column;gap:1.25rem;display:flex}.dm-page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.dm-title{color:var(--text);font-size:1.3rem;font-weight:800}.dm-subtitle{color:var(--text-dim);margin-top:.2rem;font-size:.8rem}.dm-btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;transition:var(--transition);border:none;align-items:center;gap:.4rem;padding:.5rem 1.1rem;font-size:.82rem;font-weight:600;text-decoration:none;display:inline-flex}.dm-btn-primary:hover{background:var(--primary-h)}.dm-btn-outline{color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:var(--transition);background:0 0;align-items:center;gap:.4rem;padding:.5rem 1.1rem;font-size:.82rem;font-weight:600;display:inline-flex}.dm-btn-outline:hover{background:var(--bg)}.dm-btn-sm{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:var(--transition);align-items:center;gap:.3rem;padding:.3rem .7rem;font-size:.73rem;font-weight:600;display:inline-flex}.dm-btn-sm:hover{background:var(--primary-bg);color:var(--primary);border-color:var(--primary)}.dm-btn-clear{background:var(--danger-bg);color:var(--danger);border-color:#dc262633}.dm-btn-clear:hover{background:var(--danger);color:#fff}.dm-alert{border-radius:var(--radius);padding:.7rem 1rem;font-size:.82rem;font-weight:500}.dm-alert-success{background:var(--success-bg);color:var(--success);border:1px solid #05966926}.dm-alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid #dc262626}.dm-stats{grid-template-columns:repeat(6,1fr);gap:1rem;display:grid}.dm-stats-3{grid-template-columns:repeat(3,1fr)}.dm-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:.6rem;padding:1.1rem 1.2rem;transition:all .2s;display:flex;position:relative;overflow:hidden}.dm-stat-card:before{content:"";background:var(--sc,var(--primary));border-radius:14px 14px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.dm-stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000012}.dm-stat-top{justify-content:space-between;align-items:center;display:flex}.dm-stat-icon{border-radius:9px;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.dm-stat-icon svg{width:17px;height:17px}.dm-stat-value{color:var(--text);font-size:1.45rem;font-weight:800;line-height:1}.dm-stat-label{color:var(--text-dim);font-size:.72rem;font-weight:500}.dm-stat-sub{color:var(--text-light);font-size:.68rem}.dm-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;overflow:hidden}.dm-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.9rem 1.25rem;display:flex}.dm-card-title{color:var(--text);align-items:center;gap:.45rem;font-size:.88rem;font-weight:700;display:flex}.dm-card-title svg{width:14px;height:14px;color:var(--primary)}.dm-card-link{color:var(--primary);align-items:center;gap:.2rem;font-size:.75rem;font-weight:600;text-decoration:none;display:flex}.dm-card-link:hover{text-decoration:underline}.dm-grid-2{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.dm-table-wrap{overflow-x:auto}.dm-table{border-collapse:collapse;width:100%}.dm-table th{text-align:left;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap;padding:.6rem 1.1rem;font-size:.65rem;font-weight:700}.dm-table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:.8rem 1.1rem;font-size:.8rem}.dm-table tr:last-child td{border-bottom:none}.dm-table tbody tr:hover td{background:var(--bg)}.dm-total-row td{font-size:.82rem;background:var(--bg)!important}.dm-row-empty td{opacity:.45}.dm-donor-cell{align-items:center;gap:.6rem;display:flex}.dm-av{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.65rem;font-weight:800;display:flex}.dm-av-lg{width:46px;height:46px;font-size:1rem}.dm-donor-name{color:var(--text);font-size:.8rem;font-weight:600}.dm-donor-email{color:var(--text-dim);font-size:.68rem}.dm-amount{color:#059669;font-size:.85rem;font-weight:700}.dm-dim{color:var(--text-dim);font-size:.75rem}.dm-mono{font-family:monospace}.dm-empty{text-align:center;color:var(--text-light);padding:2.5rem;font-size:.8rem}.dm-status{text-transform:capitalize;border-radius:99px;align-items:center;gap:.25rem;padding:.18rem .55rem;font-size:.68rem;font-weight:700;display:inline-flex}.dm-status:before{content:"●";font-size:.4rem}.dm-status-success{color:#059669;background:#ecfdf5}.dm-status-pending{color:#d97706;background:#fffbeb}.dm-status-failed{color:#dc2626;background:#fef2f2}.dm-count-badge{background:var(--primary-bg);color:var(--primary);border-radius:99px;padding:.15rem .55rem;font-size:.7rem;font-weight:700;display:inline-block}.dm-doc-btn{background:var(--primary-bg);color:var(--primary);border-radius:var(--radius);transition:var(--transition);align-items:center;gap:.2rem;padding:.2rem .5rem;font-size:.68rem;font-weight:700;text-decoration:none;display:inline-flex}.dm-doc-btn:hover{background:var(--primary);color:#fff}.dm-doc-btn-green{color:#059669;background:#ecfdf5}.dm-doc-btn-green:hover{color:#fff;background:#059669}.dm-search-bar{flex:1;min-width:200px;position:relative}.dm-search-icon{color:var(--text-light);pointer-events:none;width:14px;height:14px;position:absolute;top:50%;left:.7rem;transform:translateY(-50%)}.dm-search-input{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:var(--bg-card);font-size:.82rem;font-family:var(--font);transition:var(--transition);padding:.5rem .75rem .5rem 2.1rem}.dm-search-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb14}.dm-filters{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.dm-filter-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:.75rem;padding:1rem 1.25rem;display:flex}.dm-filter-row{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.dm-date-label{color:var(--text-dim);white-space:nowrap;font-size:.75rem;font-weight:600}.dm-select{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--bg-card);font-size:.8rem;font-family:var(--font);cursor:pointer;transition:var(--transition);padding:.48rem .75rem}.dm-select:focus{border-color:var(--primary);outline:none}.dm-toggle-group{border:1px solid var(--border);border-radius:var(--radius);display:flex;overflow:hidden}.dm-toggle-btn{background:var(--bg-card);color:var(--text-dim);cursor:pointer;transition:var(--transition);font-size:.78rem;font-weight:600;font-family:var(--font);border:none;padding:.45rem .9rem}.dm-toggle-btn:not(:last-child){border-right:1px solid var(--border)}.dm-toggle-btn.active{background:var(--primary);color:#fff}.dm-pagination{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:1rem;padding:.85rem 1.25rem;display:flex}.dm-page-btn{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:var(--transition);color:var(--text);padding:.4rem .9rem;font-size:.78rem;font-weight:600}.dm-page-btn:hover:not(:disabled){background:var(--primary-bg);color:var(--primary);border-color:var(--primary)}.dm-page-btn:disabled{opacity:.4;cursor:not-allowed}.dm-page-info{color:var(--text-dim);font-size:.78rem}.dm-trend-chart{align-items:flex-end;gap:.5rem;height:180px;padding:1.25rem 1.25rem .5rem;display:flex}.dm-trend-col{flex-direction:column;flex:1;align-items:center;gap:.3rem;display:flex}.dm-trend-bar-wrap{background:var(--bg);border-radius:6px 6px 0 0;flex:1;align-items:flex-end;width:100%;min-height:8px;display:flex;overflow:hidden}.dm-trend-bar{background:linear-gradient(#3b82f6,#2563eb);border-radius:6px 6px 0 0;width:100%;min-height:4px;transition:height .6s cubic-bezier(.4,0,.2,1)}.dm-trend-label{color:var(--text-dim);font-size:.65rem;font-weight:600}.dm-trend-val{color:var(--text-light);font-size:.62rem}.dm-bar-chart{align-items:flex-end;gap:.4rem;height:200px;padding:1.25rem 1.25rem 0;display:flex}.dm-bar-col{flex-direction:column;flex:1;align-items:center;gap:.3rem;display:flex}.dm-bar-wrap{flex:1;align-items:flex-end;width:100%;min-height:8px;display:flex}.dm-bar-inner{border-radius:6px 6px 0 0;flex-direction:column-reverse;width:100%;display:flex;overflow:hidden}.dm-bar-fill{width:100%;min-height:0;transition:height .7s cubic-bezier(.4,0,.2,1)}.dm-bar-onetime{background:#2563eb}.dm-bar-recurring{background:#7c3aed}.dm-bar-label{color:var(--text-dim);text-align:center;font-size:.62rem;font-weight:600}.dm-bar-val{color:var(--text-light);font-size:.6rem}.dm-chart-legend{color:var(--text-dim);align-items:center;gap:.4rem;padding:.75rem 1.25rem 1rem;font-size:.72rem;font-weight:500;display:flex}.dm-legend-dot{border-radius:3px;width:10px;height:10px;display:inline-block}.dm-purpose-list{flex-direction:column;gap:.65rem;padding:.75rem 1.25rem;display:flex}.dm-purpose-item{align-items:center;gap:.75rem;display:flex}.dm-purpose-label{color:var(--text);min-width:100px;font-size:.78rem;font-weight:500}.dm-purpose-bar-wrap{background:var(--border);border-radius:99px;flex:1;height:6px;overflow:hidden}.dm-purpose-bar{background:linear-gradient(90deg,#2563eb,#7c3aed);border-radius:99px;height:100%;transition:width .7s}.dm-purpose-val{color:var(--text);text-align:right;min-width:80px;font-size:.75rem;font-weight:700}.dm-pct-bar-wrap{align-items:center;gap:.5rem;display:flex}.dm-pct-bar{background:var(--primary);border-radius:99px;min-width:2px;height:5px;transition:width .5s}.dm-pct-label{color:var(--text-dim);white-space:nowrap;font-size:.7rem;font-weight:600}.dm-modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:2000;background:#00000080;justify-content:center;align-items:flex-start;padding:2rem 1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.dm-modal{background:var(--bg-card);border-radius:16px;flex-direction:column;width:100%;max-width:680px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0003}.dm-modal-md{max-width:520px}.dm-modal-header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex}.dm-modal-name{color:var(--text);flex:1;font-size:1rem;font-weight:700}.dm-modal-sub{color:var(--text-dim);margin-top:.15rem;font-size:.78rem}.dm-modal-close{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:30px;height:30px;color:var(--text-dim);transition:var(--transition);flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;display:flex}.dm-modal-close:hover{background:var(--danger-bg);color:var(--danger)}.dm-modal-info{border-bottom:1px solid var(--border);flex-direction:column;gap:.4rem;padding:1rem 1.5rem;display:flex}.dm-modal-section-title{color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px;padding:.75rem 1.5rem .25rem;font-size:.68rem;font-weight:700}.dm-modal-table-wrap{flex:1;overflow-y:auto}.dm-modal-body{flex:1;padding:1.25rem 1.5rem;overflow-y:auto}.dm-modal-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;gap:.6rem;padding:1rem 1.5rem;display:flex}.dm-modal form{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.dm-form-row{grid-template-columns:1fr 1fr;gap:.85rem;margin-bottom:.85rem;display:grid}.dm-form-group{flex-direction:column;gap:.3rem;display:flex}.dm-form-label{color:var(--text);font-size:.75rem;font-weight:600}.dm-form-input{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--bg-card);font-size:.82rem;font-family:var(--font);transition:var(--transition);width:100%;padding:.5rem .75rem}.dm-form-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb14}.dm-qr-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;display:grid}.dm-qr-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;flex-direction:column;transition:all .2s;display:flex;overflow:hidden}.dm-qr-card:hover{border-color:var(--primary);box-shadow:0 6px 20px #00000014}.dm-qr-inactive{opacity:.6}.dm-qr-card-header{border-bottom:1px solid var(--border);align-items:center;gap:.5rem;padding:.85rem 1rem;display:flex}.dm-qr-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dm-qr-name{color:var(--text);flex:1;font-size:.85rem;font-weight:700}.dm-qr-actions{gap:.3rem;display:flex}.dm-icon-btn{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:28px;height:28px;color:var(--text-dim);transition:var(--transition);justify-content:center;align-items:center;display:flex}.dm-icon-btn:hover{background:var(--primary-bg);color:var(--primary);border-color:var(--primary)}.dm-icon-btn-danger:hover{background:var(--danger-bg);color:var(--danger);border-color:#dc262633}.dm-qr-img-wrap{background:var(--bg);justify-content:center;align-items:center;min-height:180px;padding:1.25rem;display:flex}.dm-qr-img{object-fit:contain;border-radius:var(--radius);width:150px;height:150px}.dm-qr-placeholder{border:2px dashed var(--border);border-radius:var(--radius);width:150px;height:150px;color:var(--text-light);justify-content:center;align-items:center;font-size:.75rem;display:flex}.dm-qr-info{flex-direction:column;flex:1;gap:.35rem;padding:.85rem 1rem;display:flex}.dm-qr-upi{align-items:center;gap:.4rem;display:flex}.dm-qr-upi-id{color:var(--primary);font-family:monospace;font-size:.8rem;font-weight:600}.dm-qr-meta{color:var(--text-dim);font-size:.72rem}.dm-qr-desc{color:var(--text-light);margin-top:.2rem;font-size:.72rem}.dm-qr-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.dm-toggle-active{cursor:pointer;transition:var(--transition);background:var(--bg);color:var(--text-dim);border:none;border-radius:99px;padding:.25rem .65rem;font-size:.7rem;font-weight:700}.dm-toggle-active.active{color:#059669;background:#ecfdf5}.dm-empty-state{background:var(--bg-card);border:2px dashed var(--border);text-align:center;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 1.5rem;display:flex}.dm-empty-icon{font-size:2.5rem}.dm-empty-state h3{color:var(--text);font-size:1rem;font-weight:700}.dm-empty-state p{color:var(--text-dim);font-size:.8rem}.dm-link{color:var(--primary);text-decoration:none}.dm-link:hover{text-decoration:underline}@media (width<=1200px){.dm-stats{grid-template-columns:repeat(3,1fr)}}@media (width<=900px){.dm-stats{grid-template-columns:repeat(2,1fr)}.dm-grid-2{grid-template-columns:1fr}.dm-stats-3{grid-template-columns:1fr 1fr}}@media (width<=640px){.dm-stats{grid-template-columns:1fr 1fr}.dm-stats-3{grid-template-columns:1fr}.dm-filters{flex-direction:column;align-items:stretch}.dm-filter-row{flex-direction:column}.dm-form-row{grid-template-columns:1fr}.dm-qr-grid{grid-template-columns:1fr 1fr}.dm-bar-chart{height:140px}.dm-trend-chart{height:130px}}@media (width<=420px){.dm-qr-grid,.dm-stats{grid-template-columns:1fr}}.ofd-form{flex-direction:column;gap:0;display:flex}.ofd-grid{grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:0;display:grid}.ofd-section{background:var(--bg-card);border:1px solid var(--border);border-top:3px solid var(--sec-color,var(--primary));border-radius:14px;overflow:hidden}.ofd-section-header{border-bottom:1px solid var(--border);background:var(--bg);align-items:center;gap:.65rem;padding:.9rem 1.25rem;display:flex}.ofd-section-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.ofd-section-icon svg{width:14px;height:14px}.ofd-section-title{color:var(--text);font-size:.85rem;font-weight:700}.ofd-section-body{flex-direction:column;gap:.75rem;padding:1.1rem 1.25rem;display:flex}.ofd-field{flex-direction:column;gap:.3rem;display:flex}.ofd-label{font-size:.75rem;font-weight:700}.ofd-required{color:#dc2626;margin-left:.2rem}.ofd-error{color:#dc2626;margin-top:.15rem;font-size:.68rem}.ofd-input{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:var(--bg-card);font-size:.82rem;font-family:var(--font);transition:var(--transition);padding:.5rem .75rem}.ofd-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb14}.ofd-input-error{border-color:#dc2626!important}.ofd-textarea{resize:vertical;min-height:60px}.ofd-uppercase{text-transform:uppercase}.ofd-input-icon-wrap{position:relative}.ofd-input-icon{pointer-events:none;width:14px;height:14px;position:absolute;top:50%;left:.65rem;transform:translateY(-50%)}.ofd-rupee{pointer-events:none;font-size:.85rem;font-weight:700;position:absolute;top:50%;left:.7rem;transform:translateY(-50%)}.ofd-input-with-icon{padding-left:2.1rem}.ofd-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.ofd-row-3{grid-template-columns:1fr 1fr 1fr}.ofd-radio-group{flex-wrap:wrap;gap:.4rem;display:flex}.ofd-radio{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;transition:var(--transition);border-radius:99px;align-items:center;gap:.35rem;padding:.3rem .7rem;font-size:.75rem;font-weight:600;display:flex}.ofd-radio input{display:none}.ofd-radio.checked{color:var(--text)}.ofd-radio:hover{border-color:var(--primary);color:var(--primary)}.ofd-submit-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-top:1.25rem;padding:1rem 1.25rem;display:flex}.ofd-submit-summary{color:var(--text-dim);font-size:.82rem}.ofd-success{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.ofd-success-icon{color:#059669;font-size:3rem}.ofd-success-icon svg{width:56px;height:56px}.ofd-success h2{color:var(--text);font-size:1.3rem;font-weight:800}.ofd-success p{color:var(--text-dim);font-size:.85rem}.ofd-success-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.donor-cards-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.donor-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;flex-direction:column;transition:all .2s;display:flex;position:relative;overflow:hidden}.donor-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000017}.donor-card-accent{flex-shrink:0;width:100%;height:4px}.donor-card-top{align-items:flex-start;gap:.75rem;padding:1rem 1.1rem .75rem;display:flex}.donor-card-av{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:.85rem;font-weight:800;display:flex}.donor-card-identity{flex:1;min-width:0}.donor-card-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:700;overflow:hidden}.donor-card-type{text-transform:capitalize;border-radius:99px;margin-top:.2rem;padding:.1rem .45rem;font-size:.62rem;font-weight:700;display:inline-block}.donor-card-total{text-align:right;flex-shrink:0}.donor-card-total-val{color:#059669;font-size:.95rem;font-weight:800}.donor-card-total-label{color:var(--text-light);font-size:.62rem}.donor-card-rows{flex-direction:column;flex:1;gap:0;padding:0 1.1rem;display:flex}.donor-card-row{border-bottom:1px solid var(--border);align-items:center;gap:.6rem;padding:.45rem 0;display:flex}.donor-card-row:last-child{border-bottom:none}.donor-card-row-icon{border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.donor-card-row-icon svg{width:11px;height:11px}.donor-card-row-body{flex-direction:column;min-width:0;display:flex}.donor-card-row-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:.6rem;font-weight:700}.donor-card-row-value{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;font-weight:500;overflow:hidden}.donor-card-footer{border-top:1px solid var(--border);background:var(--bg);justify-content:space-between;align-items:center;padding:.75rem 1.1rem;display:flex}.donor-card-source{border-radius:99px;padding:.15rem .5rem;font-size:.65rem;font-weight:700}.dfs-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;margin-bottom:1.25rem;padding:1.25rem}.dfs-card-title{color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px;margin-bottom:1rem;font-size:.78rem;font-weight:700}.dfs-presets{flex-wrap:wrap;gap:.6rem;display:flex}.dfs-preset-btn{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text);transition:var(--transition);font-size:.78rem;font-weight:600;font-family:var(--font);align-items:center;gap:.5rem;padding:.45rem .85rem;display:flex}.dfs-preset-btn:hover{border-color:var(--primary);background:var(--primary-bg);color:var(--primary)}.dfs-preset-dots{gap:3px;display:flex}.dfs-preset-dot{border-radius:50%;width:10px;height:10px}.dfs-fields-grid{flex-direction:column;gap:.6rem;display:flex}.dfs-field-row{background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);align-items:center;gap:1rem;padding:.6rem .75rem;display:flex}.dfs-field-preview{border-left:3px solid;flex-direction:column;flex:1;gap:.25rem;padding-left:.65rem;display:flex}.dfs-field-label{font-size:.75rem;font-weight:700}.dfs-field-input-mock{background:var(--border);border-radius:3px;width:70%;height:6px}.dfs-color-pick{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.dfs-color-input{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:32px;height:32px;padding:2px}.dfs-hex-input{border:1px solid var(--border);border-radius:var(--radius);width:80px;color:var(--text);background:var(--bg-card);padding:.3rem .5rem;font-family:monospace;font-size:.75rem}.dfs-hex-input:focus{border-color:var(--primary);outline:none}.ofd-lookup-card{text-align:center;background:var(--bg-card);border:2px dashed var(--border);border-radius:14px;flex-direction:column;align-items:center;gap:1rem;max-width:480px;margin:0 auto;padding:3rem 2rem;display:flex}.ofd-lookup-icon{background:var(--primary-bg);width:56px;height:56px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;display:flex}.ofd-lookup-icon svg{width:24px;height:24px}.ofd-lookup-card h3{color:var(--text);font-size:1.1rem;font-weight:700}.ofd-lookup-card p{color:var(--text-dim);font-size:.82rem}.ofd-lookup-row{gap:.5rem;width:100%;display:flex}.ofd-lookup-tabs{border:1px solid var(--border);border-radius:var(--radius);display:flex;overflow:hidden}.ofd-lookup-tab{background:var(--bg-card);color:var(--text-dim);cursor:pointer;font-size:.78rem;font-weight:600;font-family:var(--font);transition:var(--transition);border:none;padding:.4rem 1rem}.ofd-lookup-tab:not(:last-child){border-right:1px solid var(--border)}.ofd-lookup-tab.active{background:var(--primary);color:#fff}.ofd-lookup-input-row{gap:.5rem;width:100%;display:flex}.ofd-lookup-input-row .ofd-input{flex:1}.ofd-lookup-or{width:100%;color:var(--text-light);align-items:center;gap:.75rem;font-size:.75rem;font-weight:600;display:flex}.ofd-lookup-or:before,.ofd-lookup-or:after{content:"";background:var(--border);flex:1;height:1px}.ofd-donor-summary{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;flex-wrap:wrap;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.ofd-donor-summary-av{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1rem;font-weight:800;display:flex}.ofd-donor-summary-info{color:var(--text);flex-direction:column;flex:1;gap:.1rem;font-size:.82rem;display:flex}.ofd-donor-summary-id{color:var(--primary);font-size:.7rem;font-weight:700}.ofd-donor-summary-stats{gap:1.5rem;display:flex}.ofd-donor-stat{flex-direction:column;align-items:center;display:flex}.ofd-donor-stat-val{color:var(--text);font-size:1.1rem;font-weight:800}.ofd-donor-stat-label{color:var(--text-dim);text-transform:uppercase;font-size:.62rem}.dfs-field-inactive{opacity:.5}.dfs-field-meta{align-items:center;gap:.3rem;margin-top:.15rem;display:flex}.dfs-field-type{text-transform:uppercase;background:var(--bg);color:var(--text-light);border-radius:3px;padding:.1rem .35rem;font-size:.6rem;font-weight:700}.dfs-field-name{color:var(--text-light);font-family:monospace;font-size:.62rem}.dfs-controls{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.dfs-toggle-btn{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:32px;height:32px;color:var(--text-light);transition:var(--transition);justify-content:center;align-items:center;display:flex}.dfs-toggle-btn:hover{border-color:var(--primary);color:var(--primary)}.dfs-toggle-btn.active{background:var(--success-bg);color:var(--success);border-color:#05966933}.dfs-req-toggle{border:1px solid var(--border);text-transform:uppercase;cursor:pointer;color:var(--text-light);transition:var(--transition);-webkit-user-select:none;user-select:none;background:var(--bg);border-radius:5px;align-items:center;gap:.25rem;padding:.2rem .5rem;font-size:.62rem;font-weight:700;display:flex}.dfs-req-toggle input{display:none}.dfs-req-toggle.active{color:#dc2626;background:#fef2f2;border-color:#dc2626}.dfs-delete-btn{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:32px;height:32px;color:var(--text-light);transition:var(--transition);justify-content:center;align-items:center;display:flex}.dfs-delete-btn:hover{color:#dc2626;background:#fef2f2;border-color:#dc2626}.dfs-default-badge{text-transform:uppercase;background:var(--primary-bg);color:var(--primary);vertical-align:middle;border-radius:3px;margin-left:.35rem;padding:.05rem .35rem;font-size:.55rem;font-weight:700;display:inline-block}.dfs-required-star{color:#dc2626;margin-left:.15rem}.ofd-payment-grid{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.ofd-payment-option{border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:var(--transition);text-align:center;flex-direction:column;align-items:center;gap:.15rem;padding:.6rem .5rem;display:flex}.ofd-payment-option input{display:none}.ofd-payment-option:hover{border-color:var(--primary)}.ofd-payment-option.selected{border-color:var(--primary);background:var(--primary-bg)}.ofd-payment-label{color:var(--text);font-size:.78rem;font-weight:700}.ofd-payment-group{color:var(--text-light);text-transform:uppercase;font-size:.62rem;font-weight:600}.ofd-online-fields{background:var(--bg);border-radius:var(--radius);border:1px dashed var(--border);flex-direction:column;gap:.75rem;padding:.75rem;display:flex}.dm-expired-badge{color:#dc2626;background:#fef2f2;border-radius:99px;padding:.1rem .4rem;font-size:.6rem;font-weight:700}.dm-fixed-badge{color:#d97706;background:#fffbeb;border-radius:99px;padding:.1rem .4rem;font-size:.6rem;font-weight:700}.dm-expired-text{color:#dc2626!important}.dm-modal-lg{max-width:640px}.rg-id-bar{background:var(--primary-bg);border-radius:var(--radius);border:1px solid #2563eb26;align-items:center;gap:.75rem;padding:.6rem .85rem;display:flex}.rg-id-label{color:var(--primary);text-transform:uppercase;letter-spacing:.5px;font-size:.7rem;font-weight:700}.rg-id-value{color:var(--text);font-family:monospace;font-size:.85rem;font-weight:800}.rg-form-grid{grid-template-columns:1fr 1fr;gap:.85rem;display:grid}.rg-template-select-row{align-items:center;gap:.5rem;display:flex}.rg-template-select-row .dm-form-input{flex:1}.rg-template-indicator{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-shrink:0;align-items:center;gap:4px;padding:.2rem .5rem;display:flex}.rg-template-dot{border:1px solid #0000000f;border-radius:50%;width:14px;height:14px}.rg-template-font-preview{background:var(--bg-card);border:1px solid var(--border);border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;font-weight:800;display:flex}.rg-template-info{background:var(--bg);border-radius:var(--radius);color:var(--text-dim);flex-wrap:wrap;gap:.5rem 1rem;padding:.5rem .75rem;font-size:.72rem;display:flex}.rg-actions{flex-wrap:wrap;gap:.5rem;display:flex}.rg-email-row{gap:.5rem;display:flex}.rg-email-row .dm-form-input{flex:1}.rg-preview-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.rg-preview-header{background:var(--bg);border-bottom:1px solid var(--border);color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:.4rem;padding:.5rem .85rem;font-size:.72rem;font-weight:700;display:flex}.rg-preview-iframe{border:none;width:100%;height:420px;display:block}.dm-date-range-tabs{flex-wrap:wrap;gap:.35rem;display:flex}.dm-range-tab{background:var(--bg-card);color:var(--text-dim);border:1px solid var(--border);cursor:pointer;transition:var(--transition);font-size:.72rem;font-weight:600;font-family:var(--font);white-space:nowrap;border-radius:99px;padding:.35rem .75rem}.dm-range-tab:hover{border-color:var(--primary);color:var(--primary)}.dm-range-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.dm-status-tabs{flex-wrap:wrap;gap:.4rem;display:flex}.dm-status-tab{background:var(--bg-card);color:var(--text-dim);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:var(--transition);font-size:.78rem;font-weight:600;font-family:var(--font);align-items:center;gap:.35rem;padding:.4rem .9rem;display:inline-flex}.dm-status-tab svg{width:14px;height:14px}.dm-status-tab:hover{border-color:var(--primary);color:var(--primary)}.dm-status-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.dm-info-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.dm-info-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.5rem;padding:.85rem 1rem;display:flex}.dm-info-card-title{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem;font-size:.7rem;font-weight:700}.dm-info-row{color:var(--text);align-items:center;gap:.5rem;font-size:.82rem;display:flex}.dm-info-row svg{width:14px;height:14px;color:var(--text-dim);flex-shrink:0}.dm-info-value{color:var(--text);justify-content:space-between;align-items:center;font-size:.82rem;display:flex}.dm-info-label{color:var(--text-dim);font-size:.7rem;font-weight:600}.dm-row-inactive{opacity:.55}.dm-status-inactive{background:var(--bg);color:var(--text-light)}.dm-search-clear{cursor:pointer;color:var(--text-light);background:0 0;border:none;align-items:center;display:flex;position:absolute;top:50%;right:.6rem;transform:translateY(-50%)}@media (width<=900px){.ofd-grid{grid-template-columns:1fr}.donor-cards-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}@media (width<=540px){.ofd-row,.ofd-row-3,.donor-cards-grid{grid-template-columns:1fr}.dfs-field-row{flex-direction:column;align-items:flex-start}}.portal-login{background:#f0f2f5;justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.portal-login-box{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow-md);padding:2.5rem 2rem}.portal-login-box h2{color:var(--text);text-align:center;margin-bottom:.25rem;font-size:1.25rem;font-weight:700}.portal-login-box>p{color:var(--text-dim);text-align:center;margin-bottom:1.75rem;font-size:.82rem}.portal-login-logo{border-radius:var(--radius);background:var(--primary);justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 1.25rem;display:flex}.portal-login-logo span{color:#fff;font-size:1.2rem;font-weight:900}.portal-login-field{margin-bottom:1rem}.portal-login-field label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.35rem;font-size:.72rem;font-weight:600;display:block}.portal-login-field input{border:1.5px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:var(--bg);transition:var(--transition);padding:.65rem .85rem;font-size:.85rem}.portal-login-field input:focus{border-color:var(--primary);background:var(--bg-card);box-shadow:0 0 0 3px var(--primary-bg);outline:none}.portal-login-msg{border-radius:var(--radius);margin-bottom:.75rem;padding:.5rem .75rem;font-size:.8rem;font-weight:500}.portal-login-msg.error{background:var(--danger-bg);color:var(--danger)}.portal-login-msg.success{color:#059669;background:#ecfdf5}.portal-login-footer{text-align:center;border-top:1px solid var(--border);color:var(--text-light);margin-top:1.25rem;padding-top:1rem;font-size:.72rem}.portal-login-footer a{color:var(--primary);font-weight:600;text-decoration:none}.portal-login-footer a:hover{text-decoration:underline}.donor-portal{background:var(--bg);min-height:100vh}.portal-header{background:var(--bg-card);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.portal-header-left{align-items:center;gap:.75rem;display:flex}.portal-tabs{border-bottom:1px solid var(--border);background:var(--bg-card);gap:.5rem;padding:1rem 1.5rem;display:flex;overflow-x:auto}.board-dashboard{max-width:1000px;margin:0 auto;padding:1.5rem}.board-footer-notice{border-radius:var(--radius);text-align:center;margin-top:2rem;padding:1rem;font-size:.82rem;line-height:1.5}@media (width<=640px){.portal-login{padding:1rem}.portal-login-box{padding:2rem 1.5rem}.portal-header{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.portal-tabs{padding:.75rem 1rem}.board-dashboard{padding:1rem}}
