/* style.css · Círculo Vivo dashboard styles.
   Shared by the standalone story.html and the Observable Framework page.
   Tokens mirror shiny/www/styles.css. */

:root{
  --cv-teal:#0D9B8C; --cv-teal-dark:#0A7A6E; --cv-teal-light:#E6F5F3;
  --cv-navy:#1B365D; --cv-gold:#D4A843; --cv-crimson:#C0392B;
  --cv-bg:#F0F5F2; --cv-surface:#FFFFFF; --cv-border:#D0DDD8;
  --cv-text:#2D3748; --cv-muted:#718096;
  --radius:8px;
  --shadow:0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);
  --shadow-lg:0 10px 30px rgba(27,54,93,.10),0 2px 8px rgba(0,0,0,.05);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--cv-bg); color:var(--cv-text);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  -webkit-font-smoothing:antialiased;
}

/* ── Masthead ─────────────────────────────────────────────────────────────── */
.masthead{ max-width:1080px; margin:0 auto; padding:70px 24px 40px; }
.kicker-brand{
  display:inline-flex; align-items:center; gap:8px;
  font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:var(--cv-teal-dark); margin-bottom:20px;
}
.kicker-brand::before{ content:""; width:26px; height:3px; background:var(--cv-crimson); border-radius:2px; }
.masthead h1{
  font-family:'Lora',Georgia,serif;
  font-size:clamp(34px,5vw,58px); line-height:1.04; font-weight:600;
  color:var(--cv-navy); margin:0 0 18px; letter-spacing:-.01em; max-width:17ch;
}
.masthead .standfirst{
  font-size:clamp(17px,2vw,21px); line-height:1.5; color:var(--cv-text);
  max-width:62ch; margin:0 0 10px; font-weight:400;
}
.masthead .byline{
  font-size:15px; color:var(--cv-muted); margin-top:22px;
  padding-top:16px; border-top:1px solid var(--cv-border); max-width:60ch;
  font-style:italic;
}

/* ── Bands (full-width sections) ──────────────────────────────────────────── */
.band{ padding:56px 0; border-top:1px solid var(--cv-border); }
.band-alt{ background:linear-gradient(180deg,#EAF2EE 0%, var(--cv-bg) 100%); }
.band-inner{ max-width:1080px; margin:0 auto; padding:0 24px; }
.band-inner.narrow{ max-width:760px; }
.section-eyebrow{
  font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--cv-teal-dark); margin-bottom:10px;
}
.section-title{
  font-family:'Lora',Georgia,serif; font-weight:600; font-size:clamp(24px,3.2vw,34px);
  line-height:1.18; color:var(--cv-navy); margin:0 0 22px; letter-spacing:-.01em;
}
.prose{ max-width:64ch; }
.prose.narrow{ max-width:60ch; }
.prose p{ font-size:16px; line-height:1.65; color:var(--cv-text); margin:0 0 14px; }
.prose b{ color:var(--cv-navy); font-weight:700; }

/* ── Three-message cards (numbered) ───────────────────────────────────────── */
.msg-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.msg-card{
  position:relative; background:var(--cv-surface); border:1px solid var(--cv-border);
  border-radius:var(--radius); box-shadow:var(--shadow); padding:26px 22px 20px; overflow:hidden;
}
.msg-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:6px;
  background:linear-gradient(90deg,var(--cv-teal),var(--cv-navy));
}
.msg-num{
  font-family:'Lora',serif; font-weight:600; font-size:60px; line-height:1;
  color:var(--cv-teal-light); position:absolute; top:8px; right:16px; z-index:0;
}
.msg-card h3{
  position:relative; z-index:1; font-family:'Lora',serif; font-weight:600;
  font-size:20px; line-height:1.22; color:var(--cv-navy); margin:6px 0 12px; max-width:15ch;
}
.msg-card p{ position:relative; z-index:1; font-size:14.5px; line-height:1.6; color:var(--cv-text); margin:0; }
.msg-card p b{ color:var(--cv-crimson); font-weight:600; }

/* ── Chart frame ──────────────────────────────────────────────────────────── */
.chart-frame{
  background:var(--cv-surface); border:1px solid var(--cv-border);
  border-radius:var(--radius); box-shadow:var(--shadow); padding:20px 20px 14px; margin-bottom:22px;
}
.chart-holder{ width:100%; }
.chart-holder svg{ max-width:100%; height:auto; display:block; margin:0 auto; }
.chart-source{
  font-size:10.5px; color:var(--cv-muted); margin-top:10px; padding-top:8px;
  border-top:1px solid var(--cv-border); line-height:1.5;
}

/* ── Map controls + legend ────────────────────────────────────────────────── */
.map-controls{ display:flex; align-items:center; flex-wrap:wrap; gap:14px; margin-bottom:14px; }
.ctrl-label{
  font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:var(--cv-muted);
}
.btn-toggle{ display:inline-flex; border:1.5px solid var(--cv-border); border-radius:8px; overflow:hidden; background:var(--cv-surface); }
.btn-toggle button{
  font-family:inherit; font-size:12px; font-weight:600; padding:6px 14px; border:none;
  background:transparent; color:var(--cv-muted); cursor:pointer; transition:all .15s;
  border-right:1px solid var(--cv-border);
}
.btn-toggle button:last-child{ border-right:none; }
.btn-toggle button:hover{ background:var(--cv-teal-light); color:var(--cv-teal-dark); }
.btn-toggle button.on{ background:var(--cv-navy); color:#fff; }
.map-legend{ display:flex; flex-wrap:wrap; gap:12px; margin-left:auto; }
.legend-item{ display:inline-flex; align-items:center; gap:5px; font-size:11px; color:var(--cv-text); }
.legend-item i{ width:13px; height:13px; border-radius:3px; display:inline-block; }

/* ── Pillar cards ─────────────────────────────────────────────────────────── */
.pillar-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:24px; }
.pillar-card{
  background:var(--cv-navy); color:#fff; border-radius:var(--radius);
  padding:22px 20px; box-shadow:var(--shadow); position:relative; overflow:hidden;
}
.pillar-card::after{
  content:""; position:absolute; right:-30px; top:-30px; width:120px; height:120px;
  background:radial-gradient(circle,rgba(13,155,140,.35),transparent 70%);
}
.pillar-tag{ font-size:10px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--cv-gold); margin-bottom:8px; }
.pillar-card h3{ font-family:'Lora',serif; font-weight:600; font-size:24px; margin:0 0 8px; }
.pillar-card p{ font-size:14px; line-height:1.5; margin:0 0 14px; color:rgba(255,255,255,.85); }
.pillar-inds{ font-size:11.5px; color:rgba(255,255,255,.7); border-top:1px solid rgba(255,255,255,.18); padding-top:10px; }

/* ── Comparison ───────────────────────────────────────────────────────────── */
.cmp-controls{
  display:flex; flex-wrap:wrap; gap:22px; align-items:flex-end; margin-bottom:20px;
  background:var(--cv-surface); border:1px solid var(--cv-border); border-radius:var(--radius);
  padding:16px 18px; box-shadow:var(--shadow);
}
.ctrl-group{ display:flex; flex-direction:column; gap:6px; }
.cmp-select{
  font-family:inherit; font-size:13px; font-weight:600; color:var(--cv-navy);
  padding:7px 12px; border:1.5px solid var(--cv-border); border-radius:8px;
  background:var(--cv-surface); cursor:pointer; min-width:190px;
}
.cmp-select:focus{ outline:none; border-color:var(--cv-teal); box-shadow:0 0 0 3px rgba(13,155,140,.15); }
.cmp-rows{ display:flex; flex-direction:column; gap:8px; }
.cmp-block{
  background:var(--cv-surface); border:1px solid var(--cv-border); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:12px 16px 6px;
}
.cmp-head{ display:flex; align-items:baseline; gap:10px; flex-wrap:wrap; margin-bottom:2px; }
.cmp-name{ font-size:14px; font-weight:700; color:var(--cv-navy); }
.cmp-def{ font-size:11px; color:var(--cv-muted); line-height:1.4; }
.cmp-def b{ color:var(--cv-text); font-weight:600; }
.cmp-readout{ margin-left:auto; font-size:12px; color:var(--cv-navy); background:var(--cv-teal-light); padding:2px 10px; border-radius:12px; white-space:nowrap; }
.cmp-readout b{ color:var(--cv-crimson); font-weight:700; }
.cmp-hint{ font-size:11px; color:var(--cv-muted); font-style:italic; margin-top:6px; padding-left:2px; }

/* ── Closing ──────────────────────────────────────────────────────────────── */
.closing{ max-width:820px; margin:0 auto; padding:64px 24px 80px; text-align:center; border-top:1px solid var(--cv-border); }
.closing h2{ font-family:'Lora',serif; font-weight:600; font-size:30px; color:var(--cv-navy); margin:0 0 16px; line-height:1.25; }
.closing p{ font-size:16px; line-height:1.65; color:var(--cv-text); margin:0 auto 26px; max-width:62ch; }
.cta{
  display:inline-flex; align-items:center; gap:8px; background:var(--cv-teal); color:#fff; text-decoration:none;
  font-size:14px; font-weight:600; padding:12px 22px; border-radius:24px; box-shadow:var(--shadow); transition:background .2s;
}
.cta:hover{ background:var(--cv-teal-dark); }
.shiny-note{
  display:none; max-width:62ch; margin:18px auto 0; padding:14px 18px; text-align:left;
  background:var(--cv-surface); border:1px solid var(--cv-border); border-left:4px solid var(--cv-teal);
  border-radius:var(--radius); box-shadow:var(--shadow); font-size:13.5px; line-height:1.6; color:var(--cv-text);
}
.shiny-note.show{ display:block; }
.shiny-note code{
  display:inline-block; margin:4px 0; padding:3px 8px; background:#EEF3F1; border-radius:5px;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:12px; color:var(--cv-navy);
  white-space:pre-wrap; word-break:break-word;
}
.storyfooter{
  max-width:1080px; margin:0 auto; padding:20px 24px 60px; font-size:11px; color:var(--cv-muted);
  text-align:center; line-height:1.7; border-top:1px solid var(--cv-border);
}

/* ── Food environment section ─────────────────────────────────────────────── */
.foodenv-controls{
  display:flex; flex-wrap:wrap; align-items:flex-end; gap:20px; margin-bottom:16px;
}
.quad-legend{ display:flex; flex-wrap:wrap; gap:12px; margin-left:auto; }

[aria-label="tip"] text{ font-family:'Inter',sans-serif !important; }

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width:820px){
  .msg-grid, .pillar-grid{ grid-template-columns:1fr; }
  .map-legend{ margin-left:0; }
  .cmp-controls{ gap:16px; }
}
