.layout{display:flex;flex-direction:column;height:100dvh;height:100vh;max-width:480px;margin:0 auto;background:var(--gray-50);position:relative;box-shadow:0 0 40px #00000014}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#fff;border-bottom:1px solid var(--gray-100);min-height:var(--header-height);flex-shrink:0;box-shadow:var(--shadow-sm)}.app-header-left{display:flex;align-items:center;gap:12px}.header-logo{width:38px;height:38px;object-fit:contain;border-radius:8px;border:1px solid var(--gray-100);padding:2px;background:#fff}.header-logo-placeholder{width:38px;height:38px;border-radius:8px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;flex-shrink:0}.header-company{font-size:12px;color:var(--gray-400);font-weight:500}.header-user{font-size:15px;font-weight:700;color:var(--gray-800)}.tz-badge{display:inline-block;padding:4px 10px;background:var(--primary-50);color:var(--primary);border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.04em}.app-main{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.bottom-nav{display:flex;align-items:stretch;background:#fff;border-top:1px solid var(--gray-100);min-height:var(--nav-height);flex-shrink:0;box-shadow:0 -2px 12px #0000000f;padding-bottom:env(safe-area-inset-bottom,0)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;color:var(--gray-400);transition:color .15s,background .15s;border-radius:0;position:relative}.nav-item:hover{color:var(--gray-600);background:var(--gray-50)}.nav-item.active{color:var(--primary)}.nav-item.active:before{content:"";position:absolute;top:0;left:20%;right:20%;height:2px;background:var(--primary);border-radius:0 0 2px 2px}.nav-icon{font-size:20px;line-height:1}.nav-label{font-size:11px;font-weight:600}.login-page{min-height:100dvh;min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(160deg,#1e3a5f,#2563eb 60%,#7c3aed);padding:0 0 40px}.login-top{display:flex;flex-direction:column;align-items:center;padding:64px 20px 40px;text-align:center;color:#fff}.login-logo-circle{width:72px;height:72px;border-radius:20px;background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:900;color:#fff;margin-bottom:20px;box-shadow:0 8px 32px #0003}.login-brand{font-size:24px;font-weight:800;color:#fff;margin-bottom:6px}.login-tagline{font-size:15px;color:#ffffffb3}.login-card{background:#fff;border-radius:24px 24px 0 0;padding:32px 24px 24px;flex:1;box-shadow:0 -8px 40px #00000026}.login-card-title{font-size:22px;font-weight:800;color:var(--gray-900);margin-bottom:4px}.login-card-sub{font-size:14px;color:var(--gray-400);margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:18px;margin-bottom:20px}.pw-wrapper{position:relative}.pw-wrapper .form-input{padding-right:48px}.pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:18px;line-height:1;cursor:pointer;padding:4px;color:var(--gray-400)}.login-hint{text-align:center;font-size:13px;color:var(--gray-400);margin-top:16px}.login-hint a{color:var(--primary)}.login-hint a:hover{text-decoration:underline}.home-page{display:flex;flex-direction:column;gap:0}.live-clock{text-align:center;padding:28px 20px 20px;background:linear-gradient(135deg,var(--primary) 0%,#7c3aed 100%);color:#fff}.clock-time{font-size:42px;font-weight:800;letter-spacing:-1px;line-height:1;font-variant-numeric:tabular-nums}.clock-date{font-size:14px;color:#ffffffbf;margin-top:6px}.status-card{margin:20px 20px 0;border-radius:var(--radius);padding:18px 20px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;transition:background .3s}.status-idle{background:var(--gray-100)}.status-in{background:var(--success-light)}.status-break{background:var(--warning-light)}.status-out{background:var(--primary-light)}.status-icon{font-size:32px;line-height:1}.status-text{font-size:17px;font-weight:700;color:var(--gray-800)}.status-sub{font-size:13px;color:var(--gray-500)}.action-area{padding:16px 20px}.clock-btn{height:58px;font-size:18px;letter-spacing:.01em;border-radius:var(--radius);box-shadow:var(--shadow-md)}.today-summary{padding:0 20px 20px}.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:4px}.summary-item{background:#fff;border-radius:var(--radius-sm);padding:14px 16px;box-shadow:var(--shadow-sm)}.summary-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-bottom:4px}.summary-value{font-size:20px;font-weight:800;color:var(--gray-800)}.break-row{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid var(--gray-100)}.break-row:last-child{border-bottom:none}.break-time{flex:1;font-size:14px;color:var(--gray-600)}.break-dur{font-size:13px;font-weight:600;color:var(--gray-500);white-space:nowrap}.break-page{gap:0}.active-break-card{background:linear-gradient(135deg,var(--warning) 0%,#f59e0b 100%);border-radius:var(--radius);padding:28px 24px 24px;margin-bottom:20px;text-align:center;color:#fff;box-shadow:var(--shadow-md)}.active-break-icon{font-size:48px;margin-bottom:10px;line-height:1}.active-break-label{font-size:20px;font-weight:800}.active-break-since{font-size:13px;opacity:.85;margin-top:4px;margin-bottom:16px}.elapsed-timer{display:block;font-size:40px;font-weight:900;letter-spacing:2px;font-variant-numeric:tabular-nums;margin-bottom:20px}.break-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.break-type-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;background:#fff;border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm)}.break-type-btn:hover{border-color:var(--warning);background:var(--warning-light)}.break-type-btn.selected{border-color:var(--warning);background:var(--warning-light);box-shadow:0 0 0 3px #d9770626}.break-type-icon{font-size:28px;line-height:1}.break-type-label{font-size:13px;font-weight:700;color:var(--gray-700);text-align:center}.break-type-desc{font-size:11px;color:var(--gray-400);text-align:center}.break-history-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--gray-100)}.break-history-row:last-child{border-bottom:none}.break-history-left{display:flex;align-items:center;gap:12px}.break-history-icon{font-size:24px;line-height:1}.break-history-type{font-size:14px;font-weight:700;color:var(--gray-800)}.break-history-time{font-size:12px;color:var(--gray-400);margin-top:2px}.break-history-dur{font-size:14px;font-weight:700;color:var(--gray-600);white-space:nowrap}.report-page{gap:0}.report-hero{background:var(--primary);border-radius:var(--radius);padding:18px 20px;display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.report-hero-date{font-size:15px;font-weight:700;color:#fff;flex:1;padding-right:12px}.time-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.time-card{background:#fff;border-radius:var(--radius-sm);padding:16px;box-shadow:var(--shadow-sm);text-align:center}.time-card-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-bottom:6px}.time-card-value{font-size:20px;font-weight:800;color:var(--gray-800)}.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:4px}.stat-box{background:#fff;border-radius:var(--radius-sm);padding:14px 10px;text-align:center;box-shadow:var(--shadow-sm)}.stat-box-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-400);margin-bottom:5px}.stat-box-value{font-size:20px;font-weight:800;color:var(--gray-800)}.break-detail-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--gray-100)}.break-detail-row:last-child{border-bottom:none}.break-detail-icon{font-size:24px;flex-shrink:0}.break-detail-info{flex:1;min-width:0}.break-detail-type{font-size:14px;font-weight:700;color:var(--gray-800)}.break-detail-time{font-size:12px;color:var(--gray-400);margin-top:2px}.break-detail-dur{font-size:14px;font-weight:700;color:var(--gray-500);white-space:nowrap}.monthly-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:10px}.monthly-stat{border-radius:var(--radius);padding:18px 12px;text-align:center;box-shadow:var(--shadow-sm)}.monthly-stat.present{background:var(--success-light)}.monthly-stat.absent{background:var(--danger-light)}.monthly-stat.late{background:var(--warning-light)}.monthly-stat-val{font-size:32px;font-weight:900;line-height:1}.present .monthly-stat-val{color:var(--success)}.absent .monthly-stat-val{color:var(--danger)}.late .monthly-stat-val{color:var(--warning)}.monthly-stat-label{font-size:12px;font-weight:700;margin-top:4px;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500)}.daily-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 16px;border-bottom:1px solid var(--gray-100)}.daily-row:last-child{border-bottom:none}.daily-row-left{display:flex;align-items:center;gap:10px}.daily-row-date{font-size:14px;font-weight:700;color:var(--gray-800);min-width:80px}.daily-row-right{text-align:right}.daily-row-times{font-size:12px;color:var(--gray-400);margin-bottom:2px}.daily-row-work{font-size:14px;font-weight:700;color:var(--gray-700)}.profile-page{gap:0}.profile-hero{display:flex;align-items:center;gap:16px;padding:20px;background:linear-gradient(135deg,var(--primary) 0%,#7c3aed 100%);border-radius:var(--radius);margin-bottom:16px;color:#fff}.profile-avatar{width:64px;height:64px;border-radius:50%;background:#fff3;border:3px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;flex-shrink:0;color:#fff}.profile-name{font-size:20px;font-weight:800;color:#fff}.profile-role{font-size:14px;color:#fffc;margin-top:2px;text-transform:capitalize}.profile-dept{font-size:13px;color:#fff9;margin-top:2px}.info-row{display:flex;align-items:center;gap:12px;padding:13px 20px;border-bottom:1px solid var(--gray-100)}.info-row:last-child{border-bottom:none}.info-label{font-size:13px;font-weight:600;color:var(--gray-400);min-width:90px;flex-shrink:0}.info-value{font-size:14px;color:var(--gray-800);font-weight:500;word-break:break-all}.profile-company-row{display:flex;align-items:center;gap:14px;padding:14px 20px}.workdays-list{display:flex;flex-wrap:wrap;gap:6px}.workday-chip{display:inline-block;padding:3px 10px;background:var(--primary-light);color:var(--primary);border-radius:999px;font-size:12px;font-weight:700}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #dbeafe;--primary-50: #eff6ff;--success: #16a34a;--success-light: #dcfce7;--warning: #d97706;--warning-light: #fef3c7;--danger: #dc2626;--danger-light: #fee2e2;--info: #0891b2;--info-light: #cffafe;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--nav-height: 64px;--header-height: 60px;--radius: 12px;--radius-sm: 8px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:15px;color:var(--gray-800);background:var(--gray-50);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:15px;transition:background .15s,transform .1s,opacity .15s;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#15803d}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover:not(:disabled){background:#b45309}.btn-secondary{background:#fff;color:var(--gray-700);border:1.5px solid var(--gray-300)}.btn-secondary:hover:not(:disabled){background:var(--gray-50)}.btn-ghost{background:transparent;color:var(--gray-600);border:none}.btn-block{width:100%}.btn-xl{padding:18px 32px;font-size:17px;border-radius:var(--radius)}.btn-sm{padding:8px 16px;font-size:13px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-weight:600;color:var(--gray-700);font-size:14px}.form-input{width:100%;padding:12px 16px;border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);background:#fff;color:var(--gray-800);font-size:15px;outline:none;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.form-input.error{border-color:var(--danger)}.form-error{color:var(--danger);font-size:13px}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card-body{padding:20px}.card-header{padding:16px 20px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-header h2{font-size:16px;font-weight:700;color:var(--gray-800)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.badge-present,.badge-success{background:var(--success-light);color:var(--success)}.badge-absent,.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-late,.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-half_day{background:var(--info-light);color:var(--info)}.badge-on-break,.badge-info{background:var(--primary-light);color:var(--primary)}.alert{padding:14px 16px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:14px;font-weight:500}.alert-error{background:var(--danger-light);color:var(--danger);border-left:4px solid var(--danger)}.alert-success{background:var(--success-light);color:var(--success);border-left:4px solid var(--success)}.alert-info{background:var(--primary-light);color:var(--primary);border-left:4px solid var(--primary)}.alert-warning{background:var(--warning-light);color:var(--warning);border-left:4px solid var(--warning)}.spinner{display:inline-block;width:20px;height:20px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.spinner-dark{border-color:var(--gray-200);border-top-color:var(--primary)}.spinner-lg{width:40px;height:40px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;padding:60px 20px;flex-direction:column;gap:16px}.loading-center p{color:var(--gray-400);font-size:14px}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:14px}th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);background:var(--gray-50);border-bottom:1px solid var(--gray-200);white-space:nowrap}td{padding:13px 14px;border-bottom:1px solid var(--gray-100);color:var(--gray-700)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--gray-50)}.empty-state{text-align:center;padding:48px 20px;color:var(--gray-400)}.empty-state .empty-icon{font-size:48px;margin-bottom:12px}.empty-state p{font-size:15px}.empty-state small{font-size:13px;color:var(--gray-300)}.page{padding:20px;max-width:600px;margin:0 auto}.page-title{font-size:22px;font-weight:800;color:var(--gray-900);margin-bottom:20px}.section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-bottom:12px}.divider{border:none;border-top:1px solid var(--gray-100);margin:20px 0}.filters-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}
