/*
Theme Name: LearnPro WordPress V2
Theme URI: https://learnpro.in/
Author: LearnPro
Description: WordPress port of the LearnPro civil services publishing and coaching site with full homepage and mega navigation.
Version: 5.4.0
Requires at least: 6.0
Tested up to: 7.0
Text Domain: learnpro
*/

:root {
  --lp-ink: #111827;
  --lp-muted: #667085;
  --lp-soft: #f5f7fa;
  --lp-paper: #ffffff;
  --lp-line: #e5e7eb;
  --lp-navy: #14283d;
  --lp-navy-2: #0f2a40;
  --lp-orange: #f97316;
  --lp-gold: #d89b25;
  --lp-teal: #27b99f;
  --lp-rose: #fa5b89;
  --lp-violet: #875cf6;
  --lp-green: #16a34a;
  --lp-shadow: 0 18px 45px rgba(16, 24, 40, .10);
  --lp-max: 1220px;
  --lp-font-body: Manrope, "Noto Sans Devanagari", "Segoe UI Variable", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, Arial, sans-serif;
  --lp-font-ui: "Segoe UI Variable", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, Arial, sans-serif;
}

/* v4.4 premium hero and navigation refinement */
.lp-mega-row {
  border-top: 1px solid #e6ebf2;
  border-bottom: 1px solid #dbe3ee;
  background: rgba(255, 255, 255, .96);
  box-shadow: 0 10px 22px rgba(11, 31, 58, .05);
}

.lp-mega-nav {
  min-height: 54px;
  gap: 4px;
}

.lp-nav-button {
  min-height: 54px;
  border-top: 0;
  border-bottom: 3px solid transparent;
  padding: 0 14px;
  color: #25364d;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.lp-nav-button:hover,
.lp-nav-button.is-active {
  border-top-color: transparent;
  border-bottom-color: #f28c28;
  background: #f7f9fc;
  color: #0b1f3a;
}

.lp-mega-panel {
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 24px;
  border: 1px solid #d8e0eb;
  border-radius: 0 0 12px 12px;
  background: #fff;
  padding: 24px;
  box-shadow: 0 24px 60px rgba(11, 31, 58, .16);
}

.lp-mega-intro {
  border-radius: 10px;
  background: linear-gradient(145deg, #0b1f3a, #12355b);
  padding: 24px;
}

.lp-mega-intro h3 {
  font-size: 30px;
  letter-spacing: 0;
}

.lp-mega-columns {
  gap: 8px 16px;
}

.lp-mega-link {
  border: 1px solid transparent;
  border-radius: 9px;
  padding: 10px 12px;
  color: #1f2937;
  font-size: 13px;
  font-weight: 850;
}

.lp-mega-link:hover {
  border-color: #dbeafe;
  background: #f5f8fc;
  color: #0b1f3a;
}

.lp-quick-nav a {
  min-height: 36px;
  border-radius: 7px;
  font-weight: 850;
}

.lp-quick-nav a.is-hot,
.lp-quick-nav a.is-forest {
  box-shadow: 0 8px 18px rgba(242, 140, 40, .16);
}

.lp-hero-band {
  background:
    linear-gradient(180deg, #f8fafc 0%, #ffffff 44%, #f5f7fb 100%);
  padding: 26px 0 40px;
}

.lp-hero-grid {
  grid-template-columns: minmax(280px, .78fr) minmax(0, 1.92fr);
  gap: 20px;
}

.lp-channel-card,
.lp-promo-slider {
  border: 1px solid #dbe3ee;
  border-radius: 14px;
  box-shadow: 0 22px 56px rgba(11, 31, 58, .11);
}

.lp-channel-card {
  min-height: 350px;
  padding: 30px 26px;
  color: #0b1f3a;
}

.lp-channel-card::after {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .90), rgba(246, 248, 251, .94)),
    radial-gradient(circle at 50% 0%, rgba(242, 140, 40, .16), transparent 42%);
}

.lp-channel-logo {
  width: 82px;
  height: 82px;
  margin-bottom: 18px;
  border: 1px solid #e6ebf2;
  border-radius: 18px;
  box-shadow: 0 18px 40px rgba(11, 31, 58, .13);
}

.lp-channel-logo img {
  width: 50px;
  height: 50px;
}

.lp-channel-card h2 {
  max-width: 420px;
  margin: 0 auto;
  color: #0b1f3a;
  font-size: clamp(30px, 3.3vw, 46px);
  font-weight: 950;
  line-height: 1.06;
}

.lp-channel-cta {
  min-height: 54px;
  border-radius: 8px;
  background: #0b1f3a;
  padding: 0 24px;
  font-size: 15px;
  letter-spacing: .01em;
  box-shadow: 0 14px 28px rgba(11, 31, 58, .18);
}

.lp-channel-cta:hover {
  background: #f28c28;
}

.lp-promo-slider {
  min-height: 350px;
  background: #0b1f3a;
}

.lp-promo-slide {
  padding: 42px 64px 54px;
}

.lp-promo-slide::after {
  opacity: .98;
}

.lp-promo-slide.is-rose::after { background: linear-gradient(115deg, #0b1f3a 0%, #12355b 46%, #7f1238 100%); }
.lp-promo-slide.is-teal::after { background: linear-gradient(115deg, #0b1f3a 0%, #12355b 48%, #0f766e 100%); }
.lp-promo-slide.is-violet::after { background: linear-gradient(115deg, #0b1f3a 0%, #12355b 48%, #4338ca 100%); }

.lp-promo-slide img {
  opacity: .18;
  filter: saturate(.9) contrast(1.08);
}

.lp-promo-tag {
  border: 1px solid rgba(255, 255, 255, .28);
  background: rgba(255, 255, 255, .12);
  color: #fff4d6;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .06em;
}

.lp-promo-slide h1 {
  max-width: 760px;
  color: #fff6c7;
  font-size: clamp(34px, 4.6vw, 58px);
  font-weight: 950;
  line-height: 1.02;
  text-wrap: balance;
}

.lp-promo-slide p {
  color: #ffffff;
  font-size: clamp(17px, 2vw, 24px);
}

.lp-promo-slide strong {
  color: #fff;
  font-size: clamp(18px, 2.2vw, 28px);
}

.lp-promo-phone {
  left: 26px;
  bottom: 22px;
  min-height: 46px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .96);
  color: #0b1f3a;
  font-size: 19px;
}

.lp-slider-dots {
  right: 26px;
  bottom: 30px;
}

.lp-slider-dots button {
  height: 5px;
  background: rgba(255, 255, 255, .34);
}

.lp-slider-dots button.is-active {
  width: 38px;
  background: #f28c28;
}

.lp-promo-slide.is-active .lp-promo-tag,
.lp-promo-slide.is-active h1,
.lp-promo-slide.is-active p,
.lp-promo-slide.is-active strong {
  animation: lpHeroTextIn .72s cubic-bezier(.2, .8, .2, 1) both;
}

.lp-promo-slide.is-active h1 { animation-delay: .06s; }
.lp-promo-slide.is-active p { animation-delay: .14s; }
.lp-promo-slide.is-active strong { animation-delay: .22s; }

@keyframes lpHeroTextIn {
  from {
    opacity: 0;
    transform: translateY(18px);
    filter: blur(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}

.lp-programme-card,
.lp-practice-quiz,
.lp-resource-panel,
.lp-method-grid article,
.lp-quick-paths a,
.lp-hero-actions {
  border-color: #dbe3ee;
  border-radius: 12px;
  box-shadow: 0 14px 34px rgba(11, 31, 58, .07);
}

.lp-programme-top h3,
.lp-resource-panel h3,
.lp-method-grid h3 {
  letter-spacing: 0;
}

@media (prefers-reduced-motion: reduce) {
  .lp-promo-slide.is-active .lp-promo-tag,
  .lp-promo-slide.is-active h1,
  .lp-promo-slide.is-active p,
  .lp-promo-slide.is-active strong {
    animation: none;
  }
}

@media (max-width: 980px) {
  .lp-hero-grid {
    gap: 16px;
  }

  .lp-channel-card,
  .lp-promo-slider {
    min-height: 330px;
  }

  .lp-promo-slide {
    padding: 34px 32px 70px;
  }
}

@media (max-width: 640px) {
  .lp-hero-band {
    padding: 16px 0 30px;
  }

  .lp-channel-card {
    min-height: 280px;
    padding: 26px 22px;
  }

  .lp-channel-logo {
    width: 72px;
    height: 72px;
    border-radius: 16px;
  }

  .lp-channel-card h2 {
    font-size: 31px;
    line-height: 1.08;
  }

  .lp-channel-cta {
    width: 100%;
    justify-content: center;
    min-height: 52px;
    margin-top: 22px;
  }

  .lp-promo-slider {
    min-height: 360px;
  }

  .lp-promo-slide {
    justify-content: flex-start;
    padding: 36px 26px 78px;
  }

  .lp-promo-slide h1 {
    font-size: 40px;
    line-height: 1.04;
  }

  .lp-promo-slide p {
    font-size: 18px;
    line-height: 1.4;
  }

  .lp-promo-phone {
    left: 20px;
    bottom: 18px;
    font-size: 16px;
  }

  .lp-slider-dots {
    right: 20px;
    bottom: 28px;
  }

  .lp-sticky-cta a {
    font-size: 14px;
    line-height: 1.2;
    padding: 10px 6px;
  }
}

/* v5.2: clean top ticker, laptop hero scale and aligned programme cards */
.lp-top-strip {
  display: none !important;
}

.lp-site-header > .lp-announcement {
  position: relative;
  z-index: 80;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  min-height: 42px;
  border-bottom: 1px solid #1d3555;
  background: #0b1f3a;
  color: #fff;
}

.lp-site-header .lp-ann-label {
  min-width: 150px;
  justify-content: center;
  background: #f28c28;
  color: #111827;
  font-size: 12px;
  letter-spacing: 0;
}

.lp-site-header .lp-ann-track {
  display: flex;
  align-items: center;
  gap: 44px;
  overflow: hidden;
  padding: 0 28px;
  color: #e8eef7;
  font-size: 13px;
  font-weight: 800;
  white-space: nowrap;
}

.lp-site-header .lp-ann-track span {
  position: relative;
}

.lp-site-header .lp-ann-track span::after {
  content: "";
  position: absolute;
  right: -25px;
  top: 50%;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: #f28c28;
  transform: translateY(-50%);
}

.lp-site-header .lp-ann-phone {
  min-width: 156px;
  justify-content: center;
  background: #f28c28;
  color: #111827;
  font-size: 12px;
  font-weight: 900;
}

@media (min-width: 901px) {
  .lp-hero-band {
    padding: 22px 0 34px;
  }

  .lp-hero-grid {
    grid-template-columns: 312px minmax(0, 1fr);
    gap: 18px;
    align-items: stretch;
  }

  .lp-channel-card {
    min-height: 380px;
    padding: 28px 30px;
  }

  .lp-channel-card h2,
  .lp-channel-card h2.is-letter-animated {
    font-size: 42px !important;
    line-height: 1.06 !important;
    font-weight: 800 !important;
  }

  .lp-channel-cta {
    min-height: 48px;
    padding: 0 22px;
    font-size: 14px;
  }

  .lp-promo-slider {
    min-height: 380px;
    border-radius: 10px;
  }

  .lp-promo-slide {
    padding: 64px 58px 66px;
  }

  .lp-promo-slide h1 {
    max-width: 670px;
    font-size: 54px !important;
    line-height: 1.04 !important;
    font-weight: 850;
  }

  .lp-promo-slide p {
    font-size: 24px;
    line-height: 1.25;
  }

  .lp-promo-slide strong {
    font-size: 26px;
    line-height: 1.25;
  }
}

.lp-programme-grid {
  align-items: stretch;
}

.lp-programme-card {
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
  min-height: 100%;
  border-radius: 8px;
  border-color: #d8e0ea;
  box-shadow: 0 12px 28px rgba(11, 31, 58, .08);
}

.lp-programme-card:nth-child(3n + 1) .lp-programme-top {
  background: linear-gradient(135deg, #0b4f8a, #0b1f3a);
}

.lp-programme-card:nth-child(3n + 2) .lp-programme-top {
  background: linear-gradient(135deg, #0f766e, #0b1f3a);
}

.lp-programme-card:nth-child(3n) .lp-programme-top {
  background: linear-gradient(135deg, #8a1c1c, #0b1f3a);
}

.lp-programme-top {
  margin: -24px -24px 18px;
  padding: 22px 24px;
  color: #fff;
}

.lp-programme-top span {
  border: 1px solid rgba(255, 255, 255, .45);
  background: rgba(255, 255, 255, .14);
  color: #fff;
}

.lp-programme-top h3 {
  min-height: 58px;
  color: #fff;
  font-size: 25px;
  line-height: 1.16;
}

.lp-programme-top p {
  min-height: 64px;
  color: #e8eef7;
}

.lp-programme-facts {
  border: 1px solid #e3e8ef;
  border-radius: 8px;
  overflow: hidden;
}

.lp-programme-facts div {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 12px;
  border-bottom: 1px solid #e3e8ef;
  padding: 11px 13px;
}

.lp-programme-facts div:last-child {
  border-bottom: 0;
}

.lp-programme-card ul {
  align-self: stretch;
}

.lp-programme-actions {
  align-self: end;
}

@media (max-width: 900px) {
  .lp-site-header > .lp-announcement {
    grid-template-columns: 1fr;
  }

  .lp-site-header .lp-ann-label,
  .lp-site-header .lp-ann-phone {
    display: none;
  }

  .lp-site-header .lp-ann-track {
    min-height: 36px;
    padding: 0 16px;
    font-size: 12px;
    gap: 32px;
  }
}

@media (max-width: 640px) {
  .lp-channel-card h2,
  .lp-channel-card h2.is-letter-animated {
    font-size: 21px !important;
    line-height: 1.22 !important;
  }

  .lp-promo-slide h1 {
    font-size: 27px !important;
    line-height: 1.1 !important;
  }

  .lp-programme-top h3 {
    min-height: 0;
    font-size: 21px;
  }

  .lp-programme-top p {
    min-height: 0;
  }
}

/* v5.2: current affairs archive layout */
.lp-ca-hero { border-bottom:1px solid #e3e8ef; background:#f6f8fb; padding:34px 0 0; }
.lp-ca-breadcrumb { display:flex; gap:8px; margin-bottom:18px; color:#6b7280; font-size:13px; font-weight:800; }
.lp-ca-breadcrumb a { color:#12355b; text-decoration:none; }
.lp-ca-hero-grid { display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:28px; align-items:end; }
.lp-ca-hero h1 { margin:0; color:#0b1f3a; font-size:clamp(36px,5vw,58px); font-weight:850; line-height:1.04; }
.lp-ca-hero p { max-width:760px; margin:14px 0 28px; color:#4b5563; font-size:17px; line-height:1.65; }
.lp-ca-hero-panel { border-radius:8px 8px 0 0; background:#0b1f3a; padding:22px; color:#fff; }
.lp-ca-hero-panel strong { display:block; color:#ffb457; font-size:40px; line-height:1; }
.lp-ca-hero-panel span { display:block; margin-top:8px; color:#dbeafe; font-size:12px; font-weight:900; text-transform:uppercase; }
.lp-ca-hero-panel a { display:block; margin-top:18px; border-radius:6px; background:#f28c28; padding:12px; color:#111827; text-align:center; text-decoration:none; font-weight:900; }
.lp-ca-tabs { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); margin-top:24px; border:1px solid #d8e0ea; border-bottom:0; border-radius:8px 8px 0 0; overflow:hidden; background:#fff; }
.lp-ca-tabs a { border-right:1px solid #d8e0ea; padding:14px; color:#0b1f3a; text-align:center; text-decoration:none; font-size:13px; font-weight:900; }
.lp-ca-tabs a.is-active { background:#f28c28; color:#111827; }
.lp-ca-main,.lp-ca-band,.lp-ca-subjects,.lp-ca-faq { padding:44px 0; }
.lp-ca-band,.lp-ca-faq { background:#f6f8fb; }
.lp-ca-layout { display:grid; grid-template-columns:minmax(0,1fr) 340px; gap:26px; align-items:start; }
.lp-ca-section-head { margin-bottom:20px; }
.lp-ca-section-head p { margin:0 0 8px; color:#f28c28; font-size:12px; font-weight:900; text-transform:uppercase; }
.lp-ca-section-head h2 { margin:0; color:#0b1f3a; font-size:clamp(28px,3vw,38px); line-height:1.12; }
.lp-ca-section-head span { display:block; margin-top:8px; color:#6b7280; font-size:15px; }
.lp-ca-list,.lp-ca-side-card { border:1px solid #dbe3ee; border-radius:8px; overflow:hidden; background:#fff; }
.lp-ca-row { display:grid; grid-template-columns:82px minmax(0,1fr) auto; gap:18px; align-items:center; border-bottom:1px solid #e3e8ef; padding:18px; }
.lp-ca-row:last-child { border-bottom:0; }
.lp-ca-date { display:grid; min-height:82px; align-content:center; justify-items:center; border:1px solid #d8e0ea; border-radius:8px; background:#f6f8fb; color:#0b1f3a; text-decoration:none; }
.lp-ca-date strong { font-size:27px; line-height:1; }
.lp-ca-date span,.lp-ca-date em { font-size:11px; font-style:normal; font-weight:900; text-transform:uppercase; }
.lp-ca-date span { color:#f28c28; }
.lp-ca-type { margin:0 0 6px; color:#6b7280; font-size:11px; font-weight:900; text-transform:uppercase; }
.lp-ca-row h2 { margin:0; font-size:21px; line-height:1.28; }
.lp-ca-row h2 a { color:#0b1f3a; text-decoration:none; }
.lp-ca-row-body > p:not(.lp-ca-type) { margin:8px 0 0; color:#4b5563; font-size:14px; line-height:1.6; }
.lp-ca-row-meta { display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.lp-ca-row-meta span { border:1px solid #dbe3ee; border-radius:999px; padding:5px 9px; color:#536174; font-size:11px; font-weight:850; }
.lp-ca-read { display:inline-flex; min-width:128px; justify-content:center; border:1px solid #0b1f3a; border-radius:6px; padding:10px 13px; color:#0b1f3a; text-decoration:none; font-size:13px; font-weight:900; white-space:nowrap; }
.lp-ca-sidebar { position:sticky; top:112px; display:grid; gap:18px; }
.lp-ca-side-card h3 { margin:0; background:#0b1f3a; padding:15px 18px; color:#fff; font-size:17px; }
.lp-ca-side-list a { display:block; border-bottom:1px solid #e3e8ef; padding:14px 18px; color:#0b1f3a; text-decoration:none; }
.lp-ca-side-list span { display:block; margin-bottom:6px; color:#6b7280; font-size:11px; font-weight:900; text-transform:uppercase; }
.lp-ca-side-list strong { display:block; font-size:15px; line-height:1.35; }
.lp-ca-side-card.is-cta { padding:18px; }
.lp-ca-side-card.is-cta h3 { margin:-18px -18px 14px; }
.lp-ca-side-card.is-cta a { display:block; margin-top:10px; border-radius:6px; background:#f28c28; padding:12px; color:#111827; text-align:center; text-decoration:none; font-weight:900; }
.lp-ca-mains-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:14px; }
.lp-ca-mains-card { min-height:140px; border:1px solid #dbe3ee; border-radius:8px; background:#fff; padding:18px; color:#0b1f3a; text-decoration:none; }
.lp-ca-mains-card span { display:block; margin-bottom:10px; color:#6b7280; font-size:11px; font-weight:900; text-transform:uppercase; }
.lp-ca-mains-card strong { font-size:17px; line-height:1.35; }
.lp-ca-pagination ul { display:flex; flex-wrap:wrap; gap:8px; margin:22px 0 0; padding:0; list-style:none; }
.lp-ca-pagination a,.lp-ca-pagination span { display:inline-flex; min-width:40px; min-height:40px; align-items:center; justify-content:center; border:1px solid #d8e0ea; border-radius:6px; background:#fff; color:#0b1f3a; padding:0 12px; text-decoration:none; font-weight:900; }
.lp-ca-pagination .current { background:#0b1f3a; color:#fff; }

@media (max-width: 900px) {
  .lp-ca-hero-grid,.lp-ca-layout { grid-template-columns:1fr; }
  .lp-ca-sidebar { position:static; }
  .lp-ca-mains-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
}

@media (max-width: 640px) {
  .lp-ca-hero h1 { font-size:34px; }
  .lp-ca-tabs { grid-template-columns:1fr; }
  .lp-ca-row { grid-template-columns:64px minmax(0,1fr); gap:14px; padding:16px; }
  .lp-ca-date { min-height:64px; }
  .lp-ca-date strong { font-size:22px; }
  .lp-ca-row h2 { font-size:18px; }
  .lp-ca-row-body > p:not(.lp-ca-type) { display:none; }
  .lp-ca-read { grid-column:1 / -1; width:100%; }
  .lp-ca-mains-grid { grid-template-columns:1fr; }
}

/* v5.3: Elementor compatibility */
.lp-elementor-page {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

.lp-elementor-page .elementor {
  width: 100%;
}

.lp-elementor-full-width {
  background: #fff;
}

.lp-elementor-canvas {
  margin: 0;
  background: #fff;
}

.lp-elementor-canvas-content {
  min-height: 100vh;
}

/* v4.7: repeating Hindi animation and strict mobile hero layout */
.lp-hindi-letter {
  animation:
    lpHindiLetterRepeat 4.8s cubic-bezier(.2, .82, .2, 1) infinite both,
    lpHindiLetterGlow 4.8s ease-in-out infinite;
  animation-delay:
    calc(var(--letter-index) * 32ms),
    calc(.9s + (var(--letter-index) * 34ms));
}

@keyframes lpHindiLetterRepeat {
  0% {
    opacity: 0;
    transform: translateY(18px) scale(.94) rotateX(24deg);
    filter: blur(6px);
  }
  13% {
    opacity: 1;
    transform: translateY(0) scale(1) rotateX(0);
    filter: blur(0);
  }
  68% {
    opacity: 1;
    transform: translateY(0) scale(1) rotateX(0);
    filter: blur(0);
  }
  76% {
    opacity: 1;
    transform: translateY(-4px) scale(1.015) rotateX(0);
    filter: blur(0);
  }
  86%, 100% {
    opacity: 1;
    transform: translateY(0) scale(1) rotateX(0);
    filter: blur(0);
  }
}

@media (max-width: 980px) {
  .lp-hero-band {
    overflow: hidden;
  }

  .lp-hero-band .lp-container,
  .lp-hero-grid {
    max-width: 100%;
    overflow: hidden;
  }

  .lp-hero-grid {
    grid-template-columns: 1fr !important;
    gap: 18px;
  }

  .lp-channel-card,
  .lp-promo-slider {
    width: 100%;
    min-width: 0;
  }
}

@media (max-width: 640px) {
  .lp-hero-band .lp-container {
    width: min(100% - 24px, var(--lp-max));
  }

  .lp-channel-card {
    min-height: 0;
    padding: 28px 20px 24px;
  }

  .lp-channel-card h2.is-letter-animated {
    max-width: 100%;
    font-size: 34px;
    line-height: 1.12;
  }

  .lp-channel-logo {
    width: 68px;
    height: 68px;
    margin-bottom: 18px;
  }

  .lp-channel-logo img {
    width: 42px;
    height: 42px;
  }

  .lp-channel-cta {
    min-height: 50px;
    margin-top: 22px;
    font-size: 15px;
  }

  .lp-promo-slider {
    min-height: 330px;
  }

  .lp-promo-slide {
    padding: 30px 22px 76px;
  }

  .lp-promo-slide h1 {
    font-size: 34px;
    line-height: 1.08;
  }

  .lp-promo-slide p {
    font-size: 16px;
  }

  .lp-promo-slide strong {
    font-size: 19px;
  }

  .lp-hero-actions {
    padding: 18px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .lp-hindi-letter {
    animation: none;
  }
}

/* v4.8: tighter mobile hero typography */
@media (max-width: 640px) {
  .lp-hero-band {
    padding-top: 12px;
  }

  .lp-channel-card {
    padding: 22px 18px 20px;
  }

  .lp-channel-card h2,
  .lp-channel-card h2.is-letter-animated {
    max-width: 320px;
    font-size: 26px;
    line-height: 1.16;
  }

  .lp-channel-logo {
    width: 58px;
    height: 58px;
    margin-bottom: 14px;
    border-radius: 14px;
  }

  .lp-channel-logo img {
    width: 36px;
    height: 36px;
  }

  .lp-channel-cta {
    min-height: 46px;
    margin-top: 18px;
    padding: 0 16px;
    font-size: 14px;
  }

  .lp-promo-slider {
    min-height: 300px;
  }

  .lp-promo-slide {
    padding: 26px 20px 70px;
  }

  .lp-promo-slide h1 {
    font-size: 28px;
    line-height: 1.1;
  }

  .lp-promo-slide p {
    font-size: 15px;
    line-height: 1.38;
  }

  .lp-promo-slide strong {
    font-size: 17px;
    line-height: 1.35;
  }

  .lp-hero-actions strong {
    font-size: 21px;
    line-height: 1.2;
  }

  .lp-hero-actions span {
    font-size: 15px;
    line-height: 1.5;
  }
}

@media (max-width: 390px) {
  .lp-channel-card h2,
  .lp-channel-card h2.is-letter-animated {
    max-width: 290px;
    font-size: 24px;
  }

  .lp-promo-slide h1 {
    font-size: 26px;
  }
}

/* v4.9: clean Hindi typography and word-safe animation */
.lp-channel-card h2,
.lp-channel-card h2.is-letter-animated {
  color: #0b1f3a;
  font-family: "Noto Sans Devanagari", Hind, Manrope, "Segoe UI", system-ui, sans-serif;
  font-weight: 800;
  text-shadow: none;
}

.lp-hindi-word {
  display: inline-block;
  white-space: nowrap;
}

.lp-hindi-letter {
  color: #0b1f3a;
  text-shadow: none;
  animation: lpHindiLetterRepeat 5.2s cubic-bezier(.2, .82, .2, 1) infinite both;
  animation-delay: calc(var(--letter-index) * 28ms);
}

.lp-channel-card:hover .lp-hindi-letter {
  animation-name: lpHindiLetterRepeat;
}

@keyframes lpHindiLetterRepeat {
  0% {
    opacity: .15;
    transform: translateY(12px);
    filter: blur(4px);
  }
  12%, 72% {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
  82% {
    opacity: 1;
    transform: translateY(-2px);
    filter: blur(0);
  }
  100% {
    opacity: .15;
    transform: translateY(10px);
    filter: blur(4px);
  }
}

@media (max-width: 640px) {
  .lp-channel-card h2,
  .lp-channel-card h2.is-letter-animated {
    max-width: 300px;
    font-size: 25px;
    font-weight: 800;
    line-height: 1.18;
  }
}

@media (max-width: 390px) {
  .lp-channel-card h2,
  .lp-channel-card h2.is-letter-animated {
    max-width: 278px;
    font-size: 23px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .lp-hindi-letter {
    opacity: 1;
    transform: none;
    filter: none;
    animation: none;
  }
}

/* v5.0: mobile hero rebuild */
@media (max-width: 640px) {
  html,
  body {
    overflow-x: hidden;
  }

  .lp-hero-band {
    overflow: hidden;
    padding: 12px 0 28px;
    background: #f6f8fb;
  }

  .lp-hero-band .lp-container {
    width: min(100% - 28px, var(--lp-max));
    overflow: visible;
  }

  .lp-hero-grid {
    display: flex !important;
    width: 100%;
    min-width: 0;
    flex-direction: column;
    gap: 14px;
    overflow: visible;
  }

  .lp-channel-card,
  .lp-promo-slider {
    width: 100%;
    min-width: 0;
    border-radius: 12px;
    box-shadow: 0 12px 30px rgba(11, 31, 58, .08);
  }

  .lp-channel-card {
    min-height: 0 !important;
    align-items: stretch;
    justify-content: flex-start;
    padding: 16px !important;
    text-align: left;
  }

  .lp-channel-card > div {
    display: grid;
    width: 100%;
    grid-template-columns: 48px minmax(0, 1fr);
    column-gap: 13px;
    align-items: center;
  }

  .lp-channel-logo {
    width: 48px !important;
    height: 48px !important;
    margin: 0 !important;
    border-radius: 12px !important;
    box-shadow: 0 10px 22px rgba(11, 31, 58, .12);
  }

  .lp-channel-logo img {
    width: 31px !important;
    height: 31px !important;
  }

  .lp-channel-card h2,
  .lp-channel-card h2.is-letter-animated {
    max-width: none !important;
    margin: 0 !important;
    color: #0b1f3a;
    font-family: Hind, "Noto Sans Devanagari", Manrope, "Segoe UI", system-ui, sans-serif;
    font-size: 21px !important;
    font-weight: 700 !important;
    line-height: 1.22 !important;
    text-align: left;
    text-shadow: none;
  }

  .lp-hindi-word {
    white-space: nowrap;
  }

  .lp-hindi-letter {
    color: #0b1f3a;
    opacity: 1;
    transform: none;
    filter: none;
    animation: lpHindiMobileSoft 4.8s ease-in-out infinite;
    animation-delay: calc(var(--letter-index) * 24ms);
    text-shadow: none;
  }

  @keyframes lpHindiMobileSoft {
    0%, 100% { opacity: .72; transform: translateY(0); }
    22%, 70% { opacity: 1; transform: translateY(0); }
  }

  .lp-channel-cta {
    grid-column: 1 / -1;
    width: 100%;
    min-height: 44px !important;
    justify-content: center;
    margin-top: 14px !important;
    border-radius: 9px;
    padding: 0 14px !important;
    font-size: 14px !important;
    box-shadow: 0 10px 20px rgba(11, 31, 58, .16);
  }

  .lp-promo-slider {
    min-height: 278px !important;
  }

  .lp-promo-slide {
    justify-content: flex-start;
    padding: 22px 18px 70px !important;
  }

  .lp-promo-tag {
    margin-bottom: 12px;
    padding: 6px 12px;
    font-size: 10px;
  }

  .lp-promo-slide h1 {
    max-width: 100%;
    font-size: 27px !important;
    font-weight: 800;
    line-height: 1.1 !important;
    text-wrap: balance;
  }

  .lp-promo-slide p {
    margin-top: 12px;
    font-size: 14px !important;
    line-height: 1.38 !important;
  }

  .lp-promo-slide strong {
    margin-top: 9px;
    font-size: 15px !important;
    line-height: 1.35 !important;
  }

  .lp-promo-phone {
    left: 16px !important;
    right: auto;
    bottom: 16px !important;
    max-width: calc(100% - 32px);
    min-height: 40px !important;
    border-radius: 999px;
    padding: 0 14px !important;
    font-size: 14px !important;
    white-space: nowrap;
  }

  .lp-slider-dots {
    right: 18px !important;
    bottom: 24px !important;
  }

  .lp-slider-dots button {
    width: 20px;
  }

  .lp-slider-dots button.is-active {
    width: 28px;
  }

  .lp-hero-actions {
    margin-top: 14px;
    padding: 16px !important;
    border-radius: 12px;
  }

  .lp-hero-actions strong {
    font-size: 20px !important;
    line-height: 1.22;
  }

  .lp-hero-actions span {
    font-size: 14px !important;
    line-height: 1.45;
  }
}

@media (max-width: 390px) {
  .lp-channel-card h2,
  .lp-channel-card h2.is-letter-animated {
    font-size: 20px !important;
  }

  .lp-promo-slide h1 {
    font-size: 25px !important;
  }
}

/* v4.6: animated Hindi headline on the left hero card */
.lp-channel-card {
  background: #fff;
}

.lp-channel-card::after {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .94), rgba(248, 250, 252, .96)),
    radial-gradient(circle at 50% 0%, rgba(242, 140, 40, .12), transparent 38%);
}

.lp-channel-card h2.is-letter-animated {
  display: block;
  max-width: 430px;
  color: #071a33;
  font-family: var(--lp-font-body);
  font-weight: 950;
  letter-spacing: 0;
  text-wrap: balance;
}

.lp-hindi-letter {
  display: inline-block;
  transform-origin: 50% 75%;
  animation:
    lpHindiLetterRise .62s cubic-bezier(.2, .82, .2, 1) both,
    lpHindiLetterGlow 3.2s ease-in-out infinite;
  animation-delay:
    calc(var(--letter-index) * 34ms),
    calc(1.1s + (var(--letter-index) * 42ms));
  will-change: transform, opacity, color;
}

.lp-hindi-letter.is-space {
  width: .28em;
}

@keyframes lpHindiLetterRise {
  0% {
    opacity: 0;
    transform: translateY(22px) scale(.92) rotateX(28deg);
    filter: blur(7px);
  }
  68% {
    opacity: 1;
    transform: translateY(-3px) scale(1.02) rotateX(0);
    filter: blur(0);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1) rotateX(0);
    filter: blur(0);
  }
}

@keyframes lpHindiLetterGlow {
  0%, 72%, 100% {
    color: #071a33;
    text-shadow: none;
  }
  36% {
    color: #b45d08;
    text-shadow: 0 10px 28px rgba(242, 140, 40, .24);
  }
}

.lp-channel-card:hover .lp-hindi-letter {
  animation-name: lpHindiLetterRise, lpHindiLetterGlow;
}

@media (prefers-reduced-motion: reduce) {
  .lp-hindi-letter {
    animation: none;
  }
}

@media (max-width: 640px) {
  .lp-channel-card h2.is-letter-animated {
    font-size: 32px;
    line-height: 1.12;
  }

  .lp-hindi-letter {
    animation-delay:
      calc(var(--letter-index) * 24ms),
      calc(1s + (var(--letter-index) * 30ms));
  }
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--lp-ink);
  background: #ffffff;
  font-family: var(--lp-font-body);
  font-size: 16px;
  line-height: 1.62;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-synthesis: none;
}

.lp-top-strip,
.lp-brand,
.lp-quick-nav,
.lp-header-tools,
.lp-mega-nav,
.lp-mobile-panel,
.lp-button,
input,
button {
  font-family: var(--lp-font-ui);
  font-synthesis: none;
}

body.lp-mobile-open {
  overflow: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

button,
input {
  font: inherit;
}

.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.lp-container {
  width: min(var(--lp-max), calc(100% - 32px));
  margin: 0 auto;
}

.lp-icon {
  width: 1em;
  height: 1em;
  flex: 0 0 auto;
}

.lp-site-header {
  position: sticky;
  top: 0;
  z-index: 90;
  background: rgba(255, 255, 255, .98);
  border-bottom: 1px solid var(--lp-line);
  box-shadow: 0 1px 0 rgba(16, 24, 40, .02);
}

.lp-top-strip {
  background: #0f172a;
  color: #dbeafe;
  font-size: 13px;
  font-weight: 700;
}

.lp-top-strip-inner,
.lp-top-left,
.lp-top-right {
  display: flex;
  align-items: center;
}

.lp-top-strip-inner {
  min-height: 34px;
  justify-content: space-between;
  gap: 16px;
}

.lp-top-left,
.lp-top-right {
  gap: 18px;
}

.lp-top-strip a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #ffffff;
}

.lp-header-main {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  min-height: 74px;
  align-items: center;
  gap: 18px;
}

.lp-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 190px;
  font-weight: 900;
}

.lp-brand img {
  width: 44px;
  height: 44px;
}

.lp-brand-name {
  display: block;
  font-size: 25px;
  line-height: 1;
  letter-spacing: 0;
}

.lp-brand-name span {
  color: var(--lp-orange);
}

.lp-brand-kicker {
  display: block;
  width: max-content;
  margin-top: 4px;
  border: 1px solid #cfd5df;
  padding: 1px 5px;
  color: var(--lp-muted);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.lp-quick-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.lp-quick-nav a {
  display: inline-flex;
  min-height: 34px;
  align-items: center;
  gap: 6px;
  border: 1px solid transparent;
  padding: 7px 12px;
  color: var(--lp-navy);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.15;
  transition: background .18s ease, color .18s ease, border-color .18s ease;
}

.lp-quick-nav .lp-icon {
  width: 14px;
  height: 14px;
}

.lp-quick-nav a:hover {
  background: #f3f6fb;
}

.lp-quick-nav a.is-hot {
  background: var(--lp-orange);
  color: #fff;
}

.lp-quick-nav a.is-outline {
  border-color: var(--lp-navy);
  background: #fff;
}

.lp-quick-nav a.is-outline:hover,
.lp-quick-nav a.is-dark {
  background: var(--lp-navy);
  color: #fff;
}

.lp-quick-nav a.is-forest {
  border-radius: 999px;
  background: #dc2626;
  color: #fff;
  padding-inline: 14px;
}

.lp-quick-nav a.is-forest img {
  width: 14px;
  height: 14px;
  filter: brightness(0) invert(1);
}

.lp-live-dot {
  width: 8px;
  height: 8px;
  border-radius: 2px;
  background: #22c55e;
  box-shadow: 0 0 0 4px rgba(34, 197, 94, .16);
}

.lp-header-tools {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.lp-search {
  position: relative;
  width: min(270px, 22vw);
}

.lp-search .lp-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  width: 15px;
  height: 15px;
  color: #98a2b3;
  transform: translateY(-50%);
}

.lp-search input,
.lp-mobile-search input {
  width: 100%;
  min-height: 38px;
  border: 1px solid #d7dce5;
  border-radius: 8px;
  background: #f8fafc;
  color: var(--lp-ink);
  outline: none;
}

.lp-search input {
  padding: 8px 12px 8px 38px;
  font-size: 14px;
}

.lp-search input:focus,
.lp-mobile-search input:focus {
  border-color: var(--lp-navy);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(20, 40, 61, .10);
}

.lp-mobile-toggle {
  display: none;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--lp-line);
  border-radius: 8px;
  background: #fff;
  color: var(--lp-navy);
}

.lp-mega-row {
  border-top: 1px solid var(--lp-line);
  background: #fff;
}

.lp-mega-wrap {
  position: relative;
}

.lp-mega-nav {
  display: flex;
  align-items: stretch;
  gap: 2px;
  min-height: 48px;
  overflow-x: auto;
  scrollbar-width: none;
}

.lp-mega-nav::-webkit-scrollbar {
  display: none;
}

.lp-nav-item {
  position: static;
}

.lp-nav-button {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  gap: 5px;
  border: 0;
  border-top: 3px solid transparent;
  background: transparent;
  padding: 0 12px;
  color: #344054;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.15;
  text-transform: none;
  white-space: nowrap;
  cursor: pointer;
  transition: color .16s ease, background .16s ease, border-color .16s ease;
}

.lp-nav-button .lp-icon {
  width: 14px;
  height: 14px;
}

.lp-nav-button:hover,
.lp-nav-button.is-active {
  border-top-color: var(--lp-gold);
  background: #f8fafc;
  color: var(--lp-navy);
}

.lp-mega-panel {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  z-index: 100;
  display: none;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 20px;
  max-height: min(72vh, 620px);
  overflow: auto;
  border: 1px solid var(--lp-line);
  border-top: 0;
  border-radius: 0 0 8px 8px;
  background: #fff;
  padding: 18px;
  box-shadow: var(--lp-shadow);
}

.lp-mega-panel.is-active {
  display: grid;
}

.lp-mega-intro {
  border-radius: 8px;
  background: linear-gradient(145deg, var(--lp-navy), #203b59);
  color: #fff;
  padding: 20px;
}

.lp-mega-intro p,
.lp-mega-intro span {
  margin: 0;
  color: #bfd2e5;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.lp-mega-intro h3 {
  margin: 8px 0 16px;
  font-size: 28px;
  line-height: 1.05;
}

.lp-mega-intro a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #ffdca8;
  font-size: 13px;
  font-weight: 900;
}

.lp-mega-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px 18px;
}

.lp-mega-branch {
  break-inside: avoid;
}

.lp-mega-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border-radius: 8px;
  padding: 9px 10px;
  color: #344054;
  font-size: 13px;
  font-weight: 750;
  line-height: 1.25;
}

.lp-mega-link:hover {
  background: #eef4ff;
  color: var(--lp-navy);
}

.lp-mega-nested {
  margin: 2px 0 6px 11px;
  border-left: 2px solid #edf1f7;
  padding-left: 8px;
}

.lp-mega-nested .lp-mega-link {
  padding-block: 6px;
  color: #5d6675;
  font-size: 12px;
  font-weight: 700;
}

.lp-static-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.lp-static-card {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 10px;
  align-items: start;
  min-height: 96px;
  border: 1px solid var(--lp-line);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.lp-static-card:hover {
  border-color: #bfdbfe;
  box-shadow: 0 14px 30px rgba(20, 40, 61, .10);
  transform: translateY(-1px);
}

.lp-static-card > span {
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border-radius: 8px;
  background: #eef4ff;
  color: var(--lp-navy);
}

.lp-static-card strong,
.lp-static-card em {
  display: block;
}

.lp-static-card strong {
  color: var(--lp-ink);
  font-size: 14px;
  line-height: 1.2;
}

.lp-static-card em {
  margin-top: 4px;
  color: var(--lp-muted);
  font-size: 12px;
  font-style: normal;
  line-height: 1.35;
}

.lp-mobile-panel {
  position: fixed;
  inset: 0 0 0 auto;
  z-index: 200;
  width: min(420px, 100vw);
  display: none;
  flex-direction: column;
  background: #fff;
  box-shadow: -20px 0 45px rgba(16, 24, 40, .20);
}

.lp-mobile-panel.is-open {
  display: flex;
}

.lp-mobile-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--lp-line);
  padding: 14px 16px;
  font-weight: 900;
}

.lp-mobile-panel-head button {
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid var(--lp-line);
  border-radius: 8px;
  background: #fff;
}

.lp-mobile-search {
  position: relative;
  padding: 12px 16px;
}

.lp-mobile-search .lp-icon {
  position: absolute;
  left: 28px;
  top: 50%;
  width: 15px;
  transform: translateY(-50%);
  color: #98a2b3;
}

.lp-mobile-search input {
  padding: 10px 12px 10px 38px;
}

.lp-mobile-scroll {
  overflow: auto;
  padding: 0 14px 18px;
}

.lp-mobile-main-link,
.lp-mobile-cta {
  display: flex;
  min-height: 42px;
  align-items: center;
  border-radius: 8px;
  padding: 9px 12px;
  font-size: 14px;
  font-weight: 800;
}

.lp-mobile-main-link.is-hot {
  color: var(--lp-orange);
}

.lp-mobile-cta {
  justify-content: center;
  margin-top: 12px;
  background: var(--lp-orange);
  color: #fff;
}

.lp-mobile-details {
  border-top: 1px solid var(--lp-line);
}

.lp-mobile-details summary {
  cursor: pointer;
  padding: 12px;
  font-weight: 900;
}

.lp-mobile-details .lp-mega-nested {
  margin-left: 4px;
}

.lp-mobile-details .lp-mega-link {
  font-size: 13px;
}

.lp-announcement {
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  overflow: hidden;
  background: #111827;
  color: #fff;
}

.lp-ann-label,
.lp-ann-phone {
  position: relative;
  z-index: 1;
  display: flex;
  min-height: 42px;
  align-items: center;
  gap: 9px;
  background: linear-gradient(90deg, var(--lp-orange), #ea580c);
  padding: 0 22px;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.lp-ann-phone {
  font-size: 13px;
  text-transform: none;
}

.lp-ann-track {
  display: flex;
  gap: 40px;
  width: max-content;
  min-width: 100%;
  padding: 0 24px;
  color: #cbd5e1;
  font-size: 13px;
  font-weight: 650;
  white-space: nowrap;
  animation: lpTicker 32s linear infinite;
}

.lp-ann-track span::after {
  content: "•";
  margin-left: 40px;
  color: var(--lp-orange);
}

@keyframes lpTicker {
  from { transform: translateX(0); }
  to { transform: translateX(-45%); }
}

.lp-button {
  display: inline-flex;
  min-height: 42px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 1px solid transparent;
  border-radius: 8px;
  padding: 10px 16px;
  background: var(--lp-navy);
  color: #fff;
  font-size: 14px;
  font-weight: 900;
  line-height: 1.1;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.lp-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(20, 40, 61, .18);
}

.lp-button.is-orange {
  background: var(--lp-orange);
}

.lp-button.is-teal {
  background: var(--lp-teal);
}

.lp-button.is-outline {
  border-color: var(--lp-navy);
  background: transparent;
  color: var(--lp-navy);
}

.lp-hero-band {
  border-bottom: 1px solid var(--lp-line);
  background: #f2f2f2;
  padding: 20px 0 34px;
}

.lp-hero-grid {
  display: grid;
  grid-template-columns: minmax(260px, .88fr) minmax(0, 1.9fr);
  gap: 14px;
}

.lp-channel-card,
.lp-promo-slider,
.lp-info-panel,
.lp-card,
.lp-update-column,
.lp-founder-card,
.lp-testimonial {
  border: 1px solid var(--lp-line);
  border-radius: 8px;
  background: var(--lp-paper);
  box-shadow: 0 10px 28px rgba(16, 24, 40, .06);
}

.lp-channel-card {
  position: relative;
  min-height: 270px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 26px;
  text-align: center;
}

.lp-channel-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--lp-channel-bg);
  background-position: center;
  background-size: cover;
}

.lp-channel-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(248, 237, 220, .84);
}

.lp-channel-card > * {
  position: relative;
  z-index: 1;
}

.lp-channel-logo {
  display: grid;
  width: 72px;
  height: 72px;
  place-items: center;
  margin: 0 auto 16px;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(16, 24, 40, .14);
}

.lp-channel-logo img {
  width: 46px;
  height: 46px;
}

.lp-channel-card h2 {
  margin: 0;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.08;
  letter-spacing: 0;
}

.lp-channel-cta {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  gap: 10px;
  margin: 24px 0 0;
  background: #dc2626;
  padding: 0 18px;
  color: #fff;
  font-size: 16px;
  font-weight: 900;
}

.lp-promo-slider {
  position: relative;
  min-height: 270px;
  overflow: hidden;
  background: #0b1220;
}

.lp-promo-slide {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  opacity: 0;
  padding: 34px 58px 42px 94px;
  color: #fff;
  transition: opacity .45s ease;
}

.lp-promo-slide.is-active {
  opacity: 1;
  z-index: 1;
}

.lp-promo-slide::before,
.lp-promo-slide::after {
  content: "";
  position: absolute;
  inset: 0;
}

.lp-promo-slide::before {
  z-index: -2;
  background: #0b1220;
}

.lp-promo-slide::after {
  z-index: -1;
  opacity: .94;
}

.lp-promo-slide.is-rose::after { background: linear-gradient(90deg, #8f1235, #a41442 55%, #3a0c20); }
.lp-promo-slide.is-teal::after { background: linear-gradient(90deg, #0a3140, #0b5268 55%, #051924); }
.lp-promo-slide.is-violet::after { background: linear-gradient(90deg, #3b187f, #6d3de8 55%, #1d0c44); }

.lp-promo-slide img {
  position: absolute;
  inset: 0;
  z-index: -3;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .34;
}

.lp-promo-slide h1 {
  max-width: 780px;
  margin: 0;
  color: #ffe45c;
  font-size: clamp(30px, 4.2vw, 50px);
  line-height: 1.04;
  letter-spacing: 0;
}

.lp-promo-slide p,
.lp-promo-slide strong {
  max-width: 780px;
}

.lp-promo-slide p {
  margin: 14px 0 0;
  color: #fff;
  font-size: clamp(16px, 2vw, 22px);
  font-weight: 900;
}

.lp-promo-slide strong {
  margin-top: 12px;
  font-size: clamp(18px, 2.2vw, 28px);
}

.lp-promo-tag {
  width: fit-content;
  margin-bottom: 14px;
  border-radius: 999px;
  background: #ffd24a;
  padding: 6px 14px;
  color: #551229;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.lp-promo-phone {
  position: absolute;
  left: 0;
  bottom: 0;
  display: inline-flex;
  min-height: 46px;
  align-items: center;
  gap: 8px;
  border-radius: 0 16px 0 0;
  background: #fff;
  padding: 0 20px;
  color: #b51b3f;
  font-size: 22px;
  font-weight: 900;
}

.lp-slider-dots {
  position: absolute;
  right: 18px;
  bottom: 16px;
  z-index: 4;
  display: flex;
  gap: 8px;
}

.lp-slider-dots button {
  width: 28px;
  height: 4px;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, .45);
  cursor: pointer;
}

.lp-slider-dots button.is-active {
  background: #ffd24a;
}

.lp-portal-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(0, .95fr) minmax(0, .95fr);
  gap: 18px;
  margin-top: 18px;
}

.lp-hero-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto auto;
  gap: 12px;
  align-items: center;
  margin-top: 22px;
  border: 1px solid #dbe3ee;
  border-radius: 8px;
  background: #fff;
  padding: 16px;
  box-shadow: 0 10px 24px rgba(16, 24, 40, .06);
}

.lp-hero-actions strong,
.lp-hero-actions span {
  display: block;
}

.lp-hero-actions strong {
  color: #0b1f3a;
  font-size: 18px;
  font-weight: 900;
}

.lp-hero-actions span {
  margin-top: 4px;
  color: #536174;
  font-size: 14px;
  line-height: 1.45;
}

.lp-quick-paths {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.lp-quick-paths a {
  border: 1px solid #dbe3ee;
  border-radius: 8px;
  background: #fff;
  padding: 16px;
  color: #0b1f3a;
}

.lp-quick-paths strong {
  display: block;
  font-size: 15px;
  font-weight: 900;
}

.lp-quick-paths span {
  display: block;
  margin-top: 5px;
  color: #667085;
  font-size: 13px;
  line-height: 1.4;
}

.lp-panel-head {
  display: flex;
  min-height: 62px;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 15px 18px;
  color: #fff;
  font-weight: 900;
}

.lp-panel-head > span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.lp-panel-head.is-teal { background: var(--lp-teal); }
.lp-panel-head.is-violet { background: var(--lp-violet); }
.lp-panel-head.is-rose { background: var(--lp-rose); }

.lp-quiz-score {
  display: inline-flex;
  min-width: 54px;
  min-height: 28px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(17, 24, 39, .95);
  color: #fff;
  font-size: 13px;
  font-weight: 800;
}

.lp-quiz-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.lp-quiz-question[hidden] {
  display: none;
}

.lp-quiz-progress {
  margin: 0 0 10px;
  color: var(--lp-teal);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.lp-quiz-question-text {
  margin: 0 0 14px;
  color: #101828;
  font-size: 15px;
  line-height: 1.48;
}

.lp-question-lead,
.lp-question-final {
  margin: 0 0 10px;
  color: #101828;
  font-size: 17px;
  font-weight: 800;
  line-height: 1.42;
}

.lp-question-final {
  margin-top: 10px;
  margin-bottom: 0;
}

.lp-question-list {
  display: grid;
  gap: 8px;
  margin: 10px 0 12px;
  padding: 0;
  list-style: none;
}

.lp-question-list li {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 9px;
  align-items: start;
  border: 1px solid #e3e8ef;
  border-radius: 8px;
  background: #f8fafc;
  padding: 9px 10px;
  color: #344054;
  font-size: 14px;
  line-height: 1.45;
}

.lp-question-list:not(.is-statements) li {
  display: block;
  padding: 11px 12px;
}

.lp-question-list:not(.is-statements) li span {
  display: block;
}

.lp-question-list.is-statements li {
  grid-template-columns: 94px minmax(0, 1fr);
}

.lp-question-no {
  color: #0f766e;
  font-weight: 900;
}

.lp-question-table {
  overflow: hidden;
  border: 1px solid #d9e2ec;
  border-radius: 8px;
  background: #fff;
  margin: 10px 0 12px;
}

.lp-question-row {
  display: grid;
  grid-template-columns: minmax(96px, .8fr) minmax(0, 1.35fr);
  border-top: 1px solid #e4e7ec;
}

.lp-question-row:first-child {
  border-top: 0;
}

.lp-question-row span {
  padding: 9px 10px;
  color: #344054;
  font-size: 13px;
  line-height: 1.42;
}

.lp-question-row span:first-child {
  border-right: 1px solid #e4e7ec;
  color: #111827;
  font-weight: 800;
}

.lp-question-row.is-head {
  background: #0f172a;
}

.lp-question-row.is-head span {
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

@media (max-width: 520px) {
  .lp-node-hero-inner,
  .lp-node-two-col {
    grid-template-columns: 1fr;
  }

  .lp-node-hero-inner {
    padding: 34px 0;
  }

  .lp-node-hero h1 {
    font-size: 32px;
  }

  .lp-node-stat-grid,
  .lp-node-link-grid,
  .lp-node-link-grid.is-subjects,
  .lp-node-link-grid.is-states,
  .lp-node-tabs {
    grid-template-columns: 1fr;
  }

  .lp-node-tabs a {
    border-right: 0;
    border-bottom: 1px solid #d0d5dd;
  }

  .lp-node-tabs a:last-child {
    border-bottom: 0;
  }

  .lp-node-table > div {
    grid-template-columns: 1fr;
  }

  .lp-node-two-col aside {
    position: static;
  }

  .lp-question-row {
    grid-template-columns: 1fr;
  }

  .lp-question-row span:first-child {
    border-right: 0;
    border-bottom: 1px solid #e4e7ec;
    background: #f8fafc;
  }

  .lp-question-row.is-head {
    display: none;
  }

  .lp-question-list.is-statements li {
    grid-template-columns: 1fr;
  }
}

.lp-quiz-options {
  display: grid;
  gap: 9px;
}

.lp-quiz-option {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  width: 100%;
  border: 2px solid #d7dce5;
  border-radius: 8px;
  background: #fff;
  padding: 9px 11px;
  color: #1f2937;
  text-align: left;
  cursor: pointer;
  transition: border-color .16s ease, background .16s ease, box-shadow .16s ease, transform .16s ease;
}

.lp-quiz-option:hover:not(:disabled) {
  border-color: #98a2b3;
  background: #f8fafc;
  transform: translateY(-1px);
}

.lp-quiz-option span {
  display: inline-grid;
  width: 28px;
  height: 28px;
  place-items: center;
  border-radius: 999px;
  background: #eef2f7;
  color: #344054;
  font-size: 12px;
  font-weight: 900;
}

.lp-quiz-option strong {
  font-size: 13px;
  line-height: 1.35;
}

.lp-quiz-option.is-selected {
  border-color: var(--lp-navy);
  background: #f0f6ff;
}

.lp-quiz-option.is-selected span {
  background: var(--lp-navy);
  color: #fff;
}

.lp-quiz-option.is-correct {
  border-color: #16a34a;
  background: #ecfdf3;
}

.lp-quiz-option.is-correct span {
  background: #16a34a;
  color: #fff;
}

.lp-quiz-option.is-wrong {
  border-color: #dc2626;
  background: #fef2f2;
}

.lp-quiz-option.is-wrong span {
  background: #dc2626;
  color: #fff;
}

.lp-quiz-option:disabled {
  cursor: default;
}

.lp-quiz-explanation {
  margin-top: 12px;
  border-left: 4px solid var(--lp-teal);
  border-radius: 8px;
  background: #f0fdfa;
  padding: 11px 13px;
}

.lp-quiz-explanation b {
  display: block;
  color: #0f766e;
  font-size: 13px;
}

.lp-quiz-explanation p {
  margin: 5px 0 0;
  color: #344054;
  font-size: 13px;
  line-height: 1.5;
}

.lp-quiz-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 14px;
}

.lp-quiz-actions button,
.lp-quiz-result button {
  min-height: 38px;
  border: 0;
  border-radius: 8px;
  background: var(--lp-navy);
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.lp-quiz-actions button:first-child,
.lp-quiz-actions button:nth-child(2) {
  border: 1px solid #d7dce5;
  background: #fff;
  color: #344054;
}

.lp-quiz-actions button:disabled {
  cursor: not-allowed;
  opacity: .45;
}

.lp-quiz-result {
  display: grid;
  gap: 7px;
  margin-top: 12px;
  border-radius: 8px;
  background: #111827;
  padding: 13px;
  color: #fff;
}

.lp-quiz-result[hidden] {
  display: none;
}

.lp-quiz-result strong {
  font-size: 16px;
}

.lp-quiz-result span {
  color: #d1d5db;
  font-size: 13px;
}

.lp-quiz-result button {
  width: fit-content;
  border: 1px solid rgba(255, 255, 255, .28);
  background: transparent;
  padding: 0 14px;
}

.lp-quiz-footer {
  margin: 13px 0 0;
}

.lp-quiz-footer a {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--lp-navy);
  font-size: 13px;
  font-weight: 900;
}

.lp-answer-tabs {
  display: flex;
  flex: 0 0 auto;
  gap: 5px;
}

.lp-answer-tabs a {
  display: inline-grid;
  width: 27px;
  height: 27px;
  place-items: center;
  border-radius: 999px;
  background: #fff;
  color: #111827;
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
  transition: background .16s ease, color .16s ease, transform .16s ease;
}

.lp-answer-tabs a:hover,
.lp-answer-tabs a:focus-visible,
.lp-answer-tabs a.is-active,
.lp-answer-tabs a[aria-selected="true"] {
  background: #111827;
  color: #fff;
}

.lp-answer-tabs a:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

.lp-answer-tabs a:hover {
  transform: translateY(-1px);
}

.lp-info-panel-body {
  padding: 20px;
}

.lp-practice-item[hidden] {
  display: none;
}

.lp-practice-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.lp-practice-summary {
  margin: 0 0 12px;
  color: #475467;
  font-size: 14px;
  line-height: 1.55;
}

.lp-practice-points {
  margin: 0 0 18px;
  padding-left: 18px;
  color: #475467;
  font-size: 14px;
  line-height: 1.55;
}

.lp-info-panel-body h3 {
  margin: 8px 0 12px;
  font-size: 19px;
  line-height: 1.45;
}

.lp-info-panel-body ol {
  margin: 0 0 18px;
  padding-left: 20px;
  color: #475467;
  font-size: 14px;
}

.lp-list-links,
.lp-link-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.lp-list-links li + li,
.lp-link-list li + li {
  border-top: 1px solid var(--lp-line);
}

.lp-list-links a,
.lp-link-list a {
  display: block;
  padding: 14px 18px;
}

.lp-list-links strong,
.lp-link-list strong {
  display: block;
  color: var(--lp-ink);
  line-height: 1.35;
}

.lp-list-links span,
.lp-link-list span,
.lp-card-kicker,
.lp-section-label {
  color: var(--lp-muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.lp-link-list a:hover strong,
.lp-list-links a:hover strong {
  color: var(--lp-orange);
}

.lp-section {
  padding: 64px 0;
}

.lp-section.is-soft {
  background: var(--lp-soft);
}

.lp-section.is-dark-band {
  background: #111827;
  color: #fff;
}

.lp-section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 26px;
}

.lp-section-head.is-centered {
  justify-content: center;
  text-align: center;
}

.lp-section-head h2,
.lp-about-grid h2,
.lp-why-grid h2,
.lp-app-grid h2,
.lp-archive-title,
.lp-entry-title {
  margin: 0;
  font-size: clamp(30px, 3.3vw, 48px);
  line-height: 1.08;
  letter-spacing: 0;
}

.lp-section-head p:not(.lp-section-label),
.lp-about-grid > div > p,
.lp-why-grid p,
.lp-app-grid p {
  max-width: 700px;
  margin: 10px 0 0;
  color: var(--lp-muted);
  font-size: 16px;
}

.lp-section-label {
  margin: 0 0 8px;
  color: var(--lp-gold);
  letter-spacing: 0;
}

.lp-updates-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr 1fr;
  gap: 18px;
}

.lp-update-column {
  overflow: hidden;
}

.lp-update-column h3 {
  margin: 0;
  border-bottom: 1px solid var(--lp-line);
  padding: 18px;
  color: var(--lp-navy);
  font-size: 20px;
}

.lp-update-column.is-dark {
  background: var(--lp-navy);
  color: #fff;
}

.lp-update-column.is-dark h3 {
  border-color: rgba(255, 255, 255, .14);
  color: #fff;
}

.lp-update-column.is-dark .lp-link-list li {
  border-color: rgba(255, 255, 255, .12);
}

.lp-update-column.is-dark .lp-link-list strong {
  color: #fff;
}

.lp-update-column.is-dark .lp-link-list span {
  color: #bfd2e5;
}

.lp-course-table {
  overflow: hidden;
  border: 1px solid var(--lp-line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 32px rgba(16, 24, 40, .06);
}

.lp-programmes-section {
  background: #f6f8fb;
}

.lp-programme-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.lp-programme-card {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  border: 1px solid #dbe3ee;
  border-radius: 8px;
  background: #fff;
  padding: 24px;
  box-shadow: 0 12px 30px rgba(16, 24, 40, .06);
}

.lp-programme-top span {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  border: 1px solid rgba(242, 140, 40, .34);
  border-radius: 999px;
  background: #fff7ed;
  padding: 0 10px;
  color: #9a4f08;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.lp-programme-top h3 {
  margin: 14px 0 10px;
  color: #0b1f3a;
  font-size: 24px;
  line-height: 1.18;
  letter-spacing: 0;
}

.lp-programme-top p {
  margin: 0;
  color: #536174;
  font-size: 15px;
  line-height: 1.65;
}

.lp-programme-facts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 20px 0 18px;
}

.lp-programme-facts div {
  border: 1px solid #e3e8ef;
  border-radius: 8px;
  background: #f8fafc;
  padding: 12px;
}

.lp-programme-facts dt {
  margin: 0 0 5px;
  color: #6b7280;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.lp-programme-facts dd {
  margin: 0;
  color: #1f2937;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.35;
}

.lp-programme-card ul {
  display: grid;
  gap: 8px;
  margin: 0 0 22px;
  padding: 0;
  list-style: none;
}

.lp-programme-card li {
  position: relative;
  padding-left: 18px;
  color: #364152;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.45;
}

.lp-programme-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .62em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #138a36;
}

.lp-programme-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: auto;
}

.lp-programme-actions .lp-button {
  min-height: 44px;
}

.lp-practice-section {
  background: #fff;
}

.lp-practice-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, .65fr);
  gap: 18px;
  align-items: start;
}

.lp-practice-quiz,
.lp-resource-panel {
  border: 1px solid #dbe3ee;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(16, 24, 40, .06);
}

.lp-practice-quiz {
  overflow: hidden;
}

.lp-practice-quiz-head {
  display: flex;
  min-height: 72px;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border-bottom: 1px solid #dbe3ee;
  background: #0b1f3a;
  padding: 18px 22px;
  color: #fff;
}

.lp-practice-quiz-head strong,
.lp-practice-quiz-head span {
  display: block;
}

.lp-practice-quiz-head strong {
  font-size: 20px;
  font-weight: 900;
}

.lp-practice-quiz-head span {
  margin-top: 4px;
  color: #dbeafe;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.lp-practice-quiz-body {
  padding: 24px;
}

.lp-resource-panel {
  display: grid;
  overflow: hidden;
}

.lp-resource-panel h3 {
  margin: 0;
  border-bottom: 1px solid #dbe3ee;
  padding: 20px 22px;
  color: #0b1f3a;
  font-size: 22px;
}

.lp-resource-panel a {
  display: block;
  border-bottom: 1px solid #e3e8ef;
  padding: 18px 22px;
  color: #0b1f3a;
}

.lp-resource-panel a:last-child {
  border-bottom: 0;
}

.lp-resource-panel strong,
.lp-resource-panel span {
  display: block;
}

.lp-resource-panel strong {
  font-size: 16px;
  font-weight: 900;
}

.lp-resource-panel span {
  margin-top: 6px;
  color: #667085;
  font-size: 14px;
  line-height: 1.45;
}

.lp-method-section {
  background: #f6f8fb;
}

.lp-method-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.lp-method-grid article {
  border: 1px solid #dbe3ee;
  border-radius: 8px;
  background: #fff;
  padding: 22px;
}

.lp-method-grid span {
  display: inline-flex;
  width: 36px;
  height: 36px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #0b1f3a;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
}

.lp-method-grid h3 {
  margin: 16px 0 8px;
  color: #0b1f3a;
  font-size: 18px;
  line-height: 1.25;
}

.lp-method-grid p {
  margin: 0;
  color: #536174;
  font-size: 14px;
  line-height: 1.55;
}

.lp-final-cta {
  background: #0b1f3a;
  color: #fff;
  padding: 56px 0;
}

.lp-final-cta-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: center;
}

.lp-final-cta h2 {
  margin: 0 0 10px;
  color: #fff;
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.05;
}

.lp-final-cta p {
  max-width: 720px;
  margin: 0;
  color: #dbeafe;
  font-size: 17px;
  line-height: 1.6;
}

.lp-final-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.lp-final-cta .lp-button.is-outline {
  border-color: rgba(255, 255, 255, .65);
  color: #fff;
}

.lp-course-row {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr) 160px 120px;
  gap: 14px;
  align-items: center;
  border-bottom: 1px solid var(--lp-line);
  padding: 16px 18px;
}

.lp-course-row:last-child {
  border-bottom: 0;
}

.lp-course-row:hover {
  background: #f8fafc;
}

.lp-course-row span {
  color: var(--lp-orange);
  font-size: 14px;
  font-weight: 900;
}

.lp-course-row strong {
  font-size: 16px;
  line-height: 1.3;
}

.lp-course-row em {
  color: var(--lp-muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 700;
}

.lp-course-row b {
  justify-self: end;
  color: var(--lp-navy);
  font-size: 13px;
}

.lp-center-action {
  margin: 24px 0 0;
  text-align: center;
}

.lp-about-grid,
.lp-why-grid,
.lp-app-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, .65fr);
  gap: 42px;
  align-items: start;
}

.lp-principles {
  display: grid;
  gap: 18px;
  margin-top: 28px;
}

.lp-principles > div {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 14px;
}

.lp-principles span {
  display: grid;
  width: 44px;
  height: 44px;
  place-items: center;
  border-radius: 8px;
  background: #fff4ed;
  color: var(--lp-orange);
}

.lp-principles strong {
  display: block;
  font-size: 16px;
}

.lp-principles p {
  grid-column: 2;
  margin: -8px 0 0;
  color: #667085;
  font-size: 14px;
}

.lp-founder-card {
  padding: 22px;
  text-align: center;
}

.lp-founder-card h3 {
  margin: 0 0 18px;
  font-size: 20px;
}

.lp-founder-card img {
  width: 190px;
  height: 190px;
  margin: 0 auto 20px;
  border: 5px solid #fed7aa;
  border-radius: 50%;
  object-fit: cover;
}

.lp-founder-card ul {
  margin: 0;
  padding: 0;
  list-style: none;
  text-align: left;
}

.lp-founder-card li {
  position: relative;
  padding: 8px 0 8px 18px;
  color: #475467;
  font-size: 14px;
}

.lp-founder-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 17px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--lp-orange);
}

.lp-why-grid {
  align-items: center;
}

.lp-why-grid p {
  color: #cbd5e1;
}

.lp-why-grid .lp-section-label {
  color: #ffd24a;
}

.lp-why-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.lp-why-cards a {
  min-height: 132px;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 8px;
  background: rgba(255, 255, 255, .06);
  padding: 18px;
  color: #fff;
  font-size: 17px;
  font-weight: 900;
}

.lp-why-cards span {
  display: block;
  margin-top: 8px;
  color: #cbd5e1;
  font-size: 13px;
  font-weight: 600;
}

.lp-study-desk-section {
  background: #fff;
  padding-top: 74px;
}

.lp-study-desk {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(420px, 1.05fr);
  gap: 34px;
  align-items: stretch;
  border: 1px solid #dbe3ee;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 24px 60px rgba(11, 31, 58, .08);
  overflow: hidden;
}

.lp-study-lead {
  padding: 36px;
  background: #0b1f3a;
  color: #fff;
}

.lp-study-tag {
  display: inline-flex;
  margin-bottom: 18px;
  color: #ffcc80;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.lp-study-lead h2 {
  max-width: 620px;
  margin: 0;
  color: #fff;
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 900;
  line-height: 1.04;
  letter-spacing: 0;
}

.lp-study-lead p {
  max-width: 620px;
  margin: 18px 0 0;
  color: #d8e2ef;
  font-size: 17px;
  line-height: 1.75;
}

.lp-study-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.lp-study-lead .lp-button.is-outline {
  border-color: rgba(255, 255, 255, .72);
  color: #fff;
}

.lp-study-workflow {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  background: #f6f8fb;
}

.lp-study-workflow a {
  min-height: 190px;
  border-left: 1px solid #dbe3ee;
  border-bottom: 1px solid #dbe3ee;
  padding: 26px;
  color: #0b1f3a;
  text-decoration: none;
}

.lp-study-workflow a:nth-last-child(-n+2) {
  border-bottom: 0;
}

.lp-study-workflow span {
  display: inline-flex;
  margin-bottom: 18px;
  color: #f28c28;
  font-size: 13px;
  font-weight: 900;
}

.lp-study-workflow strong {
  display: block;
  font-size: 21px;
  font-weight: 900;
  line-height: 1.2;
}

.lp-study-workflow em {
  display: block;
  margin-top: 10px;
  color: #5b6678;
  font-size: 14px;
  font-style: normal;
  line-height: 1.55;
}

.lp-study-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 24px;
}

.lp-study-panel {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  border: 1px solid #dbe3ee;
  border-radius: 10px;
  background: #fff;
  overflow: hidden;
}

.lp-study-panel > div:first-child {
  padding: 24px 24px 18px;
}

.lp-study-panel > div:first-child > span {
  display: inline-flex;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: #fff4e5;
  color: #f28c28;
}

.lp-study-panel h3 {
  margin: 16px 0 8px;
  color: #0b1f3a;
  font-size: 24px;
  font-weight: 900;
  line-height: 1.16;
}

.lp-study-panel p {
  margin: 0;
  color: #5b6678;
  font-size: 14px;
  line-height: 1.6;
}

.lp-study-panel .lp-link-list,
.lp-mini-paper-list {
  border-top: 1px solid #e3e8ef;
}

.lp-study-panel .lp-link-list {
  flex: 1;
}

.lp-study-panel .lp-link-list a {
  padding: 14px 24px;
}

.lp-study-panel .lp-link-list strong {
  font-size: 14px;
}

.lp-mini-paper-list {
  display: grid;
  flex: 1;
}

.lp-mini-paper-list a {
  display: block;
  border-bottom: 1px solid #e3e8ef;
  padding: 14px 24px;
  color: #0b1f3a;
}

.lp-mini-paper-list strong {
  display: block;
  font-size: 14px;
  line-height: 1.35;
}

.lp-mini-paper-list em {
  display: block;
  margin-top: 6px;
  color: #6b7280;
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
}

.lp-study-link {
  display: flex;
  min-height: 54px;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: auto;
  border-top: 1px solid #e3e8ef;
  padding: 15px 24px;
  color: #0b1f3a;
  font-size: 14px;
  font-weight: 900;
}

.lp-study-link:hover {
  color: #f28c28;
}

.lp-exam-paths {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.lp-exam-paths a {
  border: 1px solid #dbe3ee;
  border-radius: 8px;
  background: #f6f8fb;
  padding: 18px;
  color: #0b1f3a;
}

.lp-exam-paths strong {
  display: block;
  font-size: 16px;
  font-weight: 900;
}

.lp-exam-paths span {
  display: block;
  margin-top: 7px;
  color: #5b6678;
  font-size: 13px;
  line-height: 1.45;
}

.learnpro-card-grid,
.lp-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.lp-card-grid.is-three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.lp-card,
.learnpro-card {
  overflow: hidden;
}

.lp-card-image,
.learnpro-card-image {
  display: block;
  aspect-ratio: 16 / 9;
  background: #e8eef5;
}

.lp-card-image img,
.learnpro-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lp-card-body,
.learnpro-card-body {
  padding: 18px;
}

.lp-card h3,
.learnpro-card h3 {
  margin: 6px 0 10px;
  font-size: 20px;
  line-height: 1.25;
  letter-spacing: 0;
}

.lp-card p,
.learnpro-card p {
  margin: 0;
  color: var(--lp-muted);
  font-size: 14px;
}

.lp-card-meta {
  display: flex;
  gap: 10px;
  margin-top: 14px;
  color: #98a2b3;
  font-size: 12px;
  font-weight: 700;
}

.lp-course-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

.lp-course-card-meta span {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  border: 1px solid #dbe3ee;
  border-radius: 999px;
  background: #f6f8fb;
  padding: 5px 10px;
  color: #344054;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.lp-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.lp-card-cta.is-whatsapp {
  border-color: rgba(19, 138, 54, .28);
  background: #f0fdf4;
  color: #116329;
}

.lp-proof-section {
  background: #fff;
}

.lp-proof-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.lp-proof-grid article {
  border: 1px solid #e3e8ef;
  border-radius: 8px;
  background: #f8fafc;
  padding: 20px;
}

.lp-proof-grid span {
  display: inline-flex;
  width: 34px;
  height: 34px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #0b1f3a;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
}

.lp-proof-grid h3 {
  margin: 16px 0 8px;
  color: #0b1f3a;
  font-size: 18px;
  line-height: 1.25;
}

.lp-proof-grid p {
  margin: 0;
  color: #536174;
  font-size: 14px;
  line-height: 1.55;
}

.lp-card-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 16px;
  color: #0b1f3a;
  font-size: 13px;
  font-weight: 900;
}

.lp-card-cta:hover {
  color: #f28c28;
}

.lp-testimonial-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.lp-testimonial {
  padding: 22px;
}

.lp-testimonial div {
  color: #475467;
}

.lp-testimonial blockquote {
  margin: 0;
}

.lp-testimonial strong {
  display: block;
  margin-top: 16px;
  color: var(--lp-navy);
}

.lp-app-banner {
  overflow: hidden;
  background: radial-gradient(circle at 80% 30%, rgba(249, 115, 22, .20), transparent 28%), linear-gradient(135deg, #101828, #14283d);
  color: #fff;
  padding: 64px 0;
}

.lp-app-grid {
  align-items: center;
}

.lp-app-grid p {
  color: #d7e2ef;
}

.lp-app-grid .lp-section-label {
  color: #ffd24a;
}

.lp-app-media {
  position: relative;
  min-height: 300px;
}

.lp-app-media img:first-child {
  position: absolute;
  right: 120px;
  bottom: 0;
  width: 210px;
}

.lp-app-media img:last-child {
  position: absolute;
  right: 0;
  top: 0;
  width: 220px;
  border-radius: 22px;
  box-shadow: 0 24px 55px rgba(0, 0, 0, .30);
}

.lp-entry-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 40px;
  padding: 52px 0;
}

.lp-entry,
.lp-sidebar-box {
  border: 1px solid var(--lp-line);
  border-radius: 8px;
  background: #fff;
  padding: 28px;
  box-shadow: 0 10px 28px rgba(16, 24, 40, .06);
}

.lp-entry-title {
  margin-bottom: 14px;
}

.lp-entry-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 22px;
  color: var(--lp-muted);
  font-size: 13px;
  font-weight: 750;
}

.lp-entry-image {
  margin: 22px 0;
  overflow: hidden;
  border-radius: 8px;
}

.lp-entry-content {
  color: #253044;
  font-size: 17px;
  line-height: 1.78;
}

.lp-entry-content h2,
.lp-entry-content h3 {
  color: var(--lp-ink);
  line-height: 1.18;
}

.lp-node-hero {
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid #e5e7eb;
  background: linear-gradient(135deg, #f8fafc 0%, #fff 48%, #fff7ed 100%);
}

.lp-node-hero.is-current {
  background: linear-gradient(135deg, #fff7ed 0%, #fff 48%, #eef6ff 100%);
}

.lp-node-hero.is-pyq {
  background: linear-gradient(135deg, #fff7ed 0%, #fff 45%, #fef3c7 100%);
}

.lp-node-hero.is-mains {
  background: linear-gradient(135deg, #f8fafc 0%, #fff 48%, #f3e8ff 100%);
}

.lp-node-hero.is-forest {
  background: linear-gradient(135deg, #052e16 0%, #14532d 52%, #064e3b 100%);
  color: #fff;
}

.lp-node-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(260px, .7fr);
  gap: 28px;
  align-items: center;
  padding: 52px 0;
}

.lp-node-hero h1 {
  margin: 0;
  max-width: 880px;
  color: #101828;
  font-size: clamp(34px, 4.2vw, 58px);
  font-weight: 900;
  line-height: 1.02;
  letter-spacing: 0;
}

.lp-node-hero.is-forest h1,
.lp-node-hero.is-forest .lp-section-label,
.lp-node-hero.is-forest p {
  color: #fff;
}

.lp-node-hero p {
  max-width: 760px;
  margin: 16px 0 0;
  color: #475467;
  font-size: 17px;
  line-height: 1.7;
}

.lp-node-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.lp-node-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.lp-node-stat {
  min-height: 112px;
  border: 1px solid rgba(15, 23, 42, .1);
  border-radius: 10px;
  background: rgba(255, 255, 255, .78);
  padding: 18px;
  box-shadow: 0 18px 45px rgba(15, 23, 42, .08);
}

.lp-node-hero.is-forest .lp-node-stat {
  border-color: rgba(255, 255, 255, .22);
  background: rgba(255, 255, 255, .1);
  box-shadow: none;
}

.lp-node-stat strong {
  display: block;
  color: #f97316;
  font-size: 28px;
  font-weight: 900;
  line-height: 1;
}

.lp-node-hero.is-forest .lp-node-stat strong {
  color: #86efac;
}

.lp-node-stat span {
  display: block;
  margin-top: 8px;
  color: #475467;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.lp-node-hero.is-forest .lp-node-stat span {
  color: rgba(255, 255, 255, .78);
}

.lp-node-quicklinks {
  margin-top: -24px;
}

.lp-node-link-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.lp-node-link-grid a {
  display: block;
  min-height: 118px;
  border: 1px solid #e4e7ec;
  border-radius: 10px;
  background: #fff;
  padding: 16px;
  color: #101828;
  text-decoration: none;
  box-shadow: 0 14px 34px rgba(15, 23, 42, .06);
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.lp-node-link-grid a:hover {
  transform: translateY(-2px);
  border-color: #fb923c;
  box-shadow: 0 18px 42px rgba(15, 23, 42, .1);
}

.lp-node-link-grid span {
  display: inline-flex;
  margin-bottom: 10px;
  color: #f97316;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.lp-node-link-grid strong {
  display: block;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.28;
}

.lp-node-link-grid em {
  display: block;
  margin-top: 8px;
  color: #667085;
  font-size: 13px;
  font-style: normal;
  line-height: 1.5;
}

.lp-node-link-grid.is-compact {
  grid-template-columns: 1fr;
}

.lp-node-link-grid.is-compact a {
  min-height: 0;
  padding: 13px 14px;
}

.lp-node-link-grid.is-subjects,
.lp-node-link-grid.is-states {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.lp-node-tabs {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  overflow: hidden;
  border: 1px solid #d0d5dd;
  border-radius: 8px;
  background: #fff;
}

.lp-node-tabs a {
  padding: 13px 8px;
  border-right: 1px solid #d0d5dd;
  color: #344054;
  text-align: center;
  text-decoration: none;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.lp-node-tabs a:first-child {
  background: #101828;
  color: #fff;
}

.lp-node-tabs a:last-child {
  border-right: 0;
}

.lp-node-two-col {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 30px;
  align-items: start;
}

.lp-node-two-col h2 {
  margin: 0 0 12px;
  color: #101828;
  font-size: 30px;
  font-weight: 900;
}

.lp-node-two-col p {
  color: #475467;
  font-size: 16px;
  line-height: 1.7;
}

.lp-node-two-col aside {
  position: sticky;
  top: 116px;
  border: 1px solid #e4e7ec;
  border-radius: 10px;
  background: #fff;
  padding: 18px;
  box-shadow: 0 14px 34px rgba(15, 23, 42, .06);
}

.lp-node-two-col aside h3 {
  margin: 0 0 12px;
  color: #101828;
  font-size: 15px;
  font-weight: 900;
  text-transform: uppercase;
}

.lp-node-table {
  display: grid;
  gap: 10px;
  margin-top: 20px;
}

.lp-node-table > div {
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr);
  gap: 14px;
  border: 1px solid #e4e7ec;
  border-radius: 8px;
  background: #fff;
  padding: 14px;
}

.lp-node-table strong {
  color: #101828;
  font-weight: 900;
}

.lp-node-table span {
  color: #475467;
}

.lp-node-faqs {
  display: grid;
  gap: 12px;
  max-width: 860px;
}

.lp-node-faqs details {
  border: 1px solid #e4e7ec;
  border-radius: 10px;
  background: #fff;
}

.lp-node-faqs summary {
  cursor: pointer;
  padding: 16px 18px;
  color: #101828;
  font-weight: 900;
}

.lp-node-faqs p {
  margin: 0;
  padding: 0 18px 18px;
  color: #475467;
  line-height: 1.65;
}

.lp-node-empty {
  border: 1px dashed #d0d5dd;
  border-radius: 10px;
  background: #fff;
  padding: 24px;
  color: #667085;
  text-align: center;
  font-weight: 700;
}

@media (max-width: 900px) {
  .lp-node-hero-inner,
  .lp-node-two-col {
    grid-template-columns: 1fr;
  }

  .lp-node-hero-inner {
    padding: 38px 0;
  }

  .lp-node-link-grid,
  .lp-node-link-grid.is-subjects,
  .lp-node-link-grid.is-states {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lp-node-tabs {
    grid-template-columns: 1fr;
  }

  .lp-node-tabs a {
    border-right: 0;
    border-bottom: 1px solid #d0d5dd;
  }

  .lp-node-tabs a:last-child {
    border-bottom: 0;
  }

  .lp-node-two-col aside {
    position: static;
  }
}

@media (max-width: 560px) {
  .lp-node-hero h1 {
    font-size: 32px;
    line-height: 1.08;
  }

  .lp-node-stat-grid,
  .lp-node-link-grid,
  .lp-node-link-grid.is-subjects,
  .lp-node-link-grid.is-states {
    grid-template-columns: 1fr;
  }

  .lp-node-table > div {
    grid-template-columns: 1fr;
  }
}

.lp-sidebar {
  display: grid;
  align-content: start;
  gap: 18px;
}

.lp-sidebar-box h3 {
  margin: 0 0 8px;
}

.lp-archive-title {
  margin: 0;
}

.lp-footer {
  background: #0f172a;
  color: #d8e2ef;
  padding: 56px 0 0;
}

.lp-footer-grid {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: 30px;
}

.lp-footer h3,
.lp-footer h4 {
  margin: 0 0 12px;
  color: #fff;
}

.lp-footer p {
  margin: 0;
  color: #aab8ca;
}

.lp-footer a {
  display: block;
  margin: 8px 0;
  color: #d8e2ef;
  font-size: 14px;
}

.lp-footer a:hover {
  color: #ffd24a;
}

.lp-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  margin-top: 30px;
  border-top: 1px solid rgba(255, 255, 255, .10);
  padding-top: 20px;
}

.lp-footer-links a {
  margin: 0;
  color: #aab8ca;
  font-size: 13px;
  font-weight: 800;
}

.lp-footer-bottom {
  margin-top: 38px;
  border-top: 1px solid rgba(255, 255, 255, .10);
  padding: 18px 0;
  color: #94a3b8;
  font-size: 13px;
}

.lp-sticky-cta {
  position: sticky;
  bottom: 0;
  z-index: 900;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-top: 1px solid rgba(255, 255, 255, .16);
  background: #0b1f3a;
  box-shadow: 0 -12px 30px rgba(11, 31, 58, .16);
}

.lp-sticky-cta a {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-right: 1px solid rgba(255, 255, 255, .12);
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  text-align: center;
}

.lp-sticky-cta a:last-child {
  border-right: 0;
  background: #f28c28;
}

.lp-sticky-cta a:hover {
  background: #12355b;
}

.navigation.pagination {
  margin-top: 30px;
}

.nav-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.page-numbers {
  display: inline-flex;
  min-width: 38px;
  min-height: 38px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--lp-line);
  border-radius: 8px;
  padding: 6px 10px;
  font-weight: 800;
}

.page-numbers.current {
  background: var(--lp-navy);
  color: #fff;
}

@media (max-width: 1180px) {
  .lp-header-main {
    grid-template-columns: auto 1fr auto;
  }

  .lp-quick-nav {
    justify-content: flex-start;
    overflow-x: auto;
  }

  .lp-search {
    width: 210px;
  }

  .lp-mega-columns {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .lp-top-strip,
  .lp-quick-nav,
  .lp-mega-row,
  .lp-search {
    display: none;
  }

  .lp-header-main {
    display: flex;
    min-height: 68px;
    justify-content: space-between;
  }

  .lp-mobile-toggle {
    display: inline-flex;
  }

  .lp-announcement {
    grid-template-columns: 1fr;
  }

  .lp-ann-label,
  .lp-ann-phone {
    display: none;
  }

  .lp-ann-track {
    padding: 10px 16px;
  }

  .lp-hero-grid,
  .lp-portal-grid,
  .lp-hero-actions,
  .lp-quick-paths,
  .lp-updates-grid,
  .lp-practice-grid,
  .lp-about-grid,
  .lp-why-grid,
  .lp-programme-grid,
  .lp-method-grid,
  .lp-study-desk,
  .lp-study-grid,
  .lp-exam-paths,
  .lp-proof-grid,
  .lp-app-grid,
  .lp-final-cta-grid,
  .lp-entry-wrap,
  .lp-footer-grid {
    grid-template-columns: 1fr;
  }

  .lp-hero-actions {
    align-items: stretch;
  }

  .lp-hero-actions .lp-button {
    justify-content: center;
  }

  .lp-final-cta-actions {
    justify-content: flex-start;
  }

  .lp-section-head {
    display: block;
  }

  .lp-course-row {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .lp-course-row em,
  .lp-course-row b {
    grid-column: 2;
    justify-self: start;
  }

  .lp-card-grid,
  .learnpro-card-grid,
  .lp-card-grid.is-three,
  .lp-testimonial-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lp-promo-slide {
    padding: 30px 28px 58px;
  }

  .lp-promo-phone {
    font-size: 18px;
  }

  .lp-study-workflow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lp-study-workflow a {
    border-left: 0;
  }
}

@media (max-width: 640px) {
  .lp-container {
    width: min(100% - 24px, var(--lp-max));
  }

  .lp-brand img {
    width: 38px;
    height: 38px;
  }

  .lp-brand-name {
    font-size: 21px;
  }

  .lp-channel-card,
  .lp-promo-slider {
    min-height: 310px;
  }

  .lp-card-grid,
  .learnpro-card-grid,
  .lp-card-grid.is-three,
  .lp-testimonial-grid,
  .lp-programme-grid,
  .lp-proof-grid,
  .lp-quick-paths,
  .lp-method-grid,
  .lp-why-cards,
  .lp-study-workflow,
  .lp-static-grid {
    grid-template-columns: 1fr;
  }

  .lp-programme-card {
    padding: 20px;
  }

  .lp-programme-facts {
    grid-template-columns: 1fr;
  }

  .lp-programme-actions .lp-button,
  .lp-center-action .lp-button,
  .lp-final-cta-actions .lp-button {
    width: 100%;
    justify-content: center;
  }

  .lp-practice-quiz-body,
  .lp-resource-panel h3,
  .lp-resource-panel a {
    padding-right: 18px;
    padding-left: 18px;
  }

  .lp-study-lead {
    padding: 28px 22px;
  }

  .lp-study-lead h2 {
    font-size: 31px;
  }

  .lp-study-workflow a {
    min-height: 0;
    border-bottom: 1px solid #dbe3ee;
    padding: 22px;
  }

  .lp-study-workflow a:nth-last-child(-n+2) {
    border-bottom: 1px solid #dbe3ee;
  }

  .lp-study-workflow a:last-child {
    border-bottom: 0;
  }

  .lp-section {
    padding: 46px 0;
  }

  .lp-section-head h2,
  .lp-about-grid h2,
  .lp-why-grid h2,
  .lp-app-grid h2,
  .lp-archive-title,
  .lp-entry-title {
    font-size: 30px;
  }

  .lp-app-media {
    min-height: 240px;
  }

  .lp-app-media img:first-child {
    right: 42%;
    width: 160px;
  }

  .lp-app-media img:last-child {
    width: 170px;
  }

  .lp-entry,
  .lp-sidebar-box {
    padding: 20px;
  }
}

/* v4.4 final override: premium hero, typography, and mega menu */
.lp-mega-row {
  border-top: 1px solid #e6ebf2;
  border-bottom: 1px solid #dbe3ee;
  background: rgba(255, 255, 255, .96);
  box-shadow: 0 10px 22px rgba(11, 31, 58, .05);
}

.lp-mega-nav {
  min-height: 54px;
  gap: 4px;
}

.lp-nav-button {
  min-height: 54px;
  border-top: 0;
  border-bottom: 3px solid transparent;
  padding: 0 14px;
  color: #25364d;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.lp-nav-button:hover,
.lp-nav-button.is-active {
  border-top-color: transparent;
  border-bottom-color: #f28c28;
  background: #f7f9fc;
  color: #0b1f3a;
}

.lp-mega-panel {
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 24px;
  border: 1px solid #d8e0eb;
  border-radius: 0 0 12px 12px;
  background: #fff;
  padding: 24px;
  box-shadow: 0 24px 60px rgba(11, 31, 58, .16);
}

.lp-mega-intro {
  border-radius: 10px;
  background: linear-gradient(145deg, #0b1f3a, #12355b);
  padding: 24px;
}

.lp-mega-intro h3 {
  font-size: 30px;
  letter-spacing: 0;
}

.lp-mega-columns {
  gap: 8px 16px;
}

.lp-mega-link {
  border: 1px solid transparent;
  border-radius: 9px;
  padding: 10px 12px;
  color: #1f2937;
  font-size: 13px;
  font-weight: 850;
}

.lp-mega-link:hover {
  border-color: #dbeafe;
  background: #f5f8fc;
  color: #0b1f3a;
}

.lp-quick-nav a {
  min-height: 36px;
  border-radius: 7px;
  font-weight: 850;
}

.lp-quick-nav a.is-hot,
.lp-quick-nav a.is-forest {
  box-shadow: 0 8px 18px rgba(242, 140, 40, .16);
}

.lp-hero-band {
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 44%, #f5f7fb 100%);
  padding: 26px 0 40px;
}

.lp-hero-grid {
  grid-template-columns: minmax(280px, .78fr) minmax(0, 1.92fr);
  gap: 20px;
}

.lp-channel-card,
.lp-promo-slider {
  border: 1px solid #dbe3ee;
  border-radius: 14px;
  box-shadow: 0 22px 56px rgba(11, 31, 58, .11);
}

.lp-channel-card {
  min-height: 350px;
  padding: 30px 26px;
  color: #0b1f3a;
}

.lp-channel-card::after {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .90), rgba(246, 248, 251, .94)),
    radial-gradient(circle at 50% 0%, rgba(242, 140, 40, .16), transparent 42%);
}

.lp-channel-logo {
  width: 82px;
  height: 82px;
  margin-bottom: 18px;
  border: 1px solid #e6ebf2;
  border-radius: 18px;
  box-shadow: 0 18px 40px rgba(11, 31, 58, .13);
}

.lp-channel-logo img {
  width: 50px;
  height: 50px;
}

.lp-channel-card h2 {
  max-width: 420px;
  margin: 0 auto;
  color: #0b1f3a;
  font-size: clamp(30px, 3.3vw, 46px);
  font-weight: 950;
  line-height: 1.06;
}

.lp-channel-cta {
  min-height: 54px;
  border-radius: 8px;
  background: #0b1f3a;
  padding: 0 24px;
  font-size: 15px;
  letter-spacing: .01em;
  box-shadow: 0 14px 28px rgba(11, 31, 58, .18);
}

.lp-channel-cta:hover {
  background: #f28c28;
}

.lp-promo-slider {
  min-height: 350px;
  background: #0b1f3a;
}

.lp-promo-slide {
  padding: 42px 64px 54px;
}

.lp-promo-slide::after {
  opacity: .98;
}

.lp-promo-slide.is-rose::after { background: linear-gradient(115deg, #0b1f3a 0%, #12355b 46%, #7f1238 100%); }
.lp-promo-slide.is-teal::after { background: linear-gradient(115deg, #0b1f3a 0%, #12355b 48%, #0f766e 100%); }
.lp-promo-slide.is-violet::after { background: linear-gradient(115deg, #0b1f3a 0%, #12355b 48%, #4338ca 100%); }

.lp-promo-slide img {
  opacity: .18;
  filter: saturate(.9) contrast(1.08);
}

.lp-promo-tag {
  border: 1px solid rgba(255, 255, 255, .28);
  background: rgba(255, 255, 255, .12);
  color: #fff4d6;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .06em;
}

.lp-promo-slide h1 {
  max-width: 760px;
  color: #fff6c7;
  font-size: clamp(34px, 4.6vw, 58px);
  font-weight: 950;
  line-height: 1.02;
  text-wrap: balance;
}

.lp-promo-slide p {
  color: #ffffff;
  font-size: clamp(17px, 2vw, 24px);
}

.lp-promo-slide strong {
  color: #fff;
  font-size: clamp(18px, 2.2vw, 28px);
}

.lp-promo-phone {
  left: 26px;
  bottom: 22px;
  min-height: 46px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .96);
  color: #0b1f3a;
  font-size: 19px;
}

.lp-slider-dots {
  right: 26px;
  bottom: 30px;
}

.lp-slider-dots button {
  height: 5px;
  background: rgba(255, 255, 255, .34);
}

.lp-slider-dots button.is-active {
  width: 38px;
  background: #f28c28;
}

.lp-promo-slide.is-active .lp-promo-tag,
.lp-promo-slide.is-active h1,
.lp-promo-slide.is-active p,
.lp-promo-slide.is-active strong {
  animation: lpHeroTextIn .72s cubic-bezier(.2, .8, .2, 1) both;
}

.lp-promo-slide.is-active h1 { animation-delay: .06s; }
.lp-promo-slide.is-active p { animation-delay: .14s; }
.lp-promo-slide.is-active strong { animation-delay: .22s; }

@keyframes lpHeroTextIn {
  from {
    opacity: 0;
    transform: translateY(18px);
    filter: blur(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}

.lp-programme-card,
.lp-practice-quiz,
.lp-resource-panel,
.lp-method-grid article,
.lp-quick-paths a,
.lp-hero-actions {
  border-color: #dbe3ee;
  border-radius: 12px;
  box-shadow: 0 14px 34px rgba(11, 31, 58, .07);
}

.lp-programme-top h3,
.lp-resource-panel h3,
.lp-method-grid h3 {
  letter-spacing: 0;
}

@media (prefers-reduced-motion: reduce) {
  .lp-promo-slide.is-active .lp-promo-tag,
  .lp-promo-slide.is-active h1,
  .lp-promo-slide.is-active p,
  .lp-promo-slide.is-active strong {
    animation: none;
  }
}

@media (max-width: 980px) {
  .lp-hero-grid {
    gap: 16px;
  }

  .lp-channel-card,
  .lp-promo-slider {
    min-height: 330px;
  }

  .lp-promo-slide {
    padding: 34px 32px 70px;
  }
}

@media (max-width: 640px) {
  .lp-hero-band {
    padding: 16px 0 30px;
  }

  .lp-channel-card {
    min-height: 280px;
    padding: 26px 22px;
  }

  .lp-channel-logo {
    width: 72px;
    height: 72px;
    border-radius: 16px;
  }

  .lp-channel-card h2 {
    font-size: 31px;
    line-height: 1.08;
  }

  .lp-channel-cta {
    width: 100%;
    justify-content: center;
    min-height: 52px;
    margin-top: 22px;
  }

  .lp-promo-slider {
    min-height: 360px;
  }

  .lp-promo-slide {
    justify-content: flex-start;
    padding: 36px 26px 78px;
  }

  .lp-promo-slide h1 {
    font-size: 40px;
    line-height: 1.04;
  }

  .lp-promo-slide p {
    font-size: 18px;
    line-height: 1.4;
  }

  .lp-promo-phone {
    left: 20px;
    bottom: 18px;
    font-size: 16px;
  }

  .lp-slider-dots {
    right: 20px;
    bottom: 28px;
  }

  .lp-sticky-cta a {
    font-size: 14px;
    line-height: 1.2;
    padding: 10px 6px;
  }
}
