/* ============================================================================
   GMA Expressive Layer (Tom Peters Re-Imagine + Neil Patel visual layer)
   Ported from SC 19-DESIGN-LAYOUT-CANON.md §20-§26.
   Loaded ADDITIVELY on top of /css/style.css. Does not override existing styles.
   Hub palette: Pains = red-clay #B0432C. Atlas / default = gold #C9A96E.
   ============================================================================ */

/* ----- Hub palette via body data attribute ----- */
:root{
  --gme-hub-accent:#C9A96E;
  --gme-hub-accent-bright:#E8C589;
  --gme-hub-accent-soft:rgba(201,169,110,0.12);
  --gme-ink-500:#4A4A4A;
  --gme-navy:#0A1929;
  --gme-stone:#F5F2EC;
}
body[data-hub="pains"]{
  --gme-hub-accent:#B0432C;
  --gme-hub-accent-bright:#E37154;
  --gme-hub-accent-soft:rgba(176,67,44,0.10);
}
body[data-hub="problems"]{
  --gme-hub-accent:#B0432C;
  --gme-hub-accent-bright:#E37154;
  --gme-hub-accent-soft:rgba(176,67,44,0.10);
}
body[data-hub="atlas"],
body[data-hub="answers"],
body[data-hub="markets"],
body[data-hub="cities"],
body[data-hub="corridor"]{
  --gme-hub-accent:#C9A96E;
  --gme-hub-accent-bright:#E8C589;
  --gme-hub-accent-soft:rgba(201,169,110,0.12);
}
body[data-hub="case-files"]{
  --gme-hub-accent:#B7553A;
  --gme-hub-accent-bright:#E07F61;
  --gme-hub-accent-soft:rgba(183,85,58,0.10);
}
body[data-hub="ai"]{
  --gme-hub-accent:#2E6BAF;
  --gme-hub-accent-bright:#5E97DD;
  --gme-hub-accent-soft:rgba(46,107,175,0.10);
}

/* ----- Hub badge (eyebrow with accent dot) ----- */
.gme-hub-badge{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'IBM Plex Sans Condensed','Barlow Condensed',sans-serif;
  font-weight:700;font-size:11.5px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--gme-hub-accent);
}
.gme-hub-badge::before{
  content:"";display:inline-block;
  width:10px;height:10px;background:var(--gme-hub-accent);
}

/* ----- Tom Peters typographic theater ----- */
.gme-display{
  font-family:'Bebas Neue','Oswald','Arial Narrow',Impact,sans-serif;
  font-size:clamp(56px,10vw,160px);
  line-height:0.88;letter-spacing:-0.02em;
  color:var(--gme-hub-accent);
  margin:8px 0 18px;
  text-transform:uppercase;
}
.gme-display-inline{
  font-family:'Bebas Neue','Oswald','Arial Narrow',Impact,sans-serif;
  font-size:1.5em;line-height:0.9;letter-spacing:-0.01em;
  color:var(--gme-hub-accent);
  vertical-align:baseline;
}
.gme-stack-words{display:block;margin:32px 0;}
.gme-stack-words span{
  display:block;
  font-family:'Bebas Neue','Oswald','Arial Narrow',Impact,sans-serif;
  font-size:clamp(36px,5.5vw,72px);
  line-height:1;letter-spacing:-0.01em;
  color:var(--gme-hub-accent);
  text-transform:uppercase;
  margin:6px 0;
}
.gme-bleed{
  font-family:'IBM Plex Serif','DM Serif Display',Georgia,serif;
  font-style:italic;
  font-size:clamp(28px,4.5vw,56px);
  line-height:1.15;
  color:var(--gme-navy);
  max-width:980px;margin:80px auto;padding:0 24px;
  text-align:center;
}
.gme-bleed cite{
  display:block;
  font-family:'IBM Plex Sans Condensed','Barlow Condensed',sans-serif;
  font-style:normal;
  font-size:13px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--gme-hub-accent);
  margin-top:24px;
  font-weight:700;
}
.gme-rule{
  height:2px;background:var(--gme-hub-accent);
  width:60%;max-width:520px;
  margin:96px auto;border:0;
}

/* ----- Margin glyph system ----- */
.gme-mark{
  position:relative;
  display:flex;align-items:flex-start;gap:18px;
  padding:14px 18px 14px 0;
  margin:24px 0;
}
.gme-mark-glyph{
  flex-shrink:0;
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  background:var(--gme-hub-accent);
  color:#FFF;
  font-family:'Bebas Neue','Oswald','Arial Narrow',Impact,sans-serif;
  font-size:26px;line-height:1;
}
.gme-mark-body{flex:1;}
.gme-mark-lbl{
  display:block;
  font-family:'IBM Plex Sans Condensed','Barlow Condensed',sans-serif;
  font-weight:700;font-size:10.5px;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--gme-hub-accent);
  margin:0 0 6px;
}
.gme-mark-text{margin:0;font-size:17px;line-height:1.6;color:var(--gme-ink-500);}
.gme-mark-text strong{color:var(--gme-navy);}

/* ----- Technicolor Rules manifesto block ----- */
.gme-tech-rules{
  background:var(--gme-navy);color:#FFF;
  padding:48px 36px;margin:48px 0;
  border-left:6px solid var(--gme-hub-accent);
}
.gme-tech-rules-h{
  font-family:'Bebas Neue','Oswald','Arial Narrow',Impact,sans-serif;
  font-size:clamp(40px,6vw,72px);line-height:0.95;
  color:var(--gme-hub-accent-bright);
  margin:0 0 22px;
  letter-spacing:-0.01em;text-transform:uppercase;
}
.gme-tech-rules ol{list-style:none;padding:0;margin:0;counter-reset:tr;}
.gme-tech-rules li{
  counter-increment:tr;
  padding:14px 0 14px 56px;
  position:relative;
  font-size:18px;line-height:1.55;
  border-top:1px solid rgba(255,255,255,0.10);
}
.gme-tech-rules li::before{
  content:counter(tr,decimal-leading-zero);
  position:absolute;left:0;top:14px;
  font-family:'Bebas Neue',sans-serif;
  font-size:26px;color:var(--gme-hub-accent-bright);
}
.gme-tech-rules li strong{
  font-family:'Bebas Neue','Oswald','Arial Narrow',Impact,sans-serif;
  font-weight:400;font-size:22px;letter-spacing:0.02em;
  color:var(--gme-hub-accent-bright);
  text-transform:uppercase;margin-right:10px;
}

/* ----- Neil Patel visual layer ----- */
.gme-chart{margin:48px 0;}
.gme-chart svg{
  width:100%;height:auto;display:block;
  background:var(--gme-stone);padding:24px;
}
.gme-chart-cap{
  font-family:'IBM Plex Sans Condensed','Barlow Condensed',sans-serif;
  font-weight:700;font-size:12px;letter-spacing:0.10em;
  text-transform:uppercase;color:var(--gme-ink-500);
  margin:14px 0 0;
}
.gme-chart-cap a{color:var(--gme-hub-accent);text-decoration:underline;}

.gme-quote-card{
  display:grid;grid-template-columns:64px 1fr;gap:18px;
  background:var(--gme-stone);
  padding:28px 28px;margin:32px 0;
  border-left:4px solid var(--gme-hub-accent);
}
.gme-quote-card .qc-avatar{
  width:56px;height:56px;border-radius:50%;
  background:var(--gme-hub-accent);
  display:flex;align-items:center;justify-content:center;
  color:#FFF;font-family:'Bebas Neue',sans-serif;font-size:22px;
}
.gme-quote-card .qc-body p{
  font-size:17px;line-height:1.55;margin:0 0 12px;color:var(--gme-navy);
}
.gme-quote-card .qc-meta{
  font-family:'IBM Plex Sans Condensed','Barlow Condensed',sans-serif;
  font-weight:700;font-size:11.5px;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--gme-ink-500);
}
.gme-quote-card .qc-meta a{color:var(--gme-hub-accent);}

.gme-highlight{
  background:linear-gradient(180deg,transparent 55%,var(--gme-hub-accent-soft) 55%);
  padding:0 4px;
  font-weight:600;color:var(--gme-navy);
}

.gme-compare{
  width:100%;border-collapse:collapse;margin:32px 0;
  font-size:15px;
}
.gme-compare th,
.gme-compare td{
  border-bottom:1px solid #E5E0D7;
  padding:14px 16px;text-align:left;vertical-align:top;
  line-height:1.5;
}
.gme-compare th{
  font-family:'IBM Plex Sans Condensed','Barlow Condensed',sans-serif;
  font-weight:700;font-size:12px;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--gme-hub-accent);
  border-bottom:2px solid var(--gme-hub-accent);
}
.gme-compare td:first-child{font-weight:600;color:var(--gme-navy);}
.gme-compare .gme-yes{color:var(--gme-hub-accent);font-weight:700;}

/* ----- Citation block ----- */
.gme-citation{
  font-family:'IBM Plex Sans Condensed','Barlow Condensed',sans-serif;
  font-weight:600;font-size:13px;letter-spacing:0.04em;
  color:var(--gme-ink-500);
  border-top:1px solid var(--gme-hub-accent);
  padding-top:16px;margin-top:32px;
}
.gme-citation a{color:var(--gme-hub-accent);text-decoration:underline;}
.gme-citation a:hover{color:var(--gme-hub-accent-bright);}

/* ----- Section-jump TOC ----- */
.gme-toc{
  background:var(--gme-stone);
  padding:24px 28px;margin:32px 0;
  border-left:4px solid var(--gme-hub-accent);
}
.gme-toc-h{
  font-family:'IBM Plex Sans Condensed','Barlow Condensed',sans-serif;
  font-weight:700;font-size:11.5px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--gme-hub-accent);
  margin:0 0 14px;
}
.gme-toc ol{list-style:none;padding:0;margin:0;counter-reset:toc;}
.gme-toc li{counter-increment:toc;padding:6px 0;}
.gme-toc li::before{
  content:counter(toc,decimal-leading-zero) ".  ";
  font-family:'Bebas Neue',sans-serif;
  color:var(--gme-hub-accent);font-size:15px;
  margin-right:6px;
}
.gme-toc a{color:var(--gme-navy);text-decoration:none;font-weight:500;border-bottom:1px solid transparent;}
.gme-toc a:hover{border-bottom-color:var(--gme-hub-accent);}

/* ----- Mobile ----- */
@media (max-width:768px){
  .gme-mark{padding:14px 16px;background:var(--gme-hub-accent-soft);border-left:3px solid var(--gme-hub-accent);}
  .gme-mark-glyph{width:36px;height:36px;font-size:20px;}
  .gme-rule{margin:64px auto;}
  .gme-tech-rules{padding:32px 22px;margin:36px -22px;border-left:0;border-top:6px solid var(--gme-hub-accent);}
  .gme-bleed{margin:56px auto;}
  .gme-display{font-size:clamp(48px,14vw,96px);}
  .gme-stack-words span{font-size:clamp(32px,9vw,56px);}
  .gme-quote-card{grid-template-columns:48px 1fr;padding:22px;}
  .gme-quote-card .qc-avatar{width:42px;height:42px;font-size:18px;}
  .gme-toc{padding:20px 22px;margin:24px -22px;border-left:0;border-top:4px solid var(--gme-hub-accent);}
  .gme-compare{font-size:14px;}
  .gme-compare th,.gme-compare td{padding:10px 8px;}
}
/* End expressive layer */
