/* ============================================================
   Growth Hub — page-specific styles
   ============================================================ */

/* ---- Active nav link ---- */
.nav-links .gh-active{ color: var(--red) !important; }

/* ---- GH Hero adjustments ---- */
.gh-hero .hero-sub{
  color: var(--dim); font-size: clamp(16px, 1.4vw, 20px);
  max-width: 54ch; margin: 0 0 34px; line-height: 1.6;
}

/* ============================================================
   PILLARS STRIP
   ============================================================ */
.gh-pillars{
  background: var(--ink-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.pillars-grid{ display: grid; grid-template-columns: repeat(4,1fr); }
.pillar{
  text-align: center; padding: 38px 20px; position: relative;
}
.pillar + .pillar::before{
  content:""; position:absolute; left:0; top:15%; bottom:15%;
  width:1px; background: var(--line);
}
.pillar-icon{
  width:52px; height:52px; margin:0 auto 14px; color: var(--red);
}
.pillar-icon svg{ width:100%; height:100%; }
.pillar-title{
  font-family: var(--f-disp); font-weight:700; text-transform:uppercase;
  font-size:14px; letter-spacing:0.05em; margin:0 0 8px; color: var(--text);
}
.pillar-desc{
  font-size:14px; color: var(--dim); line-height:1.5;
  max-width:26ch; margin:0 auto;
}

/* ============================================================
   RESOURCE SECTION
   ============================================================ */
.gh-resources{ padding-block: clamp(70px,9vw,120px); }
.gh-resources .head-block{
  text-align:center; max-width:640px;
  margin-left:auto; margin-right:auto;
}
.gh-resources .head-block h2::after{
  content:""; display:block; width:48px; height:3px;
  background: var(--red-grad); border-radius:2px;
  margin:18px auto 0;
}

/* ---- Resource cards ---- */
.resource-grid{
  display:grid; grid-template-columns: repeat(5,1fr); gap:18px;
}
.rcard{
  background: var(--ink-2); border:1px solid var(--line);
  border-radius:14px; padding:26px 20px 22px;
  display:flex; flex-direction:column;
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.rcard:hover{
  transform: translateY(-6px);
  border-color: rgba(216,31,44,0.5);
  box-shadow: 0 22px 46px -22px rgba(0,0,0,0.75);
}
.rcard-icon{
  width:46px; height:46px; border-radius:10px;
  background: var(--ink-3); border:1px solid var(--line);
  display:grid; place-items:center; margin-bottom:16px;
  color: var(--red);
}
.rcard-icon svg{ width:22px; height:22px; }
.rcard-cat{
  font-family: var(--f-mono); font-size:10px; letter-spacing:0.1em;
  text-transform:uppercase; color: var(--red); margin-bottom:10px; font-weight:500;
}
.rcard h3{
  font-family: var(--f-disp); text-transform:uppercase; font-weight:700;
  font-size:18px; line-height:1.06; margin:0 0 12px; color: var(--text);
}
.rcard-desc{
  font-size:14px; color: var(--dim); line-height:1.55;
  margin:0 0 auto; padding-bottom:16px;
}
.rcard-meta{
  display:flex; align-items:center; gap:7px;
  font-family: var(--f-mono); font-size:11px; letter-spacing:0.04em;
  color: var(--dim-2); text-transform:uppercase; margin-bottom:14px;
}
.rcard-meta svg{ width:13px; height:13px; opacity:.6; flex:0 0 auto; }
.rcard-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family: var(--f-disp); text-transform:uppercase; font-weight:700;
  font-size:13px; letter-spacing:0.02em; color: var(--red);
  background:transparent; border:1px solid rgba(216,31,44,0.35);
  border-radius:3px; padding:10px 16px; transition: all .2s ease;
  cursor:pointer; width:100%;
}
.rcard-btn:hover{ background: var(--red); border-color: var(--red); color:#fff; }
.rcard-btn .arr{ transition: transform .2s ease; }
.rcard-btn:hover .arr{ transform: translateX(4px); }

/* ---- Score ring (card 5) ---- */
.score-ring-wrap{ display:flex; justify-content:center; padding:6px 0 10px; }
.score-ring{ width:100px; height:100px; position:relative; }
.score-ring svg{ width:100%; height:100%; }
.score-label{
  position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; pointer-events:none;
}
.score-num{
  font-family: var(--f-disp); font-weight:800;
  font-size:28px; line-height:1; color: var(--text);
}
.score-of{ font-family: var(--f-mono); font-size:11px; color: var(--dim-2); }

/* ============================================================
   RESOURCE DETAIL MODAL
   ============================================================ */
.rmodal{
  position:absolute; top:50%; left:50%; transform: translate(-50%,-50%);
  width: min(600px, calc(100vw - 32px)); max-height:90vh; overflow:auto;
  background: var(--ink-2); border:1px solid var(--line); border-radius:8px;
}
.modal-root.open .rmodal{ animation: modalIn .26s cubic-bezier(.2,.8,.2,1); }
.rmodal-head{
  padding:26px 28px 0; display:flex; align-items:flex-start;
  justify-content:space-between; gap:16px;
}
.rmodal-head .x{
  background:none; border:none; color: var(--dim);
  font-size:26px; line-height:1; cursor:pointer; flex:0 0 auto;
}
.rmodal-head .x:hover{ color:#fff; }
.rmodal-info{ flex:1; }
.rmodal-cat{
  font-family: var(--f-mono); font-size:11px; letter-spacing:0.14em;
  text-transform:uppercase; color: var(--red); margin-bottom:8px;
}
.rmodal-info h3{
  font-family: var(--f-disp); text-transform:uppercase; font-weight:800;
  font-size:26px; line-height:1.02; margin:0 0 10px;
}
.rmodal-time{
  display:flex; align-items:center; gap:7px;
  font-family: var(--f-mono); font-size:11px; color: var(--dim-2);
  text-transform:uppercase; letter-spacing:0.04em;
}
.rmodal-body{ padding:22px 28px 28px; }
.rmodal-desc{
  font-size:16px; color: var(--dim); line-height:1.6; margin:0 0 22px;
}
.rmodal-insights h4{
  font-family: var(--f-disp); text-transform:uppercase; font-weight:700;
  font-size:17px; margin:0 0 14px; color: var(--text);
}
.rmodal-insights ul{
  list-style:none; margin:0 0 24px; padding:0; display:grid; gap:10px;
}
.rmodal-insights li{
  display:flex; gap:11px; align-items:flex-start; font-size:15px; color: var(--text);
}
.rmodal-insights li::before{
  content:""; flex:0 0 auto; width:7px; height:7px; margin-top:8px;
  background: var(--red); transform: rotate(45deg);
}
.rmodal-cta{
  background: var(--ink); border:1px solid var(--line);
  border-left:3px solid var(--red); border-radius:4px;
  padding:20px 22px; display:flex; align-items:center; gap:16px;
}
.rmodal-cta p{
  margin:0; font-family: var(--f-disp); text-transform:uppercase;
  font-weight:700; font-size:16px; line-height:1.1; flex:1;
}
.rmodal-cta .btn{ font-size:14px; padding:12px 20px; white-space:nowrap; }

/* ============================================================
   GH FINAL CTA
   ============================================================ */
.gh-final{
  text-align:center; padding-block: clamp(80px,10vw,130px);
  position:relative; overflow:hidden;
}
.gh-final::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(closest-side at 50% 50%, rgba(216,31,44,0.14), transparent 65%);
}
.gh-final .wrap{ position:relative; z-index:1; }
.gh-final h2{ max-width:18ch; margin:0 auto 18px; }
.gh-final-sub{
  color: var(--dim); max-width:48ch; margin:0 auto 14px;
  font-size: clamp(16px,1.3vw,19px);
}
.gh-final-foot{
  font-family: var(--f-mono); font-size:13px; color: var(--dim-2);
  letter-spacing:0.04em; margin-top:24px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px){
  .resource-grid{ grid-template-columns: repeat(3,1fr); }
}
@media (max-width:920px){
  .pillars-grid{ grid-template-columns: repeat(2,1fr); }
  .pillar + .pillar::before{ display:none; }
  .resource-grid{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width:560px){
  .pillars-grid{ grid-template-columns:1fr; }
  .resource-grid{ grid-template-columns:1fr; }
  .rmodal-cta{ flex-direction:column; text-align:center; }
  .rmodal-cta .btn{ width:100%; justify-content:center; }
}
