:root{color-scheme:light;--spsul-primary: #010b0f;--spsul-secondary: #fffaf5;--spsul-accent: #de401a;--spsul-accent-dark: #b83314;--spsul-text: #1b0f02;--spsul-text-muted: color-mix(in srgb, var(--spsul-text) 62%, white);--spsul-surface-alt: #fcfcfd;--brand-blue: var(--spsul-accent);--brand-blue-dark: var(--spsul-accent-dark);--brand-blue-soft: color-mix(in srgb, var(--spsul-accent) 10%, var(--spsul-secondary));--ink: var(--spsul-text);--ink-muted: var(--spsul-text-muted);--surface: var(--spsul-secondary);--surface-elevated: #ffffff;--line: color-mix(in srgb, var(--spsul-text) 14%, white);--danger: #b42318;--success: #067647;--shadow: 0 18px 40px color-mix(in srgb, var(--spsul-primary) 10%, transparent);--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--font-display: "Roboto", sans-serif;--font-body: "Roboto", sans-serif}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:var(--font-body);color:var(--ink);background:radial-gradient(circle at 12% 0%,color-mix(in srgb,var(--spsul-accent) 8%,var(--spsul-secondary)),transparent 44%),linear-gradient(180deg,var(--spsul-secondary) 0%,var(--spsul-surface-alt) 100%)}h1,h2,h3{margin:0;font-family:var(--font-display);letter-spacing:-.02em}p{margin:0}a{color:inherit}button,input,select,textarea{font:inherit}.page-shell{width:min(1120px,calc(100% - 2rem));margin:0 auto;padding:clamp(1.25rem,2vw,2.5rem) 0 3rem}.page-shell--register{display:grid;gap:1.5rem}.page-shell--setup{display:grid;gap:1.25rem}.site-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.site-header__brand{display:grid;gap:.25rem}.site-header__year{font-size:.85rem;font-weight:600;color:var(--spsul-accent);text-transform:uppercase;letter-spacing:.08em}.site-header__school{font-family:var(--font-display);font-weight:600;color:var(--ink-muted)}.site-header__actions{display:flex;align-items:center;gap:.75rem}.site-footer{padding-top:1rem;color:var(--ink-muted);font-size:.92rem}.register-layout{display:grid;grid-template-columns:minmax(240px,.9fr) minmax(0,1.4fr);gap:clamp(1rem,3vw,2rem);align-items:start}.register-intro{position:sticky;top:1.5rem;padding:clamp(1.25rem,2vw,2rem);border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(160deg,var(--surface-elevated),var(--spsul-secondary));box-shadow:var(--shadow)}.step-indicator{list-style:none;margin:1.1rem 0 0;padding:0;display:grid;gap:.55rem}.step-indicator li{display:flex;align-items:center;gap:.55rem;font-size:.9rem;color:var(--ink-muted);font-weight:500}.step-indicator li span{width:1.5rem;height:1.5rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;border:1px solid var(--line);background:#fff}.step-indicator li.is-active{color:var(--ink);font-weight:600}.step-indicator li.is-active span{background:var(--spsul-accent);border-color:var(--spsul-accent);color:#fff}.step-indicator li.is-done span{background:var(--spsul-primary);border-color:var(--spsul-primary);color:#fff}.selection-summary{border:1px solid var(--line);border-radius:var(--radius-md);padding:1rem;background:color-mix(in srgb,var(--spsul-secondary) 70%,white);display:grid;gap:.75rem}.selection-summary__list{margin:0;display:grid;gap:.55rem}.selection-summary__list div{display:grid;gap:.15rem}.selection-summary__list dt{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted);font-weight:600}.selection-summary__list dd{margin:0;font-weight:600}.verify-step{padding-top:.25rem;border-top:1px dashed var(--line)}.form-actions{display:flex;flex-wrap:wrap;gap:.65rem}.register-intro h1{margin-top:.35rem;font-size:clamp(1.8rem,3vw,2.6rem);line-height:1.08}.register-intro__description{margin-top:.85rem;color:var(--ink-muted);line-height:1.6}.register-form,.setup-form,.setup-panel,.setup-login,.success-panel,.loader-panel,.error-panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface-elevated);box-shadow:var(--shadow)}.register-form,.setup-form,.setup-panel,.setup-login,.success-panel{padding:clamp(1.1rem,2vw,1.75rem)}.register-form{display:grid;gap:1.25rem}.eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--spsul-accent)}.field-block,.autocomplete{display:grid;gap:.45rem;position:relative}.field-label{font-size:.92rem;font-weight:600}.field-input{width:100%;border:1px solid var(--line);border-radius:var(--radius-sm);padding:.72rem .85rem;background:#fff;color:var(--ink);transition:border-color .16s ease,box-shadow .16s ease}.field-input:focus-visible,.button:focus-visible,.ghost-link:focus-visible,.group-card:focus-visible,.setup-tabs button:focus-visible{outline:2px solid color-mix(in srgb,var(--spsul-accent) 70%,white);outline-offset:2px}.field-input--textarea{resize:vertical;min-height:96px}.field-hint,.field-status{font-size:.86rem;color:var(--ink-muted)}.field-status--warn{color:#9a3412}.autocomplete-list{position:absolute;top:calc(100% + .35rem);left:0;right:0;z-index:20;margin:0;padding:.35rem;list-style:none;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;box-shadow:var(--shadow);max-height:240px;overflow:auto}.autocomplete-item{width:100%;border:0;background:transparent;text-align:left;padding:.65rem .75rem;border-radius:8px;cursor:pointer}.autocomplete-item:hover,.autocomplete-item.is-active{background:color-mix(in srgb,var(--spsul-accent) 10%,white)}.group-fieldset{border:0;margin:0;padding:0;display:grid;gap:.75rem}.group-fieldset legend{font-weight:600;margin-bottom:.15rem}.group-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.group-card{border:1px solid var(--line);border-radius:var(--radius-md);background:#fff;padding:.95rem;text-align:left;cursor:pointer;display:grid;gap:.55rem;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.group-card:hover:not(.is-disabled){transform:translateY(-1px);border-color:color-mix(in srgb,var(--spsul-accent) 45%,white)}.group-card:active:not(.is-disabled){transform:translateY(1px) scale(.99)}.group-card.is-selected{border-color:var(--spsul-accent);box-shadow:inset 0 0 0 1px var(--spsul-accent)}.group-card.is-disabled{opacity:.62;cursor:not-allowed}.group-card__head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.group-card__head h3{font-size:1rem}.group-card__description{color:var(--ink-muted);font-size:.9rem;line-height:1.45;min-height:2.6em}.badge{font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;border-radius:999px;padding:.2rem .55rem}.badge--full{background:color-mix(in oklch,var(--danger) 12%,white);color:var(--danger)}.capacity-meter{display:grid;gap:.35rem}.capacity-meter__track{height:8px;border-radius:999px;background:#e7edf5;overflow:hidden}.capacity-meter__fill{height:100%;border-radius:inherit;transition:width .32s ease}.capacity-meter__fill--ok{background:linear-gradient(90deg,color-mix(in srgb,var(--spsul-accent) 70%,white),var(--spsul-accent))}.capacity-meter__fill--warn{background:linear-gradient(90deg,#f59e0b,#ea580c)}.capacity-meter__fill--full{background:linear-gradient(90deg,#ef4444,var(--danger))}.capacity-meter__label{display:flex;gap:.2rem;font-size:.84rem;color:var(--ink-muted);font-variant-numeric:tabular-nums}.button{border:0;border-radius:var(--radius-sm);padding:.72rem 1rem;font-weight:600;cursor:pointer;transition:transform .12s cubic-bezier(.22,1,.36,1),background-color .16s ease,box-shadow .16s ease,border-color .16s ease,color .16s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.button--compact{padding:.45rem .7rem;font-size:.88rem}.button--primary{background:var(--spsul-accent);color:#fff;box-shadow:0 2px color-mix(in srgb,var(--spsul-accent-dark) 80%,black)}.button--primary:hover:not(:disabled){background:var(--spsul-accent-dark)}.button--primary:active:not(:disabled){transform:translateY(2px) scale(.98);box-shadow:0 0 color-mix(in srgb,var(--spsul-accent-dark) 80%,black)}.button--secondary{background:var(--brand-blue-soft);color:var(--spsul-accent-dark);border:1px solid color-mix(in srgb,var(--spsul-accent) 22%,white);box-shadow:0 2px color-mix(in srgb,var(--spsul-accent) 12%,white)}.button--secondary:hover:not(:disabled){background:color-mix(in srgb,var(--spsul-accent) 16%,white)}.button--secondary:active:not(:disabled){transform:translateY(2px) scale(.98);box-shadow:none}.button--danger{background:color-mix(in srgb,var(--danger) 12%,white);color:var(--danger);border:1px solid color-mix(in srgb,var(--danger) 22%,white);box-shadow:0 2px color-mix(in srgb,var(--danger) 10%,white)}.button--danger:hover:not(:disabled){background:color-mix(in srgb,var(--danger) 18%,white)}.button--danger:active:not(:disabled){transform:translateY(2px) scale(.98);box-shadow:none}.button--ghost,.ghost-link{background:transparent;color:var(--spsul-accent-dark);text-decoration:none;font-weight:600;border:1px solid transparent;box-shadow:none}.button--ghost:hover:not(:disabled),.ghost-link:hover{background:color-mix(in srgb,var(--spsul-accent) 8%,white);border-color:color-mix(in srgb,var(--spsul-accent) 18%,white)}.button--ghost:active:not(:disabled){transform:scale(.98);background:color-mix(in srgb,var(--spsul-accent) 14%,white)}.button:disabled{opacity:.65;cursor:not-allowed}.alert{border-radius:var(--radius-sm);padding:.75rem .9rem;font-size:.94rem}.alert--error{background:color-mix(in oklch,var(--danger) 10%,white);color:var(--danger);border:1px solid color-mix(in oklch,var(--danger) 25%,white)}.alert--success{background:color-mix(in oklch,var(--success) 10%,white);color:var(--success);border:1px solid color-mix(in oklch,var(--success) 25%,white)}.success-panel h1{margin-top:.35rem;font-size:clamp(2rem,4vw,2.8rem)}.success-panel__message{margin-top:.85rem;font-size:1.05rem}.success-panel__note{margin-top:.65rem;color:var(--ink-muted)}.loader-panel,.error-panel{padding:2rem;text-align:center}.register-closed{display:grid}.closed-panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(160deg,var(--surface-elevated),var(--spsul-secondary));box-shadow:var(--shadow);padding:clamp(1.5rem,3vw,2.75rem);text-align:center;display:grid;gap:.5rem;justify-items:center}.closed-panel h1{margin-top:.35rem;font-size:clamp(1.7rem,3vw,2.4rem);line-height:1.1}.closed-panel__lead{margin-top:.5rem;max-width:46ch;color:var(--ink-muted);line-height:1.6}.closed-panel__lead strong{color:var(--ink)}.countdown{margin-top:1.5rem;display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(.5rem,2vw,1rem)}.countdown__unit{min-width:clamp(4rem,14vw,5.5rem);padding:.85rem .5rem;border:1px solid color-mix(in srgb,var(--spsul-accent) 22%,white);border-radius:var(--radius-md);background:#fff;display:grid;gap:.3rem;box-shadow:0 2px color-mix(in srgb,var(--spsul-accent) 10%,white)}.countdown__value{font-family:var(--font-display);font-weight:700;font-size:clamp(1.8rem,5vw,2.6rem);line-height:1;color:var(--spsul-accent);font-variant-numeric:tabular-nums}.countdown__label{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted)}.setup-title{font-size:clamp(1.5rem,2.4vw,2rem)}.setup-tabs{display:flex;flex-wrap:wrap;gap:.5rem}.setup-tabs button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:.55rem .95rem;cursor:pointer;font-weight:600;color:var(--ink-muted);transition:transform .12s cubic-bezier(.22,1,.36,1),background-color .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease;box-shadow:0 2px color-mix(in srgb,var(--spsul-text) 6%,white)}.setup-tabs button:hover:not(.is-active){border-color:color-mix(in srgb,var(--spsul-accent) 30%,white);color:var(--ink)}.setup-tabs button:active:not(.is-active){transform:translateY(2px) scale(.98);box-shadow:none}.setup-tabs button.is-active{background:var(--spsul-accent);border-color:var(--spsul-accent);color:#fff;box-shadow:0 2px 0 var(--spsul-accent-dark)}.setup-tabs button.is-active:active{transform:translateY(2px) scale(.98);box-shadow:none}.setup-panel h2,.setup-form h3,.students-toolbar h2{margin-bottom:.85rem}.setup-form{display:grid;gap:.75rem}.setup-form--inline{margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--line)}.setup-login{width:min(460px,100%);margin:4rem auto 0;display:grid;gap:1rem}.setup-login__form{display:grid;gap:.75rem}.group-admin-list{display:grid;gap:.85rem}.group-admin-card{border:1px solid var(--line);border-radius:var(--radius-md);padding:.9rem;background:#fff;display:grid;gap:.75rem}.group-admin-card__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem}.group-admin-card__grid label{display:grid;gap:.35rem;font-size:.86rem;font-weight:600}.group-admin-card__description{grid-column:1 / -1}.group-admin-card__meta{display:flex;align-items:center;justify-content:space-between;gap:.75rem;color:var(--ink-muted);font-size:.9rem}.filter-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.65rem;margin-bottom:.85rem}.filter-grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}.filter-summary{margin:0 0 .85rem;color:var(--ink-muted);font-size:.9rem}.students-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1.25rem}.students-toolbar h2{margin-bottom:0}.students-toolbar__actions{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;background:color-mix(in srgb,var(--ink) 55%,transparent)}.modal-dialog{width:min(100%,640px);max-height:calc(100vh - 2rem);overflow:auto;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface-elevated);box-shadow:var(--shadow);padding:clamp(1.1rem,2vw,1.75rem)}.modal-dialog__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.modal-dialog__header h3{margin:0}.modal-dialog__close{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;color:var(--ink-muted);font-size:1.35rem;line-height:1;cursor:pointer}.modal-dialog__close:hover{color:var(--ink);background:var(--brand-blue-soft)}.modal-dialog .setup-form{border:none;box-shadow:none;padding:0}.modal-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem;margin-bottom:1rem}.modal-form-grid__full{grid-column:1 / -1}body.modal-open{overflow:hidden}.import-group{position:relative;display:inline-flex;align-items:center;gap:.35rem}.import-help__trigger{display:inline-flex;align-items:center;justify-content:center;width:2.35rem;height:2.35rem;border-radius:50%;border:1px solid color-mix(in srgb,var(--spsul-accent) 22%,white);background:#fff;color:var(--spsul-accent-dark);font-size:.95rem;font-weight:700;line-height:1;cursor:pointer;box-shadow:0 2px color-mix(in srgb,var(--spsul-accent) 12%,white);transition:transform .12s cubic-bezier(.22,1,.36,1),background-color .16s ease,box-shadow .16s ease}.import-help__trigger:hover{background:var(--brand-blue-soft)}.import-help__trigger:active{transform:translateY(2px) scale(.98);box-shadow:none}.import-help__popover{position:absolute;top:calc(100% + .45rem);right:0;z-index:20;width:min(22rem,calc(100vw - 2rem));padding:.75rem .85rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-elevated);box-shadow:var(--shadow);color:var(--ink-muted);font-size:.86rem;line-height:1.5}.import-button{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);padding:.65rem .95rem;background:var(--brand-blue-soft);color:var(--spsul-accent-dark);font-weight:600;cursor:pointer;border:1px solid color-mix(in srgb,var(--spsul-accent) 22%,white);box-shadow:0 2px color-mix(in srgb,var(--spsul-accent) 12%,white);transition:transform .12s cubic-bezier(.22,1,.36,1),background-color .16s ease,box-shadow .16s ease;-webkit-user-select:none;user-select:none}.import-button:hover{background:color-mix(in srgb,var(--spsul-accent) 16%,white)}.import-button:active{transform:translateY(2px) scale(.98);box-shadow:none}.inline-actions{display:flex;flex-wrap:wrap;gap:.45rem}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--radius-md)}.data-table{width:100%;border-collapse:collapse;min-width:720px;background:#fff}.data-table th,.data-table td{padding:.72rem .8rem;border-bottom:1px solid var(--line);text-align:left;font-size:.92rem}.data-table th{background:#f8fafc;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted)}.reveal{animation:reveal-up .56s cubic-bezier(.22,1,.36,1) both}.reveal--delay-1{animation-delay:90ms}.reveal--delay-2{animation-delay:.17s}@keyframes reveal-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media(max-width:960px){.register-layout{grid-template-columns:1fr}.register-intro{position:static}.group-grid,.group-admin-card__grid,.filter-grid{grid-template-columns:1fr 1fr}}@media(max-width:640px){.page-shell{width:min(100% - 1.25rem,1120px)}.site-header{flex-direction:column}.group-grid,.group-admin-card__grid,.filter-grid{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important}}
