.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.login-container{background:#fff;padding:3rem;border-radius:8px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-container h1{text-align:center;margin-bottom:2rem;color:#2c3e50}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:4px;border:1px solid #fcc}.btn-primary{background-color:#3498db;color:#fff;border:none;padding:.75rem;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.dashboard h2{margin-bottom:2rem;color:#2c3e50}.messages-panel{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.messages-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.messages-header h3{margin:0;color:#2c3e50}.messages-filters{display:flex;gap:.75rem}.messages-filters select{padding:.5rem;border-radius:4px;border:1px solid #ddd}.messages-list{display:flex;flex-direction:column;gap:.75rem}.message-card{border:1px solid #e0e0e0;border-radius:6px;padding:.75rem;background:#fafafa}.message-meta{display:flex;gap:1rem;font-size:.8rem;color:#666;margin-bottom:.5rem}.message-category{text-transform:capitalize;font-weight:600}.message-card p{margin:.5rem 0 0}.empty-state{text-align:center;padding:3rem;color:#999;font-size:1.1rem}.machines-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.machine-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;transition:box-shadow .2s}.machine-card.clickable{cursor:pointer}.machine-card.clickable:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px);transition:box-shadow .2s,transform .2s}.machine-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.machine-header h3{margin:0;color:#2c3e50;font-size:1.25rem}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.status-green{background-color:#d4edda;color:#155724}.status-red{background-color:#f8d7da;color:#721c24}.status-orange{background-color:#fff3cd;color:#856404}.status-gray{background-color:#e2e3e5;color:#383d41}.status-blue{background-color:#d1ecf1;color:#0c5460}.machine-crew-selector{margin-bottom:1rem;padding:.5rem;background:#f8f9fa;border-radius:4px}.machine-crew-selector label{display:block;font-size:.85rem;color:#666;margin-bottom:.25rem}.crew-select{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;background:#fff;cursor:pointer}.crew-select:focus{outline:none;border-color:#2196f3}.machine-location{color:#666;font-size:.9rem;margin-bottom:1rem}.machine-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-top:1rem}.stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.85rem;color:#666}.stat-value{font-size:1.1rem;font-weight:600;color:#2c3e50}@media (max-width: 768px){.machines-grid,.machine-stats{grid-template-columns:1fr}}.history-page h2{margin-bottom:2rem;color:#2c3e50}.history-controls{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-end}.graph-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1rem;margin-bottom:2rem}@media (max-width: 768px){.history-controls{flex-direction:column;align-items:stretch}.control-group{min-width:auto}.data-table-container{overflow-x:scroll}}.pagination-info{margin-bottom:.75rem;font-size:.9rem;color:#555}.backup-reminder-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.5rem;margin-bottom:1.5rem;background-color:#e8f4fd;border:1px solid #3498db;border-radius:8px;color:#2c3e50}.backup-reminder-banner span{flex:1}.backup-reminder-dismiss{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0 .25rem;line-height:1}.backup-reminder-dismiss:hover{color:#2c3e50}.users-page h2{margin-bottom:2rem;color:#2c3e50}.users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.user-form-container{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.user-form-container h3{margin-bottom:1.5rem;color:#2c3e50}.user-form{display:flex;flex-direction:column;gap:1.5rem}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.users-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.users-table{width:100%;border-collapse:collapse}.users-table thead{background-color:#f8f9fa}.users-table th{padding:1rem;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #e0e0e0}.users-table td{padding:.75rem 1rem;border-bottom:1px solid #f0f0f0}.users-table tbody tr:hover{background-color:#f8f9fa}@media (max-width: 768px){.users-header{flex-direction:column;align-items:flex-start;gap:1rem}.form-row{grid-template-columns:1fr}.action-buttons{flex-direction:column}}.settings-page h2{margin-bottom:2rem;color:#2c3e50}.settings-sections{display:flex;flex-direction:column;gap:2rem}.settings-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.settings-section h3{margin-bottom:1.5rem;color:#2c3e50;font-size:1.25rem}.settings-form{display:flex;flex-direction:column;gap:1.5rem}.form-group input,.form-group select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3498db}.form-group input:disabled,.form-group select:disabled{background-color:#f5f5f5;cursor:not-allowed}.btn-primary{background-color:#3498db;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;align-self:flex-start}.preferences-list{display:flex;flex-direction:column;gap:1.5rem}.preference-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;transition:background-color .2s}.preference-item:hover{background-color:#f8f9fa}.preference-item input[type=checkbox]{width:20px;height:20px;cursor:pointer;margin-bottom:.5rem}.preference-item>span:first-of-type{font-weight:500;color:#2c3e50;font-size:1.05rem}.preference-description{font-size:.9rem;color:#666;margin-top:.25rem}.section-description{color:#666;font-size:.9rem;margin:-.5rem 0 1rem}.header-actions{display:flex;gap:.5rem;align-items:center}.form-container{background:#f8f9fa;padding:1.5rem;border-radius:6px;margin-bottom:1.5rem}.form-container h4{margin-bottom:1rem;color:#2c3e50}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.btn-secondary:hover:not(:disabled){background-color:#7f8c8d}.table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto;margin-top:1rem}.btn-edit{background-color:#3498db;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.btn-edit:hover{background-color:#2980b9}.btn-delete{background-color:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.btn-delete:hover{background-color:#c0392b}.device-token{background-color:#f0f0f0;padding:.25rem .5rem;border-radius:4px;font-family:monospace;font-size:.85rem;color:#2c3e50}.no-token,.no-org{color:#999;font-style:italic}.optional-label{color:#999;font-weight:400;font-size:.85rem}.optional-text{color:#999;font-style:italic}.org-name-link{color:#3498db;text-decoration:none;font-weight:500;transition:color .2s}.org-name-link:hover{color:#2980b9;text-decoration:underline}@media (max-width: 768px){.settings-section{padding:1.5rem}.btn-primary{align-self:stretch}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.form-row{grid-template-columns:1fr}.action-buttons{flex-direction:column}}.profile-page{padding:2rem;max-width:800px;margin:0 auto}.profile-page h2{margin-bottom:2rem;color:#2c3e50}.profile-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.profile-form{display:flex;flex-direction:column;gap:1.5rem}.form-group input:disabled,.disabled-input{background-color:#f5f5f5;cursor:not-allowed;color:#666}.form-group select,.form-select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;cursor:pointer}.form-group select:focus,.form-select:focus{outline:none;border-color:#3498db}.form-group select:disabled,.form-select:disabled{background-color:#f5f5f5;cursor:not-allowed;color:#666}.field-note{font-size:.85rem;color:#999;font-style:italic}.password-section{margin-top:1rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.password-section h3{margin-bottom:.5rem;color:#2c3e50;font-size:1.1rem}.section-note{font-size:.9rem;color:#666;margin-bottom:1rem}.form-actions{margin-top:1rem}.btn-primary:hover:not(:disabled){background-color:#2980b9}.btn-primary:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.profile-page{padding:1rem}.profile-section{padding:1.5rem}}.org-detail-page{padding:2rem;max-width:1400px;margin:0 auto}.org-detail-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem}.header-title-section{flex:1;display:flex;justify-content:space-between;align-items:center;gap:1rem}.org-detail-header h2{margin:0;color:#2c3e50}.header-actions{display:flex;gap:.5rem}.btn-edit-org{background-color:#3498db;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.btn-edit-org:hover{background-color:#2980b9}.btn-delete-org{background-color:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.btn-delete-org:hover{background-color:#c0392b}.edit-org-form{display:flex;flex-direction:column;gap:1rem;padding:1rem;background-color:#f8f9fa;border-radius:6px;border:1px solid #e0e0e0}.btn-back{background-color:#95a5a6;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.btn-back:hover{background-color:#7f8c8d}.success-message{background-color:#d4edda;color:#155724;padding:1rem;border-radius:4px;border:1px solid #c3e6cb;margin-bottom:1rem}.error-message{background-color:#fee;color:#c33;padding:1rem;border-radius:4px;border:1px solid #fcc;margin-bottom:1rem}.org-detail-sections{display:flex;flex-direction:column;gap:2rem}.org-detail-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.org-detail-section h3{margin-bottom:1.5rem;color:#2c3e50;font-size:1.25rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item label{font-weight:600;color:#555;font-size:.9rem}.info-item span{color:#2c3e50;font-size:1rem}.monospace{font-family:monospace;font-size:.9rem;background-color:#f5f5f5;padding:.25rem .5rem;border-radius:4px}.table-container{background:#fff;border-radius:8px;overflow-x:auto;margin-top:1rem}.data-table td{padding:.75rem 1rem;border-bottom:1px solid #f0f0f0}.empty-cell{text-align:center;color:#999;padding:2rem}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500;background-color:#e8f4f8;color:#2c3e50}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.inactive{background-color:#f8d7da;color:#721c24}.btn-reset-password{background-color:#f39c12;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.btn-reset-password:hover{background-color:#e67e22}.btn-deactivate{background-color:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.btn-deactivate:hover{background-color:#c0392b}.btn-activate{background-color:#27ae60;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.btn-activate:hover{background-color:#229954}.password-reset-form{margin-top:2rem;padding:1.5rem;background-color:#f8f9fa;border-radius:6px;border:1px solid #e0e0e0}.password-reset-form h4{margin-bottom:1rem;color:#2c3e50}.reset-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#555}.form-group input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus{outline:none;border-color:#3498db}.btn-primary{background-color:#3498db;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:#2980b9}.btn-secondary{background-color:#95a5a6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background-color:#7f8c8d}.error-container,.loading{padding:2rem;text-align:center}@media (max-width: 768px){.org-detail-page{padding:1rem}.org-detail-section{padding:1.5rem}.action-buttons{flex-direction:column}.info-grid{grid-template-columns:1fr}}.machine-detail{padding:2rem;max-width:1200px;margin:0 auto}.machine-detail-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1rem}.loading-spinner.small{width:20px;height:20px;border-width:2px}.machine-detail-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem}.machine-detail-header h2{margin:0;color:#2c3e50;font-size:1.75rem}.machine-location{color:#666;font-size:.9rem;margin-top:.25rem}.machine-detail-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:2px solid #ddd}.machine-detail-tab{padding:.6rem 1.2rem;border:none;background:transparent;font-size:1rem;font-weight:500;color:#666;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.machine-detail-tab:hover{color:#333}.machine-detail-tab.active{color:#2196f3;border-bottom-color:#2196f3}.settings-tab-content .settings-select,.settings-tab-content .settings-input{min-width:200px;padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:.95rem}.settings-tab-content .settings-input{max-width:320px}.error-message{background:#ffebee;color:#d32f2f;padding:12px;border-radius:8px;margin-bottom:16px;border:1px solid #f44336;font-weight:500;z-index:10;position:relative}.success-message{background:#d4edda;color:#155724;padding:12px;border-radius:8px;margin-bottom:16px;border:1px solid #c3e6cb;font-weight:500;z-index:10;position:relative}.status-card{padding:16px;border-radius:8px;margin-bottom:16px;border:2px solid}.status-running{background:#e8f5e9;border-color:#4caf50}.status-stopped{background:#fafafa;border-color:#9e9e9e}.status-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.status-dot{width:12px;height:12px;border-radius:50%}.status-dot-running{background:#4caf50}.status-dot-stopped{background:#9e9e9e}.status-header h3{margin:0;font-size:16px;font-weight:600}.motor-state{font-size:20px;font-weight:700;color:#333}.bird-counts-card{margin-bottom:16px;padding:20px;border:2px solid #2196F3;border-radius:10px;background:linear-gradient(135deg,#e3f2fd,#f5f5f5)}.bird-counts-card .section-title{margin-bottom:12px}.bird-counts-row{display:flex;gap:24px;margin-bottom:12px}.bird-count-box{flex:1;padding:16px;border-radius:8px;text-align:center;min-width:0}.bird-count-done{background:#e8f5e9;border:2px solid #4CAF50}.bird-count-missed{background:#ffebee;border:2px solid #f44336}.bird-count-number{display:block;font-size:2rem;font-weight:700;line-height:1.2}.bird-count-done .bird-count-number{color:#2e7d32}.bird-count-missed .bird-count-number{color:#c62828}.bird-count-label{display:block;font-size:13px;color:#555;margin-top:4px}.bird-counts-runtime{font-size:13px;color:#666}.detail-section{margin-bottom:16px;padding:16px;border:1px solid #ddd;border-radius:8px;background:#fff}.section-title{font-size:18px;font-weight:600;margin-bottom:12px;color:#333}.status-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0}.status-row:last-child{border-bottom:none}.status-label{font-size:14px;color:#666;flex:1}.status-value{font-size:14px;font-weight:600;color:#333;flex:1;text-align:right}.missed-value{color:#f44336}.control-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.bpm-input{border:1px solid #ccc;padding:12px;border-radius:6px;font-size:16px;flex:1;margin-right:8px}.bpm-input:disabled{background:#f5f5f5;cursor:not-allowed}.fan-setpoint-label{display:flex;align-items:center;gap:6px;font-size:14px}.fan-setpoint-label .bpm-input{width:70px;flex:0 0 auto;margin-right:0}.button{padding:12px 20px;border-radius:6px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s,background .2s;min-width:100px;position:relative;z-index:1}.button:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.button-start{background:#4caf50;color:#fff;flex:1;margin-right:4px}.button-start:hover:not(:disabled){background:#45a049}.button-stop{background:#f44336;color:#fff;flex:1;margin-left:4px}.button-stop:hover:not(:disabled){background:#da190b}.button-secondary{background:#ff9800;color:#fff;flex:1}.button-notes{background:#9c27b0;color:#fff;width:100%;padding:14px}.button-notes:hover:not(:disabled){background:#7b1fa2}.sending-indicator{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px;color:#666;font-size:12px}@media (max-width: 768px){.machine-detail{padding:1rem}.bird-counts-row{flex-direction:column;gap:12px}.bird-count-number{font-size:1.75rem}.control-row{flex-direction:column}.button-start,.button-stop,.button-secondary{width:100%;margin:4px 0}.bpm-input{margin-right:0;margin-bottom:8px}}.notes-page{padding:2rem;max-width:800px;margin:0 auto}.notes-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #4CAF50;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.notes-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.back-button{background:#6c757d;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s}.back-button:hover{background:#5a6268}.notes-header h2{margin:0;color:#2c3e50;font-size:1.75rem}.message{padding:12px;border-radius:8px;margin-bottom:16px}.success-message{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.error-message{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.notes-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.notes-section h3{margin:0 0 .5rem;color:#2c3e50;font-size:1.25rem}.section-description{color:#666;font-size:.9rem;margin-bottom:1rem}.note-input{width:100%;padding:12px;border:1px solid #ccc;border-radius:6px;font-size:14px;font-family:inherit;resize:vertical;margin-bottom:1rem;box-sizing:border-box}.note-input:disabled{background:#f5f5f5;cursor:not-allowed}.note-input:focus{outline:none;border-color:#2196f3}.button{padding:12px 20px;border-radius:6px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s,background .2s}.button:disabled{opacity:.5;cursor:not-allowed}.button-primary{background:#2196f3;color:#fff}.button-primary:hover:not(:disabled){background:#1976d2}.button-secondary{background:#ff9800;color:#fff}.button-secondary:hover:not(:disabled){background:#f57c00}@media (max-width: 768px){.notes-page{padding:1rem}}.machine-assignments{padding:2rem}.machine-assignments h2{margin-bottom:1.5rem;color:#2c3e50}.assignments-section,.wizard-section{margin-bottom:2rem;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.assignments-section h3{margin:0;color:#2c3e50;font-size:1.4rem}.empty-state{text-align:center;padding:2rem;color:#999;font-size:1rem}.wizard-header{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-bottom:1.5rem}.wizard-subtitle{margin:.25rem 0 0;color:#666;font-size:.9rem}.wizard-steps{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.wizard-step{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;border-radius:6px;background:#f4f6f8;color:#666;min-width:90px;text-align:center}.wizard-step span{font-weight:700;background:#dfe3e8;padding:.25rem .5rem;border-radius:999px}.wizard-step.active{background:#e8f4ff;color:#1a4f8b}.wizard-step.active span,.wizard-step.completed span{background:#2196f3;color:#fff}.wizard-step.completed{background:#e6f5ea;color:#2e7d32}.wizard-content{margin-top:1rem}.field-label{display:block;font-weight:600;margin-bottom:.5rem;color:#2c3e50}.form-select,.form-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;background:#fff}.form-select:focus,.form-input:focus{outline:none;border-color:#2196f3}.field-note{color:#666;font-size:.85rem;margin-bottom:.75rem}.field-help{color:#666;font-size:.85rem;margin-top:.35rem;margin-bottom:.75rem}.selection-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.house-vaccine-section{margin-bottom:1.5rem;padding:1rem;border:1px solid #e0e0e0;border-radius:8px;background:#fbfbfb}.house-vaccine-section h4{margin-top:0;margin-bottom:.75rem;color:#2c3e50}.sex-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:6rem}.sex-column h5{margin:0 0 .5rem;color:#4f5b62;font-size:.95rem}.selection-card{text-align:left;display:flex;flex-direction:column;gap:.25rem;padding:.75rem;border:1px solid #e0e0e0;border-radius:8px;background:#fafafa;cursor:pointer;width:100%;font:inherit}.selection-card input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#2196F3}.selection-card-title{font-weight:600;color:#2c3e50}.selection-options{display:grid;gap:.5rem}.selection-card.option{padding:.5rem .75rem;flex-direction:row;align-items:center;gap:.5rem}.selection-card.selected{border-color:#2196f3;background:#eaf4ff;box-shadow:0 0 0 1px #2196f3 inset}.selection-check{height:20px;width:20px;border:1px solid #c9c9c9;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:.5rem;font-size:.85rem;color:#2196f3;background:#fff}.selection-card.selected .selection-check{border-color:#2196f3;background:#eaf4ff}.selection-card span{font-weight:600}.selection-card small{color:#777}.house-numbers{margin-top:1.5rem}.house-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.house-row{display:grid;grid-template-columns:1fr auto;gap:.75rem;margin-bottom:.75rem}.confirmation-card{border:1px solid #e0e0e0;border-radius:8px;padding:1rem;background:#fafafa}.confirmation-card h4{margin-top:0}.summary-row{display:flex;justify-content:space-between;gap:1rem;padding:.4rem 0;border-bottom:1px solid #e0e0e0}.summary-block{align-items:flex-start}.summary-details{display:flex;flex-direction:column;gap:.75rem;width:70%}.summary-house{padding:.5rem 0;border-bottom:1px dashed #dcdcdc}.summary-house:last-child{border-bottom:none}.summary-subrow{display:flex;justify-content:space-between;gap:1rem;padding:.2rem 0}.summary-row:last-child{border-bottom:none}.summary-row span{color:#666}.confirmation-actions{margin-top:1rem}.wizard-actions{display:flex;justify-content:space-between;margin-top:2rem}.btn-clear{padding:.5rem 1rem;background:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.btn-clear:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.wizard-header{flex-direction:column;align-items:flex-start}.wizard-actions{flex-direction:column;gap:.75rem}.summary-row{flex-direction:column;align-items:flex-start}}@media print{.header,.nav,.wizard-actions,.wizard-steps,.confirmation-actions,.success-message,.error-message,.wizard-section{display:none!important}.assignments-section{box-shadow:none;border:none}}.assignment-history-page h2{margin-bottom:2rem;color:#2c3e50}.assignment-history-controls{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-end}.control-group{display:flex;flex-direction:column;gap:.5rem;min-width:150px}.control-group label{font-weight:500;color:#555;font-size:.9rem}.control-group select,.control-group input{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem}.control-group select:focus,.control-group input:focus{outline:none;border-color:#3498db}.btn-export{background-color:#27ae60;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;height:fit-content}.btn-export:hover:not(:disabled){background-color:#229954}.btn-export:disabled{opacity:.6;cursor:not-allowed}.data-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table thead{background-color:#f8f9fa}.data-table th{padding:1rem;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #e0e0e0}.data-table td{padding:.75rem 1rem;border-bottom:1px solid #f0f0f0;vertical-align:top}.data-table tbody tr:hover{background-color:#f8f9fa}.data-table tbody tr:last-child td{border-bottom:none}@media (max-width: 768px){.assignment-history-controls{flex-direction:column;align-items:stretch}.control-group{min-width:auto}.data-table-container{overflow-x:scroll}}.history-selection-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.selection-controls{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.pagination-info{margin-bottom:0;font-size:.9rem;color:#555}.select-all-page-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;font-weight:500;color:#2c3e50}.btn-select-all-pages{padding:.4rem .9rem;font-size:.9rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer}.btn-select-all-pages:hover:not(:disabled){background-color:#2980b9}.btn-select-all-pages:disabled{opacity:.6;cursor:not-allowed}.selected-count{font-size:.9rem;color:#555}.btn-delete-selected{padding:.4rem .9rem;font-size:.9rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer}.btn-delete-selected:hover{background-color:#c0392b}.btn-clear-selection{padding:.4rem .9rem;font-size:.9rem;background-color:#95a5a6;color:#fff;border:none;border-radius:4px;cursor:pointer}.btn-clear-selection:hover{background-color:#7f8c8d}.col-checkbox{width:2.5rem;text-align:center;vertical-align:middle}.col-checkbox input[type=checkbox]{cursor:pointer}.btn-delete-row{padding:.25rem .75rem;font-size:.85rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer}.btn-delete-row:hover{background-color:#c0392b}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;padding:1rem}.pagination-controls button{padding:.5rem 1rem;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;font-size:.95rem}.pagination-controls button:hover:not(:disabled){background-color:#f0f0f0;border-color:#3498db}.pagination-controls button:disabled{opacity:.5;cursor:not-allowed}.pagination-controls span{font-size:.95rem;color:#2c3e50}.farm-directory{padding:2rem}.farm-directory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.farm-directory-header h2{margin:0;color:#2c3e50}.farm-form-container{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.farm-form-container h3{margin-top:0;margin-bottom:1.5rem;color:#2c3e50}.farm-form{display:flex;flex-direction:column;gap:1rem}.link-add-company{margin-left:.75rem;padding:0;background:none;border:none;font-size:.9rem;color:#2196f3;cursor:pointer;font-weight:400;text-decoration:underline}.link-add-company:hover{color:#1976d2}.add-company-inline{display:flex;gap:.75rem;align-items:center;margin-top:.75rem;flex-wrap:wrap}.add-company-inline .add-company-input{flex:1;min-width:180px;padding:.5rem .75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.add-company-inline .btn-add-company{padding:.5rem 1rem;font-size:.85rem}.add-company-inline .btn-add-company:disabled{opacity:.7;cursor:not-allowed}.form-group input,.form-group textarea{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#2196f3}.field-note{font-size:.85rem;color:#666;margin-top:.25rem;font-style:italic}.btn-secondary{padding:.75rem 1.5rem;background:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:600;transition:background .2s}.btn-secondary:hover{background:#5a6268}.farms-table-container{overflow-x:auto;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.farms-table{width:100%;border-collapse:collapse}.farms-table thead{background:#f8f9fa}.farms-table th{padding:1rem;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #dee2e6}.farms-table td{padding:1rem;border-bottom:1px solid #dee2e6}.farms-table tbody tr:hover{background:#f8f9fa}.notes-preview{display:inline-block;margin-left:.5rem;cursor:help}.action-buttons{display:flex;gap:.5rem}.btn-edit{padding:.5rem 1rem;background:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .2s}.btn-edit:hover{background:#1976d2}.btn-delete{padding:.5rem 1rem;background:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .2s}.btn-delete:hover{background:#d32f2f}@media (max-width: 768px){.farms-table-container{overflow-x:scroll}.farms-table{min-width:1000px}.form-row{grid-template-columns:1fr}}.vaccine-directory{padding:2rem}.loading,.error{text-align:center;padding:2rem;font-size:1.1rem}.error{color:#e74c3c}.success-message{background:#d4edda;color:#155724;padding:12px;border-radius:8px;margin-bottom:16px;border:1px solid #c3e6cb}.error-message{background:#f8d7da;color:#721c24;padding:12px;border-radius:8px;margin-bottom:16px;border:1px solid #f5c6cb}.vaccine-directory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.alert-banner{background:#fff3cd;border:1px solid #ffeeba;color:#856404;padding:12px;border-radius:8px;margin-bottom:16px;display:flex;flex-wrap:wrap;gap:8px}.alert-chip{background:#fff;border-radius:999px;padding:4px 10px;font-size:.85rem;border:1px solid #ffeeba}.alert-more{font-size:.85rem;color:#6c757d}.filters{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 4px #00000014;margin-bottom:1.5rem}.filter-row{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;min-width:180px;flex:1}.filter-group label{font-weight:600;margin-bottom:4px}.filter-group input{padding:.6rem;border:1px solid #ddd;border-radius:4px}.checkbox{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.vaccine-form-container{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.vaccine-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:.5rem;font-weight:600;color:#2c3e50}.form-group input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.form-group input:focus{outline:none;border-color:#2196f3}.form-actions{display:flex;gap:1rem;margin-top:1rem}.btn-primary{padding:.75rem 1.5rem;background:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:600;transition:background .2s}.btn-primary:hover{background:#1976d2}.btn-secondary{padding:.5rem 1rem;background:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.vaccines-table-container{overflow-x:auto;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.vaccines-table{width:100%;border-collapse:collapse}.vaccines-table thead{background:#f8f9fa}.vaccines-table th,.vaccines-table td{padding:1rem;text-align:left;border-bottom:1px solid #dee2e6}.vaccines-table tbody tr:hover{background:#f8f9fa}.vaccines-table tbody tr.selected{background:#e8f4fd}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.btn-edit{padding:.5rem 1rem;background:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.btn-delete{padding:.5rem 1rem;background:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.empty-cell{text-align:center;padding:3rem;color:#999}.vaccine-detail{margin-top:2rem;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #00000014}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.detail-card{background:#f8f9fa;padding:1rem;border-radius:8px;display:flex;flex-direction:column;gap:.6rem}.detail-card h4{margin:0 0 .5rem}.assignment-list li,.log-list li{background:#fff;padding:.75rem;border-radius:6px;border:1px solid #e0e0e0;display:flex;flex-direction:column;gap:.35rem}.assignment-list li span{font-size:.9rem}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}.vaccine-detail-page{padding:2rem}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.detail-subtitle{color:#666;font-size:.95rem}.detail-card{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 4px #00000014;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.6rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.detail-card input,.detail-card select{padding:.5rem;border:1px solid #ddd;border-radius:4px}.assignment-list,.log-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.assignment-list li,.log-list li{background:#f8f9fa;padding:.75rem;border-radius:6px;border:1px solid #e0e0e0;display:flex;flex-direction:column;gap:.35rem}.log-title{font-weight:600}.log-meta{font-size:.85rem;color:#666}.log-details{font-size:.85rem;color:#555}.muted{color:#777;font-size:.9rem}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background-color:#2c3e50;color:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:600;margin:0}.header-right{display:flex;align-items:center;gap:1rem}.user-info{font-size:.9rem;opacity:.9}.user-info-link{font-size:.9rem;opacity:.9;color:#fff;text-decoration:none;transition:opacity .2s}.user-info-link:hover{opacity:1;text-decoration:underline}.btn-logout{background-color:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.btn-logout:hover{background-color:#c0392b}.nav{background-color:#fff;border-bottom:1px solid #e0e0e0;padding:0 2rem;display:flex;gap:2rem;box-shadow:0 1px 3px #0000000d}.nav-link{padding:1rem 0;text-decoration:none;color:#555;font-weight:500;border-bottom:3px solid transparent;transition:color .2s,border-color .2s}.nav-link:hover{color:#2c3e50}.nav-link.active{color:#3498db;border-bottom-color:#3498db}.main-content{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;align-items:flex-start}.nav{flex-wrap:wrap;gap:1rem}.main-content{padding:1rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
