/*
 * Urban Tree Calculator — Frontend Evaluator Portal
 * Mobile-first, PWA-ready layout
 * Depends on shell.css for design tokens (--utc-accent, --utc-border, etc.)
 */

/* ── Reset WP admin interference on frontend ─────────────────── */
.utc-portal *, .utc-portal *::before, .utc-portal *::after {
  box-sizing: border-box;
}

/* ── Portal root ──────────────────────────────────────────────── */
.utc-portal {
  --utc-portal-header-h: 60px;
  --utc-portal-botnav-h: 64px;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
  color: var(--utc-text, #111);
  background: var(--utc-bg, #FAFAFA);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  /* Compensate for WP admin bar if present */
  padding-bottom: var(--utc-portal-botnav-h);
}

/* ── Header ───────────────────────────────────────────────────── */
.utc-portal-header {
  position: sticky;
  top: 0;
  z-index: 200;
  height: var(--utc-portal-header-h);
  background: #fff;
  border-bottom: 1px solid var(--utc-border, #E5E5E5);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 20px;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}

.utc-portal-brand {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 17px;
  font-weight: 600;
  color: var(--utc-accent, #166534);
  flex-shrink: 0;
  text-decoration: none;
}
.utc-portal-brand strong { font-weight: 800; }
.utc-portal-brand-icon { font-size: 20px; line-height: 1; }

/* Top tabs (desktop) */
.utc-portal-topnav {
  display: flex;
  gap: 2px;
  flex: 1;
  overflow-x: auto;
  scrollbar-width: none;
}
.utc-portal-topnav::-webkit-scrollbar { display: none; }
.utc-portal-tab {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 14px;
  border-radius: 7px;
  font-size: 13px;
  font-weight: 600;
  color: var(--utc-muted, #888);
  text-decoration: none;
  white-space: nowrap;
  border: none;
  background: none;
  cursor: pointer;
  transition: background .15s, color .15s;
  position: relative;
}
.utc-portal-tab:hover  { background: var(--utc-bg, #FAFAFA); color: var(--utc-accent, #166534); }
.utc-portal-tab.active { background: #f0fdf4; color: var(--utc-accent, #166534); font-weight: 700; }
.utc-portal-tab-badge {
  background: #ef4444; color: #fff;
  font-size: 10px; font-weight: 800;
  min-width: 17px; height: 17px;
  border-radius: 9px; padding: 0 4px;
  display: inline-flex; align-items: center; justify-content: center;
}

/* User info */
.utc-portal-user {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.utc-portal-avatar {
  width: 34px; height: 34px;
  background: var(--utc-accent, #166534);
  color: #fff;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 14px;
}
.utc-portal-user-info { display: none; }
.utc-portal-user-name { font-size: 13px; font-weight: 700; }
.utc-portal-user-role { font-size: 11px; color: var(--utc-muted, #888); }
.utc-portal-logout {
  font-size: 18px;
  color: var(--utc-muted, #888);
  text-decoration: none;
  padding: 4px;
  border-radius: 6px;
  transition: color .15s;
}
.utc-portal-logout:hover { color: var(--utc-danger, #dc2626); }

/* ── Body ─────────────────────────────────────────────────────── */
.utc-portal-body {
  flex: 1;
  max-width: 900px;
  width: 100%;
  margin: 0 auto;
  padding: 16px 14px;
}

/* ── Panels (tabs) ────────────────────────────────────────────── */
.utc-portal-panel { display: none; }
.utc-portal-panel.active { display: block; }

/* ── Welcome ──────────────────────────────────────────────────── */
.utc-portal-welcome {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.utc-portal-alert {
  background: #FEE2E2;
  color: #991B1B;
  font-size: 12px;
  padding: 3px 10px;
  border-radius: 20px;
  font-weight: 700;
}

/* ── KPI strip ────────────────────────────────────────────────── */
.utc-portal-kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 16px;
}
.utc-portal-kpi {
  background: #fff;
  border: 1px solid var(--utc-border, #E5E5E5);
  border-radius: 10px;
  padding: 14px 16px;
}
.utc-portal-kpi-val {
  font-size: 24px;
  font-weight: 800;
  color: var(--utc-accent, #166534);
  line-height: 1;
  margin-bottom: 4px;
}
.utc-portal-kpi-lbl {
  font-size: 11px;
  color: var(--utc-muted, #888);
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* ── Quick actions ────────────────────────────────────────────── */
.utc-portal-actions {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-bottom: 18px;
}
.utc-portal-action-btn {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 11px 14px;
  background: #fff;
  border: 1.5px solid var(--utc-border, #E5E5E5);
  border-radius: 9px;
  font-size: 13px;
  font-weight: 600;
  color: var(--utc-text, #111);
  cursor: pointer;
  text-decoration: none;
  transition: border-color .15s, background .15s;
  white-space: nowrap;
}
.utc-portal-action-btn:hover { border-color: var(--utc-accent, #166534); color: var(--utc-accent, #166534); }
.utc-portal-action-primary {
  background: var(--utc-accent, #166534);
  color: #fff !important;
  border-color: var(--utc-accent, #166534);
}
.utc-portal-action-primary:hover { background: #14532d; }

/* ── Sections ─────────────────────────────────────────────────── */
.utc-portal-section {
  background: #fff;
  border: 1px solid var(--utc-border, #E5E5E5);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 14px;
}
.utc-portal-section-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--utc-muted, #888);
  margin-bottom: 12px;
}

/* ── Tables ───────────────────────────────────────────────────── */
.utc-portal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.utc-portal-table thead th {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--utc-muted, #888);
  border-bottom: 1px solid var(--utc-border, #E5E5E5);
  padding: 6px 8px;
  text-align: left;
  white-space: nowrap;
}
.utc-portal-table thead th.r { text-align: right; }
.utc-portal-table thead th.c { text-align: center; }
.utc-portal-table td { padding: 9px 8px; border-bottom: 1px solid #f3f4f6; }
.utc-portal-table td.r { text-align: right; }
.utc-portal-table td.c { text-align: center; }
.utc-portal-table tr:last-child td { border-bottom: none; }
.utc-portal-table tr:hover td { background: #fafafa; }

/* ── Task rows ────────────────────────────────────────────────── */
.utc-portal-task-group { margin-bottom: 16px; }
.utc-portal-task-group-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--utc-muted, #888);
  margin-bottom: 8px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--utc-border, #E5E5E5);
}
.utc-portal-task-row {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: #fff;
  border: 1px solid var(--utc-border, #E5E5E5);
  border-radius: 9px;
  padding: 12px 14px;
  margin-bottom: 8px;
  transition: border-color .15s;
}
.utc-portal-task-row:hover { border-color: var(--utc-accent, #166534); }
.utc-portal-task-row.overdue { border-color: #FCA5A5; background: #FFF5F5; }
.utc-portal-task-row.done { opacity: .55; }
.utc-portal-task-info { flex: 1; min-width: 0; }
.utc-portal-task-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  flex-shrink: 0;
}
.utc-portal-task-date {
  font-size: 11px;
  color: var(--utc-muted, #888);
  white-space: nowrap;
}
.utc-portal-task-date.overdue { color: #991B1B; font-weight: 700; }

.utc-portal-priority-dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  margin-left: 5px;
  vertical-align: middle;
}
.utc-portal-priority-dot.urgent { background: #e63946; }
.utc-portal-priority-dot.high   { background: #f4a261; }
.utc-portal-priority-dot.normal { background: #40916c; }
.utc-portal-priority-dot.low    { background: #adb5bd; }

/* ── Buttons ──────────────────────────────────────────────────── */
.utc-portal-done-btn {
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  background: #f0fdf4;
  color: #166534;
  border: 1px solid #86efac;
  border-radius: 6px;
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
}
.utc-portal-done-btn:hover { background: #dcfce7; }

.utc-portal-link-btn {
  background: none;
  border: none;
  color: var(--utc-accent, #166534);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
  text-decoration: underline;
}

/* ── Map ──────────────────────────────────────────────────────── */
.utc-portal-map-stats {
  display: flex;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 12px;
  font-size: 13px;
}
.utc-portal-map-stat { display: flex; align-items: center; gap: 5px; }
.utc-portal-map-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
#utcPortalMap {
  height: 460px;
  border-radius: 10px;
  border: 1px solid var(--utc-border, #E5E5E5);
  overflow: hidden;
}

/* ── Map filter bar ───────────────────────────────────────────── */
.utc-pmap-filter-wrap {
  margin-bottom: 10px;
}
.utc-pmap-top-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}
.utc-pmap-cond-chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  flex: 1;
}
.utc-pmap-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 11px;
  border-radius: 20px;
  border: 1.5px solid var(--utc-border, #ddd);
  background: #fff;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  color: var(--utc-text, #333);
  white-space: nowrap;
}
.utc-pmap-chip:hover {
  border-color: var(--chip-color, #1b4d3e);
  color: var(--chip-color, #1b4d3e);
}
.utc-pmap-chip.active {
  background: var(--chip-color, #1b4d3e);
  border-color: var(--chip-color, #1b4d3e);
  color: #fff;
}
.utc-pmap-chip--all { --chip-color: #1b4d3e; }
.utc-pmap-chip-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--chip-color, #ccc);
  flex-shrink: 0;
  transition: background .15s;
}
.utc-pmap-chip.active .utc-pmap-chip-dot { background: rgba(255,255,255,.7); }
.utc-pmap-chip-cnt {
  font-size: 10px;
  opacity: .75;
  font-weight: 700;
}
.utc-pmap-bar-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.utc-pmap-counter {
  font-size: 12px;
  color: var(--utc-muted, #666);
  white-space: nowrap;
}
.utc-pmap-adv-btn {
  position: relative;
  padding: 5px 12px;
  border-radius: 8px;
  border: 1.5px solid var(--utc-border, #ddd);
  background: #fff;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  color: var(--utc-text, #333);
  transition: border-color .15s, background .15s;
  white-space: nowrap;
}
.utc-pmap-adv-btn:hover,
.utc-pmap-adv-btn.active {
  border-color: #1b4d3e;
  background: #f0faf5;
  color: #1b4d3e;
}
.utc-pmap-adv-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  border-radius: 8px;
  background: #1b4d3e;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  margin-left: 4px;
}
/* Advanced panel */
.utc-pmap-adv-panel {
  background: #f8faf9;
  border: 1px solid var(--utc-border, #e0e0e0);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: flex-start;
}
.utc-pmap-adv-section {
  min-width: 160px;
}
.utc-pmap-adv-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--utc-muted, #888);
  margin-bottom: 6px;
}
.utc-pmap-select {
  width: 100%;
  padding: 6px 10px;
  border-radius: 7px;
  border: 1.5px solid var(--utc-border, #ddd);
  font-size: 13px;
  background: #fff;
  color: var(--utc-text, #333);
  cursor: pointer;
}
.utc-pmap-toggle-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  cursor: pointer;
  margin-bottom: 6px;
}
.utc-pmap-toggle-row input[type="checkbox"] {
  width: 15px; height: 15px;
  accent-color: #1b4d3e;
  cursor: pointer;
}
.utc-pmap-radio-row {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  cursor: pointer;
  margin-bottom: 4px;
}
.utc-pmap-radio-row input[type="radio"] {
  accent-color: #1b4d3e;
  cursor: pointer;
}
#utcPmapWorksDetail {
  padding-left: 22px;
  margin-top: 4px;
}
.utc-pmap-reset-btn {
  align-self: flex-end;
  margin-top: auto;
  padding: 6px 14px;
  border-radius: 7px;
  border: 1.5px solid #d1d5db;
  background: #fff;
  font-size: 12px;
  font-weight: 600;
  color: #6b7280;
  cursor: pointer;
  transition: border-color .15s, color .15s;
  white-space: nowrap;
}
.utc-pmap-reset-btn:hover {
  border-color: #1b4d3e;
  color: #1b4d3e;
}
@media (max-width: 640px) {
  .utc-pmap-adv-panel { flex-direction: column; gap: 12px; }
  .utc-pmap-adv-section { min-width: unset; width: 100%; }
  .utc-pmap-reset-btn { align-self: flex-start; }
  #utcPortalMap { height: 380px; }
}

/* ── Empty state ──────────────────────────────────────────────── */
.utc-portal-empty {
  text-align: center;
  padding: 48px 24px;
  color: var(--utc-text, #111);
}

/* ── Login wall ───────────────────────────────────────────────── */
.utc-portal-login-wall {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  padding: 24px;
}
.utc-portal-login-box {
  background: #fff;
  border: 1px solid var(--utc-border, #E5E5E5);
  border-radius: 14px;
  padding: 36px 40px;
  max-width: 420px;
  width: 100%;
  text-align: center;
  box-shadow: 0 4px 24px rgba(0,0,0,.08);
}
.utc-portal-login-icon { font-size: 48px; margin-bottom: 12px; }
.utc-portal-login-box h2 { font-size: 20px; font-weight: 800; margin: 0 0 10px; }
.utc-portal-login-box p  { font-size: 14px; color: var(--utc-muted, #888); margin: 0 0 20px; }
.utc-portal-login-btn {
  display: inline-block;
  background: var(--utc-accent, #166534);
  color: #fff;
  padding: 12px 28px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  transition: background .15s;
}
.utc-portal-login-btn:hover { background: #14532d; }

/* ── Bottom navigation (mobile) ───────────────────────────────── */
.utc-portal-bottomnav {
  display: flex;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: var(--utc-portal-botnav-h);
  background: #fff;
  border-top: 1px solid var(--utc-border, #E5E5E5);
  z-index: 300;
  box-shadow: 0 -2px 12px rgba(0,0,0,.08);
}
.utc-portal-botnav-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--utc-muted, #888);
  font-size: 11px;
  font-weight: 600;
  padding: 8px 4px;
  position: relative;
  transition: color .15s;
}
.utc-portal-botnav-item.active { color: var(--utc-accent, #166534); }
.utc-portal-botnav-icon { font-size: 20px; line-height: 1; }
.utc-portal-botnav-lbl { font-size: 10px; }
.utc-portal-botnav-badge {
  position: absolute;
  top: 5px; right: calc(50% - 16px);
  background: #ef4444; color: #fff;
  font-size: 9px; font-weight: 800;
  min-width: 15px; height: 15px;
  border-radius: 8px; padding: 0 3px;
  display: flex; align-items: center; justify-content: center;
}

/* ── Responsive: tablet and up ────────────────────────────────── */
@media (min-width: 640px) {
  .utc-portal-actions { grid-template-columns: repeat(4, 1fr); }
  .utc-portal-user-info { display: block; }
  .utc-portal-body { padding: 20px 24px; }
}

/* ── Responsive: desktop ─────────────────────────────────────────*/
@media (min-width: 900px) {
  /* Hide bottom nav on desktop, use top tabs instead */
  .utc-portal-bottomnav { display: none; }
  .utc-portal { padding-bottom: 0; }
  .utc-portal-kpis { gap: 14px; }
  .utc-portal-kpi-val { font-size: 28px; }
  #utcPortalMap { height: 520px; }
}

/* ── PWA standalone mode adjustments ─────────────────────────── */
@media (display-mode: standalone) {
  .utc-portal-header { top: env(safe-area-inset-top, 0); }
  .utc-portal-bottomnav {
    padding-bottom: env(safe-area-inset-bottom, 0);
    height: calc(var(--utc-portal-botnav-h) + env(safe-area-inset-bottom, 0));
  }
}

/* ── Leaflet popup override ───────────────────────────────────── */
#utcPortalMap .leaflet-popup-content-wrapper {
  border-radius: 10px;
  box-shadow: 0 4px 20px rgba(0,0,0,.15);
}
