.app-header[data-v-2f115dd0]{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:1000;height:64px}.header-container[data-v-2f115dd0]{max-width:1400px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:32px}.brand[data-v-2f115dd0]{flex-shrink:0}.logo-link[data-v-2f115dd0]{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff;font-weight:700;font-size:20px;transition:opacity .2s}.logo-link[data-v-2f115dd0]:hover{opacity:.9}.logo-icon[data-v-2f115dd0]{font-size:28px;line-height:1}.logo-text[data-v-2f115dd0]{font-family:Segoe UI,system-ui,sans-serif;letter-spacing:.5px}.hamburger-button[data-v-2f115dd0]{display:none;background:transparent;border:none;cursor:pointer;padding:12px;width:48px;height:48px;flex-direction:column;justify-content:center;align-items:center;gap:6px;border-radius:8px;transition:background .2s;flex-shrink:0}.hamburger-button[data-v-2f115dd0]:hover{background:#ffffff1a}.hamburger-line[data-v-2f115dd0]{width:24px;height:3px;background:#fff;border-radius:2px;transition:all .3s}.nav-links[data-v-2f115dd0]{display:flex;align-items:center;gap:8px;flex:1}.nav-link[data-v-2f115dd0]{padding:8px 16px;color:#ffffffe6;text-decoration:none;border-radius:8px;font-size:15px;font-weight:500;transition:all .2s;white-space:nowrap}.nav-link[data-v-2f115dd0]:hover{background:#ffffff26;color:#fff}.nav-link.active[data-v-2f115dd0]{background:#fff3;color:#fff}.user-menu[data-v-2f115dd0]{position:relative;flex-shrink:0}.user-info[data-v-2f115dd0]{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#ffffff1a;border-radius:12px;cursor:pointer;transition:background .2s}.user-info[data-v-2f115dd0]:hover{background:#ffffff26}.user-avatar[data-v-2f115dd0]{width:36px;height:36px;border-radius:50%;background:#ffffff4d;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.user-details[data-v-2f115dd0]{display:flex;flex-direction:column;gap:2px;min-width:0}.username[data-v-2f115dd0]{color:#fff;font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role[data-v-2f115dd0]{font-size:12px;font-weight:500;padding:2px 8px;border-radius:4px;width:fit-content}.role-admin[data-v-2f115dd0]{background:#e74c3c4d;color:#fff}.role-user[data-v-2f115dd0]{background:#3498db4d;color:#fff}.role-guest[data-v-2f115dd0]{background:#95a5a64d;color:#fff}.dropdown-arrow[data-v-2f115dd0]{color:#fffc;font-size:10px;transition:transform .2s;flex-shrink:0}.dropdown-arrow.open[data-v-2f115dd0]{transform:rotate(180deg)}.dropdown-menu[data-v-2f115dd0]{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;box-shadow:0 4px 16px #00000026;min-width:220px;overflow:hidden;z-index:1001}.dropdown-item[data-v-2f115dd0]{padding:12px 16px;background:transparent;border:none;width:100%;text-align:left;font-size:14px;cursor:pointer;transition:background .2s;display:block}.dropdown-item[data-v-2f115dd0]:not(.session-info):hover{background:#f8f9fa}.session-info[data-v-2f115dd0]{display:flex;flex-direction:column;gap:4px;cursor:default;background:#f8f9fa}.session-label[data-v-2f115dd0]{font-size:12px;color:#6c757d;font-weight:500}.session-time[data-v-2f115dd0]{font-size:16px;color:#2c3e50;font-weight:700}.dropdown-divider[data-v-2f115dd0]{height:1px;background:#e9ecef;margin:4px 0}.logout-button[data-v-2f115dd0]{color:#e74c3c;font-weight:600}.logout-button[data-v-2f115dd0]:hover{background:#fee}.change-password-button[data-v-2f115dd0]:hover{background:var(--color-background-soft, #f3f4f6)}.modal-overlay[data-v-2f115dd0]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn-2f115dd0 .2s ease-out}.change-password-modal[data-v-2f115dd0]{background:#fff;border-radius:12px;width:90%;max-width:500px;box-shadow:0 25px 50px #0000004d;animation:slideUp-2f115dd0 .3s ease-out}@keyframes fadeIn-2f115dd0{0%{opacity:0}to{opacity:1}}@keyframes slideUp-2f115dd0{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.change-password-modal .modal-header[data-v-2f115dd0]{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--color-border, #e5e7eb)}.change-password-modal .modal-header h2[data-v-2f115dd0]{margin:0;font-size:1.5rem;color:var(--color-heading, #1f2937)}.change-password-modal .close-button[data-v-2f115dd0]{background:none;border:none;font-size:2rem;color:var(--color-text-secondary, #6b7280);cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.change-password-modal .close-button[data-v-2f115dd0]:hover{background:var(--color-background-soft, #f3f4f6);color:var(--color-text, #374151)}.change-password-modal .modal-body[data-v-2f115dd0]{padding:1.5rem}.change-password-modal .form-group[data-v-2f115dd0]{margin-bottom:1.25rem}.change-password-modal .form-group label[data-v-2f115dd0]{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-heading, #1f2937)}.change-password-modal .form-group input[data-v-2f115dd0]{width:100%;padding:.75rem;border:1px solid var(--color-border, #e5e7eb);border-radius:8px;font-size:1rem;transition:all .2s}.change-password-modal .form-group input[data-v-2f115dd0]:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.change-password-modal .form-group input[data-v-2f115dd0]:disabled{background:var(--color-background-soft, #f3f4f6);cursor:not-allowed}.change-password-modal .error-message[data-v-2f115dd0]{padding:.75rem;margin-bottom:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.875rem}.change-password-modal .success-message[data-v-2f115dd0]{padding:.75rem;margin-bottom:1rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;color:#16a34a;font-size:.875rem}.change-password-modal .modal-actions[data-v-2f115dd0]{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.change-password-modal .btn-primary[data-v-2f115dd0],.change-password-modal .btn-secondary[data-v-2f115dd0]{padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;border:none;font-size:1rem}.change-password-modal .btn-primary[data-v-2f115dd0]{background:var(--color-primary, #3b82f6);color:#fff}.change-password-modal .btn-primary[data-v-2f115dd0]:hover:not(:disabled){background:var(--color-primary-dark, #2563eb)}.change-password-modal .btn-secondary[data-v-2f115dd0]{background:#fff;border:1px solid var(--color-border, #e5e7eb);color:var(--color-text, #374151)}.change-password-modal .btn-secondary[data-v-2f115dd0]:hover:not(:disabled){background:var(--color-background-soft, #f3f4f6)}.change-password-modal .btn-primary[data-v-2f115dd0]:disabled,.change-password-modal .btn-secondary[data-v-2f115dd0]:disabled{opacity:.5;cursor:not-allowed}.dropdown-enter-active[data-v-2f115dd0],.dropdown-leave-active[data-v-2f115dd0]{transition:all .2s ease}.dropdown-enter-from[data-v-2f115dd0],.dropdown-leave-to[data-v-2f115dd0]{opacity:0;transform:translateY(-8px)}.mobile-nav-overlay[data-v-2f115dd0]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:2000;display:flex;align-items:flex-start;justify-content:flex-start}.mobile-nav-drawer[data-v-2f115dd0]{background:#fff;width:280px;max-width:80vw;height:100vh;box-shadow:2px 0 8px #0003;display:flex;flex-direction:column;overflow-y:auto;will-change:transform;transform:translateZ(0)}.mobile-nav-header[data-v-2f115dd0]{display:flex;align-items:center;justify-content:space-between;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-shrink:0}.mobile-nav-title[data-v-2f115dd0]{font-size:20px;font-weight:700}.close-drawer-button[data-v-2f115dd0]{background:transparent;border:none;color:#fff;font-size:32px;line-height:1;cursor:pointer;padding:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s}.close-drawer-button[data-v-2f115dd0]:hover{background:#fff3}.mobile-nav-links[data-v-2f115dd0]{display:flex;flex-direction:column;padding:8px;margin-top:auto}.mobile-nav-link[data-v-2f115dd0]{display:flex;align-items:center;gap:16px;padding:16px;color:#374151;text-decoration:none;border-radius:8px;font-size:16px;font-weight:500;transition:all .2s;min-height:44px;margin-bottom:8px}.mobile-nav-link[data-v-2f115dd0]:hover{background:#f3f4f6}.mobile-nav-link[data-v-2f115dd0]:active{background:#e5e7eb;transform:scale(.98)}.mobile-nav-link.active[data-v-2f115dd0]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.mobile-nav-link .nav-icon[data-v-2f115dd0]{font-size:24px;flex-shrink:0;width:32px;text-align:center}.mobile-nav-link .nav-text[data-v-2f115dd0]{flex:1}.drawer-enter-active[data-v-2f115dd0],.drawer-leave-active[data-v-2f115dd0]{transition:opacity .3s ease}.drawer-enter-active .mobile-nav-drawer[data-v-2f115dd0],.drawer-leave-active .mobile-nav-drawer[data-v-2f115dd0]{transition:transform .3s ease}.drawer-enter-from[data-v-2f115dd0],.drawer-leave-to[data-v-2f115dd0]{opacity:0}.drawer-enter-from .mobile-nav-drawer[data-v-2f115dd0],.drawer-leave-to .mobile-nav-drawer[data-v-2f115dd0]{transform:translate(-100%)}@media (max-width: 767px){.hamburger-button[data-v-2f115dd0]{display:flex}.nav-desktop[data-v-2f115dd0]{display:none}.header-container[data-v-2f115dd0]{padding:0 16px;gap:16px}.logo-text[data-v-2f115dd0],.user-details[data-v-2f115dd0],.dropdown-arrow[data-v-2f115dd0]{display:none}}@media (min-width: 768px) and (max-width: 1023px){.hamburger-button[data-v-2f115dd0]{display:flex}.nav-desktop[data-v-2f115dd0]{display:none}.header-container[data-v-2f115dd0]{padding:0 20px;gap:20px}.nav-links[data-v-2f115dd0]{gap:6px}.nav-link[data-v-2f115dd0]{padding:8px 14px;font-size:14px}.user-details[data-v-2f115dd0],.dropdown-arrow[data-v-2f115dd0]{display:none}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh}.mobile-fade-enter-active,.mobile-fade-leave-active{transition:opacity .15s ease}.mobile-fade-enter-from,.mobile-fade-leave-to{opacity:0}.desktop-slide-enter-active,.desktop-slide-leave-active{transition:all .2s ease}.desktop-slide-enter-from{opacity:0;transform:translate(20px)}.desktop-slide-leave-to{opacity:0;transform:translate(-20px)}.login-container[data-v-a4378315]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card[data-v-a4378315]{width:100%;max-width:420px;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;padding:2.5rem}.login-header[data-v-a4378315]{text-align:center;margin-bottom:2rem}.logo[data-v-a4378315]{font-size:2.5rem;font-weight:700;color:#667eea;margin:0 0 .5rem;letter-spacing:-.5px}.tagline[data-v-a4378315]{font-size:1rem;color:#6b7280;margin:0}.error-message[data-v-a4378315]{display:flex;align-items:center;gap:.5rem;padding:.875rem;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;color:#991b1b;font-size:.875rem;margin-bottom:1.5rem}.error-icon[data-v-a4378315]{font-size:1.25rem}.login-form[data-v-a4378315]{display:flex;flex-direction:column;gap:1.25rem}.form-group[data-v-a4378315]{display:flex;flex-direction:column;gap:.5rem}.form-label[data-v-a4378315]{font-size:.875rem;font-weight:600;color:#374151}.form-input[data-v-a4378315]{padding:.75rem 1rem;font-size:1rem;border:1px solid #d1d5db;border-radius:8px;transition:all .2s;font-family:inherit}.form-input[data-v-a4378315]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input[data-v-a4378315]:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.form-input[data-v-a4378315]::placeholder{color:#9ca3af}.checkbox-group[data-v-a4378315]{flex-direction:row;align-items:center}.checkbox-label[data-v-a4378315]{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:#4b5563}.checkbox-input[data-v-a4378315]{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:#667eea}.checkbox-input[data-v-a4378315]:disabled{cursor:not-allowed}.login-button[data-v-a4378315],.guest-button[data-v-a4378315]{padding:.875rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;cursor:pointer;transition:all .2s;font-family:inherit}.login-button[data-v-a4378315]:hover:not(:disabled),.guest-button[data-v-a4378315]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.login-button[data-v-a4378315]:active:not(:disabled),.guest-button[data-v-a4378315]:active:not(:disabled){transform:translateY(0)}.login-button[data-v-a4378315]:disabled,.guest-button[data-v-a4378315]:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-spinner[data-v-a4378315]{display:flex;align-items:center;justify-content:center;gap:.5rem}.spinner[data-v-a4378315]{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-a4378315 .8s linear infinite}@keyframes spin-a4378315{to{transform:rotate(360deg)}}.guest-access[data-v-a4378315]{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;text-align:center}.guest-text[data-v-a4378315]{font-size:.875rem;color:#6b7280;margin:0 0 1rem}.guest-link[data-v-a4378315]{color:#667eea;font-weight:600;background:none;border:none;cursor:pointer;padding:0;font-size:inherit;font-family:inherit;text-decoration:underline}.guest-link[data-v-a4378315]:hover:not(:disabled){color:#5568d3}.guest-link[data-v-a4378315]:disabled{opacity:.6;cursor:not-allowed}.guest-form[data-v-a4378315]{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.guest-button[data-v-a4378315]{background:linear-gradient(135deg,#10b981,#059669)}.guest-button[data-v-a4378315]:hover:not(:disabled){box-shadow:0 10px 20px #10b9814d}@media (max-width: 767px){.login-card[data-v-a4378315]{padding:2rem 1.5rem}.form-input[data-v-a4378315],.login-button[data-v-a4378315],.guest-button[data-v-a4378315]{min-height:44px}.logo[data-v-a4378315]{font-size:2rem}.tagline[data-v-a4378315]{font-size:.875rem}}@media (max-width: 480px){.login-card[data-v-a4378315]{padding:2rem 1.5rem}.logo[data-v-a4378315]{font-size:2rem}.tagline[data-v-a4378315]{font-size:.875rem}}.guest-login-container[data-v-4d42e205]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.guest-login-card[data-v-4d42e205]{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;padding:3rem;max-width:480px;width:100%;animation:slideIn-4d42e205 .3s ease-out}@keyframes slideIn-4d42e205{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.guest-header[data-v-4d42e205]{text-align:center;margin-bottom:2rem}.logo[data-v-4d42e205]{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.subtitle[data-v-4d42e205]{color:#6b7280;font-size:1.1rem;margin:.5rem 0 0}.instructions[data-v-4d42e205]{background:#f3f4f6;border-left:4px solid #667eea;padding:1rem;margin-bottom:2rem;border-radius:4px}.instruction-text[data-v-4d42e205]{margin:0;color:#4b5563;line-height:1.6}.step-section[data-v-4d42e205]{margin-bottom:2rem}.step-title[data-v-4d42e205]{font-size:1.25rem;color:#1f2937;margin-bottom:1.5rem}.guest-form[data-v-4d42e205],.form-group[data-v-4d42e205]{margin-bottom:1.5rem}.form-label[data-v-4d42e205]{display:block;font-weight:600;color:#374151;margin-bottom:.5rem;font-size:.95rem}.form-input[data-v-4d42e205]{width:100%;padding:.75rem 1rem;border:2px solid #d1d5db;border-radius:8px;font-size:1rem;transition:all .2s;box-sizing:border-box}.form-input[data-v-4d42e205]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input[data-v-4d42e205]:disabled{background-color:#f3f4f6;cursor:not-allowed}.input-hint[data-v-4d42e205]{margin:.5rem 0 0;font-size:.875rem;color:#6b7280}.code-input-container[data-v-4d42e205]{position:relative}.code-input[data-v-4d42e205]{width:100%;padding:.75rem 3rem .75rem 1rem;border:2px solid #d1d5db;border-radius:8px;font-size:1.5rem;font-weight:600;letter-spacing:.5rem;text-align:center;transition:all .2s;box-sizing:border-box;font-family:Courier New,monospace}.code-input[data-v-4d42e205]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.code-input.error[data-v-4d42e205]{border-color:#ef4444}.code-input[data-v-4d42e205]:disabled{background-color:#f3f4f6;cursor:not-allowed}.validation-icon[data-v-4d42e205]{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:1.5rem}.validation-icon.success[data-v-4d42e205]{color:#10b981}.validation-icon.error[data-v-4d42e205]{color:#ef4444}.request-button[data-v-4d42e205],.login-button[data-v-4d42e205]{width:100%;padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px #667eea4d}.request-button[data-v-4d42e205]:hover:not(:disabled),.login-button[data-v-4d42e205]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.request-button[data-v-4d42e205]:active:not(:disabled),.login-button[data-v-4d42e205]:active:not(:disabled){transform:translateY(0)}.request-button[data-v-4d42e205]:disabled,.login-button[data-v-4d42e205]:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-spinner[data-v-4d42e205]{display:flex;align-items:center;justify-content:center;gap:.5rem}.spinner[data-v-4d42e205]{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-4d42e205 .6s linear infinite}@keyframes spin-4d42e205{to{transform:rotate(360deg)}}.error-message[data-v-4d42e205]{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:1rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;color:#991b1b;animation:shake-4d42e205 .3s ease-in-out}@keyframes shake-4d42e205{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-icon[data-v-4d42e205]{font-size:1.25rem;flex-shrink:0}.toggle-section[data-v-4d42e205]{text-align:center;margin-top:1rem}.toggle-link[data-v-4d42e205]{background:none;border:none;color:#667eea;font-size:.95rem;cursor:pointer;text-decoration:underline;padding:.5rem;transition:color .2s}.toggle-link[data-v-4d42e205]:hover:not(:disabled){color:#764ba2}.toggle-link[data-v-4d42e205]:disabled{opacity:.5;cursor:not-allowed}.info-box[data-v-4d42e205]{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:1rem;display:flex;gap:.75rem;margin-bottom:1.5rem}.info-icon[data-v-4d42e205]{font-size:1.25rem;flex-shrink:0}.info-text[data-v-4d42e205]{margin:0;color:#1e40af;font-size:.875rem;line-height:1.5}.info-text strong[data-v-4d42e205]{font-weight:600}.back-to-login[data-v-4d42e205]{text-align:center;padding-top:1.5rem;border-top:1px solid #e5e7eb}.back-link[data-v-4d42e205]{color:#6b7280;text-decoration:none;font-size:.95rem;transition:color .2s}.back-link[data-v-4d42e205]:hover{color:#374151}@media (max-width: 767px){.guest-login-container[data-v-4d42e205]{padding:1rem}.guest-login-card[data-v-4d42e205]{padding:2rem 1.5rem}.form-input[data-v-4d42e205],.code-input[data-v-4d42e205],.request-button[data-v-4d42e205],.login-button[data-v-4d42e205]{min-height:44px}.logo[data-v-4d42e205]{font-size:2rem}}@media (max-width: 640px){.guest-login-container[data-v-4d42e205]{padding:1rem}.guest-login-card[data-v-4d42e205]{padding:2rem 1.5rem}.logo[data-v-4d42e205]{font-size:2rem}}.sensor-data[data-v-89a35b27]{margin-top:12px;padding:10px 12px;background:#0f172a0a;border:1px solid rgba(148,163,184,.2);border-radius:10px}.sensor-header[data-v-89a35b27]{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.sensor-title[data-v-89a35b27]{font-size:.85rem;font-weight:600;color:#334155}.sensor-time[data-v-89a35b27]{font-size:.75rem;color:#64748b}.sensor-grid[data-v-89a35b27]{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}.sensor-item[data-v-89a35b27]{display:flex;align-items:center;gap:6px;font-size:.85rem;color:#0f172a}.sensor-icon[data-v-89a35b27]{font-size:1rem}.sensor-value[data-v-89a35b27]{font-weight:600}@media (max-width: 767px){.sensor-grid[data-v-89a35b27]{grid-template-columns:1fr;gap:10px}.sensor-title[data-v-89a35b27],.sensor-time[data-v-89a35b27]{font-size:14px}.sensor-item[data-v-89a35b27]{font-size:14px;padding:8px;background:#fff9;border-radius:6px}.sensor-value[data-v-89a35b27]{font-size:14px}.sensor-icon[data-v-89a35b27]{font-size:1.125rem}}.camera-card[data-v-117373d7]{position:relative;display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden;transition:all .2s;cursor:pointer}.camera-card[data-v-117373d7]:hover{box-shadow:0 10px 25px #00000026;transform:translateY(-4px)}.camera-card[data-v-117373d7]:focus{outline:2px solid #667eea;outline-offset:2px}.camera-card.offline[data-v-117373d7]{opacity:.85}.status-indicator[data-v-117373d7]{position:absolute;top:.75rem;right:.75rem;display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px #00000026;z-index:10}.status-indicator.online[data-v-117373d7]{color:#059669}.status-indicator.offline[data-v-117373d7]{color:#dc2626}.status-dot[data-v-117373d7]{width:8px;height:8px;border-radius:50%;animation:pulse-117373d7 2s infinite}.status-indicator.online .status-dot[data-v-117373d7]{background:#10b981}.status-indicator.offline .status-dot[data-v-117373d7]{background:#ef4444}@keyframes pulse-117373d7{0%,to{opacity:1}50%{opacity:.5}}.live-badge[data-v-117373d7]{position:absolute;top:.75rem;left:.75rem;display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:700;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef444466;z-index:10;animation:livePulse-117373d7 2s infinite}.live-dot[data-v-117373d7]{width:8px;height:8px;border-radius:50%;background:#fff;animation:liveFlash-117373d7 1.5s infinite}@keyframes livePulse-117373d7{0%,to{box-shadow:0 2px 8px #ef444466}50%{box-shadow:0 4px 16px #ef444499}}@keyframes liveFlash-117373d7{0%,to{opacity:1}50%{opacity:.3}}.thumbnail-container[data-v-117373d7]{position:relative;width:100%;height:200px;background:#f3f4f6;overflow:hidden}.thumbnail[data-v-117373d7]{width:100%;height:100%}.thumbnail img[data-v-117373d7]{width:100%;height:100%;object-fit:cover}.image-loading-indicator[data-v-117373d7]{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f3f4f6e6;pointer-events:none;transition:opacity .3s ease}.thumbnail img.lazy-loaded~.image-loading-indicator[data-v-117373d7]{opacity:0;pointer-events:none}.thumbnail img.lazy-error~.image-loading-indicator[data-v-117373d7]{opacity:0;pointer-events:none}.loading-spinner[data-v-117373d7]{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin-camera-117373d7 .8s linear infinite}@keyframes spin-camera-117373d7{to{transform:rotate(360deg)}}.thumbnail-placeholder[data-v-117373d7]{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,#f3f4f6,#e5e7eb)}.placeholder-icon[data-v-117373d7]{font-size:3rem;opacity:.4;margin-bottom:.5rem}.placeholder-text[data-v-117373d7]{font-size:.875rem;color:#9ca3af;font-weight:500}.camera-info[data-v-117373d7]{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.camera-name[data-v-117373d7]{font-size:1.125rem;font-weight:700;color:#111827;margin:0;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.camera-location[data-v-117373d7]{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:#6b7280}.location-icon[data-v-117373d7]{font-size:1rem}.location-text[data-v-117373d7]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.camera-stats[data-v-117373d7]{display:flex;gap:1rem;padding-top:.5rem;border-top:1px solid #e5e7eb}.stat-item[data-v-117373d7]{display:flex;align-items:center;gap:.375rem;font-size:.813rem;color:#6b7280}.stat-icon[data-v-117373d7]{font-size:1rem}.stat-item.battery-low[data-v-117373d7]{color:#dc2626}.stat-item.battery-medium[data-v-117373d7]{color:#f59e0b}.stat-item.battery-high[data-v-117373d7]{color:#10b981}.stat-item.sd-card-low[data-v-117373d7]{color:#dc2626}.stat-item.sd-card-medium[data-v-117373d7]{color:#f59e0b}.stat-item.sd-card-high[data-v-117373d7]{color:#10b981}.camera-daylight[data-v-117373d7]{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-secondary, #888);margin-top:.375rem}.daylight-icon[data-v-117373d7]{font-size:.75rem;flex-shrink:0}.daylight-text[data-v-117373d7]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.camera-hardware[data-v-117373d7]{display:flex;align-items:center;gap:.5rem;font-size:.75rem;margin-top:.5rem}.hardware-type[data-v-117373d7]{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;border-radius:6px;font-weight:600;font-size:.688rem;letter-spacing:.025em;transition:all .2s}.hardware-type.hardware-esp32[data-v-117373d7]{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border:1px solid #93c5fd}.hardware-type.hardware-pi[data-v-117373d7]{background:linear-gradient(135deg,#fce7f3,#fbcfe8);color:#be185d;border:1px solid #f9a8d4}.hardware-type.hardware-unknown[data-v-117373d7]{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb}.hardware-icon[data-v-117373d7]{font-size:.875rem;line-height:1}.hardware-label[data-v-117373d7]{line-height:1}.camera-power[data-v-117373d7]{margin-top:.375rem}.power-badge[data-v-117373d7]{display:inline-flex;align-items:center;gap:.375rem;padding:.3125rem .625rem;border-radius:999px;font-size:.688rem;font-weight:600;letter-spacing:.02em;border:1px solid transparent}.power-badge.power-awake[data-v-117373d7]{background:#dcfce7;color:#166534;border-color:#86efac}.power-badge.power-sleeping[data-v-117373d7]{background:#e0f2fe;color:#075985;border-color:#7dd3fc}.power-badge.power-waking[data-v-117373d7]{background:#fef3c7;color:#92400e;border-color:#fcd34d}.power-badge.power-offline[data-v-117373d7]{background:#fee2e2;color:#991b1b;border-color:#fecaca}.power-icon[data-v-117373d7]{font-size:.8rem}.sensor-data[data-v-117373d7]{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.sensor-header[data-v-117373d7]{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.sensor-title[data-v-117373d7]{font-size:.813rem;font-weight:600;color:#374151}.sensor-time[data-v-117373d7]{font-size:.75rem;color:#9ca3af}.sensor-grid[data-v-117373d7]{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.sensor-item[data-v-117373d7]{display:flex;align-items:center;gap:.375rem;font-size:.813rem;color:#6b7280;padding:.375rem .5rem;background:#f9fafb;border-radius:6px}.sensor-icon[data-v-117373d7]{font-size:1rem}.sensor-value[data-v-117373d7]{font-weight:500;color:#111827}@media (max-width: 767px){.camera-card[data-v-117373d7]{max-width:100%}.thumbnail-container[data-v-117373d7]{height:180px}.thumbnail img[data-v-117373d7]{max-width:100%;height:auto;object-fit:cover}.camera-info[data-v-117373d7]{padding:.75rem}.camera-name[data-v-117373d7]{font-size:1rem}.camera-stats[data-v-117373d7]{flex-wrap:wrap;gap:.75rem}.stat-item[data-v-117373d7]{font-size:14px}.stat-text[data-v-117373d7]{font-size:14px!important}.stat-icon[data-v-117373d7]{font-size:1rem}.status-text[data-v-117373d7]{font-size:14px!important}.camera-location[data-v-117373d7]{font-size:14px}.location-text[data-v-117373d7]{font-size:14px!important}.hardware-type[data-v-117373d7],.power-badge[data-v-117373d7]{font-size:.625rem;padding:.313rem .5rem}.status-indicator[data-v-117373d7],.live-badge[data-v-117373d7]{min-width:44px;min-height:44px;padding:.5rem .875rem;font-size:.688rem}.camera-card[data-v-117373d7]{min-height:44px}.sensor-item[data-v-117373d7]{font-size:.75rem;padding:.313rem .438rem}.sensor-icon[data-v-117373d7]{font-size:.875rem}}@media (min-width: 768px) and (max-width: 1023px){.thumbnail-container[data-v-117373d7]{height:190px}.camera-info[data-v-117373d7]{padding:.875rem}.camera-stats[data-v-117373d7]{gap:.875rem}}.modal-overlay[data-v-c48cbaf6]{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000;animation:fadeIn-c48cbaf6 .2s ease-out;will-change:opacity;transform:translateZ(0)}@keyframes fadeIn-c48cbaf6{0%{opacity:0}to{opacity:1}}.modal-container[data-v-c48cbaf6]{width:100%;max-width:500px;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;animation:slideUp-c48cbaf6 .3s ease-out;will-change:transform,opacity;backface-visibility:hidden}@keyframes slideUp-c48cbaf6{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header[data-v-c48cbaf6]{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid #e5e7eb}.modal-title[data-v-c48cbaf6]{font-size:1.5rem;font-weight:700;color:#111827;margin:0}.close-button[data-v-c48cbaf6]{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;font-size:1.5rem;color:#6b7280;background:none;border:none;border-radius:6px;cursor:pointer;transition:all .2s;font-family:inherit}.close-button[data-v-c48cbaf6]:hover:not(:disabled){background:#f3f4f6;color:#111827}.close-button[data-v-c48cbaf6]:disabled{opacity:.5;cursor:not-allowed}.modal-body[data-v-c48cbaf6]{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.instructions[data-v-c48cbaf6]{display:flex;flex-direction:column;gap:1rem}.instruction-text[data-v-c48cbaf6]{font-size:.938rem;color:#6b7280;margin:0;line-height:1.5}.instruction-steps[data-v-c48cbaf6]{display:flex;flex-direction:column;gap:.75rem}.step[data-v-c48cbaf6]{display:flex;align-items:center;gap:.75rem}.step-number[data-v-c48cbaf6]{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;font-size:.875rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;flex-shrink:0}.step-text[data-v-c48cbaf6]{font-size:.875rem;color:#374151}.pair-form[data-v-c48cbaf6]{display:flex;flex-direction:column;gap:1.5rem}.form-group[data-v-c48cbaf6]{display:flex;flex-direction:column;gap:.5rem}.form-label[data-v-c48cbaf6]{font-size:.875rem;font-weight:600;color:#374151}.code-input-container[data-v-c48cbaf6]{position:relative;display:flex;align-items:center}.code-input[data-v-c48cbaf6]{width:100%;padding:1rem 3rem 1rem 1rem;font-size:1.5rem;font-weight:700;text-align:center;letter-spacing:.5rem;border:2px solid #d1d5db;border-radius:8px;transition:all .2s;font-family:Courier New,monospace}.code-input[data-v-c48cbaf6]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.code-input.error[data-v-c48cbaf6]{border-color:#ef4444}.code-input[data-v-c48cbaf6]:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.code-input[data-v-c48cbaf6]::placeholder{color:#d1d5db;letter-spacing:.5rem}.validation-icon[data-v-c48cbaf6]{position:absolute;right:1rem;font-size:1.25rem}.validation-icon.success[data-v-c48cbaf6]{color:#10b981}.validation-icon.error[data-v-c48cbaf6]{color:#ef4444}.input-hint[data-v-c48cbaf6]{font-size:.75rem;color:#9ca3af;margin:0}.error-message[data-v-c48cbaf6]{display:flex;align-items:center;gap:.5rem;padding:.875rem;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;color:#991b1b;font-size:.875rem}.error-icon[data-v-c48cbaf6]{font-size:1.25rem;flex-shrink:0}.modal-actions[data-v-c48cbaf6]{display:flex;gap:.75rem;justify-content:flex-end}.action-button[data-v-c48cbaf6]{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.938rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s;font-family:inherit}.action-button.primary[data-v-c48cbaf6]{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);min-width:140px}.action-button.primary[data-v-c48cbaf6]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.action-button.secondary[data-v-c48cbaf6]{color:#374151;background:#fff;border:1px solid #d1d5db}.action-button.secondary[data-v-c48cbaf6]:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.action-button[data-v-c48cbaf6]:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-content[data-v-c48cbaf6]{display:flex;align-items:center;gap:.5rem}.info-box[data-v-c48cbaf6]{display:flex;gap:.75rem;padding:1rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px}.info-icon[data-v-c48cbaf6]{font-size:1.25rem;flex-shrink:0}.info-text[data-v-c48cbaf6]{font-size:.813rem;color:#1e40af;margin:0;line-height:1.5}.info-text strong[data-v-c48cbaf6]{font-weight:700}.spinner[data-v-c48cbaf6]{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-c48cbaf6 .8s linear infinite}@keyframes spin-c48cbaf6{to{transform:rotate(360deg)}}@media (max-width: 767px){.modal-container[data-v-c48cbaf6]{max-width:100%;max-height:100vh;border-radius:0}.code-input[data-v-c48cbaf6],.form-input[data-v-c48cbaf6],.action-button[data-v-c48cbaf6]{min-height:44px}.modal-header[data-v-c48cbaf6]{padding:1.25rem}.modal-title[data-v-c48cbaf6]{font-size:1.25rem}.modal-body[data-v-c48cbaf6]{padding:1.25rem}.code-input[data-v-c48cbaf6]{font-size:1.25rem;letter-spacing:.375rem;padding:.875rem 2.5rem .875rem .875rem}.code-input[data-v-c48cbaf6]::placeholder{letter-spacing:.375rem}.modal-actions[data-v-c48cbaf6]{flex-direction:column-reverse;gap:12px}.action-button[data-v-c48cbaf6]{width:100%}}.slide-down-enter-active[data-v-983b725f],.slide-down-leave-active[data-v-983b725f]{transition:all .3s cubic-bezier(.4,0,.2,1)}.slide-down-enter-from[data-v-983b725f]{opacity:0;transform:translateY(-100%)}.slide-down-leave-to[data-v-983b725f]{opacity:0;transform:translateY(-20px)}.notification-banner[data-v-983b725f]{position:relative;display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000026,0 0 0 1px #0000000d;overflow:hidden;margin-bottom:1rem;transition:all .2s}.notification-banner[data-v-983b725f]:hover{box-shadow:0 8px 24px #0003,0 0 0 1px #00000014}.notification-banner.dismissing[data-v-983b725f]{opacity:.7;pointer-events:none}.notification-info[data-v-983b725f]{border-left:4px solid #3b82f6}.notification-success[data-v-983b725f]{border-left:4px solid #10b981}.notification-warning[data-v-983b725f]{border-left:4px solid #f59e0b}.notification-error[data-v-983b725f]{border-left:4px solid #ef4444}.notification-content[data-v-983b725f]{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem}.notification-icon[data-v-983b725f]{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;flex-shrink:0;font-size:1.25rem}.notification-info .notification-icon[data-v-983b725f]{background:#3b82f61a;color:#3b82f6}.notification-success .notification-icon[data-v-983b725f]{background:#10b9811a;color:#10b981}.notification-warning .notification-icon[data-v-983b725f]{background:#f59e0b1a;color:#f59e0b}.notification-error .notification-icon[data-v-983b725f]{background:#ef44441a;color:#ef4444}.notification-message[data-v-983b725f]{flex:1;display:flex;flex-direction:column;gap:.5rem;min-width:0}.message-header[data-v-983b725f]{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.message-title[data-v-983b725f]{font-size:.95rem;font-weight:600;color:var(--color-heading, #1f2937);line-height:1.4}.camera-badge[data-v-983b725f]{display:inline-flex;align-items:center;padding:.25rem .625rem;background:var(--color-background-soft, #f3f4f6);border-radius:6px;font-size:.8rem;font-weight:500;color:var(--color-text, #374151)}.message-timestamp[data-v-983b725f]{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:var(--color-text-muted, #6b7280)}.timestamp-icon[data-v-983b725f]{font-size:.75rem}.notification-action[data-v-983b725f]{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;background:var(--color-primary, #3b82f6);color:#fff;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s;flex-shrink:0}.notification-action[data-v-983b725f]:hover{background:var(--color-primary-dark, #2563eb);transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.notification-action[data-v-983b725f]:active{transform:translateY(0)}.notification-dismiss[data-v-983b725f]{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:6px;cursor:pointer;transition:all .2s;flex-shrink:0;color:var(--color-text-muted, #6b7280)}.notification-dismiss[data-v-983b725f]:hover{background:var(--color-background-soft, #f3f4f6);color:var(--color-text, #374151)}.dismiss-icon[data-v-983b725f]{font-size:1.125rem;line-height:1}.notification-progress[data-v-983b725f]{position:relative;height:3px;background:#0000000d;overflow:hidden}.progress-bar[data-v-983b725f]{position:absolute;top:0;left:0;height:100%;background:var(--color-primary, #3b82f6);transition:width 50ms linear}.notification-info .progress-bar[data-v-983b725f]{background:#3b82f6}.notification-success .progress-bar[data-v-983b725f]{background:#10b981}.notification-warning .progress-bar[data-v-983b725f]{background:#f59e0b}.notification-error .progress-bar[data-v-983b725f]{background:#ef4444}@media (max-width: 767px){.notification-banner[data-v-983b725f]{max-width:calc(100vw - 2rem)}.notification-content[data-v-983b725f]{padding:1rem;gap:.875rem}.notification-icon[data-v-983b725f]{width:40px;height:40px;font-size:1.25rem}.message-title[data-v-983b725f]{font-size:16px!important;line-height:1.6}.message-timestamp[data-v-983b725f],.timestamp-icon[data-v-983b725f]{font-size:14px}}@media (max-width: 640px){.notification-content[data-v-983b725f]{padding:.875rem 1rem;gap:.75rem}.notification-icon[data-v-983b725f]{width:36px;height:36px;font-size:1.125rem}.message-title[data-v-983b725f]{font-size:16px!important}.camera-badge[data-v-983b725f]{font-size:.75rem;padding:.1875rem .5rem}.notification-action[data-v-983b725f]{padding:.4375rem .875rem;font-size:.8125rem}.notification-dismiss[data-v-983b725f]{width:28px;height:28px}.dismiss-icon[data-v-983b725f]{font-size:1rem}}@media (prefers-color-scheme: dark){.notification-banner[data-v-983b725f]{background:var(--color-background-dark, #1f2937);box-shadow:0 4px 12px #0000004d,0 0 0 1px #ffffff1a}.message-title[data-v-983b725f]{color:var(--color-heading-dark, #f9fafb)}.camera-badge[data-v-983b725f]{background:var(--color-background-mute-dark, #374151);color:var(--color-text-dark, #e5e7eb)}.message-timestamp[data-v-983b725f]{color:var(--color-text-muted-dark, #9ca3af)}.notification-dismiss[data-v-983b725f]:hover{background:var(--color-background-mute-dark, #374151);color:var(--color-text-dark, #e5e7eb)}}.session-warning-banner[data-v-79d7bdf7]{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff;box-shadow:0 4px 12px #00000026;border-bottom:3px solid rgba(255,255,255,.3)}.session-warning-banner.critical[data-v-79d7bdf7]{background:linear-gradient(135deg,#e74c3c,#c0392b);animation:pulse-critical-79d7bdf7 2s ease-in-out infinite}@keyframes pulse-critical-79d7bdf7{0%,to{opacity:1}50%{opacity:.9}}.warning-content[data-v-79d7bdf7]{display:flex;align-items:center;gap:1rem;padding:1rem 2rem;max-width:1200px;margin:0 auto}.warning-icon[data-v-79d7bdf7]{font-size:2rem;animation:bounce-79d7bdf7 1s ease-in-out infinite}@keyframes bounce-79d7bdf7{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.warning-text[data-v-79d7bdf7]{flex:1;min-width:0}.warning-message[data-v-79d7bdf7]{margin:0 0 .25rem;font-size:1rem;font-weight:600}.warning-details[data-v-79d7bdf7]{margin:0;font-size:.875rem;opacity:.95}.extend-button[data-v-79d7bdf7]{padding:.5rem 1.5rem;background:#fff3;border:2px solid rgba(255,255,255,.5);border-radius:6px;color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.extend-button[data-v-79d7bdf7]:hover:not(:disabled){background:#ffffff4d;border-color:#fffc;transform:translateY(-1px)}.extend-button[data-v-79d7bdf7]:active:not(:disabled){transform:translateY(0)}.extend-button[data-v-79d7bdf7]:disabled{opacity:.6;cursor:not-allowed}.warning-progress[data-v-79d7bdf7]{height:4px;background:#0003;overflow:hidden}.progress-bar[data-v-79d7bdf7]{height:100%;background:#fffc;transition:width .3s ease;box-shadow:0 0 10px #ffffff80}.slide-down-enter-active[data-v-79d7bdf7],.slide-down-leave-active[data-v-79d7bdf7]{transition:all .3s ease}.slide-down-enter-from[data-v-79d7bdf7],.slide-down-leave-to[data-v-79d7bdf7]{transform:translateY(-100%);opacity:0}@media (max-width: 768px){.warning-content[data-v-79d7bdf7]{flex-direction:column;align-items:flex-start;gap:.75rem;padding:.875rem 1rem}.warning-icon[data-v-79d7bdf7]{font-size:1.5rem;align-self:center}.warning-text[data-v-79d7bdf7]{text-align:center}.warning-message[data-v-79d7bdf7]{font-size:.875rem}.warning-details[data-v-79d7bdf7]{font-size:.8125rem}.extend-button[data-v-79d7bdf7]{width:100%;padding:.625rem 1rem}}@media (max-width: 480px){.warning-content[data-v-79d7bdf7]{padding:.75rem .875rem}.warning-message[data-v-79d7bdf7]{font-size:.8125rem}.warning-details[data-v-79d7bdf7]{font-size:.75rem}}.storage-warning-banner[data-v-49e287cd]{position:relative;background:var(--color-surface);border-left:4px solid;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:1rem;overflow:hidden;transition:all .3s ease}.storage-warning-banner.warning-critical[data-v-49e287cd]{border-left-color:#dc2626;background:linear-gradient(90deg,rgba(220,38,38,.05) 0%,var(--color-surface) 100%)}.storage-warning-banner.warning-high[data-v-49e287cd]{border-left-color:#f59e0b;background:linear-gradient(90deg,rgba(245,158,11,.05) 0%,var(--color-surface) 100%)}.storage-warning-banner.warning-medium[data-v-49e287cd]{border-left-color:#eab308;background:linear-gradient(90deg,rgba(234,179,8,.05) 0%,var(--color-surface) 100%)}.storage-warning-banner.is-dismissing[data-v-49e287cd]{opacity:0;transform:translateY(-10px)}.banner-content[data-v-49e287cd]{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem}.banner-icon[data-v-49e287cd]{font-size:2rem;line-height:1;flex-shrink:0}.banner-message[data-v-49e287cd]{flex:1;min-width:0}.message-header[data-v-49e287cd]{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.message-title[data-v-49e287cd]{font-weight:600;font-size:1rem;color:var(--color-text)}.camera-badge[data-v-49e287cd]{display:inline-block;padding:.125rem .5rem;background:var(--color-primary);color:#fff;border-radius:12px;font-size:.75rem;font-weight:500}.message-details[data-v-49e287cd]{font-size:.875rem;color:var(--color-text-secondary);line-height:1.5}.storage-progress[data-v-49e287cd]{flex-shrink:0;width:200px}.progress-bar[data-v-49e287cd]{height:8px;background:var(--color-border);border-radius:4px;overflow:hidden;margin-bottom:.25rem}.progress-fill[data-v-49e287cd]{height:100%;transition:width .3s ease;border-radius:4px}.progress-fill.fill-critical[data-v-49e287cd]{background:linear-gradient(90deg,#dc2626,#b91c1c)}.progress-fill.fill-high[data-v-49e287cd]{background:linear-gradient(90deg,#f59e0b,#d97706)}.progress-fill.fill-medium[data-v-49e287cd]{background:linear-gradient(90deg,#eab308,#ca8a04)}.progress-label[data-v-49e287cd]{font-size:.75rem;color:var(--color-text-secondary);text-align:center}.storage-size[data-v-49e287cd]{display:block;font-size:.7rem;opacity:.8}.banner-actions[data-v-49e287cd]{display:flex;gap:.5rem;flex-shrink:0}.action-button[data-v-49e287cd]{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.action-button.reset[data-v-49e287cd]{background:var(--color-primary);color:#fff}.action-button.reset[data-v-49e287cd]:hover:not(:disabled){background:var(--color-primary-dark)}.action-button.reset[data-v-49e287cd]:disabled{opacity:.5;cursor:not-allowed}.action-button.view[data-v-49e287cd]{background:var(--color-border);color:var(--color-text)}.action-button.view[data-v-49e287cd]:hover{background:var(--color-border-hover)}.banner-dismiss[data-v-49e287cd]{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.banner-dismiss[data-v-49e287cd]:hover{background:var(--color-border);color:var(--color-text)}.dismiss-icon[data-v-49e287cd]{font-size:1rem;line-height:1}.slide-down-enter-active[data-v-49e287cd],.slide-down-leave-active[data-v-49e287cd]{transition:all .3s ease}.slide-down-enter-from[data-v-49e287cd]{opacity:0;transform:translateY(-20px)}.slide-down-leave-to[data-v-49e287cd]{opacity:0;transform:translateY(-10px)}@media (max-width: 1024px){.banner-content[data-v-49e287cd]{flex-wrap:wrap}.storage-progress[data-v-49e287cd]{width:150px}.banner-actions[data-v-49e287cd]{flex-basis:100%;margin-top:.5rem}}@media (max-width: 640px){.banner-content[data-v-49e287cd]{flex-direction:column;align-items:stretch}.storage-progress[data-v-49e287cd]{width:100%}.banner-actions[data-v-49e287cd]{margin-top:.75rem}.action-button[data-v-49e287cd]{flex:1}}.dashboard-container[data-v-27ddb4c3]{min-height:100vh;background:#f9fafb;padding:2rem}.storage-warnings-container[data-v-27ddb4c3]{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.75rem}.notifications-container[data-v-27ddb4c3]{position:fixed;top:1rem;right:1rem;left:1rem;max-width:500px;margin-left:auto;z-index:1000;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.notifications-container[data-v-27ddb4c3]>*{pointer-events:auto}.dashboard-header[data-v-27ddb4c3]{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.header-content[data-v-27ddb4c3]{flex:1;min-width:250px}.dashboard-title[data-v-27ddb4c3]{font-size:2rem;font-weight:700;color:#111827;margin:0 0 .25rem}.dashboard-subtitle[data-v-27ddb4c3]{font-size:1rem;color:#6b7280;margin:0}.header-actions[data-v-27ddb4c3]{display:flex;gap:.75rem;flex-wrap:wrap}.action-button[data-v-27ddb4c3]{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.875rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s;font-family:inherit}.action-button.primary[data-v-27ddb4c3]{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2)}.action-button.primary[data-v-27ddb4c3]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.action-button.secondary[data-v-27ddb4c3]{color:#374151;background:#fff;border:1px solid #d1d5db}.action-button.secondary[data-v-27ddb4c3]:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.action-button[data-v-27ddb4c3]:disabled{opacity:.6;cursor:not-allowed;transform:none}.action-button.large[data-v-27ddb4c3]{padding:1rem 2rem;font-size:1rem}.button-icon[data-v-27ddb4c3]{font-size:1.25rem}.button-icon.rotating[data-v-27ddb4c3]{animation:spin-27ddb4c3 1s linear infinite}@keyframes spin-27ddb4c3{to{transform:rotate(360deg)}}.stats-summary[data-v-27ddb4c3]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card[data-v-27ddb4c3]{display:flex;align-items:center;gap:1rem;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000001a;transition:all .2s}.stat-card[data-v-27ddb4c3]:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.stat-card.online[data-v-27ddb4c3]{border-left:4px solid #10b981}.stat-card.offline[data-v-27ddb4c3]{border-left:4px solid #f59e0b}.stat-card.storage[data-v-27ddb4c3]{border-left:4px solid #3b82f6}.stat-card.storage.warning[data-v-27ddb4c3]{border-left:4px solid #f59e0b}.stat-card.storage.critical[data-v-27ddb4c3]{border-left:4px solid #ef4444}.stat-icon[data-v-27ddb4c3]{font-size:2.5rem}.stat-content[data-v-27ddb4c3]{flex:1}.stat-value[data-v-27ddb4c3]{font-size:2rem;font-weight:700;color:#111827;line-height:1}.stat-label[data-v-27ddb4c3]{font-size:.875rem;color:#6b7280;margin-top:.25rem}.cameras-section[data-v-27ddb4c3]{margin-bottom:2rem}.cameras-grid[data-v-27ddb4c3]{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}@media (max-width: 767px){.cameras-grid[data-v-27ddb4c3]{grid-template-columns:1fr;gap:1rem}}@media (min-width: 768px) and (max-width: 1023px){.cameras-grid[data-v-27ddb4c3]{grid-template-columns:repeat(2,1fr);gap:1.5rem}}.pagination[data-v-27ddb4c3]{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:2rem}.pagination-button[data-v-27ddb4c3]{padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s;font-family:inherit}.pagination-button[data-v-27ddb4c3]:hover:not(:disabled){background:#f9fafb;border-color:#667eea;color:#667eea}.pagination-button[data-v-27ddb4c3]:disabled{opacity:.5;cursor:not-allowed}.pagination-pages[data-v-27ddb4c3]{display:flex;gap:.25rem}.pagination-page[data-v-27ddb4c3]{min-width:2.5rem;padding:.5rem;font-size:.875rem;font-weight:600;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:all .2s;font-family:inherit}.pagination-page[data-v-27ddb4c3]:hover{background:#f9fafb;border-color:#667eea;color:#667eea}.pagination-page.active[data-v-27ddb4c3]{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent}.loading-state[data-v-27ddb4c3],.error-state[data-v-27ddb4c3],.empty-state[data-v-27ddb4c3]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:3rem;text-align:center}.spinner-large[data-v-27ddb4c3]{width:3rem;height:3rem;border:4px solid rgba(102,126,234,.2);border-top-color:#667eea;border-radius:50%;animation:spin-27ddb4c3 .8s linear infinite;margin-bottom:1.5rem}.loading-state p[data-v-27ddb4c3]{font-size:1.125rem;color:#6b7280;margin:0}.error-icon[data-v-27ddb4c3],.empty-icon[data-v-27ddb4c3]{font-size:4rem;margin-bottom:1rem}.error-state h2[data-v-27ddb4c3],.empty-state h2[data-v-27ddb4c3]{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .5rem}.error-state p[data-v-27ddb4c3],.empty-state p[data-v-27ddb4c3]{font-size:1rem;color:#6b7280;margin:0 0 1.5rem}@media (max-width: 767px){.dashboard-container[data-v-27ddb4c3]{padding:1rem}.notifications-container[data-v-27ddb4c3]{top:.5rem;right:.5rem;left:.5rem;max-width:none}.dashboard-header[data-v-27ddb4c3]{flex-direction:column;align-items:flex-start}.header-actions[data-v-27ddb4c3]{width:100%}.action-button[data-v-27ddb4c3]{flex:1;justify-content:center}.dashboard-title[data-v-27ddb4c3]{font-size:1.5rem}.stats-summary[data-v-27ddb4c3]{grid-template-columns:1fr}.pagination[data-v-27ddb4c3]{flex-wrap:wrap}.pagination-button[data-v-27ddb4c3]{flex:1;min-width:100px}}@media (min-width: 768px) and (max-width: 1023px){.dashboard-container[data-v-27ddb4c3]{padding:1.5rem}.stats-summary[data-v-27ddb4c3]{grid-template-columns:repeat(2,1fr)}}.cameras-view[data-v-2becafdc]{padding:2rem}.media-viewer-overlay[data-v-4a0da662]{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn-4a0da662 .2s ease-out;will-change:opacity;transform:translateZ(0)}@keyframes fadeIn-4a0da662{0%{opacity:0}to{opacity:1}}.media-viewer-modal[data-v-4a0da662]{display:flex;flex-direction:column;width:90vw;height:90vh;max-width:1400px;background:var(--color-background, #ffffff);border-radius:16px;overflow:hidden;box-shadow:0 25px 50px #00000080;animation:slideUp-4a0da662 .3s ease-out;will-change:transform,opacity;backface-visibility:hidden}@keyframes slideUp-4a0da662{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header[data-v-4a0da662]{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:var(--color-background, #ffffff);border-bottom:1px solid var(--color-border, #e5e7eb)}.header-content[data-v-4a0da662]{display:flex;flex-direction:column;gap:.5rem}.modal-title[data-v-4a0da662]{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-heading, #1f2937)}.media-info[data-v-4a0da662]{display:flex;align-items:center;gap:1rem}.info-badge[data-v-4a0da662]{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:6px;font-size:.875rem;font-weight:500;text-transform:capitalize}.info-badge.badge-photo[data-v-4a0da662]{background:#dbeafe;color:#1e40af}.info-badge.badge-video[data-v-4a0da662]{background:#fce7f3;color:#be185d}.info-badge.badge-timelapse[data-v-4a0da662]{background:#fef3c7;color:#92400e}.info-text[data-v-4a0da662]{font-size:.875rem;color:var(--color-text-secondary, #6b7280)}.close-button[data-v-4a0da662]{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:var(--color-background-soft, #f3f4f6);border-radius:8px;font-size:1.5rem;cursor:pointer;transition:all .2s}.close-button[data-v-4a0da662]:hover{background:var(--color-background-mute, #e5e7eb);transform:scale(1.1)}.media-container[data-v-4a0da662]{position:relative;flex:1;display:flex;align-items:center;justify-content:center;background:#000;overflow:hidden;touch-action:pan-y pinch-zoom}.media-image[data-v-4a0da662],.media-video[data-v-4a0da662]{max-width:100%;max-height:100%;object-fit:contain}.media-image[data-v-4a0da662]{transition:transform .2s ease}.media-video[data-v-4a0da662]{width:100%;height:100%}.loading-state[data-v-4a0da662],.error-state[data-v-4a0da662]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#fff}.spinner[data-v-4a0da662]{width:48px;height:48px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin-4a0da662 .8s linear infinite;margin:0 auto 1rem}@keyframes spin-4a0da662{to{transform:rotate(360deg)}}.loading-text[data-v-4a0da662],.error-text[data-v-4a0da662]{margin:0;font-size:1rem;font-weight:500}.error-icon[data-v-4a0da662]{font-size:3rem;display:block;margin-bottom:1rem}.nav-button[data-v-4a0da662]{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:60px;height:60px;border:none;background:#ffffffe6;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #0000004d}.nav-button[data-v-4a0da662]:hover{background:#fff;transform:translateY(-50%) scale(1.1)}.nav-previous[data-v-4a0da662]{left:2rem}.nav-next[data-v-4a0da662]{right:2rem}.nav-icon[data-v-4a0da662]{font-weight:700;color:#1f2937}.modal-footer[data-v-4a0da662]{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:var(--color-background, #ffffff);border-top:1px solid var(--color-border, #e5e7eb)}.footer-info[data-v-4a0da662]{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.info-group[data-v-4a0da662]{display:flex;align-items:center;gap:.5rem}.info-icon[data-v-4a0da662]{font-size:1rem}.footer-actions[data-v-4a0da662]{display:flex;gap:.75rem}.action-button[data-v-4a0da662]{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:1px solid var(--color-border, #e5e7eb);background:#fff;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.action-button[data-v-4a0da662]:hover{border-color:var(--color-primary, #3b82f6);background:var(--color-background-soft, #f9fafb)}.action-button.delete[data-v-4a0da662]:hover{border-color:#dc2626;background:#fef2f2;color:#dc2626}.action-button.identify[data-v-4a0da662]:hover:not(:disabled){border-color:#059669;background:#f0fdf4;color:#059669}.action-button[data-v-4a0da662]:disabled{opacity:.6;cursor:not-allowed}.action-icon[data-v-4a0da662]{font-size:1rem}@media (max-width: 768px){.media-viewer-modal[data-v-4a0da662]{width:100vw;height:100vh;border-radius:0}.nav-button[data-v-4a0da662]{width:56px;height:56px}.nav-previous[data-v-4a0da662]{left:1rem}.nav-next[data-v-4a0da662]{right:1rem}.footer-info[data-v-4a0da662]{flex-direction:column;align-items:flex-start;gap:.5rem}.modal-footer[data-v-4a0da662]{flex-direction:column;gap:1rem}.footer-actions[data-v-4a0da662]{width:100%}.action-button[data-v-4a0da662]{flex:1}}.media-timeline[data-v-bfdbb556]{display:flex;flex-direction:column;gap:1.5rem}.timeline-header[data-v-bfdbb556]{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.timeline-title[data-v-bfdbb556]{display:flex;align-items:center;gap:.75rem;margin:0;font-size:1.5rem;font-weight:700;color:var(--color-heading, #1f2937)}.title-icon[data-v-bfdbb556]{font-size:1.75rem}.header-controls[data-v-bfdbb556]{display:flex;align-items:center;gap:1rem}.timeline-filters[data-v-bfdbb556]{display:flex;gap:.5rem;flex-wrap:wrap}.filter-button[data-v-bfdbb556]{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--color-border, #e5e7eb);background:#fff;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.filter-button[data-v-bfdbb556]:hover{border-color:var(--color-primary, #3b82f6);background:var(--color-background-soft, #f9fafb)}.filter-button.active[data-v-bfdbb556]{border-color:var(--color-primary, #3b82f6);background:var(--color-primary, #3b82f6);color:#fff}.filter-icon[data-v-bfdbb556]{font-size:1.125rem}.column-selector[data-v-bfdbb556]{display:flex;align-items:center;gap:.5rem;padding-left:1rem;border-left:1px solid var(--color-border, #e5e7eb)}.column-selector-label[data-v-bfdbb556]{font-size:.875rem;font-weight:500;color:var(--color-text-muted, #6b7280)}.column-button[data-v-bfdbb556]{display:flex;align-items:center;justify-content:center;min-width:2.5rem;padding:.5rem .75rem;background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:8px;font-size:.875rem;font-weight:600;color:var(--color-text, #374151);cursor:pointer;transition:all .2s}.column-button[data-v-bfdbb556]:hover{border-color:var(--color-primary, #3b82f6);color:var(--color-primary, #3b82f6);background:var(--color-primary-light, #dbeafe)}.column-button.active[data-v-bfdbb556]{background:var(--color-primary, #3b82f6);border-color:var(--color-primary, #3b82f6);color:#fff}.timeline-loading[data-v-bfdbb556],.timeline-error[data-v-bfdbb556],.timeline-empty[data-v-bfdbb556]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border-radius:12px;border:1px solid var(--color-border, #e5e7eb)}.spinner-medium[data-v-bfdbb556]{width:40px;height:40px;border:4px solid var(--color-border, #e5e7eb);border-top-color:var(--color-primary, #3b82f6);border-radius:50%;animation:spin-bfdbb556 .8s linear infinite;margin-bottom:1rem}.timeline-loading p[data-v-bfdbb556],.timeline-error p[data-v-bfdbb556],.timeline-empty p[data-v-bfdbb556]{margin:0;color:var(--color-text-muted, #6b7280)}.error-icon[data-v-bfdbb556],.empty-icon[data-v-bfdbb556]{font-size:3rem;margin-bottom:1rem}.timeline-error h3[data-v-bfdbb556],.timeline-empty h3[data-v-bfdbb556]{margin:0 0 .5rem;font-size:1.25rem;color:var(--color-heading, #1f2937)}.retry-button[data-v-bfdbb556]{margin-top:1rem;padding:.75rem 1.5rem;border:none;background:var(--color-primary, #3b82f6);color:#fff;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.retry-button[data-v-bfdbb556]:hover{background:var(--color-primary-dark, #2563eb)}.timeline-content[data-v-bfdbb556]{display:flex;flex-direction:column;gap:1.5rem}.timeline-list[data-v-bfdbb556]{display:grid;grid-template-columns:repeat(var(--columns, 1),1fr);gap:1rem}.timeline-item[data-v-bfdbb556]{display:flex;gap:1rem;padding:1rem;background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:12px;cursor:pointer;transition:all .2s}.timeline-item[data-v-bfdbb556]:hover{border-color:var(--color-primary, #3b82f6);box-shadow:0 4px 12px #3b82f626;transform:translateY(-2px)}.item-thumbnail[data-v-bfdbb556]{position:relative;width:120px;height:120px;flex-shrink:0;border-radius:8px;overflow:hidden;background:var(--color-background-soft, #f3f4f6)}.thumbnail-image[data-v-bfdbb556]{width:100%;height:100%;object-fit:cover}.image-loading-indicator[data-v-bfdbb556]{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f3f4f6e6;pointer-events:none;transition:opacity .3s ease}.loading-spinner[data-v-bfdbb556]{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin-bfdbb556 .8s linear infinite}@keyframes spin-bfdbb556{to{transform:rotate(360deg)}}.thumbnail-placeholder[data-v-bfdbb556]{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:3rem}.type-badge[data-v-bfdbb556]{position:absolute;top:.5rem;left:.5rem;display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:6px;font-size:.75rem;font-weight:500;color:#fff}.video-duration[data-v-bfdbb556]{position:absolute;bottom:.5rem;right:.5rem;display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:6px;font-size:.75rem;font-weight:500;color:#fff}.species-badge[data-v-bfdbb556]{position:absolute;bottom:.5rem;left:.5rem;display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;font-size:.75rem;font-weight:600;color:#fff;max-width:calc(100% - 1rem);border-left:3px solid;transition:all .2s}.species-badge[data-v-bfdbb556]:hover{background:#000000f2;transform:scale(1.05)}.species-badge-icon[data-v-bfdbb556]{font-size:1rem;line-height:1}.species-badge-content[data-v-bfdbb556]{display:flex;flex-direction:column;gap:.125rem;min-width:0}.species-badge-name[data-v-bfdbb556]{font-size:.75rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.species-badge-confidence[data-v-bfdbb556]{font-size:.625rem;font-weight:500;opacity:.9;line-height:1}.species-badge.confidence-high[data-v-bfdbb556]{border-left-color:#10b981;background:linear-gradient(135deg,#10b98133,#000000d9)}.species-badge.confidence-medium[data-v-bfdbb556]{border-left-color:#f59e0b;background:linear-gradient(135deg,#f59e0b33,#000000d9)}.species-badge.confidence-low[data-v-bfdbb556]{border-left-color:#ef4444;background:linear-gradient(135deg,#ef444433,#000000d9)}.item-info[data-v-bfdbb556]{flex:1;display:flex;flex-direction:column;gap:.75rem;min-width:0}.info-header[data-v-bfdbb556]{display:flex;justify-content:space-between;align-items:center;gap:1rem}.info-camera-name[data-v-bfdbb556]{margin:0;font-size:1rem;font-weight:600;color:var(--color-heading, #1f2937);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.info-timestamp[data-v-bfdbb556]{font-size:.875rem;color:var(--color-text-muted, #6b7280);white-space:nowrap}.info-details[data-v-bfdbb556]{display:flex;flex-wrap:wrap;gap:1rem}.info-detail[data-v-bfdbb556]{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--color-text, #374151)}.detail-icon[data-v-bfdbb556]{font-size:1rem}.info-species[data-v-bfdbb556]{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#10b9811a;border-radius:6px;font-size:.875rem}.species-icon[data-v-bfdbb556]{font-size:1.125rem}.species-name[data-v-bfdbb556]{font-weight:600;color:#059669}.species-confidence[data-v-bfdbb556]{margin-left:auto;font-size:.8rem;font-weight:500;color:#6b7280}.item-actions[data-v-bfdbb556]{display:flex;flex-direction:column;gap:.5rem}.action-button[data-v-bfdbb556]{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--color-border, #e5e7eb);background:#fff;border-radius:8px;font-size:1.25rem;cursor:pointer;transition:all .2s}.action-button[data-v-bfdbb556]:hover{border-color:var(--color-primary, #3b82f6);background:var(--color-background-soft, #f9fafb);transform:scale(1.1)}.action-button.delete[data-v-bfdbb556]:hover{border-color:#dc2626;background:#fef2f2}.action-button.identify[data-v-bfdbb556]:hover:not(:disabled){border-color:#059669;background:#f0fdf4}.action-button[data-v-bfdbb556]:disabled{opacity:.6;cursor:not-allowed;transform:none}.timeline-pagination[data-v-bfdbb556]{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border-radius:12px;border:1px solid var(--color-border, #e5e7eb)}.pagination-button[data-v-bfdbb556]{padding:.5rem 1rem;border:1px solid var(--color-border, #e5e7eb);background:#fff;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.pagination-button[data-v-bfdbb556]:hover:not(:disabled){border-color:var(--color-primary, #3b82f6);background:var(--color-background-soft, #f9fafb)}.pagination-button[data-v-bfdbb556]:disabled{opacity:.5;cursor:not-allowed}.pagination-info[data-v-bfdbb556]{font-size:.875rem;font-weight:500;color:var(--color-text, #374151)}@media (max-width: 767px){.header-controls[data-v-bfdbb556]{flex-direction:column;align-items:stretch;width:100%}.timeline-filters[data-v-bfdbb556]{width:100%}.filter-button[data-v-bfdbb556]{min-height:44px;justify-content:center}.info-timestamp[data-v-bfdbb556],.info-details[data-v-bfdbb556],.detail-text[data-v-bfdbb556]{font-size:14px}.column-selector[data-v-bfdbb556]{width:100%;border-left:none;padding-left:0;justify-content:space-between}.column-button[data-v-bfdbb556]{min-height:44px;min-width:44px}.timeline-list[data-v-bfdbb556]{grid-template-columns:repeat(2,1fr)}.action-button[data-v-bfdbb556]{width:44px;height:44px}}@media (min-width: 768px) and (max-width: 1023px){.timeline-list[data-v-bfdbb556]{grid-template-columns:repeat(3,1fr)}}@media (max-width: 640px){.timeline-header[data-v-bfdbb556]{flex-direction:column;align-items:flex-start}.timeline-filters[data-v-bfdbb556]{width:100%}.filter-button[data-v-bfdbb556]{flex:1;justify-content:center}.timeline-item[data-v-bfdbb556]{flex-direction:column}.item-thumbnail[data-v-bfdbb556]{width:100%;height:200px}.item-actions[data-v-bfdbb556]{flex-direction:row;justify-content:flex-end}}.livestream-modal-overlay[data-v-09f5ffa9]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;will-change:opacity;transform:translateZ(0)}.livestream-modal[data-v-09f5ffa9]{background-color:#1a1a1a;border-radius:12px;max-width:1400px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000080;touch-action:pan-y;will-change:transform,opacity;backface-visibility:hidden}.modal-header[data-v-09f5ffa9]{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #2a2a2a}.header-content[data-v-09f5ffa9]{display:flex;align-items:center;gap:1rem;flex:1}.modal-title[data-v-09f5ffa9]{font-size:1.5rem;font-weight:600;color:#fff;margin:0}.connection-status[data-v-09f5ffa9]{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:6px;font-size:.875rem;font-weight:500}.status-connecting[data-v-09f5ffa9]{background-color:#fbbf241a;color:#fbbf24}.status-connected[data-v-09f5ffa9]{background-color:#10b9811a;color:#10b981}.status-error[data-v-09f5ffa9]{background-color:#ef44441a;color:#ef4444}.status-dot[data-v-09f5ffa9]{width:8px;height:8px;border-radius:50%;background-color:currentColor;animation:pulse-09f5ffa9 2s ease-in-out infinite}@keyframes pulse-09f5ffa9{0%,to{opacity:1}50%{opacity:.5}}.status-text[data-v-09f5ffa9]{font-size:.875rem}.close-button[data-v-09f5ffa9]{width:2.5rem;height:2.5rem;border-radius:6px;border:none;background-color:#ffffff1a;color:#fff;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.close-button[data-v-09f5ffa9]:hover{background-color:#fff3}.close-icon[data-v-09f5ffa9]{font-size:1.5rem;line-height:1}.video-container[data-v-09f5ffa9]{flex:1;position:relative;background-color:#000;display:flex;align-items:center;justify-content:center;min-height:400px;width:100%;max-width:100%}.video-stream[data-v-09f5ffa9]{width:100%;height:100%;object-fit:contain}.video-stream.hidden[data-v-09f5ffa9]{display:none}.loading-state[data-v-09f5ffa9]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#fff}.spinner[data-v-09f5ffa9]{width:3rem;height:3rem;border:3px solid rgba(255,255,255,.1);border-top-color:#3b82f6;border-radius:50%;animation:spin-09f5ffa9 1s linear infinite}@keyframes spin-09f5ffa9{to{transform:rotate(360deg)}}.loading-text[data-v-09f5ffa9]{font-size:1.125rem;font-weight:500;margin:0}.loading-subtext[data-v-09f5ffa9]{font-size:.875rem;color:#9ca3af;margin:0}.error-state[data-v-09f5ffa9]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;text-align:center}.error-icon[data-v-09f5ffa9]{font-size:3rem}.error-text[data-v-09f5ffa9]{font-size:1rem;color:#ef4444;max-width:500px;margin:0}.retry-button[data-v-09f5ffa9]{margin-top:.5rem;padding:.625rem 1.25rem;border-radius:6px;border:none;background-color:#3b82f6;color:#fff;font-weight:500;cursor:pointer;transition:background-color .2s}.retry-button[data-v-09f5ffa9]:hover{background-color:#2563eb}.stream-info[data-v-09f5ffa9]{position:absolute;top:1rem;left:1rem;display:flex;gap:.75rem;pointer-events:none}.info-item[data-v-09f5ffa9]{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:6px;background-color:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:.875rem;font-weight:500}.info-icon[data-v-09f5ffa9]{font-size:1rem}.info-text[data-v-09f5ffa9]{font-size:.875rem}.modal-footer[data-v-09f5ffa9]{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-top:1px solid #2a2a2a;gap:1rem}.footer-controls[data-v-09f5ffa9]{display:flex;gap:.75rem}.led-toggle-button[data-v-09f5ffa9]{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border:2px solid rgba(255,255,255,.3);border-radius:8px;background:#0000004d;color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.led-toggle-button[data-v-09f5ffa9]:hover:not(:disabled){background:#00000080;border-color:#ffffff80}.led-toggle-button.active[data-v-09f5ffa9]{background:#fbbf244d;border-color:#fbbf24cc;color:#fbbf24}.led-toggle-button.active[data-v-09f5ffa9]:hover:not(:disabled){background:#fbbf2466;border-color:#fbbf24}.led-toggle-button[data-v-09f5ffa9]:disabled{opacity:.5;cursor:not-allowed}.led-toggle-button .button-icon[data-v-09f5ffa9]{font-size:1.125rem}.led-toggle-button .button-text[data-v-09f5ffa9]{font-weight:500}.wake-button[data-v-09f5ffa9]{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border:2px solid rgba(59,130,246,.6);border-radius:8px;background:#3b82f633;color:#bfdbfe;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.wake-button[data-v-09f5ffa9]:hover:not(:disabled){background:#3b82f64d;border-color:#3b82f6e6}.wake-button[data-v-09f5ffa9]:disabled{opacity:.6;cursor:not-allowed}.wake-error[data-v-09f5ffa9]{margin-top:.5rem;color:#fca5a5;font-size:.8rem}.footer-info[data-v-09f5ffa9]{flex:1}.footer-info .info-text[data-v-09f5ffa9]{font-size:.875rem;color:#9ca3af;margin:0;display:flex;align-items:center;gap:.5rem}.footer-info .info-icon[data-v-09f5ffa9]{font-size:1rem}kbd[data-v-09f5ffa9]{padding:.125rem .375rem;border-radius:4px;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);font-family:monospace;font-size:.75rem}.close-stream-button[data-v-09f5ffa9]{padding:.625rem 1.25rem;border-radius:6px;border:none;background-color:#ef4444;color:#fff;font-weight:500;cursor:pointer;transition:background-color .2s}.close-stream-button[data-v-09f5ffa9]:hover{background-color:#dc2626}@media (max-width: 768px){.livestream-modal-overlay[data-v-09f5ffa9]{padding:0}.livestream-modal[data-v-09f5ffa9]{width:100vw;height:100vh;max-height:100vh;border-radius:0}.close-button[data-v-09f5ffa9]{width:44px;height:44px}.video-container[data-v-09f5ffa9]{min-height:0}.modal-footer[data-v-09f5ffa9]{margin-top:auto;padding:1rem}.modal-title[data-v-09f5ffa9]{font-size:1.125rem}.header-content[data-v-09f5ffa9]{flex-direction:column;align-items:flex-start;gap:.5rem}.modal-footer[data-v-09f5ffa9]{flex-direction:column;gap:1rem}.footer-controls[data-v-09f5ffa9]{width:100%;justify-content:center}.footer-info[data-v-09f5ffa9],.close-stream-button[data-v-09f5ffa9]{width:100%}.led-toggle-button[data-v-09f5ffa9],.wake-button[data-v-09f5ffa9],.close-stream-button[data-v-09f5ffa9]{min-height:44px}}.camera-detail-view[data-v-d4fb7085]{min-height:100vh;padding:2rem;background:var(--color-background, #f9fafb)}.loading-container[data-v-d4fb7085],.error-container[data-v-d4fb7085]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.spinner-large[data-v-d4fb7085]{width:60px;height:60px;border:6px solid var(--color-border, #e5e7eb);border-top-color:var(--color-primary, #3b82f6);border-radius:50%;animation:spin-d4fb7085 .8s linear infinite;margin-bottom:1rem}@keyframes spin-d4fb7085{to{transform:rotate(360deg)}}.error-icon[data-v-d4fb7085]{font-size:4rem;margin-bottom:1rem}.error-container h2[data-v-d4fb7085]{margin:0 0 .5rem;color:var(--color-heading, #1f2937)}.error-container p[data-v-d4fb7085]{margin:0 0 1.5rem;color:var(--color-text-muted, #6b7280)}.detail-header[data-v-d4fb7085]{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.header-info[data-v-d4fb7085]{display:flex;align-items:center;gap:1rem}.camera-name[data-v-d4fb7085]{margin:0;font-size:2rem;font-weight:700;color:var(--color-heading, #1f2937)}.status-badge[data-v-d4fb7085]{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;text-transform:capitalize}.status-badge.online[data-v-d4fb7085]{background:#10b9811a;color:#059669}.status-badge.offline[data-v-d4fb7085]{background:#ef44441a;color:#dc2626}.status-indicator[data-v-d4fb7085]{width:8px;height:8px;border-radius:50%;background:currentColor}.header-actions[data-v-d4fb7085]{display:flex;gap:1rem;flex-wrap:wrap}.back-button[data-v-d4fb7085],.retry-button[data-v-d4fb7085],.action-button[data-v-d4fb7085]{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:1px solid var(--color-border, #e5e7eb);background:#fff;border-radius:8px;font-size:.875rem;font-weight:500;color:var(--color-text, #374151);cursor:pointer;transition:all .2s}.action-button.primary[data-v-d4fb7085]{border-color:var(--color-primary, #3b82f6);background:var(--color-primary, #3b82f6);color:#fff}.back-button[data-v-d4fb7085]:hover,.retry-button[data-v-d4fb7085]:hover,.action-button[data-v-d4fb7085]:hover{border-color:var(--color-primary, #3b82f6);background:var(--color-background-soft, #f9fafb);transform:translateY(-2px)}.action-button.primary[data-v-d4fb7085]:hover{background:var(--color-primary-dark, #2563eb)}.button-icon[data-v-d4fb7085]{font-size:1.125rem}.info-card[data-v-d4fb7085]{padding:2rem;background:#fff;border-radius:12px;border:1px solid var(--color-border, #e5e7eb);margin-bottom:2rem}.section-title[data-v-d4fb7085]{margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:var(--color-heading, #1f2937)}.info-grid[data-v-d4fb7085]{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.info-item[data-v-d4fb7085]{display:flex;flex-direction:column;gap:.5rem}.info-label[data-v-d4fb7085]{font-size:.875rem;font-weight:500;color:var(--color-text-muted, #6b7280)}.info-value[data-v-d4fb7085]{font-size:1rem;font-weight:600;color:var(--color-text, #374151)}.motion-status[data-v-d4fb7085]{display:flex;flex-direction:column;gap:1rem}.motion-indicator[data-v-d4fb7085]{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#10b9811a;border-radius:8px;width:fit-content}.indicator-icon[data-v-d4fb7085]{font-size:1.5rem}.indicator-text[data-v-d4fb7085]{font-size:1rem;font-weight:600;color:#059669}.motion-details[data-v-d4fb7085]{display:flex;gap:2rem;flex-wrap:wrap}.detail-item[data-v-d4fb7085]{font-size:.875rem;color:var(--color-text, #374151)}.media-section[data-v-d4fb7085]{padding:2rem;background:#fff;border-radius:12px;border:1px solid var(--color-border, #e5e7eb)}.section-header[data-v-d4fb7085]{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.view-all-link[data-v-d4fb7085]{font-size:.875rem;font-weight:500;color:var(--color-primary, #3b82f6);text-decoration:none;transition:color .2s}.view-all-link[data-v-d4fb7085]:hover{color:var(--color-primary-dark, #2563eb)}@media (max-width: 768px){.camera-detail-view[data-v-d4fb7085]{padding:1rem}.camera-name[data-v-d4fb7085]{font-size:1.5rem}.header-info[data-v-d4fb7085]{flex-direction:column;align-items:flex-start}.info-grid[data-v-d4fb7085]{grid-template-columns:1fr}.motion-details[data-v-d4fb7085]{flex-direction:column;gap:.5rem}}.capture-controls[data-v-d4fb7085]{margin-top:1.5rem}.capture-controls .section-title[data-v-d4fb7085]{margin-bottom:1.5rem}.control-buttons[data-v-d4fb7085]{display:flex;gap:1rem;flex-wrap:wrap}.control-button[data-v-d4fb7085]{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0000001a}.control-button[data-v-d4fb7085]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.control-button[data-v-d4fb7085]:disabled{opacity:.5;cursor:not-allowed;transform:none}.capture-button[data-v-d4fb7085]{background:linear-gradient(135deg,#667eea,#764ba2)}.capture-button[data-v-d4fb7085]:hover:not(:disabled){box-shadow:0 4px 16px #667eea66}.record-button[data-v-d4fb7085]{background:linear-gradient(135deg,#f093fb,#f5576c)}.record-button[data-v-d4fb7085]:hover:not(:disabled){box-shadow:0 4px 16px #f5576c66}.livestream-button[data-v-d4fb7085]{background:linear-gradient(135deg,#4facfe,#00f2fe)}.livestream-button[data-v-d4fb7085]:hover:not(:disabled){box-shadow:0 4px 16px #4facfe66}.button-icon[data-v-d4fb7085]{font-size:1.25rem}.button-text[data-v-d4fb7085]{font-size:1rem}.guest-notice[data-v-d4fb7085]{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#dbeafe,#e0e7ff);border:2px solid #bfdbfe;border-radius:10px}.notice-icon[data-v-d4fb7085]{font-size:2rem}.notice-content h3[data-v-d4fb7085]{margin:0 0 .25rem;color:#1e40af;font-size:1.1rem}.notice-content p[data-v-d4fb7085]{margin:0;color:#3b82f6;font-size:.9rem}.offline-warning[data-v-d4fb7085]{display:flex;align-items:center;gap:.75rem;padding:1rem;margin-top:1rem;background:#fbbf241a;border:2px solid rgba(251,191,36,.3);border-radius:8px;color:#b45309;font-size:.9rem;font-weight:500}.warning-icon[data-v-d4fb7085]{font-size:1.25rem}.modal-overlay[data-v-d4fb7085]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn-d4fb7085 .2s ease-out}@keyframes fadeIn-d4fb7085{0%{opacity:0}to{opacity:1}}.modal-content[data-v-d4fb7085]{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 8px 32px #0003;min-width:350px;animation:slideUp-d4fb7085 .3s ease-out}@keyframes slideUp-d4fb7085{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-title[data-v-d4fb7085]{margin:0 0 .5rem;color:#1f2937;font-size:1.5rem}.modal-description[data-v-d4fb7085]{margin:0 0 1.5rem;color:#6b7280;font-size:.9rem}.form-group[data-v-d4fb7085]{margin-bottom:1.5rem}.form-label[data-v-d4fb7085]{display:block;margin-bottom:.5rem;color:#374151;font-weight:500;font-size:.95rem}.form-input[data-v-d4fb7085]{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s}.form-input[data-v-d4fb7085]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-hint[data-v-d4fb7085]{display:block;margin-top:.5rem;color:#6b7280;font-size:.85rem}.modal-actions[data-v-d4fb7085]{display:flex;gap:1rem;margin-top:1.5rem}.modal-button[data-v-d4fb7085]{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.modal-button.primary[data-v-d4fb7085]{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.modal-button.primary[data-v-d4fb7085]:hover{transform:translateY(-2px);box-shadow:0 4px 16px #f5576c66}.modal-button.secondary[data-v-d4fb7085]{background:#f3f4f6;color:#374151}.modal-button.secondary[data-v-d4fb7085]:hover{background:#e5e7eb}.control-button[data-v-d4fb7085]:active:not(:disabled){transform:scale(.98);box-shadow:0 1px 4px #0003}@media (max-width: 767px){.control-buttons[data-v-d4fb7085]{flex-direction:column}.control-button[data-v-d4fb7085]{width:100%;justify-content:center;min-height:44px;padding:.75rem 1.5rem}.control-buttons[data-v-d4fb7085]{gap:12px}.modal-content[data-v-d4fb7085]{margin:1rem;min-width:auto}}.camera-settings-view[data-v-b9c3697f]{max-width:1600px;margin:0 auto;padding:2rem}.settings-header[data-v-b9c3697f]{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--color-border, #e5e7eb)}.header-content[data-v-b9c3697f]{display:flex;align-items:center;gap:1rem}.back-button[data-v-b9c3697f]{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:var(--color-background-soft, #f3f4f6);border-radius:8px;cursor:pointer;font-size:1.5rem;transition:all .2s}.back-button[data-v-b9c3697f]:hover{background:var(--color-background-mute, #e5e7eb);transform:translate(-2px)}.back-icon[data-v-b9c3697f]{display:block}.header-text[data-v-b9c3697f]{display:flex;flex-direction:column;gap:.25rem}.page-title[data-v-b9c3697f]{margin:0;font-size:1.75rem;font-weight:700;color:var(--color-heading, #1f2937)}.page-subtitle[data-v-b9c3697f]{margin:0;font-size:.95rem;color:var(--color-text-muted, #6b7280)}.camera-status[data-v-b9c3697f]{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500}.camera-status.online[data-v-b9c3697f]{background:#10b9811a;color:#059669}.camera-status.offline[data-v-b9c3697f]{background:#ef44441a;color:#dc2626}.status-dot[data-v-b9c3697f]{display:block;width:8px;height:8px;border-radius:50%}.online .status-dot[data-v-b9c3697f]{background:#059669;box-shadow:0 0 0 2px #10b9814d;animation:pulse-b9c3697f 2s infinite}.offline .status-dot[data-v-b9c3697f]{background:#dc2626}@keyframes pulse-b9c3697f{0%,to{opacity:1}50%{opacity:.6}}.loading-container[data-v-b9c3697f]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--color-text-muted, #6b7280)}.spinner-large[data-v-b9c3697f]{width:48px;height:48px;border:4px solid var(--color-border, #e5e7eb);border-top-color:var(--color-primary, #3b82f6);border-radius:50%;animation:spin-b9c3697f .8s linear infinite}@keyframes spin-b9c3697f{to{transform:rotate(360deg)}}.error-container[data-v-b9c3697f]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;text-align:center}.error-icon[data-v-b9c3697f]{font-size:3rem}.error-container h2[data-v-b9c3697f]{margin:0;font-size:1.5rem;color:var(--color-heading, #1f2937)}.error-container p[data-v-b9c3697f]{margin:0;color:var(--color-text-muted, #6b7280)}.retry-button[data-v-b9c3697f]{margin-top:1rem;padding:.75rem 1.5rem;border:none;background:var(--color-primary, #3b82f6);color:#fff;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.retry-button[data-v-b9c3697f]:hover{background:var(--color-primary-dark, #2563eb)}.settings-content[data-v-b9c3697f]{display:grid;grid-template-columns:1fr;gap:2rem}@media (min-width: 1024px){.settings-content[data-v-b9c3697f]{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1600px){.settings-content[data-v-b9c3697f]{grid-template-columns:repeat(2,1fr)}}.settings-section[data-v-b9c3697f]{background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000000d}.section-header[data-v-b9c3697f]{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border, #e5e7eb)}.section-title[data-v-b9c3697f]{display:flex;align-items:center;gap:.75rem;margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--color-heading, #1f2937)}.section-icon[data-v-b9c3697f]{font-size:1.75rem}.section-description[data-v-b9c3697f]{margin:0;font-size:.95rem;color:var(--color-text-muted, #6b7280)}.admin-badge[data-v-b9c3697f]{display:inline-block;margin-top:.5rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#7c3aed;background:#ede9fe;border-radius:12px;letter-spacing:.05em}.settings-form[data-v-b9c3697f]{display:flex;flex-direction:column;gap:1.5rem}.form-group[data-v-b9c3697f]{display:flex;flex-direction:column;gap:.5rem}.form-label[data-v-b9c3697f]{display:flex;flex-direction:column;gap:.25rem}.label-text[data-v-b9c3697f]{font-size:.95rem;font-weight:500;color:var(--color-heading, #1f2937)}.label-description[data-v-b9c3697f]{font-size:.85rem;color:var(--color-text-muted, #6b7280)}.toggle-group[data-v-b9c3697f]{flex-direction:row;justify-content:space-between;align-items:center;padding:1rem;background:var(--color-background-soft, #f9fafb);border-radius:8px}.toggle-switch[data-v-b9c3697f]{position:relative;display:inline-block;width:56px;height:32px;flex-shrink:0}.toggle-input[data-v-b9c3697f]{opacity:0;width:0;height:0}.toggle-slider[data-v-b9c3697f]{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e1;transition:.3s;border-radius:32px}.toggle-slider[data-v-b9c3697f]:before{position:absolute;content:"";height:24px;width:24px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0000001a}.toggle-input:checked+.toggle-slider[data-v-b9c3697f]{background-color:#3b82f6}.toggle-input:checked+.toggle-slider[data-v-b9c3697f]:before{transform:translate(24px)}.toggle-input:disabled+.toggle-slider[data-v-b9c3697f]{opacity:.5;cursor:not-allowed}.form-select[data-v-b9c3697f],.form-input[data-v-b9c3697f]{padding:.75rem 1rem;border:1px solid var(--color-border, #e5e7eb);border-radius:8px;font-size:.95rem;background:#fff;transition:all .2s}.form-select[data-v-b9c3697f]:focus,.form-input[data-v-b9c3697f]:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.form-select[data-v-b9c3697f]:disabled,.form-input[data-v-b9c3697f]:disabled{background:var(--color-background-soft, #f3f4f6);cursor:not-allowed;opacity:.6}.input-with-unit[data-v-b9c3697f]{display:flex;align-items:center;gap:.5rem}.input-with-unit .form-input[data-v-b9c3697f]{flex:1}.input-unit[data-v-b9c3697f]{font-size:.9rem;color:var(--color-text-muted, #6b7280);font-weight:500;white-space:nowrap}.input-hint[data-v-b9c3697f]{display:flex;justify-content:space-between;font-size:.85rem;color:var(--color-text-muted, #6b7280)}.hint-text[data-v-b9c3697f]{font-weight:500}.hint-range[data-v-b9c3697f]{font-style:italic}.form-info[data-v-b9c3697f]{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;font-size:.9rem;color:#1e40af}.info-icon[data-v-b9c3697f]{font-size:1.25rem;flex-shrink:0}.info-text[data-v-b9c3697f]{line-height:1.5}.checkbox-group[data-v-b9c3697f]{padding:.75rem;background:var(--color-background-soft, #f9fafb);border-radius:8px}.checkbox-grid[data-v-b9c3697f]{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem}.checkbox-label[data-v-b9c3697f]{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.95rem}.checkbox-input[data-v-b9c3697f]{width:20px;height:20px;cursor:pointer;accent-color:var(--color-primary, #3b82f6)}.checkbox-input[data-v-b9c3697f]:disabled{cursor:not-allowed;opacity:.5}.checkbox-text[data-v-b9c3697f]{display:flex;flex-direction:column;gap:.25rem}.checkbox-hint[data-v-b9c3697f]{font-size:.8rem;color:var(--color-text-muted, #6b7280);font-weight:400}.action-buttons[data-v-b9c3697f]{display:flex;gap:1rem;padding-top:1rem}.save-button[data-v-b9c3697f],.reset-button[data-v-b9c3697f]{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 2rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.save-button[data-v-b9c3697f]{flex:1;background:var(--color-primary, #3b82f6);color:#fff}.save-button[data-v-b9c3697f]:hover:not(:disabled){background:var(--color-primary-dark, #2563eb);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.save-button[data-v-b9c3697f]:disabled{opacity:.5;cursor:not-allowed}.reset-button[data-v-b9c3697f]{background:var(--color-background-soft, #f3f4f6);color:var(--color-text, #374151)}.reset-button[data-v-b9c3697f]:hover:not(:disabled){background:var(--color-background-mute, #e5e7eb)}.reset-button[data-v-b9c3697f]:disabled{opacity:.5;cursor:not-allowed}.spinner-small[data-v-b9c3697f]{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-b9c3697f .6s linear infinite}.section-action-buttons[data-v-b9c3697f]{display:flex;gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border, #e5e7eb)}.save-button-small[data-v-b9c3697f]{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.5rem;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;background:var(--color-primary, #3b82f6);color:#fff}.save-button-small[data-v-b9c3697f]:hover:not(:disabled){background:var(--color-primary-dark, #2563eb);transform:translateY(-1px);box-shadow:0 3px 10px #3b82f64d}.save-button-small[data-v-b9c3697f]:disabled{opacity:.5;cursor:not-allowed}.success-message-small[data-v-b9c3697f],.error-message-small[data-v-b9c3697f]{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500}.success-message-small[data-v-b9c3697f]{background:#10b9811a;color:#059669;border:1px solid rgba(16,185,129,.2)}.error-message-small[data-v-b9c3697f]{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.success-message[data-v-b9c3697f],.error-message[data-v-b9c3697f]{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:8px;font-size:.95rem;font-weight:500;animation:slideIn-b9c3697f .3s ease-out}@keyframes slideIn-b9c3697f{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.success-message[data-v-b9c3697f]{background:#10b9811a;color:#059669;border:1px solid rgba(16,185,129,.3)}.success-icon[data-v-b9c3697f]{font-size:1.25rem}.error-message[data-v-b9c3697f]{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.error-icon[data-v-b9c3697f]{font-size:1.25rem}.slider-container[data-v-b9c3697f]{display:flex;align-items:center;gap:1rem;margin-top:.5rem}.slider-input[data-v-b9c3697f]{flex:1;height:8px;border-radius:4px;background:var(--color-border, #e5e7eb);outline:none;-webkit-appearance:none}.slider-input[data-v-b9c3697f]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-primary, #3b82f6);cursor:pointer;transition:background .2s}.slider-input[data-v-b9c3697f]::-webkit-slider-thumb:hover{background:var(--color-primary-dark, #2563eb)}.slider-input[data-v-b9c3697f]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-primary, #3b82f6);cursor:pointer;border:none;transition:background .2s}.slider-input[data-v-b9c3697f]::-moz-range-thumb:hover{background:var(--color-primary-dark, #2563eb)}.slider-value[data-v-b9c3697f]{min-width:50px;font-size:1rem;font-weight:600;color:var(--color-text, #374151);text-align:right}.slider-buttons[data-v-b9c3697f]{margin-top:1rem}.slider-button[data-v-b9c3697f]{padding:.625rem 1.25rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.slider-button.primary[data-v-b9c3697f]{background:var(--color-primary, #3b82f6);color:#fff}.slider-button.primary[data-v-b9c3697f]:hover:not(:disabled){background:var(--color-primary-dark, #2563eb)}.slider-button[data-v-b9c3697f]:disabled{opacity:.5;cursor:not-allowed}.form-buttons[data-v-b9c3697f]{margin-top:1rem}.form-button[data-v-b9c3697f]{padding:.625rem 1.25rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.form-button.primary[data-v-b9c3697f]{background:var(--color-primary, #3b82f6);color:#fff}.form-button.primary[data-v-b9c3697f]:hover:not(:disabled){background:var(--color-primary-dark, #2563eb)}.form-button[data-v-b9c3697f]:disabled{opacity:.5;cursor:not-allowed}.led-message[data-v-b9c3697f]{display:flex;align-items:center;gap:.75rem;margin-top:1rem;padding:1rem;border-radius:8px;font-size:.9rem}.led-message.success[data-v-b9c3697f]{background:#10b9811a;color:#059669;border:1px solid rgba(16,185,129,.3)}.led-message.error[data-v-b9c3697f]{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.message-icon[data-v-b9c3697f]{font-size:1.25rem}.message-text[data-v-b9c3697f]{flex:1}.info-grid[data-v-b9c3697f]{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-top:1rem}.info-item[data-v-b9c3697f]{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:#3b82f60d;border-radius:8px;border:1px solid rgba(59,130,246,.1)}.info-label[data-v-b9c3697f]{font-size:.85rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.025em}.info-value[data-v-b9c3697f]{font-size:1rem;font-weight:600;color:#374151;font-family:Monaco,Courier New,monospace}.subsection-header[data-v-b9c3697f]{margin-top:2rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid rgba(59,130,246,.2)}.subsection-title[data-v-b9c3697f]{font-size:1.1rem;font-weight:600;color:#374151}.time-window-inputs[data-v-b9c3697f]{display:flex;align-items:center;gap:1rem;margin-top:.5rem}.time-input-group[data-v-b9c3697f]{display:flex;flex-direction:column;gap:.25rem}.time-label[data-v-b9c3697f]{font-size:.85rem;font-weight:500;color:#6b7280}.form-input-small[data-v-b9c3697f]{width:80px;padding:.625rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:all .2s}.form-input-small[data-v-b9c3697f]:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.time-separator[data-v-b9c3697f]{font-size:1.25rem;font-weight:600;color:#6b7280;margin-top:1.5rem}@media (max-width: 640px){.camera-settings-view[data-v-b9c3697f]{padding:1rem}.settings-header[data-v-b9c3697f]{flex-direction:column;align-items:flex-start;gap:1rem}.page-title[data-v-b9c3697f]{font-size:1.5rem}.settings-section[data-v-b9c3697f]{padding:1.5rem}.action-buttons[data-v-b9c3697f]{flex-direction:column}.toggle-group[data-v-b9c3697f]{flex-direction:column;align-items:flex-start;gap:1rem}}.location-search-wrapper[data-v-b9c3697f]{position:relative}.location-input-row[data-v-b9c3697f]{display:flex;gap:.5rem;align-items:center}.locate-me-btn[data-v-b9c3697f]{flex-shrink:0;width:2.5rem;height:2.5rem;border:1px solid var(--border-color, #3a3f4b);border-radius:8px;background:var(--bg-secondary, #2a2d3a);color:var(--text-primary, #e2e8f0);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.locate-me-btn[data-v-b9c3697f]:hover:not(:disabled){background:var(--bg-hover, #353849)}.locate-me-btn[data-v-b9c3697f]:disabled{opacity:.5;cursor:not-allowed}.location-dropdown[data-v-b9c3697f]{position:absolute;left:0;right:2.5rem;top:calc(100% + 2px);background:var(--bg-secondary, #2a2d3a);border:1px solid var(--border-color, #3a3f4b);border-radius:8px;list-style:none;margin:0;padding:.25rem 0;z-index:10;max-height:200px;overflow-y:auto;box-shadow:0 4px 12px #0000004d}.location-dropdown-item[data-v-b9c3697f]{padding:.5rem .75rem;font-size:.85rem;color:var(--text-primary, #e2e8f0);cursor:pointer;line-height:1.3}.location-dropdown-item[data-v-b9c3697f]:hover{background:var(--bg-hover, #353849)}.location-searching[data-v-b9c3697f]{font-size:.8rem;color:var(--text-secondary, #94a3b8);margin-top:.25rem}.latlon-display[data-v-b9c3697f]{display:flex;align-items:center;gap:.25rem;margin-top:.5rem;font-size:.82rem;color:var(--text-secondary, #94a3b8);font-family:monospace}.latlon-sep[data-v-b9c3697f]{color:var(--border-color, #3a3f4b)}.latlon-clear[data-v-b9c3697f]{margin-left:.5rem;background:none;border:none;color:var(--text-secondary, #94a3b8);cursor:pointer;font-size:.9rem;padding:0 .2rem}.latlon-clear[data-v-b9c3697f]:hover{color:var(--danger-color, #ef4444)}.osm-attribution[data-v-b9c3697f]{margin-top:.4rem;font-size:.72rem;color:var(--text-tertiary, #64748b)}.osm-attribution a[data-v-b9c3697f]{color:var(--text-secondary, #94a3b8);text-decoration:underline}.form-warning[data-v-b9c3697f]{background:#eab3081a;border-color:#eab3084d;color:#eab308}.timelapse-player[data-v-f70e09da]{display:flex;flex-direction:column;gap:1.5rem;background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000000d}.player-header[data-v-f70e09da]{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--color-border, #e5e7eb)}.player-title[data-v-f70e09da]{display:flex;align-items:center;gap:.75rem;margin:0;font-size:1.5rem;font-weight:600;color:var(--color-heading, #1f2937)}.player-icon[data-v-f70e09da]{font-size:1.75rem}.player-info[data-v-f70e09da]{display:flex;align-items:center;gap:1rem}.image-count[data-v-f70e09da]{font-size:.9rem;color:var(--color-text-muted, #6b7280);font-weight:500;padding:.25rem .75rem;background:var(--color-background-soft, #f9fafb);border-radius:6px}.image-container[data-v-f70e09da]{position:relative;width:100%;aspect-ratio:16 / 9;background:#000;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center}.loading-state[data-v-f70e09da],.error-state[data-v-f70e09da],.empty-state[data-v-f70e09da]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#fff;text-align:center;padding:2rem}.spinner[data-v-f70e09da]{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-f70e09da .8s linear infinite}@keyframes spin-f70e09da{to{transform:rotate(360deg)}}.error-icon[data-v-f70e09da],.empty-icon[data-v-f70e09da]{font-size:3rem}.empty-hint[data-v-f70e09da]{font-size:.85rem;opacity:.7}.retry-button[data-v-f70e09da]{margin-top:.5rem;padding:.5rem 1rem;border:1px solid rgba(255,255,255,.3);background:#ffffff1a;color:#fff;border-radius:6px;cursor:pointer;transition:all .2s}.retry-button[data-v-f70e09da]:hover{background:#fff3}.image-display[data-v-f70e09da]{position:relative;width:100%;height:100%}.timelapse-image[data-v-f70e09da]{width:100%;height:100%;object-fit:contain}.image-overlay[data-v-f70e09da]{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;padding:1rem;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);color:#fff;font-size:.9rem}.frame-counter[data-v-f70e09da],.image-timestamp[data-v-f70e09da]{text-shadow:0 1px 2px rgba(0,0,0,.5)}.player-controls[data-v-f70e09da]{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.control-group[data-v-f70e09da]{display:flex;align-items:center;gap:.5rem}.primary-controls[data-v-f70e09da]{flex:1;min-width:200px}.control-button[data-v-f70e09da]{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border:1px solid var(--color-border, #e5e7eb);background:#fff;border-radius:8px;cursor:pointer;transition:all .2s;font-size:1.25rem}.control-button[data-v-f70e09da]:hover:not(:disabled){background:var(--color-background-soft, #f9fafb);border-color:var(--color-primary, #3b82f6)}.control-button[data-v-f70e09da]:disabled{opacity:.5;cursor:not-allowed}.play-button[data-v-f70e09da]{background:var(--color-primary, #3b82f6);color:#fff;border-color:var(--color-primary, #3b82f6)}.play-button[data-v-f70e09da]:hover:not(:disabled){background:var(--color-primary-dark, #2563eb)}.play-button.playing[data-v-f70e09da]{background:#dc2626;border-color:#dc2626}.control-icon[data-v-f70e09da]{display:block}.frame-rate-control[data-v-f70e09da]{background:var(--color-background-soft, #f9fafb);padding:.5rem 1rem;border-radius:8px}.control-label[data-v-f70e09da]{font-size:.9rem;font-weight:500;color:var(--color-text, #374151);white-space:nowrap}.frame-rate-select[data-v-f70e09da]{padding:.5rem .75rem;border:1px solid var(--color-border, #e5e7eb);border-radius:6px;font-size:.9rem;background:#fff;cursor:pointer}.frame-rate-select[data-v-f70e09da]:disabled{opacity:.5;cursor:not-allowed}.progress-container[data-v-f70e09da]{display:flex;flex-direction:column;gap:.5rem}.progress-bar[data-v-f70e09da]{width:100%;height:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-background-mute, #e5e7eb);border-radius:4px;outline:none;cursor:pointer}.progress-bar[data-v-f70e09da]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:var(--color-primary, #3b82f6);border-radius:50%;cursor:pointer;transition:all .2s}.progress-bar[data-v-f70e09da]::-webkit-slider-thumb:hover{transform:scale(1.2)}.progress-bar[data-v-f70e09da]::-moz-range-thumb{width:16px;height:16px;background:var(--color-primary, #3b82f6);border:none;border-radius:50%;cursor:pointer;transition:all .2s}.progress-bar[data-v-f70e09da]::-moz-range-thumb:hover{transform:scale(1.2)}.progress-bar[data-v-f70e09da]:disabled{opacity:.5;cursor:not-allowed}.progress-labels[data-v-f70e09da]{display:flex;justify-content:space-between;font-size:.8rem;color:var(--color-text-muted, #6b7280)}@media (max-width: 767px){.timelapse-player[data-v-f70e09da]{padding:1rem;gap:1rem}.player-header[data-v-f70e09da]{flex-direction:column;align-items:flex-start;gap:.75rem}.player-title[data-v-f70e09da]{font-size:1.25rem}.image-container[data-v-f70e09da]{width:100%;aspect-ratio:16 / 9}.timelapse-image[data-v-f70e09da]{max-width:100%;width:100%;height:100%;object-fit:contain}.image-overlay[data-v-f70e09da]{font-size:.8rem;padding:.75rem}.player-controls[data-v-f70e09da]{flex-direction:column;gap:1rem}.primary-controls[data-v-f70e09da]{width:100%;justify-content:center}.control-button[data-v-f70e09da]{width:44px;height:44px;min-width:44px;min-height:44px}.frame-rate-control[data-v-f70e09da]{width:100%;justify-content:space-between;display:flex;padding:.75rem 1rem}.control-label[data-v-f70e09da]{font-size:1rem}.frame-rate-select[data-v-f70e09da]{min-height:44px;padding:.75rem 1rem;font-size:1rem;flex:1;margin-left:1rem}.progress-bar[data-v-f70e09da]{height:12px}.progress-bar[data-v-f70e09da]::-webkit-slider-thumb{width:20px;height:20px}.progress-bar[data-v-f70e09da]::-moz-range-thumb{width:20px;height:20px}.progress-labels[data-v-f70e09da]{font-size:.875rem}}.timelapse-view[data-v-89d42244]{max-width:1400px;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:2rem}.view-header[data-v-89d42244]{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:2px solid var(--color-border, #e5e7eb)}.header-content[data-v-89d42244]{display:flex;align-items:center;gap:1rem}.back-button[data-v-89d42244]{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:var(--color-background-soft, #f3f4f6);border-radius:8px;cursor:pointer;font-size:1.5rem;transition:all .2s}.back-button[data-v-89d42244]:hover{background:var(--color-background-mute, #e5e7eb);transform:translate(-2px)}.back-icon[data-v-89d42244]{display:block}.header-text[data-v-89d42244]{display:flex;flex-direction:column;gap:.25rem}.page-title[data-v-89d42244]{margin:0;font-size:2rem;font-weight:700;color:var(--color-heading, #1f2937)}.page-subtitle[data-v-89d42244]{margin:0;font-size:1rem;color:var(--color-text-muted, #6b7280)}.header-actions[data-v-89d42244]{display:flex;gap:.75rem}.action-button[data-v-89d42244]{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:1px solid var(--color-border, #e5e7eb);background:#fff;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.action-button[data-v-89d42244]:hover:not(:disabled){background:var(--color-background-soft, #f9fafb);border-color:var(--color-primary, #3b82f6)}.action-button[data-v-89d42244]:disabled{opacity:.5;cursor:not-allowed}.button-icon[data-v-89d42244]{font-size:1.1rem}.camera-selector-section[data-v-89d42244]{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:12px;box-shadow:0 1px 3px #0000000d}.selector-label[data-v-89d42244]{font-size:1rem;font-weight:500;color:var(--color-heading, #1f2937);white-space:nowrap}.camera-select[data-v-89d42244]{flex:1;max-width:400px;padding:.75rem 1rem;border:1px solid var(--color-border, #e5e7eb);border-radius:8px;font-size:.95rem;background:#fff;cursor:pointer;transition:all .2s}.camera-select[data-v-89d42244]:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.info-section[data-v-89d42244]{background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000000d}.info-title[data-v-89d42244]{margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:var(--color-heading, #1f2937)}.info-grid[data-v-89d42244]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.info-item[data-v-89d42244]{display:flex;flex-direction:column;gap:.5rem}.info-label[data-v-89d42244]{font-size:.85rem;font-weight:500;color:var(--color-text-muted, #6b7280);text-transform:uppercase;letter-spacing:.05em}.info-value[data-v-89d42244]{font-size:1rem;font-weight:600;color:var(--color-heading, #1f2937)}@media (max-width: 767px){.timelapse-view[data-v-89d42244]{padding:1rem}.view-header[data-v-89d42244]{flex-direction:column;align-items:flex-start;gap:1rem}.header-actions[data-v-89d42244]{width:100%}.action-button[data-v-89d42244]{flex:1;justify-content:center;min-height:44px}.page-title[data-v-89d42244]{font-size:1.75rem}.camera-selector-section[data-v-89d42244]{flex-direction:column;align-items:stretch;gap:.75rem}.selector-label[data-v-89d42244]{font-size:1rem}.camera-select[data-v-89d42244]{width:100%;max-width:none;min-height:44px;padding:.75rem 1rem;font-size:1rem}.info-grid[data-v-89d42244]{grid-template-columns:1fr;gap:1rem}.info-item[data-v-89d42244]{padding:.75rem;background:var(--color-background-soft, #f9fafb);border-radius:8px}.info-label[data-v-89d42244]{font-size:.75rem}.info-value[data-v-89d42244]{font-size:1rem}}.species-gallery-container[data-v-4338b9d3]{padding:2rem;max-width:1600px;margin:0 auto}.gallery-header[data-v-4338b9d3]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.header-content[data-v-4338b9d3]{flex:1}.gallery-title[data-v-4338b9d3]{font-size:2rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .5rem}.gallery-subtitle[data-v-4338b9d3]{font-size:1rem;color:var(--color-text-secondary);margin:0}.header-actions[data-v-4338b9d3]{display:flex;gap:1rem}.stats-summary[data-v-4338b9d3]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card[data-v-4338b9d3]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem}.stat-icon[data-v-4338b9d3]{font-size:2.5rem;line-height:1}.stat-content[data-v-4338b9d3]{flex:1}.stat-value[data-v-4338b9d3]{font-size:2rem;font-weight:700;color:var(--color-text-primary);line-height:1;margin-bottom:.25rem}.stat-label[data-v-4338b9d3]{font-size:.875rem;color:var(--color-text-secondary)}.loading-state[data-v-4338b9d3],.error-state[data-v-4338b9d3],.empty-state[data-v-4338b9d3]{text-align:center;padding:4rem 2rem}.spinner-large[data-v-4338b9d3]{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin-4338b9d3 1s linear infinite;margin:0 auto 1rem}@keyframes spin-4338b9d3{to{transform:rotate(360deg)}}.error-icon[data-v-4338b9d3],.empty-icon[data-v-4338b9d3]{font-size:4rem;margin-bottom:1rem}.empty-hint[data-v-4338b9d3]{font-size:.875rem;color:var(--color-text-tertiary);margin-top:.5rem}.species-section[data-v-4338b9d3]{margin-top:2rem}.species-grid[data-v-4338b9d3]{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.species-card[data-v-4338b9d3]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s ease}.species-card[data-v-4338b9d3]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:var(--color-primary)}.species-image[data-v-4338b9d3]{position:relative;width:100%;padding-top:75%;background:var(--color-background);overflow:hidden}.image-placeholder[data-v-4338b9d3]{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.placeholder-icon[data-v-4338b9d3]{font-size:4rem;opacity:.9}.photo-count-badge[data-v-4338b9d3]{position:absolute;bottom:.75rem;right:.75rem;background:#000000bf;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.species-info[data-v-4338b9d3]{padding:1rem}.species-name[data-v-4338b9d3]{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0 0 .25rem}.scientific-name[data-v-4338b9d3]{font-size:.875rem;font-style:italic;color:var(--color-text-secondary);margin:0 0 .75rem}.species-meta[data-v-4338b9d3]{display:flex;flex-direction:column;gap:.25rem}.meta-item[data-v-4338b9d3]{display:flex;justify-content:space-between;font-size:.75rem}.meta-label[data-v-4338b9d3]{color:var(--color-text-tertiary)}.meta-value[data-v-4338b9d3]{color:var(--color-text-secondary);font-weight:500}.pagination[data-v-4338b9d3]{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem}.pagination-button[data-v-4338b9d3]{padding:.5rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);cursor:pointer;transition:all .2s ease}.pagination-button[data-v-4338b9d3]:hover:not(:disabled){background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination-button[data-v-4338b9d3]:disabled{opacity:.5;cursor:not-allowed}.pagination-pages[data-v-4338b9d3]{display:flex;gap:.5rem}.pagination-page[data-v-4338b9d3]{width:40px;height:40px;padding:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);cursor:pointer;transition:all .2s ease}.pagination-page[data-v-4338b9d3]:hover{background:var(--color-primary-light);border-color:var(--color-primary)}.pagination-page.active[data-v-4338b9d3]{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.action-button[data-v-4338b9d3]{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.action-button.primary[data-v-4338b9d3]{background:var(--color-primary);color:#fff}.action-button.primary[data-v-4338b9d3]:hover:not(:disabled){background:var(--color-primary-dark)}.action-button.secondary[data-v-4338b9d3]{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.action-button.secondary[data-v-4338b9d3]:hover:not(:disabled){background:var(--color-background)}.action-button[data-v-4338b9d3]:disabled{opacity:.5;cursor:not-allowed}.button-icon[data-v-4338b9d3]{font-size:1.25rem;line-height:1}.button-icon.rotating[data-v-4338b9d3]{animation:spin-4338b9d3 1s linear infinite}@media (min-width: 768px) and (max-width: 1023px){.species-grid[data-v-4338b9d3]{grid-template-columns:repeat(3,1fr)}}@media (max-width: 767px){.species-gallery-container[data-v-4338b9d3]{padding:1rem}.gallery-header[data-v-4338b9d3]{flex-direction:column;gap:1rem}.species-grid[data-v-4338b9d3]{grid-template-columns:repeat(2,1fr);gap:1rem}.species-info[data-v-4338b9d3]{padding:.75rem}.stats-summary[data-v-4338b9d3]{grid-template-columns:1fr}.action-button[data-v-4338b9d3]{min-height:44px}.pagination-button[data-v-4338b9d3],.pagination-page[data-v-4338b9d3]{min-width:44px;min-height:44px}}.species-detail-container[data-v-6ccbb38e]{padding:2rem;max-width:1400px;margin:0 auto}.loading-state[data-v-6ccbb38e],.error-state[data-v-6ccbb38e]{text-align:center;padding:4rem 2rem}.spinner-large[data-v-6ccbb38e]{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin-6ccbb38e 1s linear infinite;margin:0 auto 1rem}@keyframes spin-6ccbb38e{to{transform:rotate(360deg)}}.error-icon[data-v-6ccbb38e]{font-size:4rem;margin-bottom:1rem}.error-state button[data-v-6ccbb38e]{margin:.5rem}.back-button[data-v-6ccbb38e]{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);cursor:pointer;transition:all .2s ease;margin-bottom:1.5rem}.back-button[data-v-6ccbb38e]:hover{background:var(--color-background)}.species-header[data-v-6ccbb38e]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.species-header-content[data-v-6ccbb38e]{flex:1}.species-title[data-v-6ccbb38e]{font-size:2.5rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .5rem}.scientific-name[data-v-6ccbb38e]{font-size:1.25rem;font-style:italic;color:var(--color-text-secondary);margin:0}.species-header-actions[data-v-6ccbb38e]{display:flex;gap:1rem}.species-stats[data-v-6ccbb38e]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card[data-v-6ccbb38e]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem}.stat-icon[data-v-6ccbb38e]{font-size:2.5rem;line-height:1}.stat-content[data-v-6ccbb38e]{flex:1}.stat-value[data-v-6ccbb38e]{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);line-height:1;margin-bottom:.25rem}.stat-label[data-v-6ccbb38e]{font-size:.875rem;color:var(--color-text-secondary)}.photos-section[data-v-6ccbb38e]{margin-top:3rem}.section-title[data-v-6ccbb38e]{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .5rem}.section-subtitle[data-v-6ccbb38e]{font-size:1rem;color:var(--color-text-secondary);margin:0 0 2rem}.coming-soon[data-v-6ccbb38e]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:3rem 2rem;text-align:center}.coming-soon-icon[data-v-6ccbb38e]{font-size:4rem;margin-bottom:1rem}.coming-soon h3[data-v-6ccbb38e]{font-size:1.5rem;font-weight:600;color:var(--color-text-primary);margin:0 0 1rem}.coming-soon p[data-v-6ccbb38e]{color:var(--color-text-secondary);margin:.5rem 0}.coming-soon ul[data-v-6ccbb38e]{list-style:none;padding:0;margin:1rem 0}.coming-soon li[data-v-6ccbb38e]{padding:.5rem 0;color:var(--color-text-secondary)}.coming-soon li[data-v-6ccbb38e]:before{content:"✓ ";color:var(--color-primary);font-weight:700;margin-right:.5rem}.coming-soon .note[data-v-6ccbb38e]{font-size:.875rem;color:var(--color-text-tertiary);font-style:italic;margin-top:1.5rem}.action-button[data-v-6ccbb38e]{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.action-button.primary[data-v-6ccbb38e]{background:var(--color-primary);color:#fff}.action-button.primary[data-v-6ccbb38e]:hover{background:var(--color-primary-dark)}.action-button.secondary[data-v-6ccbb38e]{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.action-button.secondary[data-v-6ccbb38e]:hover{background:var(--color-background)}.button-icon[data-v-6ccbb38e]{font-size:1.25rem;line-height:1}@media (max-width: 767px){.species-detail-container[data-v-6ccbb38e]{padding:1rem}.species-header[data-v-6ccbb38e]{flex-direction:column;align-items:flex-start;gap:1rem}.species-header-actions[data-v-6ccbb38e]{width:100%}.species-title[data-v-6ccbb38e]{font-size:1.75rem}.scientific-name[data-v-6ccbb38e]{font-size:14px}.species-stats[data-v-6ccbb38e]{grid-template-columns:1fr}.action-button[data-v-6ccbb38e]{width:100%;justify-content:center;min-height:44px}.back-button[data-v-6ccbb38e]{min-height:44px}.section-title[data-v-6ccbb38e]{font-size:1.5rem}.section-subtitle[data-v-6ccbb38e]{font-size:14px}}.statistics-container[data-v-cd413d64]{padding:2rem;max-width:1600px;margin:0 auto}.statistics-header[data-v-cd413d64]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.header-content[data-v-cd413d64]{flex:1}.statistics-title[data-v-cd413d64]{font-size:2rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .5rem}.statistics-subtitle[data-v-cd413d64]{font-size:1rem;color:var(--color-text-secondary);margin:0}.header-actions[data-v-cd413d64]{display:flex;gap:1rem}.loading-state[data-v-cd413d64],.error-state[data-v-cd413d64],.empty-state[data-v-cd413d64]{text-align:center;padding:4rem 2rem}.spinner-large[data-v-cd413d64]{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin-cd413d64 1s linear infinite;margin:0 auto 1rem}@keyframes spin-cd413d64{to{transform:rotate(360deg)}}.error-icon[data-v-cd413d64],.empty-icon[data-v-cd413d64]{font-size:4rem;margin-bottom:1rem}.stats-summary[data-v-cd413d64]{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card[data-v-cd413d64]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem}.stat-icon[data-v-cd413d64]{font-size:2.5rem;line-height:1}.stat-content[data-v-cd413d64]{flex:1}.stat-value[data-v-cd413d64]{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);line-height:1;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-label[data-v-cd413d64]{font-size:.875rem;color:var(--color-text-secondary)}.chart-section[data-v-cd413d64]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.chart-header[data-v-cd413d64]{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem}.chart-title[data-v-cd413d64]{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0}.chart-controls[data-v-cd413d64]{display:flex;align-items:center;gap:1rem}.control-label[data-v-cd413d64]{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-text-secondary)}.control-select[data-v-cd413d64]{padding:.5rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-background);color:var(--color-text-primary);cursor:pointer}.chart-container[data-v-cd413d64]{position:relative;height:400px}.table-section[data-v-cd413d64]{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem}.table-title[data-v-cd413d64]{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0 0 1.5rem}.table-container[data-v-cd413d64]{overflow-x:auto}.species-table[data-v-cd413d64]{width:100%;border-collapse:collapse}.species-table thead[data-v-cd413d64]{background:var(--color-background)}.species-table th[data-v-cd413d64]{padding:.75rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border)}.species-table td[data-v-cd413d64]{padding:1rem;border-bottom:1px solid var(--color-border)}.species-table tbody tr[data-v-cd413d64]:hover{background:var(--color-background)}.rank-cell[data-v-cd413d64]{font-weight:700;color:var(--color-primary);width:60px}.species-cell[data-v-cd413d64]{font-weight:600;color:var(--color-text-primary)}.scientific-cell[data-v-cd413d64]{font-style:italic;color:var(--color-text-secondary)}.count-cell[data-v-cd413d64]{font-weight:600;color:var(--color-text-primary);text-align:center;width:100px}.date-cell[data-v-cd413d64]{color:var(--color-text-secondary);font-size:.875rem;white-space:nowrap}.action-button[data-v-cd413d64]{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.action-button.primary[data-v-cd413d64]{background:var(--color-primary);color:#fff}.action-button.primary[data-v-cd413d64]:hover:not(:disabled){background:var(--color-primary-dark)}.action-button.secondary[data-v-cd413d64]{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.action-button.secondary[data-v-cd413d64]:hover:not(:disabled){background:var(--color-background)}.action-button[data-v-cd413d64]:disabled{opacity:.5;cursor:not-allowed}.button-icon[data-v-cd413d64]{font-size:1.25rem;line-height:1}.button-icon.rotating[data-v-cd413d64]{animation:spin-cd413d64 1s linear infinite}@media (max-width: 767px){.statistics-container[data-v-cd413d64]{padding:1rem}.statistics-header[data-v-cd413d64]{flex-direction:column;gap:1rem}.stats-summary[data-v-cd413d64]{grid-template-columns:1fr}.chart-header[data-v-cd413d64]{flex-direction:column;align-items:flex-start}.chart-container[data-v-cd413d64]{height:300px}.action-button[data-v-cd413d64]{min-height:44px}.table-container[data-v-cd413d64]{overflow-x:visible}.species-table[data-v-cd413d64]{font-size:14px}.species-table thead[data-v-cd413d64]{display:none}.species-table[data-v-cd413d64],.species-table tbody[data-v-cd413d64],.species-table tr[data-v-cd413d64]{display:block}.species-table tr[data-v-cd413d64]{background:var(--color-background);border:1px solid var(--color-border);border-radius:8px;padding:1rem;margin-bottom:1rem}.species-table tr[data-v-cd413d64]:hover{background:var(--color-surface)}.species-table td[data-v-cd413d64]{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:none;font-size:14px}.species-table td[data-v-cd413d64]:last-child{padding-bottom:0}.species-table td[data-v-cd413d64]:before{content:attr(data-label);font-weight:600;color:var(--color-text-secondary);margin-right:1rem}.rank-cell[data-v-cd413d64]:before{content:"Rank: "}.species-cell[data-v-cd413d64]:before{content:"Species: "}.scientific-cell[data-v-cd413d64]:before{content:"Scientific: "}.count-cell[data-v-cd413d64]:before{content:"Photos: "}.date-cell[data-v-cd413d64]:nth-of-type(5):before{content:"First Seen: "}.date-cell[data-v-cd413d64]:nth-of-type(6):before{content:"Last Seen: "}.rank-cell[data-v-cd413d64],.count-cell[data-v-cd413d64]{text-align:right}.scientific-cell[data-v-cd413d64]{font-style:italic}}@media (max-width: 768px){.statistics-container[data-v-cd413d64]{padding:1rem}.statistics-header[data-v-cd413d64]{flex-direction:column;gap:1rem}.stats-summary[data-v-cd413d64]{grid-template-columns:1fr}.chart-header[data-v-cd413d64]{flex-direction:column;align-items:flex-start}.chart-container[data-v-cd413d64]{height:300px}.species-table[data-v-cd413d64]{font-size:.875rem}.species-table th[data-v-cd413d64],.species-table td[data-v-cd413d64]{padding:.5rem}}.progress-modal-overlay[data-v-e5eb5b41]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn-e5eb5b41 .2s ease-in-out}@keyframes fadeIn-e5eb5b41{0%{opacity:0}to{opacity:1}}.progress-modal[data-v-e5eb5b41]{background:#fff;border-radius:16px;padding:2rem;max-width:500px;width:90%;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp-e5eb5b41 .3s ease-out}@keyframes slideUp-e5eb5b41{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.progress-header[data-v-e5eb5b41]{margin-bottom:1.5rem}.progress-title[data-v-e5eb5b41]{font-size:1.5rem;font-weight:700;color:var(--color-text-primary, #1a1a1a);margin:0;display:flex;align-items:center;gap:.75rem}.title-icon[data-v-e5eb5b41]{font-size:2rem}.progress-content[data-v-e5eb5b41]{display:flex;flex-direction:column;gap:1.5rem}.progress-bar-container[data-v-e5eb5b41]{display:flex;flex-direction:column;gap:.5rem}.progress-bar[data-v-e5eb5b41]{width:100%;height:12px;background:#e5e7eb;border-radius:9999px;overflow:hidden;position:relative}.progress-fill[data-v-e5eb5b41]{height:100%;background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:9999px;transition:width .3s ease-out;position:relative;overflow:hidden}.progress-fill[data-v-e5eb5b41]:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer-e5eb5b41 2s infinite}@keyframes shimmer-e5eb5b41{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-percentage[data-v-e5eb5b41]{text-align:right;font-size:.875rem;font-weight:600;color:var(--color-text-primary, #1a1a1a)}.progress-status[data-v-e5eb5b41]{text-align:center}.status-text[data-v-e5eb5b41]{font-size:1rem;font-weight:500;color:var(--color-text-primary, #1a1a1a);margin:0 0 .5rem}.estimated-time[data-v-e5eb5b41]{font-size:.875rem;color:var(--color-text-secondary, #666);margin:0}.file-stats[data-v-e5eb5b41]{display:flex;justify-content:space-around;padding:1rem;background:#f9fafb;border-radius:12px;gap:1rem}.stat-item[data-v-e5eb5b41]{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-label[data-v-e5eb5b41]{font-size:.75rem;font-weight:600;color:var(--color-text-secondary, #666);text-transform:uppercase;letter-spacing:.05em}.stat-value[data-v-e5eb5b41]{font-size:1rem;font-weight:700;color:var(--color-text-primary, #1a1a1a)}.progress-actions[data-v-e5eb5b41]{display:flex;justify-content:center;padding-top:1rem;border-top:1px solid #e5e7eb}.cancel-button[data-v-e5eb5b41]{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-size:.875rem;font-weight:600;color:var(--color-text-primary, #1a1a1a);cursor:pointer;transition:all .2s}.cancel-button[data-v-e5eb5b41]:hover{background:#f9fafb;border-color:#d1d5db}.cancel-button[data-v-e5eb5b41]:active{transform:scale(.98)}.button-icon[data-v-e5eb5b41]{font-size:1rem}@media (max-width: 640px){.progress-modal[data-v-e5eb5b41]{padding:1.5rem}.progress-title[data-v-e5eb5b41]{font-size:1.25rem}.file-stats[data-v-e5eb5b41]{flex-direction:column;gap:.75rem}.stat-item[data-v-e5eb5b41]{flex-direction:row;justify-content:space-between}}.downloads-view[data-v-7e0eaf18]{padding:2rem;max-width:1400px;margin:0 auto}.downloads-header[data-v-7e0eaf18]{margin-bottom:2rem}.page-title[data-v-7e0eaf18]{font-size:2rem;font-weight:700;color:var(--color-text-primary, #1a1a1a);margin-bottom:.5rem;display:flex;align-items:center;gap:.75rem}.title-icon[data-v-7e0eaf18]{font-size:2.5rem}.page-subtitle[data-v-7e0eaf18]{font-size:1rem;color:var(--color-text-secondary, #666);margin:0}.filters-section[data-v-7e0eaf18]{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.section-title[data-v-7e0eaf18]{font-size:1.5rem;font-weight:600;color:var(--color-text-primary, #1a1a1a);margin-bottom:1.5rem}.filters-grid[data-v-7e0eaf18]{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:1.5rem}.filter-group[data-v-7e0eaf18]{display:flex;flex-direction:column;gap:.5rem}.filter-label[data-v-7e0eaf18]{font-size:.875rem;font-weight:600;color:var(--color-text-primary, #1a1a1a)}.filter-input[data-v-7e0eaf18],.filter-select[data-v-7e0eaf18]{padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:.875rem;transition:border-color .2s}.filter-input[data-v-7e0eaf18]:focus,.filter-select[data-v-7e0eaf18]:focus{outline:none;border-color:#3b82f6}.date-range-inputs[data-v-7e0eaf18]{display:flex;align-items:center;gap:.5rem}.date-separator[data-v-7e0eaf18]{font-size:.875rem;color:var(--color-text-secondary, #666)}.checkbox-group[data-v-7e0eaf18]{display:flex;flex-direction:column;gap:.5rem}.checkbox-label[data-v-7e0eaf18]{display:flex;align-items:center;gap:.5rem;font-size:.875rem;cursor:pointer}.checkbox-label input[type=radio][data-v-7e0eaf18]{cursor:pointer}.filter-actions[data-v-7e0eaf18]{display:flex;gap:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.preview-section[data-v-7e0eaf18]{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.preview-header[data-v-7e0eaf18]{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.preview-stats[data-v-7e0eaf18]{display:flex;gap:1rem}.stat-badge[data-v-7e0eaf18]{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f3f4f6;border-radius:8px;font-size:.875rem;font-weight:600}.badge-icon[data-v-7e0eaf18]{font-size:1.25rem}.preview-loading[data-v-7e0eaf18],.preview-empty[data-v-7e0eaf18]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.spinner-medium[data-v-7e0eaf18]{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin-7e0eaf18 1s linear infinite}@keyframes spin-7e0eaf18{to{transform:rotate(360deg)}}.empty-icon[data-v-7e0eaf18]{font-size:4rem;margin-bottom:1rem;opacity:.5}.preview-list[data-v-7e0eaf18]{display:flex;flex-direction:column;gap:1rem}.preview-item[data-v-7e0eaf18]{display:flex;gap:1rem;padding:1rem;border:1px solid #e5e7eb;border-radius:8px;transition:background-color .2s}.preview-item[data-v-7e0eaf18]:hover{background-color:#f9fafb}.item-thumbnail[data-v-7e0eaf18]{width:80px;height:60px;border-radius:6px;overflow:hidden;flex-shrink:0;background:#f3f4f6;display:flex;align-items:center;justify-content:center}.thumbnail-image[data-v-7e0eaf18]{width:100%;height:100%;object-fit:cover}.thumbnail-placeholder[data-v-7e0eaf18]{font-size:2rem;opacity:.5}.item-info[data-v-7e0eaf18]{flex:1;display:flex;flex-direction:column;justify-content:center;gap:.25rem}.item-name[data-v-7e0eaf18]{font-size:.875rem;font-weight:600;color:var(--color-text-primary, #1a1a1a)}.item-meta[data-v-7e0eaf18]{font-size:.75rem;color:var(--color-text-secondary, #666);display:flex;align-items:center;gap:.5rem}.meta-separator[data-v-7e0eaf18]{opacity:.5}.meta-species[data-v-7e0eaf18]{color:#10b981;font-weight:600}.preview-more[data-v-7e0eaf18]{padding:1rem;text-align:center;color:var(--color-text-secondary, #666);font-size:.875rem}.warning-banner[data-v-7e0eaf18]{display:flex;gap:1rem;padding:1rem;margin-top:1.5rem;background:#fef3c7;border:1px solid #fbbf24;border-radius:8px}.warning-icon[data-v-7e0eaf18]{font-size:1.5rem;flex-shrink:0}.warning-content[data-v-7e0eaf18]{flex:1}.warning-title[data-v-7e0eaf18]{font-size:.875rem;font-weight:700;color:#92400e;margin-bottom:.25rem}.warning-text[data-v-7e0eaf18]{font-size:.875rem;color:#78350f}.download-actions[data-v-7e0eaf18]{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;text-align:center}.error-text[data-v-7e0eaf18]{color:#ef4444;font-size:.875rem;margin-top:.5rem}.action-button[data-v-7e0eaf18]{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.action-button[data-v-7e0eaf18]:disabled{opacity:.5;cursor:not-allowed}.action-button.primary[data-v-7e0eaf18]{background:#3b82f6;color:#fff}.action-button.primary[data-v-7e0eaf18]:hover:not(:disabled){background:#2563eb}.action-button.secondary[data-v-7e0eaf18]{background:#e5e7eb;color:var(--color-text-primary, #1a1a1a)}.action-button.secondary[data-v-7e0eaf18]:hover:not(:disabled){background:#d1d5db}.action-button.tertiary[data-v-7e0eaf18]{background:transparent;color:var(--color-text-secondary, #666);border:1px solid #e5e7eb}.action-button.tertiary[data-v-7e0eaf18]:hover{background:#f9fafb}.action-button.large[data-v-7e0eaf18]{padding:1rem 2rem;font-size:1rem}.button-icon[data-v-7e0eaf18]{font-size:1.25rem}.button-icon.spinning[data-v-7e0eaf18]{animation:spin-7e0eaf18 1s linear infinite}@media (max-width: 767px){.downloads-view[data-v-7e0eaf18]{padding:1rem}.downloads-header[data-v-7e0eaf18]{text-align:center}.page-title[data-v-7e0eaf18]{font-size:1.75rem}.page-subtitle[data-v-7e0eaf18]{font-size:.875rem}.filters-grid[data-v-7e0eaf18]{grid-template-columns:1fr;gap:1rem}.filter-input[data-v-7e0eaf18],.filter-select[data-v-7e0eaf18]{min-height:44px;padding:.75rem 1rem;font-size:1rem}.date-range-inputs[data-v-7e0eaf18]{flex-direction:column;gap:.75rem}.date-separator[data-v-7e0eaf18]{display:none}.checkbox-label[data-v-7e0eaf18]{min-height:44px;padding:.75rem 1rem}.checkbox-label input[type=radio][data-v-7e0eaf18]{width:20px;height:20px}.filter-actions[data-v-7e0eaf18]{flex-direction:column;gap:.75rem}.filter-actions .action-button[data-v-7e0eaf18]{width:100%;justify-content:center;min-height:44px;padding:.75rem 1.5rem}.preview-section[data-v-7e0eaf18]{padding:1rem}.preview-header[data-v-7e0eaf18]{flex-direction:column;align-items:flex-start;gap:1rem}.preview-stats[data-v-7e0eaf18]{width:100%;flex-direction:column;gap:.5rem}.stat-badge[data-v-7e0eaf18]{width:100%;justify-content:flex-start;padding:.75rem 1rem;font-size:1rem}.preview-item[data-v-7e0eaf18]{flex-direction:column;gap:.75rem;padding:1rem}.item-thumbnail[data-v-7e0eaf18]{width:100%;height:140px}.item-info[data-v-7e0eaf18]{gap:.5rem}.item-name[data-v-7e0eaf18]{font-size:1rem}.item-meta[data-v-7e0eaf18]{font-size:.875rem;flex-wrap:wrap}.warning-banner[data-v-7e0eaf18]{flex-direction:column;gap:.75rem;padding:1rem}.warning-title[data-v-7e0eaf18]{font-size:1rem}.warning-text[data-v-7e0eaf18]{font-size:.875rem}.download-actions .action-button.large[data-v-7e0eaf18]{width:100%;min-height:44px;padding:1rem;font-size:1rem}.error-text[data-v-7e0eaf18]{font-size:1rem;margin-top:.75rem}}.settings-view[data-v-2d618a92]{max-width:1200px;margin:0 auto;padding:2rem}.settings-title[data-v-2d618a92]{font-size:2rem;font-weight:700;color:var(--color-heading, #1f2937);margin-bottom:.5rem}.settings-placeholder[data-v-2d618a92]{font-size:1rem;color:var(--color-text-muted, #6b7280)}@media (max-width: 767px){.settings-view[data-v-2d618a92]{padding:1rem}.settings-title[data-v-2d618a92]{font-size:1.75rem}}.modal-overlay[data-v-6f7151d9]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn-6f7151d9 .2s ease-out;will-change:opacity;transform:translateZ(0)}@keyframes fadeIn-6f7151d9{0%{opacity:0}to{opacity:1}}.modal-container[data-v-6f7151d9]{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:slideIn-6f7151d9 .3s ease-out;will-change:transform,opacity;backface-visibility:hidden}@keyframes slideIn-6f7151d9{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header[data-v-6f7151d9]{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-title[data-v-6f7151d9]{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0}.close-button[data-v-6f7151d9]{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.close-button[data-v-6f7151d9]:hover:not(:disabled){color:#1f2937;background:#f3f4f6}.close-button[data-v-6f7151d9]:disabled{opacity:.5;cursor:not-allowed}.modal-body[data-v-6f7151d9]{padding:1.5rem}.error-message[data-v-6f7151d9]{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:1rem;margin-bottom:1.5rem;display:flex;align-items:flex-start;gap:.75rem;color:#991b1b}.error-icon[data-v-6f7151d9]{font-size:1.25rem;flex-shrink:0}.user-form[data-v-6f7151d9]{display:flex;flex-direction:column;gap:1.25rem}.form-group[data-v-6f7151d9]{display:flex;flex-direction:column;gap:.5rem}.form-label[data-v-6f7151d9]{font-weight:600;color:#374151;font-size:.95rem}.required[data-v-6f7151d9]{color:#ef4444}.form-input[data-v-6f7151d9],.form-select[data-v-6f7151d9]{width:100%;padding:.75rem 1rem;border:2px solid #d1d5db;border-radius:8px;font-size:1rem;transition:all .2s;box-sizing:border-box;font-family:inherit}.form-input[data-v-6f7151d9]:focus,.form-select[data-v-6f7151d9]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input.error[data-v-6f7151d9],.form-select.error[data-v-6f7151d9]{border-color:#ef4444}.form-input[data-v-6f7151d9]:disabled,.form-select[data-v-6f7151d9]:disabled{background-color:#f3f4f6;cursor:not-allowed}.form-select[data-v-6f7151d9]{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.5rem;padding-right:2.5rem}.password-input-container[data-v-6f7151d9]{position:relative}.password-input-container .form-input[data-v-6f7151d9]{padding-right:3rem}.toggle-password[data-v-6f7151d9]{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1;transition:opacity .2s}.toggle-password[data-v-6f7151d9]:hover:not(:disabled){opacity:.7}.toggle-password[data-v-6f7151d9]:disabled{opacity:.5;cursor:not-allowed}.input-hint[data-v-6f7151d9]{margin:0;font-size:.875rem;color:#6b7280}.error-hint[data-v-6f7151d9]{margin:0;font-size:.875rem;color:#ef4444}.info-box[data-v-6f7151d9]{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:1rem;display:flex;gap:.75rem;align-items:flex-start}.info-icon[data-v-6f7151d9]{font-size:1.25rem;flex-shrink:0}.info-content[data-v-6f7151d9]{flex:1}.info-text[data-v-6f7151d9]{margin:0;color:#1e40af;font-size:.875rem;line-height:1.6}.info-text strong[data-v-6f7151d9]{font-weight:600}.modal-actions[data-v-6f7151d9]{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.action-button[data-v-6f7151d9]{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.action-button.secondary[data-v-6f7151d9]{background:#f3f4f6;color:#4b5563}.action-button.secondary[data-v-6f7151d9]:hover:not(:disabled){background:#e5e7eb}.action-button.primary[data-v-6f7151d9]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 6px #667eea4d}.action-button.primary[data-v-6f7151d9]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.action-button[data-v-6f7151d9]:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-content[data-v-6f7151d9]{display:flex;align-items:center;justify-content:center;gap:.5rem}.spinner[data-v-6f7151d9]{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-6f7151d9 .6s linear infinite}@keyframes spin-6f7151d9{to{transform:rotate(360deg)}}@media (max-width: 767px){.modal-container[data-v-6f7151d9]{margin:0;border-radius:0;max-height:100vh}.form-input[data-v-6f7151d9],.form-select[data-v-6f7151d9],.action-button[data-v-6f7151d9]{min-height:44px}.modal-actions[data-v-6f7151d9]{flex-direction:column-reverse;gap:12px}.action-button[data-v-6f7151d9]{width:100%}}.users-view[data-v-18f25fcd]{padding:2rem;max-width:1400px;margin:0 auto}.page-header[data-v-18f25fcd]{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.header-content[data-v-18f25fcd]{flex:1}.page-title[data-v-18f25fcd]{font-size:2rem;font-weight:700;color:#1f2937;margin:0 0 .5rem}.page-description[data-v-18f25fcd]{color:#6b7280;margin:0;font-size:1rem}.create-button[data-v-18f25fcd]{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s;box-shadow:0 4px 6px #667eea4d}.create-button[data-v-18f25fcd]:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.button-icon[data-v-18f25fcd]{font-size:1.25rem;font-weight:700}.loading-container[data-v-18f25fcd]{text-align:center;padding:4rem 2rem;color:#6b7280}.spinner[data-v-18f25fcd]{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin-18f25fcd .8s linear infinite;margin:0 auto 1rem}.spinner.small[data-v-18f25fcd]{width:16px;height:16px;border-width:2px}@keyframes spin-18f25fcd{to{transform:rotate(360deg)}}.error-container[data-v-18f25fcd]{text-align:center;padding:3rem 2rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b}.error-icon[data-v-18f25fcd]{font-size:2rem;display:block;margin-bottom:1rem}.retry-button[data-v-18f25fcd]{margin-top:1rem;padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background .2s}.retry-button[data-v-18f25fcd]:hover{background:#764ba2}.empty-state[data-v-18f25fcd]{text-align:center;padding:4rem 2rem;color:#6b7280}.empty-icon[data-v-18f25fcd]{font-size:3rem;display:block;margin-bottom:1rem}.empty-state h2[data-v-18f25fcd]{font-size:1.5rem;color:#374151;margin-bottom:.5rem}.users-table-wrapper[data-v-18f25fcd]{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.users-table[data-v-18f25fcd]{width:100%;border-collapse:collapse}.users-table thead[data-v-18f25fcd]{background:#f9fafb;border-bottom:2px solid #e5e7eb}.users-table th[data-v-18f25fcd]{padding:1rem 1.5rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.users-table td[data-v-18f25fcd]{padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;color:#4b5563;vertical-align:middle}.users-table tbody tr[data-v-18f25fcd]:hover{background:#f9fafb}.users-table tbody tr.inactive[data-v-18f25fcd]{opacity:.6}.users-table tbody tr:last-child td[data-v-18f25fcd]{border-bottom:none}.username-cell[data-v-18f25fcd]{display:flex;align-items:center;gap:.5rem;min-height:3rem}.username[data-v-18f25fcd]{font-weight:600;color:#1f2937}.you-badge[data-v-18f25fcd]{display:inline-block;padding:.25rem .5rem;background:#dbeafe;color:#1e40af;border-radius:4px;font-size:.75rem;font-weight:600}.email-cell .no-email[data-v-18f25fcd]{color:#9ca3af;font-style:italic}.role-badge[data-v-18f25fcd]{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600}.role-badge.role-admin[data-v-18f25fcd]{background:#fef3c7;color:#92400e}.role-badge.role-user[data-v-18f25fcd]{background:#dbeafe;color:#1e40af}.role-badge.role-guest[data-v-18f25fcd]{background:#e5e7eb;color:#4b5563}.last-login-cell .never[data-v-18f25fcd]{color:#9ca3af;font-style:italic}.status-badge[data-v-18f25fcd]{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600}.status-badge.active[data-v-18f25fcd]{background:#d1fae5;color:#065f46}.status-badge.inactive[data-v-18f25fcd]{background:#fee2e2;color:#991b1b}.action-buttons[data-v-18f25fcd]{display:flex;gap:.5rem}.action-btn[data-v-18f25fcd]{padding:.5rem;background:none;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s;font-size:1.25rem}.action-btn[data-v-18f25fcd]:hover:not(:disabled){background:#f3f4f6;transform:scale(1.05)}.action-btn[data-v-18f25fcd]:disabled{opacity:.4;cursor:not-allowed}.delete-btn[data-v-18f25fcd]:hover:not(:disabled){background:#fee2e2;border-color:#fecaca}.edit-btn[data-v-18f25fcd]:hover:not(:disabled){background:#dbeafe;border-color:#bfdbfe}.revoke-btn[data-v-18f25fcd]:hover:not(:disabled){background:#fef3c7;border-color:#fde68a}.modal-overlay[data-v-18f25fcd]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.confirm-dialog[data-v-18f25fcd]{background:#fff;border-radius:12px;padding:2rem;max-width:400px;width:100%;box-shadow:0 20px 40px #0000004d}.confirm-title[data-v-18f25fcd]{font-size:1.5rem;color:#1f2937;margin:0 0 1rem}.confirm-message[data-v-18f25fcd]{color:#4b5563;line-height:1.6;margin-bottom:1.5rem}.confirm-message strong[data-v-18f25fcd]{color:#1f2937;font-weight:600}.confirm-actions[data-v-18f25fcd]{display:flex;gap:1rem;justify-content:flex-end}.cancel-btn[data-v-18f25fcd],.confirm-btn[data-v-18f25fcd]{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.cancel-btn[data-v-18f25fcd]{background:#f3f4f6;color:#4b5563}.cancel-btn[data-v-18f25fcd]:hover{background:#e5e7eb}.confirm-btn[data-v-18f25fcd]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.confirm-btn.delete[data-v-18f25fcd]{background:linear-gradient(135deg,#ef4444,#dc2626)}.confirm-btn[data-v-18f25fcd]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #0003}.confirm-btn[data-v-18f25fcd]:disabled{opacity:.6;cursor:not-allowed}.loading-spinner[data-v-18f25fcd]{display:flex;align-items:center;gap:.5rem}.edit-dialog[data-v-18f25fcd]{background:#fff;border-radius:12px;padding:2rem;max-width:500px;width:100%;box-shadow:0 20px 40px #0000004d}.edit-title[data-v-18f25fcd]{font-size:1.5rem;color:#1f2937;margin:0 0 1.5rem}.edit-form[data-v-18f25fcd]{display:flex;flex-direction:column;gap:1rem}.form-group[data-v-18f25fcd]{display:flex;flex-direction:column;gap:.5rem}.form-label[data-v-18f25fcd]{font-size:.875rem;font-weight:600;color:#374151}.form-input[data-v-18f25fcd],.form-select[data-v-18f25fcd]{padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;color:#1f2937;transition:border-color .2s}.form-input[data-v-18f25fcd]:focus,.form-select[data-v-18f25fcd]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input[data-v-18f25fcd]:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.form-hint[data-v-18f25fcd]{font-size:.75rem;color:#6b7280;margin:0}.edit-error[data-v-18f25fcd]{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fee2e2;border:1px solid #fecaca;border-radius:6px;color:#991b1b;font-size:.875rem}.edit-actions[data-v-18f25fcd]{display:flex;gap:1rem;justify-content:flex-end;margin-top:.5rem}@media (max-width: 767px){.users-view[data-v-18f25fcd]{padding:1rem}.page-header[data-v-18f25fcd]{flex-direction:column;align-items:stretch;gap:1rem}.create-button[data-v-18f25fcd]{width:100%;justify-content:center;min-height:44px}.users-table-wrapper[data-v-18f25fcd]{overflow-x:visible}.users-table[data-v-18f25fcd]{font-size:14px}.users-table thead[data-v-18f25fcd]{display:none}.users-table[data-v-18f25fcd],.users-table tbody[data-v-18f25fcd],.users-table tbody tr[data-v-18f25fcd]{display:block}.users-table tbody tr[data-v-18f25fcd]{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a}.users-table tbody tr[data-v-18f25fcd]:hover{background:#fff;box-shadow:0 2px 6px #00000026}.users-table tbody tr.inactive[data-v-18f25fcd]{opacity:.7}.users-table td[data-v-18f25fcd]{display:block;padding:.75rem 0;border-bottom:none;text-align:left}.users-table td[data-v-18f25fcd]:first-child{padding-top:0}.users-table td[data-v-18f25fcd]:last-child{padding-bottom:0}.username-cell[data-v-18f25fcd],.email-cell[data-v-18f25fcd],.role-cell[data-v-18f25fcd],.last-login-cell[data-v-18f25fcd],.status-cell[data-v-18f25fcd]{display:flex;justify-content:space-between;align-items:center;min-height:auto}.username-cell[data-v-18f25fcd]:before{content:"Username:";font-weight:600;color:#6b7280;margin-right:1rem}.email-cell[data-v-18f25fcd]:before{content:"Email:";font-weight:600;color:#6b7280;margin-right:1rem}.role-cell[data-v-18f25fcd]:before{content:"Role:";font-weight:600;color:#6b7280;margin-right:1rem}.last-login-cell[data-v-18f25fcd]:before{content:"Last Login:";font-weight:600;color:#6b7280;margin-right:1rem}.status-cell[data-v-18f25fcd]:before{content:"Status:";font-weight:600;color:#6b7280;margin-right:1rem}.actions-cell[data-v-18f25fcd]{display:block;padding-top:1rem;margin-top:.75rem;border-top:1px solid #e5e7eb}.action-buttons[data-v-18f25fcd]{flex-direction:column;gap:.75rem}.action-btn[data-v-18f25fcd]{width:100%;min-height:44px;padding:.75rem 1rem;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1rem}.action-btn[data-v-18f25fcd]:after{content:attr(title);font-size:.875rem;margin-left:.5rem}.you-badge[data-v-18f25fcd],.role-badge[data-v-18f25fcd],.status-badge[data-v-18f25fcd]{font-size:14px;padding:.375rem .75rem}.confirm-dialog[data-v-18f25fcd],.edit-dialog[data-v-18f25fcd]{margin:1rem;max-width:100%}.confirm-actions[data-v-18f25fcd],.edit-actions[data-v-18f25fcd]{flex-direction:column-reverse;gap:.75rem}.cancel-btn[data-v-18f25fcd],.confirm-btn[data-v-18f25fcd]{width:100%;min-height:44px;justify-content:center}.form-input[data-v-18f25fcd],.form-select[data-v-18f25fcd]{min-height:44px}}@media (max-width: 768px){.users-view[data-v-18f25fcd]{padding:1rem}.page-header[data-v-18f25fcd]{flex-direction:column;align-items:stretch}.create-button[data-v-18f25fcd]{width:100%;justify-content:center}.users-table[data-v-18f25fcd]{font-size:.875rem}.users-table th[data-v-18f25fcd],.users-table td[data-v-18f25fcd]{padding:.75rem 1rem}.action-buttons[data-v-18f25fcd]{flex-direction:column}}.not-found-view[data-v-da724961]{padding:2rem;text-align:center}a[data-v-da724961]{color:#6366f1;text-decoration:none}a[data-v-da724961]:hover{text-decoration:underline}:root{--breakpoint-mobile: 767px;--breakpoint-tablet: 768px;--breakpoint-tablet-max: 1023px;--breakpoint-desktop: 1024px}:root{--font-size-body: 1rem;--font-size-secondary: .875rem;--font-size-small: .75rem;--line-height-base: 1.6;--container-padding: 2rem}h1,.heading-1{font-size:1.5rem;line-height:1.4}h2,.heading-2{font-size:1.25rem;line-height:1.4}h3,.heading-3{font-size:1.125rem;line-height:1.4}@media (max-width: var(--breakpoint-mobile)){:root{--container-padding: 1rem}body,p,.body-text{font-size:16px!important;line-height:1.6}.secondary-text,small,.text-secondary{font-size:14px!important;line-height:1.6}h1,.heading-1{font-size:1.5rem}h2,.heading-2{font-size:1.25rem}h3,.heading-3{font-size:1.125rem}}.container,.main-content{padding:var(--container-padding)}@media (max-width: var(--breakpoint-mobile)){.container,.main-content{padding:var(--container-padding)}button,.btn,a[role=button],input[type=button],input[type=submit]{margin-bottom:.5rem}}@media (hover: none){*:hover{transform:none!important}button:hover,a:hover,.clickable:hover{background-color:inherit}}button:active:not(:disabled),.button:active:not(:disabled),[role=button]:active:not([aria-disabled=true]){transform:scale(.98);opacity:.9;transition:transform .05s ease,opacity .05s ease}a:active,.link:active{opacity:.7;transition:opacity .05s ease}.card:active,.clickable:active,[role=link]:active{transform:scale(.99);opacity:.95;transition:transform .05s ease,opacity .05s ease}.action-button:active:not(:disabled),.btn-primary:active:not(:disabled),.primary-button:active:not(:disabled){transform:scale(.97);box-shadow:0 1px 2px #0000001a;transition:transform .05s ease,box-shadow .05s ease}.action-button.secondary:active:not(:disabled),.btn-secondary:active:not(:disabled),.secondary-button:active:not(:disabled){transform:scale(.98);background-color:#0000000d;transition:transform .05s ease,background-color .05s ease}.icon-button:active:not(:disabled),button.icon:active:not(:disabled){transform:scale(.9);opacity:.8;transition:transform .05s ease,opacity .05s ease}.list-item:active,.menu-item:active,.dropdown-item:active{background-color:#0000000d;transition:background-color .05s ease}.nav-link:active,.mobile-nav-link:active{background-color:#00000014;transition:background-color .05s ease}.control-button:active:not(:disabled),.media-control:active:not(:disabled){transform:scale(.95);box-shadow:0 1px 3px #0003;transition:transform .05s ease,box-shadow .05s ease}.close-button:active:not(:disabled),.dismiss-button:active:not(:disabled){transform:scale(.9) rotate(90deg);opacity:.7;transition:transform .1s ease,opacity .05s ease}.pagination-button:active:not(:disabled),.pagination-page:active{transform:scale(.95);background-color:#0000001a;transition:transform .05s ease,background-color .05s ease}input[type=range]:active::-webkit-slider-thumb{transform:scale(1.3);transition:transform .05s ease}input[type=range]:active::-moz-range-thumb{transform:scale(1.3);transition:transform .05s ease}input[type=checkbox]:active,input[type=radio]:active{transform:scale(1.1);transition:transform .05s ease}.timeline-item:active,.grid-item:active,.gallery-item:active{transform:scale(.98);box-shadow:0 2px 4px #00000026;transition:transform .05s ease,box-shadow .05s ease}.camera-card:active,.species-card:active,.stat-card:active{transform:scale(.99);box-shadow:0 2px 8px #00000026;transition:transform .05s ease,box-shadow .05s ease}tr:active,.table-row:active{background-color:#00000008;transition:background-color .05s ease}@media (max-width: 767px){button:active:not(:disabled),.button:active:not(:disabled){transform:scale(.96)}.icon-button:active:not(:disabled){transform:scale(.85)}:active{transition-duration:.05s!important}}@media (hover: hover){*:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}}@media (hover: none){*:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}}button,a,.clickable,.card,.timeline-item,.grid-item{will-change:transform;backface-visibility:hidden;-webkit-backface-visibility:hidden}@media (hover: hover){button:hover,a:hover,.clickable:hover{will-change:transform,opacity}}
