.page-shell{margin:0 auto;padding:32px 0 56px;width:min(1180px,calc(100% - 32px))}.compact-shell{min-height:100vh;min-height:100dvh;padding:max(8px,env(safe-area-inset-top)) 0 max(12px,env(safe-area-inset-bottom));width:min(100% - 20px,520px)}.compact-checkin{grid-gap:10px;align-content:start;display:grid;gap:10px;min-height:calc(100vh - max(8px, env(safe-area-inset-top)) - max(12px, env(safe-area-inset-bottom)));min-height:calc(100dvh - max(8px, env(safe-area-inset-top)) - max(12px, env(safe-area-inset-bottom)))}.upload-panel{background:#121214f5;border:1px solid #ffffff14;border-radius:24px;box-shadow:0 18px 50px #00000057}.compact-user{color:#cbd5e1;font-size:.95rem;font-weight:600;margin:0}.compact-footer{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-top:auto;padding:0 2px}.hero-panel{grid-gap:24px;align-items:stretch;display:grid;gap:24px;grid-template-columns:minmax(320px,.95fr) minmax(360px,1.05fr)}.intro-card,.workspace-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#121214eb;border:1px solid #ffffff14;border-radius:28px;box-shadow:0 30px 90px #00000057}.intro-card{overflow:hidden;padding:36px;position:relative}.intro-card:after{background:linear-gradient(135deg,#0f629b29,#f7b32b2e);border-radius:50%;bottom:-170px;content:"";height:320px;position:absolute;right:-110px;width:320px}.eyebrow,.panel-label{color:#8ab4ff;font-size:.8rem;font-weight:800;letter-spacing:.18em;margin:0 0 12px;text-transform:uppercase}.intro-card h1,.workspace-card h2,.workspace-card h3{color:#f8fafc;margin:0}.intro-card h1{font-size:clamp(2.6rem,4.5vw,4.8rem);line-height:.96;max-width:11ch}.lead{color:#a1a1aa;font-size:1.02rem;line-height:1.8;margin:20px 0 0;max-width:58ch}.feature-item code,.lead code,.request-box code,.token-box code{background:#8ab4ff24;border-radius:999px;color:#c6dcff;padding:.14rem .4rem}.feature-list{grid-gap:16px;display:grid;gap:16px;margin-top:32px}.feature-item{grid-gap:14px;align-items:start;display:grid;gap:14px;grid-template-columns:48px 1fr}.feature-item p{color:#d4d4d8;line-height:1.7;margin:0}.feature-index{background:#8ab4ff1f;border-radius:50%;color:#8ab4ff;display:grid;font-size:.86rem;font-weight:800;height:48px;place-items:center}.workspace-card{padding:20px 22px 24px}.workspace-topbar{display:flex;gap:10px;margin-bottom:18px}.dot{border-radius:50%;height:12px;width:12px}.amber{background:#f4a261}.blue{background:#4ea8de}.green{background:#52b788}.notice{border-radius:18px;font-weight:600;line-height:1.6;margin-bottom:18px;padding:14px 16px}.notice.success{background:#22c55e1f;color:#86efac}.notice.error{background:#ef44441f;color:#fca5a5}.section-head{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:22px}.section-head.compact{margin-bottom:16px}.nav-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.login-form{grid-gap:16px;display:grid;gap:16px}.login-form label{grid-gap:8px;color:#243b53;display:grid;font-weight:600;gap:8px}.login-form input,.token-box textarea{background:#fff;border:1px solid #102a431f;border-radius:18px;color:#102a43;font:inherit;outline:0;padding:15px 16px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.login-form input:focus,.token-box textarea:focus{border-color:#0f609b80;box-shadow:0 0 0 4px #0f609b1a}.ghost-button,.primary-button,.secondary-button{border:0;border-radius:18px;cursor:pointer;font:inherit;font-weight:700;padding:14px 18px;transition:transform .2s ease,opacity .2s ease}.ghost-button:hover,.primary-button:hover,.secondary-button:hover{transform:translateY(-1px)}.ghost-button:disabled,.primary-button:disabled,.secondary-button:disabled{cursor:wait;opacity:.72}.primary-button{background:linear-gradient(135deg,#f4f4f5,#d4d4d8);color:#09090b}.ghost-button,.secondary-button{background:#ffffff14;color:#f4f4f5}.profile-box,.request-box,.token-box{background:#f8fbffe6;border:1px solid #102a4314;border-radius:22px;margin-top:22px;padding:18px}.request-box p{color:#486581;line-height:1.7;margin:14px 0 0}.attendance-card{background:radial-gradient(circle at top right,#8ab4ff14,#0000 24%),#121214f5;border:1px solid #ffffff14;border-radius:24px;margin-top:22px;padding:20px}.compact-shell .attendance-card,.compact-shell .upload-panel{margin-top:0;padding:12px 14px}.attendance-card.muted{color:#a1a1aa;font-weight:600}.attendance-head{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:18px}.attendance-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.camera-card{background:#ffffffeb;border:1px solid #102a4314;border-radius:24px;margin-top:22px;padding:20px}.attendance-form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:16px}.field{grid-gap:8px;color:#243b53;display:grid;font-weight:600;gap:8px}.field input{background:#fff;border:1px solid #102a431f;border-radius:18px;color:#102a43;font:inherit;outline:0;padding:15px 16px;width:100%}.field input:focus{border-color:#0f609b80;box-shadow:0 0 0 4px #0f609b1a}.field-hint{color:#627d98;font-size:.85rem;line-height:1.5}.camera-preview{background:linear-gradient(135deg,#28282bf2,#141416f5);border:1px dashed #ffffff24;border-radius:24px;min-height:260px;overflow:hidden}.compact-preview{min-height:120px}.camera-placeholder,.snapshot-image{min-height:260px;width:100%}.snapshot-image{display:block;max-height:420px;object-fit:cover}.camera-placeholder{color:#a1a1aa;display:grid;line-height:1.7;padding:24px;place-items:center;text-align:center}.camera-input{display:none}.status-pill{align-items:center;border-radius:999px;display:inline-flex;font-size:.88rem;font-weight:700;padding:10px 14px}.status-pill.success{background:#1987541f;color:#1f7a4d}.status-pill.idle{background:#627d9824;color:#52667a}.button-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}.compact-actions{margin-top:8px}.action-button{flex:1 1;min-height:46px}.compact-shell .eyebrow,.compact-shell .panel-label{font-size:.72rem;margin-bottom:6px}.compact-shell .attendance-head{margin-bottom:8px}.compact-shell .camera-placeholder,.compact-shell .camera-preview,.compact-shell .snapshot-image{min-height:120px}.compact-shell .camera-placeholder{font-size:.92rem;line-height:1.5;padding:14px}.compact-shell .info-card{padding:8px 10px}.compact-shell .info-label{font-size:.7rem;margin-bottom:1px}.compact-shell .info-card strong{font-size:1rem}.compact-shell .ghost-button,.compact-shell .primary-button,.compact-shell .secondary-button{padding:12px 14px}.token-box textarea{margin-top:12px;min-height:140px;resize:vertical}.session-hint{color:#486581;line-height:1.6;margin:12px 0 0}.session-hint strong{color:#102a43}.profile-box pre{color:#102a43;line-height:1.6;margin:0;overflow:auto;white-space:pre-wrap;word-break:break-word}.basic-profile{grid-gap:18px;display:grid;gap:18px}.identity-card{grid-gap:16px;align-items:center;background:#fff;border:1px solid #102a4314;border-radius:20px;display:grid;gap:16px;grid-template-columns:88px 1fr;padding:16px}.identity-card h4{color:#102a43;font-size:1.4rem;margin:0}.identity-card p{color:#486581;margin:6px 0 4px}.identity-meta{color:#0f609b;font-weight:600}.avatar{background:#0f609b14;border-radius:24px;height:88px;object-fit:cover;width:88px}.avatar-fallback{color:#0f609b;display:grid;font-size:1.5rem;font-weight:800;place-items:center}.profile-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr))}.info-card{background:#18181bfa;border:1px solid #ffffff14;border-radius:18px;padding:16px}.info-label{color:#a1a1aa;display:block;font-size:.82rem;font-weight:700;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.info-card strong{color:#fafafa;line-height:1.5}.empty-state{color:#a1a1aa;margin:0}.loading-state{background:#121214f5;border:1px solid #ffffff14;border-radius:22px;color:#d4d4d8;display:grid;font-weight:600;min-height:320px;place-items:center}.status-badge{align-items:center;background:#ffffff14;border-radius:999px;color:#f4f4f5;display:inline-flex;font-size:.88rem;font-weight:700;padding:8px 12px}@media (max-width:960px){.hero-panel{grid-template-columns:1fr}.intro-card h1{max-width:none}}@media (max-width:640px){.page-shell{padding:18px 0 40px;width:min(100% - 20px,1180px)}.compact-shell{padding:max(6px,env(safe-area-inset-top)) 0 max(10px,env(safe-area-inset-bottom));width:min(100% - 12px,520px)}.intro-card,.workspace-card{border-radius:22px;padding-left:20px;padding-right:20px}.button-row,.section-head{flex-direction:column}.attendance-form-grid,.identity-card,.profile-grid{grid-template-columns:1fr}}:root{background:radial-gradient(circle at top left,#40404038,#0000 30%),radial-gradient(circle at top right,#22222242,#0000 28%),linear-gradient(180deg,#050505,#0c0c0d);color-scheme:dark;font-family:Segoe UI,Helvetica Neue,sans-serif}*{box-sizing:border-box}html{background:radial-gradient(circle at top left,#40404038,#0000 30%),radial-gradient(circle at top right,#22222242,#0000 28%),linear-gradient(180deg,#050505,#0c0c0d);min-height:100%;scroll-behavior:smooth}body{background:#0000;color:#f3f4f6;margin:0;min-height:100vh;min-height:100dvh;min-width:320px}a,body,button{font-family:inherit}#root{min-height:100vh;min-height:100dvh}
/*# sourceMappingURL=main.3aa3ea7e.css.map*/