/* theme.css — shared editorial palette for the trump-tracker Event Card surface.
   Ported verbatim from SPEC.html (the visual contract). Amber/cream editorial look.
   Used by index.php (landing/list) and dashboard.php (the hero Event Card). */

:root{
  --bg:#17130f; --bg2:#1f1a14; --card:#f5ede1; --ink:#241d16; --muted:#7c7264;
  --accent:#d98c1f; --up:#1f9d57; --down:#d2453a; --neutral:#9a9183;
  --line:#2c2419; --hair:#e3d6c2;
  --serif:"Iowan Old Style",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:#e9e0d2;font-family:var(--sans);line-height:1.5;-webkit-font-smoothing:antialiased}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px 80px}
a{color:inherit;text-decoration:none}

/* ---- top status banner ---- */
.status{background:linear-gradient(90deg,#3a2b12,#241a0c);border-bottom:1px solid #4a3718;padding:10px 22px;font-size:13px;letter-spacing:.03em;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.status b{color:var(--accent)}
.status .pill{display:inline-block;background:var(--accent);color:#241a0c;font-weight:700;border-radius:99px;padding:2px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.08em}
.status .spacer{margin-left:auto}
.status a.home{color:#bcae9b;border:1px solid #4a3718;border-radius:7px;padding:4px 11px;font-size:12px;transition:.15s}
.status a.home:hover{color:#fff;border-color:var(--accent)}

/* ---- page header ---- */
header.hd{padding:38px 0 8px}
header.hd h1{font-family:var(--serif);font-size:34px;line-height:1.15;margin:0 0 6px;color:#fff;font-weight:600}
header.hd .sub{color:#bcae9b;font-size:16px;max-width:760px}
.tag{color:var(--accent);font-size:12px;text-transform:uppercase;letter-spacing:.18em;font-weight:700;margin-bottom:14px}
h2.sec{font-family:var(--serif);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
  border-top:1px solid #33291c;padding-top:26px;margin:46px 0 18px;font-weight:700}

/* ---- the hero Event Card ---- */
.ecard{background:var(--card);color:var(--ink);border-radius:14px;overflow:hidden;box-shadow:0 18px 40px rgba(0,0,0,.45);border:1px solid #d8c8b0}
.ecard .top{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--hair);background:#efe4d3}
.avatar{width:38px;height:38px;border-radius:50%;background:#241a0c;color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex:0 0 auto}
.who{font-weight:700;font-size:15px}
.who small{display:block;font-weight:400;color:var(--muted);font-size:12px}
.chip{margin-left:auto;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:4px 11px;border-radius:99px;white-space:nowrap}
.chip.praise{background:#e3f3e8;color:#15703f;border:1px solid #b6dcc4}
.chip.attack{background:#f7e2e0;color:#9e2c23;border:1px solid #e2b6b1}
.chip.neutral{background:#ece4d6;color:#6d655a;border:1px solid #d6c8b2}

.ecard .body{display:grid;grid-template-columns:1fr 1.35fr;gap:0}
.quote{padding:24px 22px;border-right:1px solid var(--hair);display:flex;flex-direction:column}
.quote .q{font-family:var(--serif);font-size:23px;line-height:1.32;color:#241d16}
.quote .q .mk{color:var(--accent)}
.quote .meta{margin-top:auto;padding-top:18px;color:var(--muted);font-size:13px}
.chart{padding:18px 18px 10px;position:relative;min-width:0}
.chart .canvas-box{position:relative;height:236px}
.chart .nullbox{height:236px;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;padding:18px}
/* solid slate = measured, nothing happened */
.chart .nullbox.measured{background:#e6e0d4;border:1px solid #cfc6b4}
/* hatched = no data yet / pending */
.chart .nullbox.pending{background:
  repeating-linear-gradient(45deg,#ece4d6,#ece4d6 8px,#e2d8c6 8px,#e2d8c6 16px);
  border:1px dashed #b9ac96}
.chart .nullbox .nm-ico{font-size:24px}
.chart .nullbox .nm-title{font-family:var(--serif);font-size:18px;color:#5f564a;font-weight:600}
.chart .nullbox .nm-sub{font-size:12.5px;color:#7c7264;max-width:340px}

.verdict{display:flex;align-items:baseline;gap:12px;padding:0 22px 20px;flex-wrap:wrap}
.verdict .big{font-size:30px;font-weight:800;letter-spacing:-.01em}
.verdict .vlabel{font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;padding:3px 10px;border-radius:6px}
.verdict .adj{color:var(--muted);font-size:14px}
.up{color:var(--up)} .down{color:var(--down)} .neu{color:var(--neutral)}
.vlabel.up{background:#e3f3e8;color:#15703f}
.vlabel.down{background:#f7e2e0;color:#9e2c23}
.vlabel.neu{background:#ece6db;color:#74695a}

.legend{display:flex;gap:18px;font-size:11.5px;color:#5f564a;padding:8px 4px 0;flex-wrap:wrap}
.legend i{display:inline-block;width:18px;height:0;border-top-width:3px;border-top-style:solid;vertical-align:middle;margin-right:5px}
.legend i.dash{border-top-style:dashed}
.swatch{display:inline-block;width:11px;height:11px;border-radius:2px;vertical-align:middle;margin-right:5px}

.ann{font-size:12.5px;color:#b3a48f;background:#211b14;border:1px solid #33291c;border-radius:8px;padding:10px 14px;margin-top:14px}
.ann b{color:#cdbfa8}

@media(max-width:840px){
  .ecard .body{grid-template-columns:1fr}
  .quote{border-right:0;border-bottom:1px solid var(--hair)}
  .quote .q{font-size:20px}
  header.hd h1{font-size:27px}
}

/* ---- index: company list / leaderboard ---- */
.filters{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:0 0 18px}
.filters .flabel{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-right:4px}
.inf-btn{font-size:13px;font-weight:600;border:1px solid #3a2f1f;background:#1f1a14;color:#cdbfa8;border-radius:99px;padding:6px 14px;cursor:pointer;transition:.15s;display:flex;align-items:center;gap:7px}
.inf-btn .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
.inf-btn.active{background:var(--accent);color:#241a0c;border-color:var(--accent)}
.inf-btn.active .dot{background:#241a0c}
.inf-btn.locked{opacity:.45;cursor:not-allowed}
.inf-btn.locked .dot{background:#6b6253}
.inf-btn .soon{font-size:9px;text-transform:uppercase;letter-spacing:.08em;background:#33291c;color:#9a8c6f;border-radius:4px;padding:1px 5px}

.rows{display:flex;flex-direction:column;gap:9px}
.row{display:grid;grid-template-columns:42px 1fr auto;align-items:center;gap:14px;background:var(--bg2);border:1px solid #2a2218;border-radius:11px;padding:12px 16px;cursor:pointer;transition:.15s;text-align:left}
.row:hover{border-color:var(--accent);background:#241c12;transform:translateY(-1px)}
.row .rav{width:34px;height:34px;border-radius:50%;background:#241a0c;color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}
.row .rmain .rtkr{font-weight:700;color:#fff;font-size:15px}
.row .rmain .rtkr .rname{color:var(--muted);font-weight:400;font-size:13px;margin-left:7px}
.row .rmain .rgist{font-size:13px;color:#a99e8b;margin-top:2px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}
.row .rverdict{text-align:right;white-space:nowrap}
.row .rverdict .rbig{font-size:18px;font-weight:800}
.row .rverdict .rlab{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-top:1px}
.row .rverdict .rlab.pending{color:#8a7f6e}
@media(max-width:560px){
  .row{grid-template-columns:34px 1fr;}
  .row .rverdict{grid-column:2;text-align:left;margin-top:4px}
  .row .rverdict .rbig{font-size:16px}
}

.baserate{margin-top:26px;font-size:13px;color:#9b8f7d;background:var(--bg2);border:1px solid #2a2218;border-radius:10px;padding:14px 18px}
.baserate b{color:#cdbfa8}
.note{font-size:12.5px;color:#8a7f6e;margin-top:10px}
.kk{color:var(--accent);font-weight:700}
.loading,.errbox{padding:40px 22px;text-align:center;color:#9b8f7d}
.errbox{color:#d2998f}
