:root{--bg: #eff2eb;--bg-card: #ffffff;--bg-surface: #f5f7f1;--bg-subtle: #e8ecde;--bg-hover: #e2ead6;--border: #cdd6bc;--border-in: #b8c4a3;--tx: #232d1a;--tx-md: #3d4e2e;--tx-muted: #607050;--tx-faint: #8c9e7a;--shadow: rgba(35,45,20,.08);--primary: #3d6b2a;--primary-lt: #e2ead6;--sidebar-bg: #2c4220;--accent: #3d6b2a;--bd: #cdd6bc}[data-theme=dark]{--bg: #111709;--bg-card: #182210;--bg-surface: #1e2c14;--bg-subtle: #243318;--bg-hover: #1f2e13;--border: #2d3f1e;--border-in: #374c27;--tx: #cdd8bc;--tx-md: #a4b590;--tx-muted: #718460;--tx-faint: #4d5e3c;--shadow: rgba(0,0,0,.45);--primary: #7cb54e;--primary-lt: #243318;--sidebar-bg: #131c0c;--accent: #7cb54e;--bd: #2d3f1e}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;background:var(--bg);color:var(--tx);line-height:1.5}.app-layout{display:flex;flex-direction:row;min-height:100vh}.content-area{flex:1;min-width:0;overflow-y:auto;height:100vh}.main-content{max-width:1100px;width:100%;margin:0 auto;padding:1.5rem 1.5rem 3rem}.sidebar{width:220px;flex-shrink:0;background:var(--sidebar-bg);min-height:100vh;height:100vh;display:flex;flex-direction:column;z-index:950;padding:1.25rem .75rem;position:sticky;top:0;overflow-y:auto}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:0 .5rem 1.5rem}.sidebar-logo{flex-shrink:0}.sidebar-brand-name{font-size:15px;font-weight:700;color:#fff;letter-spacing:-.01em}.sidebar-section{margin-bottom:1.5rem}.sidebar-section-label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#ffffff73;padding:0 .5rem;margin-bottom:.35rem}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;text-decoration:none;font-size:14px;font-weight:500;color:#ffffffb3;transition:background .15s,color .15s;margin-bottom:2px}.sidebar-link:hover{background:#ffffff1f;color:#fff}.sidebar-link--active{background:#fff3;color:#fff}.sidebar-link-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-toggle{display:flex;align-items:center;gap:8px;margin-top:auto;padding:10px 12px;border-radius:8px;cursor:pointer;color:#ffffff73;font-size:13px;background:none;border:none;width:100%;transition:background .15s,color .15s}.sidebar-toggle:hover{background:#ffffff1a;color:#ffffffd9;filter:none}.sidebar{transition:width .22s ease;overflow:hidden}.sidebar--collapsed{width:64px}.sidebar--collapsed .sidebar-brand{justify-content:center;padding-bottom:1.5rem}.sidebar--collapsed .sidebar-link{justify-content:center;padding:9px}.sidebar--collapsed .sidebar-toggle{justify-content:center;padding:10px}.page>h1{font-size:22px;font-weight:700;margin-bottom:1.25rem}.page>h2{font-size:16px;font-weight:600;margin:1.5rem 0 .75rem}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.page-header h1{margin:0}.page-loading{padding:2rem;color:#6b7280}.page-error{padding:2rem;color:#dc2626}.empty-state{color:#6b7280;padding:1rem 0}.card{background:#fff;border-radius:16px;padding:1.25rem;box-shadow:0 1px 4px #00000012;margin-bottom:1rem}.stat-grid{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.stat-card{flex:1;min-width:140px;background:#fff;border-radius:16px;padding:1rem 1.25rem;box-shadow:0 1px 4px #00000012;border-left:4px solid #e5e7eb}.stat-card--warn{border-left-color:#f59e0b}.stat-card--danger{border-left-color:#ef4444}.stat-card--hero{background:var(--primary);border-left-color:var(--primary);color:#fff}.stat-card--hero .stat-value{color:#fff}.stat-card--hero .stat-label{color:#ffffffb3}.stat-value{font-size:28px;font-weight:700;line-height:1}.stat-icon{font-size:18px;margin-bottom:4px}.stat-label{font-size:12px;color:#6b7280;margin-top:4px;text-transform:uppercase;letter-spacing:.04em}.category-counts{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1.5rem}.category-chip{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:4px 12px;font-size:13px}.category-chip__count{font-weight:700;color:var(--primary)}.category-filter{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:1rem}.filter-btn{padding:5px 12px;border-radius:20px;border:1px solid #d1d5db;background:#fff;cursor:pointer;font-size:13px;transition:all .15s}.filter-btn:hover{border-color:var(--primary);color:var(--primary)}.filter-btn--active{background:var(--primary);color:#fff;border-color:var(--primary)}.toolbar{display:flex;gap:8px;margin-bottom:.75rem;flex-wrap:wrap}.search-input{flex:1;min-width:180px}.form-card{margin-bottom:1.5rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem 1rem;margin-bottom:.75rem}label{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:500;color:#374151}input,select,textarea{padding:7px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;width:100%;transition:border-color .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary)}textarea{resize:vertical}.input-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.input-row input,.input-row select{width:auto;flex:1}.form-error{color:#dc2626;font-size:13px;margin-bottom:8px}.hint{font-size:12px;color:#6b7280;margin-bottom:.75rem}button{cursor:pointer;font-family:inherit;font-size:14px;border-radius:6px;border:none;padding:7px 14px;transition:filter .15s}button:hover{filter:brightness(.93)}.btn-primary{background:var(--primary);color:#fff}.btn-success{background:#16a34a;color:#fff}.btn-secondary{background:#e5e7eb;color:#374151}.btn-danger{background:#ef4444;color:#fff}.btn-refused{background:#ea580c;color:#fff}.btn-link{background:none;color:var(--primary);padding:0;font-size:13px}.btn-link:hover{filter:none;text-decoration:underline}.btn-sm{padding:4px 10px;font-size:12px;margin-right:4px}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 1px 4px #00000012}.data-table th{background:#f9fafb;text-align:left;padding:10px 14px;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#6b7280;font-weight:600;border-bottom:1px solid #e5e7eb}.data-table td{padding:10px 14px;border-bottom:1px solid #f3f4f6;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.clickable-row{cursor:pointer}.clickable-row:hover td{background:#e8edd8}.clickable-cell{cursor:pointer;color:var(--primary)}.clickable-cell:hover{text-decoration:underline}.status-row--overdue td{background:#fff5f5}.status-row--due_soon td{background:#fffbeb}.status-row--never td{background:#fafafa}.status-row--refused td{background:#fff7ed}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.badge--ok{background:#deecd0;color:var(--primary)}.badge--due-soon{background:#fef9c3;color:#854d0e}.badge--overdue{background:#fee2e2;color:#991b1b}.badge--never{background:#f3f4f6;color:#374151}.badge--auto{background:#e0f2fe;color:#0369a1}.badge--refused{background:#ffedd5;color:#c2410c}.flash-msg{background:#deecd0;color:var(--primary);border-radius:6px;padding:8px 14px;margin-bottom:1rem;font-size:13px}.breadcrumb{display:flex;align-items:center;gap:4px;margin-bottom:.75rem;font-size:.85rem}.breadcrumb-link{font-size:.85rem;color:var(--accent)}.breadcrumb-sep{color:var(--tx-muted)}.breadcrumb-current{color:var(--tx);font-weight:500}.profile-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem;margin:.5rem 0 1.25rem}.profile-header h1{font-size:24px;margin:0}.profile-meta{color:#6b7280;font-style:italic;margin-top:2px}.profile-header-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.detail-grid>div{display:flex;flex-direction:column;gap:2px}.detail-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;font-weight:600}.notes-block{margin-top:1rem}.notes-block p{color:#374151;white-space:pre-wrap;margin-top:4px}.filter-row-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;margin-bottom:4px;margin-top:.75rem}.feeding-today{font-size:13px;font-weight:600;color:#6b7280}.feeding-today--partial{color:#d97706}.feeding-today--done{color:#16a34a}.auto-tasks-badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px;white-space:nowrap}.auto-tasks-badge--on{background:var(--primary-lt);color:var(--primary)}.auto-tasks-badge--off{color:var(--tx-faint)}.batch-form{background:#e8edd8;border:1px solid #b8d4a0}.quick-feed-btn{padding:4px 10px;font-size:12px;font-weight:600;border-radius:6px;border:1px solid #16a34a;background:#e8edd8;color:#16a34a;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}.quick-feed-btn:hover,.quick-feed-btn--active{background:#16a34a;color:#fff}.quick-feed-row td{padding:0!important;border-top:none!important}.quick-feed-form{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 16px;background:#e8edd8;border-top:1px solid #b8d4a0}.quick-feed-form select,.quick-feed-form input{margin:0;padding:5px 8px;font-size:13px}.status-row--active td{background:#e8edd8!important}.todos-filters{display:flex;flex-direction:column;gap:8px;margin-bottom:1rem}.todos-filters__row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.todos-search{flex:1;min-width:180px}.todos-select--animal{padding:7px 28px 7px 12px;border-radius:8px;border:1px solid #d1d5db;background:#fff;font-size:13px;font-family:inherit;color:#374151;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='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:border-color .15s;min-width:130px}.todos-select--animal:focus{outline:none;border-color:var(--primary)}.todos-select--animal:hover{border-color:#9ca3af}.todos-status-pill{padding:5px 14px;border-radius:20px;border:1.5px solid #d1d5db;background:#fff;font-size:13px;font-family:inherit;font-weight:500;color:#374151;cursor:pointer;transition:all .15s;white-space:nowrap}.todos-status-pill:hover{border-color:var(--primary);color:var(--primary)}.todos-status-pill--active{background:var(--primary);border-color:var(--primary);color:#fff}.todos-status-pill--overdue.todos-status-pill--active{background:#dc2626;border-color:#dc2626;color:#fff}.todos-status-pill--today.todos-status-pill--active{background:#d97706;border-color:#d97706;color:#fff}.todos-type-chip{padding:4px 12px;border-radius:20px;border:1.5px solid #d1d5db;background:#fff;font-size:12px;font-family:inherit;color:#374151;cursor:pointer;transition:all .15s;white-space:nowrap}.todos-type-chip:hover{border-color:var(--primary);color:var(--primary)}.todos-type-chip--active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.todos-select{padding:7px 28px 7px 12px;border-radius:8px;border:1px solid #d1d5db;background:#fff;font-size:13px;font-family:inherit;color:#374151;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='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:border-color .15s;width:auto}.todos-select:focus{outline:none;border-color:var(--primary)}.task-form{margin-bottom:1rem}.form-field--full{grid-column:1 / -1}.form-actions{display:flex;gap:8px;margin-top:.75rem}.checkbox-label{flex-direction:row;align-items:center;gap:8px;font-weight:400;cursor:pointer}.status-filter-row{display:flex;gap:4px;flex-wrap:wrap}.task-card{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:#fff;border-radius:8px;border:1px solid #e5e7eb;margin-bottom:6px}.task-card--compact{padding:8px 10px}.task-card--overdue{border-left:3px solid #ef4444;background:#fff5f5}.task-card--due_soon{border-left:3px solid #f59e0b;background:#fffbeb}.task-card--completed{opacity:.6}.task-card__check{padding-top:2px}.task-card__body{flex:1;min-width:0}.task-card__title{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:14px;font-weight:500}.task-card__feed-info{display:flex;align-items:center;gap:6px;margin-top:3px;font-size:12px}.task-card__feed-item{color:var(--primary);font-weight:600}.task-card__feed-qty{color:var(--tx-muted)}.task-card__meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:4px;font-size:12px;color:#6b7280}.task-type-icon{font-size:14px}.task-name--done{text-decoration:line-through;color:#9ca3af}.task-animal-link{color:var(--primary);cursor:pointer;background:none;border:none;padding:0;font-size:12px}.task-animal-link:hover{text-decoration:underline}.task-animal-pill{display:inline-block;padding:2px 8px;border-radius:12px;background:#e8f0e0;color:#3a6b1a;font-size:11.5px;font-weight:500;border:1px solid #c6dba8;margin-right:4px}.tf-animal-section{display:flex;flex-direction:column;gap:6px}.tf-animal-label{font-size:13px;font-weight:600;color:#374151;display:flex;align-items:center;gap:8px}.tf-animal-selected-count{font-size:11px;color:var(--primary);font-weight:500}.tf-animal-locked{font-size:13px;color:#374151;padding:6px 0}.tf-selected-pills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}.tf-selected-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 8px 3px 10px;border-radius:14px;background:var(--primary);color:#fff;font-size:12px;font-weight:500}.tf-pill-remove{background:none;border:none;color:#fffc;cursor:pointer;font-size:14px;padding:0;line-height:1}.tf-pill-remove:hover{color:#fff}.tf-animal-picker{border:1.5px solid #d1d5db;border-radius:8px;padding:8px;background:#fafafa}.tf-animal-search{width:100%;padding:5px 10px;border-radius:6px;border:1px solid #d1d5db;font-size:12.5px;margin-bottom:8px;box-sizing:border-box}.tf-animal-chips{display:flex;flex-wrap:wrap;gap:6px}.tf-animal-chip{padding:4px 12px;border-radius:14px;border:1.5px solid #d1d5db;background:#fff;font-size:12.5px;font-family:inherit;color:#374151;cursor:pointer;transition:all .15s}.tf-animal-chip:hover{border-color:var(--primary);color:var(--primary)}.tf-animal-chip--active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.tf-animal-empty{font-size:12px;color:#9ca3af}.task-due{color:#374151}.task-recurring{color:#7c3aed;font-size:11px}.task-desc{font-size:12px;color:#6b7280;margin-top:2px}.priority-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.priority--high{background:#ef4444}.priority--medium{background:#f59e0b}.priority--low{background:#86efac}.task-row{display:flex;align-items:center;gap:8px}.task-row>.task-card{flex:1;margin-bottom:0}.task-row{margin-bottom:6px}.task-row__actions{display:flex;gap:4px;flex-shrink:0}.section-header{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin:1rem 0 .4rem}.section-header--overdue{color:#dc2626}.section-header--due-soon{color:#d97706}.completed-summary{cursor:pointer;font-size:13px;color:#6b7280;margin:1rem 0 .4rem;-webkit-user-select:none;user-select:none}.completed-summary:hover{color:#374151}.tasks-widget{margin:1.5rem 0}.tasks-widget__header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:.75rem}.tasks-widget__header h2{margin:0;font-size:16px}.tasks-widget__stats{display:flex;gap:6px;margin-left:auto}.task-card__edit-btn{margin-left:auto;flex-shrink:0}.consumption-chart{margin-bottom:1.25rem}.cc-period-pills{display:flex;gap:4px;flex-wrap:wrap}.cc-period-btn{padding:3px 10px;font-size:12px;border-radius:999px;border:1px solid var(--border);background:var(--bg-surface);color:var(--tx-muted);cursor:pointer;transition:all .15s}.cc-period-btn:hover{background:var(--bg-hover);color:var(--tx)}.cc-period-btn--active{background:var(--primary);color:#fff;border-color:var(--primary)}.cc-body{padding:.75rem 1rem 1rem}.cc-bar-list{display:flex;flex-direction:column;gap:8px}.cc-row{display:grid;grid-template-columns:130px 1fr 40px;align-items:center;gap:10px}.cc-label{font-size:13px;color:var(--tx-md);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cc-bar-track{height:18px;border-radius:4px;background:var(--bg-subtle);overflow:hidden}.cc-bar-fill{height:100%;border-radius:4px;transition:width .4s ease;min-width:4px}.cc-count{font-size:13px;font-weight:600;color:var(--tx-md);text-align:right;white-space:nowrap}.cc-unit{font-size:11px;font-weight:400;color:var(--tx-faint);margin-left:3px}.cc-row{cursor:default;border-radius:4px;padding:2px 4px;transition:background .1s}.cc-row--active,.cc-row:hover{background:var(--bg-subtle)}.cc-tooltip{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px var(--shadow);padding:10px 12px;pointer-events:auto}.cc-tooltip__header{display:flex;align-items:center;gap:7px;margin-bottom:8px;font-size:13px;color:var(--tx)}.cc-tooltip__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.cc-tooltip__empty{font-size:12px;color:var(--tx-faint);margin:4px 0}.cc-tooltip__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px}.cc-tooltip__event{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;font-size:12px;padding:3px 0;border-bottom:1px solid var(--bg-subtle)}.cc-tooltip__event:last-child{border-bottom:none}.cc-tooltip__animal{color:var(--tx-md);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cc-tooltip__qty{color:var(--primary);font-weight:600;white-space:nowrap}.cc-tooltip__ts{color:var(--tx-faint);font-size:11px;white-space:nowrap}.af-card__edit-btn{font-size:11px;color:var(--primary);margin-left:4px}.af-card__delete-btn{font-size:11px;color:#ef4444;margin-left:4px}.af-card__delete-btn:hover{color:#b91c1c}.cal-nav{display:flex;align-items:center;gap:10px;margin-bottom:.75rem}.cal-title{font-size:18px;font-weight:700;flex:1;text-align:center}.cal-legend{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:1rem;font-size:12px}.legend-item{display:flex;align-items:center;gap:5px}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid #e5e7eb;border-radius:16px;overflow:hidden;background:#e5e7eb;gap:1px}.cal-day-header{background:#f9fafb;text-align:center;padding:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280}.cal-cell{background:#fff;min-height:90px;padding:6px;cursor:pointer;transition:background .1s}.cal-cell:hover{background:#f0f9ff}.cal-cell--empty{background:#f9fafb;cursor:default}.cal-cell--today{background:#e8edd8}.cal-cell--selected{background:#deecd0}.cal-cell--overdue{background:#fff5f5}.cal-date{font-size:13px;font-weight:600;display:block;margin-bottom:4px}.cal-cell--today .cal-date{background:var(--primary);color:#fff;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px}.cal-dots{display:flex;flex-wrap:wrap;gap:3px}.cal-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cal-dot--done{opacity:.4}.cal-dot--virtual{border:1.5px dashed currentColor;background:transparent!important}.cal-more{font-size:10px;color:#6b7280}.cal-detail{margin-top:1rem}.cal-task-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid #f3f4f6;font-size:14px;cursor:pointer}.cal-task-item:last-child{border-bottom:none}.cal-task-item:hover{color:var(--primary)}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.week-col{background:#fff;border-radius:8px;border:1px solid #e5e7eb;overflow:hidden;cursor:pointer}.week-col--today{border-color:var(--primary)}.week-col-header{display:flex;flex-direction:column;align-items:center;padding:8px 4px;background:#f9fafb;font-size:11px;font-weight:600;text-transform:uppercase;color:#6b7280;border-bottom:1px solid #e5e7eb}.week-date-num{font-size:16px;font-weight:700;color:#1f2937;margin-top:2px}.week-date-num--today{background:var(--primary);color:#fff;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px}.week-tasks{padding:6px;display:flex;flex-direction:column;gap:4px}.week-task-item{padding:4px 6px;border-radius:4px;background:#f9fafb;font-size:11px}.week-task-animal{display:block;color:#6b7280;font-size:10px}.week-empty{color:#d1d5db;font-size:12px;text-align:center;margin:4px 0}.day-view{margin-top:1rem}@media (max-width: 600px){.stat-grid{gap:.5rem}.stat-card{min-width:120px}.profile-header{flex-direction:column}.profile-header-actions{width:100%}.form-grid{grid-template-columns:1fr}.data-table th,.data-table td{padding:8px 10px}}.task-widget-card{padding:0;overflow:visible;margin-bottom:2rem;border-radius:16px}.tw-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:1rem 1.25rem .75rem}.tw-header__left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.tw-header__left h2{font-size:16px;font-weight:700;color:#111827}.tw-header__right{display:flex;gap:6px}.tw-collapse-btn{background:none;border:1px solid #e5e7eb;cursor:pointer;font-size:10px;color:#9ca3af;padding:3px 7px;border-radius:4px;line-height:1}.tw-collapse-btn:hover{background:#f3f4f6;color:#374151;filter:none}.tw-badges{display:flex;gap:6px;flex-wrap:wrap}.tw-badge{font-size:12px;font-weight:600;padding:2px 8px;border-radius:20px}.tw-badge--overdue{background:#fee2e2;color:#b91c1c}.tw-badge--today{background:#ffedd5;color:#c2410c}.tw-badge--total{background:#f3f4f6;color:#6b7280}.tw-controls{display:flex;flex-direction:column;gap:8px;padding:0 1.25rem .75rem;border-bottom:1px solid #f3f4f6}.tw-type-filters{display:flex;gap:5px;flex-wrap:wrap}.tw-type-btn{padding:4px 11px;border-radius:20px;font-size:12px;font-weight:500;border:1px solid #e5e7eb;background:#fff;color:#6b7280;cursor:pointer;transition:all .12s;line-height:1.5}.tw-type-btn:hover{border-color:var(--primary);color:var(--primary);filter:none}.tw-type-btn--active{background:var(--primary);border-color:var(--primary);color:#fff}.tw-status-filters{display:flex;gap:5px;flex-wrap:wrap}.tw-status-btn{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid transparent;opacity:.35;transition:opacity .12s;text-transform:uppercase;letter-spacing:.03em}.tw-status-btn--on{opacity:1}.sf--overdue{background:#fee2e2;color:#b91c1c;border-color:#fecaca}.sf--today{background:#ffedd5;color:#c2410c;border-color:#fed7aa}.sf--upcoming{background:#e8edd8;color:#1e3012;border-color:#b8d4a0}.sf--completed{background:#e8edd8;color:#15803d;border-color:#b8d4a0}.tw-progress-row{display:flex;align-items:center;gap:10px;padding-top:2px}.tw-progress-label{font-size:12px;color:#374151;white-space:nowrap}.tw-progress-bar{flex:1;max-width:180px;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.tw-progress-fill{height:100%;background:#16a34a;border-radius:3px;transition:width .4s}.tw-rate{font-size:11px;color:#9ca3af}.tw-celebration{font-size:13px;font-weight:600;color:#15803d}.tw-undo-bar{display:flex;align-items:center;gap:8px;margin:0 1.25rem 4px;padding:7px 12px;background:#1e293b;color:#e2e8f0;font-size:13px;border-radius:6px}.tw-undo-bar .btn-link{color:#93c5fd}.tw-see-all{display:flex;align-items:center;justify-content:flex-end;gap:1rem;padding:.5rem 1.25rem .75rem;border-top:1px solid var(--border);margin-top:4px}.tw-see-all__hidden{font-size:12px;color:var(--tx-muted)}.tw-see-all__link{font-size:13px;font-weight:500;color:var(--accent)}.tw-task{display:flex;align-items:center;gap:10px;padding:10px 1.25rem;border-bottom:1px solid #f3f4f6;transition:background .1s}.tw-task:last-child{border-bottom:none}.tw-task:hover{background:#fafafa}.tw-task--overdue{border-left:3px solid #ef4444;padding-left:calc(1.25rem - 3px)}.tw-task--due_soon{border-left:3px solid #f97316;padding-left:calc(1.25rem - 3px)}.tw-task--upcoming{border-left:3px solid #93c5fd;padding-left:calc(1.25rem - 3px)}.tw-task--completed{border-left:3px solid #86efac;padding-left:calc(1.25rem - 3px);opacity:.55}.tw-task--no_date{padding-left:1.25rem}.tw-task__check{flex-shrink:0;width:16px;height:16px}.tw-task__body{flex:1;min-width:0;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.tw-task__icon{font-size:13px;flex-shrink:0}.tw-task__name{font-size:14px;font-weight:500;color:#111827}.tw-task__animal{font-size:12px;color:#6b7280;cursor:pointer;background:none;border:none;padding:0}.tw-task__animal:hover{color:var(--primary);text-decoration:underline;filter:none}.tw-task__due{font-size:12px;color:#9ca3af}.tw-task__recurring{font-size:11px;color:#9ca3af}.task-name--done{text-decoration:line-through;color:#9ca3af;font-weight:400}.tw-task__actions{position:relative;flex-shrink:0}.tw-snooze-btn{background:none;border:1px solid transparent;cursor:pointer;font-size:13px;padding:3px 6px;border-radius:4px;color:#d1d5db;line-height:1}.tw-snooze-btn:hover{background:#f3f4f6;border-color:#e5e7eb;color:#6b7280;filter:none}.tw-snooze-menu{position:absolute;right:0;top:calc(100% + 4px);z-index:60;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 8px 24px #0000001f;padding:4px;min-width:120px}.tw-snooze-menu button{display:block;width:100%;text-align:left;padding:7px 12px;font-size:13px;background:none;border:none;cursor:pointer;border-radius:5px;color:#374151}.tw-snooze-menu button:hover{background:#f3f4f6;filter:none}.log-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:1rem}.log-modal{background:var(--card-bg, #fff);border-radius:12px;box-shadow:0 20px 60px #00000040;width:100%;max-width:540px;max-height:90vh;overflow-y:auto}.log-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e5e7eb}.log-modal__header h3{margin:0;font-size:1.1rem}.log-modal__close{background:none;border:none;font-size:1.1rem;cursor:pointer;color:#6b7280;padding:4px 8px;border-radius:4px}.log-modal__close:hover{background:#f3f4f6;color:#111}.action-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:1.25rem 1.5rem}.action-type-btn{padding:12px 8px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;text-align:center;transition:all .15s;border:1.5px solid color-mix(in srgb,var(--action-color) 40%,transparent);background:color-mix(in srgb,var(--action-color) 10%,transparent);color:var(--action-color)}.action-type-btn:hover{background:color-mix(in srgb,var(--action-color) 20%,transparent);border-color:var(--action-color)}.log-modal__form{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:12px}.log-modal__form label{margin:0}.log-modal__form textarea{margin-top:4px}.log-modal__actions{display:flex;gap:8px;margin-top:4px}.activity-section{margin-top:2rem}.activity-section h2{margin-bottom:.75rem}.activity-filter-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:1rem}.activity-filter-bar select,.activity-filter-bar input[type=date]{margin:0;padding:6px 10px;font-size:13px;width:auto}.activity-list{display:flex;flex-direction:column;gap:10px}.activity-card{background:var(--card-bg, #fff);border:1px solid #e5e7eb;border-radius:10px;padding:12px 16px}.activity-card__top{display:flex;align-items:center;gap:10px;margin-bottom:6px}.activity-card__time{font-size:12px;color:#6b7280;flex:1}.activity-card__delete{font-size:12px;color:#9ca3af;padding:2px 6px}.activity-card__delete:hover{color:#dc2626}.activity-card__body{display:flex;flex-direction:column;gap:4px}.activity-card__detail{font-size:14px;font-weight:600;color:#111;display:flex;align-items:center;gap:4px}.activity-card__notes{margin:0;font-size:13px;color:#374151}.activity-card__footer{font-size:12px;color:#9ca3af;margin-top:6px}.activity-badge{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 8px;border-radius:20px;border:1px solid;white-space:nowrap}.settings-layout{display:flex;gap:1.5rem;align-items:flex-start}.settings-sidebar{width:190px;flex-shrink:0;background:#fff;border-radius:16px;padding:1rem .75rem;box-shadow:0 1px 4px #00000012;position:sticky;top:1.5rem;display:flex;flex-direction:column}.settings-sidebar__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;padding:0 6px;margin-bottom:.5rem}.settings-nav-btn{display:block;width:100%;text-align:left;padding:7px 10px;border-radius:6px;background:none;border:none;font-size:13px;color:#374151;cursor:pointer;margin-bottom:2px}.settings-nav-btn:hover{background:#f3f4f6;filter:none}.settings-nav-btn--active{background:#deecd0;color:var(--primary);font-weight:600}.settings-content{flex:1;min-width:0}.settings-section-header{margin-bottom:1.25rem}.settings-section-header h2{font-size:20px;font-weight:700;margin-bottom:4px}.settings-section-header p{color:#6b7280;font-size:13px}.section-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-toolbar h3{font-size:16px;font-weight:600;margin:0}.export-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.export-card{background:#fff;border-radius:10px;padding:1.25rem;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb}.export-card h4{font-size:14px;font-weight:600;margin-bottom:4px}.export-card p{font-size:12px;color:#6b7280;margin-bottom:.75rem}.backup-toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer}.backup-toggle input{position:absolute;opacity:0;width:0;height:0}.backup-toggle__track{display:block;width:44px;height:24px;border-radius:12px;background:var(--border-in);transition:background .2s}.backup-toggle__track:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0003}.backup-toggle input:checked+.backup-toggle__track{background:var(--primary)}.backup-toggle input:checked+.backup-toggle__track:after{transform:translate(20px)}.about-card{background:#fff;border-radius:10px;padding:1.5rem;box-shadow:0 1px 3px #00000014}.about-card h2{font-size:22px;font-weight:700;margin-bottom:4px}.about-version{font-size:13px;color:#6b7280;margin-bottom:1.25rem}.about-stack{display:flex;flex-wrap:wrap;gap:8px;margin-top:1rem}.about-chip{background:#f3f4f6;border-radius:20px;padding:4px 12px;font-size:12px;color:#374151}@media (max-width: 640px){.settings-layout{flex-direction:column}.settings-sidebar{width:100%;position:static;display:flex;flex-wrap:wrap;gap:4px;padding:.75rem}.settings-sidebar__title{width:100%}.settings-nav-btn{width:auto;flex-shrink:0}}.unit-badge{white-space:nowrap;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;padding:6px 10px;font-size:12px;color:#6b7280;flex-shrink:0}.activity-feed{background:#fff;border-radius:16px;padding:0;box-shadow:0 1px 4px #00000012;margin-bottom:1rem}.activity-feed .af-filters,.activity-feed .af-stats-bar,.activity-feed .af-list{padding-left:1.25rem;padding-right:1.25rem}.activity-feed .af-filters{padding-top:.25rem;padding-bottom:.25rem}.activity-feed .af-list{padding-bottom:1rem}.af-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.af-header h2{font-size:16px;font-weight:700;margin:0}.af-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;background:#e5e7eb;color:#374151;border-radius:20px;font-size:12px;font-weight:700}.af-filters{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.af-type-row,.af-date-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.af-type-btn,.af-date-btn{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;border:1.5px solid #d1d5db;background:#fff;color:#374151;cursor:pointer;transition:all .15s;white-space:nowrap;line-height:1.4}.af-type-btn:hover,.af-date-btn:hover{border-color:#9ca3af;background:#f9fafb}.af-type-btn--active,.af-date-btn--active{background:#111827;border-color:#111827;color:#fff}.af-custom-dates{display:inline-flex;align-items:center;gap:6px}.af-custom-dates input[type=date]{padding:4px 8px;font-size:13px;border:1.5px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;width:auto}.af-stats-bar{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;align-items:center;font-size:12px;color:#6b7280;padding:8px 12px;background:#f9fafb;border-radius:8px;margin-bottom:.75rem}.af-stats-bar strong{color:#111827}.af-list{display:flex;flex-direction:column;gap:6px}.af-card{display:flex;align-items:flex-start;gap:12px;background:#fff;border-radius:8px;padding:10px 14px;border:1px solid #e5e7eb;border-left-width:4px;box-shadow:0 1px 3px #00000014;transition:box-shadow .15s}.af-card:hover{box-shadow:0 2px 6px #0000001f}.af-card__type--Feeding{border-left-color:#16a34a}.af-card__type--Health{border-left-color:var(--primary)}.af-card__type--Medication{border-left-color:#7c3aed}.af-card__type--Tasks{border-left-color:#0891b2}.af-card__type--Cleaning{border-left-color:#6b7280}.af-card__type--Enrichment{border-left-color:#d97706}.af-card__dot{flex-shrink:0;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;color:#fff;margin-top:1px}.af-card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.af-card__title{font-size:13px;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.af-card__meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;color:#6b7280}.af-card__meta .btn-link{font-size:12px;color:var(--primary)}.af-card__ts{margin-left:auto;white-space:nowrap;font-size:11px;color:#9ca3af}.af-card__notes{margin:0;font-size:12px;color:#374151;background:#f9fafb;border-radius:4px;padding:4px 8px;border-left:2px solid #e5e7eb}@media (max-width: 640px){.af-type-row,.af-date-row{gap:4px}.af-type-btn,.af-date-btn{font-size:11px;padding:3px 9px}.af-stats-bar{font-size:11px;gap:.4rem 1rem}.af-card{padding:8px 10px}}.sidebar-bottom{margin-top:auto;display:flex;flex-direction:column;gap:2px}.activity-feed--collapsed{padding:0}[data-theme=dark] body{background:var(--bg);color:var(--tx)}[data-theme=dark] .content-area{background:var(--bg)}[data-theme=dark] .page>h1,[data-theme=dark] .page>h2{color:var(--tx)}[data-theme=dark] .page-loading,[data-theme=dark] .empty-state,[data-theme=dark] .hint{color:var(--tx-muted)}[data-theme=dark] .page-header h1{color:var(--tx)}[data-theme=dark] .card,[data-theme=dark] .activity-feed,[data-theme=dark] .export-card,[data-theme=dark] .about-card{background:var(--bg-card);box-shadow:0 1px 4px var(--shadow)}[data-theme=dark] .stat-card{background:var(--bg-card);border-left-color:var(--border);box-shadow:0 1px 4px var(--shadow)}[data-theme=dark] .stat-card--hero{background:var(--primary);border-left-color:var(--primary)}[data-theme=dark] .stat-value{color:var(--tx)}[data-theme=dark] .stat-label{color:var(--tx-muted)}[data-theme=dark] .task-widget-card,[data-theme=dark] .data-table{background:var(--bg-card)}[data-theme=dark] .data-table th{background:var(--bg-surface);color:var(--tx-muted);border-bottom-color:var(--border)}[data-theme=dark] .data-table td{border-bottom-color:var(--border);color:var(--tx)}[data-theme=dark] .clickable-row:hover td{background:var(--bg-hover)}[data-theme=dark] .clickable-cell{color:#7cb54e}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background:var(--bg-surface);border-color:var(--border-in);color:var(--tx)}[data-theme=dark] input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{border-color:#7cb54e}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder{color:var(--tx-faint)}[data-theme=dark] label{color:var(--tx-md)}[data-theme=dark] .form-error{color:#f87171}[data-theme=dark] .detail-label{color:var(--tx-faint)}[data-theme=dark] .unit-badge{background:var(--bg-surface);border-color:var(--border);color:var(--tx-muted)}[data-theme=dark] .btn-secondary{background:var(--bg-subtle);color:var(--tx-md)}[data-theme=dark] .btn-link{color:#7cb54e}[data-theme=dark] .flash-msg{background:#1e3012;color:#7cb54e}[data-theme=dark] .filter-btn{background:var(--bg-surface);border-color:var(--border-in);color:var(--tx-md)}[data-theme=dark] .filter-btn:hover{border-color:#7cb54e;color:#7cb54e}[data-theme=dark] .filter-btn--active{background:var(--primary);border-color:var(--primary);color:#fff}[data-theme=dark] .filter-row-label{color:var(--tx-faint)}[data-theme=dark] .todos-select,[data-theme=dark] .todos-select--animal{background-color:var(--bg-surface);border-color:var(--border-in);color:var(--tx-md)}[data-theme=dark] .todos-status-pill{background:var(--bg-surface);border-color:var(--border-in);color:var(--tx-md)}[data-theme=dark] .todos-status-pill:hover{border-color:var(--primary);color:var(--primary)}[data-theme=dark] .todos-status-pill--active{background:var(--primary);border-color:var(--primary);color:#fff}[data-theme=dark] .todos-status-pill--overdue.todos-status-pill--active{background:#dc2626;border-color:#dc2626}[data-theme=dark] .todos-status-pill--today.todos-status-pill--active{background:#d97706;border-color:#d97706}[data-theme=dark] .todos-type-chip{background:var(--bg-surface);border-color:var(--border-in);color:var(--tx-md)}[data-theme=dark] .todos-type-chip:hover{border-color:var(--primary);color:var(--primary)}[data-theme=dark] .todos-type-chip--active{background:var(--primary);border-color:var(--primary);color:#fff}[data-theme=dark] .category-chip{background:var(--bg-card);border-color:var(--border);color:var(--tx-md)}[data-theme=dark] .category-chip__count{color:#7cb54e}[data-theme=dark] .badge--ok{background:#1e3012;color:#7cb54e}[data-theme=dark] .badge--never{background:var(--bg-subtle);color:var(--tx-muted)}[data-theme=dark] .profile-header h1{color:var(--tx)}[data-theme=dark] .profile-meta{color:var(--tx-muted)}[data-theme=dark] .notes-block p{color:var(--tx-md)}[data-theme=dark] .tw-header__left h2{color:var(--tx)}[data-theme=dark] .tw-collapse-btn{border-color:var(--border);color:var(--tx-faint)}[data-theme=dark] .tw-collapse-btn:hover{background:var(--bg-subtle);color:var(--tx)}[data-theme=dark] .tw-controls,[data-theme=dark] .tw-task{border-bottom-color:var(--border)}[data-theme=dark] .tw-task:hover{background:var(--bg-subtle)}[data-theme=dark] .tw-task__name{color:var(--tx)}[data-theme=dark] .tw-task__due,[data-theme=dark] .tw-task__animal,[data-theme=dark] .tw-task__recurring{color:var(--tx-muted)}[data-theme=dark] .tw-progress-label{color:var(--tx-md)}[data-theme=dark] .tw-rate{color:var(--tx-faint)}[data-theme=dark] .tw-badge--total{background:var(--bg-subtle);color:var(--tx-muted)}[data-theme=dark] .tw-type-btn{background:var(--bg-surface);border-color:var(--border);color:var(--tx-muted)}[data-theme=dark] .tw-type-btn:hover{border-color:#7cb54e;color:#7cb54e;filter:none}[data-theme=dark] .tw-type-btn--active{background:var(--primary);border-color:var(--primary);color:#fff}[data-theme=dark] .tw-snooze-btn{color:var(--tx-faint)}[data-theme=dark] .tw-snooze-btn:hover{background:var(--bg-subtle);color:var(--tx-muted);filter:none}[data-theme=dark] .tw-snooze-menu{background:var(--bg-card);border-color:var(--border);box-shadow:0 8px 24px #00000080}[data-theme=dark] .tw-snooze-menu button{color:var(--tx-md)}[data-theme=dark] .tw-snooze-menu button:hover{background:var(--bg-subtle)}[data-theme=dark] .tw-undo-bar{background:#1a2e20;color:var(--tx-md)}[data-theme=dark] .af-badge{background:var(--bg-subtle);color:var(--tx-md)}[data-theme=dark] .af-type-btn,[data-theme=dark] .af-date-btn{background:var(--bg-surface);border-color:var(--border-in);color:var(--tx-md)}[data-theme=dark] .af-type-btn:hover,[data-theme=dark] .af-date-btn:hover{border-color:#7cb54e;background:var(--bg-subtle);filter:none}[data-theme=dark] .af-type-btn--active,[data-theme=dark] .af-date-btn--active{background:var(--primary);border-color:var(--primary);color:#fff}[data-theme=dark] .af-stats-bar{background:var(--bg-surface);color:var(--tx-muted)}[data-theme=dark] .af-stats-bar strong{color:var(--tx)}[data-theme=dark] .af-card{background:var(--bg-surface);border-color:var(--border);box-shadow:none}[data-theme=dark] .af-card:hover{box-shadow:0 2px 8px #00000059}[data-theme=dark] .af-card__title{color:var(--tx)}[data-theme=dark] .af-card__meta{color:var(--tx-muted)}[data-theme=dark] .af-card__ts{color:var(--tx-faint)}[data-theme=dark] .af-card__notes{background:var(--bg-subtle);border-left-color:var(--border);color:var(--tx-md)}[data-theme=dark] .af-card__meta .btn-link{color:#7cb54e}[data-theme=dark] .log-modal-overlay{background:#000000a6}[data-theme=dark] .log-modal{background:var(--bg-card)}[data-theme=dark] .log-modal__header{border-bottom-color:var(--border)}[data-theme=dark] .log-modal__header h3{color:var(--tx)}[data-theme=dark] .log-modal__close{color:var(--tx-muted)}[data-theme=dark] .log-modal__close:hover{background:var(--bg-subtle);color:var(--tx);filter:none}[data-theme=dark] .activity-card{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .activity-card__time{color:var(--tx-muted)}[data-theme=dark] .activity-card__detail{color:var(--tx)}[data-theme=dark] .activity-card__notes{color:var(--tx-md)}[data-theme=dark] .activity-card__footer,[data-theme=dark] .activity-card__delete{color:var(--tx-faint)}[data-theme=dark] .task-card{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .task-animal-link{color:#7cb54e}[data-theme=dark] .task-animal-pill{background:#1e3a12;color:#9fd065;border-color:#3a6b1a}[data-theme=dark] .tf-animal-picker{background:var(--bg-surface);border-color:var(--border-in)}[data-theme=dark] .tf-animal-chip{background:var(--bg-surface);border-color:var(--border-in);color:var(--tx-md)}[data-theme=dark] .tf-animal-chip--active{background:var(--primary);border-color:var(--primary);color:#fff}[data-theme=dark] .tf-animal-search{background:var(--bg-card);border-color:var(--border-in);color:var(--tx-md)}[data-theme=dark] .task-due{color:var(--tx-md)}[data-theme=dark] .section-header,[data-theme=dark] .completed-summary{color:var(--tx-muted)}[data-theme=dark] .completed-summary:hover{color:var(--tx)}[data-theme=dark] .quick-feed-btn{background:var(--bg-surface);border-color:#2a5c35;color:#7cb54e}[data-theme=dark] .quick-feed-btn:hover,[data-theme=dark] .quick-feed-btn--active{background:var(--primary);color:#fff}[data-theme=dark] .quick-feed-form{background:var(--bg-surface);border-top-color:var(--border)}[data-theme=dark] .status-row--active td{background:#16a34a1a!important}[data-theme=dark] .status-row--overdue td{background:#ef444412}[data-theme=dark] .status-row--due_soon td{background:#f59e0b12}[data-theme=dark] .status-row--never td{background:var(--bg-card)}[data-theme=dark] .status-row--refused td{background:#ea580c12}[data-theme=dark] .batch-form{background:var(--bg-surface);border-color:var(--border)}[data-theme=dark] .settings-sidebar{background:var(--bg-card)}[data-theme=dark] .settings-sidebar__title{color:var(--tx-faint)}[data-theme=dark] .settings-nav-btn{color:var(--tx-md)}[data-theme=dark] .settings-nav-btn:hover{background:var(--bg-subtle);filter:none}[data-theme=dark] .settings-nav-btn--active{background:#1e3012;color:#7cb54e}[data-theme=dark] .settings-section-header h2{color:var(--tx)}[data-theme=dark] .settings-section-header p{color:var(--tx-muted)}[data-theme=dark] .section-toolbar h3,[data-theme=dark] .export-card h4{color:var(--tx)}[data-theme=dark] .export-card p{color:var(--tx-muted)}[data-theme=dark] .about-card h2{color:var(--tx)}[data-theme=dark] .about-version{color:var(--tx-muted)}[data-theme=dark] .about-chip{background:var(--bg-subtle);color:var(--tx-md)}[data-theme=dark] .cal-grid{background:var(--border);border-color:var(--border);border-radius:16px}[data-theme=dark] .cal-day-header{background:var(--bg-surface);color:var(--tx-muted)}[data-theme=dark] .cal-cell{background:var(--bg-card)}[data-theme=dark] .cal-cell--empty{background:var(--bg)}[data-theme=dark] .cal-cell--today{background:var(--bg-hover)}[data-theme=dark] .cal-cell:hover{background:var(--bg-subtle)}[data-theme=dark] .cal-cell--selected{background:#1e3012}[data-theme=dark] .cal-date{color:var(--tx-md)}[data-theme=dark] .cal-more{color:var(--tx-faint)}[data-theme=dark] .cal-task-item{color:var(--tx-md);border-bottom-color:var(--border)}[data-theme=dark] .cal-task-item:hover{color:#7cb54e}[data-theme=dark] .cal-title{color:var(--tx)}[data-theme=dark] .week-col{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .week-col-header{background:var(--bg-surface);color:var(--tx-muted);border-bottom-color:var(--border)}[data-theme=dark] .week-date-num{color:var(--tx)}[data-theme=dark] .week-task-item{background:var(--bg-surface);color:var(--tx-md)}[data-theme=dark] .week-task-animal,[data-theme=dark] .week-empty{color:var(--tx-faint)}.mobile-topbar{display:none;align-items:center;gap:12px;padding:12px 16px;background:var(--sidebar-bg);position:sticky;top:0;z-index:100}.mobile-topbar-title{font-size:16px;font-weight:700;color:#fff}.mobile-menu-btn{background:none;border:none;color:#fff;padding:6px;display:flex;align-items:center;border-radius:6px}.mobile-menu-btn:hover{background:#ffffff26;filter:none}.mobile-nav-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:199}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:12px}.table-scroll .data-table{min-width:560px}@media (max-width: 768px){.app-layout{flex-direction:row}.sidebar{position:fixed;left:0;top:0;height:100%;z-index:200;width:220px!important;transform:translate(-100%);transition:transform .25s ease;box-shadow:4px 0 24px #0000004d}.sidebar--mobile-open{transform:translate(0)}.mobile-nav-backdrop{display:block}.sidebar--collapsed{width:220px}.sidebar--collapsed .sidebar-brand{justify-content:flex-start;padding-bottom:1.5rem}.sidebar--collapsed .sidebar-link{justify-content:flex-start;padding:9px 12px}.sidebar--collapsed .sidebar-toggle{justify-content:flex-start;padding:10px 12px}.sidebar--collapsed .sidebar-brand-name,.sidebar--collapsed .sidebar-section-label{display:block}.content-area{width:100%}.mobile-topbar{display:flex}.main-content{padding:1rem .875rem 3rem}button:not(.tw-collapse-btn):not(.log-modal__close):not(.mobile-menu-btn){min-height:40px}.btn-sm{min-height:36px;padding:6px 10px}.tw-type-btn,.af-type-btn,.cc-period-btn,.tw-status-btn{min-height:36px;padding:6px 12px;font-size:13px}.sidebar-link{padding:12px;min-height:44px}.cc-row{grid-template-columns:100px 1fr 50px}.cc-label{font-size:12px}.tw-header{gap:8px}.tw-header__right{flex-wrap:wrap}.stat-card{min-width:100px}.log-modal__form{padding:.75rem 1rem}.log-modal__header{padding:.875rem 1rem}.page-header{flex-wrap:wrap;gap:8px}.page>h1{font-size:20px}.profile-header{flex-direction:column;align-items:flex-start}.profile-header-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.profile-edit-header{flex-wrap:wrap;gap:8px}}@media (max-width: 480px){.main-content{padding:.75rem .75rem 3rem}.stat-card{min-width:calc(50% - .5rem);flex:1 1 calc(50% - .5rem)}.cc-row{grid-template-columns:80px 1fr 44px;gap:6px}.action-type-grid{grid-template-columns:repeat(2,1fr)!important}.af-type-row,.af-date-row{gap:4px}.af-type-btn,.af-date-btn{padding:5px 8px;font-size:12px}.cc-period-pills{gap:3px}.cc-period-btn{padding:4px 8px;font-size:11px}.toolbar{flex-direction:column}.search-input{min-width:unset;width:100%}.tw-type-filters{gap:4px}.tw-type-btn{font-size:11px;padding:5px 8px}.table-scroll .data-table .col-hide-mobile{display:none}}.login-page{display:flex;min-height:100vh;background:var(--bg)}.login-panel--left{flex:0 0 44%;background:linear-gradient(145deg,#2d7a55,#3ea06e 55%,#5bbf8a);display:flex;align-items:center;justify-content:center;padding:3rem 2.5rem;position:relative;overflow:hidden}.login-panel--left:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 60%,rgba(255,255,255,.12) 0%,transparent 70%);pointer-events:none}.login-panel__inner{display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center;z-index:1}.login-illustration{width:280px;height:220px;max-width:90%}.login-panel__title{font-size:2rem;font-weight:800;color:#fff;letter-spacing:-.5px;margin:0}.login-panel__sub{font-size:.95rem;color:#ffffffd1;line-height:1.6;margin:0;max-width:280px}.login-panel__dots{display:flex;gap:6px;margin-top:.5rem}.login-dot{width:8px;height:8px;border-radius:50%;background:#ffffff59;display:inline-block}.login-dot--active{background:#ffffffe6;width:22px;border-radius:4px}.login-panel--right{flex:1;display:flex;align-items:center;justify-content:center;padding:3rem 2rem;background:var(--bg)}.login-form-wrap{width:100%;max-width:400px;display:flex;flex-direction:column;gap:0}.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:2rem}.login-logo__text{font-size:1.35rem;font-weight:800;color:var(--tx);letter-spacing:-.3px}.login-form__heading{font-size:1.6rem;font-weight:700;color:var(--tx);margin:0 0 .4rem;letter-spacing:-.4px}.login-form__sub{font-size:.92rem;color:var(--tx-muted);margin:0 0 1.75rem}.login-form__error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;font-size:.88rem;padding:.65rem .9rem;border-radius:8px;margin-bottom:1rem}[data-theme=dark] .login-form__error{background:#dc262626;border-color:#dc262666;color:#f87171}.login-form{display:flex;flex-direction:column;gap:1rem}.login-field{display:flex;flex-direction:column;gap:.4rem}.login-field label{font-size:.85rem;font-weight:600;color:var(--tx-muted);letter-spacing:.01em}.login-field input{width:100%;padding:.75rem 1rem;border:1.5px solid var(--bd);border-radius:10px;font-size:.95rem;background:var(--bg-surface);color:var(--tx);transition:border-color .15s;box-sizing:border-box}.login-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61f}.login-field__pw-wrap{position:relative}.login-field__pw-wrap input{padding-right:2.8rem}.login-field__pw-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;padding:0;cursor:pointer;color:var(--tx-muted);display:flex;align-items:center}.login-field__pw-toggle:hover{color:var(--tx)}.login-submit{margin-top:.5rem;width:100%;padding:.85rem 1rem;background:#1e2d3b;color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;letter-spacing:.01em}.login-submit:hover:not(:disabled){background:#2a3f52}.login-submit:active:not(:disabled){transform:scale(.98)}.login-submit:disabled{opacity:.6;cursor:not-allowed}[data-theme=dark] .login-submit{background:var(--accent)}[data-theme=dark] .login-submit:hover:not(:disabled){background:#2563eb}.login-form__toggle{margin-top:1.25rem;text-align:center;font-size:.88rem;color:var(--tx-muted)}.login-form__toggle-link{background:none;border:none;padding:0;cursor:pointer;color:var(--accent);font-size:.88rem;font-weight:600;text-decoration:underline;text-underline-offset:2px}.login-form__toggle-link:hover{opacity:.8}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.auth-loading__spinner{width:36px;height:36px;border:3px solid var(--bd);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 700px){.login-page{flex-direction:column}.login-panel--left{flex:0 0 auto;padding:2rem 1.5rem 1.5rem}.login-illustration{width:180px;height:140px}.login-panel__title{font-size:1.4rem}.login-panel__sub,.login-panel__dots{display:none}.login-panel--right{padding:2rem 1.25rem 3rem}}.um-section{display:flex;flex-direction:column;gap:1.25rem}.um-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.um-title{font-size:1.15rem;font-weight:700;color:var(--tx);margin:0 0 .2rem}.um-sub{font-size:.88rem;color:var(--tx-muted);margin:0}.um-invite-btn{white-space:nowrap}.um-success{font-size:.9rem;color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:.6rem .9rem;margin:0}[data-theme=dark] .um-success{background:#16a34a26;border-color:#16a34a59;color:#4ade80}.um-error,.um-loading{font-size:.9rem;color:var(--tx-muted);margin:0}.um-invite-form{background:var(--bg-surface);border:1px solid var(--bd);border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;gap:.9rem}.um-invite-form__title{font-size:.95rem;font-weight:600;color:var(--tx);margin:0}.um-invite-form__error{font-size:.88rem;color:#dc2626;margin:0}.um-invite-form__row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.um-invite-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;font-weight:500;color:var(--tx-muted)}.um-invite-form input{padding:.6rem .75rem;border:1.5px solid var(--bd);border-radius:8px;font-size:.9rem;background:var(--bg);color:var(--tx)}.um-invite-form input:focus{outline:none;border-color:var(--accent)}.um-invite-form__actions{display:flex;justify-content:flex-end}.um-list{display:flex;flex-direction:column;gap:.5rem}.um-row{display:flex;align-items:center;gap:.9rem;padding:.75rem 1rem;background:var(--bg-surface);border:1px solid var(--bd);border-radius:10px}.um-row__avatar{width:38px;height:38px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;flex-shrink:0}.um-row__info{flex:1;display:flex;flex-direction:column;min-width:0}.um-row__name{font-size:.9rem;font-weight:600;color:var(--tx)}.um-row__email{font-size:.8rem;color:var(--tx-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.um-row__role{font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:99px;white-space:nowrap}.um-row__role--owner{background:#3b82f61f;color:#2563eb}[data-theme=dark] .um-row__role--owner{background:#3b82f633;color:#93c5fd}.um-row__role--sub_user{background:#6b72801a;color:#6b7280}[data-theme=dark] .um-row__role--sub_user{background:#6b728026;color:#9ca3af}.um-row__pending{font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:99px;background:#d977061a;color:#b45309;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;flex-shrink:0}[data-theme=dark] .um-row__pending{background:#d9770626;color:#fbbf24}.login-page--centered{justify-content:center;background:#eff2eb;min-height:100vh}.login-email-sent{display:flex;flex-direction:column;align-items:center;text-align:center;padding:16px 0}.login-email-sent__icon{margin-bottom:20px}.um-row__remove{background:none;border:1px solid #fca5a5;color:#dc2626;font-size:.78rem;padding:4px 10px;border-radius:6px;cursor:pointer;white-space:nowrap;flex-shrink:0}.um-row__remove:hover{background:#fef2f2}[data-theme=dark] .um-row__remove{border-color:#dc262666;color:#f87171}[data-theme=dark] .um-row__remove:hover{background:#dc26261a}.settings-sidebar__user{margin-top:auto;padding-top:1rem;border-top:1px solid var(--bd);display:flex;flex-direction:column;gap:.5rem}.settings-sidebar__user-name{font-size:.82rem;font-weight:500;color:var(--tx-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-sidebar__logout{background:none;border:1px solid var(--bd);color:var(--tx-muted);font-size:.82rem;padding:5px 10px;border-radius:6px;cursor:pointer;text-align:left;transition:color .15s,border-color .15s}.settings-sidebar__logout:hover{color:#dc2626;border-color:#fca5a5}.demo-reset-section{display:flex;flex-direction:column;gap:.75rem;max-width:480px}.demo-reset__title{font-size:1.1rem;font-weight:700;color:var(--tx);margin:0}.demo-reset__sub{font-size:.88rem;color:var(--tx-muted);line-height:1.5;margin:0}.demo-reset__msg{font-size:.88rem;color:var(--tx-muted);margin:0}.demo-reset__btn{align-self:flex-start;padding:.6rem 1.25rem;background:#dc2626;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.demo-reset__btn:hover:not(:disabled){background:#b91c1c}.demo-reset__btn:disabled{opacity:.6;cursor:not-allowed}.ob-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column;align-items:center;padding:2rem 1rem 4rem;gap:1.5rem}.ob-logo{display:flex;align-items:center;gap:10px}.ob-logo__text{font-size:1.2rem;font-weight:800;color:var(--tx);letter-spacing:-.3px}.ob-progress{width:100%;max-width:560px;display:flex;flex-direction:column;gap:.5rem}.ob-progress__label{font-size:.82rem;font-weight:600;color:var(--tx-muted);text-align:center;margin:0;letter-spacing:.04em;text-transform:uppercase}.ob-progress__bar{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.ob-progress__seg{height:5px;border-radius:99px;background:var(--bd);transition:background .3s}.ob-progress__seg--done,.ob-progress__seg--active{background:var(--accent)}.ob-progress__names{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.ob-progress__name{font-size:.72rem;text-align:center;line-height:1.3;padding:0 2px}.ob-progress__name--current{color:var(--tx);font-weight:700}.ob-progress__name--done{color:var(--tx-muted)}.ob-progress__name--future{color:var(--tx-faint, #bbb)}.ob-card{width:100%;max-width:560px;background:var(--bg-surface, #fff);border:1px solid var(--bd);border-radius:18px;box-shadow:0 4px 24px #00000014;overflow:hidden}[data-theme=dark] .ob-card{background:var(--bg-card);box-shadow:0 4px 24px #0000004d}.ob-card__inner{padding:2rem;animation:ob-fadein .22s ease both}@keyframes ob-fadein{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ob-step__title{font-size:1.45rem;font-weight:800;color:var(--tx);margin:0 0 .3rem;letter-spacing:-.3px;line-height:1.25}.ob-step__sub{font-size:.92rem;color:var(--tx-muted);margin:0 0 1.25rem}.ob-help{display:flex;gap:.6rem;background:#3b82f60f;border:1px solid rgba(59,130,246,.15);border-radius:10px;padding:.75rem .9rem;margin-bottom:1.5rem}[data-theme=dark] .ob-help{background:#3b82f61a;border-color:#3b82f640}.ob-help__icon{color:var(--accent);flex-shrink:0;margin-top:2px}.ob-help p{font-size:.86rem;color:var(--tx-muted);line-height:1.55;margin:0}.ob-field-group{margin-bottom:1.25rem}.ob-field-label{display:block;font-size:.82rem;font-weight:600;color:var(--tx-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.6rem}.ob-chips{display:flex;flex-wrap:wrap;gap:8px}.ob-chip{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border:1.5px solid var(--bd);border-radius:99px;background:var(--bg);color:var(--tx-muted);font-size:.88rem;font-weight:500;cursor:pointer;transition:border-color .14s,background .14s,color .14s;min-height:44px;-webkit-user-select:none;user-select:none}.ob-chip:hover{border-color:var(--accent);color:var(--tx)}.ob-chip--active{border-color:#2d5220;background:#2d5220;color:#fff;font-weight:600}[data-theme=dark] .ob-chip--active{border-color:#7cb54e;background:#7cb54e;color:#111709}.ob-chip__check{flex-shrink:0}.ob-chip__icon{font-size:1rem;line-height:1}.ob-taginput{display:flex;flex-direction:column;gap:.6rem}.ob-taginput__row{display:flex;gap:8px}.ob-taginput__input{flex:1;padding:.65rem .9rem;border:1.5px solid var(--bd);border-radius:10px;font-size:.9rem;background:var(--bg);color:var(--tx);min-height:44px}.ob-taginput__input:focus{outline:none;border-color:var(--accent)}.ob-taginput__add{padding:0 1.1rem;background:#2d5220;color:#fff;border:none;border-radius:10px;font-size:.88rem;font-weight:600;cursor:pointer;white-space:nowrap;min-height:44px;transition:opacity .15s}[data-theme=dark] .ob-taginput__add{background:#7cb54e;color:#111709}.ob-taginput__add:disabled{opacity:.4;cursor:not-allowed}.ob-taginput__tags{display:flex;flex-wrap:wrap;gap:6px}.ob-taginput__tag{display:inline-flex;align-items:center;gap:4px;padding:5px 10px 5px 12px;background:#3b82f61a;border:1px solid rgba(59,130,246,.25);color:var(--accent);border-radius:99px;font-size:.84rem;font-weight:500}.ob-taginput__remove{background:none;border:none;color:var(--accent);cursor:pointer;font-size:1rem;line-height:1;padding:0 2px;opacity:.7}.ob-taginput__remove:hover{opacity:1}.ob-item-config{border:1.5px solid var(--bd);border-radius:12px;overflow:hidden}.ob-item-config__header{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;padding:.55rem .9rem;background:var(--bg-surface);border-bottom:1.5px solid var(--bd)}.ob-item-config__col,.ob-item-config__col-name{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--tx-muted)}.ob-item-config__row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;align-items:center;padding:.55rem .9rem;border-bottom:1px solid var(--bd)}.ob-item-config__row:last-child{border-bottom:none}.ob-item-config__row:nth-child(2n){background:var(--bg-surface)}.ob-item-config__name{font-size:.88rem;font-weight:600;color:var(--tx);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ob-item-config__select{width:100%;padding:.45rem .65rem;border:1.5px solid var(--bd);border-radius:8px;background:var(--bg-card);color:var(--tx);font-size:.83rem;cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.ob-item-config__select:focus{outline:none;border-color:var(--accent)}[data-theme=dark] .ob-item-config__select{background:var(--bg-surface)}.ob-form,.ob-form__row{display:flex;flex-direction:column;gap:1rem}.ob-form__row--2{flex-direction:row}@media (max-width: 520px){.ob-form__row--2{flex-direction:column}}.ob-form__field{display:flex;flex-direction:column;gap:.35rem;flex:1}.ob-form__field label{font-size:.84rem;font-weight:600;color:var(--tx-muted)}.ob-form__field--required label:after{content:" *";color:#ef4444}.ob-form__optional{font-weight:400;color:var(--tx-faint, #bbb);font-size:.78rem}.ob-form__field input,.ob-form__field select,.ob-form__field textarea{padding:.65rem .85rem;border:1.5px solid var(--bd);border-radius:10px;font-size:.9rem;background:var(--bg);color:var(--tx);font-family:inherit}.ob-form__field input:focus,.ob-form__field select:focus,.ob-form__field textarea:focus{outline:none;border-color:var(--accent)}.ob-form__field textarea{resize:vertical;min-height:80px}.ob-actions{display:flex;gap:.75rem;margin-top:1.5rem;align-items:center}.ob-actions--center{justify-content:center;margin-top:.5rem}.ob-btn-primary{flex:1;padding:.8rem 1.5rem;background:#2d5220;color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s;min-height:48px}.ob-btn-primary:hover:not(:disabled){opacity:.9}.ob-btn-primary:active:not(:disabled){transform:scale(.98)}.ob-btn-primary:disabled{opacity:.45;cursor:not-allowed}[data-theme=dark] .ob-btn-primary{background:#7cb54e;color:#111709}.ob-btn-secondary{padding:.8rem 1.25rem;background:var(--bg-surface, #fff);color:var(--tx-muted);border:1.5px solid var(--bd);border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;white-space:nowrap;min-height:48px;transition:border-color .15s,color .15s}.ob-btn-secondary:hover{border-color:var(--tx-muted);color:var(--tx)}[data-theme=dark] .ob-btn-secondary{background:var(--bg-card)}.ob-btn-finish{flex:1;padding:.8rem 1.5rem;background:#16a34a;color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;min-height:48px;transition:opacity .15s,transform .1s}.ob-btn-finish:hover:not(:disabled){opacity:.9}.ob-btn-finish:active:not(:disabled){transform:scale(.98)}.ob-btn-finish:disabled{opacity:.45;cursor:not-allowed}.ob-skip-link{background:none;border:none;color:var(--tx-muted);font-size:.88rem;cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:.25rem}.ob-skip-link:hover{color:var(--tx)}.ob-error{font-size:.88rem;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:.6rem .9rem;margin:.5rem 0 0}[data-theme=dark] .ob-error{background:#dc26261f;border-color:#dc262659;color:#f87171}.welcome-toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:#16a34a;color:#fff;padding:.85rem 1.25rem;border-radius:12px;font-size:.92rem;font-weight:600;display:flex;align-items:center;gap:.6rem;box-shadow:0 4px 20px #0003;z-index:9999;white-space:nowrap;animation:ob-fadein .3s ease both}.welcome-toast__icon{font-size:1.1rem}.welcome-toast__close{background:none;border:none;color:#fffc;font-size:1.2rem;cursor:pointer;padding:0 0 0 .25rem;line-height:1}.welcome-toast__close:hover{color:#fff}@media (max-width: 500px){.welcome-toast{white-space:normal;max-width:90vw;text-align:center;flex-wrap:wrap;justify-content:center}.ob-card__inner{padding:1.5rem 1.25rem}}.tour-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000007a;z-index:900}.tour-highlight{background:#7cb54e38!important;border-radius:8px;outline:2px solid rgba(124,181,78,.9);outline-offset:1px;box-shadow:0 0 0 5px #7cb54e2e!important;position:relative;z-index:960!important}.tour-popup{position:fixed;z-index:1000;width:296px;background:#fff;border-radius:14px;padding:18px 20px 15px;box-shadow:0 12px 44px #0000003d,0 2px 10px #0000001a}[data-theme=dark] .tour-popup{background:var(--bg-card);box-shadow:0 12px 44px #0000008c,0 2px 10px #0000004d}.tour-popup__arrow{position:absolute;left:-9px;transform:translateY(-50%);border:9px solid transparent;border-right-color:#fff;border-left:0;pointer-events:none}[data-theme=dark] .tour-popup__arrow{border-right-color:var(--bg-card)}.tour-popup__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.tour-popup__title{font-size:.97rem;font-weight:700;color:#232d1a}[data-theme=dark] .tour-popup__title{color:var(--tx)}.tour-popup__count{font-size:.76rem;font-weight:600;color:#607050;background:#eef3e6;padding:2px 9px;border-radius:99px}[data-theme=dark] .tour-popup__count{background:var(--bg-surface);color:var(--tx-muted)}.tour-popup__body{font-size:.875rem;line-height:1.6;color:#3d4e2e;margin-bottom:16px}[data-theme=dark] .tour-popup__body{color:var(--tx-md)}.tour-popup__actions{display:flex;justify-content:space-between;align-items:center}.tour-btn-skip{background:none;border:none;font-size:.82rem;color:#607050;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px;min-height:0}.tour-btn-skip:hover{color:#232d1a}[data-theme=dark] .tour-btn-skip{color:var(--tx-muted)}[data-theme=dark] .tour-btn-skip:hover{color:var(--tx)}.tour-btn-next{background:#2d5220;color:#fff;border:none;border-radius:8px;padding:.5rem 1.15rem;font-size:.87rem;font-weight:600;cursor:pointer;transition:opacity .15s;min-height:0}.tour-btn-next:hover{opacity:.88}[data-theme=dark] .tour-btn-next{background:#7cb54e;color:#111709}@media (max-width: 768px){.tour-overlay,.tour-popup{display:none}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:2000;display:flex;align-items:center;justify-content:center;padding:16px}.modal-box{background:#fff;border-radius:16px;box-shadow:0 12px 48px #00000038;display:flex;flex-direction:column;max-height:90vh;width:100%;max-width:600px;overflow:hidden}.modal-box--wide{max-width:820px}[data-theme=dark] .modal-box{background:#1d2410;box-shadow:0 12px 48px #0000008c}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:22px 24px 0;flex-shrink:0}.modal-title{font-size:1.25rem;font-weight:700;color:#232d1a;margin:0}[data-theme=dark] .modal-title{color:#e8f0e0}.modal-sub{font-size:.82rem;color:#8c9e7a;margin:2px 0 0}.modal-close{background:none;border:none;font-size:1.5rem;line-height:1;color:#8c9e7a;cursor:pointer;padding:0 2px;flex-shrink:0}.modal-close:hover{color:#232d1a}[data-theme=dark] .modal-close:hover{color:#e8f0e0}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid #cdd6bc;flex-shrink:0}[data-theme=dark] .modal-footer{border-top-color:#2d3f1e}.report-filters{padding:18px 24px 0;display:flex;flex-direction:column;gap:16px;flex-shrink:0}.report-filter-group__label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#607050;margin-bottom:8px;display:flex;align-items:center;gap:12px}[data-theme=dark] .report-filter-group__label{color:#8c9e7a}.report-filter-group__toggle-all{background:none;border:none;font-size:.75rem;color:#2d5220;cursor:pointer;padding:0;font-weight:600;text-decoration:underline;text-underline-offset:2px}[data-theme=dark] .report-filter-group__toggle-all{color:#7cb54e}.report-type-chips{display:flex;flex-wrap:wrap;gap:6px}.report-type-chip{padding:5px 14px;border-radius:99px;border:1.5px solid #cdd6bc;background:#fff;color:#607050;font-size:.83rem;font-weight:500;cursor:pointer;transition:all .13s}.report-type-chip:hover{border-color:#2d5220;color:#2d5220}.report-type-chip--active{background:#2d5220;border-color:#2d5220;color:#fff}[data-theme=dark] .report-type-chip{background:#1d2410;border-color:#2d3f1e;color:#8c9e7a}[data-theme=dark] .report-type-chip--active{background:#7cb54e;border-color:#7cb54e;color:#111709}.report-due-options{display:flex;gap:20px;flex-wrap:wrap}.report-due-option{display:flex;align-items:center;gap:6px;font-size:.9rem;color:#3d4d30;cursor:pointer}[data-theme=dark] .report-due-option{color:#c2d6a8}.report-due-option input[type=radio]{accent-color:#2d5220}.report-preview{flex:1;overflow-y:auto;padding:16px 24px;min-height:0}.report-preview__header{display:flex;align-items:center;justify-content:flex-end;margin-bottom:10px}.report-preview__count{font-size:.82rem;color:#8c9e7a;font-weight:600}.report-preview__empty{text-align:center;color:#8c9e7a;padding:28px 0;font-size:.9rem}.report-table th,.report-table td{font-size:.83rem}.status-badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:.75rem;font-weight:600;white-space:nowrap}.status-badge--ok{background:#22c55e1f;color:#16a34a}.status-badge--due_soon{background:#eab3081f;color:#a16207}.status-badge--overdue{background:#ef44441f;color:#dc2626}.status-badge--never{background:#6b72801f;color:#6b7280}.status-badge--refused{background:#ea580c1f;color:#c2410c}[data-theme=dark] .status-badge--ok{background:#22c55e26;color:#4ade80}[data-theme=dark] .status-badge--due_soon{background:#eab30826;color:#fbbf24}[data-theme=dark] .status-badge--overdue{background:#ef444426;color:#f87171}[data-theme=dark] .status-badge--never{background:#6b728026;color:#9ca3af}[data-theme=dark] .status-badge--refused{background:#ea580c26;color:#fb923c}.report-generate-btn{background:#fff;border:1.5px solid #cdd6bc;color:#2d5220;font-size:.87rem;font-weight:600;padding:7px 16px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .13s;white-space:nowrap}.report-generate-btn:hover{background:#2d5220;border-color:#2d5220;color:#fff}[data-theme=dark] .report-generate-btn{background:#1d2410;border-color:#2d3f1e;color:#7cb54e}[data-theme=dark] .report-generate-btn:hover{background:#7cb54e;border-color:#7cb54e;color:#111709}@media (max-width: 600px){.modal-box--wide{max-height:95vh}.report-due-options{gap:12px}}.report-section{margin-bottom:20px}.report-section__title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#607050;margin:0 0 8px;padding-bottom:6px;border-bottom:1px solid #cdd6bc}[data-theme=dark] .report-section__title{color:#8c9e7a;border-bottom-color:#2d3f1e}.report-who-list{display:flex;flex-wrap:wrap;gap:4px}.report-who-chip{display:inline-block;background:#f0f4eb;border:1px solid #cdd6bc;color:#3d4d30;font-size:.78rem;padding:2px 8px;border-radius:99px;white-space:nowrap}[data-theme=dark] .report-who-chip{background:#2a3820;border-color:#2d3f1e;color:#c2d6a8}.report-mark-fed-btn{background:#f0f7ec;border:1.5px solid #7cb54e;color:#2d5220;font-size:.8rem;font-weight:600;padding:4px 12px;border-radius:6px;cursor:pointer;transition:all .13s;white-space:nowrap}.report-mark-fed-btn:hover:not(:disabled){background:#2d5220;border-color:#2d5220;color:#fff}.report-mark-fed-btn:disabled{opacity:.4;cursor:not-allowed}[data-theme=dark] .report-mark-fed-btn{background:#1d2f10;border-color:#4a7a2e;color:#7cb54e}[data-theme=dark] .report-mark-fed-btn:hover:not(:disabled){background:#7cb54e;border-color:#7cb54e;color:#111709}.report-fed-check{font-size:.8rem;font-weight:700;color:#16a34a;padding:4px 6px;white-space:nowrap}[data-theme=dark] .report-fed-check{color:#4ade80}.report-refused-check{font-size:.8rem;font-weight:700;color:#ea580c;padding:4px 6px;white-space:nowrap}[data-theme=dark] .report-refused-check{color:#fb923c}.report-mark-refused-btn{background:#fff7ed;border:1.5px solid #ea580c;color:#9a3412;border-radius:6px;padding:4px 8px;font-size:.75rem;font-weight:600;cursor:pointer;white-space:nowrap}.report-mark-refused-btn:hover:not(:disabled){background:#ea580c;border-color:#ea580c;color:#fff}.report-mark-refused-btn:disabled{opacity:.4;cursor:not-allowed}[data-theme=dark] .report-mark-refused-btn{background:#2d1500;border-color:#c2410c;color:#fb923c}[data-theme=dark] .report-mark-refused-btn:hover:not(:disabled){background:#c2410c;border-color:#c2410c;color:#fff}.report-detail-scroll .data-table{min-width:480px}.report-action-col{position:sticky;right:0;background:#fff;text-align:right;white-space:nowrap;padding-left:8px!important;box-shadow:-2px 0 6px #0000000f}[data-theme=dark] .report-action-col{background:var(--bg-card)}.status-row--ok .report-action-col,.status-row--overdue .report-action-col,.status-row--due_soon .report-action-col,.status-row--never .report-action-col,.status-row--refused .report-action-col{background:inherit}.watch-toggle-btn{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1.5px solid #cdd6bc;color:#607050;font-size:.85rem;font-weight:600;padding:6px 14px;border-radius:8px;cursor:pointer;transition:all .13s;white-space:nowrap}.watch-toggle-btn:hover{border-color:#2d5220;color:#2d5220}.watch-toggle-btn--active{background:#2d5220;border-color:#2d5220;color:#fff}.watch-toggle-btn--active:hover{background:#1e3a16;border-color:#1e3a16}[data-theme=dark] .watch-toggle-btn{background:#1d2410;border-color:#2d3f1e;color:#8c9e7a}[data-theme=dark] .watch-toggle-btn--active{background:#7cb54e;border-color:#7cb54e;color:#111709}.animal-row--watched td:first-child{position:relative}.animal-name-cell{display:inline-flex;align-items:center;gap:6px}.animal-watch-eye{color:#2d5220;flex-shrink:0}[data-theme=dark] .animal-watch-eye{color:#7cb54e}.animal-section-divider td{background:#f5f7f1;padding:5px 14px!important;border-bottom:none!important}[data-theme=dark] .animal-section-divider td{background:#1a2310}.animal-section-label{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#2d5220}.animal-section-label--muted{color:#8c9e7a}[data-theme=dark] .animal-section-label{color:#7cb54e}[data-theme=dark] .animal-section-label--muted{color:#607050}.watchlist-widget{margin-bottom:24px;padding:0;overflow:hidden}.watchlist-cards{display:flex;flex-direction:column;padding:0 0 8px}.watchlist-card{display:flex;align-items:center;gap:12px;padding:11px 20px;cursor:pointer;border-top:1px solid #f0f4eb;transition:background .12s}.watchlist-card:hover{background:#f5f7f1}[data-theme=dark] .watchlist-card{border-top-color:#2d3f1e}[data-theme=dark] .watchlist-card:hover{background:#1a2310}.watchlist-card__avatar{width:36px;height:36px;border-radius:50%;background:#2d5220;color:#fff;font-size:1rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}[data-theme=dark] .watchlist-card__avatar{background:#7cb54e;color:#111709}.watchlist-card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.watchlist-card__name{font-size:.92rem;font-weight:700;color:#232d1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}[data-theme=dark] .watchlist-card__name{color:#e8f0e0}.watchlist-card__meta{font-size:.78rem;color:#8c9e7a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.watchlist-card__right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0}.watchlist-card__fed{font-size:.75rem;color:#8c9e7a;white-space:nowrap}
