.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height);background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-around;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;color:var(--color-text-muted);text-decoration:none;border:none;background:none;border-radius:var(--radius);transition:color .15s;cursor:pointer}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-icon{font-size:1.25rem}.bottom-nav-label{font-size:.625rem;font-weight:500}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-content{flex:1;padding-bottom:var(--bottom-nav-height)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:16px;font-size:.75rem;font-weight:500}.status-badge.online{background:#d1fae5;color:#065f46}.status-badge.offline{background:#fee2e2;color:#991b1b}.status-dot{width:8px;height:8px;border-radius:50%}.status-badge.online .status-dot{background:#10b981}.status-badge.offline .status-dot{background:#ef4444}.status-fps{opacity:.7}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:8px}.session-card{display:block;width:100%;text-align:left;border:none;cursor:pointer;transition:box-shadow .15s}.session-card:hover{box-shadow:var(--shadow-lg)}.session-card:active{transform:scale(.99)}.session-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.session-night{font-weight:600;font-size:.95rem}.session-count{font-size:.8rem;color:var(--color-text-secondary);background:var(--color-bg);padding:2px 8px;border-radius:10px}.session-card-bottom{display:flex;align-items:center;justify-content:space-between}.session-time{font-size:.8rem;color:var(--color-text-muted)}.session-categories{display:flex;gap:6px}.session-card-wrapper{position:relative;margin-bottom:12px}.session-card-wrapper .session-card{margin-bottom:0}.session-card-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px;opacity:0;transition:opacity .15s}.session-card-wrapper:hover .session-card-actions{opacity:1}.session-card-wrapper.is-deleted{opacity:.55}.session-card-wrapper.is-deleted .session-card{border-left:3px dashed var(--color-text-muted)}.image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px}@media(min-width:640px){.image-gallery{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.gallery-thumb{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:6px;border:1px solid var(--color-border);background:none;padding:0;cursor:pointer}.gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}.gallery-thumb-size{position:absolute;bottom:2px;right:2px;background:#000000a6;color:#fff;font-size:.6rem;font-weight:600;padding:1px 4px;border-radius:3px;line-height:1.3}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;z-index:200;display:flex;align-items:center;justify-content:center}.lightbox-content{position:relative;max-width:95vw;max-height:90vh}.lightbox-content img{max-width:95vw;max-height:85vh;object-fit:contain;border-radius:4px}.lightbox-close{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;padding:4px 8px}.lightbox-info{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:8px}.lightbox-size,.lightbox-confidence{color:#ffffffb3;font-size:.8rem}.lightbox-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:8px}.lightbox-btn{background:#fff3;border:none;color:#fff;font-size:1.5rem;padding:8px 16px;border-radius:6px;cursor:pointer}.lightbox-btn:hover{background:#ffffff4d}.lightbox-counter{color:#ffffffb3;font-size:.875rem}.video-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin-top:8px}@media(min-width:640px){.video-gallery{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}.video-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;border-radius:6px;border:1px solid var(--color-border);background:#000;padding:0;cursor:pointer}.video-thumb video{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.video-play-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;color:#ffffffd9;background:#0006;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding-left:4px}.video-duration{position:absolute;bottom:4px;right:6px;font-size:.7rem;color:#fff;background:#0009;padding:1px 5px;border-radius:3px}.video-section-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:10px;margin-bottom:4px}.video-thumb-full{grid-column:1 / -1;max-width:400px}.video-lightbox-content{max-width:95vw;max-height:90vh}.video-lightbox-player{max-width:95vw;max-height:80vh;border-radius:4px;background:#000}.detection-card{border-left:4px solid var(--color-border)}.detection-card:has(.badge-animal){border-left-color:var(--color-animal)}.detection-card:has(.badge-human){border-left-color:var(--color-human)}.detection-header{margin-bottom:12px}.detection-name-row{display:flex;align-items:center;gap:10px;margin-bottom:4px}.detection-actions{margin-left:auto;display:flex;gap:4px;opacity:0;transition:opacity .15s}.detection-card:hover .detection-actions{opacity:1}.btn-icon-sm{width:24px;height:24px;border:none;border-radius:50%;background:var(--color-bg);display:flex;align-items:center;justify-content:center;font-size:.65rem;cursor:pointer;transition:background .15s}.btn-icon-sm.btn-delete:hover{background:var(--color-human-light)}.btn-icon-sm.btn-hard-delete{color:var(--color-human)}.btn-icon-sm.btn-hard-delete:hover{background:var(--color-human-light)}.detection-fantasy-name{font-size:1.1rem;font-weight:600;color:var(--color-text)}.detection-meta{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--color-text-secondary)}.detection-class{text-transform:capitalize}.detection-separator,.detection-temp{color:var(--color-text-muted)}.detection-card.is-deleted{opacity:.55;border-left-style:dashed}.back-link{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--color-primary);font-size:.875rem;padding:4px 0;margin-bottom:12px;cursor:pointer}.back-link:hover{text-decoration:underline}.session-header{margin-bottom:20px}.session-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.session-header-actions{display:flex;gap:4px;flex-shrink:0}.btn-icon{width:28px;height:28px;border:none;border-radius:50%;background:var(--color-bg);display:flex;align-items:center;justify-content:center;font-size:.75rem;cursor:pointer;transition:background .15s}.btn-delete:hover{background:var(--color-human-light)}.btn-hard-delete{color:var(--color-human)}.btn-hard-delete:hover{background:var(--color-human-light)}.session-info{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--color-text-secondary);margin-bottom:8px}.session-info-sep{color:var(--color-text-muted)}.session-summary{display:flex;gap:8px}.detections-list{display:flex;flex-direction:column;gap:12px}.temp-chart{width:100%}.temp-chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.temp-chart-title{font-size:.85rem;font-weight:500;color:var(--color-text-secondary)}.temp-chart-current{font-size:.95rem;font-weight:600;color:var(--color-primary)}.temp-chart-svg{width:100%;height:auto}.temp-empty{font-size:.8rem;color:var(--color-text-muted);text-align:center;padding:12px 0}.size-calibrator{display:flex;flex-direction:column;gap:12px}.size-calibrator-preview{position:relative;width:150%;margin-left:-25%;aspect-ratio:16/9;background:#111;border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center}.size-calibrator-img{width:100%;height:100%;object-fit:contain;display:block}.size-calibrator-placeholder{color:var(--color-text-muted);font-size:.85rem}.size-calibrator-cat{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:2}.size-calibrator-cat svg{width:100%;height:100%}.size-calibrator-effective{display:none}.size-calibrator-controls{display:flex;flex-direction:column;gap:10px}.size-calibrator-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 0;border-top:1px solid var(--color-border)}.size-calibrator-slider-group{display:flex;align-items:center;gap:8px;flex-shrink:0}.size-calibrator-range{width:120px;accent-color:var(--color-primary)}.size-calibrator-value{font-size:.85rem;font-weight:600;min-width:40px;text-align:right}.size-calibrator-summary{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px;background:var(--color-bg);border-radius:var(--radius);font-size:.85rem}.size-calibrator-visual{color:var(--color-animal);font-weight:600}.size-calibrator-arrow{color:var(--color-text-muted)}.size-calibrator-eff{color:var(--color-human);font-weight:600}.size-calibrator-refresh{align-self:flex-start}.settings-section{margin-bottom:16px}.settings-section-title{font-size:.95rem;font-weight:600;margin-bottom:8px}.settings-hint{font-size:.8rem;color:var(--color-text-muted);margin-bottom:12px}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-top:1px solid var(--color-border)}.settings-label{font-size:.875rem;font-weight:500;display:flex;flex-direction:column}.settings-sublabel{font-size:.75rem;font-weight:400;color:var(--color-text-muted)}.settings-time{width:120px}.settings-number{width:80px;text-align:center}.settings-save{width:100%;margin-top:8px;padding:12px}.settings-error{color:var(--color-human);font-size:.85rem;margin-top:8px;text-align:center}.settings-admin-divider{display:flex;align-items:center;gap:12px;margin:28px 0 16px}.settings-admin-divider:before,.settings-admin-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.settings-admin-divider span{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.user-list{display:flex;flex-direction:column}.user-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-top:1px solid var(--color-border);gap:8px}.user-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.user-name{font-size:.875rem;font-weight:500}.user-inactive{font-size:.7rem;color:var(--color-text-muted);font-style:italic}.user-actions{display:flex;gap:6px;flex-shrink:0}.btn-sm{padding:4px 10px;font-size:.75rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;transition:background .15s}.btn-sm:hover{background:var(--color-bg)}.btn-sm-danger{color:var(--color-human);border-color:var(--color-human-light)}.btn-sm-danger:hover{background:var(--color-human-light)}.add-user-form{display:flex;flex-direction:column;gap:10px;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.add-user-buttons{display:flex;gap:8px}.user-edit-form{display:flex;flex-direction:column;gap:8px;padding:10px 0 14px;border-bottom:1px solid var(--color-border)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}.login-card{width:100%;max-width:360px;padding:32px 24px;text-align:center}.login-title{font-size:1.5rem;font-weight:700;color:var(--color-primary);margin-bottom:4px}.login-subtitle{font-size:.85rem;color:var(--color-text-muted);margin-bottom:24px}.login-field{margin-bottom:16px;text-align:left}.login-label{display:block;font-size:.85rem;font-weight:500;margin-bottom:4px}.login-error{color:var(--color-human);font-size:.85rem;margin-bottom:12px}.login-btn{width:100%;padding:12px;margin-top:4px}:root{--color-primary: #2d6a4f;--color-primary-hover: #1b4332;--color-primary-light: #d8f3dc;--color-animal: #e09f3e;--color-animal-light: #fef3c7;--color-human: #dc2626;--color-human-light: #fee2e2;--color-bg: #f9fafb;--color-surface: #ffffff;--color-border: #e5e7eb;--color-text: #111827;--color-text-secondary: #6b7280;--color-text-muted: #9ca3af;--radius: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1);--bottom-nav-height: 60px}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}body{padding-bottom:var(--bottom-nav-height)}a{color:var(--color-primary);text-decoration:none}button{cursor:pointer;font:inherit}input,select,textarea{font:inherit;color:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border:none;border-radius:var(--radius);font-weight:500;font-size:.875rem;transition:background-color .15s}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-ghost{background:transparent;color:var(--color-text-secondary);padding:6px 8px}.btn-ghost:hover{background:var(--color-border)}.input{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);outline:none;transition:border-color .15s}.input:focus{border-color:var(--color-primary)}.page{max-width:700px;margin:0 auto;padding:16px}.page-title{font-size:1.25rem;font-weight:600;margin-bottom:16px}.card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:12px}.empty-state{text-align:center;padding:48px 16px;color:var(--color-text-muted)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600}.badge-animal{background:var(--color-animal-light);color:#92400e}.badge-human{background:var(--color-human-light);color:#991b1b}.badge-deleted{background:#e5e7eb;color:#6b7280;margin-left:6px}
