@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--clr-bg:#f4f7fe;--clr-surface:#fff;--clr-surface-2:#f0f4ff;--clr-border:#d1d9e6;--clr-primary:#e31e24;--clr-primary-h:#c1171d;--clr-accent:#036;--clr-success:#059669;--clr-warning:#facc15;--clr-danger:#dc2626;--clr-text:#1a202c;--clr-text-2:#4a5568;--clr-text-3:#718096;--grad-primary:linear-gradient(135deg, #036 0%, #e31e24 100%);--grad-success:linear-gradient(135deg, #059669 0%, #036 100%);--grad-danger:linear-gradient(135deg, #e31e24 0%, #8b0000 100%);--grad-warning:linear-gradient(135deg, #facc15 0%, #e31e24 100%);--shadow-card:0 4px 24px #00336614;--shadow-glow:0 0 40px #e31e2426;--shadow-success:0 0 40px #05966926;--shadow-danger:0 0 40px #e31e2426;--shadow-warning:0 0 40px #facc1526;--r-sm:clamp(6px, 1.5vw, 8px);--r-md:clamp(10px, 2.5vw, 14px);--r-lg:16px;--r-xl:clamp(16px, 4.5vw, 28px);--r-full:9999px;--safe-bottom:env(safe-area-inset-bottom,0px);--t-fast:.15s ease;--t-base:.25s ease;--t-slow:.4s ease}html,body{background-color:var(--clr-bg);height:100%;color:var(--clr-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;font-family:Inter,system-ui,sans-serif;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--clr-bg)}::-webkit-scrollbar-thumb{background:var(--clr-border);border-radius:var(--r-full)}.container{width:100%;max-width:480px;margin:0 auto;padding:0 clamp(14px,3vw,16px)}.full-page{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2px;display:flex}.glass-card{border:1px solid var(--clr-border);border-radius:var(--r-xl);box-shadow:var(--shadow-card);background:#fff;width:100%;padding:clamp(2px,5vw,32px) clamp(14px,3vw,16px)}.brand-header{text-align:center;margin-bottom:32px}.brand-icon{border-radius:var(--r-lg);background:var(--grad-primary);width:72px;height:72px;box-shadow:var(--shadow-glow);justify-content:center;align-items:center;margin:0 auto 16px;font-size:32px;animation:3s ease-in-out infinite float;display:flex}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.brand-title{background:var(--grad-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(22px,5vw,28px);font-weight:800;line-height:1.2}.brand-title-row{flex-direction:column;justify-content:center;align-items:center;gap:10px;margin-bottom:6px;display:flex}.brand-title-row .brand-logo{object-fit:contain;width:auto;height:70px}.brand-title-row .brand-title{margin-bottom:0;font-size:clamp(20px,5.5vw,28px)}@media (width>=480px){.brand-title-row{flex-direction:row;gap:14px}.brand-title-row .brand-logo{height:72px}}.brand-subtitle{color:var(--clr-text-2);margin-top:6px;font-size:13px;font-weight:400}.form-group{margin-bottom:20px;position:relative}.form-label{color:var(--clr-text-2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:12px;font-weight:600;display:block}.form-input{background:var(--clr-surface-2);border:1.5px solid var(--clr-border);border-radius:var(--r-md);width:100%;color:var(--clr-text);min-height:48px;transition:border-color var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);-webkit-appearance:none;outline:none;padding:14px 16px;font-family:inherit;font-size:16px;font-weight:500}.form-input::placeholder{color:var(--clr-text-3);font-weight:400}.form-input:focus{border-color:var(--clr-primary);background:#fff;box-shadow:0 0 0 3px #4f46e51f}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-hint{color:var(--clr-text-3);margin-top:6px;font-size:11px}.btn{border-radius:var(--r-md);cursor:pointer;min-height:48px;transition:transform var(--t-fast), opacity var(--t-fast), box-shadow var(--t-fast);white-space:nowrap;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px 24px;font-family:inherit;font-size:15px;font-weight:700;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:0 4px 18px #4f46e54d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 26px #4f46e56b}.btn-outline{border:1.5px solid var(--clr-border);color:var(--clr-text-2);background:0 0}.btn-outline:hover:not(:disabled){border-color:var(--clr-primary);color:var(--clr-primary);background:#4f46e50d}.btn-success{background:var(--grad-success);color:#fff;box-shadow:0 4px 18px #05966947}.btn-danger{background:var(--grad-danger);color:#fff;box-shadow:0 4px 18px #dc262647}.btn-sm{border-radius:var(--r-sm);padding:10px 18px;font-size:13px}.btn-ghost{color:var(--clr-text-2);background:0 0;padding:10px 16px;font-weight:500}.btn-ghost:hover:not(:disabled){color:var(--clr-primary);background:#4f46e50f}.alert{border-radius:var(--r-md);align-items:flex-start;gap:10px;padding:12px 16px;font-size:14px;font-weight:500;animation:.3s slideUp;display:flex}.alert-error{color:#b91c1c;background:#dc262614;border:1px solid #dc262640}.alert-success{color:#065f46;background:#05966914;border:1px solid #05966940}.alert-warning{color:#92400e;background:#d9770614;border:1px solid #d9770640}.spinner{border:3px solid #4f46e526;border-top-color:var(--clr-primary);border-radius:50%;flex-shrink:0;width:22px;height:22px;animation:.7s linear infinite spin}.spinner-lg{border-width:4px;border-color:#4f46e526;border-top-color:var(--clr-primary);width:48px;height:48px;margin:24px auto}@keyframes spin{to{transform:rotate(360deg)}}.qr-wrapper{flex-direction:column;align-items:center;gap:20px;display:flex}.qr-frame{border-radius:var(--r-lg);box-shadow:var(--shadow-glow);border:2px solid var(--clr-border);background:#fff;padding:18px;animation:2.5s ease-in-out infinite pulseGlow}@keyframes pulseGlow{0%,to{box-shadow:0 0 24px #4f46e52e}50%{box-shadow:0 0 44px #4f46e557}}.student-card{background:var(--clr-surface-2);border:1px solid var(--clr-border);border-radius:var(--r-lg);align-items:center;gap:16px;padding:18px;display:flex}.student-avatar{border-radius:var(--r-md);object-fit:cover;border:2px solid var(--clr-border);background:var(--clr-surface);flex-shrink:0;width:72px;height:72px}.student-avatar-fallback{border-radius:var(--r-lg);background:var(--grad-primary);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:28px;font-weight:800;display:flex}.student-info{flex:1;min-width:0}.student-name{color:var(--clr-text);white-space:nowrap;text-overflow:ellipsis;font-size:18px;font-weight:700;overflow:hidden}.student-meta{color:var(--clr-text-2);margin-top:4px;font-size:13px}.student-id{color:var(--clr-accent);letter-spacing:.06em;margin-top:6px;font-family:monospace;font-size:12px;font-weight:600}.status-banner{border-radius:var(--r-lg);text-align:center;padding:20px;animation:.35s slideUp}.status-banner.valid{border:2px solid var(--clr-success);box-shadow:var(--shadow-success);background:#05966914}.status-banner.invalid{border:2px solid var(--clr-danger);box-shadow:var(--shadow-danger);background:#dc262614}.status-banner.used{border:2px solid var(--clr-warning);box-shadow:var(--shadow-warning);background:#d9770614}.status-icon{margin-bottom:8px;font-size:48px;line-height:1;animation:.5s cubic-bezier(.68,-.55,.27,1.55) bounceIn}@keyframes bounceIn{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}.status-text{color:var(--clr-text);font-size:18px;font-weight:700}.status-sub{color:var(--clr-text-2);margin-top:4px;font-size:13px}.scanner-box{border-radius:var(--r-lg);border:2px solid var(--clr-border);background:#f8fafc;justify-content:center;align-items:center;min-height:260px;display:flex;position:relative;overflow:hidden}.divider{align-items:center;gap:12px;margin:20px 0;display:flex}.divider:before,.divider:after{content:"";background:var(--clr-border);flex:1;height:1px}.divider span{color:var(--clr-text-3);white-space:nowrap;font-size:12px}.bg-blob{filter:blur(90px);opacity:.12;pointer-events:none;z-index:0;border-radius:50%;position:fixed}.bg-blob-1{background:var(--clr-primary);width:420px;height:420px;top:-140px;left:-140px}.bg-blob-2{background:var(--clr-accent);width:380px;height:380px;bottom:-120px;right:-120px}.chip{border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.chip-success{color:var(--clr-success);background:#0596691f}.chip-danger{color:var(--clr-danger);background:#dc26261f}.chip-warning{color:var(--clr-warning);background:#d977061f}.chip-info{color:var(--clr-accent);background:#0891b21f}.topbar{-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--clr-border);z-index:100;background:#ffffffd9;justify-content:space-between;align-items:center;height:60px;padding:0 20px;display:flex;position:sticky;top:0;box-shadow:0 1px 8px #4f46e50d}@media (width>=768px){.topbar{height:64px}}.tab-switcher{background:var(--clr-surface-2);border-radius:var(--r-full);border:1.5px solid var(--clr-border);gap:4px;padding:4px;display:flex}@media (width<=400px){.tab-switcher{flex:1;width:100%;margin:0 10px}.tab-btn{flex:1;justify-content:center;padding:6px 4px}}.tab-btn{border-radius:var(--r-full);color:var(--clr-text-2);cursor:pointer;transition:all var(--t-fast);white-space:nowrap;background:0 0;border:none;align-items:center;gap:6px;padding:6px 16px;font-size:13px;font-weight:600;display:flex}.tab-btn.active{color:var(--clr-primary);background:#fff;box-shadow:0 2px 8px #4f46e51f}.tab-btn:hover:not(.active){background:#00000008}.records-list{flex-direction:column;gap:2px;max-height:480px;padding-right:4px;display:flex;overflow-y:auto}.record-item{border-radius:var(--r-md);transition:background var(--t-fast);align-items:center;gap:14px;padding:12px;display:flex}.record-item:hover{background:var(--clr-surface-2)}.record-avatar{background:var(--grad-primary);color:#fff;opacity:.9;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:18px;font-weight:700;display:flex}.record-content{flex:1;min-width:0}.record-header{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.record-name{color:var(--clr-text);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:700;overflow:hidden}.record-time{color:var(--clr-text-3);background:var(--clr-surface-2);border-radius:var(--r-full);padding:2px 8px;font-size:11px;font-weight:600}.record-sub{color:var(--clr-text-2);align-items:center;gap:8px;font-size:12px;display:flex}.record-sub .dot{background:var(--clr-border);border-radius:50%;width:4px;height:4px}.topbar-title{background:var(--grad-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:16px;font-weight:800}.session-banner{background:var(--clr-primary);color:#fff;z-index:90;justify-content:center;align-items:center;gap:12px;padding:8px 16px;font-size:12px;font-weight:600;animation:.3s slideDown;display:flex;position:sticky;top:60px}@media (width>=768px){.session-banner{font-size:13px;top:64px}}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.btn-fab{bottom:calc(24px + var(--safe-bottom));background:var(--grad-primary);color:#fff;z-index:200;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;animation:.5s cubic-bezier(.68,-.55,.27,1.55) bounceIn;display:flex;position:fixed;right:20px;box-shadow:0 4px 20px #4f46e566}.btn-fab:active{transform:scale(.9)}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-slideUp{animation:.35s slideUp}@media (width<=360px){.glass-card{padding:16px 14px}.btn{padding:12px 16px;font-size:14px}.brand-title{font-size:20px}}.animate-fadeIn{animation:.35s fadeIn}.text-center{text-align:center}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}.gap-3{gap:12px}.flex{display:flex}.flex-col{flex-direction:column}#root{padding-bottom:var(--safe-bottom)}@media (width<=480px){.glass-card{border-radius:16px;width:100%}.btn{padding:15px 20px;font-size:16px}.form-input{font-size:16px}}.pill-about-page{background-color:#024;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:80px 20px;font-family:Inter,system-ui,sans-serif;display:flex;overflow-x:hidden}.pill-container{justify-content:center;gap:30px;max-width:1200px;display:flex}@media (width<=1100px){.pill-about-page{justify-content:flex-start;align-items:center;padding:80px 0 20px}.pill-container{scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;flex-wrap:nowrap;justify-content:flex-start;gap:16px;width:100vw;padding:20px calc(50vw - 120px) 40px;overflow-x:auto}.pill-container::-webkit-scrollbar{display:none}.pill-card-wrapper{scroll-snap-align:center;scroll-snap-stop:always;flex-shrink:0;transform:none!important}.pill-card-wrapper:nth-child(2n),.pill-card-wrapper:hover,.pill-card-wrapper:nth-child(2n):hover{transform:none!important}.pill-card{opacity:.35;transition:opacity .4s,transform .4s cubic-bezier(.25,.8,.25,1);transform:scale(.85);animation:none!important}.pill-card-wrapper.is-active .pill-card{opacity:1;transform:scale(1)}}@media (width<=480px){.pill-container{gap:12px;padding:20px calc(50vw - 100px) 40px}.pill-card{border-radius:100px;width:200px;height:480px}.pill-content{padding:50px 16px 0}.pill-name{font-size:1.05rem}.pill-role{font-size:.8rem}}.pill-card-wrapper{transition:transform .4s cubic-bezier(.25,.8,.25,1)}.pill-card-wrapper:nth-child(2n){transform:translateY(60px)}.pill-card-wrapper:hover{transform:translateY(-10px)}.pill-card-wrapper:nth-child(2n):hover{transform:translateY(50px)}.pill-card{cursor:pointer;border-radius:120px;flex-direction:column;width:240px;height:560px;animation:.8s cubic-bezier(.25,.8,.25,1) backwards cardAppear;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 30px #00000080}.pill-card-wrapper:first-child .pill-card{animation-delay:50ms}.pill-card-wrapper:nth-child(2) .pill-card{animation-delay:.15s}.pill-card-wrapper:nth-child(3) .pill-card{animation-delay:.25s}.pill-card-wrapper:nth-child(4) .pill-card{animation-delay:.35s}.pill-card-wrapper:nth-child(5) .pill-card{animation-delay:.45s}@keyframes cardAppear{0%{opacity:0;transform:translateY(40px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.pill-content{text-align:center;z-index:2;padding:60px 20px 0;position:relative}.pill-name{color:#000;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:6px;font-size:1.15rem;font-weight:800;line-height:1.2}.pill-role{color:#333;font-size:.9rem;font-weight:500}.pill-image{object-fit:cover;object-position:top center;width:100%;height:70%;transition:transform .4s cubic-bezier(.25,.8,.25,1);position:absolute;bottom:0;left:0}.pill-card-wrapper:hover .pill-image{transform:scale(1.05)}.back-btn{color:#fff;cursor:pointer;z-index:100;background:#ffffff1a;border:1px solid #fff3;border-radius:100px;align-items:center;gap:8px;padding:10px 20px;font-size:.85rem;font-weight:600;transition:all .2s;display:flex;position:fixed;top:30px;left:30px}.back-btn:hover{background:#fff3;transform:translateY(-2px)}
