:root{color:#17221f;font-synthesis:none;--ink:#17221f;--muted:#6c7b76;--line:#dde6e2;--green:#287d71;--green-dark:#1f6158;--green-soft:#dfeeea;--gold:#e5a654;--red:#c95549;--panel:#fff;--shadow:0 10px 32px #1a372f12;background:#f4f7f6;font-family:Avenir Next,Segoe UI,system-ui,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.boot{min-height:100vh;color:var(--muted);justify-content:center;align-items:center;gap:14px;display:flex}.loader{border:3px solid var(--line);border-top-color:var(--green);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.brand{color:var(--ink);align-items:center;gap:12px;display:flex}.brand__mark{color:#fff;background:var(--green);border-radius:13px;place-items:center;width:44px;height:44px;display:grid;box-shadow:0 8px 18px #287d7138}.brand>span:last-child{align-items:baseline;gap:5px;display:flex}.brand strong{letter-spacing:-1px;font:800 24px/1 Avenir Next,Segoe UI,system-ui,sans-serif}.brand small{letter-spacing:2px;color:var(--green);font:700 10px/1 Avenir Next,Segoe UI,system-ui,sans-serif}.brand--compact .brand__mark{border-radius:10px;width:36px;height:36px}.brand--compact strong{font-size:20px}.brand--compact small{font-size:8px}.eyebrow,.panel__kicker{color:var(--green);letter-spacing:1.8px;text-transform:uppercase;font:700 11px/1.2 Avenir Next,Segoe UI,system-ui,sans-serif;display:block}.button{border:0;border-radius:11px;justify-content:center;align-items:center;gap:9px;padding:12px 18px;font-weight:700;transition:transform .15s,background .15s,box-shadow .15s;display:inline-flex}.button:hover:not(:disabled){transform:translateY(-1px)}.button--primary{color:#fff;background:var(--green);box-shadow:0 8px 16px #287d712e}.button--primary:hover:not(:disabled){background:var(--green-dark)}.button--dark{background:var(--ink);color:#fff}.button--ghost{color:var(--ink);background:#eef2f0}.button--wide{width:100%}.icon-button{border:1px solid var(--line);color:#52615d;background:#fff;border-radius:11px;place-items:center;width:40px;height:40px;display:grid}.icon-button:hover{color:var(--green);border-color:#b8d2cb}.login-shell{background:#f7f9f8;grid-template-columns:minmax(400px,1.05fr) minmax(400px,.95fr);min-height:100vh;display:grid}.login-story{color:#fff;background:#173d37;flex-direction:column;justify-content:space-between;min-height:100vh;padding:42px 7vw;display:flex;position:relative;overflow:hidden}.login-story:before{content:"";border:1px solid #ffffff1f;border-radius:50%;width:620px;height:620px;position:absolute;bottom:-150px;right:-180px;box-shadow:0 0 0 80px #ffffff06,0 0 0 160px #ffffff05}.login-story:after{content:"";background:linear-gradient(135deg,#0000 50%,#e5a6541f);position:absolute;inset:0}.login-story>*{z-index:1;position:relative}.login-story .brand{color:#fff}.login-story .brand small{color:#d8b774}.login-story .brand__mark{color:#173d37;background:#f1d393}.login-story__content{max-width:640px}.login-story__content .eyebrow{color:#e6be72}.login-story h1{letter-spacing:-3px;margin:20px 0;font:700 clamp(42px,5.1vw,74px)/1.06 Avenir Next,Segoe UI,system-ui,sans-serif}.login-story h1 em{color:#f0c777;font-style:normal}.login-story p{color:#c7d7d3;max-width:520px;font-size:18px;line-height:1.65}.login-story__foot{color:#aec4be;gap:32px;font-size:13px;display:flex}.login-story__foot span:before{content:"";background:#e5a654;border-radius:50%;width:7px;height:7px;margin-right:9px;display:inline-block}.login-panel{place-items:center;padding:48px;display:grid}.login-card{background:#fff;border:1px solid #e3e9e6;border-radius:24px;width:min(440px,100%);padding:44px;box-shadow:0 24px 70px #1b362f17}.login-card__icon{display:none}.login-card h2{letter-spacing:-1.2px;margin:10px 0;font:800 36px/1.15 Avenir Next,Segoe UI,system-ui,sans-serif}.login-card>p{color:var(--muted);margin:0 0 30px}.login-card label,.date-field{color:#44534f;margin:18px 0 7px;font-size:13px;font-weight:700;display:block}.login-card input,.date-field input{background:#fbfcfc;border:1px solid #d7e0dc;border-radius:10px;outline:none;width:100%;margin-top:8px;padding:13px 14px}.login-card input:focus,.date-field input:focus{border-color:var(--green);box-shadow:0 0 0 3px #287d711a}.form-error{color:#8f332a;background:#fbeae7;border:1px solid #f2cec8;border-radius:9px;margin:14px 0;padding:11px 13px;font-size:13px}.login-help{color:#87938f;text-align:center;margin-top:20px;line-height:1.5;display:block}.app-shell{flex-direction:column;min-height:100vh;display:flex}.topbar{border-bottom:1px solid var(--line);z-index:20;background:#fff;align-items:center;gap:16px;max-width:100%;height:64px;padding:0 20px;display:flex;position:sticky;top:0}.topbar__start{flex-shrink:0;align-items:center;gap:14px;min-width:0;display:flex}.topbar__project{border-left:1px solid var(--line);flex-direction:column;min-width:0;padding-left:14px;display:flex}.topbar__project small{letter-spacing:1.2px;color:#8b9894;font:700 9px Avenir Next,Segoe UI,system-ui,sans-serif}.topbar__project strong{white-space:nowrap;font:700 13px Avenir Next,Segoe UI,system-ui,sans-serif}.topbar__nav{flex-wrap:wrap;align-items:center;gap:8px;margin-left:auto;margin-right:12px;display:flex}.topbar-nav-link{color:#52615d;white-space:nowrap;background:#eef2f0;border-radius:10px;align-items:center;gap:7px;padding:8px 13px;font:700 13px Avenir Next,Segoe UI,system-ui,sans-serif;text-decoration:none;transition:background .15s,color .15s,box-shadow .15s;display:inline-flex}.topbar-nav-link svg{width:17px;height:17px}.topbar-nav-link:hover{color:var(--ink);background:#e4ebe8}.topbar-nav-link--active{color:var(--green);background:var(--green-soft);box-shadow:inset 0 0 0 1px #c5ddd7}.topbar-nav-link--accent{background:var(--ink);color:#fff}.topbar-nav-link--accent:hover{color:#fff;background:#24302d}.topbar-nav-link--accent.topbar-nav-link--active{box-shadow:0 6px 16px #17221f2e}.topbar__actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.updated{border-right:1px solid var(--line);align-items:center;gap:8px;padding-right:12px;display:flex}.updated>span:last-child,.user-chip div{flex-direction:column;display:flex}.updated small,.user-chip small{color:#899590;font-size:10px}.updated strong,.user-chip strong{font-size:12px}.live-dot{background:#42a88e;border-radius:50%;width:8px;height:8px;box-shadow:0 0 0 5px #e7f5f1}.user-chip{align-items:center;gap:8px;display:flex}.user-chip>span{background:var(--green-soft);width:32px;height:32px;color:var(--green);border-radius:9px;place-items:center;font-size:13px;font-weight:800;display:grid}.icon-button{border-radius:9px;width:36px;height:36px}.dashboard{flex:1;width:100%;max-width:1320px;margin:0 auto;padding:28px 20px 48px}.dashboard--page{max-width:900px}.page-heading{justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:22px;display:flex}.page-heading--compact{margin-bottom:20px}.page-heading h1{letter-spacing:-1.2px;margin:6px 0;font:800 clamp(26px,2.8vw,36px)/1.1 Avenir Next,Segoe UI,system-ui,sans-serif}.page-heading p{color:var(--muted);margin:0;font-size:14px}.page-panel{padding:24px}.page-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.page-error{align-items:center;gap:8px;margin-bottom:16px;display:flex}.page-loading{color:var(--muted);margin:0 0 16px;font-size:13px}.upload-page__form{max-width:640px}.users-panel__table-wrap--page{max-height:none;margin-bottom:20px}.users-panel__form--page{border-top:1px solid var(--line);padding-top:18px}.heading-actions{align-items:stretch;gap:12px;display:flex}.cutoff-date-select{min-width:260px;position:relative}.cutoff-date-select__trigger{border:1px solid var(--line);width:100%;color:var(--ink);text-align:left;background:#fff;border-radius:14px;align-items:center;gap:11px;padding:10px 14px;transition:border-color .15s,box-shadow .15s;display:flex}.cutoff-date-select__trigger:hover:not(:disabled){border-color:#b8d2cb}.cutoff-date-select--open .cutoff-date-select__trigger{border-color:var(--green);box-shadow:0 0 0 3px #287d711f}.cutoff-date-select__icon{width:36px;height:36px;color:var(--green);background:var(--green-soft);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.cutoff-date-select__copy{flex-direction:column;flex:1;min-width:0;display:flex}.cutoff-date-select__copy small{color:#8b9793;text-transform:uppercase;letter-spacing:.7px;font-size:9px}.cutoff-date-select__copy strong{white-space:nowrap;text-overflow:ellipsis;font:700 14px/1.25 Avenir Next,Segoe UI,system-ui,sans-serif;overflow:hidden}.cutoff-date-select__chevron{color:#8b9793;flex-shrink:0;transition:transform .18s}.cutoff-date-select--open .cutoff-date-select__chevron{color:var(--green);transform:rotate(180deg)}.cutoff-date-select__menu{z-index:40;background:#fff;border:1px solid #d8e4df;border-radius:16px;max-height:min(320px,60vh);margin:0;padding:8px;list-style:none;animation:.16s cutoff-menu-in;position:absolute;top:calc(100% + 8px);left:0;right:0;overflow:auto;box-shadow:0 18px 48px #17342c24}.cutoff-date-select__option{width:100%;color:var(--ink);text-align:left;background:0 0;border:0;border-radius:12px;align-items:center;gap:10px;padding:11px 12px;font:600 14px/1.3 Avenir Next,Segoe UI,system-ui,sans-serif;transition:background .12s,color .12s;display:flex}.cutoff-date-select__option svg{opacity:0;flex-shrink:0;width:16px;height:16px}.cutoff-date-select__option:hover:not(.cutoff-date-select__option--selected){background:#f3f7f5}.cutoff-date-select__option--selected{color:#fff;background:linear-gradient(135deg,#2f86ff,#1f6fe0);box-shadow:inset 0 0 0 1px #0f2d5f59,0 8px 18px #1f6fe038}.cutoff-date-select__option--selected svg{opacity:1}@keyframes cutoff-menu-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.loading-line{background:var(--green);z-index:30;height:2px;animation:1.2s infinite loading;position:fixed;top:63px;left:0}@keyframes loading{0%{width:0;left:0}50%{width:70%;left:15%}to{width:0;left:100%}}.notice{color:#7a5a20;background:#fff9ed;border:1px solid #ead5ae;border-radius:12px;margin:0 0 18px}.notice summary{cursor:pointer;align-items:center;gap:10px;padding:13px 16px;font-weight:600;display:flex}.notice summary span:last-child{margin-left:auto;font-size:12px}.notice>div{padding:0 18px 12px;font-size:13px}.notice p{margin:6px 0}.notice--error{color:#8e352c;background:#fff0ed;border-color:#f1ccc6;align-items:center;gap:10px;padding:13px 16px;display:flex}.notice--error button{color:inherit;background:0 0;border:0;margin-left:auto;text-decoration:underline}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px;display:grid}.stat-card{background:#fff;border:1px solid #e1e9e5;border-radius:17px;padding:22px 23px;box-shadow:0 4px 18px #17342c09}.stat-card__top{color:#697773;justify-content:space-between;align-items:center;font-size:13px;display:flex}.stat-card__icon{width:38px;height:38px;color:var(--green);background:var(--green-soft);border-radius:11px;place-items:center;display:grid}.stat-card>strong{letter-spacing:-1px;margin:12px 0 2px;font:800 32px Avenir Next,Segoe UI,system-ui,sans-serif;display:block}.stat-card>small{color:#8b9793}.stat-card--accent{color:#fff;background:var(--green);border-color:var(--green)}.stat-card--accent .stat-card__top,.stat-card--accent>small{color:#d2e8e3}.stat-card--accent .stat-card__icon{color:#fff;background:#ffffff24}.content-grid{gap:16px;margin-bottom:16px;display:grid}.content-grid--top{grid-template-columns:minmax(0,2.1fr) minmax(300px,.9fr)}.demographics-grid{grid-template-columns:1fr 1fr}.panel{box-shadow:var(--shadow);background:#fff;border:1px solid #e1e9e5;border-radius:17px;overflow:hidden}.panel__header{justify-content:space-between;align-items:flex-start;gap:15px;min-height:78px;padding:20px 22px 12px;display:flex}.panel__header h2{margin:6px 0;font:700 17px Avenir Next,Segoe UI,system-ui,sans-serif}.panel__header>svg{color:var(--green)}.panel__total{color:#71807b;background:#f1f5f3;border-radius:20px;padding:7px 10px;font-size:11px}.progress-badge{color:var(--green);background:var(--green-soft);border-radius:10px;align-items:baseline;gap:6px;padding:8px 11px;display:flex}.progress-badge span{font:800 17px Avenir Next,Segoe UI,system-ui,sans-serif}.progress-badge small{font-size:10px}.chart{height:250px;padding:0 10px 12px;font-size:11px}.chart--large{height:300px}.quota-panel{flex-direction:column;display:flex}.quota-donut{height:218px;position:relative}.quota-donut>div:last-child{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.quota-donut strong{font:800 24px Avenir Next,Segoe UI,system-ui,sans-serif}.quota-donut span{color:var(--muted);font-size:11px}.quota-legend{grid-template-columns:1fr 1fr;gap:8px;padding:0 24px 20px;display:grid}.quota-legend p{color:var(--muted);grid-template-columns:auto 1fr;gap:2px 8px;margin:0;font-size:12px;display:grid}.quota-legend i,.sex-legend i{border-radius:50%;width:8px;height:8px;margin-top:4px}.quota-legend strong{color:var(--ink);grid-column:2;font-size:16px}.sex-layout{grid-template-columns:1fr 1.25fr;align-items:center;height:250px;display:grid}.chart--donut{height:220px;padding:0}.sex-legend{flex-direction:column;gap:12px;padding-right:24px;display:flex}.sex-legend>div{border-bottom:1px solid #edf1ef;grid-template-columns:auto 1fr auto;align-items:start;gap:9px;padding-bottom:10px;display:grid}.sex-legend span{font-size:12px}.sex-legend small{color:var(--muted);margin-top:3px;display:block}.sex-legend strong{color:var(--green);font:700 13px Avenir Next,Segoe UI,system-ui,sans-serif}.entity-panel{margin-top:0}.search{border:1px solid var(--line);color:#86938f;border-radius:10px;align-items:center;gap:8px;width:260px;padding:9px 12px;display:flex}.search input{border:0;outline:0;width:100%}.table-wrap{max-height:500px;overflow:auto}.table-wrap table{border-collapse:collapse;width:100%;min-width:760px}.table-wrap thead{z-index:1;background:#f6f8f7;position:sticky;top:0}.table-wrap th{text-align:left;color:#7d8985;text-transform:uppercase;letter-spacing:.8px;border-block:1px solid #e7ecea;padding:12px 20px;font-size:10px}.table-wrap td{border-bottom:1px solid #edf1ef;padding:13px 20px;font-size:13px}.table-wrap tbody tr:hover{background:#fafcfb}.code{color:#517069;background:#edf3f1;border-radius:8px;place-items:center;width:29px;height:29px;font-weight:700;display:grid}.mini-bar{background:var(--green);border-radius:10px;width:140px;height:7px;display:flex;overflow:hidden}.mini-bar span{background:var(--gold)}.mini-bar i{flex:1}.table-footer{color:#7c8985;justify-content:space-between;padding:14px 20px;font-size:11px;display:flex}.table-footer span:last-child{align-items:center;gap:6px;display:flex}.table-footer i{border-radius:50%;width:8px;height:8px;margin-left:8px}.legend-fixed{background:var(--gold)}.legend-mobile{background:var(--green)}.site-footer{border-top:1px solid var(--line);color:#85918d;align-items:center;gap:20px;width:100%;max-width:1320px;margin:0 auto;padding:18px 20px;font-size:11px;display:flex}.site-footer>span:last-child{margin-left:auto}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0d1c188a;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.confirm-modal{text-align:center;background:#fff;border-radius:20px;width:min(420px,100%);padding:28px 26px 24px;box-shadow:0 30px 90px #00000040}.confirm-modal__icon{width:52px;height:52px;color:var(--green);background:var(--green-soft);border-radius:15px;place-items:center;margin:0 auto 14px;display:grid}.confirm-modal h2{letter-spacing:-.8px;margin:8px 0 10px;font:800 26px/1.15 Avenir Next,Segoe UI,system-ui,sans-serif}.confirm-modal p{color:var(--muted);margin:0;font-size:14px;line-height:1.55}.confirm-modal p strong{color:var(--ink);font-weight:700}.confirm-modal__actions{justify-content:center;margin-top:24px}.upload-panel{background:#fff;border-radius:20px;width:min(650px,100%);max-height:90vh;padding:26px;overflow:auto;box-shadow:0 30px 90px #00000040}.upload-panel>header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.upload-panel h2{margin:6px 0;font:800 26px Avenir Next,Segoe UI,system-ui,sans-serif}.upload-panel .icon-button{font-size:24px}.dropzone{color:#52625d;cursor:pointer;background:#f8fbfa;border:1.5px dashed #b9cbc6;border-radius:15px;flex-direction:column;justify-content:center;align-items:center;gap:7px;height:190px;margin:20px 0;display:flex}.dropzone:hover,.dropzone--selected{border-color:var(--green);background:#f1f8f6}.dropzone input{opacity:0;pointer-events:none;position:absolute}.dropzone__icon{width:48px;height:48px;color:var(--green);background:var(--green-soft);border-radius:14px;place-items:center;display:grid}.dropzone small{color:#899691}.modal-actions{justify-content:flex-end;gap:10px;margin-top:22px;display:flex}.preview__status{color:#266b60;background:#eaf6f2;border-radius:12px;align-items:center;gap:12px;padding:15px;display:flex}.preview__status--error{color:#9a3e34;background:#fbecea}.preview__status>div{flex-direction:column;display:flex}.preview__status span{opacity:.75;margin-top:2px;font-size:12px}.preview__metrics{grid-template-columns:repeat(4,1fr);gap:8px;margin:14px 0;display:grid}.preview__metrics>div{background:#f4f7f6;border-radius:10px;flex-direction:column;padding:12px;display:flex}.preview__metrics small{color:var(--muted);font-size:9px}.preview__metrics strong{margin-top:4px;font:800 19px Avenir Next,Segoe UI,system-ui,sans-serif}.issue-list{color:#73551d;background:#fff8e9;border:1px solid #efdebb;border-radius:10px;max-height:160px;margin-top:10px;padding:13px 15px;font-size:12px;overflow:auto}.issue-list--error{color:#8d332b;background:#fff0ed;border-color:#edcbc5}.issue-list p{margin:6px 0}.users-panel{width:min(760px,100%)}.users-panel__error{align-items:center;gap:8px;margin-bottom:14px;display:flex}.users-panel__loading{color:var(--muted);margin:0 0 12px;font-size:13px}.users-panel__table-wrap{border:1px solid var(--line);border-radius:12px;max-height:280px;margin-bottom:18px;overflow:auto}.users-table{border-collapse:collapse;width:100%;min-width:620px}.users-table th,.users-table td{text-align:left;border-bottom:1px solid #edf1ef;padding:11px 14px;font-size:13px}.users-table th{text-transform:uppercase;letter-spacing:.7px;color:#7d8985;background:#f6f8f7;font-size:10px}.users-table select{border:1px solid var(--line);background:#fff;border-radius:8px;padding:7px 8px}.users-table__actions{justify-content:flex-end;gap:6px;display:flex}.users-table__actions .button{padding:7px 10px;font-size:12px}.users-panel__form h3{margin:0 0 12px;font-size:15px}.users-panel__fields{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px;display:grid}.users-panel__fields label{color:#44534f;font-size:12px;font-weight:700;display:block}.users-panel__fields input,.users-panel__fields select{border:1px solid #d7e0dc;border-radius:9px;width:100%;margin-top:6px;padding:10px 11px}@media (width<=1050px){.topbar__project,.updated{display:none}.topbar__nav{margin-left:0}.stats-grid{grid-template-columns:repeat(2,1fr)}.content-grid--top{grid-template-columns:1fr}.quota-panel{min-height:370px}.quota-donut{height:230px}.demographics-grid{grid-template-columns:1fr}.login-story{padding:40px}.login-story h1{font-size:48px}}@media (width<=720px){.topbar{gap:10px;height:58px;padding:0 12px}.topbar .brand small,.user-chip div,.topbar__project{display:none}.topbar__nav{gap:6px;margin-right:6px}.topbar-nav-link{padding:7px 10px;font-size:12px}.topbar-nav-link span{display:none}.topbar-nav-link svg{margin:0}.topbar__actions{gap:6px}.dashboard{padding:20px 14px 36px}.page-heading{flex-direction:column;align-items:flex-start}.page-heading h1{font-size:26px}.heading-actions{width:100%}.cutoff-date-select{width:100%;min-width:0}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-card{padding:16px}.stat-card>strong{font-size:25px}.stat-card__icon{width:32px;height:32px}.panel__header{padding:17px 16px 10px}.chart--large{height:260px}.sex-layout{grid-template-columns:.9fr 1.1fr}.search{width:100%}.entity-panel .panel__header{flex-direction:column}.site-footer{padding:20px 16px}.site-footer .brand{display:none}.preview__metrics{grid-template-columns:1fr 1fr}.login-shell{grid-template-columns:1fr}.login-story{display:none}.login-panel{min-height:100vh;padding:20px}.login-card{padding:30px 24px}.login-card__icon{color:#fff;background:var(--green);border-radius:15px;place-items:center;width:52px;height:52px;margin-bottom:24px;display:grid}}@media (width<=430px){.stats-grid{grid-template-columns:1fr}.topbar-nav-link{padding:7px 9px}.users-panel__fields{grid-template-columns:1fr}.stat-card>strong,.stat-card>small{grid-column:1}.stat-card__top{display:contents}.stat-card__top>span:first-child{grid-column:1}.stat-card__icon{grid-area:1/2/3}.sex-layout{grid-template-columns:1fr;height:auto}.chart--donut{height:180px}.sex-legend{padding:0 18px 18px}.table-footer span:last-child{display:none}.modal-backdrop{padding:8px}.upload-panel{padding:20px 16px}.confirm-modal{padding:24px 18px 20px}.confirm-modal__actions{flex-direction:column-reverse}.confirm-modal__actions .button{width:100%}.modal-actions .button{padding:11px 13px}.site-footer{justify-content:space-between}.site-footer>span:last-child{margin:0}}
