@import "https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&family=Mulish:wght@400;500;600;700&display=swap";
.roster-scope{--blue:#1668e0;--blue-700:#0f52b5;--blue-800:#0a3f8f;--blue-50:#eef4fd;--blue-100:#dbe8fb;--green:#1f9d57;--green-700:#177a43;--green-50:#eaf7f0;--grad:linear-gradient(135deg,#1668e0 0%,#1786c0 55%,#1f9d57 100%);--grad-soft:linear-gradient(135deg,#eef4fd 0%,#eaf7f0 100%);--ink:#0f2a45;--ink-2:#33506e;--muted:#6a809a;--faint:#9fb1c6;--line:#e4eaf1;--line-2:#eef2f7;--bg:#f4f7fb;--card:#fff;--danger:#d64545;--danger-bg:#fdecec;--warn:#c97a16;--warn-bg:#fcf3e5;--ok:#1f9d57;--ok-bg:#eaf7f0;--r-lg:18px;--r:13px;--r-sm:9px;--shadow-sm:0 1px 2px #0f2a450d,0 1px 3px #0f2a450f;--shadow:0 6px 20px #0f2a4514;--shadow-lg:0 18px 50px #0f2a4524;--display:"Poppins",system-ui,sans-serif;--body:"Mulish",system-ui,sans-serif;--accent:var(--blue);--accent-700:var(--blue-700);font-family:var(--body);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.55}.roster-scope *,.roster-scope :before,.roster-scope :after{box-sizing:border-box}.roster-scope h1,.roster-scope h2,.roster-scope h3,.roster-scope h4,.roster-scope h5{font-family:var(--display);color:var(--ink);letter-spacing:-.01em;margin:0;line-height:1.15}.roster-scope p{margin:0}.roster-scope a{color:var(--accent);text-decoration:none}.roster-scope button{font-family:var(--body);cursor:pointer}.roster-scope input,.roster-scope select,.roster-scope textarea{font-family:var(--body)}.roster-scope .site-header{border-bottom:1px solid var(--line);z-index:40;background:#fff;position:sticky;top:0}.roster-scope .site-header .inner{align-items:center;gap:28px;max-width:1240px;margin:0 auto;padding:14px 28px;display:flex}.roster-scope .brand{align-items:center;gap:12px;text-decoration:none;display:flex}.roster-scope .brand-mark{background:var(--grad);border-radius:12px;flex:none;place-items:center;width:46px;height:46px;display:grid;box-shadow:0 6px 16px #1668e047}.roster-scope .brand-mark svg{width:26px;height:26px}.roster-scope .brand-name{font-family:var(--display);color:var(--ink);letter-spacing:.01em;font-size:21px;font-weight:800;line-height:1}.roster-scope .brand-sub{color:var(--muted);letter-spacing:.02em;margin-top:3px;font-size:10.5px;font-weight:600}.roster-scope .hero{background:var(--grad);color:#fff;border-radius:0 0 24px 24px;position:relative;overflow:hidden}.roster-scope .hero:after{content:"";pointer-events:none;background:radial-gradient(900px 380px at 85% -10%,#ffffff29,#0000 60%);position:absolute;inset:0}.roster-scope .hero .inner{z-index:1;max-width:1240px;margin:0 auto;padding:46px 28px 54px;position:relative}.roster-scope .hero-badge{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff29;border:1px solid #ffffff52;border-radius:999px;align-items:center;gap:9px;padding:8px 16px;font-size:13.5px;font-weight:600;display:inline-flex}.roster-scope .hero-badge .dot{background:#8ff0b6;border-radius:50%;width:8px;height:8px;box-shadow:0 0 0 3px #8ff0b64d}.roster-scope .hero h1{color:#fff;letter-spacing:-.02em;max-width:17ch;margin:20px 0 14px;font-size:clamp(30px,4.4vw,52px);font-weight:800}.roster-scope .hero p.lead{color:#ffffffeb;max-width:62ch;font-size:clamp(15px,1.5vw,18px);font-weight:500}.roster-scope .hero-meta{flex-wrap:wrap;gap:10px;margin-top:24px;display:flex}.roster-scope .hero-chip{background:#ffffff24;border:1px solid #ffffff47;border-radius:11px;align-items:center;gap:8px;padding:10px 15px;font-size:13.5px;font-weight:600;display:inline-flex}.roster-scope .hero-chip svg{opacity:.9;width:16px;height:16px}.roster-scope .page{max-width:1240px;margin:0 auto;padding:0 28px}.roster-scope .shell{max-width:920px;margin:0 auto;padding:0 28px}.roster-scope .card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}.roster-scope .card-pad{padding:26px 28px}.roster-scope .form-wrap{padding:30px 0 70px}.roster-scope .form-grid{grid-template-columns:268px 1fr;align-items:start;gap:30px;display:grid}@media (max-width:880px){.roster-scope .form-grid{grid-template-columns:1fr}}.roster-scope .stepper{position:sticky;top:92px}.roster-scope .stepper-card{border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);background:#fff;padding:20px;overflow:hidden}.roster-scope .stepper h4{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:12px;font-weight:700;font-family:var(--body);margin-bottom:14px}.roster-scope .step-item{cursor:pointer;gap:13px;padding:9px 0;display:flex;position:relative}.roster-scope .step-item .bullet{width:30px;height:30px;font-family:var(--display);background:var(--line-2);color:var(--muted);border:2px solid #0000;border-radius:50%;flex:none;place-items:center;font-size:13px;font-weight:700;transition:all .2s;display:grid}.roster-scope .step-item .line{background:var(--line);width:2px;position:absolute;top:39px;bottom:-9px;left:14px}.roster-scope .step-item:last-child .line{display:none}.roster-scope .step-item .s-label{color:var(--ink-2);padding-top:4px;font-size:14px;font-weight:600}.roster-scope .step-item .s-sub{color:var(--faint);font-size:12px;font-weight:500}.roster-scope .step-item.active .bullet{background:var(--accent);color:#fff;box-shadow:0 6px 14px #1668e04d}.roster-scope .step-item.active .s-label{color:var(--ink)}.roster-scope .step-item.done .bullet{background:var(--green);color:#fff}.roster-scope .step-item.done .line{background:var(--green)}.roster-scope .step-item:hover .s-label{color:var(--ink)}.roster-scope .rail-progress{border-top:1px solid var(--line-2);margin-top:16px;padding-top:16px}.roster-scope .rail-progress .bar{background:var(--line-2);border-radius:999px;height:7px;overflow:hidden}.roster-scope .rail-progress .bar>i{background:var(--grad);border-radius:999px;height:100%;transition:width .35s;display:block}.roster-scope .rail-progress .pct{color:var(--muted);margin-top:8px;font-size:12.5px;font-weight:600}.roster-scope .mstep{display:none}@media (max-width:880px){.roster-scope .mstep{margin-bottom:18px;display:block}.roster-scope .mstep .bar{background:var(--line-2);border-radius:999px;height:7px;overflow:hidden}.roster-scope .mstep .bar>i{background:var(--grad);height:100%;display:block}.roster-scope .mstep .lbl{color:var(--muted);justify-content:space-between;margin-top:8px;font-size:13px;font-weight:600;display:flex}}.roster-scope .panel{border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);background:#fff;overflow:hidden}.roster-scope .panel-head{border-bottom:1px solid var(--line-2);background:linear-gradient(#fbfdff,#fff);padding:26px 30px 22px}.roster-scope .panel-head .eyebrow{letter-spacing:.06em;text-transform:uppercase;color:var(--accent);background:var(--blue-50);border-radius:999px;align-items:center;gap:8px;padding:5px 11px;font-size:12px;font-weight:700;display:inline-flex}.roster-scope .panel-head h2{margin:13px 0 6px;font-size:25px;font-weight:700}.roster-scope .panel-head p{color:var(--muted);max-width:64ch;font-size:14.5px}.roster-scope .panel-body{padding:26px 30px 30px}.roster-scope .fset{border:none;margin:0 0 30px;padding:0}.roster-scope .fset:last-child{margin-bottom:0}.roster-scope .fset>legend{font-family:var(--display);color:var(--ink);align-items:center;gap:9px;margin-bottom:4px;padding:0;font-size:16px;font-weight:600;display:flex}.roster-scope .fset .fset-note{color:var(--muted);margin-bottom:16px;font-size:13px}.roster-scope .fset-num{background:var(--accent);color:#fff;width:24px;height:24px;font-size:12px;font-weight:700;font-family:var(--display);border-radius:7px;place-items:center;display:inline-grid}.roster-scope .row{grid-template-columns:1fr 1fr;gap:16px 18px;display:grid}.roster-scope .row.c3{grid-template-columns:1fr 1fr 1fr}.roster-scope .row.c1{grid-template-columns:1fr}.roster-scope .col-2{grid-column:span 2}@media (max-width:620px){.roster-scope .row,.roster-scope .row.c3{grid-template-columns:1fr}.roster-scope .col-2{grid-column:auto}}.roster-scope .field{flex-direction:column;gap:7px;min-width:0;display:flex}.roster-scope .field>label{color:var(--ink-2);align-items:center;gap:6px;font-size:13.5px;font-weight:600;display:flex}.roster-scope .req{color:var(--danger);font-weight:700}.roster-scope .opt{color:var(--faint);font-size:12px;font-weight:500}.roster-scope .hint{color:var(--muted);font-size:12.5px}.roster-scope .err-msg{color:var(--danger);align-items:center;gap:5px;font-size:12.5px;font-weight:600;display:flex}.roster-scope .inp,.roster-scope .sel,.roster-scope .ta{border:1.5px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:10px;padding:11px 13px;font-size:14.5px;transition:border-color .15s,box-shadow .15s}.roster-scope .ta{resize:vertical;min-height:92px;line-height:1.5}.roster-scope .inp::placeholder,.roster-scope .ta::placeholder{color:var(--faint)}.roster-scope .inp:focus,.roster-scope .sel:focus,.roster-scope .ta:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3.5px #1668e021}.roster-scope .inp.invalid,.roster-scope .sel.invalid,.roster-scope .ta.invalid{border-color:var(--danger);box-shadow:0 0 0 3.5px #d645451a}.roster-scope .sel{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236a809a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 13px center;background-repeat:no-repeat;padding-right:36px}.roster-scope .inp-prefix{position:relative}.roster-scope .inp-prefix .px{color:var(--faint);pointer-events:none;font-size:14px;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.roster-scope .inp-prefix .inp{padding-left:34px}.roster-scope .choices{flex-direction:column;gap:10px;display:flex}.roster-scope .choices.cols{grid-template-columns:1fr 1fr;gap:10px;display:grid}@media (max-width:620px){.roster-scope .choices.cols{grid-template-columns:1fr}}.roster-scope .choice{border:1.5px solid var(--line);cursor:pointer;background:#fff;border-radius:12px;align-items:flex-start;gap:12px;padding:13px 15px;transition:all .15s;display:flex}.roster-scope .choice:hover{border-color:var(--blue-100);background:var(--blue-50)}.roster-scope .choice.sel{border-color:var(--accent);background:var(--blue-50);box-shadow:0 0 0 1px var(--accent)inset}.roster-scope .choice .box{border:2px solid var(--faint);background:#fff;border-radius:6px;flex:none;place-items:center;width:21px;height:21px;margin-top:1px;transition:all .15s;display:grid}.roster-scope .choice.radio .box{border-radius:50%}.roster-scope .choice.sel .box{background:var(--accent);border-color:var(--accent)}.roster-scope .choice .box svg{color:#fff;opacity:0;width:13px;height:13px;transition:all .15s}.roster-scope .choice.sel .box svg{opacity:1}.roster-scope .choice .ct{flex-direction:column;gap:1px;min-width:0;display:flex}.roster-scope .choice .ct .t{color:var(--ink);font-size:14px;font-weight:600}.roster-scope .choice .ct .d{color:var(--muted);font-size:12.5px}.roster-scope .cat-group{margin-bottom:14px}.roster-scope .cat-group>.cat-label{letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 8px;font-size:12px;font-weight:700}.roster-scope .rate-row{border-bottom:1px solid var(--line-2);justify-content:space-between;align-items:center;gap:14px;padding:11px 0;display:flex}.roster-scope .rate-row:last-child{border-bottom:none}.roster-scope .rate-row .rl{color:var(--ink-2);max-width:62%;font-size:14px;font-weight:500}.roster-scope .rate{flex:none;gap:7px;display:flex}.roster-scope .rate button{border:1.5px solid var(--line);width:36px;height:36px;font-family:var(--display);color:var(--muted);background:#fff;border-radius:9px;font-size:14px;font-weight:700;transition:all .12s}.roster-scope .rate button:hover{border-color:var(--accent);color:var(--accent)}.roster-scope .rate button.on{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 5px 12px #1668e040}.roster-scope .rate-legend{color:var(--faint);margin-top:4px;font-size:12px}.roster-scope .lang-table{border-collapse:collapse;width:100%}.roster-scope .lang-table th{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);text-align:center;padding:6px 4px;font-size:12px;font-weight:700}.roster-scope .lang-table th:first-child{text-align:left}.roster-scope .lang-table td{border-top:1px solid var(--line-2);color:var(--ink-2);padding:9px 4px;font-size:14px;font-weight:500}.roster-scope .lang-table td.cb{text-align:center;width:64px}.roster-scope .tick{border:2px solid var(--faint);cursor:pointer;vertical-align:middle;background:#fff;border-radius:6px;place-items:center;width:24px;height:24px;transition:all .12s;display:inline-grid}.roster-scope .tick svg{color:#fff;opacity:0;width:13px;height:13px}.roster-scope .tick.on{background:var(--accent);border-color:var(--accent)}.roster-scope .tick.on svg{opacity:1}.roster-scope .filedrop{border:2px dashed var(--line);cursor:pointer;background:#fcfdff;border-radius:13px;align-items:center;gap:14px;padding:20px;transition:all .15s;display:flex}.roster-scope .filedrop:hover,.roster-scope .filedrop.drag{border-color:var(--accent);background:var(--blue-50)}.roster-scope .filedrop .ico{background:var(--blue-50);width:42px;height:42px;color:var(--accent);border-radius:11px;flex:none;place-items:center;display:grid}.roster-scope .filedrop .ico svg{width:21px;height:21px}.roster-scope .filedrop .ft{color:var(--ink);font-size:14px;font-weight:600}.roster-scope .filedrop .fs{color:var(--muted);font-size:12.5px}.roster-scope .filedrop.has{border-style:solid;border-color:var(--green);background:var(--green-50)}.roster-scope .filedrop.has .ico{color:var(--green);background:#fff}.roster-scope .file-pill{color:var(--green-700);align-items:center;gap:8px;font-size:13px;font-weight:600;display:inline-flex}.roster-scope .file-x{border:1px solid var(--line);width:30px;height:30px;color:var(--muted);background:#fff;border-radius:8px;place-items:center;margin-left:auto;display:grid}.roster-scope .file-x:hover{color:var(--danger);border-color:var(--danger)}.roster-scope .rep{border:1px solid var(--line);background:#fff;border-radius:14px;margin-bottom:14px;overflow:hidden}.roster-scope .rep-head{background:var(--grad-soft);border-bottom:1px solid var(--line-2);align-items:center;gap:12px;padding:13px 16px;display:flex}.roster-scope .rep-head .rn{border:1px solid var(--line);width:28px;height:28px;font-family:var(--display);color:var(--accent);background:#fff;border-radius:8px;place-items:center;font-size:13px;font-weight:700;display:grid}.roster-scope .rep-head .rt{color:var(--ink);font-size:15px;font-weight:700;font-family:var(--display)}.roster-scope .rep-head .rx{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:8px;align-items:center;gap:6px;margin-left:auto;padding:6px 11px;font-size:13px;font-weight:600;display:flex}.roster-scope .rep-head .rx:hover{color:var(--danger);border-color:var(--danger);background:var(--danger-bg)}.roster-scope .rep-body{padding:18px 18px 20px}.roster-scope .add-btn{border:1.5px dashed var(--line);width:100%;color:var(--accent);background:#fff;border-radius:13px;justify-content:center;align-items:center;gap:9px;padding:14px;font-size:14px;font-weight:700;transition:all .15s;display:flex}.roster-scope .add-btn:hover{border-color:var(--accent);background:var(--blue-50)}.roster-scope .form-foot{align-items:center;gap:14px;margin-top:24px;display:flex}.roster-scope .btn{border:none;border-radius:12px;align-items:center;gap:9px;padding:13px 24px;font-size:15px;font-weight:700;text-decoration:none;transition:all .15s;display:inline-flex}.roster-scope .btn:disabled{opacity:.6;cursor:not-allowed}.roster-scope .btn-primary{background:var(--accent);color:#fff;box-shadow:0 10px 22px #1668e042}.roster-scope .btn-primary:hover{background:var(--accent-700)}.roster-scope .btn-ghost{border:1.5px solid var(--line);color:var(--ink-2);background:#fff}.roster-scope .btn-ghost:hover{border-color:var(--muted);color:var(--ink)}.roster-scope .btn-green{background:var(--green);color:#fff;box-shadow:0 10px 22px #1f9d5742}.roster-scope .btn-green:hover{background:var(--green-700)}.roster-scope .foot-spacer{flex:1}.roster-scope .save-note{color:var(--muted);align-items:center;gap:6px;font-size:12.5px;display:flex}.roster-scope .callout{border-radius:12px;gap:12px;margin-bottom:18px;padding:14px 16px;font-size:13.5px;line-height:1.5;display:flex}.roster-scope .callout svg{flex:none;width:19px;height:19px;margin-top:1px}.roster-scope .callout.warn{background:var(--warn-bg);color:#8a560f;border:1px solid #f1dcb8}.roster-scope .callout.info{background:var(--blue-50);color:var(--blue-800);border:1px solid var(--blue-100)}.roster-scope .callout.ok{background:var(--ok-bg);color:var(--green-700);border:1px solid #c7ebd6}.roster-scope .subhead{font-family:var(--display);color:var(--ink);border-bottom:1px dashed var(--line);align-items:center;gap:8px;margin:22px 0 12px;padding-bottom:8px;font-size:14.5px;font-weight:600;display:flex}.roster-scope .subhead:first-child{margin-top:0}.roster-scope .confirm{text-align:center;max-width:680px;margin:0 auto;padding:40px 0 70px}.roster-scope .confirm .seal{background:var(--grad);border-radius:50%;place-items:center;width:96px;height:96px;margin:0 auto 22px;display:grid;box-shadow:0 18px 40px #1f9d5752}.roster-scope .confirm .seal svg{color:#fff;width:48px;height:48px}.roster-scope .confirm h1{margin-bottom:12px;font-size:32px}.roster-scope .confirm p{color:var(--ink-2);max-width:52ch;margin:0 auto 8px;font-size:16px}.roster-scope .ref-box{border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff;border-radius:14px;flex-direction:column;gap:3px;margin:26px 0;padding:18px 30px;display:inline-flex}.roster-scope .ref-box .rl{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-size:12px;font-weight:700}.roster-scope .ref-box .rv{font-family:var(--display);color:var(--accent);letter-spacing:.03em;font-size:26px;font-weight:800}.roster-scope.admin-body{background:var(--bg);min-height:100vh}.roster-scope .admin-top{color:#fff;z-index:40;background:#0c2138;position:sticky;top:0}.roster-scope .admin-top .inner{align-items:center;gap:22px;max-width:1320px;margin:0 auto;padding:13px 26px;display:flex}.roster-scope .admin-top .brand-name{color:#fff;font-size:18px}.roster-scope .admin-top .brand-sub{color:#8fb6e6}.roster-scope .admin-badge{letter-spacing:.05em;text-transform:uppercase;color:#cfe0f5;background:#ffffff1f;border:1px solid #fff3;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700}.roster-scope .admin-nav{gap:6px;margin-left:10px;display:flex}.roster-scope .admin-nav button{color:#bcd0e8;background:0 0;border:none;border-radius:9px;padding:8px 14px;font-size:14.5px;font-weight:600}.roster-scope .admin-nav button:hover{color:#fff;background:#ffffff14}.roster-scope .admin-nav button.active{color:#fff;background:#ffffff24}.roster-scope .admin-user{color:#cfe0f5;align-items:center;gap:11px;margin-left:auto;font-size:13.5px;display:flex}.roster-scope .admin-user .av{background:var(--grad);width:34px;height:34px;font-family:var(--display);color:#fff;border-radius:50%;place-items:center;font-size:13px;font-weight:700;display:grid}.roster-scope .admin-logout{color:#cfe0f5;background:#ffffff14;border:1px solid #ffffff29;border-radius:9px;align-items:center;gap:6px;padding:7px 12px;font-size:13px;font-weight:600;display:inline-flex}.roster-scope .admin-logout:hover{color:#fff;background:#ffffff29}.roster-scope .admin-main{max-width:1320px;margin:0 auto;padding:30px 26px 70px}.roster-scope .admin-h{flex-wrap:wrap;align-items:flex-end;gap:16px;margin-bottom:22px;display:flex}.roster-scope .admin-h h1{font-size:27px;font-weight:700}.roster-scope .admin-h p{color:var(--muted);font-size:14.5px}.roster-scope .admin-h .spacer{flex:1}.roster-scope .stat-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}@media (max-width:1000px){.roster-scope .stat-grid{grid-template-columns:repeat(2,1fr)}}.roster-scope .stat{border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff;border-radius:16px;padding:18px 20px;position:relative;overflow:hidden}.roster-scope .stat .si{border-radius:11px;place-items:center;width:40px;height:40px;margin-bottom:14px;display:grid}.roster-scope .stat .si svg{width:21px;height:21px}.roster-scope .stat .sv{font-family:var(--display);color:var(--ink);font-size:30px;font-weight:800;line-height:1}.roster-scope .stat .sk{color:var(--muted);margin-top:4px;font-size:13px;font-weight:600}.roster-scope .stat .sd{margin-top:7px;font-size:12px;font-weight:700}.roster-scope .si.b{background:var(--blue-50);color:var(--blue)}.roster-scope .si.g{background:var(--green-50);color:var(--green)}.roster-scope .si.o{background:var(--warn-bg);color:var(--warn)}.roster-scope .si.p{color:#7c4fd0;background:#f1ecfb}.roster-scope .chart-grid{grid-template-columns:1.3fr 1fr;gap:16px;margin-bottom:24px;display:grid}@media (max-width:1000px){.roster-scope .chart-grid{grid-template-columns:1fr}}.roster-scope .chart-card{border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff;border-radius:16px;padding:20px 22px}.roster-scope .chart-card h3{margin-bottom:3px;font-size:15px;font-weight:700}.roster-scope .chart-card .csub{color:var(--muted);margin-bottom:18px;font-size:12.5px}.roster-scope .hbar{flex-direction:column;gap:13px;display:flex}.roster-scope .hbar .row2{grid-template-columns:160px 1fr 42px;align-items:center;gap:12px;display:grid}.roster-scope .hbar .row2 .lab{color:var(--ink-2);text-align:right;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.roster-scope .hbar .track{background:var(--line-2);border-radius:999px;height:13px;overflow:hidden}.roster-scope .hbar .track>i{background:var(--grad);border-radius:999px;height:100%;display:block}.roster-scope .hbar .num{color:var(--ink);font-size:13px;font-weight:700;font-family:var(--display)}@media (max-width:520px){.roster-scope .hbar .row2{grid-template-columns:96px 1fr 34px}}.roster-scope .donut-wrap{align-items:center;gap:22px;display:flex}.roster-scope .legend{flex-direction:column;flex:1;gap:10px;display:flex}.roster-scope .legend .li{color:var(--ink-2);align-items:center;gap:9px;font-size:13.5px;display:flex}.roster-scope .legend .li .sw{border-radius:4px;flex:none;width:12px;height:12px}.roster-scope .legend .li .lv{font-weight:700;font-family:var(--display);color:var(--ink);margin-left:auto}.roster-scope .tbl-card{border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff;border-radius:16px;overflow:hidden}.roster-scope .tbl-tools{border-bottom:1px solid var(--line-2);flex-wrap:wrap;align-items:center;gap:12px;padding:16px 18px;display:flex}.roster-scope .search{flex:1;min-width:200px;position:relative}.roster-scope .search svg{width:17px;height:17px;color:var(--faint);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.roster-scope .search input{border:1.5px solid var(--line);border-radius:10px;width:100%;padding:10px 12px 10px 36px;font-size:14px}.roster-scope .search input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #1668e01f}.roster-scope .fbtns{flex-wrap:wrap;gap:7px;display:flex}.roster-scope .chip{border:1.5px solid var(--line);color:var(--ink-2);background:#fff;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600}.roster-scope .chip:hover{border-color:var(--accent);color:var(--accent)}.roster-scope .chip.on{background:var(--accent);border-color:var(--accent);color:#fff}.roster-scope table.tbl{border-collapse:collapse;width:100%}.roster-scope table.tbl th{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);text-align:left;border-bottom:1px solid var(--line);background:#fbfcfe;padding:13px 18px;font-size:11.5px;font-weight:700}.roster-scope table.tbl td{border-bottom:1px solid var(--line-2);color:var(--ink-2);vertical-align:middle;padding:14px 18px;font-size:14px}.roster-scope table.tbl tr{cursor:pointer}.roster-scope table.tbl tbody tr:hover{background:var(--blue-50)}.roster-scope .cand-name{align-items:center;gap:12px;display:flex}.roster-scope .cand-name .av{width:38px;height:38px;font-family:var(--display);color:#fff;border-radius:50%;flex:none;place-items:center;font-size:13.5px;font-weight:700;display:grid}.roster-scope .cand-name .n{color:var(--ink);font-size:14px;font-weight:700}.roster-scope .cand-name .e{color:var(--muted);font-size:12px}.roster-scope .score-pill{font-family:var(--display);align-items:center;gap:7px;font-size:15px;font-weight:800;display:inline-flex}.roster-scope .score-pill .ring{color:#fff;border-radius:50%;place-items:center;width:34px;height:34px;font-size:11.5px;display:grid}.roster-scope .badge{white-space:nowrap;border-radius:999px;align-items:center;gap:6px;padding:5px 11px;font-size:12px;font-weight:700;display:inline-flex}.roster-scope .badge .bd{border-radius:50%;width:7px;height:7px}.roster-scope .badge.s-nouveau{background:var(--blue-50);color:var(--blue-800)}.roster-scope .badge.s-nouveau .bd{background:var(--blue)}.roster-scope .badge.s-encours{background:var(--warn-bg);color:#8a560f}.roster-scope .badge.s-encours .bd{background:var(--warn)}.roster-scope .badge.s-evalue{color:#5b35a8;background:#f1ecfb}.roster-scope .badge.s-evalue .bd{background:#7c4fd0}.roster-scope .badge.s-retenu{background:var(--ok-bg);color:var(--green-700)}.roster-scope .badge.s-retenu .bd{background:var(--green)}.roster-scope .badge.s-rejete{background:var(--danger-bg);color:#a82e2e}.roster-scope .badge.s-rejete .bd{background:var(--danger)}.roster-scope .detail-grid{grid-template-columns:1fr 360px;align-items:start;gap:22px;display:grid}@media (max-width:1080px){.roster-scope .detail-grid{grid-template-columns:1fr}}.roster-scope .back-link{color:var(--muted);background:0 0;border:none;align-items:center;gap:7px;margin-bottom:14px;font-size:14px;font-weight:600;display:inline-flex}.roster-scope .back-link:hover{color:var(--ink)}.roster-scope .dcard{border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff;border-radius:16px;margin-bottom:18px;overflow:hidden}.roster-scope .dcard-h{border-bottom:1px solid var(--line-2);background:linear-gradient(#fbfdff,#fff);align-items:center;gap:10px;padding:16px 20px;display:flex}.roster-scope .dcard-h h3{align-items:center;gap:9px;font-size:15px;font-weight:700;display:flex}.roster-scope .dcard-b{padding:18px 20px}.roster-scope .kv{grid-template-columns:1fr 1fr;gap:14px 22px;display:grid}@media (max-width:560px){.roster-scope .kv{grid-template-columns:1fr}}.roster-scope .kv .k{text-transform:uppercase;letter-spacing:.03em;color:var(--muted);margin-bottom:3px;font-size:11.5px;font-weight:700}.roster-scope .kv .v{color:var(--ink);font-size:14px;font-weight:600}.roster-scope .kv .v.empty{color:var(--faint);font-style:italic;font-weight:500}.roster-scope .kv .full{grid-column:1/-1}.roster-scope .taglist{flex-wrap:wrap;gap:7px;display:flex}.roster-scope .taglist .tg{background:var(--blue-50);color:var(--blue-800);border-radius:7px;padding:4px 10px;font-size:12.5px;font-weight:600}.roster-scope .mini-rate{gap:4px;display:flex}.roster-scope .mini-rate .d{background:var(--line);border-radius:3px;width:22px;height:7px}.roster-scope .mini-rate .d.on{background:var(--accent)}.roster-scope .eval-panel{position:sticky;top:88px}.roster-scope .eval-card{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:16px;overflow:hidden}.roster-scope .eval-head{background:var(--grad);color:#fff;padding:18px 20px}.roster-scope .eval-head h3{color:#fff;font-size:17px}.roster-scope .eval-head p{color:#ffffffd9;margin-top:3px;font-size:12.5px}.roster-scope .eval-total{align-items:baseline;gap:6px;margin-top:12px;display:flex}.roster-scope .eval-total .tv{font-family:var(--display);font-size:40px;font-weight:800;line-height:1}.roster-scope .eval-total .tm{opacity:.85;font-size:16px;font-weight:600}.roster-scope .eval-total .tlevel{background:#ffffff2e;border:1px solid #ffffff4d;border-radius:999px;align-self:center;margin-left:auto;padding:5px 11px;font-size:12.5px;font-weight:700}.roster-scope .eval-body{padding:8px 20px 20px}.roster-scope .crit{border-bottom:1px solid var(--line-2);padding:14px 0}.roster-scope .crit:last-child{border-bottom:none}.roster-scope .crit .ch{color:var(--ink);justify-content:space-between;align-items:center;margin-bottom:4px;font-size:13.5px;font-weight:700;display:flex}.roster-scope .crit .ch .cm{font-family:var(--display);color:var(--accent);font-weight:800}.roster-scope .subcrit{align-items:center;gap:10px;padding:7px 0;display:flex}.roster-scope .subcrit .sl{color:var(--ink-2);flex:1;font-size:12.5px}.roster-scope .subcrit .smax{color:var(--faint);font-size:11px;font-weight:600}.roster-scope .subcrit input[type=number]{border:1.5px solid var(--line);text-align:center;width:54px;color:var(--ink);font-size:13px;font-weight:700;font-family:var(--display);border-radius:8px;padding:6px 8px}.roster-scope .subcrit input:focus{border-color:var(--accent);outline:none}.roster-scope .elim-row{color:var(--ink-2);border-bottom:1px solid var(--line-2);align-items:center;gap:10px;padding:9px 0;font-size:13px;display:flex}.roster-scope .elim-row:last-child{border-bottom:none}.roster-scope .elim-row .seg{gap:5px;margin-left:auto;display:flex}.roster-scope .elim-row .seg button{border:1.5px solid var(--line);color:var(--muted);background:#fff;border-radius:8px;padding:5px 11px;font-size:12px;font-weight:700}.roster-scope .elim-row .seg button.yes.on{background:var(--green);border-color:var(--green);color:#fff}.roster-scope .elim-row .seg button.no.on{background:var(--danger);border-color:var(--danger);color:#fff}.roster-scope .classif{flex-direction:column;gap:8px;margin-top:6px;display:flex}.roster-scope .roster-login{background:radial-gradient(1200px 600px at 50% -10%,#11355f,#0c2138 60%);place-items:center;min-height:100vh;padding:24px;display:grid}.roster-scope .roster-login-card{width:100%;max-width:412px;box-shadow:var(--shadow-lg);background:#fff;border-radius:20px;padding:34px 32px}.roster-scope .roster-login-card .brand{justify-content:center;margin-bottom:20px}.roster-scope .roster-login-card h1{text-align:center;margin-bottom:6px;font-size:22px}.roster-scope .roster-login-card .sub{text-align:center;color:var(--muted);margin-bottom:22px;font-size:13.5px}.roster-scope .roster-login-card .field{margin-bottom:14px}.roster-scope .login-err{background:var(--danger-bg);color:#a82e2e;border:1px solid #f3c9c9;border-radius:10px;margin-bottom:14px;padding:11px 13px;font-size:13px;font-weight:600}.roster-scope .muted{color:var(--muted)}.roster-scope .small{font-size:13px}.roster-scope .flex{align-items:center;display:flex}.roster-scope .gap8{gap:8px}.roster-scope .gap12{gap:12px}.roster-scope .mt0{margin-top:0}.roster-scope .mb0{margin-bottom:0}.roster-scope .spin{animation:1s linear infinite roster-spin}.roster-scope .fade-in{animation:.3s roster-fade}@keyframes roster-spin{to{transform:rotate(360deg)}}@keyframes roster-fade{0%{opacity:.4;transform:translateY(6px)}to{opacity:1;transform:none}}@media print{.roster-scope .admin-top,.roster-scope .eval-panel .btn,.roster-scope .no-print{display:none!important}.roster-scope .admin-main,.roster-scope .detail-grid{max-width:none;padding:0;display:block}.roster-scope .dcard{break-inside:avoid;box-shadow:none}.roster-scope.admin-body{background:#fff}}
