/* ========================================
   GOAL CARDS
   ======================================== */
.gg { display: grid; grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); gap: 24px; }
.gc {
  background: white; border: 1px solid var(--border); border-radius: 20px;
  padding: 40px; position: relative; overflow: hidden;
  transition: transform .3s, box-shadow .3s; cursor: default;
}
.gc:hover { transform: translateY(-4px); box-shadow: 0 20px 60px rgba(7, 14, 41, 0.08); }
.gc::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; }
.gc:nth-child(1)::before { background: var(--mint); }
.gc:nth-child(2)::before { background: var(--lavender); }
.gc:nth-child(3)::before { background: var(--gold-accent); }
.gc:nth-child(4)::before { background: var(--mint); }
.gc:nth-child(5)::before { background: var(--lavender); }
.gn { font-family: 'Newsreader', serif; font-size: 42px; font-weight: 300; color: var(--border); margin-bottom: 12px; }
.gname { font-family: 'Newsreader', serif; font-size: 22px; font-weight: 600; margin-bottom: 14px; color: var(--text-primary); }
.gc-emoji { position: absolute; top: 28px; right: 28px; font-size: 32px; opacity: .5; }
.gdesc { font-size: 14px; color: var(--text-secondary); line-height: 1.7; }
.gdet { max-height: 0; overflow: hidden; transition: max-height .5s ease; }
.gc.expanded .gdet { max-height: 600px; }
.gdi { padding-top: 20px; margin-top: 20px; border-top: 1px solid var(--border); }
.gdi div { font-size: 13px; color: var(--text-secondary); line-height: 1.65; padding: 6px 0 6px 20px; position: relative; }
.gdi div::before { content: '→'; position: absolute; left: 0; color: var(--mint); font-weight: 700; }
.gtog {
  display: inline-flex; align-items: center; gap: 6px; margin-top: 16px;
  font-size: 12px; font-weight: 600; color: var(--main); cursor: pointer;
  letter-spacing: 0.04em; text-transform: uppercase; border: none; background: none;
}
.gtog:hover { color: var(--accent); }
.gtog svg { transition: transform .3s; }
.gc.expanded .gtog svg { transform: rotate(180deg); }

/* --- DARK VARIANT (gc-dark) — pale mint card, very dark navy text --- */
.gc.gc-dark {
  background: var(--mint-pale);
  border: 1px solid rgba(7, 14, 41, 0.12);
  border-left: 3px solid var(--dark);
  box-shadow: 0 4px 20px rgba(7, 14, 41, 0.08);
  padding: 36px 36px 32px;
  position: relative;
  overflow: hidden;
}
/* Consistent dark left accent on all cards */
.gc.gc-dark:nth-child(1),
.gc.gc-dark:nth-child(2),
.gc.gc-dark:nth-child(3),
.gc.gc-dark:nth-child(4),
.gc.gc-dark:nth-child(5) { border-left-color: var(--dark); }
/* Top stripe — dark navy on pale mint */
.gc.gc-dark::before { background: var(--dark); }
/* No glow overlay needed */
.gc.gc-dark::after { display: none; }
.gc.gc-dark:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(7, 14, 41, 0.14);
  background: var(--mint-light);
  border-color: rgba(7, 14, 41, 0.18);
}
.gc.gc-dark .gn {
  font-size: 56px;
  font-weight: 200;
  line-height: 1;
  margin-bottom: 14px;
  color: rgba(7, 14, 41, 0.15);
}
.gc.gc-dark .gname {
  color: var(--dark);
  font-size: 20px;
  position: relative;
  z-index: 1;
}
.gc-icon {
  position: absolute; top: 28px; right: 28px;
  width: 48px; height: 48px; border-radius: 12px;
  background: rgba(7, 14, 41, 0.07);
  border: 1px solid rgba(7, 14, 41, 0.12);
  display: flex; align-items: center; justify-content: center;
  z-index: 1;
}
/* Icons — dark navy on pale mint */
.gc.gc-dark .gc-icon svg { stroke: var(--dark); }
.gc.gc-dark .gdesc {
  color: rgba(7, 14, 41, 0.68);
  position: relative;
  z-index: 1;
}
.gc.gc-dark .gdi {
  border-top-color: rgba(7, 14, 41, 0.12);
  position: relative;
  z-index: 1;
}
.gc.gc-dark .gdi div {
  color: rgba(7, 14, 41, 0.65);
}
.gc.gc-dark .gdi div::before { color: var(--dark); }
.gc.gc-dark .gtog {
  color: var(--dark);
  position: relative;
  z-index: 1;
}
.gc.gc-dark .gtog:hover {
  color: var(--plum);
}

/* ========================================
   PILLAR CARDS
   ======================================== */
.pg { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.pc {
  border-radius: 20px; padding: 36px 28px; text-align: center;
  position: relative; overflow: hidden;
  transition: transform .3s, box-shadow .3s;
}
.pc:hover { transform: translateY(-6px); box-shadow: 0 16px 48px rgba(7, 14, 41, 0.06); }
.pc::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; }
.pc:nth-child(1) { background: rgba(25, 48, 106, 0.05); }
.pc:nth-child(1)::before { background: var(--main); }
.pc:nth-child(2) { background: rgba(157, 212, 207, 0.08); }
.pc:nth-child(2)::before { background: var(--mint); }
.pc:nth-child(3) { background: rgba(5, 66, 64, 0.05); }
.pc:nth-child(3)::before { background: var(--accent); }
.pc:nth-child(4) { background: rgba(167, 160, 210, 0.06); }
.pc:nth-child(4)::before { background: var(--lavender); }
.pnum { font-family: 'Newsreader', serif; font-size: 32px; font-weight: 300; color: var(--text-muted); margin-bottom: 10px; }
.pname { font-family: 'Newsreader', serif; font-size: 20px; font-weight: 600; margin-bottom: 12px; }
.pdesc { font-size: 13px; color: var(--text-secondary); line-height: 1.65; }

/* ========================================
   AUDIENCE CARDS
   ======================================== */
.ag { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.ac {
  background: rgba(255, 255, 255, 0.04); border: 1px solid var(--border-dark);
  border-radius: 20px; padding: 36px; display: flex; gap: 20px; transition: all .3s;
}
.ac:hover { border-color: rgba(157, 212, 207, 0.3); transform: translateY(-3px); background: rgba(255, 255, 255, 0.06); }
.ai {
  width: 48px; height: 48px; border-radius: 12px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Newsreader', serif; font-size: 20px; font-weight: 600; color: var(--dark);
}
.ac:nth-child(1) .ai { background: var(--mint); }
.ac:nth-child(2) .ai { background: var(--lavender); }
.ac:nth-child(3) .ai { background: var(--gold-accent); }
.ac:nth-child(4) .ai { background: var(--mint-light); }
.aname { font-family: 'Newsreader', serif; font-size: 18px; font-weight: 600; color: white; margin-bottom: 8px; }
.adesc { font-size: 14px; color: var(--text-on-dark-muted); line-height: 1.65; }

/* ========================================
   DIFFERENTIATION CARDS
   ======================================== */
.dg { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.dc { background: white; border: 1px solid var(--border); border-radius: 16px; padding: 32px; transition: transform .3s, box-shadow .3s; }
.dc:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(7, 14, 41, 0.06); }
.dcl { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 12px; }
.dc:nth-child(1) .dcl { color: var(--main); }
.dc:nth-child(2) .dcl { color: var(--mint); }
.dc:nth-child(3) .dcl { color: var(--accent); }
.dc:nth-child(4) .dcl { color: var(--lavender); }
.dct { font-family: 'Newsreader', serif; font-size: 20px; font-weight: 600; margin-bottom: 10px; }
.dcd { font-size: 14px; color: var(--text-secondary); line-height: 1.65; }

/* ========================================
   TIER CARDS
   ======================================== */
.tg { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.tc {
  border-radius: 20px; padding: 36px; border: 1px solid var(--border-dark);
  background: rgba(255, 255, 255, 0.03); transition: transform .3s;
}
.tc:hover { transform: translateY(-4px); }
.tc.feat { border-color: var(--mint); background: rgba(157, 212, 207, 0.06); }
.tl-label { font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mint); margin-bottom: 12px; }
.tn { font-family: 'Newsreader', serif; font-size: 24px; font-weight: 600; color: white; margin-bottom: 8px; }
.tp { font-size: 14px; color: var(--text-on-dark-muted); margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid var(--border-dark); }
.tf { list-style: none; }
.tf li { font-size: 13px; color: var(--text-on-dark-muted); padding: 6px 0 6px 20px; position: relative; }
.tf li::before { content: '✓'; position: absolute; left: 0; color: var(--mint); font-weight: 700; }
