body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.cooler-card{border-left:4px solid #e0e0e0;box-shadow:0 2px 8px #0000001a;cursor:pointer;padding:1.5rem;transition:all .2s ease}.cooler-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.cooler-card.normal{border-left-color:#4caf50}.cooler-card.warning{border-left-color:#ff9800}.cooler-card.critical{background:#fef7f7;border-left-color:#f44336}.cooler-card.offline{border-left-color:#757575;opacity:.8}.cooler-header{align-items:flex-start;margin-bottom:1rem}.cooler-header h3{color:#333;font-size:1.125rem;font-weight:600;margin:0}.cooler-status-icon{flex-shrink:0;font-size:1.25rem}.cooler-location{align-items:center;color:#666;display:flex;font-size:.875rem;gap:.25rem;margin-bottom:1.5rem}.temperature-display{margin-bottom:1rem}.current-temp{color:#333;font-size:2rem;font-weight:700;margin-bottom:.25rem}.temp-range{background:#f5f5f5;border-radius:4px;color:#666;display:inline-block;font-size:.75rem;padding:.25rem .5rem}.humidity-display{font-size:.875rem;gap:.25rem;margin-bottom:1rem}.cooler-footer,.humidity-display{align-items:center;color:#666;display:flex}.cooler-footer{border-top:1px solid #f0f0f0;font-size:.75rem;justify-content:space-between;margin-top:1.5rem;padding-top:1rem}.last-update{align-items:center;display:flex;gap:.25rem}.device-info{display:flex;gap:.75rem}.battery-info,.signal-info{align-items:center;display:flex;gap:.25rem;white-space:nowrap}@media (max-width:640px){.cooler-card{padding:1rem}.cooler-header{align-items:flex-start;flex-direction:column;gap:.5rem}.current-temp{font-size:1.75rem}.cooler-footer{align-items:flex-start;flex-direction:column;gap:.5rem}.device-info{justify-content:space-between;width:100%}}.alert-panel{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;height:-webkit-fit-content;height:fit-content;padding:1.5rem}.alert-panel h2{color:#333;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem}.active-alerts,.recent-alerts{margin-bottom:2rem}.active-alerts:last-child,.recent-alerts:last-child{margin-bottom:0}.active-alerts h3,.recent-alerts h3{align-items:center;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin-bottom:1rem}.alerts-list{display:flex;flex-direction:column;gap:1rem}.alert-item{background:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1rem}.alert-item.critical{background:#fef7f7;border-left-color:#f44336}.alert-item.high{background:#fff3e0;border-left-color:#ff5722}.alert-item.medium{background:#fff8e1;border-left-color:#ff9800}.alert-item.warning{background:#fffde7;border-left-color:#ffc107}.alert-header{align-items:center;display:flex;gap:.75rem;margin-bottom:.5rem}.alert-icon{flex-shrink:0;font-size:1.25rem}.alert-info{flex:1 1;min-width:0}.alert-info strong{color:#333;display:block;font-weight:600;margin-bottom:.125rem}.alert-location,.alert-time{color:#666;font-size:.75rem}.alert-time{flex-shrink:0}.alert-message{color:#555;font-size:.875rem;line-height:1.4;margin-bottom:.75rem}.alert-details{background:#0000000d;border-radius:4px;color:#666;font-family:monospace;font-size:.75rem;margin-bottom:.75rem;padding:.25rem .5rem}.resolve-button{background:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;font-weight:500;padding:.375rem .75rem;transition:background-color .2s}.resolve-button:hover{background:#45a049}.recent-alerts-list{display:flex;flex-direction:column;gap:.5rem}.recent-alert-item{align-items:center;background:#f9f9f9;border-radius:6px;display:flex;font-size:.875rem;gap:.5rem;padding:.75rem}.recent-alert-item.resolved{opacity:.7}.recent-alert-item .alert-icon{font-size:1rem}.alert-summary{flex:1 1;min-width:0}.alert-summary strong{font-weight:600;margin-right:.5rem}.alert-message-short{color:#666;font-size:.75rem}.alert-timestamp{color:#999;flex-shrink:0;font-size:.75rem}.resolved-indicator{flex-shrink:0;font-size:.875rem}.no-alerts{color:#666;padding:3rem 1rem;text-align:center}.no-alerts-icon{font-size:3rem;margin-bottom:1rem}.no-alerts h3{color:#4caf50;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.no-alerts p{font-size:.875rem;opacity:.8}@media (max-width:640px){.alert-panel{padding:1rem}.alert-header{flex-wrap:wrap;gap:.5rem}.alert-time{order:3;text-align:right;width:100%}.recent-alert-item{align-items:flex-start;flex-direction:column;gap:.25rem}.alert-summary{width:100%}.alert-timestamp{align-self:flex-end}}.dashboard{display:flex;flex-direction:column;gap:2rem}.dashboard-header{justify-content:space-between;margin-bottom:1rem}.dashboard-header,.status-overview{align-items:center;display:flex}.status-indicator{border-radius:12px;box-shadow:0 2px 8px #0000001a;gap:1rem;padding:1rem 1.5rem}.status-indicator.good{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.status-indicator.warning{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.status-indicator.critical{background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff}.status-icon{font-size:2rem}.status-text h2{font-size:1.125rem;font-weight:600;margin-bottom:.25rem}.status-text p{font-size:.875rem;opacity:.9}.refresh-button{background:#2196f3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s}.refresh-button:hover{background:#1976d2}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:2fr 1fr}.alerts-section h2,.coolers-section h2{color:#333;font-size:1.25rem;font-weight:600;margin-bottom:1rem}.coolers-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.empty-state{background:#fff;border:2px dashed #e0e0e0;border-radius:12px;color:#666;grid-column:1/-1;padding:3rem 1rem;text-align:center}.empty-state p{font-size:1.125rem;margin-bottom:.5rem}.empty-state small{font-size:.875rem;opacity:.7}.dashboard-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:2rem}.stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;text-align:center}.stat-card h3{color:#666;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.stat-value{color:#2196f3;font-size:2rem}.stat-value.critical{color:#f44336}@media (max-width:968px){.dashboard-grid{gap:1.5rem;grid-template-columns:1fr}.coolers-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:640px){.dashboard-header{align-items:stretch;flex-direction:column;gap:1rem}.coolers-grid{grid-template-columns:1fr}.dashboard-stats{grid-template-columns:repeat(2,1fr)}}.settings{margin:0 auto;max-width:800px}.read-only-notice{background-color:#e3f2fd;border-left:4px solid #1976d2;border-radius:6px;color:#1976d2;margin:1rem 0;padding:1rem}.read-only-notice p{font-weight:500;margin:0}input[readonly]{background-color:#f5f5f5!important;border-color:#ddd!important;color:#666!important;cursor:not-allowed!important}.settings-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;gap:1rem;margin-bottom:2rem;padding-bottom:1rem}.settings-header h2{color:#333;font-size:1.5rem;font-weight:600}.settings-content{display:flex;flex-direction:column;gap:3rem}.settings-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:2rem}.settings-section h3{align-items:center;border-bottom:1px solid #f0f0f0;color:#333;display:flex;font-size:1.25rem;font-weight:600;gap:.5rem;margin-bottom:1.5rem;padding-bottom:.75rem}.yolink-status{margin-bottom:1.5rem}.yolink-status h4{color:#666;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.status-indicator{align-items:center;display:flex;font-size:.875rem;gap:.5rem}.status-indicator.connected{color:#4caf50}.status-indicator.disconnected{color:#f44336}.status-dot{background-color:currentColor}.form-group{margin-bottom:1.5rem}.form-group label{color:#333;font-size:.875rem}.form-group input,.form-group select{border:1px solid #e0e0e0;border-radius:6px;font-size:.875rem;padding:.75rem;transition:border-color .2s,box-shadow .2s;width:100%}.form-group input:focus,.form-group select:focus{border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a;outline:none}.form-group small{color:#666;display:block;font-size:.75rem;line-height:1.4;margin-top:.25rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:2fr 1fr}.test-button{background:#ff9800;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.test-button:hover:not(:disabled){background:#f57c00}.test-button:disabled{background:#ccc;cursor:not-allowed}.deployment-info{grid-gap:1rem;display:grid;gap:1rem}.info-card{background:#f9f9f9;border-left:4px solid #2196f3;border-radius:8px;padding:1.5rem}.info-card h4{color:#333;font-size:1rem;font-weight:600;margin-bottom:.75rem}.info-card p{color:#666;font-size:.875rem;line-height:1.5;margin-bottom:.5rem}.info-card code{background:#e0e0e0;border-radius:3px;font-family:Monaco,Menlo,monospace;font-size:.8125rem;padding:.125rem .375rem}.info-card ol{color:#666;font-size:.875rem;margin-left:1.25rem}.info-card li{margin-bottom:.25rem}.settings-footer{border-top:1px solid #e0e0e0;display:flex;justify-content:center;margin-top:2rem;padding:2rem 0}.save-button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;min-width:150px;padding:1rem 2rem;transition:background-color .2s}.save-button:hover:not(:disabled){background:#45a049}.save-button:disabled{background:#ccc;cursor:not-allowed}.sms-recipients-section{background:#f8f9fa;border-left:4px solid #ff9800;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.sms-recipients-section h4{color:#333;font-size:1.1rem;font-weight:600;margin-bottom:.5rem;margin-top:0}.sms-recipients-section p{color:#666;font-size:.875rem;line-height:1.5;margin-bottom:1.5rem}.sms-recipient-row{grid-gap:1rem;align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;display:grid;gap:1rem;grid-template-columns:200px 1fr;margin-bottom:1rem;padding:.75rem}.recipient-checkbox .checkbox-label{align-items:center;display:flex;gap:.5rem;margin:0}.recipient-checkbox input[type=checkbox]{margin:0;width:auto}.recipient-label{color:#333;font-size:.875rem;font-weight:500}.recipient-phone input{border:1px solid #e0e0e0;border-radius:4px;font-size:.875rem;padding:.5rem;transition:border-color .2s,background-color .2s;width:100%}.recipient-phone input.enabled{background-color:#f0fff0;border-color:#4caf50}.recipient-phone input.disabled{background-color:#f5f5f5;color:#999}.recipient-phone input:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f31a;outline:none}.test-buttons{display:flex;gap:1rem;margin-top:1.5rem}.test-button.secondary{background:#757575}.test-button.secondary:hover:not(:disabled){background:#616161}@media (max-width:768px){.settings{padding:1rem}.settings-section{padding:1.5rem}.deployment-info,.form-row{grid-template-columns:1fr}.settings-header{align-items:stretch;flex-direction:column;text-align:center}.sms-recipient-row{gap:.5rem;grid-template-columns:1fr}.test-buttons{flex-direction:column}}.admin-login-required{align-items:center;display:flex;justify-content:center;min-height:400px;padding:2rem}.login-card{background:#fff;border:2px solid #f44336;border-radius:12px;box-shadow:0 4px 20px #f443361a;max-width:600px;padding:3rem;text-align:center}.login-card h3{color:#f44336;font-size:1.5rem;margin-bottom:1rem}.login-card p{color:#666;font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.access-denied-info{background:#fafafa;border-left:4px solid #f44336;border-radius:0 6px 6px 0;margin:2rem 0;padding:1.5rem;text-align:left}.access-denied-info p{color:#333;font-weight:600;margin-bottom:.5rem}.access-denied-info ul{list-style-type:none;margin:1rem 0;padding-left:0}.access-denied-info li{color:#666;padding:.25rem 0 .25rem 1.5rem;position:relative}.access-denied-info li:before{content:"🔒";left:0;position:absolute}.login-instruction{color:#333!important;font-weight:500}.back-button-large{background:#2196f3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:1rem 2rem;transition:background-color .2s}.back-button-large:hover{background:#1976d2}@media (max-width:768px){.login-card{margin:1rem;padding:2rem}.access-denied-info{margin:1rem 0;padding:1rem}}.cooler-details{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:2rem}.details-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.back-button{background:#757575;font-size:.875rem;padding:.75rem 1.5rem;transition:background-color .2s}.back-button:hover{background:#616161}.header-actions{display:flex;gap:.75rem}.edit-button,.save-button{border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s}.edit-button{background:#2196f3}.edit-button:hover{background:#1976d2}.save-button{background:#4caf50;color:#fff}.save-button:hover{background:#45a049}.details-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr 1fr}.cooler-info-section{display:flex;flex-direction:column;gap:2rem}.cooler-status{align-items:center;border-radius:12px;display:flex;gap:1.5rem;margin-bottom:1rem;padding:1.5rem}.cooler-status.normal{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);color:#2e7d32}.cooler-status.warning{background:linear-gradient(135deg,#fff3e0,#ffcc02);color:#e65100}.cooler-status.critical{background:linear-gradient(135deg,#ffebee,#ffcdd2);color:#c62828}.cooler-status.unknown{background:linear-gradient(135deg,#f5f5f5,#e0e0e0);color:#424242}.status-indicator{font-size:3rem}.current-readings h1{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.location{align-items:center;display:flex;font-size:.875rem;gap:.25rem;opacity:.8}.readings-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.reading-card{background:#f9f9f9;border-radius:8px;padding:1.5rem;text-align:center}.reading-card h3{align-items:center;color:#666;display:flex;font-size:.875rem;font-weight:500;gap:.25rem;justify-content:center;margin-bottom:.75rem}.reading-value{color:#333;font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.reading-range{color:#666;font-size:.75rem}.edit-input{background:#fff;border:2px solid #e0e0e0;border-radius:4px;font-size:inherit;font-weight:inherit;padding:.5rem;transition:border-color .2s;width:100%}.edit-input:focus{border-color:#2196f3;outline:none}.temp-input{background:#fff;border:1px solid #e0e0e0;border-radius:4px;margin:0 .25rem;padding:.25rem;text-align:center;width:60px}.alert-settings{background:#f9f9f9;border-radius:8px;padding:1rem}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem}.checkbox-label input[type=checkbox]{margin:0}.chart-section{display:flex;flex-direction:column}.chart-header{justify-content:space-between;margin-bottom:1.5rem}.chart-header,.chart-header h2{align-items:center;display:flex}.chart-header h2{color:#333;font-size:1.25rem;font-weight:600;gap:.5rem}.time-range-select{background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:.875rem;padding:.5rem 1rem}.chart-container{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1rem}.no-data{color:#666;padding:3rem 1rem;text-align:center}.no-data p{font-size:1.125rem;margin-bottom:.5rem}.no-data small{font-size:.875rem;opacity:.7}@media (max-width:1024px){.details-content{gap:2rem;grid-template-columns:1fr}.readings-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:640px){.cooler-details{padding:1rem}.details-header{align-items:stretch;flex-direction:column;gap:1rem}.header-actions{justify-content:center}.cooler-status{flex-direction:column;gap:1rem;text-align:center}.readings-grid{grid-template-columns:1fr}.chart-header{align-items:stretch;flex-direction:column;gap:1rem}}.analytics-container{margin:0 auto;max-width:1200px;padding:20px}.analytics-header{align-items:center;border-bottom:2px solid #2c2b79;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:15px}.analytics-header h2{color:#2c2b79;font-size:2rem;margin:0}.timeframe-selector{align-items:center;display:flex;gap:10px}.timeframe-selector label{color:#2c2b79;font-weight:600}.timeframe-selector select{background:#fff;border:2px solid #2c2b79;border-radius:6px;color:#2c2b79;cursor:pointer;font-weight:500;padding:8px 12px}.timeframe-selector select:focus{border-color:#ec2027;outline:none}.system-summary{background:linear-gradient(135deg,#2c2b79,#1e1b5c);border-radius:12px;color:#fff;margin-bottom:30px;padding:25px}.system-summary h3{font-size:1.5rem;margin:0 0 20px}.summary-stats{display:flex;gap:20px;margin-bottom:20px}.stat-card{background:#ffffff1a;border-radius:8px;display:flex;flex:1 1;flex-direction:column;padding:15px}.stat-label{font-size:.9rem;margin-bottom:5px;opacity:.8}.stat-value{font-size:1.4rem;font-weight:700}.health-status{align-items:center;display:flex;gap:5px}.system-alerts{background:#ec20271a;border:1px solid #ec20274d;border-radius:8px;padding:15px}.system-alerts h4{color:#ffcccb;margin:0 0 10px}.system-alert{background:#ec202733;border-radius:6px;font-weight:500;margin-bottom:8px;padding:8px 12px}.system-alert:last-child{margin-bottom:0}.cooler-analytics h3{color:#2c2b79;font-size:1.5rem;margin:0 0 20px}.cooler-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:20px;transition:all .3s ease}.cooler-card:hover{border-color:#2c2b79;box-shadow:0 4px 15px #2c2b7926}.cooler-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:10px}.cooler-header h4{color:#2c2b79;font-size:1.3rem;margin:0}.cooler-location{color:#6c757d;font-size:.9rem;font-style:italic}.risk-badge{border-radius:20px;color:#fff;font-size:.8rem;font-weight:700;padding:4px 12px;text-transform:uppercase}.cooler-stats{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:15px}.stat-row{border-bottom:1px solid #f8f9fa;display:flex;justify-content:space-between;padding:8px 0}.stat-row:last-child{border-bottom:none}.stat-row span:first-child{color:#6c757d;font-weight:500}.stat-row span:last-child{color:#2c2b79;font-weight:700}.insights-section{background:#f8f9fa;border-radius:8px;margin:15px 0;padding:15px}.insights-section h5{color:#2c2b79;font-size:1.1rem;margin:0 0 10px}.insight-item{align-items:center;border-bottom:1px solid #e9ecef;display:flex;gap:10px;padding:8px 0}.insight-item:last-child{border-bottom:none}.insight-icon{font-size:1.2rem}.insight-message{color:#495057;font-weight:500}.recommendations-section{background:#e8f5e8;border-left:4px solid #28a745;border-radius:8px;margin:15px 0;padding:15px}.recommendations-section h5{color:#155724;font-size:1.1rem;margin:0 0 10px}.recommendation-item{border-bottom:1px solid #d4edda;color:#155724;font-weight:500;padding:8px 0}.recommendation-item:last-child{border-bottom:none}.anomalies-section,.defrost-section{background:#fff3cd;border-left:4px solid #ffc107;border-radius:8px;margin:15px 0;padding:15px}.anomalies-section{background:#f8d7da;border-left-color:#dc3545}.anomalies-section h5,.defrost-section h5{color:#856404;font-size:1.1rem;margin:0 0 10px}.anomalies-section h5{color:#721c24}.anomalies-section p,.defrost-section p{font-weight:500;margin:5px 0}.anomalies-section small,.defrost-section small{color:#6c757d}.analytics-error,.analytics-loading,.analytics-login-required{background:#f8f9fa;border-radius:12px;margin:20px 0;padding:60px 20px;text-align:center}.analytics-error h2,.analytics-loading h2,.analytics-login-required h2{color:#2c2b79;margin-bottom:20px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e9ecef;border-radius:50%;border-top-color:#2c2b79;height:50px;margin:20px auto;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.retry-button{background:#ec2027;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:700;padding:12px 24px;transition:background .3s ease}.retry-button:hover{background:#d41e24}.analytics-footer{border-top:1px solid #e9ecef;color:#6c757d;margin-top:30px;padding:20px;text-align:center}.analytics-footer small{line-height:1.4}@media (max-width:768px){.analytics-container{padding:15px}.analytics-header{flex-direction:column;gap:15px;text-align:center}.cooler-header,.summary-stats{flex-direction:column;gap:10px}.cooler-header{text-align:center}.cooler-stats{grid-template-columns:1fr}}.maintenance-container{margin:0 auto;max-width:1200px;padding:20px}.maintenance-header{align-items:center;border-bottom:2px solid #2c2b79;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:15px}.header-left{gap:15px}.header-left h2{color:#2c2b79;font-size:2rem;margin:0}.header-right{align-items:center;display:flex;gap:15px}.back-button{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:background .3s ease}.back-button:hover{background:#5a6268}.filter-select{background:#fff;border:2px solid #2c2b79;border-radius:6px;color:#2c2b79;cursor:pointer;font-weight:500;padding:8px 12px}.add-button{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:700;padding:10px 20px;transition:background .3s ease}.add-button:hover{background:#218838}.error-message{background:#f8d7da;border-radius:6px;margin-bottom:20px;padding:12px}.form-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.form-modal{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-height:80vh;max-width:600px;overflow-y:auto;padding:30px;width:90%}.form-modal h3{color:#2c2b79;font-size:1.5rem;margin:0 0 20px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{color:#2c2b79;font-size:.9rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:2px solid #e9ecef;border-radius:6px;font-size:1rem;padding:10px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2c2b79;outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-actions{gap:10px;margin-top:20px}.form-actions button{border-radius:6px;font-weight:700;padding:10px 20px;transition:background .3s ease}.form-actions button[type=button]{background:#6c757d}.form-actions button[type=button]:hover{background:#5a6268}.form-actions button[type=submit]{background:#28a745}.form-actions button[type=submit]:hover{background:#218838}.loading{color:#6c757d;font-size:1.2rem;padding:40px}.no-logs{background:#f8f9fa;border:2px dashed #dee2e6;border-radius:12px;padding:40px;text-align:center}.no-logs p{color:#6c757d;font-size:1.1rem;margin:10px 0}.maintenance-login-required{background:#f8f9fa;border-radius:12px;margin:20px 0;padding:60px 20px;text-align:center}.maintenance-login-required h2{color:#2c2b79;margin-bottom:20px}.logs-container{margin-top:20px}.logs-list{display:flex;flex-direction:column;gap:20px}.log-entry{background:#fff;border:2px solid #e9ecef;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:20px;transition:all .3s ease}.log-entry:hover{border-color:#2c2b79;box-shadow:0 4px 15px #2c2b7926}.log-header{align-items:flex-start;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:10px}.log-title h4{color:#2c2b79;font-size:1.2rem;margin:0 0 5px}.cooler-name{background:#e8f4fd;border-radius:12px;color:#2c5aa0;font-size:.8rem;font-weight:500;padding:2px 8px}.log-meta{color:#6c757d;font-size:.9rem;text-align:right}.log-date{display:block;font-weight:500;margin-bottom:2px}.log-user{font-style:italic}.log-content p{color:#495057;line-height:1.6;margin-bottom:15px}.log-details{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:15px}.detail-item{background:#f8f9fa;border-radius:6px;color:#495057;font-size:.9rem;font-weight:500;padding:5px 10px}.log-actions{display:flex;gap:10px;justify-content:flex-end}.delete-button,.edit-button{border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;padding:6px 12px;transition:background .3s ease}.edit-button{background:#007bff;color:#fff}.edit-button:hover{background:#0056b3}.delete-button{background:#dc3545;color:#fff}.delete-button:hover{background:#c82333}@media (max-width:768px){.maintenance-container{padding:15px}.maintenance-header{flex-direction:column;gap:15px;text-align:center}.header-right{flex-direction:column;gap:10px;width:100%}.add-button,.filter-select{width:100%}.form-grid{gap:15px;grid-template-columns:1fr}.form-modal{padding:20px;width:95%}.log-header{flex-direction:column;gap:10px}.log-header,.log-meta{text-align:center}.log-actions,.log-details{justify-content:center}}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f5f5;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:90vw;min-width:300px;padding:2rem}.modal-content h2{color:#333}.form-group,.modal-content h2{margin-bottom:1rem}.form-group label{display:block;font-weight:500;margin-bottom:.5rem}.form-group input{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;width:100%}.form-group input:focus{border-color:#ec2027;box-shadow:0 0 0 2px #007bff40;outline:none}.form-actions{display:flex;gap:.5rem;justify-content:flex-end}.form-actions button{border:none;border-radius:4px;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.form-actions button[type=submit]{background-color:#ec2027;color:#fff}.form-actions button[type=submit]:hover{background-color:#0056b3}.form-actions button[type=button]{background-color:#6c757d;color:#fff}.form-actions button[type=button]:hover{background-color:#545b62}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin-bottom:1rem;padding:.75rem}.login-btn,.logout-btn{background-color:#28a745!important;color:#fff!important}.login-btn:hover,.logout-btn:hover{background-color:#218838!important}.user-info{align-items:center;display:flex;gap:15px}.welcome-text{color:#fff;font-size:.9rem;font-weight:500}.App{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,#2c2b79,#1e1b5c);box-shadow:0 2px 4px #0000001a;color:#fff;padding:1rem 2rem}.header-content{justify-content:space-between;margin:0 auto;max-width:1200px}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:1rem}.header-left h1{align-items:center;display:flex;font-size:1.5rem;font-weight:600;gap:.75rem}.taylors-logo{background-color:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 2px 4px #0000001a;height:40px;padding:4px 8px;width:auto}.connection-status{align-items:center;display:flex;font-size:.875rem;gap:.5rem;opacity:.9}.status-dot{border-radius:50%;display:inline-block;height:8px;width:8px}.header-nav{display:flex;gap:.5rem}.header-nav button{background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:background-color .2s}.header-nav button:hover{background:#ffffff4d}.header-nav button.active{background:#fff6;font-weight:600}.app-main{flex:1 1;margin:0 auto;max-width:1200px;padding:2rem;width:100%}.app-footer{background:#fff;border-top:1px solid #e0e0e0;color:#666;padding:1rem 2rem;text-align:center}.app-footer,.btn{font-size:.875rem}.btn{background:#ec2027;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:.75rem 1.5rem;transition:background-color .2s}.btn:hover{background:#c41e24}.btn:disabled{background:#ccc;cursor:not-allowed}.btn-secondary{background:#757575}.btn-secondary:hover{background:#616161}.btn-danger{background:#f44336}.btn-danger:hover{background:#d32f2f}.loading{color:#666;padding:2rem;text-align:center}@media (max-width:768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.app-main{padding:1rem}.header-nav{justify-content:center;width:100%}}
/*# sourceMappingURL=main.4873823f.css.map*/