@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;800&family=DM+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{margin:0;font-family:DM Sans,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#f8fafc;background:#06122f;-webkit-font-smoothing:antialiased}button{border:0;background:transparent;font:inherit;cursor:pointer}button:disabled{cursor:not-allowed}svg{display:block}#app-root{min-height:100dvh}.font-mono{font-family:DM Mono,monospace}.clock-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;padding:42px 22px 26px;position:relative;overflow:hidden;background:radial-gradient(circle at 80% 8%,rgba(155,75,255,.58),transparent 32%),radial-gradient(circle at 18% 82%,rgba(46,96,255,.44),transparent 30%),linear-gradient(135deg,#06112d,#081a45 42%,#121f4e 67%,#4d1b88)}.clock-page:before,.clock-page:after{content:"";position:fixed;border-radius:999px;pointer-events:none;filter:blur(2px)}.clock-page:before{width:720px;height:720px;right:-260px;top:-280px;background:radial-gradient(circle,rgba(138,92,255,.32),transparent 68%)}.clock-page:after{width:540px;height:540px;left:-230px;bottom:-220px;background:radial-gradient(circle,rgba(31,92,255,.34),transparent 65%)}.clock-shell{width:min(1220px,100%);min-height:760px;display:grid;grid-template-columns:.92fr 1.45fr;overflow:hidden;border:1px solid rgba(255,255,255,.18);border-radius:18px;background:#ffffff0f;box-shadow:0 36px 110px #00000057,inset 0 1px #ffffff1f;position:relative;z-index:1}.brand-panel{position:relative;overflow:hidden;padding:42px 48px;background:radial-gradient(circle at 85% 78%,rgba(112,70,255,.42),transparent 30%),radial-gradient(circle at 20% 15%,rgba(43,91,255,.34),transparent 36%),linear-gradient(180deg,#081439fa,#050f2cfa)}.brand-panel:before{content:"";position:absolute;width:390px;height:390px;right:-190px;bottom:120px;border-radius:50%;background:repeating-radial-gradient(circle,rgba(110,88,255,.33) 0 1px,transparent 1px 12px);opacity:.6}.brand-panel:after{content:"";position:absolute;inset:auto -20% 12% 34%;height:170px;border-radius:50%;border-top:1px solid rgba(95,87,255,.35);transform:rotate(-22deg);box-shadow:0 -30px 65px #7742ff4d}.brand-top,.brand-hero,.feature-list,.illustration-wrap{position:relative;z-index:2}.brand-top{display:flex;align-items:center;gap:18px}.brand-logo{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#7d61ff,#2e55ff);box-shadow:0 18px 38px #3a4dff6b,inset 0 1px #ffffff59}.brand-top h1{font-size:28px;letter-spacing:-.04em;line-height:1;font-weight:800}.brand-top p{margin-top:8px;text-transform:uppercase;letter-spacing:.14em;color:#e2e8f0b3;font-size:13px;font-weight:600}.brand-hero{margin-top:118px;display:flex;align-items:flex-start;gap:20px}.brand-line{width:4px;height:112px;border-radius:999px;background:linear-gradient(180deg,#a855f7,#2f55ff);box-shadow:0 0 34px #a855f7b8;flex:0 0 auto}.brand-hero h2{font-size:clamp(30px,3vw,38px);line-height:1.05;letter-spacing:-.05em;font-weight:800}.brand-hero p{margin-top:20px;max-width:330px;color:#e2e8f0d1;font-size:18px;line-height:1.55}.feature-list{margin-top:54px;width:min(360px,100%);padding:20px 28px;border-radius:20px;background:linear-gradient(180deg,#ffffff1c,#ffffff0e);border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.feature-item{display:grid;grid-template-columns:58px 1fr;gap:18px;align-items:center;padding:16px 0}.feature-item+.feature-item{border-top:1px solid rgba(255,255,255,.09)}.feature-icon{width:52px;height:52px;display:grid;place-items:center;color:#fff;border-radius:14px;background:linear-gradient(135deg,#a17dfff5,#3053fff5);box-shadow:0 16px 30px #2e55ff42,inset 0 1px #ffffff47}.feature-item h3{color:#fff;font-size:15px;font-weight:800}.feature-item p{margin-top:5px;color:#e2e8f0c7;font-size:14px;line-height:1.45}.illustration-wrap{position:absolute;left:50px;right:28px;bottom:32px;height:170px}.clock-illus{position:absolute;left:96px;bottom:0;width:166px;height:166px;border-radius:50%;background:linear-gradient(145deg,#a08cff,#554af0 52%,#2e3fbc);box-shadow:0 24px 42px #00000047,inset 0 7px 16px #ffffff40;display:grid;place-items:center}.clock-face{position:relative;width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,#ffffff38,#ffffff0d);border:2px solid rgba(255,255,255,.22)}.clock-face i{position:absolute;left:62px;top:10px;width:4px;height:13px;background:#ffffffbf;border-radius:999px;transform-origin:2px 55px}.hand-hour,.hand-minute{position:absolute;left:63px;top:63px;width:5px;border-radius:999px;background:#fff;transform-origin:50% 100%;box-shadow:0 3px 8px #00000040}.hand-hour{height:34px;transform:translateY(-34px) rotate(42deg)}.hand-minute{height:48px;transform:translateY(-48px) rotate(28deg)}.clock-face em{position:absolute;left:56px;top:56px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 3px 10px #00000038}.plant{position:absolute;left:18px;bottom:0;width:72px;height:122px;border-bottom:42px solid #f8fafc;border-left:14px solid transparent;border-right:14px solid transparent;border-radius:0 0 16px 16px}.plant span{position:absolute;width:42px;height:24px;border-radius:42px 42px 4px;background:linear-gradient(135deg,#54d19a,#278d68)}.plant span:nth-child(1){left:17px;bottom:68px;transform:rotate(-55deg)}.plant span:nth-child(2){left:39px;bottom:84px;transform:rotate(32deg)}.plant span:nth-child(3){left:29px;bottom:42px;transform:rotate(30deg)}.cloud{position:absolute;left:260px;bottom:10px;width:104px;height:48px;border-radius:999px;background:#ffffffdb;box-shadow:-30px 12px #ffffffd1,28px 10px #ffffffbf}.pin-panel{position:relative;min-width:0;background:radial-gradient(circle at 82% 16%,rgba(112,70,255,.08),transparent 28%),linear-gradient(135deg,#fff,#f8f9ff 56%,#f3f6ff);color:#09122f;display:flex;align-items:center;justify-content:center;padding:54px 42px 42px}.pin-panel:after{content:"";position:absolute;top:94px;right:48px;width:120px;height:150px;background-image:radial-gradient(rgba(71,85,255,.16) 1.5px,transparent 1.5px);background-size:14px 14px}.theme-btn{position:absolute;top:34px;right:38px;width:48px;height:48px;display:grid;place-items:center;color:#3555ff;border-radius:50%;background:#ffffffe6;border:1px solid rgba(226,232,240,.95);box-shadow:0 14px 34px #0f172a1f;z-index:3}.pin-content{width:min(430px,100%);display:flex;flex-direction:column;align-items:center;position:relative;z-index:2}.lock-badge{width:82px;height:82px;display:grid;place-items:center;color:#4f46e5;border-radius:50%;background:linear-gradient(180deg,#f2f0ff,#e8eaff);margin-bottom:18px}.live-clock-card{text-align:center;margin-bottom:18px}.live-clock-time{font-size:34px;line-height:1;font-weight:500;letter-spacing:-.04em;color:#101833}.live-clock-date{margin-top:8px;font-size:12px;color:#7a86a5;font-weight:700;letter-spacing:.03em}.pin-heading{text-align:center}.pin-heading h2{font-size:30px;font-weight:800;letter-spacing:-.045em;color:#09122f}.pin-heading p{margin-top:10px;font-size:16px;color:#66739a;font-weight:600}.pin-dots{display:flex;gap:25px;align-items:center;justify-content:center;height:58px;margin:12px 0 14px}.pin-dot{width:18px;height:18px;border-radius:50%;border:2px solid #9aa8cf;background:#fff;transition:.22s cubic-bezier(.22,1,.36,1)}.pin-dot.filled{border-color:#4f46e5;background:linear-gradient(135deg,#605bff,#334cff);box-shadow:0 10px 20px #3f46ff47;transform:scale(1.05)}.pin-dot.error{border-color:#ef4444;background:#ef4444;animation:shake .42s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.employee-section{width:100%;margin-bottom:18px;padding:14px;border:1px solid #e1e7f5;border-radius:18px;background:#ffffffd1;box-shadow:0 16px 40px #2a356314}.employee-row{display:flex;align-items:center;gap:12px}.employee-avatar{width:48px;height:48px;flex:0 0 auto;border-radius:15px;background:linear-gradient(135deg,#654cff,#334cff);color:#fff;display:grid;place-items:center;font-weight:800}.employee-details{min-width:0;flex:1}.employee-name{color:#101833;font-size:15px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-code{color:#7380a2;font-size:12px;margin-top:2px}.status-badge{display:inline-flex;align-items:center;gap:7px;padding:7px 11px;border-radius:999px;font-size:11px;font-weight:800;text-transform:uppercase;white-space:nowrap}.badge-dot{width:7px;height:7px;border-radius:50%}.status-badge.in{background:#eafcf1;color:#15803d}.status-badge.in .badge-dot{background:#16a34a;box-shadow:0 0 0 4px #16a34a29}.status-badge.out{background:#eef2ff;color:#4338ca}.status-badge.out .badge-dot{background:#4f46e5}.clock-info-row,.worked-row{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;color:#66739a;font-size:13px;font-weight:700}.clock-info-row b,.worked-row b{color:#101833}.worked-row b{color:#15803d}.numpad-grid{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:14px 17px;margin-top:6px}.key{height:72px;display:grid;place-items:center;border:1px solid #dfe5f1;border-radius:11px;color:#0c1530;background:linear-gradient(180deg,#fff,#f7f8fc);box-shadow:0 11px 21px #16224614,inset 0 1px #fffffff2;font-size:24px;font-weight:800;transition:.18s cubic-bezier(.22,1,.36,1);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.key:hover:not(:disabled){transform:translateY(-2px);border-color:#bfc9ff;box-shadow:0 16px 25px #3a49a51f;color:#4338ca}.key:active:not(:disabled){transform:translateY(0) scale(.97)}.key:disabled{opacity:.5}.key-clear{color:#ff4b4b;font-size:16px}.key-back{color:#0f172a}.btn-clock{width:100%;height:66px;margin-top:34px;border-radius:10px;color:#fff;background:linear-gradient(135deg,#263fff,#6548ff 52%,#9138e6);box-shadow:0 22px 38px #4f46e552;font-size:20px;font-weight:800;transition:.22s cubic-bezier(.22,1,.36,1);overflow:hidden;position:relative}.btn-clock:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.23),transparent);transform:translate(-120%);transition:.55s ease}.btn-clock:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 26px 46px #4f46e566}.btn-clock:hover:not(:disabled):before{transform:translate(120%)}.btn-clock:active:not(:disabled){transform:translateY(0) scale(.99)}.btn-clock:disabled{opacity:.55;box-shadow:none}.btn-clock.clock-out{background:linear-gradient(135deg,#0f172a,#334155);box-shadow:0 22px 38px #0f172a3d}.btn-clock span{display:inline-flex;align-items:center;justify-content:center;gap:14px;position:relative;z-index:1}.spinner{width:24px;height:24px;border-radius:50%;border:3px solid rgba(255,255,255,.35);border-top-color:#fff;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.pin-divider{display:flex;align-items:center;gap:17px;margin:22px 0 12px;color:#a4adc6;font-size:14px}.pin-divider span{width:64px;height:1px;background:#dce2ef}.forgot-btn{color:#3555ff;font-weight:700;font-size:15px}.forgot-btn:hover{text-decoration:underline}.clock-footer{color:#e2e8f0db;font-size:15px;font-weight:500;display:inline-flex;align-items:center;gap:9px;position:relative;z-index:1}.clock-footer span{width:20px;height:20px;border-radius:6px;background:linear-gradient(135deg,#7059ff,#2f55ff);box-shadow:0 8px 20px #4c53ff66}.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%);z-index:9999;max-width:calc(100vw - 32px);display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:16px;color:#fff;box-shadow:0 20px 55px #00000038;font-weight:800}.toast--success{background:linear-gradient(135deg,#16a34a,#22c55e)}.toast--error{background:linear-gradient(135deg,#dc2626,#ef4444)}.toast--info{background:linear-gradient(135deg,#2563eb,#4f46e5)}.toast-icon{flex:0 0 auto}.toast-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toast-enter-active,.toast-leave-active{transition:all .28s ease}.toast-enter-from,.toast-leave-to{opacity:0;transform:translate(-50%) translateY(12px)}.slide-in-enter-active,.slide-in-leave-active{transition:all .28s cubic-bezier(.22,1,.36,1)}.slide-in-enter-from,.slide-in-leave-to{opacity:0;transform:translateY(-10px)}.success-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;display:flex;align-items:center;justify-content:center;padding:22px;background:#030a208f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.success-popup-card{position:relative;width:min(390px,100%);overflow:hidden;border-radius:30px;padding:38px 30px 34px;text-align:center;color:#fff;box-shadow:0 30px 90px #00000057;animation:popupBounce .45s cubic-bezier(.22,1,.36,1)}.popup-clock-in{background:linear-gradient(135deg,#16a34a,#22c55e 48%,#53d985)}.popup-clock-out{background:linear-gradient(135deg,#2643ff,#6548ff 55%,#9b39ec)}.popup-glow{position:absolute;width:250px;height:250px;right:-90px;top:-120px;border-radius:50%;background:#ffffff2e}.popup-icon{width:104px;height:104px;margin:0 auto 22px;display:grid;place-items:center;border-radius:50%;background:#ffffff29;border:1px solid rgba(255,255,255,.24);box-shadow:inset 0 1px #ffffff3d;position:relative;z-index:1}.success-popup-card h2{font-size:29px;letter-spacing:-.04em;margin-bottom:16px;position:relative;z-index:1}.success-popup-card strong{display:block;font-size:44px;line-height:1;margin-bottom:12px;position:relative;z-index:1}.success-popup-card p{opacity:.92;font-weight:600;margin-bottom:18px;position:relative;z-index:1}.popup-employee{display:inline-flex;padding:10px 18px;border-radius:999px;background:#ffffff29;border:1px solid rgba(255,255,255,.22);font-weight:800;margin-bottom:18px;position:relative;z-index:1}.success-popup-card small{display:block;font-size:16px;font-weight:700;position:relative;z-index:1}.success-popup-enter-active,.success-popup-leave-active{transition:all .28s ease}.success-popup-enter-from,.success-popup-leave-to{opacity:0;transform:scale(.92)}@keyframes popupBounce{0%{transform:scale(.82) translateY(24px);opacity:0}65%{transform:scale(1.03) translateY(0);opacity:1}to{transform:scale(1)}}@media (max-width: 1050px){.clock-shell{grid-template-columns:1fr;min-height:auto;max-width:680px}.brand-panel{padding:34px 36px 250px;min-height:620px}.brand-hero{margin-top:70px}.pin-panel{padding:46px 28px 42px}.theme-btn{top:24px;right:24px}}@media (max-width: 640px){.clock-page{justify-content:flex-start;padding:16px 12px 24px;gap:16px}.clock-shell{border-radius:22px}.brand-panel{display:none}.pin-panel{min-height:calc(100dvh - 72px);padding:34px 16px 28px}.pin-panel:after{display:none}.theme-btn{width:42px;height:42px;top:16px;right:16px}.lock-badge{width:70px;height:70px;margin-top:24px}.live-clock-time{font-size:28px}.pin-heading h2{font-size:26px}.pin-heading p{font-size:14px}.pin-dots{gap:18px;height:48px}.pin-dot{width:15px;height:15px}.numpad-grid{gap:11px}.key{height:60px;font-size:21px}.key-clear{font-size:14px}.btn-clock{height:60px;margin-top:24px;font-size:18px}.employee-row{align-items:flex-start}.status-badge{align-self:center}.clock-footer{font-size:12px;text-align:center}}@media (max-width: 380px){.pin-panel{padding-inline:12px}.key{height:54px}.numpad-grid{gap:9px}.pin-divider{margin-top:16px}}@media (min-width: 641px) and (max-width: 1050px){.clock-page{justify-content:center;padding:14px;gap:10px;overflow:hidden}.clock-shell{width:min(100%,940px);height:calc(100dvh - 48px);min-height:0;max-height:720px;grid-template-columns:.9fr 1.1fr}.brand-panel{display:block;min-height:0;padding:22px 26px}.brand-logo{width:44px;height:44px}.brand-top h1{font-size:22px}.brand-top p{font-size:10px}.brand-hero{margin-top:38px;gap:14px}.brand-line{height:76px}.brand-hero h2{font-size:24px}.brand-hero p{font-size:13px;margin-top:10px}.feature-list{margin-top:24px;padding:12px 16px;width:100%}.feature-item{grid-template-columns:42px 1fr;gap:12px;padding:10px 0}.feature-icon{width:38px;height:38px}.feature-item h3{font-size:12px}.feature-item p{font-size:11px}.illustration-wrap{height:110px;left:26px;bottom:16px}.clock-illus{width:96px;height:96px;left:70px}.clock-face{width:74px;height:74px}.cloud{left:178px;width:76px}.plant{width:50px;height:82px}.pin-panel{padding:26px 28px}.lock-badge{width:58px;height:58px;margin-bottom:10px}.live-clock-time{font-size:25px}.pin-heading h2{font-size:23px}.pin-heading p{font-size:13px}.pin-dots{height:38px;margin:6px 0 8px}.numpad-grid{gap:9px 12px}.key{height:48px;font-size:18px}.btn-clock{height:48px;margin-top:16px;font-size:15px}.pin-divider{margin:10px 0 6px}.clock-footer{font-size:11px}}@media (min-width: 1051px){.clock-shell{max-height:600px!important}.brand-hero{margin-top:46px!important}.feature-list{margin-top:24px!important;padding:12px 20px!important}.illustration-wrap{height:95px!important;bottom:10px!important}.pin-panel{padding:18px 34px!important}.lock-badge{width:52px!important;height:52px!important;margin-bottom:8px!important}.live-clock-time{font-size:26px!important}.pin-dots{height:34px!important;margin:5px 0 7px!important}.key{height:48px!important}.btn-clock{height:46px!important;margin-top:14px!important}.pin-divider,.forgot-btn{display:none!important}}@media (min-width: 1051px){.clock-page{height:100dvh;min-height:100dvh;padding:14px 22px;gap:10px;overflow:hidden}.clock-shell{width:min(1120px,100%);height:calc(100dvh - 54px);min-height:0;max-height:640px;grid-template-columns:.9fr 1.25fr}.brand-panel{padding:26px 34px}.brand-logo{width:48px;height:48px}.brand-top h1{font-size:24px}.brand-top p{font-size:11px;margin-top:6px}.brand-hero{margin-top:58px;gap:16px}.brand-line{height:88px}.brand-hero h2{font-size:32px}.brand-hero p{font-size:15px;margin-top:14px;line-height:1.45}.feature-list{margin-top:34px;width:min(330px,100%);padding:14px 22px}.feature-item{grid-template-columns:48px 1fr;gap:14px;padding:11px 0}.feature-icon{width:42px;height:42px}.feature-item h3{font-size:13px}.feature-item p{font-size:12px}.illustration-wrap{height:120px;bottom:20px;left:42px}.clock-illus{width:112px;height:112px;left:86px}.clock-face{width:86px;height:86px}.plant{width:56px;height:88px}.cloud{left:220px;width:84px;height:38px}.pin-panel{padding:24px 34px}.theme-btn{top:24px;right:28px;width:42px;height:42px}.lock-badge{width:60px;height:60px;margin-bottom:12px}.lock-badge svg{width:28px;height:28px}.live-clock-card{margin-bottom:12px}.live-clock-time{font-size:28px}.live-clock-date{margin-top:6px;font-size:11px}.pin-heading h2{font-size:25px}.pin-heading p{margin-top:8px;font-size:14px}.pin-dots{height:42px;margin:8px 0 10px;gap:20px}.pin-dot{width:15px;height:15px}.numpad-grid{gap:10px 14px}.key{height:54px;font-size:20px}.btn-clock{height:52px;margin-top:18px;font-size:16px}.pin-divider{margin:12px 0 8px;font-size:12px}.forgot-btn{font-size:13px}.clock-footer{font-size:11px}}@media (min-width: 1051px){.clock-shell{max-height:700px!important;height:calc(100dvh - 34px)!important}}
