.attendance-modal-backdrop{z-index:9999;opacity:0;visibility:hidden;background:0 0;justify-content:center;align-items:center;padding:20px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;inset:0}.attendance-modal-backdrop.visible{-webkit-backdrop-filter:blur(4px);opacity:1;visibility:visible;background:#0006}.attendance-modal{text-align:center;opacity:0;background:#fff;border-radius:20px;width:100%;max-width:320px;padding:32px 28px 28px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;transform:scale(.95)translateY(10px);box-shadow:0 4px 6px -1px #0000000d,0 10px 15px -3px #00000014}.attendance-modal-backdrop.visible .attendance-modal{opacity:1;transform:scale(1)translateY(0)}.attendance-modal-close{color:#bbb;cursor:pointer;z-index:1;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:color .15s;display:flex;position:absolute;top:12px;right:12px}.attendance-modal-close:hover{color:#666}.attendance-modal-visual{background:linear-gradient(145deg,#f8f8f8,#fff);border:1px solid #0000000a;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 24px;display:flex;box-shadow:0 2px 8px #0000000a,inset 0 -1px 2px #00000005}.attendance-modal-visual.complete{background:linear-gradient(145deg,#f0fdf4,#fff);border-color:#22c55e1a}.attendance-modal-logo-circle{justify-content:center;align-items:center;width:100%;height:100%;animation:.4s cubic-bezier(.4,0,.2,1) attendance-icon-appear;display:flex}@keyframes attendance-icon-appear{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.attendance-modal-visual.complete .attendance-modal-logo-circle{color:#22c55e}.attendance-modal-title{color:#111;letter-spacing:-.02em;margin:0 0 6px;font-size:18px;font-weight:600}.attendance-modal-desc{color:#888;margin:0 0 24px;font-size:13px;font-weight:400}.attendance-modal-reward{background:#fafafa;border:1px solid #0000000a;border-radius:14px;align-items:center;gap:6px;margin-bottom:24px;padding:14px 28px;display:inline-flex}.attendance-modal-token-icon{color:#7c3aed;opacity:.9}.attendance-modal-reward-amount{color:#111;letter-spacing:-.02em;font-size:26px;font-weight:700}.attendance-modal-reward-unit{color:#888;font-size:13px;font-weight:500}.attendance-modal-btn{cursor:pointer;letter-spacing:-.01em;border:none;border-radius:12px;width:100%;height:48px;padding:0 24px;font-size:15px;font-weight:600;transition:all .15s;display:block}.attendance-modal-btn:active{transform:scale(.98)}.attendance-modal-btn:disabled{cursor:not-allowed;opacity:.6}.attendance-modal-btn:not(.outline){color:#fff;background:#7c3aed;transition:all .15s,box-shadow .2s;box-shadow:0 2px 8px #7c3aed40}.attendance-modal-btn:not(.outline):hover:not(:disabled){background:#6d28d9;box-shadow:0 4px 12px #7c3aed59}.attendance-modal-btn:not(.outline):active:not(:disabled){transform:scale(.97);box-shadow:0 1px 4px #7c3aed33}.attendance-modal-btn.outline{color:#111;background:#fafafa;border:1px solid #00000014}.attendance-modal-btn.outline:hover:not(:disabled){background:#f5f5f5}.attendance-modal-btn.loading{pointer-events:none}:root[data-theme=dark] .attendance-modal,[data-theme=dark] .attendance-modal{background:#1c1c1e;box-shadow:0 4px 6px -1px #0003,0 10px 15px -3px #0000004d}:root[data-theme=dark] .attendance-modal-close,[data-theme=dark] .attendance-modal-close{color:#666}:root[data-theme=dark] .attendance-modal-close:hover,[data-theme=dark] .attendance-modal-close:hover{color:#999}:root[data-theme=dark] .attendance-modal-visual,[data-theme=dark] .attendance-modal-visual{background:linear-gradient(145deg,#2c2c2e,#1c1c1e);border-color:#ffffff0f;box-shadow:0 2px 8px #0003,inset 0 -1px 2px #0000001a}:root[data-theme=dark] .attendance-modal-visual.complete,[data-theme=dark] .attendance-modal-visual.complete{background:linear-gradient(145deg,#1a2e1a,#1c1c1e);border-color:#22c55e26}:root[data-theme=dark] .attendance-modal-title,[data-theme=dark] .attendance-modal-title{color:#f5f5f5}:root[data-theme=dark] .attendance-modal-desc,[data-theme=dark] .attendance-modal-desc{color:#888}:root[data-theme=dark] .attendance-modal-reward,[data-theme=dark] .attendance-modal-reward{background:#2c2c2e;border-color:#ffffff0f}:root[data-theme=dark] .attendance-modal-reward-amount,[data-theme=dark] .attendance-modal-reward-amount{color:#f5f5f5}:root[data-theme=dark] .attendance-modal-btn:not(.outline),[data-theme=dark] .attendance-modal-btn:not(.outline){color:#fff;background:#8b5cf6;box-shadow:0 2px 8px #8b5cf64d}:root[data-theme=dark] .attendance-modal-btn:not(.outline):hover:not(:disabled),[data-theme=dark] .attendance-modal-btn:not(.outline):hover:not(:disabled){background:#7c3aed;box-shadow:0 4px 12px #8b5cf666}:root[data-theme=dark] .attendance-modal-btn.outline,[data-theme=dark] .attendance-modal-btn.outline{color:#f5f5f5;background:#2c2c2e;border-color:#ffffff14}:root[data-theme=dark] .attendance-modal-btn.outline:hover:not(:disabled),[data-theme=dark] .attendance-modal-btn.outline:hover:not(:disabled){background:#3c3c3e}
/*# sourceMappingURL=4feeba0f79ebdcf4.css.map*/