/* ============================================================
   Explora Investor Deck — Reusable components
   ============================================================ */

/* ---------- title block ---------- */
.eyebrow {
  font-size:var(--fs-eyebrow); font-weight:700;
  letter-spacing:3.4px; text-transform:uppercase;
  color:var(--honey-dk);
}
.slide.dark .eyebrow,.slide.jungle .eyebrow { color:var(--honey); }

.slide-title {
  font-family:var(--font-serif); font-weight:800;
  font-size:var(--fs-title); line-height:1.08; color:var(--jungle);
  letter-spacing:-.6px;
  text-transform:uppercase;
}
.slide.dark .slide-title,.slide.jungle .slide-title { color:var(--on-dark); }
.slide-title em { font-style:normal; font-weight:700; color:var(--honey-dk); }
.slide.dark .slide-title em,.slide.jungle .slide-title em { color:var(--honey); }

.standfirst {
  font-family:var(--font-sans); font-style:normal; font-weight:400;
  font-size:var(--fs-sub); line-height:1.5; color:var(--muted);
  max-width:830px;
}
.slide.dark .standfirst,.slide.jungle .standfirst { color:var(--on-dark-soft); }

.title-block { margin-bottom:30px; }
.title-block .eyebrow { display:block; margin-bottom:11px; }
.title-block .standfirst { margin-top:13px; }

.accent-rule { width:54px; height:3px; background:var(--honey-dk); border-radius:2px; margin-top:16px; }
.slide.dark .accent-rule { background:var(--honey); }

/* ---------- footer ---------- */
.slide-footer {
  position:absolute; left:76px; right:76px; bottom:30px;
  display:flex; justify-content:space-between; align-items:center;
  font-size:var(--fs-micro); color:var(--muted);
  letter-spacing:.4px;
}
.slide.dark .slide-footer,.slide.jungle .slide-footer { color:var(--on-dark-faint); }
.slide-footer .src { font-style:italic; }

/* ---------- cards ---------- */
.card {
  background:#fff; border:var(--border); border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
.slide.dark .card,.slide.jungle .card {
  background:rgba(242,235,219,.06); border:var(--border-dark); box-shadow:none;
}

/* numbered card (slide 2) */
.num-card { padding:24px 24px 26px; display:flex; flex-direction:column; }
.num-card .nc-index {
  font-family:var(--font-serif); font-size:30px; font-weight:800;
  color:var(--honey-dk); line-height:1; margin-bottom:13px;
}
.num-card .nc-title {
  font-size:18px; font-weight:600; color:var(--jungle);
  line-height:1.22; margin-bottom:10px;
}
.num-card .nc-desc { font-size:13.5px; line-height:1.55; color:var(--muted); }
.num-card .nc-fig {
  margin-top:auto; padding-top:14px; font-size:14.5px;
  line-height:1.42; color:var(--jungle-md); font-weight:600;
}
.num-card .nc-fig b { color:var(--terra); }
.num-card .nc-bar { height:3px; border-radius:2px; background:var(--sand); margin-bottom:16px; }

/* stat / KPI */
.kpi .kpi-label {
  font-size:var(--fs-label); font-weight:600; letter-spacing:1.6px;
  text-transform:uppercase; color:var(--jungle-lt);
}
.kpi .kpi-note { font-size:12px; font-style:italic; color:var(--muted); margin-top:1px; }
.kpi .kpi-value {
  font-size:54px; font-weight:600; color:var(--jungle);
  line-height:1; letter-spacing:-1px; margin:8px 0 6px;
}
.kpi .kpi-cap {
  font-size:12.5px; color:var(--muted); line-height:1.5;
  padding-top:9px; border-top:var(--border);
}

/* pill / badge */
.pill {
  display:inline-flex; align-items:center; gap:6px;
  font-size:var(--fs-micro); font-weight:600;
  letter-spacing:1.3px; text-transform:uppercase;
  padding:6px 14px; border-radius:var(--radius-pill);
  background:var(--sage-xl); color:var(--jungle-md);
}
.pill.terra { background:#F0DDD3; color:var(--terra); }
.pill.blush { background:var(--blush); color:var(--jungle); }
.pill.solid { background:var(--jungle-md); color:var(--on-dark); }

/* threat tag */
.threat { font-weight:600; font-size:12px; }
.threat.high { color:var(--terra); }
.threat.medium { color:#C68A2E; }
.threat.low { color:var(--jungle-lt); }
.threat::before {
  content:""; display:inline-block; width:7px; height:7px;
  border-radius:50%; margin-right:6px; vertical-align:1px;
  background:currentColor;
}

/* ---------- buttons ---------- */
.btn {
  display:inline-flex; align-items:center; gap:9px;
  font-size:13px; font-weight:600; letter-spacing:.6px;
  padding:13px 26px; border-radius:var(--radius-pill);
  transition:transform var(--dur) var(--ease), background var(--dur) var(--ease);
}
.btn:hover { transform:translateY(-2px); }
.btn-primary { background:var(--sage); color:var(--jungle); }
.btn-primary:hover { background:var(--sage-lt); }
.btn-ghost { border:1px solid rgba(242,235,219,.35); color:var(--on-dark); }
.btn-ghost:hover { background:rgba(242,235,219,.1); }

/* ---------- data table (slides 10 & 11) ---------- */
.dtable { width:100%; border-collapse:separate; border-spacing:0; }
.dtable thead th {
  text-align:left; font-size:11px; font-weight:600;
  letter-spacing:1.4px; text-transform:uppercase; color:var(--jungle-lt);
  padding:13px 18px; background:var(--cream-dk);
  border-bottom:1px solid var(--sand);
}
.dtable thead th:first-child { border-radius:var(--radius-sm) 0 0 0; }
.dtable thead th:last-child  { border-radius:0 var(--radius-sm) 0 0; }
.comp-row {
  cursor:pointer;
  transition:background var(--dur) var(--ease);
}
.comp-row > td {
  padding:13px 18px; border-bottom:1px solid var(--sand);
  vertical-align:top; font-size:13.5px;
}
.comp-row:hover { background:#fff; }
.comp-row .c-name { font-weight:600; color:var(--jungle); font-size:14.5px; }
.comp-row .c-loc { font-size:11.5px; color:var(--muted); margin-top:2px; }
.comp-row .c-seg { color:var(--muted); }
.comp-row .c-dist { font-weight:600; color:var(--jungle); }
.comp-row .c-toggle {
  width:24px; height:24px; border-radius:50%;
  border:1px solid var(--sand); color:var(--jungle-md);
  display:grid; place-items:center; font-size:15px;
  transition:transform var(--dur) var(--ease), background var(--dur) var(--ease);
}
.comp-row.open .c-toggle { transform:rotate(45deg); background:var(--jungle-md); color:#fff; border-color:var(--jungle-md); }
.comp-detail > td { padding:0 18px; border-bottom:1px solid var(--sand); }
.comp-detail .cd-inner {
  display:grid; grid-template-columns:1.4fr 1fr; gap:24px;
  max-height:0; overflow:hidden;
  transition:max-height var(--dur-lg) var(--ease), padding var(--dur-lg) var(--ease);
}
.comp-row.open + .comp-detail .cd-inner { max-height:200px; padding:4px 0 18px; }
.cd-block .cd-h {
  font-size:10.5px; font-weight:600; letter-spacing:1.4px;
  text-transform:uppercase; color:var(--jungle-lt); margin-bottom:6px;
}
.cd-block p { font-size:13px; line-height:1.6; color:var(--jungle-md); }
.cd-block.adv { background:var(--sage-xl); border-radius:var(--radius-sm); padding:14px 16px; }
.cd-block.adv .cd-h { color:var(--jungle-md); }
.cd-block.adv.pending p { font-style:italic; color:var(--muted); }

/* ---------- hotspot (slide: building) ---------- */
.hotspot {
  position:absolute; width:34px; height:34px;
  transform:translate(-50%,-50%);
}
.hotspot button {
  width:100%; height:100%; border-radius:50%;
  background:var(--honey); color:var(--jungle);
  font-size:17px; font-weight:700; display:grid; place-items:center;
  box-shadow:0 0 0 0 rgba(232,199,127,.7);
  animation:pulse 2.4s infinite;
}
@keyframes pulse {
  0% { box-shadow:0 0 0 0 rgba(232,199,127,.6); }
  70% { box-shadow:0 0 0 16px rgba(232,199,127,0); }
  100% { box-shadow:0 0 0 0 rgba(232,199,127,0); }
}
.hotspot .hs-card {
  position:absolute; left:50%; bottom:46px; transform:translateX(-50%) translateY(8px);
  width:210px; background:#fff; border-radius:var(--radius-sm);
  padding:13px 15px; box-shadow:var(--shadow-lg);
  opacity:0; pointer-events:none;
  transition:opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.hotspot.open .hs-card { opacity:1; transform:translateX(-50%) translateY(0); }
.hotspot .hs-card h4 { font-size:14px; color:var(--jungle-md); margin-bottom:4px; }
.hotspot .hs-card p { font-size:12px; color:var(--muted); line-height:1.5; }

/* ---------- placeholder panel (content gaps) ---------- */
.placeholder {
  border:1.5px dashed var(--sand); border-radius:var(--radius);
  background:repeating-linear-gradient(45deg,#fff,#fff 14px,var(--cream) 14px,var(--cream) 28px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:30px; gap:8px;
}
.placeholder .ph-tag {
  font-size:10.5px; font-weight:600; letter-spacing:1.6px; text-transform:uppercase;
  color:var(--terra); background:#F0DDD3; padding:5px 12px; border-radius:var(--radius-pill);
}
.placeholder h4 { font-family:var(--font-serif); font-size:21px; color:var(--jungle); font-weight:600; }
.placeholder p { font-size:13px; color:var(--muted); max-width:420px; line-height:1.6; }

/* ---------- generic helpers ---------- */
.chip {
  display:inline-block; font-size:12px; color:var(--jungle-md);
  background:var(--cream-dk); border:var(--border);
  padding:5px 12px; border-radius:var(--radius-pill); margin:0 5px 7px 0;
}
.icon-badge {
  width:46px; height:46px; border-radius:13px;
  display:grid; place-items:center; flex:none;
}
.icon-badge svg { width:24px; height:24px; }
