:root{--bg:#faf9f7;--surface:#fff;--border:#e5e7eb;--text:#1f2937;--text-muted:#6b7280;--text-faint:#9ca3af;--accent:#2563eb;--accent-hover:#1d4ed8}*{box-sizing:border-box}html,body,#root{background:var(--bg);height:100%;color:var(--text);margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5}button{font:inherit;cursor:pointer}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.app{flex-direction:column;min-height:100%;display:flex}.header{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;justify-content:space-between;align-items:center;padding:12px 24px;display:flex;position:sticky;top:0}.header h1{margin:0;font-size:18px;font-weight:600}.header-actions{align-items:center;gap:12px;display:flex}.signout{border:1px solid var(--border);color:var(--text-muted);background:0 0;border-radius:6px;padding:6px 12px}.signout:hover{color:var(--text);border-color:var(--text-muted)}.main{flex:1;width:100%;max-width:960px;margin:0 auto;padding:24px}.nav-link{border:1px solid var(--border);color:var(--text-muted);border-radius:6px;padding:6px 10px;font-size:13px}.nav-link:hover{color:var(--text);border-color:var(--text-muted);text-decoration:none}.manage-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.manage-bar label,.add-form label{color:var(--text-muted);flex-direction:column;gap:4px;font-size:12px;display:flex}.manage-bar input[type=date],.add-form input[type=time],.add-form input[type=text],.add-form select{font:inherit;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:6px;padding:6px 8px}.add-form{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:12px;margin-top:24px;padding:16px;display:flex}.add-form h3{margin:0;font-size:14px;font-weight:600}.add-row{flex-wrap:wrap;gap:12px;display:flex}.add-form .notes-label,.add-form .notes-label input{width:100%}.add-form button[type=submit]{background:var(--accent);color:#fff;border:none;border-radius:6px;align-self:flex-start;padding:8px 16px;font-weight:500}.add-form button[type=submit]:hover:not(:disabled){background:var(--accent-hover)}.add-form button[type=submit]:disabled{opacity:.5;cursor:default}.event-list{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin:0;padding:0;list-style:none;overflow:hidden}.event-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 14px;font-size:13px;display:flex}.event-row:last-child{border-bottom:none}.event-time{font-variant-numeric:tabular-nums;color:var(--text);white-space:nowrap;font-size:12px;font-weight:600}.event-type{text-transform:capitalize;color:var(--text)}.event-sub{color:var(--text-muted)}.event-notes{color:var(--text-faint);text-overflow:ellipsis;white-space:nowrap;flex:1;font-style:italic;overflow:hidden}.edit-btn{border:1px solid var(--border);color:var(--text-muted);background:0 0;border-radius:6px;margin-left:auto;padding:4px 10px;font-size:12px}.edit-btn:hover{color:var(--accent);border-color:var(--accent)}.delete-btn{border:1px solid var(--border);color:var(--text-muted);background:0 0;border-radius:6px;padding:4px 8px;font-size:12px}.delete-btn:hover{color:#b91c1c;border-color:#fecaca}.modal-backdrop{z-index:100;background:#0006;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:12px;width:100%;max-width:480px;padding:20px;display:flex}.modal h3{margin:0;font-size:16px;font-weight:600}.modal label{color:var(--text-muted);flex-direction:column;gap:4px;font-size:12px;display:flex}.modal input[type=date],.modal input[type=time],.modal input[type=text],.modal select{font:inherit;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:6px;padding:6px 8px}.modal form{flex-direction:column;gap:12px;display:flex}.modal .add-row{flex-wrap:wrap;gap:12px;display:flex}.modal .notes-label,.modal .notes-label input{width:100%}.modal-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.modal-actions button{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:6px;padding:8px 16px;font-size:13px;font-weight:500}.modal-actions button[type=submit]{background:var(--accent);color:#fff;border-color:var(--accent)}.modal-actions button[type=submit]:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.modal-actions button:disabled{opacity:.5;cursor:default}.center{min-height:60vh;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.empty{text-align:center;color:var(--text-muted);padding:64px 16px}.empty .empty-icon{margin-bottom:8px;font-size:48px}.error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px;padding:12px 16px}.log-buttons-wrap{margin-bottom:20px}.log-buttons{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}@media (width>=560px){.log-buttons{grid-template-columns:repeat(4,1fr)}}.log-btn{background:var(--surface);border:1px solid var(--border);min-height:88px;color:var(--text);border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:18px 12px;transition:transform 50ms,border-color .15s,background .15s;display:flex}.log-btn:hover:not(:disabled){border-color:var(--accent)}.log-btn:active:not(:disabled){background:#f3f4f6;transform:scale(.98)}.log-btn:disabled{opacity:.5;cursor:default}.log-btn.pending{border-color:var(--accent);background:#eff6ff}.log-btn-icon{font-size:28px;line-height:1}.log-btn-label{font-size:13px;font-weight:500}.toast{border-radius:10px;align-items:center;gap:12px;margin-top:12px;padding:10px 14px;font-size:13px;display:flex}.toast-success{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0}.toast-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.toast-msg{flex:1}.toast-action{color:inherit;background:0 0;border:1px solid;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:500}.toast-action:hover{opacity:.85}.toast-dismiss{color:inherit;opacity:.7;background:0 0;border:none;padding:4px 6px;font-size:14px}.toast-dismiss:hover{opacity:1}.history-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;overflow-x:auto}.history-table{border-collapse:collapse;font-variant-numeric:tabular-nums;width:100%}.history-table th,.history-table td{text-align:center;border-bottom:1px solid var(--border);padding:8px 6px;font-size:14px}.history-table th{color:var(--text-muted);text-transform:none;font-size:12px;font-weight:600}.history-table tr:last-child td{border-bottom:none}.history-table .date-cell{text-align:left;white-space:nowrap;min-width:64px;color:var(--text);font-weight:500}.history-table .cell{min-width:56px}.history-table .cell.empty{color:var(--text-faint)}.history-table .cell.extra{color:var(--text-muted);white-space:nowrap;font-size:12px}.history-table .cell.has-annotation{cursor:help}.history-table .cell.has-annotation .annotation{color:var(--text-muted);font-size:11px;display:none}@media (hover:hover) and (pointer:fine){.history-table .cell.has-annotation:hover .annotation{display:inline}}.history-table .cell.has-annotation.revealed .annotation{display:inline}.legend{border-top:1px solid var(--border);color:var(--text-muted);flex-wrap:wrap;justify-content:center;gap:12px 20px;margin-top:12px;padding-top:10px;font-size:12px;display:flex}.legend-item{white-space:nowrap}.range-bar select{font:inherit;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:6px;padding:6px 8px}.report-summary-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;grid-template-columns:1fr;gap:12px;margin-bottom:16px;padding:16px 20px;display:grid}@media (width>=480px){.report-summary-card{grid-template-columns:1.4fr 1fr 1.2fr;gap:24px}}.report-summary-stat .stat-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:4px;font-size:11px}.report-summary-stat .stat-value{color:var(--text);font-size:18px;font-weight:600}.report-summary-stat .stat-sub{color:var(--text-muted);font-size:12px;font-weight:400}.history-table.report-table td.cell{vertical-align:top;padding:10px 6px}.history-table.report-table .cell-primary{color:var(--text);font-size:14px;font-weight:600}.history-table.report-table .cell-secondary{color:var(--text-muted);white-space:nowrap;margin-top:2px;font-size:11px}.history-table.report-table .cell.empty .cell-primary,.history-table.report-table .cell.empty .cell-secondary{color:var(--text-faint)}.report-extras{grid-template-columns:1fr;gap:16px;margin-top:20px;display:grid}@media (width>=640px){.report-extras{grid-template-columns:1fr 1fr}}.report-extra{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.report-extra h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin:0 0 10px;font-size:13px;font-weight:600}.weekday-pattern{border-collapse:collapse;font-variant-numeric:tabular-nums;width:100%;font-size:13px}.weekday-pattern td{vertical-align:middle;padding:3px 4px}.weekday-pattern .wd-name{width:36px;color:var(--text-muted)}.weekday-pattern .wd-blocks{letter-spacing:-1px;color:var(--accent);font-family:monospace}.weekday-pattern .wd-val{text-align:right;width:36px;color:var(--text)}.streak-line{color:var(--text);margin:4px 0;font-size:13px}
