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}:root{--primary-color:#4caf50;--primary-dark:#388e3c;--secondary-color:#f5f5f5;--text-color:#333;--text-light:#666;--border-radius:8px;--box-shadow:0 4px 6px #0000001a;--transition:all 0.3s ease;--overlay-bg:#fffc}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f9f9f9;color:#333;color:var(--text-color);font-family:Roboto,Arial,sans-serif;line-height:1.6;padding:20px}nav{background-color:#4caf50;background-color:var(--primary-color);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 4px 6px #0000001a;box-shadow:var(--box-shadow);display:flex;gap:20px;justify-content:flex-start;margin-bottom:20px;padding:15px 20px}nav a{color:#fff;font-size:16px;font-weight:500;text-decoration:none;transition:all .3s ease;transition:var(--transition)}nav a:hover{opacity:.9;text-decoration:underline}h1{color:#388e3c;color:var(--primary-dark);margin:20px 0}.notification,h1{text-align:center}.notification{animation:fadeout 3s forwards;background-color:#4caf50;background-color:var(--primary-color);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 4px 6px #0000001a;box-shadow:var(--box-shadow);color:#fff;max-width:300px;padding:15px 30px;position:fixed;right:20px;top:20px;z-index:1000}.notification.error{background-color:#f44336}@keyframes fadeout{0%{opacity:1}70%{opacity:1}to{opacity:0}}.loading-overlay{align-items:center;background-color:#fffc;background-color:var(--overlay-bg);display:flex;flex-direction:column;height:100%;justify-content:center;left:0;pointer-events:all;position:fixed;top:0;width:100%;z-index:1000}.spinner{animation:spin 1s linear infinite;border:5px solid #f5f5f5;border-radius:50%;border-top-color:#4caf50;border:5px solid var(--secondary-color);border-top-color:var(--primary-color);height:50px;margin-bottom:15px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading{color:var(--text-light);font-size:18px;padding:20px;text-align:center}.empty-state{background-color:#fff;border-radius:8px;border-radius:var(--border-radius);box-shadow:0 4px 6px #0000001a;box-shadow:var(--box-shadow);color:#666;color:var(--text-light);margin:40px auto;max-width:600px;padding:40px 20px;text-align:center}.empty-state h3{color:#388e3c;color:var(--primary-dark);margin-bottom:15px}.error-message{border-radius:8px;border-radius:var(--border-radius);font-size:14px;margin-top:10px;padding:10px}.weather-history-graphs{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr}.weather-history-card{background-color:#fff;border-radius:8px;border-radius:var(--border-radius);box-shadow:0 4px 6px #0000001a;box-shadow:var(--box-shadow);padding:12px}.weather-history-card h4{color:#388e3c;color:var(--primary-dark);margin-bottom:8px}@media (max-width:768px){.action-buttons{align-items:center;flex-direction:column}.action-button{max-width:300px;width:100%}}.action-buttons{display:flex;gap:15px;justify-content:center;margin:20px 0}.action-button{background-color:var(--primary-color);border:none;border-radius:var(--border-radius);box-shadow:var(--box-shadow);color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:var(--transition)}.action-button:hover{background-color:var(--primary-dark);transform:translateY(-2px)}#file-list{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:0 auto 230px;max-width:1400px}@media (min-width:1200px){#file-list{grid-template-columns:repeat(auto-fill,minmax(280px,350px));justify-content:center}}@media (min-width:1600px){#file-list{grid-template-columns:repeat(auto-fill,minmax(280px,380px))}}.file{align-items:center;background-color:#fff;border:1px solid #ddd;border-radius:var(--border-radius);box-shadow:var(--box-shadow);display:flex;flex-direction:column;padding:15px;transition:var(--transition);width:100%}.file:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-5px)}.file img{border-radius:var(--border-radius);height:200px;max-height:300px;object-fit:cover}.file img,.file-info{margin-bottom:15px;width:100%}.file-info,.file-name{text-align:center}.file-name{word-wrap:break-word;color:var(--primary-dark);font-size:16px;font-weight:500;margin-bottom:5px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-name:hover{overflow:visible;text-overflow:clip;white-space:normal}.timestamp{color:var(--text-light);font-size:14px}.actions{display:flex;flex-direction:column;gap:8px;width:100%}.actions button{background-color:var(--secondary-color);border:none;border-radius:var(--border-radius);color:var(--text-color);cursor:pointer;font-size:14px;font-weight:500;padding:10px;transition:var(--transition);width:100%}.actions button:hover{background-color:#e0e0e0}.actions button.delete-button{background-color:#f44336;color:#fff}.actions button.delete-button:hover{background-color:#d32f2f}#log-console{background-color:#fff;border-radius:12px 12px 0 0;border-top:1px solid #ddd;bottom:0;box-shadow:0 -2px 10px #0000001a;font-family:Roboto Mono,monospace;font-size:14px;left:0;max-height:200px;overflow-y:auto;padding:15px;position:fixed;transition:max-height .3s ease,padding .3s ease;width:100%;z-index:1000}#log-console.minimized{cursor:pointer;max-height:40px;overflow:hidden;padding:10px 15px}#log-console.minimized .log-header{margin-bottom:0}#log-console.hidden{border-top:none;max-height:0;padding:0 15px}.log-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:10px}.log-header h3{font-size:16px;font-weight:500;margin:0}.log-controls{display:flex;gap:10px}.log-control-button{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:16px;transition:color .3s ease}.log-control-button:hover{color:var(--primary-color)}#log-list{list-style-type:none}#log-list li{border-bottom:1px solid #f0f0f0;padding:5px 0}#log-list li.log-entry{align-items:center;display:flex;gap:10px;justify-content:space-between}.log-content{flex-grow:1;word-break:break-word}.rollback-button{background-color:#ff9800;border:none;border-radius:4px;box-shadow:0 1px 3px #0003;color:#fff;cursor:pointer;font-size:11px;padding:4px 8px;transition:background-color .2s;white-space:nowrap}.rollback-button:hover{background-color:#f57c00;box-shadow:0 2px 4px #0000004d}#log-list li:last-child{border-bottom:none}.main-navigation{align-items:center;background-color:#333;color:#fff;display:flex;justify-content:space-between;padding:1rem 2rem}.nav-links{display:flex;gap:1.5rem}.nav-links a{color:#fff;font-weight:500;text-decoration:none;transition:color .3s}.nav-links a:hover{color:#4285f4}.user-controls{align-items:center;display:flex;gap:1rem}.username{font-weight:500}.logout-button{background-color:initial;border:1px solid #fff;border-radius:4px;color:#fff;cursor:pointer;padding:.5rem 1rem;transition:all .3s}.logout-button:hover{background-color:#ffffff1a}.camera-list{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin:0 auto;max-width:1400px;padding:10px}@media (min-width:1200px){.camera-list{grid-template-columns:repeat(auto-fill,minmax(320px,400px));justify-content:center}}@media (min-width:1600px){.camera-list{grid-template-columns:repeat(auto-fill,minmax(320px,450px))}}.camera-item{background-color:#fff;border:1px solid #ddd;border-radius:var(--border-radius);box-shadow:var(--box-shadow);overflow:hidden;padding:15px;transition:var(--transition)}.camera-item:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-5px)}.camera-item iframe,.camera-item img,.camera-item video{border-radius:var(--border-radius);height:220px;margin-bottom:10px;max-height:320px;object-fit:cover;width:100%}.camera-title{color:var(--primary-dark);font-size:18px;font-weight:500;margin-bottom:8px}.camera-info{background-color:var(--secondary-color);border-radius:var(--border-radius);color:var(--text-light);font-size:15px;margin-top:10px;padding:10px}.weather-info{align-items:center;display:flex;margin-top:5px}.weather-type{color:var(--primary-dark);font-weight:500}.confidence{color:var(--text-light);font-size:14px;margin-left:10px}.refresh-button{background-color:var(--primary-color);border:none;border-radius:var(--border-radius);color:#fff;cursor:pointer;display:block;font-size:16px;margin:20px auto;padding:10px 20px;transition:var(--transition)}.refresh-button:hover{background-color:var(--primary-dark)}.history-button{align-items:center;background-color:#17a2b8;border:none;border-radius:var(--border-radius);color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;margin-bottom:10px;margin-top:10px;padding:8px 15px;transition:var(--transition);width:100%}.history-button:hover{background-color:#138496;transform:translateY(-2px)}@media (max-width:768px){.camera-list{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}.login-container{align-items:center;background-color:#f5f5f5;display:flex;justify-content:center;min-height:100vh}.login-card{background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;max-width:400px;padding:2rem;text-align:center;width:100%}.login-logo{height:auto;margin-bottom:1rem;width:50px}.login-card h1{color:#333;margin-bottom:.5rem}.login-card p{color:#666;margin-bottom:2rem}.login-button{background-color:#4285f4;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;margin-bottom:1.5rem;padding:.75rem 1.5rem;transition:background-color .3s}.login-button:hover{background-color:#3367d6}.error-message{background-color:#ffebee;border-radius:4px;color:#d32f2f;font-size:.9rem;margin-bottom:1.5rem;padding:.75rem}.loading{color:#666;font-style:italic;margin-bottom:1.5rem}.setup-info{border-top:1px solid #eee;color:#888;font-size:.8rem;margin-top:1.5rem;padding-top:1rem}.setup-info a{color:#4285f4;text-decoration:none}.setup-info a:hover{text-decoration:underline}
/*# sourceMappingURL=main.a59e1a0f.css.map*/