/* Canopy dashboard component styles (UI redesign P3).
   Split out of canopy.css to keep each stylesheet under the 300-line cap.
   Uses the same brand tokens defined in canopy.css :root. Loaded after it. */

/* ---- Dashboard: next-step hero + room status tiles + toolbar ------------- */
.notice-dark {
  background: var(--card); border: 1px solid var(--border);
  border-left: 6px solid var(--burgundy); border-radius: 11px;
  padding: 12px 18px; margin: 12px 0;
}
.notice-dark h3 { margin: 0 0 6px; color: var(--burgundy); }

.hero {
  background: var(--card); border: 1px solid var(--border);
  border-left: 6px solid var(--green); border-radius: 12px;
  padding: 18px 22px; margin: 12px 0 18px;
  box-shadow: 0 3px 9px rgba(94,42,48,.06);
}
.hero h2 { font-size: 24px; margin: 0 0 6px; color: var(--burgundy); }
.hero-readiness { margin: 4px 0 8px; color: var(--muted); font-weight: 700; }
.progress {
  height: 9px; background: var(--panel); border: 1px solid var(--panel-border);
  border-radius: 6px; overflow: hidden; margin: 0 0 12px; max-width: 360px;
}
.progress-fill { display: block; height: 100%; background: var(--green); }
.hero-cta { margin: 8px 0 4px; }

.room-grid {
  /* align-items:start so opening one <details> tile never stretches the height
     of its row neighbours (P4 layout-jank fix). */
  display: grid; gap: 12px; margin: 8px 0 18px; align-items: start;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}
.room-tile {
  background: var(--card); border: 1px solid var(--border);
  border-left: 5px solid var(--faint); border-radius: 10px; padding: 0;
}
/* Coverage gradient (P4): green / yellow-green / orange / red, derived from the
   brand tokens. Neutral (nothing to monitor) keeps the faint default. */
.room-tile.room-level-green { border-left-color: var(--green); }
.room-tile.room-level-yellow-green { border-left-color: var(--green-light); }
.room-tile.room-level-orange { border-left-color: var(--gold); }
.room-tile.room-level-red { border-left-color: var(--burgundy); }
.room-tile.room-level-neutral { border-left-color: var(--border); }
.room-icon { color: var(--green-dark); flex: 0 0 auto; }

/* Gradient coverage badge (the OOB-swappable p/t pill). */
.badge-level-green { background: var(--green); color: #fff; border-color: var(--green-dark); }
.badge-level-yellow-green { background: var(--green-light); color: var(--text); border-color: var(--green); }
.badge-level-orange { background: var(--gold); color: #fff; border-color: var(--gold); }
.badge-level-red { background: var(--burgundy); color: #fff; border-color: var(--burgundy); }
.badge-level-neutral { background: var(--panel); color: var(--muted); border-color: var(--border); }

/* Add-all-suggested-sensors card, above the room grid. */
.add-all-card {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  flex-wrap: wrap; margin: 8px 0 14px; padding: 14px 18px;
  background: var(--panel); border: 1px solid var(--panel-border);
  border-radius: 11px;
}
.add-all-card h3 { margin: 0 0 2px; color: var(--green-dark); }
.add-all-card form { margin: 0; }

/* Redo-guided-setup entry + clearly-separated destructive delete zone (P4-4c). */
.setup-rerun { margin: 14px 0 6px; }
.danger-zone {
  margin: 14px 0; padding: 8px 14px; border: 1px solid var(--border);
  border-left: 5px solid var(--burgundy); border-radius: 10px; background: var(--card);
}
.danger-zone > summary {
  cursor: pointer; font-weight: 700; color: var(--burgundy); list-style: none;
}
.danger-zone > summary::-webkit-details-marker { display: none; }
.btn.danger { background: var(--burgundy); border-color: var(--burgundy); color: #fff; }
.placement { margin: 4px 0; }
.placement > summary { cursor: pointer; color: var(--muted); font-size: 12.5px; }
.room-tile > summary {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  cursor: pointer; padding: 12px 14px; list-style: none;
}
.room-tile > summary::-webkit-details-marker { display: none; }
.room-tile > summary::after { content: "\25BE"; margin-left: auto; color: var(--faint); }
.room-tile[open] > summary::after { content: "\25B4"; }
.room-name { font-weight: 700; color: var(--green-dark); }
.room-body { padding: 0 14px 14px; }
.goal-list { list-style: none; padding-left: 0; margin: 6px 0; }
.goal-list li { padding: 4px 0; border-bottom: 1px solid var(--border); }
.room-edit { margin-top: 8px; }
.room-edit > summary { cursor: pointer; font-weight: 700; color: var(--muted); }
.empty-rooms { color: var(--muted); margin: 12px 0; }

.toolbar { display: flex; gap: 10px; flex-wrap: wrap; margin: 14px 0; }
.toolbar .tbtn { display: inline-flex; align-items: center; gap: 6px; }
.icon-sm { width: 16px; height: 16px; vertical-align: middle; }
.add-room { margin: 10px 0; }
.add-room > summary {
  display: inline-flex; align-items: center; gap: 6px; cursor: pointer;
  font-weight: 700; color: var(--green-dark);
}

/* ---- Browse: square-ish sensor card grid (UI overhaul P6) ---------------- */
.browse-grid {
  display: grid; gap: 12px; margin: 8px 0 18px; align-items: start;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}
.browse-card {
  display: flex; flex-direction: column; gap: 6px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 11px; padding: 16px;
}
.browse-icon { width: 40px; height: 40px; color: var(--green-dark); }
.browse-goal { margin: 2px 0 0; font-size: 16px; color: var(--burgundy); }
.browse-meta { margin: 0; }
.browse-add {
  margin: 4px 0 0; display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
}
.browse-add select { flex: 1 1 auto; min-width: 0; }
.browse-details > summary { cursor: pointer; color: var(--muted); font-size: 12.5px; }

/* ---- Inline room rename: pencil -> text field + check/x (UI overhaul P6) -- */
.room-rename { display: flex; align-items: center; gap: 6px; margin: 0 0 8px; }
.room-rename-text { font-weight: 700; color: var(--green-dark); }
.room-rename-edit input[type="text"] { flex: 1 1 auto; min-width: 0; }
.iconbtn {
  display: inline-flex; align-items: center; justify-content: center;
  background: none; border: 1px solid var(--border); border-radius: 7px;
  color: var(--green-dark); cursor: pointer; padding: 3px 6px;
}
.iconbtn:hover { background: var(--panel); }
.field-error { color: var(--burgundy); font-size: 12.5px; }
