:root{--bg-page: #f1f5f9;--border: #e2e8f0;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:var(--text-primary);background:var(--bg-page);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}h1,h2,h3{line-height:1.3}.page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-page)}.page-content{flex:1;max-width:900px;width:100%;margin:0 auto;padding:24px 16px 48px;display:flex;flex-direction:column;gap:32px}.app-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 16px;height:56px;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.app-logo{display:flex;align-items:center;gap:7px;text-decoration:none;color:inherit;min-width:0}.app-logo-icon{font-size:1.25rem;line-height:1;flex-shrink:0}.app-logo-text{display:flex;flex-direction:column;line-height:1.15;min-width:0}.app-logo-name{font-size:.9rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.app-logo-sub{font-size:.6rem;font-weight:500;color:var(--text-muted);letter-spacing:.03em}.app-page-title{font-size:.72rem;font-weight:600;color:var(--text-muted);background:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;padding:3px 12px;white-space:nowrap;justify-self:center}.app-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.header-right{display:flex;align-items:center;gap:8px;justify-self:end}.user-name{font-size:.875rem;color:var(--text-secondary);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.section{background:#fff;border:1px solid var(--border);border-radius:12px;padding:24px}.section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 16px}.section-desc{font-size:.875rem;color:var(--text-secondary);margin:-8px 0 16px}.clock-panel{display:flex;flex-direction:column;gap:16px}.clock-status{margin-bottom:4px}.status-badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:.875rem;font-weight:600;margin:0}.status-in{background:#dcfce7;color:#15803d}.status-out{background:#f1f5f9;color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:8px;border:none;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s,background .15s;white-space:nowrap;font-family:inherit}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-primary{background:#2563eb;color:#fff;width:100%}.btn-in{background:#16a34a;color:#fff;align-self:flex-start;min-width:120px}.btn-in:hover:not(:disabled){background:#15803d}.btn-out{background:#dc2626;color:#fff;align-self:flex-start;min-width:120px}.btn-out:hover:not(:disabled){background:#b91c1c}.btn-secondary{background:#f1f5f9;color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:#f1f5f9}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 20px;background:#fff;border:1px solid var(--border);border-radius:8px;font-size:.9rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:background .15s;font-family:inherit}.btn-google:hover:not(:disabled){background:#f8fafc}.btn-google:disabled{opacity:.55;cursor:not-allowed}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.form-group input,.form-group textarea{padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:.9rem;color:var(--text-primary);background:#fff;transition:border-color .15s,box-shadow .15s;font-family:inherit;resize:vertical}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg-page)}.login-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:40px 36px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:20px}.login-header{text-align:center}.login-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 6px}.login-subtitle{font-size:.9rem;color:var(--text-secondary);margin:0}.login-form{display:flex;flex-direction:column;gap:16px}.divider{position:relative;text-align:center}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border)}.divider span{position:relative;background:#fff;padding:0 12px;font-size:.8rem;color:var(--text-muted)}.table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid var(--border)}.attendance-table{width:100%;border-collapse:collapse;font-size:.875rem}.attendance-table th{background:#f8fafc;padding:10px 14px;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap}.attendance-table td{padding:10px 14px;border-bottom:1px solid #f1f5f9;color:var(--text-primary);vertical-align:top}.attendance-table tbody tr:last-child td{border-bottom:none}.attendance-table tbody tr:hover td{background:#f8fafc}.row-active td{background:#f0fdf4}.row-active:hover td{background:#dcfce7!important}.memo-cell{max-width:200px;white-space:pre-wrap;word-break:break-word;color:var(--text-secondary)!important;font-size:.8rem!important}.error-message{color:#dc2626;font-size:.875rem;margin:0;padding:10px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}.reset-password-link{margin-top:6px;color:#6b7280;font-size:.8rem;text-decoration:underline;padding:2px 0;background:none;border:none}.reset-password-link:hover:not(:disabled){color:#374151}.reset-sent-message{color:#16a34a;font-size:.875rem;margin:0;padding:10px 12px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px}.empty-message{color:var(--text-muted);font-size:.875rem;text-align:center;padding:32px 0;margin:0}.loading-text{color:var(--text-muted);font-size:.875rem;margin:0}.full-screen-center{min-height:100vh;display:flex;align-items:center;justify-content:center}.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media (max-width: 600px){.summary-grid{grid-template-columns:repeat(2,1fr)}}.summary-item{display:flex;flex-direction:column;gap:6px;background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:14px 16px}.summary-item--accent{background:#eff6ff;border-color:#bfdbfe}.summary-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.summary-value{font-size:1.25rem;font-weight:700;color:var(--text-primary);line-height:1.2}.summary-item--accent .summary-value{color:#1d4ed8}.summary-active{font-size:.8rem;font-weight:600;color:#15803d;background:#dcfce7;padding:2px 8px;border-radius:12px}.summary-active-hint{font-size:.72rem;font-weight:500;color:#15803d;margin-left:4px}.clock-status-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.clock-actions{display:flex;gap:10px;flex-wrap:wrap}.tc-badge{display:inline-block;padding:3px 10px;background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;border-radius:12px;font-size:.78rem;font-weight:600}.tc-badge--work{background:#f0fdf4;color:#15803d;border-color:#bbf7d0}.text-muted{color:var(--color-text-muted);font-size:.85rem}.tc-select{padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:.9rem;color:var(--text-primary);background:#fff;font-family:inherit;cursor:pointer;transition:border-color .15s,box-shadow .15s}.tc-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.status-break{background:#fff7ed;color:#c2410c}.btn-break-start{background:#f59e0b;color:#fff;align-self:flex-start;min-width:110px}.btn-break-start:hover:not(:disabled){background:#d97706}.btn-break-end{background:#0284c7;color:#fff;align-self:flex-start;min-width:110px}.btn-break-end:hover:not(:disabled){background:#0369a1}.break-done-badge{display:inline-block;padding:3px 10px;background:#fef3c7;color:#92400e;border:1px solid #fde68a;border-radius:12px;font-size:.78rem;font-weight:600}.today-summary{display:flex;flex-direction:column;gap:20px}.tc-breakdown{border-top:1px solid var(--border);padding-top:16px;display:flex;flex-direction:column;gap:8px}.tc-breakdown-title{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.tc-breakdown-row{display:flex;align-items:center;gap:12px}.tc-breakdown-row--active{opacity:.8}.tc-breakdown-time{font-size:.9rem;font-weight:700;color:var(--text-primary)}.summary-sublabel{font-size:.7rem;color:var(--text-muted);margin-top:2px}.tc-toggle-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}.tc-toggle-btn{padding:7px 14px;border:1.5px solid var(--border);border-radius:20px;font-size:.85rem;font-weight:500;background:#fff;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,background .15s,color .15s;font-family:inherit;white-space:nowrap}.tc-toggle-btn:hover{border-color:#2563eb;color:#2563eb}.tc-toggle-btn--active{background:#2563eb;border-color:#2563eb;color:#fff;font-weight:600}.clockout-group{display:flex;flex-direction:column;gap:12px;background:#fef2f2;border:1.5px solid #fecaca;border-radius:10px;padding:16px;margin-top:4px}.clockout-group-label{font-size:.78rem;font-weight:700;color:#dc2626;text-transform:uppercase;letter-spacing:.06em}.section-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title-row .section-title{margin-bottom:0}.history-filter-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:20px}.history-date-chip{display:inline-flex;align-items:center;gap:6px;background:#dbeafe;color:#1e40af;border-radius:20px;padding:5px 14px;font-size:.85rem;font-weight:600;white-space:nowrap}.history-date-chip-clear{background:none;border:none;cursor:pointer;color:#1e40af;font-size:1rem;line-height:1;padding:0 2px;opacity:.7}.history-date-chip-clear:hover{opacity:1}.history-cal-wrap{position:relative;flex-shrink:0}.history-cal-btn{background:none;border:1px solid var(--border, #e2e8f0);border-radius:8px;cursor:pointer;padding:0 12px;font-size:1.1rem;color:var(--text-muted, #64748b);transition:background .15s,border-color .15s,color .15s;line-height:1;height:43px;display:flex;align-items:center;justify-content:center}.history-cal-btn:hover,.history-cal-btn--active{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.history-cal-dropdown{position:absolute;right:0;top:calc(100% + 6px);z-index:200;background:#fff;border-radius:14px;box-shadow:0 6px 24px #00000021;padding:8px;min-width:296px}.history-cal-dropdown .mini-calendar{border:none;padding:8px 10px;font-size:.875rem}.history-cal-dropdown .mini-calendar-title{font-size:.95rem}.history-cal-dropdown .mini-calendar-weekday{font-size:.75rem;padding-bottom:6px}.history-cal-dropdown .mini-calendar-cell{font-size:.85rem}.filter-group{display:flex;background:#f1f5f9;border-radius:10px;padding:4px;gap:2px}.filter-btn{padding:7px 18px;border:none;border-radius:7px;font-size:.875rem;font-weight:500;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s,font-weight .1s;font-family:inherit;white-space:nowrap}.filter-btn:hover{background:#e2e8f0;color:var(--text-primary)}.filter-btn--active{background:#fff;color:var(--text-primary);font-weight:700;box-shadow:0 1px 3px #0000001a}.history-count{font-size:.875rem;color:var(--text-muted);font-weight:500}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:60px;background:#fff;border-top:1px solid var(--border);display:flex;align-items:stretch;z-index:100;box-shadow:0 -2px 8px #0000000f}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text-muted);text-decoration:none;font-size:.68rem;font-weight:500;transition:color .15s;padding:6px 0}.bottom-nav-item:hover,.bottom-nav-item--active{color:#2563eb}.bottom-nav-item--active svg{stroke:#2563eb}.page-content{padding-bottom:80px}.reason-preset-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}.reason-preset-btn{padding:6px 13px;border:1.5px solid var(--border);border-radius:20px;font-size:.82rem;font-weight:500;background:#fff;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,background .15s,color .15s;font-family:inherit;white-space:nowrap}.reason-preset-btn:hover{border-color:#7c3aed;color:#7c3aed}.reason-preset-btn--active{background:#7c3aed;border-color:#7c3aed;color:#fff}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}.modal{background:#fff;border-radius:14px;width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003;overflow:hidden}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:1.05rem;font-weight:700;margin:0 0 4px;color:var(--text-primary)}.modal-subtitle{font-size:.85rem;color:var(--text-muted);margin:0}.modal-close{background:none;border:none;font-size:1.1rem;color:var(--text-muted);cursor:pointer;padding:4px 6px;border-radius:6px;line-height:1;flex-shrink:0}.modal-close:hover{background:#f1f5f9;color:var(--text-primary)}.modal-body{padding:20px 24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border);flex-shrink:0}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 480px){.form-row-2{grid-template-columns:1fr}}.input-with-clear{display:flex;gap:6px;align-items:center}.input-with-clear input{flex:1;min-width:0}.btn-clear{background:none;border:1px solid var(--border);border-radius:6px;font-size:.78rem;color:var(--text-muted);cursor:pointer;padding:6px 8px;white-space:nowrap;font-family:inherit}.btn-clear:hover{background:#f1f5f9;color:var(--text-primary)}.required{color:#dc2626;margin-left:2px}.label-hint{font-size:.75rem;color:var(--text-muted);font-weight:400;margin-left:6px}.field-warning{font-size:.78rem;color:#e53e3e;margin:4px 0 0;line-height:1.4}.field-hint{font-size:.78rem;color:#2b6cb0;margin:4px 0 0;line-height:1.4}.btn-primary{background:#2563eb;color:#fff;min-width:100px}.btn-primary:hover:not(:disabled){background:#1d4ed8}.btn-xs{padding:4px 10px;font-size:.78rem}.action-cell{white-space:nowrap;width:1%}.view-toggle{display:flex;gap:4px;margin-bottom:16px}.view-toggle-btn{padding:7px 16px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:.85rem;color:var(--text-secondary);cursor:pointer;transition:all .15s}.view-toggle-btn:hover{border-color:#2563eb;color:#2563eb}.view-toggle-btn--active{background:#2563eb;border-color:#2563eb;color:#fff;font-weight:600}.calendar{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden}.calendar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.calendar-title{font-size:1rem;font-weight:700;color:var(--text-primary)}.calendar-nav-btn{width:32px;height:32px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:1.1rem;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.calendar-nav-btn:hover{border-color:#2563eb;color:#2563eb}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-weekday{padding:10px 0;text-align:center;font-size:.75rem;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border)}.calendar-weekday--sat{color:#2563eb}.calendar-weekday--sun{color:#dc2626}.calendar-cell{aspect-ratio:1;border:none;border-right:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:4px 2px;cursor:default;position:relative}.calendar-cell:nth-child(7n){border-right:none}.calendar-cell--empty{background:#fafafa}.calendar-cell--day{cursor:pointer;transition:background .12s}.calendar-cell--day:hover{background:#f0f7ff}.calendar-cell--today .calendar-day-num{background:#2563eb;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.calendar-cell--selected{background:#eff6ff!important;outline:2px solid #2563eb;outline-offset:-2px}.calendar-cell--sat .calendar-day-num{color:#2563eb}.calendar-cell--sun .calendar-day-num{color:#dc2626}.calendar-cell--future{opacity:.45;pointer-events:none}.calendar-cell--worked{background:#f0fdf4}.calendar-cell--worked:hover{background:#dcfce7}.calendar-day-num{font-size:.82rem;font-weight:500;color:var(--text-primary);width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.calendar-day-hours{font-size:.62rem;color:#15803d;font-weight:600;line-height:1}.calendar-day-memo-dot{width:5px;height:5px;border-radius:50%;background:#f59e0b;flex-shrink:0}.calendar-legend{display:flex;gap:16px;padding:10px 16px;border-top:1px solid var(--border);background:#fafafa}.calendar-legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-muted)}.calendar-legend-dot{width:10px;height:10px;border-radius:2px}.calendar-legend-dot--worked{background:#bbf7d0;border:1px solid #16a34a}.calendar-legend-dot--memo{background:#fef3c7;border:1px solid #f59e0b;border-radius:50%}.calendar-detail{margin-top:20px;border:1px solid var(--border);border-radius:12px;padding:16px;background:#fff}.calendar-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.calendar-detail-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.calendar-detail-subtitle{font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 10px}.memo-section{display:flex;flex-direction:column;gap:16px}.memo-form{background:#f8fafc;border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:12px}.memo-textarea{width:100%;min-width:0;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:.9rem;font-family:inherit;color:var(--text-primary);background:#fff;resize:vertical;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.memo-textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.memo-form-row{display:flex;flex-direction:column;gap:6px}.memo-form-label{font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.memo-tc-group{display:flex;flex-wrap:wrap;gap:6px}.memo-tc-btn{padding:4px 12px;border:1px solid var(--border);border-radius:20px;background:#fff;font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all .15s}.memo-tc-btn:hover{border-color:#2563eb;color:#2563eb}.memo-tc-btn--active{background:#2563eb;border-color:#2563eb;color:#fff}.memo-select{padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:.88rem;font-family:inherit;color:var(--text-primary);background:#fff;cursor:pointer}.memo-form-actions{display:flex;justify-content:flex-end;gap:8px}.memo-list{display:flex;flex-direction:column;gap:10px}.memo-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.memo-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;min-height:24px}.memo-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.memo-author{font-size:.82rem;font-weight:600;color:var(--text-primary)}.memo-linked-record{font-size:.75rem;color:var(--text-muted);background:#f1f5f9;padding:2px 8px;border-radius:10px}.memo-card-actions{display:flex;gap:4px;flex-shrink:0}.btn-icon{background:none;border:none;cursor:pointer;font-size:.9rem;padding:2px 4px;border-radius:4px;opacity:.6;transition:opacity .15s}.btn-icon:hover{opacity:1}.memo-content{font-size:.92rem;color:var(--text-primary);line-height:1.6;white-space:pre-wrap;margin:0}.memo-timestamp{font-size:.72rem;color:var(--text-muted);align-self:flex-end}.memo-edit-form{display:flex;flex-direction:column;gap:8px}.history-tab-bar{display:flex;gap:4px;margin:12px 0 16px;border-bottom:2px solid var(--border)}.history-tab-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:.9rem;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s}.history-tab-btn:hover{color:var(--text-primary)}.history-tab-btn--active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.audit-log-list{display:flex;flex-direction:column;gap:12px}.audit-log-item{border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:8px;background:#fafafa}.audit-log-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.audit-log-target{font-weight:700;font-size:.9rem;color:var(--text-primary)}.audit-log-date{font-size:.8rem;color:var(--text-muted)}.audit-log-editor{font-size:.8rem;color:var(--text-secondary);margin-left:auto}.audit-log-note{font-size:.85rem;color:#92400e;background:#fef3c7;border:1px solid #fde68a;border-radius:6px;padding:6px 10px;margin:0}.audit-log-diff{display:flex;gap:10px;align-items:flex-start}.audit-diff-col{flex:1;display:flex;flex-direction:column;gap:4px}.audit-diff-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.audit-diff-before .audit-diff-label{color:#dc2626}.audit-diff-after .audit-diff-label{color:#15803d}.audit-diff-arrow{font-size:1.2rem;color:var(--text-muted);padding-top:18px;flex-shrink:0}.audit-snapshot{display:flex;flex-direction:column;gap:2px;margin:0;font-size:.8rem}.audit-snapshot-row{display:flex;gap:6px}.audit-snapshot-row dt{color:var(--text-muted);min-width:52px;flex-shrink:0}.audit-snapshot-row dd{color:var(--text-primary);margin:0;word-break:break-all}.role-badge{display:inline-block;padding:3px 12px;border-radius:12px;font-size:.8rem;font-weight:600}.role-badge--admin{background:#ede9fe;color:#6d28d9;border:1px solid #ddd6fe}.role-badge--staff{background:#f1f5f9;color:#475569;border:1px solid var(--border)}.account-card{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden}.account-row{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid #f1f5f9}.account-row:last-child{border-bottom:none}.account-label{font-size:.85rem;color:var(--text-muted);font-weight:500;min-width:100px;flex-shrink:0}.account-value{font-size:.9rem;color:var(--text-primary)}.account-row--edit{align-items:flex-start;flex-direction:column;gap:10px}@media (min-width: 640px){.account-row--edit{flex-direction:row;align-items:center}}.account-edit-field{flex:1;width:100%}.save-success{font-size:.875rem;color:#15803d;background:#dcfce7;border:1px solid #bbf7d0;border-radius:8px;padding:8px 14px;margin:0 20px 12px}.users-table .user-display-name{font-weight:600;color:var(--text-primary)}.users-table .user-email{font-size:.85rem;color:var(--text-secondary)}.users-table .user-date{font-size:.85rem;color:var(--text-muted);white-space:nowrap}.self-badge{display:inline-block;margin-left:8px;padding:1px 8px;background:#e0f2fe;color:#0369a1;border-radius:8px;font-size:.72rem;font-weight:600}.row-self td{background:#f8fafc}.role-promote{color:#6d28d9;border-color:#ddd6fe}.role-demote{color:#dc2626;border-color:#fecaca}.role-toggle-disabled{font-size:.78rem;color:var(--text-muted)}.users-note{font-size:.8rem;color:var(--text-muted);margin-top:12px;padding:0 4px;line-height:1.6}.btn-danger{color:#dc2626;border-color:#fecaca}.btn-danger:hover:not(:disabled){background:#fef2f2;border-color:#dc2626}.users-notes{display:flex;flex-direction:column;gap:4px;margin-top:14px}.account-row--wrap{flex-wrap:wrap;align-items:flex-start;gap:8px}.provider-linked{font-size:.85rem;font-weight:600;color:#15803d}.provider-action{display:flex;flex-direction:column;align-items:flex-start;gap:6px}.provider-error{font-size:.8rem;color:#dc2626;margin:0}.provider-success{font-size:.8rem;font-weight:600;color:#15803d;margin:0}.provider-link-form{display:flex;flex-direction:column;gap:12px;padding:16px 20px;background:#f8fafc;border-top:1px solid var(--border)}.provider-link-actions{display:flex;gap:8px;justify-content:flex-end}.section-desc{font-size:.85rem;color:var(--text-muted);margin:-12px 0 16px}.verify-link-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-page);padding:24px 16px}.verify-link-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:40px 32px;width:100%;max-width:420px;display:flex;flex-direction:column;gap:20px}.verify-link-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.verify-link-desc{font-size:.9rem;color:var(--text-muted);line-height:1.6;margin:0}.verify-link-success{font-size:1rem;font-weight:600;color:#15803d;margin:0}.link-form-note{font-size:.82rem;color:var(--text-muted);line-height:1.6;margin:0;padding:10px 12px;background:#f0f9ff;border-left:3px solid #38bdf8;border-radius:4px}.provider-linked-row{display:flex;align-items:center;gap:10px}.verify-login-icon{font-size:2.5rem;text-align:center}.verify-login-note{font-size:.82rem;color:var(--text-muted);line-height:1.7;background:#fffbeb;border-left:3px solid #f59e0b;border-radius:4px;padding:10px 12px}.verify-login-note p{margin:0}.verify-login-divider{border:none;border-top:1px solid var(--border);margin:4px 0}.invite-section{margin-top:24px;padding:20px;background:#f8faff;border:1px solid #dbeafe;border-radius:12px}.invite-title{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0 0 6px}.invite-desc{font-size:.82rem;color:var(--text-muted);margin:0 0 14px;line-height:1.6}.inline-action-form{margin:0;display:flex;flex-direction:column;gap:12px;width:100%}.inline-action-field{display:flex;flex-direction:column;gap:8px;min-width:0}.invite-label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.inline-action-input{width:100%;min-width:0;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:.9rem;color:var(--text-primary);background:#fff;transition:border-color .15s,box-shadow .15s;font-family:inherit}.inline-action-input::placeholder{color:#94a3b8}.inline-action-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.inline-action-button{width:100%}.invite-success{font-size:.85rem;color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;padding:8px 12px;margin-bottom:12px}@media (min-width: 640px){.inline-action-form{flex-direction:row;align-items:flex-end}.inline-action-field{flex:1}.inline-action-button{width:auto;flex-shrink:0}}.totp-icon{font-size:2.5rem;margin-bottom:8px}.totp-input{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:8px;font-size:1.5rem;font-weight:700;letter-spacing:.3em;text-align:center;color:var(--text-primary);background:#fff;transition:border-color .15s,box-shadow .15s;font-family:monospace}.totp-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.totp-fallback{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);text-align:center}.totp-fallback-label{font-size:.8rem;color:var(--text-muted);margin:0 0 8px}.totp-setup{padding:16px 20px 20px;display:flex;flex-direction:column;gap:12px}.totp-setup-desc{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.6}.totp-qr{width:180px;height:180px;border-radius:8px;border:1px solid var(--border);align-self:flex-start}.auth-logo{display:flex;align-items:center;gap:8px;justify-content:center;margin-bottom:20px}.auth-logo-icon{font-size:1.6rem}.auth-logo-name{font-size:1.2rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.auth-title{font-size:1.4rem;font-weight:700;color:var(--text-primary);margin:0 0 8px;text-align:center}.auth-desc{font-size:.85rem;color:var(--text-muted);line-height:1.7;margin:0 0 20px;text-align:center}.break-row{display:flex;align-items:center;gap:6px;margin-bottom:8px;flex-wrap:wrap}.break-row-num{font-size:.78rem;font-weight:600;color:var(--text-muted);min-width:48px;flex-shrink:0}.break-row-sep{color:var(--text-muted);flex-shrink:0}.break-row input[type=datetime-local]{flex:1;min-width:160px}.category-row{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap}.category-row:last-child{border-bottom:none}.category-row--inactive{opacity:.5}.category-order-btns{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.category-order-btn{padding:0 5px!important;font-size:.65rem!important;line-height:1.4!important;min-width:22px}.category-order-btn:disabled{opacity:.2;cursor:default}.category-id{font-size:.75rem;background:#f1f5f9;border-radius:4px;padding:2px 6px;color:var(--text-muted);font-family:monospace;flex-shrink:0;min-width:80px}.category-label-text{flex:1;font-weight:500}.category-edit-inline{flex:1;display:flex;gap:6px;align-items:center}.category-edit-inline input{flex:1}.category-actions{display:flex;gap:4px;flex-shrink:0}.expense-view-toggle{display:flex;gap:8px;margin-bottom:4px}.expense-pending-badge{display:inline-flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;font-size:.65rem;font-weight:700;border-radius:10px;min-width:16px;height:16px;padding:0 4px;margin-left:5px;vertical-align:middle}.expense-status{display:inline-block;font-size:.75rem;font-weight:600;border-radius:20px;padding:2px 10px}.expense-status--pending{background:#fef3c7;color:#92400e}.expense-status--approved{background:#d1fae5;color:#065f46}.expense-status--rejected{background:#fee2e2;color:#991b1b}.expense-modal{max-width:500px}.expense-form-section{display:flex;flex-direction:column;gap:10px}.expense-form-section-label{font-size:.82rem;font-weight:600;color:var(--color-text-muted, #64748b);letter-spacing:.04em;text-transform:uppercase;margin:0;display:flex;align-items:center;gap:6px}.expense-form-optional{font-size:.72rem;font-weight:500;color:#94a3b8;background:#f1f5f9;border-radius:4px;padding:1px 6px;text-transform:none;letter-spacing:0}.expense-chip-group{display:flex;flex-wrap:wrap;gap:8px}.expense-chip{display:flex;align-items:center;gap:5px;padding:7px 14px;border:1.5px solid #e2e8f0;border-radius:20px;background:#fff;color:#475569;font-size:.85rem;font-weight:500;cursor:pointer;transition:border-color .12s,background .12s,color .12s;white-space:nowrap}.expense-chip:hover{border-color:#cbd5e1;background:#f8fafc}.expense-chip--active{background:#fffbeb;border-color:#f59e0b;color:#92400e;font-weight:600}.expense-chip-icon{font-size:1rem;line-height:1}.expense-chip--work{border-color:#e2e8f0;color:#475569}.expense-chip--work:hover{border-color:#86efac;background:#f0fdf4;color:#166534}.expense-chip--work-active{background:#f0fdf4;border-color:#22c55e;color:#15803d;font-weight:600}.expense-amount-wrap{display:flex;align-items:stretch;border:1px solid var(--border, #e2e8f0);border-radius:8px;overflow:hidden;background:#fff}.expense-amount-prefix{padding:0 13px;background:#f8fafc;border-right:1px solid var(--border, #e2e8f0);color:#64748b;font-weight:700;font-size:1rem;display:flex;align-items:center;flex-shrink:0}.expense-amount-input{flex:1;border:none!important;border-radius:0!important;outline:none!important;box-shadow:none!important;text-align:right;font-size:1.05rem;font-variant-numeric:tabular-nums;padding-right:12px!important}.expense-amount-wrap:focus-within{border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px #3b82f626}.expense-review-note{font-size:.72rem;color:var(--text-muted);margin:2px 0 0}.expense-review-detail{display:flex;flex-direction:column;gap:8px;background:#f8faff;border-radius:8px;padding:14px 16px}.expense-review-detail>div{display:flex;gap:12px;align-items:baseline}.expense-review-detail .account-label{min-width:70px;flex-shrink:0}.history-layout{display:flex;gap:20px;align-items:flex-start}.history-main{flex:1;min-width:0}.history-sidebar{flex-shrink:0;width:224px}.history-selected-date{font-size:.9rem;font-weight:600;color:var(--text-primary, #1e293b)}@media (max-width: 640px){.history-layout{flex-direction:column-reverse}.history-sidebar{width:100%}}.mini-calendar{background:#fff;border:1px solid var(--border, #e2e8f0);border-radius:10px;padding:12px;font-size:.8rem}.mini-calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.mini-calendar-title{font-weight:600;font-size:.85rem;color:var(--text-primary, #1e293b)}.mini-calendar-nav{background:none;border:none;cursor:pointer;font-size:1.1rem;color:var(--text-muted, #64748b);padding:2px 6px;border-radius:4px;line-height:1;transition:background .15s}.mini-calendar-nav:hover{background:#f1f5f9;color:var(--text-primary, #1e293b)}.mini-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.mini-calendar-weekday{text-align:center;font-size:.7rem;font-weight:600;color:var(--text-muted, #64748b);padding:2px 0 4px}.mini-calendar-weekday--sat{color:#3b82f6}.mini-calendar-weekday--sun{color:#ef4444}.mini-calendar-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem;cursor:pointer;border:none;background:transparent;color:var(--text-primary, #1e293b);transition:background .12s,color .12s;padding:0;font-variant-numeric:tabular-nums}.mini-calendar-cell--empty{cursor:default}.mini-calendar-cell--day:not(:disabled):hover{background:#e0eaff}.mini-calendar-cell--sat{color:#3b82f6}.mini-calendar-cell--sun{color:#ef4444}.mini-calendar-cell--worked{background:#dcfce7;color:#166534;font-weight:600}.mini-calendar-cell--worked:not(:disabled):hover{background:#bbf7d0}.mini-calendar-cell--today{background:#3b82f6!important;color:#fff!important;font-weight:700}.mini-calendar-cell--today:not(:disabled):hover{background:#2563eb!important}.mini-calendar-cell--selected{background:#1e40af!important;color:#fff!important;font-weight:700}.mini-calendar-cell--selected:not(:disabled):hover{background:#1e3a8a!important}.mini-calendar-cell--future{color:#cbd5e1;cursor:default}.mini-calendar-cell:disabled{cursor:default}.page-back-nav{margin-bottom:16px}.page-back-link{display:inline-flex;align-items:center;gap:4px;font-size:.875rem;font-weight:500;color:var(--text-muted, #64748b);text-decoration:none;padding:6px 12px 6px 8px;border-radius:8px;transition:background .15s,color .15s}.page-back-link:hover{background:#f1f5f9;color:var(--text-primary, #1e293b)}.expense-action-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.expense-new-btn{white-space:nowrap;flex-shrink:0;width:auto}.admin-shortcuts{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.admin-shortcut-card{display:flex;align-items:center;gap:10px;padding:14px 20px;background:#fff;border:1.5px solid var(--border, #e2e8f0);border-radius:12px;text-decoration:none;color:var(--text-primary, #1e293b);font-weight:600;font-size:.9rem;transition:border-color .15s,box-shadow .15s,background .15s;min-width:140px}.admin-shortcut-card:hover{border-color:#3b82f6;background:#eff6ff;box-shadow:0 2px 8px #3b82f61f;color:#1e40af}.admin-shortcut-icon{font-size:1.3rem;line-height:1}.admin-filter-bar{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}.admin-filter-select{height:43px;padding:0 28px 0 10px;border:1px solid var(--border, #e2e8f0);border-radius:8px;background:#fff;font-size:.875rem;color:var(--text-primary, #1e293b);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.admin-filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.admin-filter-count{margin-left:auto;font-size:.85rem;color:var(--text-muted, #64748b);font-weight:500;white-space:nowrap}.admin-bulk-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#fff7ed;border:1.5px solid #fed7aa;border-radius:10px;margin-bottom:12px}.admin-bulk-label{font-size:.875rem;font-weight:600;color:#c2410c;flex:1}.select-col{width:36px;text-align:center;padding-left:12px!important;padding-right:4px!important}.select-col input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#3b82f6}.row-selected td{background:#eff6ff!important}.btn-danger{background:#ef4444;color:#fff;border:none;border-radius:8px;padding:7px 14px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s;font-family:inherit}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-danger:disabled{opacity:.6;cursor:not-allowed}
