: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}.env-banner{width:100%;padding:6px 16px;background:#fef3c7;color:#92400e;border-bottom:1px solid #f59e0b;font-size:.75rem;font-weight:700;text-align:center}.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)}.attendance-card-list{display:flex;flex-direction:column;gap:1px;background:var(--border);border-radius:8px;overflow:hidden;border:1px solid var(--border)}.attendance-card-select-all{display:flex;align-items:center;gap:8px;background:#f8fafc;padding:8px 14px;font-size:.78rem;color:var(--text-secondary);border-bottom:1px solid var(--border)}.attendance-card-select-all input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#3b82f6}.attendance-card{background:#fff;padding:12px 14px;display:flex;flex-direction:column;gap:6px}.attendance-card:hover{background:#f8fafc}.attendance-card--active{border-left:3px solid #22c55e}.attendance-card--selected{background:#eff6ff!important}.attendance-card-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.attendance-card-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#3b82f6;flex-shrink:0}.attendance-card-date{font-size:.85rem;font-weight:700;color:#0f172a}.attendance-card-user{font-size:.78rem;color:#64748b}.attendance-card-duration{margin-left:auto;font-size:.9rem;font-weight:700;color:#0f172a;white-space:nowrap}.attendance-card-metrics{margin-left:auto;display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}.attendance-card-metric{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid #e2e8f0;background:#f8fafc;color:#0f172a;font-size:.8rem;font-weight:700;white-space:nowrap}.attendance-card-metric--accent{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.attendance-card-metric-label{font-size:.68rem;font-weight:700;letter-spacing:.04em;color:#64748b}.attendance-card-metric--accent .attendance-card-metric-label{color:#2563eb}.attendance-card-metric-note{font-size:.68rem;font-weight:600;color:#15803d}.attendance-card-body{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.attendance-card-times{font-size:.82rem;color:#334155;white-space:nowrap}.attendance-card-time-label{font-size:.72rem;color:#94a3b8;margin-right:2px}.attendance-card-arrow{color:#94a3b8}.attendance-card-break{font-size:.75rem;color:#c2410c;background:#fff7ed;padding:2px 7px;border-radius:99px;white-space:nowrap}.attendance-card-actions{margin-left:auto;display:flex;gap:6px;flex-shrink:0}.attendance-card-memo{font-size:.78rem;color:#475569;line-height:1.5;white-space:pre-wrap;word-break:break-word;border-left:2px solid #e2e8f0;padding-left:8px;margin:0}.attendance-card-memo--clamped{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.attendance-card-memo-wrap{position:relative}.attendance-card-memo-toggle{display:block;width:24px;height:24px;background:none;border:1px solid #e2e8f0;border-radius:50%;padding:0;cursor:pointer;margin-left:auto;margin-top:4px;position:relative;transition:background .15s}.attendance-card-memo-toggle:hover{background:#f1f5f9}.attendance-card-memo-toggle:after{content:"";display:block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid #94a3b8;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transition:transform .2s}.attendance-card-memo-toggle--open:after{transform:translate(-50%,-50%) rotate(180deg)}.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}.tc-toggle-btn--active:hover{color:#fff;background:#1d4ed8;border-color:#1d4ed8}.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}.history-summary-panel{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:16px}.history-summary-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.history-summary-title{margin:0;font-size:1rem;font-weight:700;color:var(--text-primary)}.history-summary-caption{margin:4px 0 0;font-size:.82rem;color:var(--text-muted)}.history-range-inputs{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;margin-bottom:14px}.history-range-field{display:flex;flex-direction:column;gap:6px;min-width:152px}.history-range-label{font-size:.76rem;font-weight:600;color:var(--text-muted)}.history-range-input{height:40px;border:1px solid var(--border);border-radius:8px;padding:0 12px;font-size:.9rem;color:var(--text-primary);background:#fff;font-family:inherit}.history-range-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.history-range-separator{font-size:1rem;color:var(--text-muted);line-height:40px}.history-summary-grid{grid-template-columns:repeat(3,1fr)}.history-summary-note{margin:12px 0 0;font-size:.8rem;color:var(--text-muted);text-align:right}.history-calendar-view{display:flex;flex-direction:column;gap:16px}@media (max-width: 720px){.history-summary-grid{grid-template-columns:1fr}.history-range-separator{display:none}.history-range-field{width:100%}}.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:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:2px;padding:8px;border:1px solid transparent;border-radius:12px;transition:border-color .15s,background .15s,box-shadow .15s}.reason-preset-group--error{border-color:#fecaca;background:#fef2f2;box-shadow:inset 0 0 0 1px #dc26260a}.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:hover{border-color:#7c3aed;color:#fff}.reason-preset-btn:focus-visible{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed29}.reason-preset-group--error .reason-preset-btn:focus-visible{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261f}.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;overflow-y:auto;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:50%;width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text-muted);cursor:pointer;flex-shrink:0;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-error{font-size:.78rem;color:#dc2626;margin:4px 0 0;line-height:1.4;font-weight:600}.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}.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,minmax(0,1fr));align-items:stretch}.calendar-weekday{padding:10px 0;text-align:center;font-size:.75rem;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);min-width:0}.calendar-weekday--sat{color:#2563eb}.calendar-weekday--sun{color:#dc2626}.calendar-cell{min-height:112px;border:none;border-right:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9;background:#fff;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:5px;padding:8px;cursor:default;position:relative;min-width:0;text-align:left;font-family:inherit}.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:not(.calendar-cell--worked){opacity:.45}.calendar-cell:disabled{cursor:default}.calendar-cell--worked{background:#f0fdf4}.calendar-cell--worked:hover{background:#dcfce7}.calendar-cell--active{background:#fff7ed}.calendar-cell--active:hover{background:#ffedd5}.calendar-day-top{display:flex;align-items:center;justify-content:space-between;gap:4px;min-width:0}.calendar-day-num{font-size:.82rem;font-weight:700;color:var(--text-primary);width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.calendar-day-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:20px;padding:0 6px;border-radius:999px;background:#dcfce7;color:#166534;font-size:.68rem;font-weight:700;white-space:nowrap}.calendar-day-shift{display:flex;flex-direction:column;gap:2px;min-width:0}.calendar-day-shift-row{color:var(--text-secondary);font-size:.68rem;font-weight:600;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-day-hours{width:fit-content;min-width:0;max-width:100%;border-radius:6px;background:#dcfce7;padding:2px 5px;font-size:.68rem;color:#15803d;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-day-break{color:#64748b;font-size:.66rem;font-weight:600;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-day-memo-dot{position:absolute;right:7px;bottom:7px;width:7px;height:7px;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--active{background:#fed7aa;border:1px solid #f97316}.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;gap:12px;flex-wrap:wrap;margin-bottom:16px}.calendar-detail-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.calendar-detail-meta{margin:4px 0 0;font-size:.82rem;color:var(--text-muted)}.calendar-detail-subtitle{font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 10px}@media (max-width: 720px){.calendar-header{padding:12px}.calendar-weekday{padding:8px 0;font-size:.7rem}.calendar-cell{min-height:72px;padding:5px 4px;gap:3px}.calendar-day-num{width:22px;height:22px;font-size:.76rem}.calendar-day-count,.calendar-day-shift,.calendar-day-break{display:none}.calendar-day-hours{width:100%;padding:1px 4px;font-size:.58rem;text-align:center}.calendar-legend{flex-wrap:wrap;gap:8px 12px}}@media (max-width: 420px){.calendar-cell{min-height:58px}.calendar-day-hours{font-size:.55rem}}.admin-attendance-calendar-view{display:flex;flex-direction:column;gap:16px}.admin-attendance-calendar .calendar-cell--worked{background:#f0fdf4}.admin-attendance-calendar .calendar-cell--active{background:#fff7ed}.admin-calendar-cell{min-height:124px}.admin-calendar-count-line{display:flex;gap:4px;flex-wrap:wrap;min-width:0}.admin-calendar-count-badge{display:inline-flex;align-items:center;width:fit-content;max-width:100%;border-radius:999px;background:#e0f2fe;color:#0369a1;padding:2px 6px;font-size:.66rem;font-weight:700;line-height:1.2;white-space:nowrap}.admin-calendar-count-badge--records{background:#dbeafe;color:#1d4ed8}.admin-calendar-count-badge--users{background:#ede9fe;color:#6d28d9}.admin-calendar-active-badge{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:20px;padding:0 6px;border-radius:999px;background:#fed7aa;color:#c2410c;font-size:.66rem;font-weight:700;white-space:nowrap}.admin-calendar-detail{margin-top:0}.admin-calendar-detail-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:16px}.admin-calendar-detail-summary>span{display:flex;flex-direction:column;gap:4px;border:1px solid var(--border);border-radius:8px;background:#f8fafc;padding:10px 12px;color:var(--text-primary);font-size:1rem;font-weight:800;min-width:0}.admin-calendar-detail-summary-label{color:var(--text-muted);font-size:.72rem;font-weight:700}.admin-calendar-detail-summary-accent{background:#eff6ff!important;border-color:#bfdbfe!important;color:#1d4ed8!important}@media (max-width: 920px){.admin-calendar-cell{min-height:88px;padding:6px 5px}.admin-attendance-calendar .calendar-day-shift,.admin-attendance-calendar .calendar-day-break{display:none}.admin-calendar-count-badge{padding:1px 5px;font-size:.6rem}.admin-attendance-calendar .calendar-day-hours{width:100%;text-align:center;font-size:.6rem}}@media (max-width: 720px){.admin-calendar-cell{min-height:72px}.admin-calendar-count-line{display:none}.admin-calendar-active-badge{min-width:0;width:7px;height:7px;padding:0;color:transparent;border-radius:50%;overflow:hidden}.admin-calendar-detail-summary{grid-template-columns:1fr}}.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-tc-btn--active:hover{color:#fff;background:#1d4ed8;border-color:#1d4ed8}.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-top-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.history-top-row>.btn{flex-shrink:0;width:auto;min-width:180px}.history-tab-bar{display:flex;gap:4px;margin:12px 0 16px;border-bottom:2px solid var(--border);flex:0 0 auto}.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;white-space:nowrap}.history-tab-btn:hover{color:var(--text-primary)}.history-tab-btn--active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}@media (max-width: 520px){.history-top-row{flex-direction:column;align-items:stretch;gap:8px;margin-bottom:16px}.history-top-row .history-tab-bar{margin-bottom:0}.history-top-row>.btn{width:100%;margin-top:0}}.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}.deleted-badge{display:inline-block;margin-left:8px;padding:1px 8px;background:#fee2e2;color:#b91c1c;border-radius:8px;font-size:.72rem;font-weight:600}.deleted-users-section,.pending-invitations{margin-top:24px}.existing-account-dialog{margin-top:24px;padding:16px 20px;background:#fffbeb;border:1px solid #fcd34d;border-radius:10px}.existing-account-actions{display:flex;flex-direction:column;gap:8px;margin-top:12px}.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}.btn-warning{color:#d97706;border-color:#fde68a}.btn-warning:hover:not(:disabled){background:#fffbeb;border-color:#d97706}.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-card{background:#f8fafc;border:1px solid var(--border);border-radius:8px;padding:10px 12px;margin-bottom:8px}.break-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.break-card-label{font-size:.78rem;font-weight:600;color:var(--text-muted)}.break-card-fields{display:flex;flex-direction:column;gap:6px}.break-card-field{display:flex;align-items:center;gap:8px}.break-card-field-label{font-size:.78rem;color:var(--text-muted);width:28px;flex-shrink:0}.break-card-field input{flex:1}.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,minmax(0,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}.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}.admin-tab-bar{display:flex;gap:0;background:transparent;border-bottom:2px solid var(--border, #e2e8f0);padding:0;margin-bottom:24px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.admin-tab-bar::-webkit-scrollbar{display:none}.admin-tab-btn{display:flex;align-items:center;gap:6px;flex:1;min-width:80px;padding:10px 14px;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;border-radius:0;background:transparent;font-size:.84rem;font-weight:500;color:var(--text-muted, #94a3b8);cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;font-family:inherit;justify-content:center}.admin-tab-btn:hover:not(.admin-tab-btn--active){color:var(--text-secondary, #475569);background:transparent}.admin-tab-btn--active{background:transparent;color:#1e40af;font-weight:700;border-bottom-color:#1e40af;box-shadow:none}.admin-tab-icon{font-size:.95rem;line-height:1}.admin-tab-label{line-height:1}.audit-log-toggle{width:100%;display:flex;align-items:center;gap:8px;padding:12px 16px;border:none;background:transparent;cursor:pointer;text-align:left;font-family:inherit;flex-wrap:wrap}.audit-log-toggle:hover{background:var(--surface-2, #f8fafc)}.audit-log-item{border:1px solid var(--border, #e2e8f0);border-radius:10px;margin-bottom:8px;overflow:hidden;background:#fff}.audit-log-item--expanded{border-color:#bfdbfe}.audit-log-body{padding:4px 16px 16px;border-top:1px solid var(--border, #e2e8f0)}.audit-log-chevron{margin-left:auto;font-size:.7rem;color:var(--text-muted, #94a3b8)}.audit-action-badge{display:inline-block;font-size:.7rem;font-weight:700;padding:2px 7px;border-radius:20px;flex-shrink:0}.audit-action-edit{background:#dbeafe;color:#1d4ed8}.audit-action-create{background:#dcfce7;color:#15803d}.audit-action-delete{background:#fee2e2;color:#b91c1c}.memo-date-badge{font-size:.78rem;color:var(--text-muted, #64748b);background:var(--surface-2, #f1f5f9);padding:2px 8px;border-radius:20px}.delete-confirm-card{margin:0 20px 4px;padding:14px 16px;background:#fff1f2;border:1.5px solid #fecdd3;border-radius:10px}.delete-confirm-title{font-size:.95rem;font-weight:700;color:#be123c;margin-bottom:4px}.delete-confirm-desc{font-size:.82rem;color:#9f1239;margin-bottom:12px}.delete-confirm-actions{display:flex;gap:8px;justify-content:flex-end}.modal-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 16px;border-top:1px solid var(--border, #e2e8f0);background:var(--surface-1, #fff)}.modal-footer .btn{padding:8px 12px;font-size:.85rem;min-width:auto}.modal-footer-right{display:flex;gap:8px;margin-left:auto}.modal-delete-btn{color:#ef4444!important;font-size:.82rem!important}.modal-delete-btn:hover{background:#fee2e2!important}.data-block{display:flex;flex-direction:column;gap:12px}.data-divider{border:none;border-top:1px solid var(--border, #e2e8f0);margin:8px 0}.import-upload-label{display:inline-flex;align-items:center;gap:8px;cursor:pointer}.import-upload-text{display:inline-block;padding:8px 14px;font-size:.85rem;font-weight:500;border:1px solid var(--border, #e2e8f0);border-radius:6px;background:#f8fafc;color:var(--text-primary);transition:background .15s}.import-upload-label:hover .import-upload-text{background:#f1f5f9}.import-file-input{display:none}.import-success{font-size:.85rem;color:#16a34a;font-weight:500;margin-top:4px}.import-preview{margin-top:16px;display:flex;flex-direction:column;gap:12px}.import-preview-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.import-preview-count{font-size:.85rem;font-weight:500;color:var(--text-primary)}.import-preview-errors{color:#dc2626;font-weight:600;margin-left:4px}.import-preview-pending{color:#c2410c;font-weight:600;margin-left:4px}.import-preview-dup{color:#475569;font-weight:600;margin-left:4px}.import-row-error{background:#fff5f5;color:#7f1d1d}.import-row-warn{background:#fffbeb;color:#78350f}.import-badge{display:inline-block;font-size:.72rem;font-weight:600;padding:2px 7px;border-radius:4px;white-space:nowrap}.import-badge--ok{background:#dcfce7;color:#15803d}.import-badge--error{background:#fee2e2;color:#b91c1c;cursor:help}.import-badge--pending{background:#fff7ed;color:#c2410c;cursor:help}.import-badge--dup{background:#f1f5f9;color:#475569;cursor:help}.import-history-section{margin-top:8px}.dc-stack{display:flex;flex-direction:column;gap:20px}.data-card{border:1px solid var(--border, #e2e8f0);border-radius:10px;overflow:hidden;background:var(--surface, #fff)}.data-card-header{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border, #e2e8f0)}.data-card-icon{font-size:1rem;line-height:1}.data-card-title{margin:0;font-size:.95rem;font-weight:700}.data-card-header--att{background:#eff6ff;color:#1d4ed8}.data-card-header--memo{background:#f0fdf4;color:#15803d}.data-card-header--exp{background:#fefce8;color:#b45309}.data-card-header--history{background:#f8fafc;color:#475569}.data-card-body{display:grid;grid-template-columns:1fr auto 1fr;align-items:flex-start}.data-card-col{padding:18px 20px;display:flex;flex-direction:column;gap:12px}.data-card-sep{width:1px;background:var(--border, #e2e8f0);margin:12px 0;align-self:stretch}.data-card-body--full{padding:16px 20px}.data-card-body--backup{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;flex-wrap:wrap}.data-col-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin:0 0 2px}.import-history-empty{font-size:.85rem;color:var(--text-secondary);padding:8px 0}.import-error-detail{background:#fff5f5;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;display:flex;flex-direction:column;gap:4px}.import-error-detail-title{font-size:.8rem;font-weight:600;color:#dc2626;margin-bottom:4px}.import-error-detail-item{font-size:.8rem;color:#7f1d1d}.history-record-count{font-size:.82rem;color:var(--text-muted, #64748b);margin-bottom:8px;text-align:right}.header-clock-wrap{display:flex;align-items:center;gap:6px;font-size:.78rem;line-height:1}.header-clock-date{color:var(--text-muted);font-weight:400}.header-clock-time{color:var(--text-secondary);font-weight:500;font-variant-numeric:tabular-nums;letter-spacing:.04em;font-family:SF Mono,Fira Code,Menlo,monospace}.header-clock-sep{width:1px;height:14px;background:var(--border);flex-shrink:0}.about-hero{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 0 8px}.about-app-icon{width:64px;height:64px;border-radius:16px;background:#eff6ff;border:1px solid #bfdbfe;display:flex;align-items:center;justify-content:center;color:#2563eb}.about-app-name{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:.01em}.about-version{font-size:.82rem;color:var(--text-muted);margin:0}.about-release-shell{display:flex;flex-direction:column;gap:16px}.about-release-spotlight{position:relative;overflow:hidden;padding:20px;border-radius:24px;border:1px solid #cbdafc;background:radial-gradient(circle at top right,rgba(59,130,246,.18),transparent 32%),linear-gradient(135deg,#eff6ff,#fff 52%,#f8fbff);box-shadow:0 16px 32px #2563eb14}.about-release-spotlight:after{content:"";position:absolute;inset:auto -28px -40px auto;width:120px;height:120px;border-radius:999px;background:#2563eb14}.about-release-kicker-row{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.about-release-kicker{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#ffffffe0;border:1px solid rgba(59,130,246,.16);color:#1d4ed8;font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.about-release-spotlight-main{position:relative;z-index:1;display:flex;flex-direction:column;gap:10px}.about-release-version--hero{align-self:flex-start;box-shadow:0 8px 18px #2563eb1f}.about-release-spotlight-title{margin:0;font-size:1.18rem;font-weight:800;line-height:1.35;color:var(--text-primary)}.about-release-spotlight-summary{margin:0;max-width:38rem;color:#385274;font-size:.94rem;line-height:1.7}.about-release-chip-row{position:relative;z-index:1;display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.about-release-chip{display:inline-flex;align-items:center;padding:7px 11px;border-radius:999px;background:#ffffffd1;border:1px solid rgba(148,163,184,.24);color:#334155;font-size:.78rem;font-weight:600}.about-release-detail-card{position:relative;z-index:1;margin-top:18px;padding:16px 18px;border-radius:18px;background:#ffffffc7;border:1px solid rgba(148,163,184,.18);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.about-release-card{gap:0}.about-release-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.about-release-desc{margin:0;font-size:.84rem;color:var(--text-muted)}.about-release-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}.about-release-entry{position:relative;scroll-margin-top:88px;padding:18px 0 0 18px;border-top:1px solid var(--border)}.about-release-entry:before{content:"";position:absolute;left:0;top:20px;width:8px;height:8px;border-radius:999px;background:#2563eb;box-shadow:0 0 0 6px #2563eb1a}.about-release-entry:first-child{padding-top:0;border-top:none}.about-release-entry:first-child:before{top:2px}.about-release-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.about-release-entry-heading{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.about-release-version{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-size:.8rem;font-weight:700}.about-release-entry-title{font-size:.95rem;font-weight:700;color:var(--text-primary)}.about-release-date{font-size:.78rem;color:var(--text-muted)}.about-release-entry-summary{margin:0 0 10px;color:var(--text-muted);font-size:.88rem;line-height:1.65}.about-release-points{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:8px;color:var(--text-primary);font-size:.9rem;line-height:1.6}.about-release-points--hero{padding-left:20px}.about-release-past{padding:20px;border-radius:16px;border:1px solid #e5e7eb;background:#fff}.about-release-past-title{margin:6px 0 10px;font-size:1rem;font-weight:600;color:var(--text-primary)}@media (max-width: 640px){.about-release-spotlight{padding:18px;border-radius:20px}.about-release-kicker-row,.about-release-meta{align-items:flex-start;flex-direction:column}.about-release-entry{padding-left:16px}.about-release-detail-card{padding:14px 16px}}.notif-bell-wrap{position:relative;display:flex;align-items:center}.notif-bell-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;border-radius:8px;cursor:pointer;color:var(--text-secondary, #666);transition:background .15s,color .15s;padding:0}.notif-bell-btn:hover{background:var(--bg-hover, #f0f0f0);color:var(--text-primary, #111)}.notif-badge{position:absolute;top:3px;right:3px;min-width:16px;height:16px;padding:0 3px;background:#e53e3e;color:#fff;font-size:.62rem;font-weight:700;line-height:16px;border-radius:8px;text-align:center;pointer-events:none}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-width:calc(100vw - 24px);background:#fff;border:1px solid var(--border, #e2e8f0);border-radius:12px;box-shadow:0 8px 24px #0000001f;z-index:200;overflow:hidden}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 10px;border-bottom:1px solid var(--border, #e2e8f0)}.notif-panel-title{font-size:.9rem;font-weight:600;color:var(--text-primary, #111)}.notif-mark-read-btn{border:none;background:transparent;font-size:.75rem;color:var(--primary, #3b82f6);cursor:pointer;padding:2px 4px;border-radius:4px}.notif-mark-read-btn:hover{background:var(--bg-hover, #f0f0f0)}.notif-list{list-style:none;margin:0;padding:0;max-height:360px;overflow-y:auto}.notif-empty{padding:24px 16px;text-align:center;color:var(--text-muted, #999);font-size:.85rem;margin:0}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border, #e2e8f0);cursor:default;transition:background .1s}.notif-item:last-child{border-bottom:none}.notif-item[role=button]{cursor:pointer}.notif-item[role=button]:hover{background:var(--bg-hover, #f7f7f7)}.notif-item--unread{background:#eff6ff}.notif-item--unread:hover{background:#dbeafe}.notif-item--dismissed{opacity:.5}.notif-item--dismissed .notif-item-title{text-decoration:line-through}.notif-show-all-btn{display:block;width:100%;padding:10px 16px;border:none;border-top:1px solid var(--border, #e2e8f0);background:transparent;font-size:.78rem;color:var(--text-secondary, #666);cursor:pointer;text-align:center;transition:background .1s}.notif-show-all-btn:hover{background:var(--bg-hover, #f7f7f7)}.notif-item-icon-wrap{flex-shrink:0;width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-top:1px}.notif-icon--announcement{background:#fef3c7;color:#d97706}.notif-icon--expense_pending{background:#fee2e2;color:#dc2626}.notif-icon--expense_reviewed{background:#dcfce7;color:#16a34a}.notif-item-icon{width:16px;height:16px}.notif-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.notif-item-title{font-size:.82rem;font-weight:600;color:var(--text-primary, #111);line-height:1.3}.notif-item-desc{font-size:.76rem;color:var(--text-secondary, #666);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-item-right{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px}.notif-item-time{font-size:.7rem;color:var(--text-muted, #999);white-space:nowrap}.notif-dismiss-btn{border:none;background:transparent;font-size:.85rem;color:var(--text-muted, #bbb);cursor:pointer;padding:0 2px;line-height:1;border-radius:3px;opacity:0;transition:opacity .15s,color .15s}.notif-item:hover .notif-dismiss-btn{opacity:1}.notif-dismiss-btn:hover{color:var(--text-secondary, #666)}.receipt-upload-area{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start}.receipt-preview-wrap{position:relative;width:80px;height:80px;border-radius:8px;overflow:hidden;border:1px solid #e2e8f0;flex-shrink:0}.receipt-preview-img{width:100%;height:100%;object-fit:cover;display:block}.receipt-remove-btn{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;background:#0000008c;color:#fff;border:none;font-size:.65rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.receipt-add-btn{width:80px;height:80px;border:2px dashed #cbd5e1;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;font-size:.72rem;color:#64748b;transition:border-color .15s,background .15s;flex-shrink:0}.receipt-add-btn:hover{border-color:#94a3b8;background:#f8fafc}.receipt-add-btn span:first-child{font-size:1.4rem}.receipt-preview-list{margin-top:12px}.expense-delete-confirm{margin-top:16px;padding:12px 14px;background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;font-size:.85rem;color:#be123c}.expense-delete-confirm p{margin:0 0 10px}.expense-delete-confirm-btns{display:flex;gap:8px;justify-content:flex-end}.ann-form-heading{font-size:14px;font-weight:600;color:var(--text-primary, #1a1a1a);margin-bottom:16px}.ann-mode-tabs{display:flex;gap:8px;margin-bottom:12px}.ann-mode-tab{padding:6px 14px;font-size:13px;font-weight:500;border:1px solid var(--border, #e2e8f0);border-radius:20px;background:transparent;color:var(--text-secondary, #475569);cursor:pointer;transition:background .15s,color .15s}.ann-mode-tab:hover:not(:disabled){background:var(--bg-subtle, #f8fafc)}.ann-mode-tab--active{background:var(--color-primary, #4f46e5);color:#fff;border-color:var(--color-primary, #4f46e5)}.ann-mode-tab--active:hover:not(:disabled){background:var(--color-primary, #4f46e5)}.ann-mode-note{font-size:12px;color:var(--text-secondary, #475569);background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:8px 12px;margin-bottom:12px;line-height:1.6}.ann-form-row{display:flex;gap:12px}.ann-select{width:100%;padding:8px 10px;border:1px solid var(--border-color, #e0e0e0);border-radius:8px;font-size:14px;background:var(--bg-input, #fff);color:var(--text-primary, #1a1a1a)}.ann-email-toggle{margin-top:4px;margin-bottom:4px}.ann-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text-primary, #1a1a1a);-webkit-user-select:none;user-select:none}.ann-toggle-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary, #4f46e5)}.ann-email-note{font-size:12px;color:var(--text-secondary, #666);margin-top:6px;padding:8px 10px;background:var(--bg-subtle, #f5f5f5);border-radius:6px}.ann-recipient-mode{display:flex;gap:16px;margin-top:10px;margin-bottom:4px}.ann-recipient-radio{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer}.ann-recipient-radio input[type=radio]{accent-color:var(--color-primary, #4f46e5);cursor:pointer}.ann-user-list{margin-top:8px;border:1px solid var(--border, #e2e8f0);border-radius:8px;overflow:hidden}.ann-user-list-header{background:var(--bg-subtle, #f8fafc);border-bottom:1px solid var(--border, #e2e8f0);padding:0}.ann-user-list-body{max-height:220px;overflow-y:auto}.ann-user-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;font-size:13px}.ann-user-item:hover{background:var(--bg-subtle, #f8fafc)}.ann-user-item input[type=checkbox]{flex-shrink:0;accent-color:var(--color-primary, #4f46e5);cursor:pointer}.ann-user-item--disabled{opacity:.5;cursor:default}.ann-user-item--disabled:hover{background:transparent}.ann-user-item--disabled input[type=checkbox]{cursor:not-allowed}.ann-user-name{font-weight:500;color:var(--text-primary, #0f172a);min-width:80px}.ann-user-email{color:var(--text-secondary, #475569);font-size:12px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ann-user-optout{font-size:11px;color:var(--text-muted, #94a3b8);background:#f1f5f9;border-radius:4px;padding:2px 6px;white-space:nowrap}.ann-result-box{margin-top:16px;padding:12px 16px;background:var(--color-success-bg, #f0fdf4);border:1px solid var(--color-success-border, #bbf7d0);border-radius:8px}.ann-result-title{font-size:14px;font-weight:600;color:var(--color-success, #15803d);margin-bottom:6px}.ann-result-list{list-style:none;padding:0;margin:0;font-size:13px;color:var(--text-secondary, #444);display:flex;flex-direction:column;gap:2px}.ann-result-error{color:var(--color-danger, #dc2626)}.ann-result-sub{font-size:13px;color:var(--text-secondary, #666);margin:0}.ann-history-title{font-size:14px;font-weight:600;color:var(--text-secondary, #555);margin-bottom:10px}.ann-history-item{padding:14px 20px}.ann-history-item--border{border-bottom:1px solid var(--border-color, #e8e8e8)}.ann-history-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.ann-history-date{font-size:12px;color:var(--text-secondary, #888);margin-left:auto}.ann-history-title-text{font-size:14px;font-weight:500;color:var(--text-primary, #1a1a1a);margin:0 0 4px}.ann-history-email-row{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary, #666);margin-top:4px}.ann-history-email-label{color:var(--text-secondary, #888)}.ann-history-stats{color:var(--text-secondary, #888);margin-left:4px}.ann-kind-badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px;line-height:1.6}.ann-kind-badge--update{background:var(--bg-subtle, #f0f0f0);color:var(--text-secondary, #555)}.ann-kind-badge--important{background:#fef3c7;color:#92400e}.ann-confirm-row{display:flex;align-items:baseline;gap:12px;padding:8px 0;border-bottom:1px solid var(--border-color, #eee);font-size:14px}.ann-confirm-label{font-size:12px;color:var(--text-secondary, #888);min-width:72px;flex-shrink:0}.ann-confirm-value{color:var(--text-primary, #1a1a1a);font-weight:500}.ann-confirm-body{margin-top:12px}.ann-confirm-body-text{font-size:13px;color:var(--text-primary, #333);white-space:pre-wrap;background:var(--bg-subtle, #f5f5f5);border-radius:6px;padding:10px 12px;max-height:160px;overflow-y:auto;margin:0}.ann-confirm-warn{margin-top:12px;font-size:12px;color:var(--color-warning, #b45309);background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:8px 10px}.toggle-switch{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-switch input[type=checkbox]{display:none}.toggle-switch__track{position:relative;width:40px;height:22px;border-radius:11px;background:#ccc;transition:background .2s;flex-shrink:0}.toggle-switch__track:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000040;transition:transform .2s}.toggle-switch input:checked~.toggle-switch__track{background:var(--color-primary, #4f46e5)}.toggle-switch input:checked~.toggle-switch__track:after{transform:translate(18px)}.toggle-switch input:disabled~.toggle-switch__track{opacity:.5;cursor:not-allowed}.toggle-switch__label{font-size:13px;color:var(--text-secondary, #666);min-width:64px}
