/* ============================================================
   INDUSTRY / PROGRAM LANDING PAGES
   Built on the shared brand tokens (styles.css + brand file).
   Class prefix: ind-
   ============================================================ */

/* ---------- hero ---------- */
.ind-hero {
  position: relative;
  background:
    radial-gradient(1100px 460px at 78% -8%, hsl(255 60% 60% / .26), transparent 60%),
    linear-gradient(165deg, hsl(var(--csx-navy, 230 42% 13%)) 0%, hsl(232 44% 9%) 100%);
  color: #fff;
  padding: 84px 0 76px;
  overflow: hidden;
}
.ind-hero::after {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(hsl(0 0% 100% / .05) 1px, transparent 1px);
  background-size: 26px 26px; opacity: .5; pointer-events: none;
}
.ind-hero .container-wide { position: relative; z-index: 1; }
.ind-kicker {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 14px; font-weight: 600; letter-spacing: .02em;
  color: hsl(255 70% 84%);
  background: hsl(255 60% 62% / .16);
  border: 1px solid hsl(255 60% 70% / .32);
  padding: 7px 15px; border-radius: 999px; margin: 0 0 22px;
}
.ind-kicker::before {
  content: ""; width: 7px; height: 7px; border-radius: 50%;
  background: hsl(152 60% 55%); box-shadow: 0 0 0 4px hsl(152 60% 55% / .22);
}
.ind-hero h1 {
  font-family: var(--font-display, 'Space Grotesk'), sans-serif;
  font-size: clamp(38px, 5.2vw, 66px); line-height: 1.04; font-weight: 700;
  letter-spacing: -.025em; margin: 0; max-width: 16ch; text-wrap: balance;
}
.ind-h1-eyebrow {
  display: block; font-family: var(--font-mono, 'Roboto Mono'), monospace;
  font-size: clamp(13px, 1.4vw, 16px); font-weight: 500; letter-spacing: .08em;
  text-transform: uppercase; color: hsl(255 72% 82%); margin: 0 0 18px; max-width: none;
}
.ind-hero .ind-lede { margin: 26px 0 0; max-width: 60ch; }
.ind-hero .ind-lede p {
  font-size: 18px; line-height: 1.62; color: hsl(225 30% 82%); margin: 0 0 14px;
}
.ind-hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 36px; }

/* ---------- generic section ---------- */
.ind-sec { padding: 84px 0; }
.ind-sec.tint { background: hsl(230 40% 97%); border-block: 1px solid hsl(230 30% 91%); }
.ind-eyebrow {
  font-size: 13px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: hsl(255 55% 56%); margin: 0 0 14px;
}
.ind-h2 {
  font-family: var(--font-display, 'Space Grotesk'), sans-serif;
  font-size: clamp(28px, 3.4vw, 42px); line-height: 1.12; font-weight: 700;
  letter-spacing: -.02em; color: hsl(230 42% 14%); margin: 0; text-wrap: balance;
}
.ind-sec-head { max-width: 60ch; margin-bottom: 44px; }
.ind-sec-head .ind-sub { font-size: 18px; color: hsl(230 14% 42%); margin: 14px 0 0; line-height: 1.6; }

/* ---------- experience: proof cards ---------- */
.ind-proof { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.ind-proof-card {
  background: #fff; border: 1px solid hsl(230 28% 90%); border-radius: 16px;
  padding: 30px 28px; position: relative;
  box-shadow: 0 1px 2px hsl(230 40% 20% / .04);
}
.ind-proof-card::before {
  content: ""; display: block; width: 38px; height: 4px; border-radius: 3px;
  background: linear-gradient(90deg, hsl(255 60% 60%), hsl(152 55% 48%)); margin-bottom: 18px;
}
.ind-proof-card p { margin: 0; font-size: 16.5px; line-height: 1.6; color: hsl(230 20% 28%); }

/* ---------- experience: logo strip ---------- */
.ind-logos { display: flex; flex-wrap: wrap; align-items: center; gap: 30px 52px; }
.ind-logos img {
  height: 38px; width: auto; max-width: 150px; object-fit: contain;
  filter: grayscale(1) opacity(.62); transition: filter .25s;
}
.ind-logos img:hover { filter: grayscale(0) opacity(1); }

/* ---------- goals grid ---------- */
.ind-goals { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.ind-goal {
  background: #fff; border: 1px solid hsl(230 28% 89%); border-radius: 18px;
  padding: 30px 30px 26px; transition: border-color .2s, box-shadow .2s, transform .2s;
}
.ind-goal:hover { border-color: hsl(255 60% 70%); box-shadow: 0 14px 36px hsl(255 50% 30% / .1); transform: translateY(-2px); }
.ind-goal-n {
  font-family: var(--font-mono, 'Roboto Mono'), monospace;
  font-size: 13px; font-weight: 500; color: hsl(255 55% 58%); margin: 0 0 10px;
}
.ind-goal h3 {
  font-family: var(--font-display, 'Space Grotesk'), sans-serif;
  font-size: 22px; font-weight: 600; letter-spacing: -.01em; color: hsl(230 42% 15%);
  margin: 0 0 18px; line-height: 1.2;
}
.ind-goal-links { display: flex; flex-wrap: wrap; gap: 9px; }
.ind-goal-links a {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 14px; font-weight: 500; color: hsl(230 30% 28%);
  background: hsl(230 40% 96%); border: 1px solid hsl(230 28% 89%);
  padding: 8px 13px; border-radius: 10px; text-decoration: none; transition: all .18s;
}
.ind-goal-links a:hover { background: hsl(255 60% 96%); border-color: hsl(255 55% 78%); color: hsl(255 50% 40%); }
.ind-goal-links a svg { width: 13px; height: 13px; opacity: .55; }

/* ---------- services grid ---------- */
.ind-services { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.ind-svc {
  display: flex; flex-direction: column; gap: 12px;
  background: #fff; border: 1px solid hsl(230 28% 89%); border-radius: 16px;
  padding: 26px 26px 24px; text-decoration: none; transition: all .2s; min-height: 168px;
}
.ind-svc:hover { border-color: hsl(152 50% 55%); box-shadow: 0 14px 34px hsl(152 40% 28% / .12); transform: translateY(-2px); }
.ind-svc-ic {
  width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center;
  background: linear-gradient(150deg, hsl(255 60% 62% / .16), hsl(152 55% 48% / .16));
  color: hsl(255 52% 52%);
}
.ind-svc-ic svg { width: 22px; height: 22px; }
.ind-svc h3 {
  font-family: var(--font-display, 'Space Grotesk'), sans-serif;
  font-size: 18px; font-weight: 600; letter-spacing: -.01em; color: hsl(230 42% 15%);
  margin: 0; line-height: 1.25;
}
.ind-svc .go {
  margin-top: auto; display: inline-flex; align-items: center; gap: 7px;
  font-size: 14px; font-weight: 600; color: hsl(255 52% 52%);
}
.ind-svc .go svg { width: 14px; height: 14px; }

/* ---------- CTA ---------- */
.ind-cta { padding: 80px 0; text-align: center; background: hsl(230 40% 97%); }
.ind-cta h2 {
  font-family: var(--font-display, 'Space Grotesk'), sans-serif;
  font-size: clamp(28px, 3.4vw, 40px); font-weight: 700; letter-spacing: -.02em;
  color: hsl(230 42% 14%); margin: 0 0 14px;
}
.ind-cta p { font-size: 18px; color: hsl(230 14% 42%); margin: 0 0 30px; }

/* ---------- responsive ---------- */
@media (max-width: 900px) {
  .ind-proof, .ind-services { grid-template-columns: 1fr 1fr; }
  .ind-goals { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .ind-proof, .ind-services { grid-template-columns: 1fr; }
  .ind-hero { padding: 60px 0 54px; }
  .ind-sec { padding: 60px 0; }
}

/* ============================================================
   AGENCY landing page (conversion-rate-optimization-agency)
   ============================================================ */
/* hero "what you'll discover" list */
.ag-discover { list-style: none; margin: 26px 0 0; padding: 0; display: grid; gap: 13px; max-width: 56ch; }
.ag-discover li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 17.5px; line-height: 1.45; color: hsl(225 32% 86%);
}
.ag-discover li svg { flex: 0 0 auto; width: 22px; height: 22px; color: hsl(152 60% 56%); margin-top: 1px; }
.ag-hero-note { font-size: 13.5px; color: hsl(225 22% 64%); margin: 22px 0 0; max-width: 52ch; }

/* stats band */
.ag-stats { display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; }
.ag-stat { text-align: center; padding: 8px 6px; }
.ag-stat .n {
  font-family: var(--font-display, 'Space Grotesk'), sans-serif;
  font-size: clamp(30px, 3.4vw, 44px); font-weight: 700; letter-spacing: -.02em;
  color: hsl(255 52% 52%); line-height: 1;
}
.ag-stat .l { font-size: 13.5px; line-height: 1.4; color: hsl(230 14% 42%); margin-top: 9px; }
.ag-stats.on-dark .ag-stat .n { color: hsl(152 62% 60%); }
.ag-stats.on-dark .ag-stat .l { color: hsl(225 28% 78%); }

/* big testimonial */
.ag-quote { max-width: 60ch; margin: 0 auto; text-align: center; }
.ag-quote p {
  font-family: var(--font-display, 'Space Grotesk'), sans-serif;
  font-size: clamp(24px, 3vw, 34px); font-weight: 500; line-height: 1.3;
  letter-spacing: -.015em; color: hsl(230 42% 16%); margin: 0; text-wrap: balance;
}
.ag-quote .mk { color: hsl(255 52% 52%); }

/* feature grid */
.ag-features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.ag-feature { background: #fff; border: 1px solid hsl(230 28% 89%); border-radius: 16px; padding: 28px 26px; }
.ag-feature h3 {
  font-family: var(--font-display, 'Space Grotesk'), sans-serif;
  font-size: 19px; font-weight: 600; letter-spacing: -.01em; color: hsl(230 42% 15%);
  margin: 0 0 10px; line-height: 1.25;
}
.ag-feature p { margin: 0; font-size: 15.5px; line-height: 1.6; color: hsl(230 16% 40%); }

/* result testimonial cards */
.ag-results { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.ag-result {
  background: linear-gradient(160deg, hsl(230 42% 13%), hsl(232 44% 9%)); color: #fff;
  border-radius: 18px; padding: 32px 28px; position: relative; overflow: hidden;
}
.ag-result::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(420px 200px at 110% -10%, hsl(255 60% 60% / .3), transparent 60%); pointer-events: none;
}
.ag-result .n {
  font-family: var(--font-display, 'Space Grotesk'), sans-serif;
  font-size: 30px; font-weight: 700; letter-spacing: -.01em; line-height: 1.1;
  color: hsl(152 62% 62%); position: relative;
}
.ag-result .d { font-size: 15.5px; line-height: 1.5; color: hsl(225 28% 82%); margin: 12px 0 18px; position: relative; }
.ag-result .by { font-size: 14px; font-weight: 600; color: #fff; position: relative; }

@media (max-width: 960px) {
  .ag-stats { grid-template-columns: repeat(3, 1fr); gap: 26px 14px; }
  .ag-features, .ag-results { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 620px) {
  .ag-stats { grid-template-columns: 1fr 1fr; }
  .ag-features, .ag-results { grid-template-columns: 1fr; }
}
