*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}.modal-content{animation:slideUp .3s ease;background:#fff;background:var(--white);border-radius:16px;border-radius:var(--radius-xl);border-top:4px solid #78b3ce;border-top:4px solid var(--brand-blue);box-shadow:0 20px 60px #0000004d;max-height:90vh;overflow-y:auto;position:relative;width:min(500px,100%)}.modal-header{padding:28px 28px 16px}.modal-logo-img{height:45px;margin:0 auto 12px;object-fit:contain;width:150px}.modal-header h2{font-size:24px}.admin-form{padding:8px 28px 28px}.admin-form .form-group{margin-bottom:16px}.admin-form label{color:#707070;color:var(--text-body);display:block;font-size:14px;font-weight:600;margin-bottom:6px}.admin-form .required{color:#f96e2a;color:var(--brand-orange)}.admin-form input{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:12px;border-radius:var(--radius-lg);box-sizing:border-box;color:#292929;color:var(--text-strong);font-size:16px;outline:0;padding:14px 16px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.admin-form input::placeholder{color:#707070b3}.admin-form input:focus{border-color:#78b3ce;border-color:var(--brand-blue);box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.admin-form .error-text{color:#d0021b;font-size:14px;margin-bottom:16px;margin-top:5px}.admin-form .btn{background:#f96e2a;background:var(--brand-orange);border:0;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 2px 0 #0000000d;color:#fff;color:var(--white);cursor:pointer;font-size:16px;font-weight:700;padding:14px 16px;transition:filter .15s ease,transform .02s ease,box-shadow .15s ease;width:100%}.admin-form .btn:hover{filter:brightness(.92)}.admin-form .btn:active{transform:translateY(1px)}.admin-form .btn:focus-visible{box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.admin-form .btn:disabled{cursor:not-allowed;opacity:.65}@media (max-width:420px){.modal-content{border-radius:12px}.modal-header{padding:24px 20px 12px}.admin-form{padding:8px 20px 24px}}@media (prefers-reduced-motion:reduce){.admin-form .btn,.admin-form input,.modal-close,.modal-content,.modal-overlay{animation:none;transition:none}}.otp-page{background:linear-gradient(0deg,#c9e6f038,#c9e6f038) #fbf8ef;background:linear-gradient(0deg,#c9e6f038,#c9e6f038) var(--bg-cream);color:#707070;color:var(--text-body);display:grid;font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif;min-height:100dvh;padding:24px;place-items:center;position:relative}.otp-container{background:#fff;background:var(--white);border-radius:16px;border-radius:var(--radius-xl);border-top:4px solid #78b3ce;border-top:4px solid var(--brand-blue);box-shadow:0 10px 30px #00000014;box-shadow:var(--shadow-1);overflow:hidden;width:min(600px,100%)}.otp-header{padding:28px 28px 16px;text-align:center}.otp-logo{background:radial-gradient(ellipse at 50% 45%,#c9e6f0,#e9f4f8);background:radial-gradient(ellipse at 50% 45%,var(--bg-tint),#e9f4f8);border-radius:14px;box-shadow:inset 0 0 0 2px #78b3ce80;color:#78b3ce;color:var(--brand-blue);display:grid;font-size:28px;height:56px;margin:0 auto 12px;place-items:center;width:56px}.otp-header h1{color:#292929;color:var(--text-strong);font-size:clamp(24px,3vw,32px);font-weight:600;margin:0 0 6px}.otp-header p{color:#707070;color:var(--text-body);margin:0}.otp-form-container{padding:8px 28px 28px}.otp-form-container h2{color:#292929;color:var(--text-strong);font-size:20px;font-weight:700;margin:0 0 4px}.otp-description{color:#707070;color:var(--text-body);margin:0 0 20px}.otp-form .form-group{margin-bottom:16px}.otp-form label{color:#707070;color:var(--text-body);display:block;font-size:14px;font-weight:600;margin-bottom:6px}.otp-form .required{color:#f96e2a;color:var(--brand-orange)}.otp-form input[type=email]{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:12px;border-radius:var(--radius-lg);box-sizing:border-box;color:#292929;color:var(--text-strong);font-size:16px;outline:0;padding:14px 16px;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;width:100%}.otp-form input::placeholder{color:#707070b3}.otp-form input:focus{background:#fff;border-color:#78b3ce;border-color:var(--brand-blue);box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.otp-form small{color:#707070e6;display:block;font-size:13px;margin-top:6px}.btn{background:var(--brand-orange);color:var(--white)}.logo{align-items:center;display:flex;justify-content:center;margin-bottom:10px}.logo-img{height:60px;object-fit:contain;width:200px}@media (max-width:420px){.otp-container{border-radius:12px}.otp-form-container{padding:8px 20px 24px}.otp-header{padding:24px 20px 12px}}@media (prefers-reduced-motion:reduce){.btn,.otp-form input{transition:none}}.verify-page{background:linear-gradient(0deg,#c9e6f038,#c9e6f038) #fbf8ef;background:linear-gradient(0deg,#c9e6f038,#c9e6f038) var(--bg-cream);color:#707070;color:var(--text-body);display:grid;font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif;min-height:100dvh;padding:24px;place-items:center;position:relative}.admin-btn-top{background:#fff;background:var(--white);border:1px solid #78b3ce;border:1px solid var(--brand-blue);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 10px 30px #00000014;box-shadow:var(--shadow-1);color:#78b3ce;color:var(--brand-blue);cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px;position:fixed;right:24px;top:24px;transition:all .15s ease;z-index:100}.admin-btn-top:hover{background:#c9e6f0;background:var(--bg-tint);box-shadow:0 12px 35px #0000001f;transform:translateY(-2px)}.admin-btn-top:active{transform:translateY(0)}.admin-btn-top:focus-visible{box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.verify-container{background:#fff;background:var(--white);border-radius:16px;border-radius:var(--radius-xl);border-top:4px solid #78b3ce;border-top:4px solid var(--brand-blue);box-shadow:0 10px 30px #00000014;box-shadow:var(--shadow-1);overflow:hidden;width:min(600px,100%)}.verify-header{padding:28px 28px 16px;text-align:center}.verify-logo{background:radial-gradient(ellipse at 50% 45%,#c9e6f0,#e9f4f8);background:radial-gradient(ellipse at 50% 45%,var(--bg-tint),#e9f4f8);border-radius:14px;box-shadow:inset 0 0 0 2px #78b3ce80;color:#78b3ce;color:var(--brand-blue);display:grid;font-size:28px;height:56px;margin:0 auto 12px;place-items:center;width:56px}.verify-header h1{color:#292929;color:var(--text-strong);font-size:clamp(24px,3vw,32px);font-weight:600;margin:0 0 6px}.verify-header p{color:#707070;color:var(--text-body);margin:0}.verify-form-container{padding:8px 28px 28px}.verify-form-container h2{color:#292929;color:var(--text-strong);font-size:20px;font-weight:700;margin:0 0 4px}.verify-description{color:#707070;color:var(--text-body);margin:0 0 20px}.verify-form .form-group{margin-bottom:16px}.verify-form label{color:#707070;color:var(--text-body);display:block;font-size:14px;font-weight:600;margin-bottom:6px}.verify-form .required{color:#f96e2a;color:var(--brand-orange)}.verify-form input[type=email],.verify-form input[type=text]{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:12px;border-radius:var(--radius-lg);box-sizing:border-box;color:#292929;color:var(--text-strong);font-size:18px;outline:0;padding:14px 16px;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;width:100%}.verify-form input::placeholder{color:#707070b3}.verify-form input:focus{background:#fff;border-color:#78b3ce;border-color:var(--brand-blue);box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.read-only-input{background:linear-gradient(#fff,#fff) padding-box,linear-gradient(90deg,#78b3ce4d,#78b3ce1a) border-box;border:1px solid #c9e6f0;border:1px solid var(--bg-tint);color:#292929d9}.read-only-input:focus{border-color:#c9e6f0;border-color:var(--bg-tint);box-shadow:none}.verify-form small{color:#707070e6;display:block;font-size:13px;margin-top:6px}@media (max-width:420px){.verify-container{border-radius:12px}.verify-form-container{padding:8px 20px 24px}.verify-header{padding:24px 20px 12px}}@media (prefers-reduced-motion:reduce){.btn,.verify-form input{transition:none}}.login-page{background:linear-gradient(0deg,#c9e6f038,#c9e6f038) #fbf8ef;background:linear-gradient(0deg,#c9e6f038,#c9e6f038) var(--bg-cream);color:#707070;color:var(--text-body);display:grid;font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif;min-height:100dvh;padding:24px;place-items:center}.login-container{background:#fff;background:var(--white);border-radius:16px;border-radius:var(--radius-xl);border-top:4px solid #78b3ce;border-top:4px solid var(--brand-blue);box-shadow:0 10px 30px #00000014;box-shadow:var(--shadow-1);overflow:hidden;width:min(720px,100%)}.login-header{padding:28px 28px 16px;text-align:center}.logo{background:radial-gradient(ellipse at 50% 45%,#c9e6f0,#e9f4f8);background:radial-gradient(ellipse at 50% 45%,var(--bg-tint),#e9f4f8);border-radius:14px;box-shadow:inset 0 0 0 2px #78b3ce80;color:#78b3ce;color:var(--brand-blue);display:grid;font-size:28px;height:56px;margin:0 auto 12px;place-items:center;width:56px}.login-header h1{color:#292929;color:var(--text-strong);font-size:clamp(24px,3vw,32px);font-weight:600;margin:0 0 6px}.login-header p{color:#707070;color:var(--text-body);margin:0}.login-form-container{padding:8px 28px 28px}.login-form-container h2{color:#292929;color:var(--text-strong);font-size:20px;font-weight:700;margin:0 0 4px}.form-description{color:#707070;color:var(--text-body);margin:0 0 20px}.login-form .form-group{margin-bottom:16px}.login-form label{color:#707070;color:var(--text-body);display:block;font-size:14px;font-weight:600;margin-bottom:6px}.required{color:#f96e2a;color:var(--brand-orange)}.login-form input[type=email],.login-form select{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:12px;border-radius:var(--radius-lg);box-sizing:border-box;color:#292929;color:var(--text-strong);font-size:16px;outline:0;padding:14px 16px;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;width:100%}.login-form input::placeholder{color:#707070b3}.login-form input:focus,.login-form select:focus{border-color:#78b3ce;border-color:var(--brand-blue);box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.role-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:linear-gradient(90deg,#fff,#fff) padding-box,linear-gradient(90deg,#78b3ce40,#78b3ce1a) border-box;background-position:right 14px center,0 0;background-size:0 0,100% 100%;padding-right:44px;position:relative}.role-select::-ms-expand{display:none}.role-select{background-image:linear-gradient(45deg,#0000 50%,#707070 0),linear-gradient(135deg,#707070 50%,#0000 0),linear-gradient(90deg,#78b3ce40,#78b3ce1a);background-image:linear-gradient(45deg,#0000 50%,var(--text-body) 50%),linear-gradient(135deg,var(--text-body) 50%,#0000 50%),linear-gradient(90deg,#78b3ce40,#78b3ce1a);background-position:right 22px center,right 16px center,0 0;background-repeat:no-repeat;background-size:6px 6px,6px 6px,100% 100%}.login-form small{color:#707070e6;display:block;font-size:13px;margin-top:6px}.btn{background:#f96e2a;background-image:none;border:0;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 2px 0 #0000000d;color:#fff;cursor:pointer;font-size:16px;font-weight:700;padding:14px 16px;transition:filter .15s ease,transform .02s ease,box-shadow .15s ease;width:100%}.btn:hover{filter:brightness(.92)}.btn:active{transform:translateY(1px)}.btn:focus-visible{box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.btn:disabled{cursor:not-allowed;opacity:.65}.btn-secondary{background:#fff;border:1px solid #78b3ce;border:1px solid var(--brand-blue);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 2px 0 #00000008;color:#78b3ce;color:var(--brand-blue);cursor:pointer;font-size:16px;font-weight:700;padding:14px 16px;transition:all .15s ease;width:100%}.btn-secondary:hover{background:#c9e6f0;background:var(--bg-tint);border-color:#78b3ce;border-color:var(--brand-blue)}.btn-secondary:active{transform:translateY(1px)}.btn-secondary:focus-visible{box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.btn-secondary:disabled{cursor:not-allowed;opacity:.65}.divider{align-items:center;color:#707070;color:var(--text-body);display:flex;font-size:14px;margin:20px 0;opacity:.7;text-align:center}.divider:after,.divider:before{background:#c9e6f0;background:var(--bg-tint);content:"";flex:1 1;height:1px}.divider span{font-weight:600;padding:0 16px}.input-error{border-color:#f96e2a!important;border-color:var(--brand-orange)!important;box-shadow:0 0 0 3px #f96e2a40!important}.text-error{color:#f96e2a;color:var(--brand-orange);font-size:13px;margin-top:6px}.error-text{color:#d0021b;font-size:14px;margin-top:5px}.error-input{background-color:#fff6f6;border:1px solid #d0021b!important}@media (max-width:500px){.login-container{border-radius:12px}.login-form-container{padding:8px 20px 24px}.login-header{padding:24px 20px 12px}}@media (prefers-reduced-motion:reduce){.btn,.login-form input,.login-form select{transition:none}}.powerbi-report-container{background:#fff;border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 6px 18px #00000014;box-shadow:var(--shadow-2);overflow:hidden}.report-header{background:linear-gradient(0deg,#c9e6f01f,#c9e6f01f) #fff;border-bottom:1px solid #0000000f;gap:12px;justify-content:space-between;padding:14px 16px}.report-header,.report-title{align-items:center;display:flex}.report-title{flex-wrap:wrap;gap:10px}.report-title h2{color:#292929;color:var(--text-strong);font-size:clamp(18px,2vw,20px);font-weight:700;margin:0}.report-badge{background:#fff;border:1px solid #78b3ce;border:1px solid var(--brand-blue);border-radius:999px;color:#78b3ce;color:var(--brand-blue);display:inline-block;font-size:12px;font-weight:800;padding:4px 8px}.report-actions{display:flex;flex-wrap:wrap;gap:8px}.action-button{background:#fff;border:1px solid #78b3ce;border:1px solid var(--brand-blue);border-radius:10px;color:#78b3ce;color:var(--brand-blue);cursor:pointer;font-weight:800;padding:10px 12px;transition:background .15s ease,box-shadow .15s ease,transform .02s ease}.action-button:hover{background:#f6fafc}.action-button:active{transform:translateY(1px)}.action-button:focus-visible{box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.action-button:disabled{cursor:not-allowed;opacity:.6}.report-content{align-items:stretch;background:#fff;display:flex;justify-content:stretch;min-height:420px}.report-loading{grid-gap:10px;display:grid;gap:10px;padding:40px;place-items:center;width:100%}.spinner{border:4px solid #eaf3f7;height:36px;width:36px}.report-error{padding:24px;text-align:center;width:100%}.report-error h3{color:#292929;color:var(--text-strong);margin:0 0 6px}.retry-button{background:#f96e2a;border:0;border-radius:12px;box-shadow:0 2px 0 #0000000d;color:#fff;cursor:pointer;font-weight:800;margin-top:10px;padding:12px 16px;transition:filter .15s ease,transform .02s ease,box-shadow .15s ease}.retry-button:hover{filter:brightness(.92)}.retry-button:active{transform:translateY(1px)}.retry-button:focus-visible{box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.report-iframe{background:#fff;border:0;height:72vh;min-height:520px;width:100%}@media (max-width:980px){.report-iframe{height:64vh}}.report-iframe iframe{background:#fff!important;border:0!important;display:block;height:100%!important;width:100%!important}.report-footer{align-items:center;background:#fff;border-top:1px solid #0000000f;color:#707070;color:var(--text-body);display:flex;font-size:13px;gap:12px;justify-content:space-between;padding:10px 16px}.token-info{opacity:.9}@media (prefers-reduced-motion:reduce){.action-button,.retry-button{transition:none}}.report-selector{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem}.report-selector h2{color:#333;font-size:1.25rem;margin:0 0 1rem}.report-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.report-card{align-items:center;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;gap:1rem;padding:1rem;text-align:left;transition:all .2s;width:100%}.report-card:hover{background:#f5f7ff;border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.report-card.active{background:linear-gradient(135deg,#667eea15,#764ba215);border-color:#667eea;box-shadow:0 4px 12px #667eea33}.report-icon{flex-shrink:0;font-size:2rem}.report-info{flex:1 1;min-width:0}.report-info h3{color:#333;font-size:1rem;margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.report-id{color:#999;font-family:monospace;font-size:.75rem;margin:0}.active-indicator{color:#667eea;flex-shrink:0;font-size:1.5rem}@media (max-width:768px){.report-list{grid-template-columns:1fr}}.dashboard{background:linear-gradient(0deg,#c9e6f038,#c9e6f038) #fbf8ef;background:linear-gradient(0deg,#c9e6f038,#c9e6f038) var(--bg-cream);color:#707070;color:var(--text-body);display:flex;flex-direction:column;min-height:100dvh}.dashboard-header{background:#fff;background:var(--white);border-top:4px solid #78b3ce;border-top:4px solid var(--brand-blue);box-shadow:0 10px 30px #00000014;box-shadow:var(--shadow-1);position:-webkit-sticky;position:sticky;top:0;z-index:10}.header-content{max-width:1200px;padding:8px 24px}.header-left h1{font-size:clamp(20px,2.2vw,28px)}.header-left p{margin:2px 0 0}.user-info{align-items:center;border-radius:14px;display:flex;gap:14px;padding:10px 12px}.user-avatar{background:radial-gradient(ellipse at 50% 45%,#c9e6f0,#e9f4f8);background:radial-gradient(ellipse at 50% 45%,var(--bg-tint),#e9f4f8);border-radius:10px;box-shadow:inset 0 0 0 2px #78b3ce80;color:#78b3ce;color:var(--brand-blue);display:grid;font-weight:800;height:40px;place-items:center;width:40px}.user-details{line-height:1.2}.user-name{color:#292929;color:var(--text-strong);font-weight:700}.user-email{font-size:13px;opacity:.9}.user-roles{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.role-badge{background:#fff;border:1px solid #78b3ce;border:1px solid var(--brand-blue);font-weight:700;padding:4px 8px}.logout-btn{padding:10px 12px}.dashboard-main{margin:0 auto;width:100%}.content-full{display:flex;flex-direction:column;gap:20px}.content-full .report-selector{padding:16px;width:100%}.content-full .report-selector,.report-fullscreen{background:#fff;border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 6px 18px #00000014;box-shadow:var(--shadow-2)}.report-fullscreen{flex:1 1;height:calc(100vh - 260px);overflow:hidden}.report-fullscreen iframe{border:0;height:100%;width:100%}.dashboard-footer{background:#fff;border-top:1px solid #0000000f;font-size:13px;margin-top:auto;padding:12px 24px}:root{--success:#10b981;--danger:#ef4444;--warning:#f59e0b}.admin-email-management{margin:0 auto;max-width:1400px;padding:24px}.alert-error{align-items:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:12px;border-radius:var(--radius-lg);display:flex;font-size:14px;font-weight:600;justify-content:space-between;margin-bottom:20px;padding:12px 16px}.alert-close,.alert-error{color:#ef4444;color:var(--danger)}.alert-close{background:none;border:0;border-radius:4px;cursor:pointer;font-size:18px;padding:4px 8px;transition:background .15s ease}.alert-close:hover{background:#ef44441a}.management-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.header-left h2{color:#292929;color:var(--text-strong);font-size:28px;font-weight:700;margin:0 0 4px}.header-left p{margin:0}.btn-add{background:#f96e2a;background:var(--brand-orange);border:0;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 6px 18px #00000014;box-shadow:var(--shadow-2);color:#fff;color:var(--white);cursor:pointer;font-size:14px;font-weight:700;padding:12px 24px;transition:filter .15s ease,transform .02s ease}.btn-add:hover{filter:brightness(.92)}.btn-add:active{transform:translateY(1px)}.management-controls{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px}.search-box{flex:1 1;max-width:400px;min-width:250px;position:relative}.search-icon{color:#707070;color:var(--text-body);font-size:16px;left:14px;position:absolute;top:50%;transform:translateY(-50%)}.search-box input{border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:12px;border-radius:var(--radius-lg);font-size:14px;outline:0;padding:12px 16px 12px 42px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.search-box input:focus{border-color:#78b3ce;border-color:var(--brand-blue);box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.stats{display:flex;gap:20px}.stat-item{color:#707070;color:var(--text-body);font-size:18px}.stat-item strong{color:#292929;color:var(--text-strong);font-size:20px;font-weight:700}.table-container{background:#fff;background:var(--white);border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 10px 30px #00000014;box-shadow:var(--shadow-1);overflow:hidden}.table-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:64px 24px}.spinner{animation:spin 1s linear infinite;border:4px solid #78b3ce33;border-radius:50%;border-top-color:#78b3ce;border-top:4px solid var(--brand-blue);height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.table-loading p{color:#707070;color:var(--text-body);font-size:14px}.email-table{border-collapse:collapse;width:100%}.email-table thead{background:linear-gradient(135deg,#78b3ce14,#78b3ce05)}.email-table th{border-bottom:2px solid #c9e6f0;border-bottom:2px solid var(--bg-tint);color:#292929;color:var(--text-strong);font-size:13px;font-weight:700;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.email-table td:first-child,.email-table th:first-child{padding-right:24px;text-align:right;width:80px}.email-table tbody tr{border-bottom:1px solid #c9e6f04d;transition:background-color .15s ease}.email-table tbody tr:hover{background-color:#78b3ce08}.email-table td{color:#707070;color:var(--text-body);font-size:14px;padding:16px}.user-cell{gap:12px}.user-avatar-small,.user-cell{align-items:center;display:flex}.user-avatar-small{background:radial-gradient(ellipse at 50% 45%,#c9e6f0,#e9f4f8);background:radial-gradient(ellipse at 50% 45%,var(--bg-tint),#e9f4f8);border-radius:8px;box-shadow:inset 0 0 0 2px #78b3ce4d;color:#78b3ce;color:var(--brand-blue);font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.email-cell{align-items:center;display:flex;gap:12px}.email-avatar-small{align-items:center;background:radial-gradient(ellipse at 50% 45%,#c9e6f0,#e9f4f8);background:radial-gradient(ellipse at 50% 45%,var(--bg-tint),#e9f4f8);border-radius:8px;box-shadow:inset 0 0 0 2px #78b3ce4d;color:#78b3ce;color:var(--brand-blue);display:flex;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.roles-badges{display:flex;flex-wrap:wrap;gap:6px}.role-badge{background:#78b3ce1a;border:1px solid #78b3ce4d;border-radius:999px;color:#78b3ce;color:var(--brand-blue);display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.email-form .role-select{max-width:280px;width:100%}.status-badge{border-radius:999px;display:inline-block;font-size:12px;font-weight:700;padding:4px 12px}.status-badge.active{background:#10b9811a;border:1px solid #10b9814d;color:#10b981;color:var(--success)}.status-badge.inactive{background:#6b72801a;border:1px solid #6b72804d;color:#6b7280}.action-buttons{display:flex;gap:8px}.btn-action{align-items:center;border:0;border-radius:6px;cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;transition:all .15s ease;width:32px}.btn-edit{background:#78b3ce1a;color:#78b3ce;color:var(--brand-blue)}.btn-edit:hover{background:#78b3ce33;transform:translateY(-1px)}.btn-delete{background:#ef44441a;color:#ef4444;color:var(--danger)}.btn-delete:hover{background:#ef444433;transform:translateY(-1px)}.no-data{color:#707070;color:var(--text-body);font-style:italic;padding:48px!important;text-align:center}.modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:24px;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content-form{border-top:4px solid #78b3ce;border-top:4px solid var(--brand-blue);max-height:90vh;overflow-y:auto;position:relative;width:min(600px,100%)}.modal-content-confirm,.modal-content-form{animation:slideUp .3s ease;background:#fff;background:var(--white);border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 20px 60px #0000004d}.modal-content-confirm{padding:32px;text-align:center;width:min(400px,100%)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close{align-items:center;background:#0000000d;border:0;border-radius:8px;color:#707070;color:var(--text-body);cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .15s ease;width:32px;z-index:10}.modal-close:hover{background:#0000001a;transform:rotate(90deg)}.modal-header{border-bottom:1px solid #c9e6f0;border-bottom:1px solid var(--bg-tint);padding:28px 28px 20px;text-align:center}.modal-header h2{color:#292929;color:var(--text-strong);font-size:22px;font-weight:700;margin:0 0 6px}.modal-header p{color:#707070;color:var(--text-body);font-size:14px;margin:0}.email-form{padding:24px 28px 28px}.email-form .form-group{margin-bottom:20px}.email-form label{color:#707070;color:var(--text-body);display:block;font-size:14px;font-weight:600;margin-bottom:8px}.email-form .required{color:#f96e2a;color:var(--brand-orange)}.email-form input,.email-form select{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:12px;border-radius:var(--radius-lg);box-sizing:border-box;color:#292929;color:var(--text-strong);font-size:14px;outline:0;padding:12px 16px;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.email-form input::placeholder{color:#707070b3}.email-form input:focus,.email-form select:focus{border-color:#78b3ce;border-color:var(--brand-blue);box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-actions{border-top:1px solid #c9e6f0;border-top:1px solid var(--bg-tint);display:flex;gap:12px;margin-top:24px;padding-top:24px}.btn-cancel{background:#fff;background:var(--white);border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:12px;border-radius:var(--radius-lg);color:#707070;color:var(--text-body);cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:12px 24px;transition:all .15s ease}.btn-cancel:hover{background:#fbf8ef;background:var(--bg-cream);border-color:#78b3ce;border-color:var(--brand-blue)}.btn-submit{background:#f96e2a;background:var(--brand-orange);border:0;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 6px 18px #00000014;box-shadow:var(--shadow-2);color:#fff;color:var(--white);cursor:pointer;flex:1 1;font-size:14px;font-weight:700;padding:12px 24px;transition:filter .15s ease}.btn-submit:hover{filter:brightness(.92)}.confirm-icon{font-size:48px;margin-bottom:16px}.modal-content-confirm h2{color:#292929;color:var(--text-strong);font-size:22px;font-weight:700;margin:0 0 12px}.modal-content-confirm p{color:#707070;color:var(--text-body);font-size:14px;margin:0 0 8px}.warning-text{color:#ef4444;color:var(--danger);font-weight:600;margin-bottom:24px!important}.confirm-actions{display:flex;gap:12px;margin-top:24px}.btn-delete-confirm{background:#ef4444;background:var(--danger);border:0;border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 6px 18px #00000014;box-shadow:var(--shadow-2);color:#fff;color:var(--white);cursor:pointer;flex:1 1;font-size:14px;font-weight:700;padding:12px 24px;transition:filter .15s ease}.btn-delete-confirm:hover{filter:brightness(.9)}@media (max-width:768px){.management-header{align-items:flex-start;flex-direction:column}.btn-add{width:100%}.management-controls{align-items:stretch;flex-direction:column}.search-box{max-width:100%}.stats{justify-content:space-between}.table-container{overflow-x:auto}.email-table{min-width:800px}.form-row{grid-template-columns:1fr}.modal-content-form{border-radius:12px}.email-form{padding:20px}}@media (prefers-reduced-motion:reduce){.btn-action,.btn-add,.email-table tbody tr,.modal-close,.modal-content-confirm,.modal-content-form,.modal-overlay{animation:none;transition:none}}:root{--brand-orange:#f96e2a;--brand-blue:#78b3ce;--bg-tint:#c9e6f0;--bg-cream:#fbf8ef;--text-strong:#292929;--text-body:#707070;--white:#fff;--radius-xl:16px;--radius-lg:12px;--shadow-1:0 10px 30px #00000014;--shadow-2:0 6px 18px #00000014;--focus:0 0 0 3px #78b3ce59}.admin-dashboard{flex-direction:column}.admin-dashboard,.loading-admin{background:linear-gradient(0deg,#c9e6f038,#c9e6f038) #fbf8ef;background:linear-gradient(0deg,#c9e6f038,#c9e6f038) var(--bg-cream);display:flex;min-height:100vh}.loading-admin{align-items:center;color:#707070;color:var(--text-body);font-size:18px;justify-content:center}.admin-header{background:#fff;background:var(--white);border-top:4px solid #78b3ce;border-top:4px solid var(--brand-blue);box-shadow:0 10px 30px #00000014;box-shadow:var(--shadow-1);position:-webkit-sticky;position:sticky;top:0;z-index:10}.header-content{align-items:center;display:flex;gap:20px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:16px 24px}.header-left h1{color:#292929;color:var(--text-strong);font-size:clamp(22px,2.5vw,32px);font-weight:700;margin:0}.header-left p{color:#707070;color:var(--text-body);font-size:14px;margin:4px 0 0}.admin-user-info{align-items:center;background:#fff;border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:14px;box-shadow:0 6px 18px #00000014;box-shadow:var(--shadow-2);display:flex;gap:14px;padding:10px 16px}.admin-avatar{background:radial-gradient(ellipse at 50% 45%,#f96e2a26,#f96e2a0d);border-radius:10px;box-shadow:inset 0 0 0 2px #f96e2a4d;color:#f96e2a;color:var(--brand-orange);display:grid;font-size:18px;font-weight:800;height:44px;place-items:center;width:44px}.admin-details{line-height:1.3}.admin-role{color:#292929;color:var(--text-strong);font-size:14px;font-weight:700}.admin-email{color:#707070;color:var(--text-body);font-size:12px;opacity:.9}.logout-btn{background:#fff;border:1px solid #c9e6f0;border:1px solid var(--bg-tint);border-radius:10px;color:#292929;color:var(--text-strong);cursor:pointer;font-size:13px;font-weight:700;margin-left:8px;padding:10px 16px;transition:background .15s ease,box-shadow .15s ease}.logout-btn:hover{background:#f6fafc;border-color:#78b3ce;border-color:var(--brand-blue)}.logout-btn:focus-visible{box-shadow:0 0 0 3px #78b3ce59;box-shadow:var(--focus)}.admin-main{flex:1 1;padding:32px 0}.admin-footer{background:#fff;background:var(--white);border-top:1px solid #0000000f;color:#707070;color:var(--text-body);font-size:13px;padding:16px 24px;text-align:center}.admin-footer p{margin:0}@media (max-width:768px){.admin-header,.header-content{padding:12px 16px}.header-content{align-items:flex-start;flex-direction:column}.header-left h1{font-size:20px}.admin-user-info{padding:10px 12px;width:100%}.admin-main{padding:20px 0}}@media (prefers-reduced-motion:reduce){.logout-btn{transition:none}}
/*# sourceMappingURL=main.b1ba3ce6.css.map*/