@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@600;700;800&display=swap");:root{--bg:#f0f4ff;--bg-card:#ffffff;--bg-subtle:#f8faff;--primary:#4361ee;--primary-h:#3451db;--primary-l:rgba(67,97,238,0.10);--accent:#7c3aed;--accent-l:rgba(124,58,237,0.10);--success:#06d6a0;--success-l:rgba(6,214,160,0.12);--warning:#f59e0b;--warning-l:rgba(245,158,11,0.12);--danger:#ef4444;--danger-l:rgba(239,68,68,0.10);--text:#0d0f1c;--text-2:#5c6080;--text-3:#9aa0b8;--border:#e4e8f7;--border-2:#c9d0ea;--focus:rgba(67,97,238,0.22);--shadow-s:0 1px 3px rgba(0,0,0,0.06);--shadow-m:0 4px 16px rgba(0,0,0,0.08);--shadow-l:0 8px 32px rgba(0,0,0,0.12);--r-s:6px;--r-m:10px;--r-l:14px;--r-xl:20px;--r-f:9999px;--sidebar-w:260px;--bottom-nav-h:68px;--sb-bg:#1a1f36;--sb-hover:rgba(255,255,255,0.10);--sb-active:#4361ee;--sb-fg:#a8b0cc}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased}body{font-family:Inter,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;font-size:15px;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.25;color:var(--text)}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit;outline:none}img{max-width:100%;display:block}.pwa-shell{display:flex;flex-direction:column;min-height:100dvh;max-width:480px;margin:0 auto;background:var(--bg);position:relative}.pwa-topbar{background:var(--bg-card);border-bottom:1px solid var(--border);padding:.875rem 1.25rem;justify-content:space-between;position:sticky;top:0;z-index:20}.pwa-topbar,.pwa-topbar-brand{display:flex;align-items:center}.pwa-topbar-brand{gap:.625rem}.pwa-topbar-brand .brand-dot{width:30px;height:30px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:var(--r-m);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;color:white}.pwa-topbar-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1rem;color:var(--text)}.pwa-user-chip{gap:.5rem;padding:.35rem .65rem;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-f)}.pwa-avatar,.pwa-user-chip{display:flex;align-items:center}.pwa-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));justify-content:center;font-size:.7rem;font-weight:700;color:white}.pwa-user-name{font-size:.8rem;font-weight:600;color:var(--text)}.pwa-content{flex:1 1;padding:1.25rem 1rem calc(var(--bottom-nav-h) + 1rem);overflow-y:auto}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;height:var(--bottom-nav-h);background:var(--bg-card);border-top:1px solid var(--border);display:flex;align-items:stretch;z-index:50;box-shadow:0 -4px 24px rgba(0,0,0,.08)}.bottom-nav-item{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text-3);font-size:.7rem;font-weight:500;text-decoration:none;border:none;background:none;cursor:pointer;transition:color .15s;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item.active,.bottom-nav-item:hover{color:var(--primary)}.bottom-nav-icon{font-size:1.4rem;line-height:1;display:block}.bottom-nav-label{display:block}.app-layout{display:flex;height:100dvh;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--sb-bg);display:flex;flex-direction:column;height:100%;z-index:40;flex-shrink:0}.sidebar-logo{padding:1.25rem 1.25rem .5rem;gap:.625rem;margin-bottom:.5rem}.logo-icon,.sidebar-logo{display:flex;align-items:center}.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:var(--r-m);justify-content:center;font-weight:800;flex-shrink:0}.logo-icon,.sidebar-logo h2{font-size:1.1rem;color:white}.sidebar-section-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--sb-fg);padding:.75rem 1.25rem .25rem;margin-top:.5rem}.sidebar nav{flex:1 1;padding:0 .75rem;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.7rem .9rem;border-radius:var(--r-m);color:var(--sb-fg);font-weight:500;font-size:.9rem;transition:all .15s;text-align:left;width:100%;background:transparent}.nav-icon{font-size:1.1rem;width:20px;text-align:center;flex-shrink:0}.nav-item:hover{background:var(--sb-hover);color:white}.nav-item.active{background:var(--sb-active);color:white;font-weight:600}.sidebar-footer{padding:1rem .75rem;border-top:1px solid rgba(255,255,255,.06);margin-top:auto}.sidebar-user{gap:.75rem;padding:.75rem;border-radius:var(--r-m);margin-bottom:.5rem}.sidebar-avatar,.sidebar-user{display:flex;align-items:center}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));justify-content:center;font-weight:700;font-size:.85rem;color:white;flex-shrink:0}.user-name{color:white;font-weight:600;font-size:.875rem}.user-role{color:var(--sb-fg);font-size:.75rem}.mobile-topbar{display:none;height:60px;background:var(--bg-card);border-bottom:1px solid var(--border);padding:0 1rem;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:30;flex-shrink:0}.mobile-topbar-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1rem}.hamburger-btn{display:flex;flex-direction:column;gap:4px;padding:6px;border-radius:var(--r-s)}.hamburger-btn span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:39}@media (max-width:900px){.sidebar{position:fixed;top:0;left:0;bottom:0;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:200}.sidebar.open{transform:translateX(0)}.sidebar-overlay.show{display:block}.mobile-topbar{display:flex}}.main-content{flex:1 1;overflow-y:auto;display:flex;flex-direction:column;min-width:0}.page-wrapper{padding:1.75rem 2rem;flex:1 1}@media (max-width:900px){.page-wrapper{padding:1.25rem 1rem}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-l);box-shadow:var(--shadow-s)}.card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.5rem}.card-header h3{font-size:.95rem}.card-body,.glass-panel{padding:1.25rem}.glass-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-l);box-shadow:var(--shadow-s)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.25rem}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:540px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-l);padding:1rem 1.25rem;box-shadow:var(--shadow-s);gap:.875rem}.stat-card,.stat-card-icon{display:flex;align-items:center}.stat-card-icon{width:44px;height:44px;border-radius:var(--r-m);justify-content:center;font-size:1.35rem;flex-shrink:0}.stat-card-icon.blue{background:var(--primary-l)}.stat-card-icon.green{background:var(--success-l)}.stat-card-icon.purple{background:var(--accent-l)}.stat-card-icon.amber{background:var(--warning-l)}.stat-card-body h3{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2);font-family:Inter,sans-serif;margin-bottom:.2rem}.stat-num{font-size:1.75rem;font-weight:800;color:var(--text);line-height:1}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;font-weight:600;font-size:.9rem;padding:.6rem 1.25rem;border-radius:var(--r-m);background:var(--primary);color:white;box-shadow:0 1px 3px rgba(67,97,238,.3);cursor:pointer;border:none;font-family:inherit;transition:all .18s;text-decoration:none}.btn-primary:hover{background:var(--primary-h);transform:translateY(-1px)}.btn-primary:active{transform:none}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-success{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;font-weight:600;font-size:.9rem;padding:.6rem 1.25rem;border-radius:var(--r-m);background:var(--success);color:white;cursor:pointer;border:none;font-family:inherit;transition:all .18s}.btn-success:hover{background:#04b88a}.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;font-weight:600;font-size:.9rem;padding:.6rem 1.25rem;border-radius:var(--r-m);background:var(--danger-l);color:var(--danger);border:1px solid rgba(239,68,68,.2);cursor:pointer;font-family:inherit;transition:all .18s}.btn-danger:hover{background:rgba(239,68,68,.18)}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;font-weight:600;font-size:.9rem;padding:.6rem 1.25rem;border-radius:var(--r-m);background:transparent;color:var(--text-2);border:1.5px solid var(--border);cursor:pointer;font-family:inherit;transition:all .18s}.btn-ghost:hover{background:var(--bg-subtle);border-color:var(--border-2);color:var(--text)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--r-s);border:1px solid var(--border);background:transparent;color:var(--text-2);font-size:.9rem;cursor:pointer;transition:all .15s}.btn-icon:hover{background:var(--bg-subtle);color:var(--primary);border-color:var(--primary)}.btn-icon.danger:hover{background:var(--danger-l);color:var(--danger);border-color:var(--danger)}.form-group{display:flex;flex-direction:column;gap:.35rem}.label{font-size:.83rem;font-weight:600;color:var(--text)}.input-field{width:100%;padding:.65rem .9rem;border:1.5px solid var(--border);border-radius:var(--r-m);background:var(--bg-card);color:var(--text);font-size:.95rem;transition:border-color .15s,box-shadow .15s;appearance:none}.input-field::placeholder{color:var(--text-3)}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--focus)}.form-inline{display:grid;grid-template-columns:1fr 1fr;gap:.875rem}@media (max-width:400px){.form-inline{grid-template-columns:1fr}}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{width:100%;border-collapse:collapse;min-width:400px}.data-table th{padding:.65rem .875rem;text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-2);background:var(--bg-subtle);white-space:nowrap}.data-table td,.data-table th{border-bottom:1px solid var(--border)}.data-table td{padding:.8rem .875rem;font-size:.88rem;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--bg-subtle)}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:var(--r-f);font-size:.73rem;font-weight:600;line-height:1.4;white-space:nowrap}.badge-blue{background:var(--primary-l);color:var(--primary)}.badge-green{background:var(--success-l);color:#047857}.badge-purple{background:var(--accent-l);color:var(--accent)}.badge-red{background:var(--danger-l);color:var(--danger)}.badge-amber{background:var(--warning-l);color:#b45309}.alert-error{background:var(--danger-l);border:1px solid rgba(239,68,68,.25);color:#b91c1c;border-radius:var(--r-m)}.alert-error,.alert-success{padding:.75rem 1rem;font-size:.875rem}.alert-success{background:var(--success-l);border:1px solid rgba(6,214,160,.25);color:#047857;border-radius:var(--r-m)}.modal-backdrop{position:fixed;inset:0;background:rgba(10,10,30,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-end;padding:0}@media (min-width:600px){.modal-backdrop{align-items:center;padding:1rem}}.modal{background:var(--bg-card);width:100%;border-radius:var(--r-xl) var(--r-xl) 0 0;max-height:90dvh;overflow-y:auto;animation:slideUp .25s cubic-bezier(.34,1.56,.64,1)}@media (min-width:600px){.modal{max-width:480px;border-radius:var(--r-xl);margin:auto;animation:popIn .2s cubic-bezier(.34,1.56,.64,1)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.25rem 0}.modal-header h3{font-size:1.1rem}.modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:0 1.25rem 1.25rem}.login-page{min-height:100dvh;display:grid;place-items:center;background:linear-gradient(135deg,#0d0f1c,#1a1f36 60%,#141630);padding:1rem}.login-card{width:100%;max-width:380px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:var(--r-xl);padding:2rem 1.5rem;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 32px 64px rgba(0,0,0,.4)}.login-brand{gap:.75rem;margin-bottom:1.75rem}.brand-icon,.login-brand{display:flex;align-items:center;justify-content:center}.brand-icon{width:42px;height:42px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:var(--r-m);font-size:1.3rem;font-weight:800;color:white}.login-card h2{color:white;font-size:1.25rem}.login-card p{color:rgba(255,255,255,.45);font-size:.875rem}.login-card .label{color:rgba(255,255,255,.65)}.login-card .input-field{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1);color:white}.login-card .input-field::placeholder{color:rgba(255,255,255,.25)}.login-card .input-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(67,97,238,.3)}.page-header{margin-bottom:1.25rem}.page-header h1{font-size:1.35rem}.page-header p{font-size:.85rem;color:var(--text-2);margin-top:.2rem}.punch-hero{flex-direction:column;text-align:center;gap:1.25rem;padding:2rem 1rem}.punch-hero,.punch-ring{display:flex;align-items:center;justify-content:center}.punch-ring{width:140px;height:140px;border-radius:50%;font-size:2.5rem;border:4px solid var(--border);background:var(--bg-subtle);box-shadow:var(--shadow-m),inset 0 0 0 8px var(--bg-card);transition:all .3s}.punch-ring.active{border-color:var(--success);background:var(--success-l);box-shadow:0 0 0 10px rgba(6,214,160,.08),var(--shadow-m),inset 0 0 0 8px var(--bg-card);animation:pulsePing 2s ease infinite}.punch-ring.ready{border-color:var(--primary);background:var(--primary-l);box-shadow:0 0 0 10px rgba(67,97,238,.08),var(--shadow-m),inset 0 0 0 8px var(--bg-card)}@keyframes pulsePing{0%,to{box-shadow:0 0 0 10px rgba(6,214,160,.08),var(--shadow-m),inset 0 0 0 8px var(--bg-card)}50%{box-shadow:0 0 0 18px rgba(6,214,160,.04),var(--shadow-m),inset 0 0 0 8px var(--bg-card)}}.punch-btn{width:100%;max-width:260px;padding:1rem;font-size:1.05rem;font-weight:700;border-radius:var(--r-f);border:none;cursor:pointer;transition:all .2s;font-family:inherit}.punch-btn.in{background:var(--primary);color:white;box-shadow:0 4px 16px rgba(67,97,238,.35)}.punch-btn.in:hover{background:var(--primary-h);transform:translateY(-2px)}.punch-btn.out{background:var(--danger);color:white;box-shadow:0 4px 16px rgba(239,68,68,.3)}.punch-btn.out:hover{background:#dc2626;transform:translateY(-2px)}.punch-btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.text-muted{color:var(--text-3);font-size:.83rem}.text-secondary{color:var(--text-2)}.font-semibold{font-weight:600}.stack{display:flex;flex-direction:column;gap:1rem}.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--text-2)}.empty-state .empty-icon{font-size:2.25rem;margin-bottom:.625rem}.empty-state h3{font-size:.95rem;margin-bottom:.35rem}.empty-state p{font-size:.85rem;color:var(--text-3)}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media (max-width:700px){.two-col{grid-template-columns:1fr}}