@import "https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap";:root{--font-serif:"DM Serif Display", Georgia, serif;--font-sans:"DM Sans", system-ui, -apple-system, sans-serif}h1{font-family:var(--font-serif);color:var(--color-text-primary);margin:0;font-size:32px;font-weight:700;line-height:1.2}h2{font-family:var(--font-serif);color:var(--color-text-primary);margin:0;font-size:24px;font-weight:400;line-height:1.3}h3{font-family:var(--font-sans);color:var(--color-text-primary);margin:0;font-size:18px;font-weight:600;line-height:1.4}h4{font-family:var(--font-sans);color:var(--color-text-primary);margin:0;font-size:16px;font-weight:600;line-height:1.4}p{font-family:var(--font-sans);color:var(--color-text-primary);margin:0;font-size:14px;font-weight:400;line-height:1.6}label{font-family:var(--font-sans);color:var(--color-text-secondary);font-size:13px;font-weight:500;display:block}small,.caption{font-family:var(--font-sans);color:var(--color-text-secondary);font-size:11px;font-weight:400;line-height:1.5}.editorial{font-family:var(--font-serif);font-style:italic}.text-muted{color:var(--color-text-secondary)}.text-inverse{color:var(--color-text-inverse)}:root{--color-forest:#3d5c1a;--color-olive-dark:#5c5c2c;--color-olive-mid:#6b7a3a;--color-olive-light:#8bbc4a;--color-clay:#9b7355;--color-sand:#c4b89a;--color-gold:#c4a86a;--color-cream:#fff;--color-cream-dark:#f5f5f7;--color-cream-mid:#ededef;--color-terra:#a05c3c;--color-rust:#8b3a1c;--color-text-primary:#2a2a1a;--color-text-secondary:#5c5c3a;--color-text-inverse:#fff;--color-text-disabled:#9e9e7a;--color-success:#8bbc4a;--color-warning:#c4a86a;--color-critical:#a05c3c;--color-info:#6b7a3a;--color-border:#e5e4e0;--color-border-focus:#3d5c1a;--shadow-sm:0 1px 3px #2a2a1a0f;--shadow-md:0 4px 16px #2a2a1a14;--shadow-lg:0 12px 40px #2a2a1a1f;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:999px;--transition-fast:.12s ease;--transition-base:.2s ease;--sidebar-width:240px;--topbar-height:56px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-sans);color:var(--color-text-primary);background-color:var(--color-cream);min-height:100vh;font-size:14px}#root{flex-direction:column;min-height:100vh;display:flex}img{max-width:100%;display:block}a{color:var(--color-forest);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:var(--font-sans);background:0 0;border:none}input,textarea,select{font-family:var(--font-sans);font-size:14px}ul,ol{list-style:none}.divider{border:none;border-top:1px solid var(--color-border);margin:var(--space-5) 0}.page-loading{min-height:100vh;font-family:var(--font-sans);color:var(--color-text-secondary);background:var(--color-cream);justify-content:center;align-items:center;font-size:14px;display:flex}.error-message{font-family:var(--font-sans);color:var(--color-rust);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);background:#8b3a1c14;border:1px solid #8b3a1c33;font-size:13px}.success-message{font-family:var(--font-sans);color:var(--color-olive-dark);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);background:#8bbc4a1a;border:1px solid #8bbc4a4d;font-size:13px}.badge{font-family:var(--font-sans);border-radius:var(--radius-full);white-space:nowrap;align-items:center;padding:2px 10px;font-size:11px;font-weight:500;display:inline-flex}.badge--success{color:var(--color-olive-dark);background:#8bbc4a26}.badge--warning{color:var(--color-olive-dark);background:#c4a86a33}.badge--critical{color:var(--color-rust);background:#a05c3c26}.badge--info{color:var(--color-olive-mid);background:#6b7a3a1f}.badge--neutral{background:var(--color-cream-mid);color:var(--color-text-secondary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-sand);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-olive-mid)}:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.sidebar{width:var(--sidebar-width);background:var(--color-cream);border-right:1px solid var(--color-border);padding:var(--space-5);gap:var(--space-4);z-index:100;transition:transform var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar__brand{align-items:center;gap:var(--space-3);padding-bottom:var(--space-3);display:flex}.sidebar__logo{object-fit:contain;flex-shrink:0;width:36px;height:36px}.sidebar__brand-text{flex-direction:column;line-height:1.1;display:flex}.sidebar__name{font-family:var(--font-sans);color:var(--color-text-primary);font-size:16px;font-weight:600}.sidebar__version{font-family:var(--font-serif);color:var(--color-text-secondary);letter-spacing:.04em;font-size:11px;font-style:italic}.sidebar__farm{flex-direction:column;gap:3px;display:flex}.sidebar__farm-label{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-secondary);margin:0;font-size:10px;font-weight:600}.sidebar__farm-name{font-family:var(--font-sans);color:var(--color-text-primary);margin:0;font-size:15px;font-weight:600}.sidebar__farm-role{font-family:var(--font-sans);color:var(--color-text-secondary);align-items:center;gap:5px;margin:2px 0 0;font-size:11px;font-weight:500;display:inline-flex}.sidebar__farm-role-dot{background:var(--color-text-secondary);border-radius:50%;flex-shrink:0;width:6px;height:6px}.sidebar__farm-role--owner .sidebar__farm-role-dot{background:var(--color-forest)}.sidebar__farm-role--owner{color:var(--color-forest)}.sidebar__farm-role--admin .sidebar__farm-role-dot{background:var(--color-olive-mid)}.sidebar__farm-role--admin{color:var(--color-olive-mid)}.sidebar__farm-role--staff .sidebar__farm-role-dot{background:var(--color-text-secondary)}.sidebar__farm-role--staff{color:var(--color-text-secondary)}.sidebar__switch-farm{border:1px solid var(--color-border);border-radius:var(--radius-full);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);background:0 0;align-self:flex-start;margin-top:8px;padding:4px 10px;font-size:11px;font-weight:500}.sidebar__switch-farm:hover{background:var(--color-cream-dark);color:var(--color-forest);border-color:var(--color-forest)}.sidebar__switch-confirm{background:var(--color-cream-dark);border:1px solid var(--color-border);border-radius:var(--radius-sm);gap:var(--space-2);flex-direction:column;margin-top:8px;padding:8px 10px;display:flex}.sidebar__switch-confirm-label{color:var(--color-text-secondary);margin:0;font-size:12px;font-weight:600}.sidebar__switch-confirm-btns{gap:var(--space-2);display:flex}.sidebar__switch-confirm-no,.sidebar__switch-confirm-yes{border-radius:var(--radius-full);font-family:var(--font-sans);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);border:1px solid var(--color-border);flex:1;padding:4px 8px;font-size:11px;font-weight:600}.sidebar__switch-confirm-no{color:var(--color-text-secondary);background:0 0}.sidebar__switch-confirm-no:hover{background:var(--color-cream);color:var(--color-text-primary)}.sidebar__switch-confirm-yes{background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);color:var(--color-text-inverse);border-color:var(--color-forest)}.sidebar__switch-confirm-yes:hover{background:linear-gradient(135deg, #2f4614 0%, var(--color-olive-mid) 100%);border-color:var(--color-olive-dark)}.sidebar .divider{border-color:var(--color-border);margin:0}.sidebar__nav{flex:1}.sidebar__nav ul{flex-direction:column;gap:2px;display:flex}.sidebar__link{align-items:center;gap:var(--space-3);padding:10px var(--space-3);border-radius:var(--radius-md);font-family:var(--font-sans);color:var(--color-text-secondary);transition:background var(--transition-fast), color var(--transition-fast);text-align:left;cursor:pointer;background:0 0;border:none;width:100%;font-size:14px;font-weight:400;text-decoration:none;display:flex}.sidebar__link:hover{background:var(--color-cream-dark);color:var(--color-text-primary);text-decoration:none}.sidebar__link--active{color:var(--color-forest);background:#3d5c1a1a;font-weight:600}.sidebar__link-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.sidebar__footer{flex-direction:column;gap:2px;display:flex}.sidebar__signout{color:var(--color-text-secondary)}.sidebar__signout:hover{color:var(--color-rust);background:#8b3a1c12}.sidebar__app-version{font-family:var(--font-sans);color:var(--color-text-disabled);text-align:center;letter-spacing:.06em;padding-top:var(--space-1);-webkit-user-select:none;user-select:none;font-size:10px}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar--open{box-shadow:var(--shadow-lg);transform:translate(0)}.sidebar-overlay{z-index:99;background:#2a2a1a80;position:fixed;inset:0}}.topbar{z-index:50;height:var(--topbar-height);background:var(--color-cream);border-bottom:1px solid var(--color-border);align-items:center;gap:var(--space-4);padding:0 var(--space-5);box-shadow:var(--shadow-sm);display:flex;position:sticky;top:0}.topbar__menu-btn{border-radius:var(--radius-full);width:36px;height:36px;color:var(--color-text-primary);transition:background var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:none}.topbar__menu-btn:hover{background:var(--color-cream-dark)}.topbar__hamburger{font-size:18px;line-height:1}.topbar__title-group{flex-direction:column;flex:1;gap:1px;display:flex}.topbar__title{font-family:var(--font-sans);color:var(--color-text-primary);font-size:16px;font-weight:600}.topbar__farm{color:var(--color-text-secondary)}.topbar__right{align-items:center;gap:var(--space-3);display:flex}.topbar__version{color:var(--color-olive-mid);font-size:12px}.topbar__scan-btn{align-items:center;gap:var(--space-1);height:32px;padding:0 var(--space-3);background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);border-radius:var(--radius-full);color:var(--color-text-inverse);font-family:var(--font-sans);cursor:pointer;transition:background var(--transition-fast), transform var(--transition-fast);border:none;font-size:13px;font-weight:500;display:flex}.topbar__scan-btn:hover{background:linear-gradient(135deg, #2f4614 0%, var(--color-olive-mid) 100%)}.topbar__scan-btn:active{transform:scale(.97)}.topbar__scan-icon{font-size:15px;line-height:1}.topbar__scan-label{letter-spacing:.01em}@media (width<=480px){.topbar__scan-label{display:none}.topbar__scan-btn{padding:0 var(--space-2)}}@media (width<=768px){.topbar__menu-btn{display:flex}.topbar{padding:0 var(--space-4)}}.qrs{z-index:1100;background:#0f0f0a;flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.qrs__header{padding:var(--space-4) var(--space-5);z-index:2;background:#0f0f0aeb;border-bottom:1px solid #f2ede31a;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.qrs__title-group{align-items:center;gap:var(--space-3);display:flex}.qrs__icon{color:var(--color-olive-light);font-size:20px;line-height:1}.qrs__title{font-family:var(--font-sans);color:var(--color-text-inverse);margin:0;font-size:16px;font-weight:600}.qrs__close{border-radius:var(--radius-full);width:36px;height:36px;color:var(--color-text-inverse);cursor:pointer;transition:background var(--transition-fast);background:#f2ede31a;border:1px solid #f2ede326;justify-content:center;align-items:center;font-size:14px;display:flex}.qrs__close:hover{background:#f2ede333}.qrs__body{background:#000;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.qrs__video{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.qrs__canvas{display:none}.qrs__frame{z-index:2;pointer-events:none;width:min(260px,70vw);height:min(260px,70vw);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.qrs__body:before{content:"";z-index:1;background:#00000073;position:absolute;inset:0}.qrs__body:after{content:"";z-index:1;border-radius:4px;width:min(260px,70vw);height:min(260px,70vw);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 9999px #00000073}.qrs__corner{border-color:var(--color-olive-light);border-style:solid;width:24px;height:24px;position:absolute}.qrs__corner--tl{border-width:3px 0 0 3px;border-radius:4px 0 0;top:0;left:0}.qrs__corner--tr{border-width:3px 3px 0 0;border-radius:0 4px 0 0;top:0;right:0}.qrs__corner--bl{border-width:0 0 3px 3px;border-radius:0 0 0 4px;bottom:0;left:0}.qrs__corner--br{border-width:0 3px 3px 0;border-radius:0 0 4px;bottom:0;right:0}.qrs__state{z-index:3;align-items:center;gap:var(--space-4);padding:var(--space-8);text-align:center;color:#f2ede3b3;flex-direction:column;display:flex;position:relative}.qrs__spinner{border:3px solid #f2ede326;border-top-color:var(--color-olive-light);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite qrs-spin}@keyframes qrs-spin{to{transform:rotate(360deg)}}.qrs__state-icon{color:var(--color-gold);font-size:32px}.qrs__cam-error{color:#f2ede3d9;max-width:300px;margin:0;font-size:14px;line-height:1.6}.qrs__btn-secondary{padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);color:var(--color-text-inverse);font-family:var(--font-sans);cursor:pointer;transition:background var(--transition-fast);background:#f2ede31a;border:1px solid #f2ede333;font-size:14px}.qrs__btn-secondary:hover{background:#f2ede32e}.qrs__scan-error{bottom:var(--space-5);z-index:4;background:var(--color-rust);color:var(--color-text-inverse);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);white-space:nowrap;pointer-events:none;font-size:13px;font-weight:500;animation:.2s qrs-toast-in;position:absolute;left:50%;transform:translate(-50%)}@keyframes qrs-toast-in{0%{opacity:0;transform:translate(-50%)translateY(6px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.qrs__hint{text-align:center;padding:var(--space-4) var(--space-5);color:#f2ede380;font-family:var(--font-sans);z-index:2;background:#0f0f0ae0;flex-shrink:0;margin:0;font-size:13px}.layout{background:var(--color-cream);min-height:100vh;display:flex}.layout__main{min-width:0;margin-left:var(--sidebar-width);flex-direction:column;flex:1;display:flex}.layout__content{padding:var(--space-6);flex:1;width:100%;max-width:1280px}@media (width<=768px){.layout__main{margin-left:0}.layout__content{padding:var(--space-4)}}.btn{font-family:var(--font-sans);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), opacity var(--transition-fast);white-space:nowrap;border:1.5px solid #0000;justify-content:center;align-items:center;gap:8px;font-weight:500;text-decoration:none;display:inline-flex;position:relative}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--sm{height:32px;padding:6px 14px;font-size:12px}.btn--md{height:40px;padding:9px 20px;font-size:14px}.btn--lg{height:48px;padding:12px 28px;font-size:15px}.btn--full{width:100%}.btn--primary{background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);color:var(--color-text-inverse);border-color:#0000}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg, #2f4614 0%, var(--color-olive-mid) 100%);box-shadow:var(--shadow-sm)}.btn--secondary{background:var(--color-cream-dark);color:var(--color-text-primary);border-color:var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-cream-mid);border-color:var(--color-olive-mid)}.btn--ghost{color:var(--color-forest);background:0 0;border-color:#0000}.btn--ghost:hover:not(:disabled){background:#3d5c1a0f}.btn--danger{background:var(--color-rust);color:var(--color-text-inverse);border-color:var(--color-rust)}.btn--danger:hover:not(:disabled){background:var(--color-terra);border-color:var(--color-terra)}.btn--loading{cursor:wait}.btn__spinner{border:2px solid #ffffff4d;border-top-color:currentColor;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite btn-spin;position:absolute}.btn__label--hidden{opacity:0}@keyframes btn-spin{to{transform:rotate(360deg)}}.landing{min-height:100vh;display:flex}.landing__panel{padding:var(--space-8) var(--space-7);flex-direction:column;flex:1;justify-content:center;display:flex}.landing__panel--brand{background:radial-gradient(circle at 15% 85%, #ffffff24, transparent 55%), radial-gradient(circle at 90% 10%, #c4a86a59, transparent 45%), linear-gradient(160deg, #2f4614 0%, var(--color-forest) 45%, var(--color-olive-mid) 100%);gap:var(--space-5);position:relative;overflow:hidden}.landing__panel--actions{background:var(--color-cream);align-items:center}.landing__brand{align-items:center;gap:var(--space-4);display:flex}.landing__logo{object-fit:contain;border-radius:var(--radius-lg);box-sizing:border-box;width:52px;height:52px;box-shadow:var(--shadow-sm);background:#ffffffeb;padding:6px}.landing__app-name{font-family:var(--font-serif);color:var(--color-text-inverse);font-size:36px;font-weight:700;line-height:1}.landing__app-version{font-family:var(--font-serif);color:#ffffffbf;letter-spacing:.1em;text-transform:uppercase;margin-top:2px;font-size:14px;font-style:italic}.landing__slogan{font-family:var(--font-serif);color:var(--color-text-inverse);font-size:22px;font-style:italic;line-height:1.4}.landing__tagline{font-family:var(--font-sans);color:#fffc;max-width:340px;font-size:14px;line-height:1.7}.landing__card{gap:var(--space-5);flex-direction:column;width:100%;max-width:400px;display:flex}.landing__card-title{font-family:var(--font-serif);color:var(--color-text-primary);font-size:28px}.landing__card-sub{color:var(--color-text-secondary);margin-top:-12px}.landing__options{gap:var(--space-3);flex-direction:column;display:flex}.landing__option{align-items:center;gap:var(--space-4);background:var(--color-cream-dark);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);cursor:pointer;transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);text-align:left;width:100%;display:flex}.landing__option:hover{border-color:var(--color-olive-mid);background:var(--color-cream);box-shadow:var(--shadow-md)}.landing__option-icon{background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);width:40px;height:40px;color:var(--color-text-inverse);border-radius:var(--radius-full);flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.landing__option-title{font-family:var(--font-sans);color:var(--color-text-primary);margin-bottom:2px;font-size:15px;font-weight:600}.landing__option-desc{color:var(--color-text-secondary)}@media (width<=768px){.landing{flex-direction:column}.landing__panel--brand{padding:var(--space-7) var(--space-5);gap:var(--space-4);border-right:none;border-bottom:1px solid var(--color-border)}.landing__panel--actions{padding:var(--space-6) var(--space-5);align-items:stretch}.landing__tagline{display:none}.landing__card{max-width:100%}}.field{flex-direction:column;gap:6px;display:flex}.field__label{font-family:var(--font-sans);color:var(--color-text-secondary);font-size:13px;font-weight:500;display:block}.field__required{color:var(--color-terra)}.field__input{width:100%;font-family:var(--font-sans);color:var(--color-text-primary);background:var(--color-cream);border:1.5px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);appearance:none;outline:none;padding:10px 14px;font-size:14px}.field__input::placeholder{color:var(--color-text-disabled)}.field__input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px #3d5c1a1a}.field__input--error{border-color:var(--color-rust)}.field__input--error:focus{box-shadow:0 0 0 3px #8b3a1c1a}.field__textarea{resize:vertical;min-height:80px;line-height:1.5}.field__select{cursor:pointer;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='%235C5C3A' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.field__password-wrap{align-items:center;display:flex;position:relative}.field__input--has-toggle{padding-right:42px}.field__password-toggle{cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-full);transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;line-height:1;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.field__password-toggle:hover{color:var(--color-text-primary);background:var(--color-cream-dark)}.field__error{font-family:var(--font-sans);color:var(--color-rust);font-size:12px}.field__helper{font-family:var(--font-sans);color:var(--color-text-secondary);font-size:12px}.auth-page{background:radial-gradient(circle at 12% 8%, #8bbc4a29, transparent 42%), radial-gradient(circle at 88% 92%, #c4a86a33, transparent 42%), radial-gradient(circle at 90% 5%, #a05c3c1a, transparent 35%), var(--color-cream);min-height:100vh;padding:var(--space-5);justify-content:center;align-items:center;display:flex}.auth-page__inner{gap:var(--space-6);flex-direction:column;width:100%;max-width:440px;display:flex}.auth-page__back{align-items:center;gap:var(--space-2);cursor:pointer;font-family:var(--font-sans);color:var(--color-text-secondary);background:0 0;border:none;padding:0;font-size:13px;font-weight:500;transition:color .15s;display:inline-flex}.auth-page__back:hover{color:var(--color-text-primary)}.auth-page__back-icon{font-size:16px;line-height:1}.auth-page__brand{align-items:center;gap:var(--space-3);display:flex}.auth-page__logo{object-fit:contain;width:36px;height:36px}.auth-page__app-name{font-family:var(--font-sans);color:var(--color-forest);font-size:15px;font-weight:600}.auth-page__card{background:var(--color-cream-dark);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-7) var(--space-6);gap:var(--space-5);box-shadow:var(--shadow-md);flex-direction:column;display:flex;position:relative;overflow:hidden}.auth-page__card:before{content:"";background:linear-gradient(90deg, var(--color-forest) 0%, var(--color-olive-light) 50%, var(--color-gold) 100%);height:5px;position:absolute;top:0;left:0;right:0}.auth-page__title{font-family:var(--font-serif);color:var(--color-text-primary);font-size:26px}.auth-page__sub{color:var(--color-text-secondary);margin-top:var(--space-1)}.auth-page__form{gap:var(--space-4);flex-direction:column;display:flex}.auth-page__forgot{text-align:right;margin-top:-8px}.auth-page__link{font-family:var(--font-sans);color:var(--color-forest);font-size:13px;font-weight:500}.auth-page__link:hover{text-decoration:underline}.auth-page__footer{text-align:center;color:var(--color-text-secondary);padding-top:var(--space-2);border-top:1px solid var(--color-border);font-size:13px}.auth-page__steps{gap:var(--space-2);justify-content:center;align-items:center;display:flex}.auth-page__step{border-radius:var(--radius-full);background:var(--color-border);width:28px;height:4px;transition:background var(--transition-base)}.auth-page__step--active{background:linear-gradient(90deg, var(--color-forest) 0%, var(--color-olive-light) 100%)}.auth-page__step--done{background:var(--color-olive-light)}.auth-page__portal-hint{margin-top:var(--space-5);text-align:center}.auth-page__portal-link{letter-spacing:.06em;color:var(--color-text-secondary);opacity:.6;font-size:11px;font-weight:500;text-decoration:none;transition:opacity .15s}.auth-page__portal-link:hover{opacity:1;color:var(--color-olive-mid)}.farm-config{background:var(--color-cream);min-height:100vh;padding:var(--space-7) var(--space-5);justify-content:center;align-items:flex-start;display:flex}.farm-config__inner{gap:var(--space-6);flex-direction:column;width:100%;max-width:520px;display:flex}.farm-config__back{align-items:center;gap:var(--space-2);cursor:pointer;font-family:var(--font-sans);color:var(--color-text-secondary);background:0 0;border:none;padding:0;font-size:13px;font-weight:500;transition:color .15s;display:inline-flex}.farm-config__back:hover{color:var(--color-text-primary)}.farm-config__header{align-items:center;gap:var(--space-3);display:flex}.farm-config__logo{object-fit:contain;width:40px;height:40px}.farm-config__app-name{font-family:var(--font-sans);color:var(--color-forest);font-size:16px;font-weight:600}.farm-config__tagline{color:var(--color-text-secondary);font-size:12px}.farm-config__progress{gap:var(--space-2);align-items:center;display:flex}.farm-config__progress-step{border-radius:var(--radius-full);background:var(--color-border);height:5px;transition:background var(--transition-base);flex:1}.farm-config__progress-step--active{background:var(--color-forest)}.farm-config__progress-step--done{background:var(--color-olive-light)}.farm-config__mode-toggle{border:1.5px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-cream-dark);gap:0;display:flex;overflow:hidden}.farm-config__mode-btn{padding:var(--space-3) var(--space-4);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex:1;font-size:14px;font-weight:500}.farm-config__mode-btn+.farm-config__mode-btn{border-left:1.5px solid var(--color-border)}.farm-config__mode-btn--active{background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);color:var(--color-text-inverse);font-weight:600}.farm-config__card{background:var(--color-cream-dark);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-7) var(--space-6);box-shadow:var(--shadow-md);gap:var(--space-5);flex-direction:column;display:flex}.farm-config__step{gap:var(--space-5);flex-direction:column;display:flex}.farm-config__fields{gap:var(--space-4);flex-direction:column;display:flex}.farm-config__animal-grid{gap:var(--space-3);grid-template-columns:repeat(2,1fr);display:grid}.farm-config__animal-tile{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-cream);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-sans);color:var(--color-text-primary);cursor:pointer;transition:border-color var(--transition-fast), background var(--transition-fast);text-align:left;font-size:14px;font-weight:500;display:flex}.farm-config__animal-tile:hover{border-color:var(--color-olive-mid);background:var(--color-cream-mid)}.farm-config__animal-tile--selected{border-color:var(--color-forest);color:var(--color-forest);background:#3d5c1a14}.farm-config__animal-check{border-radius:var(--radius-sm);border:1.5px solid var(--color-border);background:var(--color-cream);width:20px;height:20px;color:var(--color-forest);transition:border-color var(--transition-fast), background var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.farm-config__animal-tile--selected .farm-config__animal-check{border-color:var(--color-forest);background:var(--color-forest);color:var(--color-cream)}.farm-config__nav{gap:var(--space-3);justify-content:space-between;display:flex}.farm-config__nav .btn{flex:1}.farm-config__sign-out-hint{text-align:center;color:var(--color-text-secondary);margin:0;font-size:12px}.farm-config__sign-out-link{font-family:var(--font-sans);color:var(--color-terra);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;font-size:12px;text-decoration:underline}.farm-config__sign-out-link:hover{color:var(--color-rust)}@media (width<=480px){.farm-config,.farm-config__card{padding:var(--space-5) var(--space-4)}.farm-config__animal-grid{grid-template-columns:1fr}}.farm-sel{background:var(--color-cream);flex-direction:column;min-height:100vh;display:flex}.farm-sel__header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);background:var(--color-cream);justify-content:space-between;align-items:center;display:flex}.farm-sel__brand{align-items:center;gap:var(--space-3);display:flex}.farm-sel__logo{object-fit:contain;width:32px;height:32px}.farm-sel__app-name{font-family:var(--font-serif);color:var(--color-forest);margin:0;font-size:20px;font-weight:700}.farm-sel__sign-out{cursor:pointer;font-family:var(--font-sans);color:var(--color-text-secondary);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);background:0 0;border:none;font-size:13px;transition:color .15s}.farm-sel__sign-out:hover{color:var(--color-text-primary)}.farm-sel__header-actions{align-items:center;gap:var(--space-3);display:flex}.farm-sel__body{padding:var(--space-8) var(--space-5);flex:1;justify-content:center;align-items:flex-start;display:flex}.farm-sel__inner{gap:var(--space-6);flex-direction:column;width:100%;max-width:560px;display:flex}.farm-sel__title h1{margin:0 0 var(--space-2)}.farm-sel__title .text-muted{margin:0}.farm-sel__list{gap:var(--space-3);flex-direction:column;display:flex}.farm-sel__card{background:var(--color-cream-dark);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-5);transition:border-color .15s,box-shadow .15s}.farm-sel__card:hover{border-color:var(--color-olive-mid);box-shadow:0 2px 12px #3d5c1a14}.farm-sel__card-body{justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.farm-sel__card-info{gap:var(--space-2);flex-direction:column;min-width:0;display:flex}.farm-sel__card-top{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.farm-sel__farm-name{color:var(--color-text-primary);margin:0;font-size:17px;font-weight:600}.farm-sel__role{letter-spacing:.04em;border-radius:100px;flex-shrink:0;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.farm-sel__role--owner{color:var(--color-forest);background:#3d5c1a1a;border:1px solid #3d5c1a40}.farm-sel__role--admin{color:var(--color-olive-dark);background:#6b7a3a1f;border:1px solid #6b7a3a4d}.farm-sel__role--staff{color:var(--color-text-secondary);border:1px solid var(--color-border);background:#c4b89a33}.farm-sel__card-meta{gap:var(--space-2);flex-wrap:wrap;display:flex}.farm-sel__meta-item{color:var(--color-text-secondary);font-size:12px}.farm-sel__meta-item+.farm-sel__meta-item:before{content:"·";margin-right:var(--space-2)}.farm-sel__empty{background:var(--color-cream-dark);border:1.5px dashed var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8) var(--space-6);text-align:center;gap:var(--space-3);flex-direction:column;align-items:center;display:flex}.farm-sel__empty-title{font-family:var(--font-serif);color:var(--color-text-primary);margin:0;font-size:20px}.farm-sel__empty p.text-muted{max-width:340px;margin:0;line-height:1.6}.farm-sel__empty-actions{gap:var(--space-3);margin-top:var(--space-2);flex-wrap:wrap;justify-content:center;display:flex}.farm-sel__overlay{padding:var(--space-5);z-index:100;background:#2a2a1a73;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.farm-sel__modal{background:var(--color-cream);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);width:100%;max-width:380px;animation:.18s slideUp;box-shadow:0 8px 40px #2a2a1a2e}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.farm-sel__modal-title{margin:0 0 var(--space-2);font-size:20px}.farm-sel__modal-sub{margin:0 0 var(--space-2);color:var(--color-text-secondary);font-size:14px;line-height:1.6}.farm-sel__modal-loc{margin:0 0 var(--space-5)}.farm-sel__modal-actions{gap:var(--space-3);justify-content:flex-end;display:flex}@media (width<=640px){.farm-sel__header{padding:var(--space-3) var(--space-4)}.farm-sel__body{padding:var(--space-5) var(--space-4)}.farm-sel__card-body{align-items:flex-start;gap:var(--space-3);flex-direction:column}.farm-sel__card-body>button{width:100%}.farm-sel__empty-actions{flex-direction:column}.farm-sel__empty-actions>*{width:100%}.farm-sel__modal-actions{flex-direction:column-reverse}.farm-sel__modal-actions>*{width:100%}}.home{gap:var(--space-6);flex-direction:column;display:flex}.home__welcome h1{margin-bottom:var(--space-2);font-size:26px}.home__metrics{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.home__metric-tile{border-radius:var(--radius-xl);padding:var(--space-5);gap:var(--space-2);min-height:176px;box-shadow:var(--shadow-md);flex-direction:column;display:flex;position:relative;overflow:hidden}.home__metric-label{text-transform:uppercase;letter-spacing:.05em;color:#fffc;margin:0}.home__metric-value{font-family:var(--font-sans);font-variant-numeric:tabular-nums;color:var(--color-text-inverse);margin:0;font-size:48px;font-weight:700;line-height:1}.home__metric-sub{color:#ffffffd9;margin:0 0 auto}.home__metric-cta{margin-top:var(--space-3);padding:6px var(--space-3);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(8px);color:var(--color-text-inverse);transition:background var(--transition-fast);background:#ffffff29;border:1px solid #ffffff4d;align-self:flex-start;align-items:center;gap:4px;font-size:12px;font-weight:500;text-decoration:none;display:inline-flex}.home__metric-cta:hover{background:#ffffff47;text-decoration:none}.home__metric-tile--animals{background:radial-gradient(circle at 20% 100%,#ffffff2e,#0000 60%),linear-gradient(135deg,#2f4614 0%,#3d5c1a 45%,#8bbc4a 100%)}.home__metric-tile--camps{background:radial-gradient(circle at 20% 100%,#ffffff2e,#0000 60%),linear-gradient(135deg,#5c5c2c 0%,#6b7a3a 50%,#c4a86a 100%)}.home__metric-tile--pregnant{background:radial-gradient(circle at 20% 100%,#fff3,#0000 60%),linear-gradient(135deg,#8b3a1c 0%,#a05c3c 45%,#c4a86a 100%)}.home__metric-tile--health{background:radial-gradient(circle at 20% 100%,#ffffff2e,#0000 60%),linear-gradient(135deg,#3d5c1a 0%,#6b7a3a 50%,#8bbc4a 100%);transition:background .4s}.home__metric-tile--health-alert{background:radial-gradient(circle at 20% 100%,#ffffff38,#0000 60%),linear-gradient(135deg,#5c1a0c 0%,#8b3a1c 45%,#a05c3c 100%)}.home__section{gap:var(--space-3);flex-direction:column;display:flex}.home__section-header{justify-content:space-between;align-items:baseline;gap:var(--space-3);display:flex}.home__section-header h3{margin:0}.home__section-link{color:var(--color-forest);white-space:nowrap;font-weight:500;text-decoration:none}.home__section-link:hover{text-underline-offset:2px;text-decoration:underline}.home__empty-section{background:var(--color-cream-dark);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6)}.home__link{color:var(--color-forest);font-weight:500;text-decoration:none}.home__link:hover{text-underline-offset:2px;text-decoration:underline}.home__camp-wrap{border:1.5px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-cream-dark);overflow-x:auto}.camp-summary-table{border-collapse:collapse;width:100%;font-size:13px}.camp-summary-table thead tr{border-bottom:2px solid var(--color-border)}.camp-summary-table th{padding:var(--space-3) var(--space-4);text-align:left;font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);white-space:nowrap;font-size:11px;font-weight:600}.camp-summary-table__row{border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.camp-summary-table__row:last-child{border-bottom:none}.camp-summary-table__row:hover{background:var(--color-cream-mid)}.camp-summary-table td{padding:var(--space-3) var(--space-4);vertical-align:middle}.camp-summary-table__name{color:var(--color-text-primary);white-space:nowrap;font-weight:600}.camp-summary-table__num{font-variant-numeric:tabular-nums;color:var(--color-text-primary)}.camp-summary-table__pasture,.camp-summary-table__rainfall{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.camp-summary-table__rainfall-val{color:var(--color-text-primary);font-variant-numeric:tabular-nums;font-weight:500}.camp-summary-table__age{white-space:nowrap}.camp-summary-table__util{min-width:140px}.camp-summary-table__capacity{font-size:12px}.util-bar{align-items:center;gap:var(--space-2);display:flex}.util-bar__track{background:var(--color-cream-mid);border-radius:var(--radius-full);flex:1;height:6px;overflow:hidden}.util-bar__fill{border-radius:var(--radius-full);height:100%;transition:width .4s}.util-bar__fill--low{background:var(--color-olive-light)}.util-bar__fill--mid{background:var(--color-olive-mid)}.util-bar__fill--high{background:var(--color-gold)}.util-bar__fill--over{background:var(--color-terra)}.util-bar__pct{font-variant-numeric:tabular-nums;white-space:nowrap;text-align:right;min-width:36px;font-size:12px;font-weight:600}.util-bar__pct--low{color:var(--color-olive-mid)}.util-bar__pct--mid{color:var(--color-olive-dark)}.util-bar__pct--high{color:#8a5e00}.util-bar__pct--over{color:var(--color-terra)}.home__camp-loading{align-items:center;gap:var(--space-3);padding:var(--space-5);background:var(--color-cream-dark);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex}.home__spinner{border:2px solid var(--color-border);border-top-color:var(--color-forest);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite home-spin}@keyframes home-spin{to{transform:rotate(360deg)}}.home__alerts{gap:var(--space-2);flex-direction:column;display:flex}.home__alert{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid;display:flex}.home__alert--critical,.home__alert--high{background:#8b3a1c0f;border-color:#8b3a1c38}.home__alert--warning{background:#c4a86a1a;border-color:#c4a86a59}.home__alert-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;line-height:1;display:flex}.home__alert--critical .home__alert-icon,.home__alert--high .home__alert-icon{background:var(--color-rust);color:var(--color-text-inverse)}.home__alert--warning .home__alert-icon{background:var(--color-gold);color:var(--color-text-primary)}.home__alert-label{color:var(--color-text-primary);flex:1;margin:0;font-size:13px;line-height:1.4}.home__alert-date{white-space:nowrap;flex-shrink:0}@media (width<=640px){.home__metrics{grid-template-columns:1fr 1fr}}.modal-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;padding:var(--space-4);background:#2a2a1a73;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--color-cream);border-radius:var(--radius-xl);flex-direction:column;width:100%;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 8px 40px #2a2a1a38}.modal--sm{max-width:400px}.modal--md{max-width:560px}.modal--lg{max-width:720px}.modal--xl{max-width:1140px}.modal__header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.modal__title{font-family:var(--font-serif);color:var(--color-text-primary);margin:0;font-size:20px}.modal__close{width:32px;height:32px;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-full);transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;display:flex}.modal__close:hover{color:var(--color-text-primary);background:var(--color-cream-dark)}.modal__body{padding:var(--space-6);flex:1;overflow-y:auto}@media (width<=480px){.modal-backdrop{align-items:flex-end;padding:0}.modal{border-bottom-right-radius:0;border-bottom-left-radius:0;max-height:95vh}.modal__body{padding:var(--space-4)}}.animal-form{gap:var(--space-5);flex-direction:column;display:flex}.animal-form__section{gap:var(--space-4);border:none;flex-direction:column;margin:0;padding:0;display:flex}.animal-form__legend{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);margin-bottom:var(--space-1);border-bottom:1px solid var(--color-border);width:100%;padding:0;padding-bottom:var(--space-2);font-size:11px;font-weight:600}.animal-form__row{gap:var(--space-3);display:grid}.animal-form__row--2{grid-template-columns:1fr 1fr}.animal-form__row--3{grid-template-columns:1fr 1fr 1fr}.animal-form__checkbox-label{align-items:center;gap:var(--space-2);font-family:var(--font-sans);color:var(--color-text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;display:flex}.animal-form__checkbox{width:16px;height:16px;accent-color:var(--color-forest);cursor:pointer;flex-shrink:0}.animal-form__sire-wrap,.animal-form__external-sire{gap:var(--space-1);flex-direction:column;display:flex}.animal-form__link-btn{font-family:var(--font-sans);color:var(--color-olive-mid);cursor:pointer;text-align:left;text-underline-offset:2px;background:0 0;border:none;padding:0;font-size:11px;text-decoration:underline}.animal-form__link-btn:hover{color:var(--color-forest)}.animal-form__actions{gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border);justify-content:flex-end;display:flex}.animal-form__actions .btn{min-width:120px}@media (width<=540px){.animal-form__row--2,.animal-form__row--3{grid-template-columns:1fr}.animal-form__actions{flex-direction:column-reverse}.animal-form__actions .btn{width:100%}}.batch-animal{gap:var(--space-4);flex-direction:column;display:flex}.batch-animal__toolbar{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.batch-animal__mode-tabs{border-bottom:2px solid var(--color-border);margin-bottom:var(--space-1);gap:0;display:flex}.batch-animal__mode-tab{padding:var(--space-2) var(--space-4);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;font-size:13px;font-weight:500}.batch-animal__mode-tab:hover{color:var(--color-text-primary)}.batch-animal__mode-tab--active{color:var(--color-forest);border-bottom-color:var(--color-forest);font-weight:600}.csv-import{gap:var(--space-3);flex-direction:column;display:flex}.csv-import__input-row{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.csv-import__template-link{font-family:var(--font-sans);color:var(--color-forest);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;font-weight:500;text-decoration:underline}.csv-import__textarea{width:100%;min-height:160px;padding:var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-cream);color:var(--color-text-primary);font-family:var(--font-sans);resize:vertical;box-sizing:border-box;font-size:13px}.csv-import__textarea:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 2px #3d5c1a26}.csv-import__mapping{gap:var(--space-2);max-height:320px;padding:var(--space-1);flex-direction:column;display:flex;overflow-y:auto}.csv-import__mapping-row{align-items:center;gap:var(--space-2);grid-template-columns:1fr auto 1fr;display:grid}.csv-import__mapping-header{min-width:0;color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.csv-import__mapping-arrow{color:var(--color-text-secondary)}.batch-animal__save-error{margin:0}.batch-animal__scroll{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-cream);overflow-x:auto}.batch-animal__table{border-collapse:collapse;width:100%;min-width:920px;font-size:13px}.bat__th{padding:var(--space-2) var(--space-3);text-align:left;font-family:var(--font-sans);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;background:var(--color-cream-dark);border-bottom:2px solid var(--color-border);white-space:nowrap;font-size:11px;font-weight:600}.bat__req{color:var(--color-rust);font-size:12px}.bat__th--num{text-align:center;width:36px}.bat__th--tag{width:130px}.bat__th--sex{width:110px}.bat__th--breed{width:130px}.bat__th--dob{width:140px}.bat__th--cat,.bat__th--status{width:120px}.bat__th--camp,.bat__th--flock{width:130px}.bat__th--del{width:40px}.bat__row{transition:background var(--transition-fast)}.bat__row:hover{background:var(--color-cream-dark)}.bat__row--err{background:#8b3a1c0a}.bat__row+.bat__row{border-top:1px solid var(--color-border)}.bat__cell{padding:var(--space-1) var(--space-2);vertical-align:middle}.bat__cell--num{text-align:center;color:var(--color-text-secondary);padding-left:var(--space-1);padding-right:var(--space-1);font-size:11px}.bat__cell--del{text-align:center;padding:var(--space-1)}.bat__input,.bat__select{width:100%;height:32px;padding:0 var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-cream);color:var(--color-text-primary);font-family:var(--font-sans);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);box-sizing:border-box;font-size:13px}.bat__input:focus,.bat__select:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 2px #3d5c1a26}.bat__input--err,.bat__select--err{border-color:var(--color-rust);background:#8b3a1c0a}.bat__input--err:focus,.bat__select--err:focus{box-shadow:0 0 0 2px #8b3a1c26}.bat__input--date{padding-right:var(--space-1)}.bat__input::placeholder{color:var(--color-text-disabled)}.bat__input:disabled,.bat__select:disabled{opacity:.6;cursor:not-allowed}.bat__del{border-radius:var(--radius-full);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;margin:0 auto;font-size:12px;display:flex}.bat__del:hover:not(:disabled){color:var(--color-rust);border-color:var(--color-rust);background:#8b3a1c0f}.bat__del:disabled{opacity:.3;cursor:not-allowed}.batch-animal__actions{justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border);display:flex}.lineage-graph{padding:var(--space-4) var(--space-2);flex-direction:column;align-items:center;gap:0;min-width:0;display:flex;overflow-x:auto}.lg-row{gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.lg-row--grandparents{align-items:flex-end;gap:var(--space-5)}.lg-row--parents{gap:var(--space-6,48px)}.lg-row--focus{z-index:1}.lg-row--offspring{gap:var(--space-3);flex-wrap:wrap;justify-content:center;max-width:640px}.lg-pair{gap:var(--space-3);align-items:flex-end;display:flex}.lg-pair-gap{width:var(--space-6,48px)}.lg-connectors{justify-content:center;align-items:flex-start;width:100%;display:flex}.lg-connectors--grandparents{gap:var(--space-6,48px);padding:0 var(--space-4);height:32px}.lg-connectors--parents,.lg-connectors--offspring{align-items:center;height:28px}.lg-branch{flex-direction:column;flex:1;align-items:center;height:32px;display:flex;position:relative}.lg-branch__h{background:var(--color-olive-mid);opacity:.5;width:60%;height:2px}.lg-branch__v{background:var(--color-olive-mid);opacity:.5;flex:1;width:2px}.lg-branch-gap{width:var(--space-6,48px)}.lg-v-line{background:var(--color-olive-mid);opacity:.5;width:2px;height:28px}.lg-node{background:var(--color-cream-dark);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);text-align:center;flex-direction:column;gap:2px;min-width:110px;max-width:150px;display:flex}.lg-node--focus{background:var(--color-forest);border-color:var(--color-forest);min-width:140px;box-shadow:0 2px 8px #3d5c1a40}.lg-node--unknown{opacity:.55;background:0 0;border-style:dashed}.lg-node--external{border-color:var(--color-gold);background:#c4a86a14}.lg-node__role{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-secondary);font-size:9px;font-weight:600}.lg-node--focus .lg-node__role{color:#f5f0e8b3}.lg-node__tag{font-family:var(--font-sans);color:var(--color-text-primary);font-size:13px;font-weight:600}.lg-node--focus .lg-node__tag{color:var(--color-text-inverse);font-size:15px}.lg-node--unknown .lg-node__tag{font-style:italic;font-weight:400}.lg-node__name{font-family:var(--font-sans);color:var(--color-text-secondary);font-size:11px}.lg-node--focus .lg-node__name{color:#f5f0e8cc}.lg-node__breed{font-family:var(--font-sans);color:var(--color-text-secondary);font-size:10px;font-style:italic}.lg-node__sex{font-family:var(--font-sans);margin-top:2px;font-size:10px}.lg-node__sex--female{color:var(--color-terra)}.lg-node__sex--male{color:var(--color-olive-mid)}.lg-node__sex--castrated{color:var(--color-text-secondary)}.lg-node--focus .lg-node__sex{color:#f5f0e8bf}.lg-node__badge{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.06em;color:var(--color-gold);margin-top:2px;font-size:9px;font-weight:600}.lg-empty{font-family:var(--font-sans);color:var(--color-text-secondary);text-align:center;padding:var(--space-6) var(--space-4);font-size:13px;font-style:italic}@media (width<=540px){.lg-row--grandparents{gap:var(--space-3)}.lg-pair-gap,.lg-branch-gap{width:var(--space-3)}.lg-node{min-width:88px;padding:var(--space-2)}}.livestock{gap:var(--space-5);flex-direction:column;display:flex}.livestock__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);display:flex}.livestock__header h1{margin:0 0 var(--space-1)}.livestock__tabs{border-bottom:2px solid var(--color-border);flex-wrap:wrap;gap:0;display:flex}.livestock__tab{padding:var(--space-2) var(--space-5);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;font-size:14px;font-weight:500}.livestock__tab:hover{color:var(--color-text-primary)}.livestock__tab--active{color:var(--color-forest);border-bottom-color:var(--color-forest);font-weight:600}.livestock__content{min-height:200px}.animal-tab{gap:var(--space-4);flex-direction:column;display:flex}.animal-tab__toolbar{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.animal-tab__add-menu{display:inline-flex;position:relative}.animal-tab__add-chevron{margin-left:2px;font-size:10px;line-height:1;display:inline-block}.animal-tab__add-menu-list{top:calc(100% + var(--space-1));z-index:20;min-width:140px;padding:var(--space-1);background:var(--color-cream);border:1.5px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:2px;display:flex;position:absolute;right:0;box-shadow:0 4px 16px #2a2a1a1f}.animal-tab__add-menu-item{text-align:left;width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-family:var(--font-sans);color:var(--color-text-primary);cursor:pointer;transition:background var(--transition-fast);background:0 0;border:none;font-size:13px;font-weight:500}.animal-tab__add-menu-item:hover,.animal-tab__add-menu-item:focus-visible{background:var(--color-cream-dark);outline:none}.animal-tab__state{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-5);text-align:center;color:var(--color-text-secondary);flex-direction:column;display:flex}.animal-tab__state--empty{background:var(--color-cream-dark);border:1.5px dashed var(--color-border);border-radius:var(--radius-xl)}.animal-tab__empty-icon{font-size:36px;line-height:1}.animal-tab__state h3{color:var(--color-text-primary);margin:0}.animal-tab__state p{max-width:320px;margin:0}.animal-tab__spinner{border:3px solid var(--color-border);border-top-color:var(--color-forest);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.animal-tab__table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-cream-dark);overflow-x:auto}.animal-table{border-collapse:collapse;width:100%;font-family:var(--font-sans);font-size:13px}.animal-table thead th{padding:var(--space-2) var(--space-3);text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap;background:var(--color-cream);font-size:11px;font-weight:600}.animal-table thead th:first-child{border-radius:var(--radius-lg) 0 0 0}.animal-table thead th:last-child{border-radius:0 var(--radius-lg) 0 0}.animal-row{cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--color-border)}.animal-row:last-child{border-bottom:none}.animal-row:hover{background:#3d5c1a0a}.animal-row td{padding:7px var(--space-3);color:var(--color-text-primary);vertical-align:middle;white-space:nowrap}.animal-row__tag{color:var(--color-forest);letter-spacing:.02em;font-size:14px;font-weight:700}.animal-row__type{color:var(--color-olive-mid);font-weight:500}.animal-row__location{flex-direction:column;justify-content:center;gap:2px;min-height:32px;display:flex}.animal-row__loc{color:var(--color-text-secondary);font-size:12px}.animal-row__action{text-align:right;white-space:nowrap}.animal-row__qr-cell{white-space:nowrap}.animal-row__qr-badge{align-items:center;gap:var(--space-1);color:var(--color-forest);border-radius:var(--radius-sm);padding:2px var(--space-2);background:#3d5c1a1a;border:1px solid #3d5c1a33;font-size:12px;font-weight:500;display:inline-flex}.animal-row__edit-hint{color:var(--color-olive-mid);opacity:0;transition:opacity var(--transition-fast);font-size:11px}.animal-row:hover .animal-row__edit-hint{opacity:1}.badge--gold{color:var(--color-olive-dark);background:#c4a86a2e;border:1px solid #c4a86a59}.animal-detail{gap:var(--space-4);flex-direction:column;display:flex}.animal-detail__tabs{border-bottom:2px solid var(--color-border);margin-bottom:var(--space-1);gap:0;display:flex}.animal-detail__tab{padding:var(--space-2) var(--space-4);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;font-size:13px;font-weight:500}.animal-detail__tab:hover{color:var(--color-text-primary)}.animal-detail__tab--active{color:var(--color-forest);border-bottom-color:var(--color-forest);font-weight:600}.animal-tab__toolbar-actions{align-items:center;gap:var(--space-2);display:flex}@media (width<=640px){.livestock__header{flex-direction:column}.livestock__header .btn{width:100%}}.batch-camp{gap:var(--space-4);flex-direction:column;display:flex}.batch-camp__toolbar{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.batch-camp__save-error{margin:0}.batch-camp__scroll{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-cream);overflow-x:auto}.batch-camp__table{border-collapse:collapse;width:100%;min-width:680px;font-size:13px}.bct__th{padding:var(--space-2) var(--space-3);text-align:left;font-family:var(--font-sans);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;background:var(--color-cream-dark);border-bottom:2px solid var(--color-border);white-space:nowrap;font-size:11px;font-weight:600}.bct__req{color:var(--color-rust);font-size:12px}.bct__th--num{text-align:center;width:36px}.bct__th--name{width:200px}.bct__th--desc{min-width:180px}.bct__th--size{width:90px}.bct__th--unit{width:70px}.bct__th--cap{width:100px}.bct__th--del{width:40px}.bct__row{transition:background var(--transition-fast)}.bct__row:hover{background:var(--color-cream-dark)}.bct__row--err{background:#8b3a1c0a}.bct__row+.bct__row{border-top:1px solid var(--color-border)}.bct__cell{padding:var(--space-1) var(--space-2);vertical-align:middle}.bct__cell--num{text-align:center;color:var(--color-text-secondary);padding-left:var(--space-1);padding-right:var(--space-1);font-size:11px}.bct__cell--del{text-align:center;padding:var(--space-1)}.bct__input,.bct__select{width:100%;height:32px;padding:0 var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-cream);color:var(--color-text-primary);font-family:var(--font-sans);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);box-sizing:border-box;font-size:13px}.bct__input:focus,.bct__select:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 2px #3d5c1a26}.bct__input--err{border-color:var(--color-rust);background:#8b3a1c0a}.bct__input--err:focus{box-shadow:0 0 0 2px #8b3a1c26}.bct__input--num{text-align:right;padding-right:var(--space-2)}.bct__input::placeholder{color:var(--color-text-disabled)}.bct__input:disabled,.bct__select:disabled{opacity:.6;cursor:not-allowed}.bct__del{border-radius:var(--radius-full);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;margin:0 auto;font-size:12px;display:flex}.bct__del:hover:not(:disabled){color:var(--color-rust);border-color:var(--color-rust);background:#8b3a1c0f}.bct__del:disabled{opacity:.3;cursor:not-allowed}.batch-camp__actions{justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border);display:flex}.batch-flock{gap:var(--space-4);flex-direction:column;display:flex}.batch-flock__toolbar{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.batch-flock__save-error{margin:0}.batch-flock__scroll{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-cream);overflow-x:auto}.batch-flock__table{border-collapse:collapse;width:100%;min-width:560px;font-size:13px}.bft__th{padding:var(--space-2) var(--space-3);text-align:left;font-family:var(--font-sans);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;background:var(--color-cream-dark);border-bottom:2px solid var(--color-border);white-space:nowrap;font-size:11px;font-weight:600}.bft__req{color:var(--color-rust);font-size:12px}.bft__th--num{text-align:center;width:36px}.bft__th--name{min-width:200px}.bft__th--type{width:160px}.bft__th--camp{width:180px}.bft__th--del{width:40px}.bft__row{transition:background var(--transition-fast)}.bft__row:hover{background:var(--color-cream-dark)}.bft__row--err{background:#8b3a1c0a}.bft__row+.bft__row{border-top:1px solid var(--color-border)}.bft__cell{padding:var(--space-1) var(--space-2);vertical-align:middle}.bft__cell--num{text-align:center;color:var(--color-text-secondary);padding-left:var(--space-1);padding-right:var(--space-1);font-size:11px}.bft__cell--del{text-align:center;padding:var(--space-1)}.bft__input,.bft__select{width:100%;height:32px;padding:0 var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-cream);color:var(--color-text-primary);font-family:var(--font-sans);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);box-sizing:border-box;font-size:13px}.bft__input:focus,.bft__select:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 2px #3d5c1a26}.bft__input--err,.bft__select--err{border-color:var(--color-rust);background:#8b3a1c0a}.bft__input--err:focus,.bft__select--err:focus{box-shadow:0 0 0 2px #8b3a1c26}.bft__input::placeholder{color:var(--color-text-disabled)}.bft__input:disabled,.bft__select:disabled{opacity:.6;cursor:not-allowed}.bft__del{border-radius:var(--radius-full);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;margin:0 auto;font-size:12px;display:flex}.bft__del:hover:not(:disabled){color:var(--color-rust);border-color:var(--color-rust);background:#8b3a1c0f}.bft__del:disabled{opacity:.3;cursor:not-allowed}.batch-flock__actions{justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border);display:flex}.camps{gap:var(--space-5);flex-direction:column;display:flex}.camps__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.camps__header h1{margin:0 0 var(--space-1)}.camps__tabs{border-bottom:2px solid var(--color-border);-webkit-overflow-scrolling:touch;display:flex;overflow-x:auto}.camps__tab{padding:var(--space-2) var(--space-5);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;font-size:14px;font-weight:500}.camps__tab:hover{color:var(--color-text-primary)}.camps__tab--active{color:var(--color-forest);border-bottom-color:var(--color-forest);font-weight:600}.camps__content{min-height:200px;padding-top:var(--space-4)}.camps-panel{gap:var(--space-4);flex-direction:column;display:flex}.camps-panel__toolbar{justify-content:space-between;align-items:center;display:flex}.camps-panel__loading{align-items:center;gap:var(--space-3);padding:var(--space-5);display:flex}.camps-panel__spinner{border:2px solid var(--color-border);border-top-color:var(--color-forest);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite camps-spin}@keyframes camps-spin{to{transform:rotate(360deg)}}.camps-panel__empty{align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-5);text-align:center;background:var(--color-cream-dark);border:1.5px dashed var(--color-border);border-radius:var(--radius-xl);flex-direction:column;display:flex}.camps-panel__empty-icon{font-size:36px;line-height:1}.camps-panel__empty h3{color:var(--color-text-primary);margin:0}.camps-panel__empty p{max-width:300px;margin:0}.camps-panel__list{gap:var(--space-3);flex-direction:column;display:flex}.camps-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-cream-dark);overflow-x:auto}.camps-table{border-collapse:collapse;width:100%;font-family:var(--font-sans);font-size:13px}.camps-table thead th{padding:var(--space-2) var(--space-3);text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap;background:var(--color-cream);font-size:11px;font-weight:600}.camps-table thead th:first-child{border-radius:var(--radius-lg) 0 0 0}.camps-table thead th:last-child{border-radius:0 var(--radius-lg) 0 0}.camps-row{cursor:pointer;border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.camps-row:last-child{border-bottom:none}.camps-row:hover td{background:#3d5c1a0a}.camps-row td{padding:var(--space-2) var(--space-3);vertical-align:middle;color:var(--color-text-primary)}.camps-row__name{color:var(--color-text-primary);font-weight:600}.camps-row__desc{color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:220px;overflow:hidden}.camps-row__action{text-align:right}.camps-row__hint{color:var(--color-olive-mid);opacity:0;transition:opacity var(--transition-fast);font-size:11px}.camps-row:hover .camps-row__hint{opacity:1}.camp-card{background:var(--color-cream-dark);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);gap:var(--space-2);text-align:left;cursor:pointer;width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);flex-direction:column;display:flex}.camp-card:hover{border-color:var(--color-olive-mid);box-shadow:var(--shadow-sm)}.camp-card__header{justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.camp-card__name{color:var(--color-text-primary);margin:0;font-size:15px;font-weight:600}.camp-card__actions{align-items:center;gap:var(--space-2);display:flex}.camp-card__arrow{color:var(--color-olive-mid);font-size:12px;font-weight:500}.camp-card__desc{margin:0;font-size:13px}.simple-form{gap:var(--space-4);flex-direction:column;display:flex}.simple-form__row{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.simple-form__actions{gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border);justify-content:flex-end;display:flex}.simple-form__actions .btn{min-width:100px}.record-form{gap:var(--space-3);flex-direction:column;display:flex}.camp-detail{gap:var(--space-5);flex-direction:column;display:flex}.camp-detail__header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border);display:flex}.camp-detail__name{margin:0 0 var(--space-1);font-size:18px}.camp-detail__tabs{border-bottom:2px solid var(--color-border);display:flex}.camp-detail__tab{padding:var(--space-2) var(--space-4);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;font-size:13px;font-weight:500}.camp-detail__tab:hover{color:var(--color-text-primary)}.camp-detail__tab--active{color:var(--color-forest);border-bottom-color:var(--color-forest);font-weight:600}.camp-detail__panel{gap:var(--space-4);padding-top:var(--space-2);flex-direction:column;display:flex}.camp-detail__panel-toolbar{justify-content:space-between;align-items:center;display:flex}.camp-detail__inline-form{background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}.camp-detail__empty{background:var(--color-cream-dark);border:1px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center;color:var(--color-text-secondary);font-size:13px}.record-log{flex-direction:column;gap:0;display:flex}.record-log__entry{justify-content:space-between;align-items:flex-start;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);display:flex}.record-log__entry:last-child{border-bottom:none}.record-log__left{gap:var(--space-1);flex-direction:column;display:flex}.record-log__notes{color:var(--color-text-secondary);margin:0;font-size:13px}.record-log__time{color:var(--color-text-secondary);white-space:nowrap;flex-shrink:0}.flock-detail{gap:var(--space-5);flex-direction:column;display:flex}.flock-detail__header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);display:flex}.flock-detail__name{margin:0 0 var(--space-1);font-size:18px}.flock-detail__meta{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.flock-detail__members-header{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.flock-detail__members-header h3{margin:0}.flock-detail__count{font-family:var(--font-sans);color:var(--color-text-secondary);font-size:14px;font-weight:400}.flock-detail__empty{background:var(--color-cream-dark);border:1px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.flock-detail__member-list{gap:var(--space-2);flex-direction:column;display:flex}.flock-detail__member{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex}.flock-detail__member-info{align-items:center;gap:var(--space-2);flex-wrap:wrap;min-width:0;display:flex}.flock-detail__member-tag{font-weight:600;font-family:var(--font-sans);font-size:14px}.flock-detail__member-name{color:var(--color-text-secondary);font-size:13px}.flock-detail__member-remove{cursor:pointer;color:var(--color-text-secondary);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;font-size:13px;line-height:1}.flock-detail__member-remove:hover{background:var(--color-cream-dark);color:var(--color-rust)}.flock-picker{gap:var(--space-3);flex-direction:column;display:flex}.flock-picker__search{width:100%;padding:var(--space-2) var(--space-3);border:1.5px solid var(--color-sand);border-radius:var(--radius-md);font-family:var(--font-sans);background:var(--color-cream);color:var(--color-text-primary);box-sizing:border-box;font-size:14px}.flock-picker__search:focus{border-color:var(--color-olive-mid);outline:none}.flock-picker__select-all{align-items:center;gap:var(--space-2);color:var(--color-text-secondary);cursor:pointer;padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border);font-size:13px;display:flex}.flock-picker__select-all input[type=checkbox]{accent-color:var(--color-forest);cursor:pointer;width:15px;height:15px}.flock-picker__list{border:1px solid var(--color-border);border-radius:var(--radius-md);max-height:300px;padding:var(--space-1);flex-direction:column;gap:2px;display:flex;overflow-y:auto}.flock-picker__empty{padding:var(--space-4);text-align:center}.flock-picker__item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;flex-wrap:wrap;display:flex}.flock-picker__item:hover{background:var(--color-cream-dark)}.flock-picker__item input[type=checkbox]{accent-color:var(--color-forest);cursor:pointer;flex-shrink:0;width:15px;height:15px}.flock-picker__tag{min-width:56px;font-size:13px;font-weight:600}.flock-picker__name{font-size:13px}.flock-picker__breed{font-size:11px}.flock-picker__current{font-size:11px;font-style:italic}.flock-picker__actions{justify-content:flex-end;gap:var(--space-2);padding-top:var(--space-3);border-top:1px solid var(--color-border);display:flex}@media (width<=640px){.camps__header{flex-direction:column}.camps__header .btn{width:100%}.camps-panel__toolbar{gap:var(--space-2);flex-wrap:wrap}.flock-detail__header{flex-direction:column}}@media (width<=480px){.simple-form__row{grid-template-columns:1fr}.camp-detail__header{flex-direction:column}.record-log__entry{gap:var(--space-2);flex-direction:column}.flock-picker__actions{flex-direction:column}.flock-picker__actions .btn{width:100%}}.health{gap:var(--space-5);flex-direction:column;display:flex}.health__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.health__header h1{margin:0 0 var(--space-1)}.health__filters{gap:var(--space-2);flex-wrap:wrap;display:flex}.health__filter-btn{padding:var(--space-2) var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);background:0 0;font-size:13px;font-weight:500}.health__filter-btn:hover{border-color:var(--color-olive-mid);color:var(--color-text-primary)}.health__filter-btn--active{background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);border-color:var(--color-forest);color:var(--color-text-inverse)}.health__loading{align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-5);display:flex}.health__spinner{border:2px solid var(--color-border);border-top-color:var(--color-forest);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite health-spin}@keyframes health-spin{to{transform:rotate(360deg)}}.health__empty{align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-5);text-align:center;background:var(--color-cream-dark);border:1.5px dashed var(--color-border);border-radius:var(--radius-xl);flex-direction:column;display:flex}.health__empty-icon{font-size:40px;line-height:1}.health__empty h3{color:var(--color-text-primary);margin:0}.health__empty p{max-width:320px;margin:0}.health__table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-cream-dark);overflow-x:auto}.health-table{border-collapse:collapse;width:100%;font-family:var(--font-sans);font-size:13px}.health-table thead tr{border-bottom:1px solid var(--color-border)}.health-table th{padding:var(--space-2) var(--space-3);text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-secondary);white-space:nowrap;background:var(--color-cream);font-size:11px;font-weight:600}.health-table thead th:first-child{border-radius:var(--radius-lg) 0 0 0}.health-table thead th:last-child{border-radius:0 var(--radius-lg) 0 0}.he-row{border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast)}.he-row:last-child{border-bottom:none}.he-row:hover{background:#3d5c1a0a}.he-row:focus{outline:2px solid var(--color-border-focus);outline-offset:-2px}.he-row td{padding:var(--space-2) var(--space-3);vertical-align:middle}.he-row__date{white-space:nowrap;color:var(--color-text-primary);font-weight:500}.he-row__target{flex-direction:column;justify-content:center;gap:2px;min-height:34px;display:flex}.he-row__target-type{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);font-size:10px;font-weight:600}.he-row__desc{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:240px;overflow:hidden}.he-row__action{text-align:right}.he-row__edit-hint{color:var(--color-olive-mid);font-size:12px;font-weight:500}.he-resolve-bar{justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);border:1px solid var(--color-gold);border-radius:var(--radius-lg);margin-bottom:var(--space-4);background:#fff8ed;flex-wrap:wrap;display:flex}.he-resolve-bar p{margin:0}.he-form{gap:var(--space-4);flex-direction:column;display:flex}.he-form__section{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);gap:var(--space-3);flex-direction:column;display:flex}.he-form__legend{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-secondary);padding:0 var(--space-2);font-size:11px;font-weight:600}.he-form__row--2{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.he-form__actions{gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border);justify-content:flex-end;display:flex}.he-form__actions .btn{min-width:110px}@media (width<=640px){.health__header{flex-direction:column}.he-form__row--2{grid-template-columns:1fr}.he-resolve-bar{flex-direction:column;align-items:flex-start}}.notes{gap:var(--space-5);flex-direction:column;display:flex}.notes__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.notes__header h1{margin:0 0 var(--space-1)}.notes__tabs{border-bottom:2px solid var(--color-border);display:flex}.notes__tab{padding:var(--space-2) var(--space-5);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;font-size:14px;font-weight:500}.notes__tab:hover{color:var(--color-text-primary)}.notes__tab--active{color:var(--color-forest);border-bottom-color:var(--color-forest);font-weight:600}.notes__content{padding-top:var(--space-2)}.notes-tab{gap:var(--space-4);flex-direction:column;display:flex}.notes-tab__toolbar{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.notes-tab__toolbar p{margin:0}.notes-tab__list{gap:var(--space-3);flex-direction:column;display:flex}.notes__loading{align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-5);display:flex}.notes__spinner{border:2px solid var(--color-border);border-top-color:var(--color-forest);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite notes-spin}@keyframes notes-spin{to{transform:rotate(360deg)}}.notes__empty{align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-5);text-align:center;background:var(--color-cream-dark);border:1.5px dashed var(--color-border);border-radius:var(--radius-xl);flex-direction:column;display:flex}.notes__empty-icon{font-size:40px;line-height:1}.notes__empty h3{color:var(--color-text-primary);margin:0}.notes__empty p{max-width:320px;margin:0}.note-card{background:var(--color-cream-dark);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);gap:var(--space-3);cursor:pointer;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);flex-direction:column;display:flex;position:relative}.note-card:hover{border-color:var(--color-olive-mid);box-shadow:var(--shadow-sm)}.note-card:focus{outline:2px solid var(--color-forest);outline-offset:2px}.note-card__header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);flex-wrap:wrap;display:flex}.note-card__meta{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.note-card__target{align-items:center;gap:var(--space-1);color:var(--color-text-secondary);font-size:12px;display:flex}.note-card__target-type{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-disabled);font-size:10px;font-weight:600}.note-card__counts{align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex}.note-card__count-item{flex-direction:column;gap:2px;display:flex}.note-card__count-item strong{color:var(--color-text-primary);font-size:20px;font-weight:600}.note-card__count-sep{color:var(--color-text-secondary);font-size:16px}.note-card__diff{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);margin-left:auto;font-size:14px;font-weight:700}.note-card__diff--neutral{background:var(--color-cream-mid);color:var(--color-text-secondary)}.note-card__diff--increase{color:#3d7a12;background:#e8f5da}.note-card__diff--minor-decrease{color:#8a5e00;background:#fff3da}.note-card__diff--decrease{color:var(--color-rust);background:#fdeae2}.note-card__body{color:var(--color-text-primary);white-space:pre-wrap;margin:0;font-size:13px;line-height:1.6}.note-card__tags{gap:var(--space-1);flex-wrap:wrap;display:flex}.note-card__tag{padding:2px var(--space-2);background:var(--color-cream-mid);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:11px;font-weight:500}.note-card__edit-hint{color:var(--color-olive-mid);align-self:flex-end;font-size:12px;font-weight:500}.note-form{gap:var(--space-4);flex-direction:column;display:flex}.note-form__row--2{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.note-form__prev-info{padding:var(--space-2) var(--space-3);background:var(--color-cream-mid);border-radius:var(--radius-md);margin:0}.note-form__diff{padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;font-size:13px;display:flex}.note-form__diff-label{color:var(--color-text-secondary);font-weight:500}.note-form__diff-value{font-size:15px;font-weight:700}.note-form__diff--neutral{background:var(--color-cream-mid)}.note-form__diff--increase{color:#3d7a12;background:#e8f5da}.note-form__diff--minor-decrease{color:#8a5e00;background:#fff3da}.note-form__diff--decrease{color:var(--color-rust);background:#fdeae2}.note-form__tags{gap:var(--space-2);flex-direction:column;display:flex}.note-form__tags-label{margin:0}.note-form__tag-list{gap:var(--space-2);flex-wrap:wrap;display:flex}.note-form__tag{padding:var(--space-1) var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);background:0 0;font-size:12px;font-weight:500}.note-form__tag:hover{border-color:var(--color-olive-mid);color:var(--color-text-primary)}.note-form__tag--active{background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);border-color:var(--color-forest);color:var(--color-text-inverse)}.note-form__actions{gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border);justify-content:flex-end;display:flex}.note-form__actions .btn{min-width:110px}.notes__delete-bar{padding-top:var(--space-4);margin-top:var(--space-2);border-top:1px solid var(--color-border);justify-content:flex-end;display:flex}@media (width<=600px){.note-form__row--2{grid-template-columns:1fr}.note-card__counts{gap:var(--space-3);flex-wrap:wrap}.note-card__diff{margin-left:0}.notes__header{flex-direction:column}}.settings{gap:var(--space-6);flex-direction:column;max-width:800px;display:flex}.settings__header h1{margin:0 0 var(--space-1)}.settings__tabs{border-bottom:2px solid var(--color-border);gap:0;display:flex}.settings__tab{padding:var(--space-3) var(--space-5);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;font-size:14px;font-weight:500}.settings__tab:hover{color:var(--color-text-primary)}.settings__tab--active{color:var(--color-forest);border-bottom-color:var(--color-forest);font-weight:600}.settings__tab-pane,.settings__defaults{gap:var(--space-5);flex-direction:column;display:flex}.settings__card{gap:var(--space-5);padding:var(--space-6);background:var(--color-cream-dark);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);flex-direction:column;display:flex}.settings__card-header{gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border);flex-direction:column;display:flex}.settings__card-header h3,.settings__card-header .caption{margin:0}.settings__card-header-row{justify-content:space-between;align-items:flex-start;gap:var(--space-4);display:flex}.settings__header-actions{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.settings__saved-badge{color:#3d6010;white-space:nowrap;font-size:12px;font-weight:600}.settings__defaults-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);padding-bottom:var(--space-4);border-bottom:2px solid var(--color-border);display:flex}.settings__defaults-header h3,.settings__defaults-header .caption{margin:0}.settings__form{gap:var(--space-5);flex-direction:column;display:flex}.settings__form-grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.settings__readonly-grid{gap:var(--space-4);padding:0 var(--space-5) var(--space-5);grid-template-columns:1fr 1fr;display:grid}.settings__readonly-field{flex-direction:column;gap:4px;display:flex}.settings__readonly-value{font-family:var(--font-sans);color:var(--color-text-primary);margin:0;font-size:14px}.settings__form-actions{padding-top:var(--space-3);border-top:1px solid var(--color-border);justify-content:flex-end;display:flex}.settings__success{padding:var(--space-3) var(--space-4);border:1px solid var(--color-olive-light);border-radius:var(--radius-lg);color:#3d6010;background:#eaf5da;margin:0;font-size:13px;font-weight:500}.settings__field-group{gap:var(--space-3);flex-direction:column;display:flex}.settings__field-label{color:var(--color-text-primary);margin:0;font-size:13px;font-weight:600}.settings__field-error{color:var(--color-rust);margin:0;font-size:12px}.settings__animal-grid{gap:var(--space-2);flex-wrap:wrap;display:flex}.settings__animal-tile{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-cream);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:border-color var(--transition-fast), background var(--transition-fast), color var(--transition-fast);font-size:13px;font-weight:500;display:flex}.settings__animal-tile:hover{border-color:var(--color-olive-mid);color:var(--color-text-primary)}.settings__animal-tile--selected{border-color:var(--color-forest);background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);color:var(--color-text-inverse)}.settings__animal-check{text-align:center;width:14px;font-size:11px}.settings__units-row{gap:var(--space-3);grid-template-columns:1fr 1fr 1fr;display:grid}.settings__table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow-x:auto}.settings__table{border-collapse:collapse;width:100%;font-size:13px}.settings__table th{padding:var(--space-3) var(--space-4);text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);background:var(--color-cream);border-bottom:2px solid var(--color-border);white-space:nowrap;font-size:11px;font-weight:600}.settings__table td{padding:var(--space-3) var(--space-4);vertical-align:middle;border-bottom:1px solid var(--color-border)}.settings__table tr:last-child td{border-bottom:none}.settings__table tbody tr:hover{background:var(--color-cream)}.settings__member-name{color:var(--color-text-primary);font-weight:600}.settings__member-you{margin-left:var(--space-2);padding:1px var(--space-2);text-transform:uppercase;letter-spacing:.04em;background:var(--color-cream-mid);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:10px;font-weight:600;display:inline-block}.settings__cell-muted{color:var(--color-text-secondary);font-size:12px}.settings__role-select{padding:var(--space-1) var(--space-2);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-sans);background:var(--color-cream);color:var(--color-text-primary);cursor:pointer;font-size:12px}.settings__invite-form{gap:var(--space-4);flex-direction:column;display:flex}.settings__invite-row{gap:var(--space-3);grid-template-columns:2fr 1fr;display:grid}.settings__breed-tabs{gap:var(--space-2);flex-wrap:wrap;display:flex}.settings__breed-tab{padding:var(--space-1) var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;font-size:13px;font-weight:500}.settings__breed-tab:hover{border-color:var(--color-olive-mid);color:var(--color-text-primary)}.settings__breed-tab--active{background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);border-color:var(--color-forest);color:var(--color-text-inverse)}.settings__reminder-row{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.list-editor{gap:var(--space-3);flex-direction:column;display:flex}.list-editor__tags{gap:var(--space-2);flex-wrap:wrap;align-items:flex-start;min-height:36px;display:flex}.list-editor__tag{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--color-cream);border:1.5px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-primary);font-size:13px;font-weight:500;line-height:1.4;display:inline-flex}.list-editor__remove{width:16px;height:16px;color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;display:inline-flex}.list-editor__remove:hover{background:var(--color-rust);color:var(--color-text-inverse)}.list-editor__row{gap:var(--space-2);display:flex}.list-editor__input{padding:var(--space-2) var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-sans);background:var(--color-cream);color:var(--color-text-primary);transition:border-color var(--transition-fast);flex:1;font-size:13px}.list-editor__input:focus{border-color:var(--color-border-focus);outline:none}.list-editor__input::placeholder{color:var(--color-text-disabled)}.list-editor__add-btn{padding:var(--space-2) var(--space-4);border:1.5px solid var(--color-forest);border-radius:var(--radius-full);font-family:var(--font-sans);color:var(--color-forest);cursor:pointer;white-space:nowrap;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;font-size:13px;font-weight:600}.list-editor__add-btn:hover{background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);color:var(--color-text-inverse)}@media (width<=640px){.settings__card{padding:var(--space-4)}.settings__form-grid,.settings__units-row,.settings__invite-row,.settings__reminder-row{grid-template-columns:1fr}.settings__tab{padding:var(--space-3) var(--space-3);font-size:13px}.settings__table th:nth-child(3),.settings__table td:nth-child(3),.settings__table th:nth-child(6),.settings__table td:nth-child(6){display:none}}.animal-page{background:var(--color-cream);min-height:100vh;padding:var(--space-5) var(--space-4)}.animal-page--centered{justify-content:center;align-items:center;gap:var(--space-4);text-align:center;flex-direction:column;display:flex}.animal-page__inner{gap:var(--space-4);flex-direction:column;max-width:600px;margin:0 auto;display:flex}.animal-page__back-link{color:var(--color-olive-mid);align-items:center;gap:var(--space-1);cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:0;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.animal-page__back-link:hover{color:var(--color-forest)}.animal-page__header{gap:var(--space-2);padding:var(--space-5) var(--space-5) var(--space-4);background:var(--color-forest);border-radius:var(--radius-xl);color:var(--color-text-inverse);flex-direction:column;display:flex}.animal-page__tag{font-family:var(--font-serif);color:var(--color-text-inverse);font-size:36px;font-weight:700;line-height:1.1}.animal-page__name{color:#f2ede3cc;margin:0;font-size:16px;font-weight:500}.animal-page__type-label{margin:var(--space-1) 0 0;color:#f2ede38c}.animal-page__badges{gap:var(--space-2);margin-top:var(--space-1);flex-wrap:wrap;display:flex}.animal-page__header .badge{color:var(--color-text-inverse);background:#f2ede326;border:1.5px solid #f2ede34d}.animal-page__tabs{background:var(--color-cream-dark);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-1);gap:0;display:flex}.animal-page__tab{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);white-space:nowrap;background:0 0;border:none;flex:1;font-size:13px;font-weight:500}.animal-page__tab:hover{color:var(--color-text-primary);background:var(--color-cream-mid)}.animal-page__tab--active{background:var(--color-cream);color:var(--color-forest);box-shadow:var(--shadow-sm);font-weight:600}.animal-page__card{background:var(--color-cream-dark);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);gap:var(--space-3);flex-direction:column;display:flex}.animal-page__card--flush{padding:0;overflow:hidden}.animal-page__card--flush .animal-form{padding:var(--space-5)}.animal-page__section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);margin:0;font-size:13px;font-weight:600}.animal-page__details{flex-direction:column;gap:0;display:flex}.animal-page__detail-row{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--color-border);display:flex}.animal-page__detail-row:last-child{border-bottom:none}.animal-page__detail-label{color:var(--color-text-secondary);flex-shrink:0;font-size:13px}.animal-page__detail-value{color:var(--color-text-primary);text-align:right;font-size:13px;font-weight:500}.animal-page__notes{color:var(--color-text-primary);white-space:pre-wrap;margin:0;font-size:13px;line-height:1.7}.assign-form__fields{gap:var(--space-3);flex-direction:column;display:flex}.assign-form__actions{padding-top:var(--space-2);justify-content:flex-end;display:flex}.assign-form__saved{color:var(--color-forest);margin:0;font-size:13px;font-weight:500}.health-tab__header{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.health-tab__form-wrap{border-top:1px solid var(--color-border);padding-top:var(--space-4)}.health-tab__empty{padding:var(--space-4) 0}.health-tab__list{gap:var(--space-3);border-top:1px solid var(--color-border);padding-top:var(--space-3);flex-direction:column;display:flex}.health-event{border-left:3px solid var(--color-border);padding:var(--space-3) var(--space-3) var(--space-3) var(--space-4);background:var(--color-cream);border-radius:0 var(--radius-md) var(--radius-md) 0;gap:var(--space-2);flex-direction:column;display:flex}.health-event--info{border-left-color:var(--color-info)}.health-event--warning{border-left-color:var(--color-warning)}.health-event--critical{border-left-color:var(--color-critical)}.health-event__top{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.health-event__type{color:var(--color-text-primary);font-size:13px;font-weight:600}.health-event__meta{gap:var(--space-2);flex-wrap:wrap;align-items:center;display:flex}.health-event__desc{color:var(--color-text-primary);margin:0;font-size:13px;line-height:1.6}.health-event__drug,.health-event__followup{margin:0}.health-form{gap:var(--space-3);flex-direction:column;display:flex}.health-form__row{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.health-form__actions{justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border);display:flex}.animal-page__spinner{border:3px solid var(--color-border);border-top-color:var(--color-forest);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.animal-page__not-found{color:var(--color-text-secondary);margin:0;font-size:16px}@media (width<=480px){.animal-page{padding:var(--space-4) var(--space-3)}.animal-page__tag{font-size:28px}.animal-page__tab{padding:var(--space-2);font-size:12px}.health-form__row{grid-template-columns:1fr}}.admin{background:var(--color-cream);min-height:100vh;padding:var(--space-6) var(--space-5)}.admin__inner{gap:var(--space-6);flex-direction:column;max-width:960px;margin:0 auto;display:flex}.admin__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);display:flex}.admin__eyebrow{margin:0 0 var(--space-1);text-transform:uppercase;letter-spacing:.1em;color:var(--color-olive-mid);font-size:11px;font-weight:600}.admin__header h1{margin:0}.admin__apps{gap:var(--space-4);flex-direction:column;display:flex}.admin__app-card{background:var(--color-cream-dark);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5) var(--space-6);gap:var(--space-5);flex-direction:column;display:flex}.admin__app-header{align-items:center;gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border);display:flex}.admin__app-badge{background:var(--color-forest);width:40px;height:40px;color:var(--color-text-inverse);border-radius:var(--radius-lg);font-family:var(--font-serif);flex-shrink:0;justify-content:center;align-items:center;font-size:22px;font-weight:700;display:flex}.admin__app-header h3,.admin__app-header .caption{margin:0}.admin__stats{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.admin-stat{background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);text-align:center}.admin-stat__value{margin:0 0 var(--space-1);font-family:var(--font-serif);color:var(--color-forest);font-size:36px;font-weight:700;line-height:1}.admin-stat__label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);margin:0;font-size:12px;font-weight:600}.admin-stat__sub{margin:var(--space-1) 0 0;color:var(--color-text-secondary);font-size:11px}.admin__section{gap:var(--space-3);flex-direction:column;display:flex}.admin__section h3{margin:0}.admin__table-wrap{border:1.5px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-cream-dark);overflow-x:auto}.admin__table{border-collapse:collapse;width:100%;font-size:13px}.admin__table th{padding:var(--space-2) var(--space-4);text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);background:var(--color-cream);border-bottom:1.5px solid var(--color-border);white-space:nowrap;font-size:11px;font-weight:600}.admin__table th:first-child{border-radius:var(--radius-lg) 0 0 0}.admin__table th:last-child{border-radius:0 var(--radius-lg) 0 0}.admin__table td{padding:var(--space-3) var(--space-4);vertical-align:middle;border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.admin__table tbody tr:last-child td{border-bottom:none}.admin__table tbody tr:hover{background:#3d5c1a08}.admin__farm-name{font-weight:600;display:block}.admin__farm-loc{color:var(--color-text-secondary);margin-top:1px;font-size:11px;display:block}.admin__owner-name{font-weight:500;display:block}.admin__owner-email{color:var(--color-text-secondary);font-size:11px;display:block}.admin__cell-muted{color:var(--color-text-secondary)}.admin__cell-num{font-variant-numeric:tabular-nums;text-align:center;font-weight:600}@media (width<=640px){.admin{padding:var(--space-4) var(--space-3)}.admin__stats{grid-template-columns:repeat(3,1fr)}.admin-stat__value{font-size:28px}.admin__app-card{padding:var(--space-4)}.admin__table th:nth-child(2),.admin__table td:nth-child(2),.admin__table th:nth-child(6),.admin__table td:nth-child(6){display:none}}.qr-page{padding:var(--space-5) var(--space-5);max-width:960px}.qr-page__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.qr-page__title{margin:0 0 var(--space-1);font-family:var(--font-serif);color:var(--color-text-primary);font-size:28px}.qr-page__subtitle{color:var(--color-text-secondary);margin:0}.qr-page__header-actions{gap:var(--space-2);flex-shrink:0;align-items:center;display:flex}.qr-page__filters{gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;align-items:center;display:flex}.qr-page__search{min-width:200px;height:36px;padding:0 var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-cream);font-family:var(--font-sans);color:var(--color-text-primary);transition:border-color var(--transition-fast);outline:none;flex:1;font-size:14px}.qr-page__search:focus{border-color:var(--color-forest)}.qr-page__search::placeholder{color:var(--color-text-secondary)}.qr-page__filter-tabs{background:var(--color-cream-dark);border:1.5px solid var(--color-border);border-radius:var(--radius-md);gap:0;padding:2px;display:flex}.qr-page__filter-tab{padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);white-space:nowrap;background:0 0;border:none;font-size:13px;font-weight:500}.qr-page__filter-tab--active{background:var(--color-cream);color:var(--color-forest);box-shadow:var(--shadow-sm);font-weight:600}.qr-page__table-wrap{background:var(--color-cream-dark);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);overflow-x:auto}.qr-table{border-collapse:collapse;table-layout:fixed;width:100%}.qr-table thead th:first-child{width:auto}.qr-table thead th:nth-child(2){width:120px}.qr-table thead th:nth-child(3){width:200px}.qr-table thead th:nth-child(4){width:160px}.qr-table thead th{padding:var(--space-3) var(--space-4);text-align:left;font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);border-bottom:1.5px solid var(--color-border);background:var(--color-cream);white-space:nowrap;font-size:11px;font-weight:600;overflow:hidden}.qr-row td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);vertical-align:middle;overflow:hidden}.qr-row:last-child td{border-bottom:none}.qr-row:hover td{background:var(--color-cream)}.qr-row__label{flex-direction:column;gap:2px;display:flex}.qr-row__tag-label{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.qr-row__notes{color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.qr-row__animal{text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.qr-row__actions{white-space:nowrap;align-items:center;gap:6px;display:flex}.qr-action-btn{border:1.5px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-cream);width:30px;height:30px;color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.qr-action-btn:hover{background:var(--color-cream-dark);color:var(--color-forest);border-color:var(--color-olive-mid)}.qr-action-btn--danger:hover{background:var(--color-rust);color:var(--color-text-inverse);border-color:var(--color-rust)}.qr-page__state{align-items:center;gap:var(--space-4);padding:var(--space-10) var(--space-5);text-align:center;flex-direction:column;display:flex}.qr-page__spinner{border:3px solid var(--color-border);border-top-color:var(--color-forest);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite qr-spin}@keyframes qr-spin{to{transform:rotate(360deg)}}.qr-page__empty{align-items:center;gap:var(--space-3);padding:var(--space-10) var(--space-5);text-align:center;flex-direction:column;max-width:420px;margin:0 auto;display:flex}.qr-page__empty-icon{color:var(--color-olive-mid);margin:0;font-size:48px;line-height:1}.qr-page__empty h3{color:var(--color-text-primary);margin:0}.qr-modal{align-items:center;gap:var(--space-3);padding:var(--space-2) 0 var(--space-4);flex-direction:column;display:flex}.qr-modal__code{background:var(--color-cream);padding:var(--space-4);border-radius:var(--radius-lg);border:1.5px solid var(--color-border);line-height:0}.qr-modal__label{color:var(--color-text-primary);margin:0;font-size:18px;font-weight:600}.qr-modal__animal{color:var(--color-text-secondary);margin:0;font-size:14px}.qr-modal__url{color:var(--color-text-secondary);word-break:break-all;text-align:center;max-width:280px;margin:0}.qr-modal__actions{gap:var(--space-2);width:100%;padding-top:var(--space-2);border-top:1px solid var(--color-border);flex-direction:column;display:flex}.assign-modal__current{margin:0 0 var(--space-4);padding:var(--space-3);border:1px solid var(--color-gold);border-radius:var(--radius-md);color:var(--color-olive-dark);background:#c4a86a26;font-size:13px}.unassign-modal__desc{margin:0 0 var(--space-4);color:var(--color-text-primary);font-size:14px;line-height:1.6}.history-modal{overflow-x:auto}.history-table{border-collapse:collapse;width:100%;font-size:13px}.history-table th{text-align:left;padding:var(--space-2) var(--space-3);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);border-bottom:1.5px solid var(--color-border);white-space:nowrap;background:var(--color-cream);font-size:11px;font-weight:600}.history-table td{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border);vertical-align:middle;color:var(--color-text-primary)}.history-table tr:last-child td{border-bottom:none}.history-table tbody tr:hover td{background:var(--color-cream-dark)}.history-table__animal{font-weight:500}.form-stack{gap:var(--space-3);margin-bottom:var(--space-4);flex-direction:column;display:flex}.modal-actions{justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--color-border);display:flex}.bulk-qr{z-index:1000;background:var(--color-cream);flex-direction:column;display:flex;position:fixed;inset:0;overflow-y:auto}.bulk-qr__controls{justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--color-cream-dark);border-bottom:1.5px solid var(--color-border);flex-wrap:wrap;flex-shrink:0;display:flex}.bulk-qr__controls-left h3{margin:0 0 2px}.bulk-qr__controls-left .caption{margin:0}.bulk-qr__controls-right{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.bulk-qr__toggle{align-items:center;gap:var(--space-2);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;font-size:13px;display:inline-flex}.bulk-qr__grid{gap:var(--space-3);padding:var(--space-5) var(--space-6);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.bulk-qr__item{align-items:center;gap:var(--space-2);padding:var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition-fast), opacity var(--transition-fast);background:#fff;flex-direction:column;display:flex;position:relative}.bulk-qr__item--selected{border-color:var(--color-forest)}.bulk-qr__grid:has(.bulk-qr__item--selected) .bulk-qr__item:not(.bulk-qr__item--selected){opacity:.45}.bulk-qr__item-check{top:var(--space-2);right:var(--space-2);cursor:pointer;width:16px;height:16px;position:absolute}.bulk-qr__tag{color:var(--color-text-primary);letter-spacing:.02em;font-size:13px;font-weight:700}.bulk-qr__printed-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);background:var(--color-cream-mid);border-radius:var(--radius-full);padding:2px 8px;font-size:10px;font-weight:500}@media print{#root{display:none!important}.bulk-qr{position:static!important;overflow:visible!important}.bulk-qr__controls{display:none!important}.bulk-qr__grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;padding:0}.bulk-qr__item{break-inside:avoid;border:1px solid #ccc;opacity:1!important}.bulk-qr__item:not(.bulk-qr__item--selected),.bulk-qr__item-check,.bulk-qr__printed-badge{display:none!important}}@media (width<=768px){.qr-page{padding:var(--space-4) var(--space-3)}.qr-page__filters{flex-direction:column;align-items:stretch}.qr-page__search{min-width:0}}.qrl{background:var(--color-cream);min-height:100vh;padding:var(--space-5)}.qrl--centered{text-align:center;justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.qrl__spinner{border:3px solid var(--color-border);border-top-color:var(--color-forest);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite qrl-spin}@keyframes qrl-spin{to{transform:rotate(360deg)}}.qrl__icon{color:var(--color-olive-mid);font-size:48px;line-height:1}.qrl__heading{font-family:var(--font-serif);color:var(--color-text-primary);margin:0;font-size:24px}.qrl__body{color:var(--color-text-secondary);max-width:340px;margin:0;font-size:15px;line-height:1.6}.qrl__actions{gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.qrl__btn{height:40px;padding:0 var(--space-5);border-radius:var(--radius-full);font-family:var(--font-sans);cursor:pointer;transition:background var(--transition-fast);border:none;justify-content:center;align-items:center;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex}.qrl__btn--primary{background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);color:var(--color-text-inverse)}.qrl__btn--primary:hover{background:linear-gradient(135deg, #2f4614 0%, var(--color-olive-mid) 100%)}.qrl__btn--secondary{background:var(--color-cream-dark);color:var(--color-text-primary);border:1.5px solid var(--color-border)}.qrl__btn--secondary:hover{background:var(--color-sand)}.pastures{gap:var(--space-5);flex-direction:column;display:flex}.pastures__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.pastures__header h1{margin:0 0 var(--space-1)}.pastures__summary{gap:var(--space-2);flex-wrap:wrap;align-items:center;display:flex}.pastures__summary .badge{padding:3px 12px;font-size:12px}.pastures__filters{gap:var(--space-2);flex-wrap:wrap;display:flex}.pastures__filter-btn{padding:var(--space-2) var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);background:0 0;font-size:13px;font-weight:500}.pastures__filter-btn:hover{border-color:var(--color-olive-mid);color:var(--color-text-primary)}.pastures__filter-btn--active{background:linear-gradient(135deg, var(--color-forest) 0%, var(--color-olive-light) 100%);border-color:var(--color-forest);color:var(--color-text-inverse)}.pastures__table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-cream-dark);overflow-x:auto}.pasture-table{border-collapse:collapse;width:100%;font-family:var(--font-sans);font-size:13px}.pasture-table thead th{padding:var(--space-2) var(--space-3);text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap;background:var(--color-cream);font-size:11px;font-weight:600}.pasture-table thead th:first-child{border-radius:var(--radius-lg) 0 0 0}.pasture-table thead th:last-child{border-radius:0 var(--radius-lg) 0 0}.pasture-row{border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.pasture-row:last-child{border-bottom:none}.pasture-row:hover td{background:#3d5c1a0a}.pasture-row td{padding:var(--space-2) var(--space-3);vertical-align:middle;color:var(--color-text-primary)}.pasture-row--poor .pasture-row__name{box-shadow:inset 3px 0 0 var(--color-rust)}.pasture-row--stale .pasture-row__name{box-shadow:inset 3px 0 0 var(--color-gold)}.pasture-row__name{color:var(--color-text-primary);font-weight:600}.pasture-row__age--stale{color:var(--color-terra);font-weight:500}.pasture-row__animals{font-variant-numeric:tabular-nums}.pasture-row__rainfall{align-items:baseline;gap:var(--space-1);font-variant-numeric:tabular-nums;display:inline-flex}.pasture-row__rainfall-age{white-space:nowrap}.pasture-row__action{text-align:right}.pasture-log-btn{padding:4px var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-cream);font-family:var(--font-sans);color:var(--color-forest);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);white-space:nowrap;font-size:12px;font-weight:500}.pasture-log-btn:hover{background:var(--color-cream-dark);border-color:var(--color-forest)}.pasture-log-form{gap:var(--space-4);flex-direction:column;display:flex}.pasture-log-form__camp{color:var(--color-text-primary);margin:0;font-size:15px;font-weight:600}.pasture-log-form__tabs{border-bottom:2px solid var(--color-border);gap:0;display:flex}.pasture-log-form__tab{padding:var(--space-2) var(--space-4);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;font-size:13px;font-weight:500}.pasture-log-form__tab:hover{color:var(--color-text-primary)}.pasture-log-form__tab--active{color:var(--color-forest);border-bottom-color:var(--color-forest);font-weight:600}.pasture-log-form__fields{gap:var(--space-3);flex-direction:column;display:flex}.pasture-log-form__row{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.pasture-log-form__actions{justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border);margin-top:var(--space-1);display:flex}.pastures__loading{align-items:center;gap:var(--space-3);padding:var(--space-5);display:flex}.pastures__spinner{border:2px solid var(--color-border);border-top-color:var(--color-forest);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite pasture-spin}@keyframes pasture-spin{to{transform:rotate(360deg)}}.pastures__empty{align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-5);text-align:center;background:var(--color-cream-dark);border:1.5px dashed var(--color-border);border-radius:var(--radius-xl);flex-direction:column;display:flex}.pastures__empty-icon{font-size:36px;line-height:1}.pastures__empty h3{color:var(--color-text-primary);margin:0}.pastures__empty p{max-width:320px;margin:0}@media (width<=640px){.pastures__header{flex-direction:column}}
