:root{--bg: #0e1729;--surface: #182238;--elevated: #1f2c47;--input: #2a3a5a;--border: rgba(255,255,255,.06);--border-strong: rgba(0,224,199,.2);--accent: #00E0C7;--accent-hover: #1ff5dc;--accent-soft: rgba(0,224,199,.08);--accent-deep: #0d8071;--accent-text: #080f1e;--text: #ffffff;--text-muted: #8a9ab8;--text-dim: #5e6e8a;--success: #2dd4bf;--warning: #f59e0b;--danger: #ef4444;--danger-soft: rgba(239,68,68,.12);--info: #60a5fa;--purple: #a78bfa}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden;-webkit-text-size-adjust:100%;text-size-adjust:100%;-webkit-overflow-scrolling:touch;width:100%;max-width:100vw}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;overflow-x:hidden;width:100%;max-width:100vw;touch-action:manipulation;position:relative;font-feature-settings:"tnum";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{overflow-x:hidden;width:100%;max-width:100vw}.btn{display:block;width:100%;padding:1rem 1.5rem;border:none;border-radius:999px;font-size:1.05rem;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;font-family:inherit}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-green{background:var(--success);color:var(--accent-text)}.btn-red{background:var(--danger);color:#fff}.btn-blue{background:var(--accent);color:var(--accent-text);font-weight:700}.btn-blue:hover:not(:disabled){background:var(--accent-hover)}.btn-outline{background:transparent;border:1.5px solid var(--accent);color:var(--accent)}.btn-outline:hover:not(:disabled){background:var(--accent-soft)}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000040;max-width:100%;overflow-x:hidden}.page{max-width:480px;margin:0 auto;padding:1.5rem 1rem 3rem;display:flex;flex-direction:column;gap:1.25rem;min-width:0;width:100%;overflow-x:hidden}.app-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.app-header .logo{font-weight:800;font-size:1.15rem;color:var(--accent);letter-spacing:-.01em}.app-header .user-name{font-size:.85rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px}.app-header .logout-btn{border:none;background:none;cursor:pointer;font-size:.85rem;color:var(--text-muted);font-weight:600;white-space:nowrap;transition:color .15s}.app-header .logout-btn:hover{color:var(--danger)}.desktop-nav{display:flex;gap:.75rem;margin-left:.5rem}.nav-link{font-size:.875rem;color:var(--text-muted);font-weight:600;text-decoration:none;white-space:nowrap;transition:color .15s}.nav-link:hover{color:var(--accent)}.hamburger-btn{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;width:32px;height:32px;padding:0;flex-shrink:0}.ham-line{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .2s}.mobile-drawer{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:200}.mobile-drawer-inner{position:absolute;top:0;left:0;width:72vw;max-width:280px;height:100%;background:var(--elevated);border-right:1px solid var(--border);display:flex;flex-direction:column;padding-top:3.5rem;box-shadow:4px 0 32px #00000080}.drawer-link{display:block;padding:.9rem 1.25rem;font-size:1rem;font-weight:600;color:var(--text-muted);text-decoration:none;border-bottom:1px solid var(--border);transition:color .15s,background .15s}.drawer-link:hover{background:var(--accent-soft);color:var(--accent)}.drawer-logout{margin:1rem 1.25rem;padding:.65rem;border-radius:999px;border:none;background:var(--danger);color:#fff;font-size:.95rem;font-weight:700;cursor:pointer}@media (max-width: 600px){.hamburger-btn{display:flex}.desktop-nav,.app-header .user-name,.app-header .logout-btn{display:none}.page{padding:1rem .75rem 3rem}.card{padding:1.1rem}table{font-size:.78rem}th,td{padding:.4rem .5rem}.status-circle{width:170px;height:170px}}.status-circle{width:200px;height:200px;border-radius:50%;border:3px solid;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:.5rem auto;gap:.35rem;transition:all .3s}.status-circle.off{border-color:var(--danger);background:var(--danger-soft)}.status-circle.on{border-color:var(--success);background:#2dd4bf14}.status-circle.break{border-color:var(--warning);background:#f59e0b14}.status-circle .dot{width:12px;height:12px;border-radius:50%}.status-circle.off .dot{background:var(--danger);box-shadow:0 0 24px var(--danger)}.status-circle.on .dot{background:var(--success);box-shadow:0 0 24px var(--success)}.status-circle.break .dot{background:var(--warning);box-shadow:0 0 24px var(--warning)}.status-circle .status-label{font-weight:800;font-size:1.2rem;letter-spacing:.04em}.status-circle.off .status-label{color:var(--danger)}.status-circle.on .status-label{color:var(--success)}.status-circle.break .status-label{color:var(--warning)}.status-circle .timer{font-size:.9rem;color:var(--text-muted);font-weight:600}.punch-status-card{width:100%;max-width:320px;border-radius:12px;padding:.85rem 1rem;background:var(--elevated);border:1px solid var(--border);text-align:center;margin-top:.25rem}.punch-status-title{font-size:.98rem;font-weight:700;color:var(--text)}.punch-status-help{font-size:.82rem;color:var(--text-muted);margin-top:.25rem;line-height:1.35}.login-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(145deg,#0e1729,#182238 55%,#08101e)}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border)}.login-card h1{font-size:1.5rem;font-weight:800;margin-bottom:1.5rem;text-align:center;color:var(--text);letter-spacing:-.01em}.form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.form-group label{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.65rem .85rem;border-radius:8px;border:1px solid var(--border);font-size:16px;outline:none;background:var(--input);color:var(--text);transition:border .15s,box-shadow .15s;font-family:inherit}input,select,textarea{font-size:max(16px,1rem)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.form-group input::placeholder{color:var(--text-dim)}.form-group select option{background:var(--elevated);color:var(--text)}.error-msg{color:var(--danger);font-size:.875rem;font-weight:600;margin-top:.5rem;text-align:center}.form-section-title{font-size:.72rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin:0 0 .75rem;padding-bottom:.4rem;border-bottom:1px solid var(--border-strong)}table{width:100%;border-collapse:collapse;font-size:.875rem}th{padding:.65rem .75rem;text-align:left;font-weight:600;font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:transparent}td{padding:.7rem .75rem;border-bottom:1px solid var(--border);color:var(--text)}tbody tr{transition:background .12s}tbody tr:hover{background:var(--accent-soft)}tr:last-child td{border-bottom:none}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.tabs{display:flex;flex-wrap:wrap;gap:0;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:0;margin-bottom:0;max-width:100%;border-bottom:1px solid var(--border)}@media (max-width: 600px){.tabs{flex-wrap:nowrap;overflow-x:auto}}.tabs::-webkit-scrollbar{display:none}.tab-btn{flex-shrink:0;padding:.75rem 1rem;border-radius:0;border:none;border-bottom:2px solid transparent;font-size:.875rem;font-weight:500;cursor:pointer;background:transparent;color:var(--text-muted);white-space:nowrap;transition:color .15s,border-color .15s;font-family:inherit;margin-bottom:-1px}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);background:transparent;font-weight:600}.badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.72rem;font-weight:600}.badge-green{background:#2dd4bf1f;color:var(--success)}.badge-red{background:var(--danger-soft);color:var(--danger)}.tl-check{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:18px;height:18px;border-radius:5px;border:1.5px solid var(--text-muted);background:var(--input);cursor:pointer;flex-shrink:0;display:inline-grid;place-content:center;transition:background .15s,border-color .15s;position:relative}.tl-check:before{content:"";width:10px;height:10px;transform:scale(0);transition:transform .12s ease-in-out;background:var(--accent-text);clip-path:polygon(14% 44%,0 65%,50% 100%,100% 16%,80% 0%,43% 62%)}.tl-check:checked{background:var(--accent);border-color:var(--accent)}.tl-check:checked:before{transform:scale(1)}.tl-check:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.text-link{color:var(--accent);font-size:.875rem;font-weight:500;text-decoration:none;background:none;border:none;cursor:pointer;transition:color .15s;font-family:inherit;padding:0}.text-link:hover{color:var(--accent-hover)}.action-btn-outline{display:inline-block;font-size:.78rem;font-weight:600;cursor:pointer;padding:.3rem .8rem;border-radius:8px;background:transparent;transition:background .15s,color .15s;margin-right:.35rem;font-family:inherit}.action-btn-blue{border:1px solid var(--accent);color:var(--accent)}.action-btn-blue:hover{background:var(--accent);color:var(--accent-text)}.action-btn-red{border:1px solid var(--danger);color:var(--danger)}.action-btn-red:hover{background:var(--danger);color:#fff}
