*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}@keyframes spin{to{transform:rotate(360deg)}}:root{--blue: #2563eb;--blue-light: #eff6ff;--blue-dark: #1d4ed8;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-400: #9ca3af;--gray-600: #4b5563;--gray-800: #1f2937;--red: #dc2626;--red-light: #fef2f2;--green: #16a34a;--green-light: #f0fdf4;--amber: #d97706;--amber-light: #fffbeb;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{background:var(--gray-50);color:var(--gray-800);min-height:100dvh}#root{max-width:430px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;background:#fff}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;display:grid;grid-template-columns:repeat(4,1fr);background:#fff;border-top:1px solid var(--gray-200);z-index:100}.bottom-nav button{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0 12px;background:none;border:none;cursor:pointer;font-size:9px;color:var(--gray-400);transition:color .15s}.bottom-nav button.active{color:var(--blue)}.bottom-nav button svg{width:20px;height:20px}.page-header{padding:16px 16px 8px;background:#fff;border-bottom:1px solid var(--gray-100);position:sticky;top:0;z-index:50}.page-header h1{font-size:18px;font-weight:700}.page-header p{font-size:12px;color:var(--gray-400);margin-top:2px}.page-body{flex:1;overflow-y:auto;padding:0 0 80px}.month-nav{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;flex-shrink:0}.month-nav span{font-size:16px;font-weight:600}.month-nav button{width:32px;height:32px;border:1px solid var(--gray-200);border-radius:8px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--gray-600)}.cal-page{display:flex;flex-direction:column;height:calc(100dvh - 130px);overflow:hidden}.cal-page .summary-bar{flex-shrink:0;margin-bottom:0}.cal-dow-row{display:grid;grid-template-columns:repeat(7,1fr);border-top:1px solid var(--gray-100);border-left:1px solid var(--gray-100);flex-shrink:0}.cal-dow{font-size:10px;color:var(--gray-400);text-align:center;padding:5px 0;border-right:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100)}.cal-dow:first-child{color:var(--red)}.cal-dow:last-child{color:var(--blue)}.cal-date-grid{flex:1;min-height:0;display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:1fr;border-left:1px solid var(--gray-100)}.cal-cell{border-right:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);padding:4px;cursor:pointer;position:relative;background:#fff;transition:background .1s;overflow:hidden}.cal-cell:hover{background:var(--blue-light)}.cal-cell.empty{cursor:default;background:var(--gray-50)}.cal-cell.empty:hover{background:var(--gray-50)}.cal-cell.today .day-num{background:var(--blue);color:#fff;border-radius:50%}.day-num{font-size:12px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-weight:500}.day-sun .day-num{color:var(--red)}.day-sat .day-num{color:var(--blue)}.shift-chip{margin-top:2px;border-radius:4px;padding:1px 4px;font-size:9px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}.summary-bar{margin:6px 12px;padding:10px 14px;background:var(--blue-light);border-radius:12px;display:flex;gap:16px}.summary-bar .item{flex:1}.summary-bar .label{font-size:10px;color:var(--blue-dark)}.summary-bar .amount{font-size:18px;font-weight:700;color:var(--blue-dark)}.payday-section{margin:12px 16px 0;border:1px solid var(--gray-200);border-radius:12px;overflow:hidden}.payday-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--gray-50);border-bottom:1px solid var(--gray-200);cursor:pointer}.payday-header .pday-title{font-size:14px;font-weight:600}.payday-header .pday-total{font-size:18px;font-weight:700;color:var(--blue)}.shift-row{padding:10px 14px;border-bottom:1px solid var(--gray-100);cursor:pointer}.shift-row:last-child{border-bottom:none}.shift-row-top{display:flex;align-items:baseline;justify-content:space-between}.shift-row-label{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}.shift-row-wp{font-size:11px;color:var(--gray-600);font-weight:400}.shift-row-total{font-size:14px;font-weight:700}.shift-row-time{font-size:11px;color:var(--gray-600);margin-top:2px}.breakdown-box{margin:6px 0 2px;background:var(--gray-50);border-radius:8px;padding:10px 12px;font-size:12px}.breakdown-row{display:flex;justify-content:space-between;align-items:baseline;padding:3px 0;gap:8px}.breakdown-row .b-label{color:var(--gray-600);flex:1;font-family:Menlo,Consolas,monospace}.breakdown-row .b-amount{font-weight:600;font-family:Menlo,Consolas,monospace;text-align:right;min-width:64px}.breakdown-divider{border:none;border-top:1px solid var(--gray-200);margin:4px 0}.breakdown-total-row{display:flex;justify-content:space-between;font-weight:700;padding-top:4px}.closing-badge{display:inline-block;font-size:10px;padding:2px 6px;background:var(--amber-light);color:var(--amber);border-radius:4px;margin-top:4px}.wp-card{margin:12px 16px 0;border:1px solid var(--gray-200);border-radius:12px;overflow:hidden}.wp-card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--gray-100)}.wp-card-header .wp-name{font-size:15px;font-weight:600}.wp-card-body{padding:12px 14px;font-size:13px}.wp-prop{display:flex;justify-content:space-between;padding:4px 0}.wp-prop .key{color:var(--gray-600)}.wp-prop .val{font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;display:flex;align-items:flex-end;justify-content:center}.modal-sheet{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:430px;padding:20px 16px 32px;max-height:90dvh;overflow-y:auto}.modal-handle{width:36px;height:4px;background:var(--gray-200);border-radius:2px;margin:0 auto 16px}.modal-title{font-size:16px;font-weight:700;margin-bottom:16px}.form-field{margin-bottom:14px}.form-field label{display:block;font-size:12px;color:var(--gray-600);margin-bottom:4px}.form-field input,.form-field select{width:100%;padding:10px 12px;border:1px solid var(--gray-200);border-radius:8px;font-size:14px;outline:none}.form-field input:focus,.form-field select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1a}.form-row{display:flex;gap:10px}.form-row .form-field{flex:1}.btn{width:100%;padding:13px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer}.btn-primary{background:var(--blue);color:#fff}.btn-danger{background:var(--red-light);color:var(--red)}.btn-ghost{background:none;border:1px solid var(--gray-200);color:var(--gray-600)}.btn+.btn{margin-top:8px}.fab{position:fixed;bottom:72px;right:16px;width:52px;height:52px;border-radius:26px;background:var(--blue);color:#fff;border:none;cursor:pointer;font-size:28px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #2563eb66;z-index:90}.color-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.disclaimer{margin:16px 16px 0;padding:10px 12px;background:var(--amber-light);border-radius:8px;font-size:11px;color:var(--amber);line-height:1.5}
