:root{--msu-blue:#0a2472;--msu-blue-dark:#061a52;--msu-blue-mid:#1a3a8f;--msu-accent:#2563eb;--msu-blue-light:#e8eef9;--text:#1e293b;--text-muted:#51607a;--bg-from:#f4f7fc;--bg-to:#e8eef9;--border:#cbd6e8;--danger:#c0392b;--success:#1a8a52;--font-heading:"Manrope", "Golos Text", "Inter", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;font:16px/150% var(--font-body);color:var(--text);-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0}#root{min-height:100svh}h1,h2{font-family:var(--font-heading);color:var(--msu-blue);margin:0 0 8px;font-weight:700}h1{letter-spacing:-.2px;font-size:clamp(26px,3.4vw,36px)}h2{font-size:20px}p{margin:0}button{font-family:var(--font-body)}.page{background:linear-gradient(160deg, var(--bg-from), var(--bg-to));min-height:100svh}.shell{flex-direction:column;min-height:100svh;display:flex}.brand-col{background:radial-gradient(circle at 100% 0%, #2563eb59, transparent 55%), radial-gradient(circle at 0% 100%, #ffffff14, transparent 45%), linear-gradient(160deg, var(--msu-blue-mid) 0%, var(--msu-blue) 55%, var(--msu-blue-dark) 100%);color:#fff;align-items:center;display:flex}.brand-col-inner{width:100%;padding:clamp(28px,6vw,48px) clamp(20px,6vw,56px)}.brand-col h1{color:#fff;font-size:clamp(24px,4vw,32px);line-height:124%}.brand-subtitle{color:#ffffffd1;margin-bottom:24px;font-size:17px}.event-info{flex-direction:column;gap:14px;margin-top:8px;display:flex}.event-info-row{align-items:flex-start;gap:12px;display:flex}.event-info-icon{color:#fff;box-sizing:border-box;background:#ffffff24;border-radius:8px;flex-shrink:0;width:30px;height:30px;margin-top:2px;padding:6px}.event-info-label{text-transform:uppercase;letter-spacing:.05em;color:#ffffffa6;margin-bottom:2px;font-size:12px}.event-info-value{color:#fff;font-size:16px;font-weight:500}.form-col{flex:1;justify-content:center;align-items:center;display:flex}.form-col-inner{flex-direction:column;align-items:center;width:100%;padding:clamp(24px,6vw,48px) clamp(20px,4vw,40px);display:flex}.card{background:#fff;border-radius:16px;width:100%;max-width:440px;padding:clamp(32px,4vw,40px);box-shadow:0 24px 60px #00000073,0 4px 16px #00000040}.step{flex-direction:column;gap:18px;display:flex}.step h2{margin-bottom:0}.step label{color:var(--text-muted);flex-direction:column;gap:16px;font-size:14px;font-weight:500;display:flex}.step input[type=text]{font-size:16px;font-family:var(--font-body);border:1.5px solid var(--border);color:var(--text);border-radius:10px;width:100%;height:48px;padding:13px 14px;transition:border-color .15s,box-shadow .15s}.step input[type=text]:focus{border-color:var(--msu-accent);outline:none;box-shadow:0 0 0 4px #2563eb26}.consent-label{color:var(--text);align-items:flex-start;font-size:15px;font-weight:400;flex-direction:row!important}.consent-label input[type=checkbox]{width:22px;height:22px;accent-color:var(--msu-accent);flex-shrink:0;margin:0 10px 0 0}.status-text{align-items:center;gap:8px;margin:0;font-size:14px;font-weight:500;display:flex}.status-found{color:var(--success)}.status-missing{color:var(--danger)}.student-confirmed{background:var(--msu-blue-light);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;font-size:15px;display:flex}.student-confirmed button{border:1.5px solid var(--msu-accent);color:var(--msu-accent);cursor:pointer;background:#fff;border-radius:8px;flex-shrink:0;padding:7px 14px;font-weight:500}.student-confirmed button:hover{background:var(--msu-blue-light)}.duplicate-picker{flex-direction:column;gap:10px;display:flex}.duplicate-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.duplicate-list button{text-align:left;width:100%;color:var(--text);border:1.5px solid var(--border);cursor:pointer;background:#fff;border-radius:10px;padding:12px 14px;font-size:15px;font-weight:500;transition:border-color .15s,background .15s}.duplicate-list button:hover{border-color:var(--msu-accent);background:var(--msu-blue-light)}.error-text{color:var(--danger);font-size:14px;font-weight:500}.step-nav{justify-content:flex-end;gap:12px;margin-top:20px;display:flex}.step-nav .btn:only-child{width:100%}.btn{font-size:15px;font-weight:600;font-family:var(--font-body);cursor:pointer;border:1.5px solid #0000;border-radius:10px;min-height:48px;padding:13px 24px;transition:background-color .15s,border-color .15s,transform 50ms,box-shadow .15s}.btn-primary{color:#fff;background:#1a3a8f;border-color:#1a3a8f;font-weight:600;box-shadow:0 8px 20px #1a3a8f40}.btn-primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.btn-primary:active:not(:disabled){transform:translateY(1px);box-shadow:0 4px 10px #2563eb40}.btn-primary:focus-visible{outline:none;box-shadow:0 0 0 4px #2563eb4d}.btn-primary:disabled{color:#94a3b8;box-shadow:none;cursor:not-allowed;background:#cbd6e8;border-color:#cbd6e8}.btn-secondary{border-color:var(--border);color:var(--text);background:#fff}.btn-secondary:hover:not(:disabled){border-color:var(--msu-accent);color:var(--msu-accent)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.qr-code{border:1px solid var(--border);background:#fff;border-radius:10px;width:min(260px,80%);margin:8px auto;padding:10px;display:block}.event-summary-mobile{color:#ffffffd1;margin-top:6px;font-size:13px;display:none}.event-footer-mobile{display:none}@media (width>=1024px){.shell{flex-direction:row}.brand-col{width:45%}.form-col{width:55%}}@media (width<=1023px){.brand-col-inner{padding:clamp(14px,4vw,20px) clamp(16px,5vw,24px)}.brand-col h1{margin-bottom:4px;font-size:clamp(19px,5.5vw,23px)}.brand-subtitle{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:0;font-size:14px;display:-webkit-box;overflow:hidden}.brand-col .event-info{display:none}.event-summary-mobile{display:block}.form-col{justify-content:flex-start;align-items:stretch}.form-col-inner{align-items:stretch;padding:clamp(16px,5vw,24px)}.page .card{max-width:100%;box-shadow:none;border-radius:0;padding:clamp(20px,5vw,28px)}.event-footer-mobile{border-top:1px solid var(--border);background:#fff;padding:clamp(20px,5vw,28px);display:block}.event-footer-mobile .event-info-icon{color:var(--msu-blue);background:var(--msu-blue-light)}.event-footer-mobile .event-info-label{color:var(--text-muted)}.event-footer-mobile .event-info-value{color:var(--text)}}@media (width<=380px){.brand-col-inner{padding:12px 14px}.form-col-inner{padding:14px}.page .card,.event-footer-mobile{padding:16px 14px}}.app-root{position:fixed;inset:0;overflow:hidden}.screen{will-change:transform, opacity;transition:transform .52s cubic-bezier(.65,0,.35,1),opacity .48s ease-in-out;position:absolute;inset:0}.screen--intro[data-active=true]{opacity:1;pointer-events:auto;transform:translate(0)}.screen--intro[data-active=false]{opacity:0;pointer-events:none;transform:translate(-100%)}.screen--form[data-active=true]{opacity:1;pointer-events:auto;transform:translate(0)}.screen--form[data-active=false]{opacity:0;pointer-events:none;transform:translate(100%)}@media (prefers-reduced-motion:reduce){.screen{transition:opacity .15s}.screen--intro[data-active=false],.screen--form[data-active=false]{transform:none}}.intro-screen{background-color:#030916;background-image:url(/hero-bg.jpg);background-position:50%;background-repeat:no-repeat;background-size:cover;justify-content:center;align-items:flex-start;width:100%;height:100dvh;display:flex;position:relative;overflow:hidden auto}.intro-scrim{z-index:0;pointer-events:none;background:linear-gradient(90deg,#060c1ee6 0%,#060c1ea6 36%,#060c1e2e 60%,#0000 78%);position:absolute;inset:0}.intro-mobile-overlay{z-index:0;pointer-events:none;background:#040a18bd;display:none;position:absolute;inset:0}.intro-content{z-index:1;flex-direction:column;gap:clamp(18px,2.8vh,28px);width:100%;max-width:520px;margin:0 auto;padding:clamp(16px,2.5vh,28px) clamp(24px,5vw,48px) clamp(28px,5vh,52px);display:flex;position:relative}.intro-content .event-info{margin-top:clamp(24px,5vh,56px)}.intro-heading-group{flex-direction:column;gap:clamp(10px,1.4vh,16px);display:flex}.intro-heading{font-family:var(--font-heading);color:#fff;letter-spacing:-.5px;text-shadow:0 1px 14px #040a18f2,0 3px 40px #040a18bf;margin:0;font-size:clamp(26px,4.8vw,52px);font-weight:700;line-height:1.16}.intro-subtitle{font-family:var(--font-body);color:#c7d4e8;max-width:56ch;margin:0;font-size:clamp(14px,1.6vw,16px);font-weight:400;line-height:1.55}.intro-content .event-info-label{color:#8cb9e6d9}.intro-content .event-info{gap:clamp(10px,1.8vh,14px);margin-top:0}.intro-bottom{flex-direction:column;flex-shrink:0;align-items:flex-start;gap:14px;display:flex}.intro-cta{color:#0a2472;font-family:var(--font-body);cursor:pointer;background:#fff;border:none;border-radius:12px;align-items:center;gap:10px;min-height:52px;padding:clamp(13px,2vh,16px) clamp(22px,3vw,32px);font-size:clamp(15px,1.8vw,17px);font-weight:600;transition:background .15s,box-shadow .15s,transform .1s;display:inline-flex;box-shadow:0 8px 28px #00000038}.intro-cta:hover{background:#f0f5ff;box-shadow:0 12px 36px #00000047}.intro-cta:active{transform:translateY(1px);box-shadow:0 5px 16px #00000038}.intro-cta:focus-visible{outline-offset:3px;outline:3px solid #ffffffa6}.intro-swipe-hint{color:#fff6;margin:0;font-size:13px;display:none}@media (hover:none) and (pointer:coarse){.intro-swipe-hint{display:block}}@media (width<=767px){.intro-screen{background-position:30%;align-items:flex-end}.form-screen{background-position:30%}.intro-mobile-overlay{display:block}.intro-scrim{display:none}.intro-content{gap:clamp(16px,2.5vh,24px);max-width:100%;padding:clamp(20px,4vh,36px) clamp(20px,5vw,28px) clamp(32px,6vh,52px)}.intro-heading{font-size:clamp(22px,6.5vw,32px)}.intro-subtitle{font-size:14px}.intro-content .event-info{gap:10px}}.form-screen{-webkit-overflow-scrolling:touch;background-color:#030916;background-image:url(/hero-bg.jpg);background-position:50%;background-repeat:no-repeat;background-size:cover;flex-direction:column;width:100%;height:100%;display:flex;position:relative;overflow-y:auto}.form-screen:before{content:"";z-index:0;pointer-events:none;background:#040a189e;position:absolute;inset:0}.form-screen-header{z-index:1;border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;align-items:center;gap:12px;min-height:54px;padding:clamp(10px,2vh,14px) clamp(16px,3vw,28px);display:flex;position:relative}.form-back-btn{color:var(--text-muted);font-family:var(--font-body);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:8px;flex-shrink:0;align-items:center;gap:2px;min-height:36px;padding:7px 10px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.form-back-btn:hover{background:var(--msu-blue-light);color:var(--msu-blue)}.form-back-btn:focus-visible{outline:2px solid var(--msu-accent);outline-offset:2px}.form-context-line{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;opacity:.75;font-size:13px;overflow:hidden}.form-screen-body{z-index:1;flex-direction:column;flex:1;align-items:center;padding:clamp(20px,4vh,44px) clamp(16px,4vw,32px);display:flex;position:relative;overflow-y:auto}.form-content-wrap{outline:none;flex-direction:column;gap:16px;width:100%;max-width:440px;margin-block:auto;display:flex;transform:translateY(clamp(-48px,-6vh,-16px))}.form-step-indicator{align-items:center;gap:12px;display:flex}.form-step-label{color:var(--text-muted);white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;font-size:12px;font-weight:600}.form-progress-track{background:var(--border);border-radius:2px;flex:1;height:4px;overflow:hidden}.form-progress-fill{background:var(--msu-accent);border-radius:2px;height:100%;transition:width .3s}.result-screen{box-sizing:border-box;background-color:#030916;background-image:url(/hero-bg.jpg);background-position:50%;background-repeat:no-repeat;background-size:cover;justify-content:center;align-items:center;width:100%;min-height:100dvh;padding:clamp(20px,4vw,40px);display:flex;position:relative}.result-scrim{z-index:0;pointer-events:none;background:#040a189e;position:absolute;inset:0}.result-card{z-index:1;position:relative}.result-download-area{border-top:1px solid var(--border);text-align:center;flex-direction:column;align-items:center;gap:14px;margin-top:24px;padding-top:20px;display:flex}.result-save-hint{color:var(--text-muted);margin:0;font-size:13px;line-height:1.5}.result-download-btn{justify-content:center;align-items:center;gap:8px;width:100%;display:inline-flex}@media (width<=767px){.result-screen{background-position:30%;align-items:center;padding:24px}.result-screen .qr-code{width:100%;min-width:180px;max-width:260px}}
