:root{color:#e8f1fb;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 100% 0,#1c4a7a 0%,#0b2c52 45%,#071b35 100%);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.45}*{box-sizing:border-box}html,body,#root{background:0 0;min-height:100vh;margin:0}a{color:inherit}.app-shell{grid-template-columns:240px 1fr;min-height:100vh;display:grid}.sidebar{color:#e6eef8;background:#0c2a4a;padding:1.25rem 1rem}.sidebar-logo{width:145px;height:auto;margin:0 auto 1rem;display:block}.sidebar nav{gap:.4rem;display:grid}.sidebar a{color:#d3e3f5;border-radius:8px;align-items:center;gap:.55rem;padding:.55rem .7rem;text-decoration:none;display:flex}.sidebar-nav-icon{opacity:.88;flex-shrink:0;width:1.2rem;height:1.2rem}.sidebar a.active .sidebar-nav-icon{opacity:1}.sidebar a.active{color:#0c2a4a;background:#f4c14b;font-weight:600}.shell-main{flex-direction:column;min-height:100vh;display:flex}.content{flex:1;padding:1.5rem}.dashboard-page{gap:1rem;max-width:980px;display:grid}.dashboard-page.admin-members-page{max-width:1180px}.dashboard-card{background:linear-gradient(135deg,#0a2a4f 0%,#163f6e 55%,#0a2a4f 100%);border:1px solid #163a63;border-radius:18px;padding:1.5rem;box-shadow:0 22px 48px #0714293d}.dashboard-kicker{color:#b9d6f5;letter-spacing:.03em;text-transform:uppercase;margin:0 0 .35rem;font-size:.83rem}.dashboard-card h1{color:#f4fbff;margin:0 0 .45rem;font-size:1.9rem}.dashboard-subtitle{color:#d9e7f6;margin:0 0 1.1rem}.dashboard-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;display:grid}.dashboard-grid article{background:#0a233e59;border:1px solid #a3c2e459;border-radius:10px;gap:.15rem;padding:.72rem .82rem;display:grid}.dashboard-grid article span{color:#d1e4f7;font-size:.82rem}.dashboard-grid article strong{color:#f4c14b;word-break:break-word;font-size:.86rem;font-weight:600}.dashboard-loading{color:#d9e7f6;margin:0}.dashboard-error{color:#ffd2d2;margin:.95rem 0 0;font-size:.92rem}.dashboard-actions{margin-top:1rem}.dashboard-logout-btn{color:#e9f3ff;cursor:pointer;background:#081e3859;border:1px solid #4c7198;border-radius:10px;padding:.65rem 1rem;font-size:.92rem;transition:background .15s,border-color .15s,transform .15s}.dashboard-logout-btn:hover{background:#0b264594;border-color:#6e94bc;transform:translateY(-1px)}.dashboard-profile-card{background:#f3f9ffb8;border:1px solid #d4e4f5;border-radius:16px;padding:1.1rem 1rem}.dashboard-profile-card h2{color:#0e3258;margin:0 0 .35rem;font-size:1.2rem}.dashboard-profile-card p{color:#46698e;margin:0 0 .85rem}.dashboard-profile-form{gap:.8rem;max-width:520px;display:grid}.dashboard-profile-form label{gap:.32rem;display:grid}.dashboard-profile-form label span{color:#2f5378;font-size:.86rem}.dashboard-profile-form input{color:#0f2f52;background:#fff;border:1px solid #c6d6e8;border-radius:10px;padding:.6rem .7rem;font-size:.93rem}.dashboard-profile-form input:focus{border-color:#f4c14b;outline:2px solid #f4c14b}.dashboard-profile-hint{color:#5a7998;word-break:break-all;margin:-.2rem 0 0;font-size:.78rem}.dashboard-profile-preview{background:#fff;border:2px solid #d0e3f7;border-radius:999px;width:62px;height:62px;overflow:hidden}.dashboard-profile-preview img{object-fit:cover;width:100%;height:100%}.dashboard-save-btn{color:#0a2a4f;cursor:pointer;background:#f4c14b;border:1px solid #d7a52f;border-radius:10px;width:fit-content;padding:.62rem .95rem;font-size:.9rem}.dashboard-save-btn:disabled{opacity:.72;cursor:not-allowed}.dashboard-clear-file-btn{color:#24486f;cursor:pointer;background:#f6fbff;border:1px solid #9db6cf;border-radius:8px;width:fit-content;padding:.45rem .7rem;font-size:.82rem}.dashboard-profile-message{color:#0f4b2e;margin:.8rem 0 0;font-size:.9rem}.layout-footer{color:#c6d9ef;border-top:1px solid #a2bede33;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;margin-top:auto;padding:.95rem 1rem 1rem;font-size:.84rem;display:flex}.layout-footer a{color:#f4c14b;text-decoration:none}.layout-footer a:hover{text-decoration:underline}.layout-footer-divider{opacity:.65}.layout-build-stamp{opacity:.55;letter-spacing:.02em;white-space:nowrap;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.68rem}.layout-footer-credit{text-align:center;opacity:.72;letter-spacing:.01em;flex-basis:100%;margin-top:.35rem;font-size:.72rem;font-style:italic}@media (width<=820px){.app-shell,.dashboard-grid{grid-template-columns:1fr}}@media (width<=640px){.sidebar nav{grid-template-columns:1fr}.content{padding:1rem}.dashboard-card{padding:1.2rem}.dashboard-profile-card{padding:1rem .85rem}.layout-footer{flex-direction:column;gap:.2rem}}.container{text-align:left;flex-direction:column;max-width:1024px;min-height:100vh;margin:0 auto;padding:4rem 1.25rem;display:flex}.hero-card{background:linear-gradient(135deg,#0a2a4f 0%,#163f6e 55%,#0a2a4f 100%);border:1px solid #163a63;border-radius:18px;padding:2rem;box-shadow:0 24px 48px #07142933}.hero-logo{width:clamp(150px,24vw,220px);height:auto;margin:0 0 .9rem auto;display:block}.hero-card h1{color:#fff;margin:0 0 1rem;font-size:clamp(1.8rem,2.5vw,2.4rem);line-height:1.2}.badge{letter-spacing:.04em;text-transform:uppercase;color:#0a2a4f;background:#f4c14b;border:1px solid #f8d370;border-radius:999px;margin-bottom:.75rem;padding:.3rem .65rem;font-size:.8rem;font-weight:600;display:inline-block}.kicker{color:#b9d6f5;letter-spacing:.03em;text-transform:uppercase;margin:0 0 .35rem;font-size:.95rem}.subtitle{color:#d9e7f6;max-width:760px;margin:0 0 1rem;font-size:1.02rem}.actions{justify-content:center;gap:.75rem;margin-top:1rem;display:flex}.primary-btn,.ghost-btn{cursor:pointer;border:1px solid #0000;border-radius:10px;padding:.7rem 1.05rem;font-size:.95rem;transition:transform .15s,box-shadow .15s,opacity .15s}.primary-btn:hover,.ghost-btn:hover{transform:translateY(-1px)}.primary-btn{color:#0a2a4f;background:#f4c14b;box-shadow:0 8px 20px #f4c14b40}.ghost-btn{color:#f0f7ff;background:0 0;border-color:#95b7db}.panel{color:#f0f7ff;background:#05152b59;border:1px solid #3f6490;border-radius:8px;gap:.5rem;margin:1.1rem 0;padding:1rem;display:grid}.panel code{word-break:break-all;color:#f4c14b;display:inline-block}.hero-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin-top:1.2rem;display:grid}.hero-metrics>div{background:#0a233e59;border:1px solid #a3c2e459;border-radius:10px;gap:.1rem;padding:.7rem .8rem;display:grid}.hero-metrics strong{color:#f4c14b;font-size:1.05rem}.hero-metrics span{color:#d9e7f6;font-size:.85rem}.landing-footer{color:#c6d9ef;border-top:1px solid #a2bede33;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;margin-top:auto;padding:.95rem .4rem 0;font-size:.84rem;display:flex}.landing-footer a{color:#f4c14b;text-decoration:none}.landing-footer a:hover{text-decoration:underline}.footer-divider{opacity:.65}.footer-credit{text-align:center;opacity:.72;letter-spacing:.01em;flex-basis:100%;margin-top:.35rem;font-size:.72rem;font-style:italic}.login-wrapper{flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:980px;min-height:100vh;margin:0 auto;padding:2rem 1rem 7.5rem;display:flex;position:relative}.login-card{background:linear-gradient(160deg,#0a2a4ff2 0%,#123c66ed 100%);border:1px solid #234f7e;border-radius:16px;width:100%;max-width:460px;padding:1.4rem 1.2rem;box-shadow:0 20px 45px #07142940}.login-logo{opacity:.96;width:clamp(88px,14vw,118px);height:auto;margin:0 0 .7rem auto;display:block}.kicker-dark{color:#b9d6f5;letter-spacing:.03em;text-transform:uppercase;margin:0 0 .25rem;font-size:.82rem}.login-card h1{color:#f6fbff;margin:0 0 .3rem;font-size:1.9rem}.login-subtitle{color:#d7e8fa;margin:0 0 1rem}.login-form{gap:.85rem;display:grid}.login-form label{gap:.35rem;display:grid}.login-form label span{color:#d7e8fa;font-size:.88rem}.login-form input{color:#f3f8ff;background:#071a3180;border:1px solid #3e6693;border-radius:10px;padding:.62rem .7rem;font-size:.95rem}.login-form input:focus{border-color:#f4c14b;outline:2px solid #f4c14b}.login-form input::placeholder{color:#9bb8d8}.login-btn{width:100%;margin-top:.25rem}.login-error{color:#b91c1c;margin:.85rem 0 0;font-size:.92rem}.login-back-btn{color:#d9ecff;background:#081e3859;border:1px solid #4c7198;border-radius:10px;justify-content:center;align-items:center;width:100%;margin-top:.7rem;padding:.58rem .8rem;font-size:.9rem;text-decoration:none;transition:background .15s,border-color .15s,transform .15s;display:inline-flex}.login-back-btn:hover{background:#0b264594;border-color:#6e94bc;transform:translateY(-1px)}.login-footer{width:100%;max-width:460px;margin-top:0;position:absolute;bottom:1rem;left:50%;transform:translate(-50%)}.login-forgot-wrap{width:100%;margin-top:.55rem}.login-forgot-link{text-align:center;color:#f4c14b;width:100%;padding:.25rem 0;font-size:.9rem;text-decoration:none;display:inline-block}.login-forgot-link:hover{text-decoration:underline}.dashboard-admins-card{margin-top:1.25rem}.dashboard-admins-table-wrap{margin:.8rem 0;overflow-x:auto}.dashboard-admins-table{border-collapse:collapse;width:100%}.dashboard-admins-table th,.dashboard-admins-table td{text-align:left;border-bottom:1px solid #a2bede40;padding:.55rem .4rem;font-size:.92rem}.admin-th-sort{color:#e8f1fb;width:100%;font:inherit;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:.25rem;margin:0;padding:.15rem .2rem;font-size:.88rem;font-weight:600;line-height:1.25;display:inline-flex}.admin-th-sort:hover{color:#f4c14b;background:#ffffff14}.admin-th-sort-ico{opacity:.85;font-size:.72rem;font-weight:700}.dashboard-admin-avatar{object-fit:cover;border:1px solid #a2bede40;border-radius:10px;width:38px;height:38px}.dashboard-admin-action-btn{color:#d9ecff;cursor:pointer;background:#081e3859;border:1px solid #4c7198;border-radius:10px;margin-right:.35rem;padding:.4rem .6rem;font-size:.88rem}.dashboard-admin-action-btn:hover{transform:translateY(-1px)}.dashboard-admin-action-btn-danger{border-color:#b91c1c80}.dashboard-admins-form-card{background:#123c6640;border:1px solid #234f7e;border-radius:16px;margin-top:.8rem;padding:1rem .95rem}.dashboard-admins-form-head{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.6rem;display:flex}.dashboard-admins-form-head h3{margin:0;font-size:1.1rem}.dashboard-admin-secondary-btn{color:#d9ecff;cursor:pointer;background:#081e3859;border:1px solid #4c7198;border-radius:10px;padding:.45rem .65rem}.dashboard-admins-hint{opacity:.85;margin:.1rem 0 .8rem;font-size:.9rem}.dashboard-admins-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem;display:grid}.dashboard-admins-form label{gap:.35rem;display:grid}.dashboard-admins-form label span{color:#d7e8fa;font-size:.88rem}.dashboard-admins-form input,.dashboard-admins-form select{color:#f3f8ff;background:#071a3180;border:1px solid #3e6693;border-radius:10px;padding:.62rem .7rem;font-size:.95rem}.dashboard-admins-form button[type=submit]{grid-column:1/-1}.dashboard-admin-secondary-btn:hover,.dashboard-admin-action-btn:hover{background:#0b264594}.dashboard-admin-preview img{object-fit:cover;border:1px solid #a2bede40;border-radius:16px;width:72px;height:72px}.admin-status{border-radius:8px;padding:.2rem .5rem;font-size:.82rem;font-weight:600;display:inline-block}.admin-status-on{color:#6ee7b7;background:#34d39933;border:1px solid #34d39973}.admin-status-off{color:#fecaca;background:#f8717126;border:1px solid #f8717159}.admin-members-card-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem 1.5rem;margin-bottom:.35rem;display:flex}.admin-members-card-head-text{flex:240px;min-width:0}.admin-members-subtitle{margin-bottom:0}.admin-btn-create-admin{letter-spacing:.02em;color:#0a2a4f;cursor:pointer;background:linear-gradient(#f4c14b 0%,#e5ac2e 100%);border:1px solid #e8b84a;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;gap:.55rem;padding:.72rem 1.15rem;font-size:.95rem;font-weight:600;transition:transform .15s,box-shadow .15s,filter .15s;display:inline-flex;box-shadow:0 6px 20px #07142947}.admin-btn-create-admin:hover{filter:brightness(1.03);transform:translateY(-2px);box-shadow:0 10px 26px #07142959}.admin-btn-create-admin:active{transform:translateY(0)}.admin-btn-create-admin-icon{flex-shrink:0;width:1.35rem;height:1.35rem}@media (width<=640px){.admin-btn-create-admin{order:-1;width:100%}.admin-members-card-head{flex-direction:column}}.admin-toolbar{flex-wrap:wrap;align-items:flex-end;gap:.85rem 1rem;margin:.85rem 0 1rem;display:flex}.admin-toolbar-field{flex:160px;gap:.3rem;min-width:min(100%,200px);display:grid}.admin-toolbar-field span{color:#d7e8fa;font-size:.82rem}.admin-toolbar-field input,.admin-toolbar-field select{color:#f3f8ff;background:#071a3180;border:1px solid #3e6693;border-radius:10px;padding:.55rem .65rem;font-size:.92rem}.admin-table-loading-msg{opacity:.92;margin:.35rem 0 .5rem;font-size:.88rem}.dashboard-admins-table-wrap.admin-table-loading{opacity:.55;pointer-events:none;transition:opacity .15s}.admin-table-empty{text-align:center;color:#b9d6f5;font-size:.95rem;padding:1.5rem!important}.admin-pagination{border-top:1px solid #a2bede33;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-top:1rem;padding-top:.85rem;display:flex}.admin-pagination-info{color:#d7e8fa;margin:0;font-size:.88rem}.admin-pagination-actions{align-items:center;gap:.65rem;display:flex}.admin-pagination-page{color:#e8f1fb;text-align:center;min-width:8rem;font-size:.88rem}.admin-pagination-actions button:disabled{opacity:.45;cursor:not-allowed}.admin-modal-backdrop{z-index:1000;background:#071429b8;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.admin-modal{background:linear-gradient(160deg,#0a2a4ffa 0%,#123c66f5 100%);border:1px solid #234f7e;border-radius:16px;flex-direction:column;width:100%;max-width:560px;max-height:min(92vh,900px);display:flex;overflow:hidden;box-shadow:0 24px 60px #07142973}.admin-modal-header{border-bottom:1px solid #a2bede40;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.1rem;display:flex}.admin-modal-header h2{color:#f6fbff;margin:0;font-size:1.15rem}.admin-modal-close{color:#e8f1fb;cursor:pointer;background:#081e3880;border:none;border-radius:10px;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;font-size:1.5rem;line-height:1;display:flex}.admin-modal-close:hover{background:#0b2645bf}.admin-modal-body{padding:1rem 1.1rem 1.25rem;overflow-y:auto}.admin-modal-form{margin-top:.35rem}.admin-modal-footer-btns{flex-wrap:wrap;grid-column:1/-1;justify-content:flex-end;gap:.65rem;margin-top:.25rem;display:flex}.admin-confirm-backdrop{z-index:1300}.admin-confirm-dialog{max-width:440px}.admin-confirm-message{color:#e8f1fb;margin:0 0 .65rem;font-size:.95rem;line-height:1.45}.admin-confirm-message strong{color:#f4c14b;font-weight:600}.admin-confirm-email{color:#b9d6f5;word-break:break-all}.admin-confirm-hint{color:#9eb9d9;margin:0 0 1.1rem;font-size:.86rem;line-height:1.4}.admin-confirm-actions{margin-top:.5rem}@keyframes cap-toast-in{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.cap-toast{z-index:10000;pointer-events:auto;max-width:min(22rem,100vw - 2rem);animation:.32s cubic-bezier(.22,1,.36,1) forwards cap-toast-in;position:fixed;bottom:1.25rem;right:1.25rem}.cap-toast-inner{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(155deg,#0a2a4ff7 0%,#0e345cf2 100%);border:1px solid #a2bede47;border-radius:14px;align-items:flex-start;gap:.75rem;padding:.85rem .75rem .85rem .9rem;display:flex;box-shadow:0 18px 42px #0714298c,inset 0 0 0 1px #0000001f}.cap-toast-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1rem;font-weight:700;line-height:1;display:flex}.cap-toast-text{flex:1;min-width:0}.cap-toast-title{color:#f6fbff;font-size:.92rem;font-weight:600;line-height:1.35;display:block}.cap-toast-subtitle{color:#b9d6f5;opacity:.92;margin:.25rem 0 0;font-size:.8rem;line-height:1.4}.cap-toast-dismiss{color:#d9e7f6;cursor:pointer;background:#081e3873;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.25rem;line-height:1;transition:background .15s,color .15s;display:flex}.cap-toast-dismiss:hover{color:#fff8e6;background:#f4c14b33}.cap-toast--success .cap-toast-inner{border-color:#56c49673;box-shadow:0 18px 42px #0714298c,inset 0 0 0 1px #56c4961f}.cap-toast--success .cap-toast-icon{color:#e8fff5;background:linear-gradient(145deg,#2d8f6a 0%,#1f6b4f 100%);border:1px solid #90e6c859}.cap-toast--error .cap-toast-inner{border-color:#e8787873;box-shadow:0 18px 42px #0714298c,inset 0 0 0 1px #e878781a}.cap-toast--error .cap-toast-icon{color:#fff5f5;background:linear-gradient(145deg,#c44 0%,#8a2f2f 100%);border:1px solid #ffb4b459}.cap-toast--accent .cap-toast-inner{border-color:#f4c14b80;box-shadow:0 18px 42px #0714298c,inset 0 0 0 1px #f4c14b1f}.cap-toast--accent .cap-toast-icon{color:#0a2a4f;background:linear-gradient(145deg,#f4c14b 0%,#d49a1f 100%);border:1px solid #ffe09699}@media (width<=640px){.container{padding-top:2rem}.hero-card{padding:1.25rem}.actions{flex-direction:column}.landing-footer{flex-direction:column;gap:.2rem}.hero-metrics{grid-template-columns:1fr}}
