*{box-sizing:border-box}body{background:#fafafa;margin:0}#root{min-height:100vh}:root{--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-light:#eff6ff;--color-success:#059669;--color-success-light:#ecfdf5;--color-success-border:#a7f3d0;--color-warning:#d97706;--color-warning-light:#fffbeb;--color-warning-border:#fcd34d;--color-error:#dc2626;--color-error-light:#fef2f2;--color-error-border:#fecaca;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-400:#9ca3af;--color-gray-500:#6b7280;--color-gray-600:#4b5563;--color-gray-700:#374151;--color-gray-800:#1f2937;--color-gray-900:#111827;--font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono:"SF Mono", "Monaco", "Menlo", "Ubuntu Mono", "Consolas", monospace;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.625;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--radius-sm:4px;--radius:6px;--radius-md:8px;--radius-lg:12px;--border-width:1px;--border-color:var(--color-gray-200);--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--transition-fast:.15s ease;--transition-normal:.2s ease;--transition-slow:.3s ease;--sidebar-width:240px;--header-height:56px}*,:before,:after{box-sizing:border-box}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-gray-900);background-color:var(--color-gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}.loading-screen{justify-content:center;align-items:center;gap:var(--spacing-4);min-height:100vh;color:var(--color-gray-500);flex-direction:column;display:flex}.loading-screen .spinner{border:2px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.public-layout{flex-direction:column;min-height:100vh;display:flex}.public-header{border-bottom:var(--border-width) solid var(--border-color);padding:var(--spacing-4) var(--spacing-6);background:#fff}.public-header .header-content{max-width:1200px;margin:0 auto}.public-header .logo{align-items:center;gap:var(--spacing-2);color:var(--color-gray-900);font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg);text-decoration:none;display:flex}.public-header .logo svg{color:var(--color-primary)}.public-main{padding:var(--spacing-8);flex:1}.public-footer{border-top:var(--border-width) solid var(--border-color);padding:var(--spacing-6);text-align:center;background:#fff}.public-footer p{color:var(--color-gray-500);font-size:var(--font-size-sm);margin:0}.admin-layout{min-height:100vh;display:flex}.admin-sidebar{width:var(--sidebar-width);background:var(--color-gray-900);color:#fff;z-index:100;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{padding:var(--spacing-5);border-bottom:1px solid #ffffff1a}.sidebar-logo{align-items:center;gap:var(--spacing-3);color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);text-decoration:none;display:flex}.sidebar-logo svg{color:var(--color-primary)}.sidebar-nav{padding:var(--spacing-4) 0;flex:1;overflow-y:auto}.nav-item{align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-5);color:var(--color-gray-400);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-fast);text-decoration:none;display:flex}.nav-item:hover{color:#fff;background:#ffffff0d}.nav-item.active{color:#fff;border-left:2px solid var(--color-primary);background:#2563eb33}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.nav-icon svg{width:18px;height:18px}.sidebar-footer{padding:var(--spacing-4) var(--spacing-5);border-top:1px solid #ffffff1a}.user-info{align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-3);display:flex}.user-avatar{background:var(--color-primary);width:36px;height:36px;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.user-details{flex:1;min-width:0}.user-name{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.user-email{font-size:var(--font-size-xs);color:var(--color-gray-400);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.logout-btn{width:100%;padding:var(--spacing-2) var(--spacing-4);color:#fff;border-radius:var(--radius);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background var(--transition-fast);justify-content:center;align-items:center;gap:var(--spacing-2);background:#ffffff1a;border:none;display:flex}.logout-btn svg{flex-shrink:0}.logout-btn:hover{background:#ffffff26}.admin-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.admin-header{border-bottom:var(--border-width) solid var(--border-color);padding:var(--spacing-4) var(--spacing-6);z-index:50;height:var(--header-height);background:#fff;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.header-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.header-org{font-size:var(--font-size-sm);color:var(--color-gray-500)}.admin-main{padding:var(--spacing-6);background:var(--color-gray-50);flex:1}.container{max-width:560px;padding:var(--spacing-8);margin:0 auto}.container header{text-align:center;margin-bottom:var(--spacing-8)}.container h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin:0 0 var(--spacing-2);color:var(--color-gray-900)}.container header p{color:var(--color-gray-500);margin:0}.card{border:var(--border-width) solid var(--border-color);border-radius:var(--radius-md);background:#fff;overflow:hidden}.card-header{padding:var(--spacing-4) var(--spacing-5);border-bottom:var(--border-width) solid var(--border-color);background:var(--color-gray-50);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);text-transform:uppercase;letter-spacing:.025em;margin:0}.card-actions{gap:var(--spacing-2);display:flex}.card-body{padding:var(--spacing-5)}.card h2{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-4);color:var(--color-gray-800)}.status-badge{padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:capitalize;align-items:center;line-height:1;display:inline-flex}.status-success{background:var(--color-success-light);color:var(--color-success)}.status-pending{background:var(--color-warning-light);color:var(--color-warning)}.status-error{background:var(--color-error-light);color:var(--color-error)}.status-default{background:var(--color-gray-100);color:var(--color-gray-600)}.spinner{border-style:solid;border-color:var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:.8s linear infinite spin;display:inline-block}.spinner-small{border-width:2px;width:14px;height:14px}.spinner-medium{border-width:2px;width:24px;height:24px}.spinner-large{border-width:3px;width:32px;height:32px}.empty-state{text-align:center;padding:var(--spacing-12) var(--spacing-8)}.empty-icon{width:48px;height:48px;margin:0 auto var(--spacing-4);background:var(--color-gray-100);border-radius:50%;justify-content:center;align-items:center;display:flex}.empty-icon svg{width:24px;height:24px;color:var(--color-gray-400)}.empty-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-2);color:var(--color-gray-900)}.empty-description{color:var(--color-gray-500);font-size:var(--font-size-sm);margin:0 0 var(--spacing-6)}.empty-action{justify-content:center;display:flex}.alert{align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-4);border-radius:var(--radius);margin-bottom:var(--spacing-4);border:var(--border-width) solid;display:flex}.alert-info{background:var(--color-primary-light);color:var(--color-primary);border-color:#bfdbfe}.alert-success{background:var(--color-success-light);border-color:var(--color-success-border);color:var(--color-success)}.alert-warning{background:var(--color-warning-light);border-color:var(--color-warning-border);color:var(--color-warning)}.alert-error{background:var(--color-error-light);border-color:var(--color-error-border);color:var(--color-error)}.alert-icon{flex-shrink:0;width:20px;height:20px}.alert-content{flex:1}.alert-title{font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-1)}.alert-message{font-size:var(--font-size-sm)}.alert-close{font-size:var(--font-size-xl);cursor:pointer;opacity:.5;color:inherit;background:0 0;border:none;padding:0;line-height:1}.alert-close:hover{opacity:1}.modal-overlay{padding:var(--spacing-8);z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;flex-direction:column;width:100%;max-height:calc(100vh - 4rem);display:flex}.modal-small{max-width:400px}.modal-medium{max-width:520px}.modal-large{max-width:680px}.modal-header{padding:var(--spacing-5);border-bottom:var(--border-width) solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.modal-close{font-size:var(--font-size-xl);cursor:pointer;color:var(--color-gray-400);background:0 0;border:none;padding:0;line-height:1}.modal-close:hover{color:var(--color-gray-600)}.modal-body{padding:var(--spacing-5);overflow-y:auto}.modal-footer{justify-content:flex-end;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-5);border-top:var(--border-width) solid var(--border-color);background:var(--color-gray-50);display:flex}.table-container{overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th,.table td{padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:var(--border-width) solid var(--border-color)}.table th{font-weight:var(--font-weight-medium);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-gray-500);background:var(--color-gray-50)}.table tbody tr:hover{background:var(--color-gray-50)}.table tbody tr.clickable{cursor:pointer}.btn{justify-content:center;align-items:center;gap:var(--spacing-2);font-family:inherit;font-weight:var(--font-weight-medium);border:var(--border-width) solid transparent;border-radius:var(--radius);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-small{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs)}.btn-medium{padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-sm)}.btn-large{padding:var(--spacing-3) var(--spacing-5);font-size:var(--font-size-base)}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-secondary{color:var(--color-gray-700);border-color:var(--color-gray-300);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-400)}.btn-danger{background:var(--color-error);color:#fff;border-color:var(--color-error)}.btn-danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.btn-ghost{color:var(--color-gray-600);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--color-gray-100)}.btn-primary:not(.btn){width:100%;padding:var(--spacing-3) var(--spacing-5);background:var(--color-primary);color:#fff;border-radius:var(--radius);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:background var(--transition-fast);border:none}.btn-primary:not(.btn):hover:not(:disabled){background:var(--color-primary-hover)}.btn-primary:not(.btn):disabled{opacity:.5;cursor:not-allowed}.btn-secondary:not(.btn){padding:var(--spacing-3) var(--spacing-5);color:var(--color-gray-700);border:var(--border-width) solid var(--color-gray-300);border-radius:var(--radius);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);background:#fff}.btn-secondary:not(.btn):hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-400)}.form-group{margin-bottom:var(--spacing-4)}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700);margin-bottom:var(--spacing-2);display:block}.form-label .required{color:var(--color-error);margin-left:var(--spacing-1)}.form-input,.form-select{width:100%;padding:var(--spacing-2) var(--spacing-3);border:var(--border-width) solid var(--color-gray-300);border-radius:var(--radius);font-size:var(--font-size-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:#fff;font-family:inherit}.form-input:focus,.form-select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-input.has-error,.form-select.has-error{border-color:var(--color-error)}.form-input::placeholder{color:var(--color-gray-400)}.form-error{font-size:var(--font-size-xs);color:var(--color-error);margin-top:var(--spacing-1);display:block}.input-group{gap:var(--spacing-2);display:flex}.input-group input{padding:var(--spacing-3);border:var(--border-width) solid var(--color-gray-300);border-radius:var(--radius);font-size:var(--font-size-sm);flex:1}.input-group input:focus{border-color:var(--color-primary);outline:none}pre.message{background:var(--color-gray-50);border:var(--border-width) solid var(--border-color);padding:var(--spacing-4);border-radius:var(--radius);font-size:var(--font-size-xs);white-space:pre-wrap;word-break:break-all;margin:0 0 var(--spacing-4);font-family:var(--font-mono);color:var(--color-gray-700)}code{font-family:var(--font-mono);background:var(--color-gray-100);border-radius:var(--radius-sm);padding:.125em .375em;font-size:.875em}.success{color:var(--color-success);font-weight:var(--font-weight-medium)}.failure{color:var(--color-error);font-weight:var(--font-weight-medium)}.error{color:var(--color-error);background:var(--color-error-light);padding:var(--spacing-4);border-radius:var(--radius);margin-top:var(--spacing-4);font-size:var(--font-size-sm);border:var(--border-width) solid var(--color-error-border)}.admin-link{margin-top:var(--spacing-8);text-align:center}.admin-link a{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none}.admin-link a:hover{text-decoration:underline}@media (width<=768px){.admin-sidebar{transition:transform var(--transition-slow);transform:translate(-100%)}.admin-sidebar.open{transform:translate(0)}.admin-content{margin-left:0}.container,.admin-main,.public-main{padding:var(--spacing-4)}}
