*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --bg:#0f1209; --surface:#161a0e; --surface2:#1e2414; --border:#2c3320;
  --accent:#a8c44a; --accent2:#e8a030; --accent3:#5db87a;
  --text:#dde8c0; --muted:#6b7a50; --danger:#e05a3a;
  --mono:'DM Mono',monospace; --serif:'Playfair Display',Georgia,serif; --sans:'DM Sans',sans-serif;
  --radius:5px;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:14px;min-height:100vh}

/* HEADER */
header{background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;position:sticky;top:0;z-index:100}
.header-inner{max-width:1600px;margin:0 auto;height:64px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px}
.brand-emblem{font-size:28px}
.brand-title{display:block;font-family:var(--serif);font-size:16px;font-weight:700;color:var(--accent);letter-spacing:.08em;text-align:center}
.brand-sub{display:block;font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-top:1px;text-align:center}
.header-stats{display:flex;align-items:center;gap:4px}
.hstat{display:flex;flex-direction:column;align-items:center;padding:6px 14px;border-left:1px solid var(--border)}
.hstat-val{font-family:var(--mono);font-size:18px;font-weight:500;color:var(--accent);line-height:1}
.hstat-label{font-family:var(--mono);font-size:9px;color:var(--muted);margin-top:3px;letter-spacing:.08em;text-transform:uppercase}
.hstat-total .hstat-val{color:var(--accent2);font-size:22px}
.live-dot{color:var(--accent3);font-size:10px;padding-left:14px;animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}

/* LAYOUT */
.layout{display:grid;grid-template-columns:300px 1fr;max-width:1600px;margin:0 auto;min-height:calc(100vh - 64px)}
.sidebar{border-right:1px solid var(--border);padding:20px 16px;display:flex;flex-direction:column;gap:16px}
.main-content{padding:20px 24px 60px}

/* PANELS */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.panel-title{font-family:var(--serif);font-size:13px;font-weight:700;color:var(--accent);margin-bottom:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.panel-sub{font-family:var(--mono);font-size:10px;color:var(--muted);font-weight:400}
.panel-title select{font-family:var(--mono);font-size:11px;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:3px;padding:2px 6px}
.empty-panel{font-family:var(--mono);font-size:11px;color:var(--muted);padding:8px 0}

/* CALENDAR */
.calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cal-nav-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);width:28px;height:28px;border-radius:3px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:border-color .15s}
.cal-nav-btn:hover{border-color:var(--accent);color:var(--accent)}
.cal-month-label{font-family:var(--mono);font-size:12px;color:var(--text);font-weight:500}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-dow{font-family:var(--mono);font-size:9px;color:var(--muted);text-align:center;padding:4px 0;letter-spacing:.05em}
.cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:3px;cursor:pointer;border:1px solid transparent;transition:all .15s;font-family:var(--mono);font-size:11px}
.cal-day:hover{border-color:var(--accent);background:var(--surface2)}
.cal-day.has-detections{background:rgba(168,196,74,.1);border-color:rgba(168,196,74,.25)}
.cal-day.has-detections:hover{background:rgba(168,196,74,.2)}
.cal-day.selected{background:var(--accent)!important;border-color:var(--accent)!important;color:#0f1209!important;font-weight:700}
.cal-day.today{border-color:var(--accent2)}
.cal-day.empty{cursor:default;opacity:0;pointer-events:none}
.cal-count{font-size:8px;color:var(--accent);line-height:1;margin-top:1px}
.cal-day.selected .cal-count{color:#0f1209}
.clear-date-btn{display:block;text-align:center;margin-top:10px;font-family:var(--mono);font-size:11px;color:var(--danger);text-decoration:none}
.clear-date-btn:hover{text-decoration:underline}

/* FILTERS */
.filter-row{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.filter-row label{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.filter-row select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--mono);font-size:12px;padding:7px 10px;width:100%;outline:none;appearance:none;-webkit-appearance:none;transition:border-color .15s}
.filter-row select:focus,.filter-row select:hover{border-color:var(--accent)}

/* EXPORT PANEL */
.export-group{display:flex;flex-direction:column;gap:8px}
.export-group label{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.date-input{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--mono);font-size:12px;padding:7px 10px;width:100%;outline:none}
.date-input:focus{border-color:var(--accent)}
.btn-export{background:var(--accent);color:#0f1209;border:none;border-radius:var(--radius);padding:8px 14px;font-family:var(--mono);font-size:12px;font-weight:700;cursor:pointer;letter-spacing:.05em;transition:filter .15s;width:100%;margin-top:4px}
.btn-export:hover{filter:brightness(1.1)}
.btn-report{background:var(--accent2)}

/* SPECIES BARS */
.species-row{display:grid;grid-template-columns:80px 1fr 36px;align-items:center;gap:8px;margin-bottom:8px}
.species-name{font-family:var(--mono);font-size:11px;color:var(--text);text-transform:lowercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.species-bar-wrap{background:var(--surface2);border-radius:2px;height:6px}
.species-bar{background:linear-gradient(90deg,var(--accent3),var(--accent));height:100%;border-radius:2px;transition:width .4s ease}
.species-count{font-family:var(--mono);font-size:11px;color:var(--accent);text-align:right}

/* HOURLY CHART */
.hourly-chart{display:flex;align-items:flex-end;gap:2px;height:60px;position:relative}
.hr-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;position:relative}
.hr-bar{width:100%;background:var(--accent3);border-radius:2px 2px 0 0;min-height:2px;transition:height .3s ease;opacity:.8}
.hr-bar-wrap:hover .hr-bar{opacity:1;background:var(--accent)}
.hr-label{font-family:var(--mono);font-size:8px;color:var(--muted);position:absolute;bottom:-14px}

/* MONTHLY CHART */
.monthly-panel{margin-bottom:20px}
.monthly-chart{display:flex;align-items:flex-end;gap:6px;height:80px;margin-top:8px}
.mo-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:4px}
.mo-bar{width:100%;background:linear-gradient(to top,var(--accent3),var(--accent));border-radius:3px 3px 0 0;min-height:3px;transition:height .4s ease;cursor:pointer}
.mo-bar:hover{filter:brightness(1.2)}
.mo-label{font-family:var(--mono);font-size:9px;color:var(--muted)}
.mo-count{font-family:var(--mono);font-size:9px;color:var(--accent)}

/* RESULTS HEADER */
.results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.results-title{font-family:var(--serif);font-size:15px;color:var(--text);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.results-count{font-family:var(--mono);font-size:11px;color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:3px;padding:2px 8px}

/* DETECTION GRID */
.detection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .15s,border-color .15s,box-shadow .15s;animation:fadeUp .3s ease both}
.card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 6px 20px rgba(0,0,0,.4)}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.card.deleting{opacity:0;transform:scale(.95);transition:all .3s ease}
.card-img-wrap{position:relative;aspect-ratio:16/9;background:var(--surface2);overflow:hidden;cursor:pointer}
.card-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.card:hover .card-img-wrap img{transform:scale(1.04)}
.no-snapshot{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--muted)}
.no-snapshot span:first-child{font-size:28px}
.no-snapshot span:last-child{font-family:var(--mono);font-size:11px}
.card-overlay{position:absolute;bottom:0;left:0;right:0;padding:20px 10px 6px;background:linear-gradient(transparent,rgba(0,0,0,.75))}
.card-cam{font-family:var(--mono);font-size:10px;font-weight:500;color:#fff;letter-spacing:.05em}
.card-body{padding:10px 12px;display:flex;flex-direction:column;gap:6px}
.card-objects{display:flex;flex-wrap:wrap;gap:5px}
.tag{display:inline-block;background:rgba(168,196,74,.12);color:var(--accent);border:1px solid rgba(168,196,74,.3);border-radius:3px;font-family:var(--mono);font-size:10px;font-weight:500;padding:2px 7px;text-transform:lowercase}
.tag-dim{background:rgba(107,122,80,.1);color:var(--muted);border-color:var(--border)}
.card-time{font-family:var(--mono);font-size:10px;color:var(--muted)}

/* DELETE BUTTON */
.btn-delete{width:100%;margin-top:4px;background:transparent;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);font-family:var(--mono);font-size:11px;padding:6px;cursor:pointer;transition:all .15s;text-align:center}
.btn-delete:hover{background:rgba(224,90,58,.12);border-color:var(--danger);color:var(--danger)}

/* CONFIRM MODAL */
.confirm-modal{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:32px;max-width:380px;width:100%;text-align:center;animation:modalIn .2s ease}
.confirm-icon{font-size:40px;margin-bottom:12px}
.confirm-title{font-family:var(--serif);font-size:20px;color:var(--text);margin-bottom:10px}
.confirm-sub{font-family:var(--mono);font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:24px}
.confirm-btns{display:flex;gap:12px;justify-content:center}
.btn-cancel{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:var(--radius);padding:10px 24px;font-family:var(--mono);font-size:12px;cursor:pointer;transition:border-color .15s}
.btn-cancel:hover{border-color:var(--accent)}
.btn-confirm-delete{background:var(--danger);border:none;color:#fff;border-radius:var(--radius);padding:10px 24px;font-family:var(--mono);font-size:12px;font-weight:700;cursor:pointer;transition:filter .15s}
.btn-confirm-delete:hover{filter:brightness(1.15)}

/* PAGINATION */
.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:36px}
.pg-btn{font-family:var(--mono);font-size:12px;color:var(--accent);text-decoration:none;border:1px solid var(--border);padding:7px 16px;border-radius:var(--radius);transition:all .15s}
.pg-btn:hover{background:var(--surface2);border-color:var(--accent)}
.pg-info{font-family:var(--mono);font-size:12px;color:var(--muted)}

/* EMPTY STATE */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:12px;text-align:center}
.empty-icon{font-size:48px}
.empty-state p{font-family:var(--serif);font-size:16px;color:var(--muted)}
.empty-sub{font-family:var(--mono);font-size:12px;color:var(--muted);max-width:360px;line-height:1.6}

/* MODAL */
.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(8px);z-index:999;align-items:center;justify-content:center;padding:24px}
.modal-backdrop.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;max-width:900px;width:100%;position:relative;animation:modalIn .2s ease}
@keyframes modalIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.modal-close{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.6);border:1px solid var(--border);border-radius:50%;color:var(--text);width:30px;height:30px;cursor:pointer;font-size:12px;z-index:10;display:flex;align-items:center;justify-content:center;transition:background .15s}
.modal-close:hover{background:rgba(224,90,58,.4)}
.modal img{width:100%;display:block;max-height:540px;object-fit:contain;background:#000}
.modal-meta{padding:14px 18px;display:flex;flex-wrap:wrap;gap:16px;font-family:var(--mono);font-size:12px;color:var(--muted);border-top:1px solid var(--border)}
.modal-meta strong{color:var(--text);display:block;font-size:10px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}

/* TOAST */
.toast{position:fixed;bottom:24px;right:24px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--mono);font-size:12px;color:var(--text);padding:12px 20px;z-index:9999;transform:translateY(80px);opacity:0;transition:all .3s ease;pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{border-color:var(--accent3);color:var(--accent3)}
.toast.error{border-color:var(--danger);color:var(--danger)}

/* SCROLLBAR */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* RESPONSIVE */
@media(max-width:900px){
  .layout{grid-template-columns:1fr}
  .sidebar{border-right:none;border-bottom:1px solid var(--border)}
  .hstat:nth-child(n+4){display:none}
}

/* MegaDetector label tags */
.tag-md {
  background: rgba(232,160,48,0.15);
  color: var(--accent2);
  border: 1px solid rgba(232,160,48,0.35);
  border-radius: 3px;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  padding: 2px 7px;
  text-transform: lowercase;
  display: inline-block;
}
.tag-conf {
  background: rgba(93,184,122,0.12);
  color: var(--accent3);
  border: 1px solid rgba(93,184,122,0.25);
  border-radius: 3px;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  padding: 2px 6px;
  display: inline-block;
}
.camect-label {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--muted);
}

/* Majete logo in header */
.brand-logo {
  display: flex;
  align-items: center;
}
.brand-logo img {
  height: 44px;
  width: auto;
  object-fit: contain;
  border-radius: 3px;
}

/* ── FOOTER ──────────────────────────────────────────── */
.site-footer {
  background: var(--surface);
  border-top: 1px solid var(--border);
  padding: 16px 24px;
  margin-top: auto;
}
.footer-inner {
  max-width: 1600px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--muted);
}
.footer-divider {
  color: var(--border);
}
.footer-link {
  color: var(--accent);
  text-decoration: none;
  transition: color 0.15s;
}
.footer-link:hover {
  color: var(--text);
  text-decoration: underline;
}

/* ── Camera link & YouTube stream modal ──────────────── */
.card-meta-row {
  display: flex;
  align-items: center;
  margin-bottom: 4px;
}
.card-cam-link {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  color: #5bc8f5;
  text-decoration: none;
  letter-spacing: 0.04em;
  transition: color 0.15s;
}
.card-cam-link:hover {
  color: var(--accent);
  text-decoration: underline;
}
.card-cam-plain {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--muted);
}

/* Stream modal */
.stream-modal {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  max-width: 900px;
  width: 100%;
  animation: modalIn .2s ease;
}
.stream-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
}
.stream-title {
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 600;
  color: #5bc8f5;
}
.stream-body {
  position: relative;
  aspect-ratio: 16/9;
  background: #000;
}
.stream-body iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}
.stream-footer {
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  text-align: center;
}
.stream-yt-btn {
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  color: #ff4444;
  text-decoration: none;
  padding: 6px 16px;
  border: 1px solid rgba(255,68,68,0.3);
  border-radius: var(--radius);
  background: rgba(255,68,68,0.08);
  transition: all 0.15s;
}
.stream-yt-btn:hover {
  background: rgba(255,68,68,0.18);
  border-color: #ff4444;
}
