/*
|=======================================================================================================================
| Duke Language School — main.less
| Compiled to assets/css/src/main.css by less-watch-compiler
|=======================================================================================================================
*/
/* ── Variables ──────────────────────────────────────────────────────────── */
/* ── Base ───────────────────────────────────────────────────────────────── */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
:root {
  --blue: #0066FF;
  --blue-d: #003FB5;
  --blue-l: #1E88FF;
  --blue-deep: #001F66;
  --blue-pale: #E8F1FF;
  --blue-glow: rgba(0, 102, 255, 0.35);
  --yellow: #FFD60A;
  --yellow-d: #FFB000;
  --yellow-l: #FFE566;
  --dark: #0F1B2D;
  --gray: #5A6A7E;
  --light: #F4F8FF;
  --white: #FFFFFF;
  --line: #E5EAF2;
  --lav: #C8D8F5;
  --lav-d: #A8C0EE;
  --r: 24px;
  --r-lg: 32px;
  --shadow: 0 8px 40px rgba(0, 102, 255, 0.14);
  --shadow-lg: 0 20px 70px rgba(0, 102, 255, 0.22);
  --fh: 'Montserrat', sans-serif;
  --fb: 'Lato', sans-serif;
  --fth: 'Kanit', sans-serif;
  --fzh: 'Noto Sans SC', sans-serif;
}
:lang(th),
.thai-text,
[lang="th"] {
  font-family: 'Kanit', sans-serif;
}
:lang(zh),
.zh-text,
[lang="zh"] {
  font-family: 'Noto Sans SC', sans-serif;
}
html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  scroll-padding-top: calc(var(--header-h, 130px) + 16px);
}
body {
  font-family: 'Lato', sans-serif;
  color: #0F1B2D;
  background: #fff;
  overflow-x: hidden;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
a {
  text-decoration: none;
  color: inherit;
}
img {
  max-width: 100%;
  display: block;
}
ul {
  list-style: none;
}
button {
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  border: none;
  background: none;
  outline: none;
}
/* ── Utilities ──────────────────────────────────────────────────────────── */
.wrap {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 48px;
}
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 16px 36px;
  border-radius: 50px;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  cursor: pointer;
  border: 2px solid transparent;
}
.btn-blue {
  background: #0066FF;
  color: #fff;
  border-color: #0066FF;
  box-shadow: 0 8px 30px rgba(0, 102, 255, 0.35);
}
.btn-blue:hover {
  background: #003FB5;
  border-color: #003FB5;
  transform: translateY(-3px);
  box-shadow: 0 14px 42px rgba(0, 102, 255, 0.35);
}
.btn-ghost {
  background: transparent;
  color: #fff;
  border-color: rgba(255, 255, 255, 0.6);
}
.btn-ghost:hover {
  background: #fff;
  color: #0066FF;
  border-color: #fff;
  transform: translateY(-3px);
}
.btn-yellow {
  background: #FFD60A;
  color: #0F1B2D;
  border-color: #FFD60A;
  box-shadow: 0 8px 28px rgba(255, 214, 10, 0.5);
}
.btn-yellow:hover {
  background: #FFB000;
  border-color: #FFB000;
  transform: translateY(-3px);
}
.btn-outline-blue {
  background: transparent;
  color: #0066FF;
  border-color: #0066FF;
}
.btn-outline-blue:hover {
  background: #0066FF;
  color: #fff;
  transform: translateY(-3px);
}
.sec {
  padding: 100px 0;
}
.sec-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: #0066FF;
  margin-bottom: 14px;
  display: block;
}
.sec-title {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 900;
  line-height: 1.08;
  margin-bottom: 18px;
  color: #0F1B2D;
}
.sec-title em {
  font-style: normal;
  color: #0066FF;
}
.sec-sub {
  font-size: 16px;
  line-height: 1.85;
  color: #5A6A7E;
  max-width: 560px;
}
/* ── Sticky Header ──────────────────────────────────────────────────────── */
.header-sticky {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  transition: box-shadow 0.3s;
}
.header-sticky.scrolled {
  box-shadow: 0 4px 40px rgba(0, 102, 255, 0.14);
}
.header-spacer {
  display: block;
  width: 100%;
  height: 130px;
}
/* ── Top bar ────────────────────────────────────────────────────────────── */
.topbar {
  background: #001F66;
  padding: 10px 0;
}
.topbar .wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}
.tb-left {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
}
.tb-left a,
.tb-right a {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: rgba(255, 255, 255, 0.65);
  transition: color 0.2s;
  display: flex;
  align-items: center;
  gap: 7px;
}
.tb-left a:hover,
.tb-right a:hover {
  color: #FFD60A;
}
.tb-right {
  display: flex;
  gap: 16px;
}
/* ── Navbar ─────────────────────────────────────────────────────────────── */
#nav {
  position: relative;
  z-index: 1000;
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(16px);
  transition: box-shadow 0.3s, background 0.3s;
}
.nav-wrap {
  display: flex;
  align-items: center;
  height: 78px;
  padding: 0 48px;
  gap: 24px;
  max-width: 1440px;
  margin: 0 auto;
  flex-wrap: nowrap;
}
.nav-logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.nav-logo img {
  height: 50px;
  width: auto;
  object-fit: contain;
  transition: transform 0.25s;
}
.nav-logo:hover img {
  transform: scale(1.04);
}
.nav-menu {
  display: flex;
  gap: 2px;
  align-items: center;
  flex: 1 1 auto;
  justify-content: center;
  list-style: none;
  min-width: 0;
  flex-wrap: nowrap;
  overflow: visible;
}
.nav-menu > li {
  position: relative;
}
.nav-menu > li > a {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 13px;
  padding: 10px 14px;
  border-radius: 10px;
  color: #0F1B2D;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.25s;
  letter-spacing: 0.3px;
}
.nav-menu > li > a i {
  font-size: 9px;
  opacity: 0.5;
  transition: transform 0.25s;
}
.nav-menu > li > a:hover,
.nav-menu > li.on > a {
  color: #0066FF;
  background: rgba(0, 102, 255, 0.07);
}
.nav-menu > li:hover > a i {
  transform: rotate(180deg);
  opacity: 0.9;
}
.drop {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 220px;
  background: #fff;
  border-radius: 16px;
  border-top: 3px solid #0066FF;
  box-shadow: 0 20px 64px rgba(0, 102, 255, 0.18);
  padding: 10px 0;
  list-style: none;
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
  transition: all 0.28s cubic-bezier(0.25, 0.8, 0.25, 1);
  z-index: 99;
}
.drop li a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 22px;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #0F1B2D;
  transition: all 0.2s;
}
.drop li a::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #0066FF;
  opacity: 0;
  transform: scale(0);
  transition: all 0.2s;
  flex-shrink: 0;
}
.drop li a:hover {
  color: #0066FF;
  background: rgba(0, 102, 255, 0.05);
  padding-left: 26px;
}
.drop li a:hover::before {
  opacity: 1;
  transform: scale(1);
}
.nav-menu > li:hover > .drop {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
/* Depth-2 fly-out */
.drop li.has-flyout {
  position: relative;
}
.drop--sub {
  top: -10px;
  left: calc(100% - 6px);
  transform: translateX(14px);
  border-top: none;
  border-left: 3px solid #0066FF;
  border-radius: 0 16px 16px 16px;
  min-width: 230px;
  padding: 14px 0;
  box-shadow: 8px 16px 48px rgba(0, 102, 255, 0.18);
  /* connector triangle pointing back to parent item */
  /* tiny inner triangle for white fill */
}
.drop--sub::before {
  content: '';
  position: absolute;
  top: 20px;
  left: -11px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 8px 8px 0;
  border-color: transparent #0066FF transparent transparent;
}
.drop--sub::after {
  content: '';
  position: absolute;
  top: 21px;
  left: -4px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7px 7px 7px 0;
  border-color: transparent #fff transparent transparent;
}
.drop--sub li a {
  padding: 10px 22px;
  font-size: 13px;
}
.drop li.has-flyout:hover > .drop--sub {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
}
/* Parent item active styling when flyout is open */
.drop li.has-flyout > a {
  justify-content: space-between;
  position: relative;
}
.drop li.has-flyout:hover > a {
  background: linear-gradient(90deg, rgba(0, 102, 255, 0.08), rgba(0, 102, 255, 0.02));
  color: #0066FF;
  padding-left: 26px;
}
.drop li.has-flyout:hover > a::before {
  opacity: 1;
  transform: scale(1);
}
/* Chevron animation */
.drop li.has-flyout > a .fa-chevron-right {
  font-size: 10px;
  color: #5A6A7E;
  transition: transform 0.25s ease, color 0.25s;
  flex-shrink: 0;
  margin-left: auto;
}
.drop li.has-flyout:hover > a .fa-chevron-right {
  color: #0066FF;
  transform: translateX(4px);
}
.nav-phone {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: 12.5px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  background: #FFD60A;
  color: #0F1B2D;
  padding: 11px 22px;
  border-radius: 50px;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: all 0.3s;
  box-shadow: 0 6px 22px rgba(255, 214, 10, 0.4);
  white-space: nowrap;
  flex-shrink: 0;
  order: 99;
}
.nav-phone:hover {
  background: #FFB000;
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(255, 176, 0, 0.5);
}
/* ── Language Switcher ─────────────────────────────────────────────── */
.lang-sw {
  position: relative;
  flex-shrink: 0;
}
.lang-sw .lang-sw-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(0, 102, 255, 0.07);
  border: 1.5px solid rgba(0, 102, 255, 0.2);
  border-radius: 8px;
  padding: 8px 12px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: #0F1B2D;
  transition: background 0.2s, border-color 0.2s;
  white-space: nowrap;
}
.lang-sw .lang-sw-btn .lang-flag {
  width: 20px;
  height: 14px;
  border-radius: 2px;
  object-fit: cover;
  flex-shrink: 0;
}
.lang-sw .lang-sw-btn .lang-code {
  letter-spacing: 0.5px;
}
.lang-sw .lang-sw-btn .lang-arrow {
  font-size: 9px;
  color: #5A6A7E;
  transition: transform 0.22s;
  margin-left: 1px;
}
.lang-sw .lang-sw-btn:hover,
.lang-sw .lang-sw-btn.open {
  background: rgba(0, 102, 255, 0.13);
  border-color: rgba(0, 102, 255, 0.4);
}
.lang-sw .lang-sw-btn.open .lang-arrow {
  transform: rotate(180deg);
}
.lang-sw .lang-sw-drop {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(0, 31, 102, 0.13);
  min-width: 160px;
  padding: 6px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity 0.2s, transform 0.2s, visibility 0.2s;
  z-index: 300;
}
.lang-sw .lang-sw-drop.open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.lang-sw .lang-opt {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 8px;
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #0F1B2D;
  text-decoration: none;
  transition: background 0.15s;
}
.lang-sw .lang-opt img {
  width: 20px;
  height: 14px;
  border-radius: 2px;
  object-fit: cover;
  flex-shrink: 0;
}
.lang-sw .lang-opt:hover {
  background: #F4F8FF;
}
.lang-sw .lang-opt.active {
  background: rgba(0, 102, 255, 0.06);
  color: #0066FF;
  font-weight: 700;
}
/* Compact on mobile: flag only, no text/chevron */
@media (max-width: 900px) {
  .lang-sw .lang-sw-btn {
    padding: 7px 9px;
    gap: 0;
  }
  .lang-sw .lang-sw-btn .lang-code,
  .lang-sw .lang-sw-btn .lang-arrow {
    display: none;
  }
  .lang-sw .lang-sw-drop {
    top: calc(100% + 8px);
    right: 0;
  }
}
.hbg {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 4px;
  cursor: pointer;
}
.hbg span {
  display: block;
  width: 24px;
  height: 2.5px;
  background: #0066FF;
  border-radius: 2px;
  transition: all 0.3s;
}
/* ── Hero Swiper ────────────────────────────────────────────────────────── */
.hero-swiper {
  width: 100%;
  height: calc(100vh - var(--header-h, 130px));
  min-height: 700px;
  overflow: hidden;
  position: relative;
}
.hero-slide {
  position: relative;
  height: 100%;
  width: 100%;
  overflow: hidden;
  display: flex;
  align-items: center;
}
.hs-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.08);
  transition: transform 9s ease;
  will-change: transform;
}
.swiper-slide-active .hs-bg {
  transform: scale(1);
}
.hs-ov1 {
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, rgba(0, 31, 102, 0.94) 0%, rgba(0, 63, 181, 0.82) 30%, rgba(0, 102, 255, 0.45) 58%, rgba(0, 31, 102, 0.18) 100%);
}
.hs-ov2 {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 8, 32, 0.82) 0%, rgba(0, 8, 32, 0.1) 48%, transparent 100%);
}
.hs-accent {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 5px;
  z-index: 15;
  background: linear-gradient(to bottom, transparent 4%, #FFD60A 22%, #FFD60A 78%, transparent 96%);
}
.hs-counter {
  display: none;
}
.hs-char {
  position: absolute;
  right: -1%;
  bottom: -6%;
  font-size: clamp(260px, 38vw, 560px);
  font-weight: 900;
  color: rgba(255, 255, 255, 0.04);
  line-height: 1;
  user-select: none;
  pointer-events: none;
  font-family: 'Montserrat', sans-serif;
  z-index: 2;
  letter-spacing: -10px;
}
@keyframes hsUp {
  from {
    opacity: 0;
    transform: translateY(34px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.hs-tag,
.hs-h1,
.hs-sub,
.hs-btns,
.hs-stats {
  opacity: 0;
  transform: translateY(34px);
}
.swiper-slide-active .hs-tag {
  animation: hsUp 0.65s 0.06s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.swiper-slide-active .hs-h1 {
  animation: hsUp 0.72s 0.2s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.swiper-slide-active .hs-sub {
  animation: hsUp 0.7s 0.38s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.swiper-slide-active .hs-btns {
  animation: hsUp 0.7s 0.52s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.swiper-slide-active .hs-stats {
  animation: hsUp 0.7s 0.65s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.hs-card {
  opacity: 0;
  transform: translateY(28px);
}
.swiper-slide-active .hs-card {
  animation: hsUp 0.82s 0.28s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.hs-content {
  position: relative;
  z-index: 10;
  padding: 0 0 130px 112px;
  max-width: 720px;
}
.hs-tag {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
}
.hs-tag-line {
  width: 36px;
  height: 2px;
  background: #FFD60A;
  border-radius: 1px;
  flex-shrink: 0;
}
.hs-h1 {
  font-family: 'Montserrat', sans-serif;
  line-height: 0.9;
  margin-bottom: 28px;
  color: #fff;
}
.hs-h1-sub {
  font-size: clamp(22px, 3vw, 42px);
  font-weight: 400;
  color: rgba(255, 255, 255, 0.55);
  display: block;
  letter-spacing: -0.3px;
  margin-bottom: 8px;
}
.hs-h1-main {
  font-size: clamp(64px, 10vw, 148px);
  font-weight: 900;
  letter-spacing: -3px;
  display: block;
  color: #FFD60A;
  line-height: 0.88;
}
.hs-sub {
  font-family: 'Lato', sans-serif;
  font-size: 17px;
  line-height: 1.85;
  color: rgba(255, 255, 255, 0.72);
  max-width: 520px;
  margin-bottom: 46px;
}
.hs-btns {
  display: flex;
  gap: 14px;
  align-items: center;
  margin-bottom: 54px;
  flex-wrap: wrap;
}
.hs-stats {
  display: flex;
  gap: 48px;
  padding-top: 28px;
  border-top: 1px solid rgba(255, 255, 255, 0.14);
  flex-wrap: wrap;
}
.hs-stat {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.hs-stat-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 32px;
  font-weight: 900;
  color: #FFD60A;
  line-height: 1;
}
.hs-stat-lbl {
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.55);
  text-transform: uppercase;
  margin-top: 6px;
}
.hs-card {
  position: absolute;
  right: 8%;
  top: 42%;
  transform: translateY(-50%);
  z-index: 10;
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 28px;
  padding: 36px 28px;
  text-align: center;
  width: 236px;
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.36), inset 0 1px 0 rgba(255, 255, 255, 0.12);
}
.hs-card-flag {
  display: flex;
  justify-content: center;
  margin-bottom: 16px;
}
.hs-card-flag img {
  height: 54px;
  width: 80px;
  border-radius: 7px;
  object-fit: cover;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  border: 2px solid rgba(255, 255, 255, 0.2);
}
.hs-card-lang {
  font-family: 'Montserrat', sans-serif;
  font-size: 28px;
  font-weight: 900;
  color: #fff;
  line-height: 1;
  margin-bottom: 6px;
}
.hs-card-script {
  font-size: 18px;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 18px;
  letter-spacing: 1px;
  font-family: 'Lato', sans-serif;
}
.hs-card-script.thai-text {
  font-family: 'Kanit', sans-serif;
  font-weight: 500;
  font-size: 19px;
  letter-spacing: 0.3px;
}
.hs-card-divider {
  width: 32px;
  height: 2px;
  background: #FFD60A;
  border-radius: 1px;
  margin: 0 auto 18px;
}
.hs-card-badge {
  display: inline-block;
  background: rgba(255, 214, 10, 0.18);
  color: #FFD60A;
  border: 1px solid rgba(255, 214, 10, 0.32);
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  padding: 7px 16px;
  border-radius: 20px;
}
.hero-lang-nav {
  position: absolute;
  bottom: 50px;
  left: 112px;
  z-index: 20;
  display: flex;
  gap: 6px;
  align-items: center;
}
.hln-btn {
  padding: 11px 28px;
  border-radius: 50px;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
  cursor: pointer;
  transition: all 0.32s;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.14);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.hln-btn img {
  width: 18px;
  height: 13px;
  border-radius: 2px;
  object-fit: cover;
}
.hln-btn:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.16);
  border-color: rgba(255, 255, 255, 0.28);
}
.hln-btn.on {
  background: #FFD60A;
  color: #0F1B2D;
  border-color: #FFD60A;
  box-shadow: 0 8px 28px rgba(255, 214, 10, 0.4);
}
.hero-arrows {
  position: absolute;
  bottom: 44px;
  right: 8%;
  z-index: 25;
  display: flex;
  gap: 14px;
  align-items: center;
  background: rgba(10, 18, 40, 0.55);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 100px;
  padding: 9px 13px;
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.35);
}
.hero-arr {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s;
  color: #fff;
  font-size: 14px;
  border: 1.5px solid rgba(255, 255, 255, 0.22);
  flex-shrink: 0;
}
.hero-arr:hover {
  background: #FFD60A;
  color: #0F1B2D;
  border-color: #FFD60A;
  transform: scale(1.08);
}
.hero-dots {
  display: flex;
  gap: 10px;
  margin: 0 8px;
  align-items: center;
}
.hero-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.35);
  border: none;
  cursor: pointer;
  transition: all 0.3s;
  padding: 0;
}
.hero-dot:hover {
  background: rgba(255, 255, 255, 0.6);
}
.hero-dot.on {
  background: #FFD60A;
  width: 36px;
  border-radius: 6px;
  box-shadow: 0 0 0 4px rgba(255, 214, 10, 0.18);
}
.slide-progress {
  position: absolute;
  right: 0;
  top: 0;
  width: 4px;
  height: 0;
  background: #FFD60A;
  z-index: 20;
  transition: height linear;
}
/* ── Tagline Strip ──────────────────────────────────────────────────────── */
.tagline-strip {
  background: linear-gradient(135deg, #0066FF 0%, #1E88FF 50%, #003FB5 100%);
  padding: 38px 0;
  position: relative;
  overflow: hidden;
}
.tagline-strip::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20% 50%, rgba(255, 214, 10, 0.2), transparent 50%), radial-gradient(circle at 80% 50%, rgba(255, 214, 10, 0.12), transparent 50%);
}
.tagline-in {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 0 32px;
}
.tagline-in h2 {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(28px, 4.5vw, 52px);
  font-weight: 900;
  color: #fff;
  letter-spacing: 1px;
  line-height: 1.1;
  text-transform: uppercase;
}
.tagline-in h2 .fun {
  background: linear-gradient(135deg, #FFD60A, #FFE566);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
/* ── Why Duke ───────────────────────────────────────────────────────────── */
.why-sec {
  background: linear-gradient(180deg, #fff 0%, #F4F8FF 100%);
  position: relative;
  padding: 120px 0;
}
.why-sec .wrap {
  max-width: 1320px;
}
.why-head {
  text-align: center;
  margin-bottom: 64px;
}
.why-head .sec-sub {
  margin: 14px auto 0;
}
.why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.why-card {
  background: #fff;
  border-radius: 20px;
  padding: 24px;
  position: relative;
  transition: all 0.35s cubic-bezier(0.25, 0.8, 0.25, 1);
  overflow: hidden;
  border: 1px solid #E5EAF2;
  display: flex;
  flex-direction: column;
}
.why-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
  border-color: #1E88FF;
}
.why-card:hover .why-img {
  transform: scale(1.015);
}
.why-card:hover .why-img::before {
  opacity: 0.7;
}
.why-card h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: 20px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 10px;
  letter-spacing: -0.2px;
}
.why-card p {
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  color: #5A6A7E;
  line-height: 1.7;
}
.why-img {
  position: relative;
  width: 100%;
  aspect-ratio: 4/3;
  background: #4a5568;
  background-size: cover;
  background-position: center;
  border-radius: 14px;
  margin-bottom: 22px;
  overflow: hidden;
  transition: transform 0.5s ease;
}
.why-img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, rgba(0, 31, 102, 0.15) 0%, rgba(0, 31, 102, 0.55) 100%);
  z-index: 1;
  transition: opacity 0.35s;
}
.why-img .pill {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: #0066FF;
  padding: 6px 12px;
  border-radius: 30px;
}
/* ── Courses ────────────────────────────────────────────────────────────── */
.courses-sec {
  background: #C8D8F5;
  padding: 100px 0;
  position: relative;
  overflow: hidden;
}
.courses-sec::before {
  content: '';
  position: absolute;
  top: -100px;
  right: -100px;
  width: 340px;
  height: 340px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 102, 255, 0.1), transparent 70%);
}
.courses-hdr {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 54px;
  gap: 20px;
  flex-wrap: wrap;
}
.c-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.c-card {
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0, 102, 255, 0.14);
  transition: all 0.38s cubic-bezier(0.25, 0.8, 0.25, 1);
  background: #fff;
  display: flex;
  flex-direction: column;
}
.c-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
}
.c-img {
  height: 220px;
  position: relative;
  overflow: hidden;
  background-size: cover;
  background-position: center;
}
.c-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 40%, rgba(0, 0, 0, 0.35) 100%);
}
.c-img-label {
  position: absolute;
  top: 18px;
  left: 18px;
  z-index: 2;
  background: rgba(255, 255, 255, 0.95);
  border-radius: 30px;
  padding: 7px 16px;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #0066FF;
  backdrop-filter: blur(8px);
}
.c-body {
  padding: 26px 28px 28px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.c-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 800;
  margin-bottom: 8px;
  line-height: 1.2;
  color: #0F1B2D;
}
.c-desc {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.65;
  margin-bottom: 16px;
  flex: 1;
}
.c-price {
  display: flex;
  align-items: baseline;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.c-price .lbl {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #5A6A7E;
  width: 100%;
  margin-bottom: 2px;
}
.c-price .amt {
  font-family: 'Montserrat', sans-serif;
  font-size: 36px;
  font-weight: 900;
  color: #0066FF;
  line-height: 1;
  letter-spacing: -1.2px;
}
.c-price .unit {
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: #5A6A7E;
  font-weight: 700;
}
.c-meta {
  display: flex;
  gap: 14px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #5A6A7E;
  margin-bottom: 16px;
  flex-wrap: wrap;
  padding-top: 14px;
  border-top: 1px dashed #E5EAF2;
}
.c-meta span {
  display: flex;
  align-items: center;
  gap: 6px;
}
.c-meta i {
  color: #0066FF;
}
.c-link {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #0066FF;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: gap 0.25s;
  align-self: flex-start;
}
.c-link:hover {
  gap: 14px;
}
/* ── Testimonials ───────────────────────────────────────────────────────── */
.testi-sec {
  background: linear-gradient(180deg, #fff 0%, #E8F1FF 100%);
  padding: 100px 0 80px;
}
.testi-head {
  text-align: center;
  margin-bottom: 56px;
}
.testi-head .sec-sub {
  margin: 14px auto 0;
}
.swiper-testi {
  overflow: visible!important;
  padding: 54px 4px 30px!important;
}
.swiper-testi .swiper-wrapper {
  align-items: stretch;
}
.swiper-testi .swiper-slide {
  height: auto;
  display: flex;
}
.t-card {
  background: #fff;
  border-radius: 32px;
  padding: 36px 32px;
  box-shadow: 0 8px 40px rgba(0, 102, 255, 0.14);
  transition: all 0.35s;
  position: relative;
  border: 1px solid #E5EAF2;
  height: 100%;
  display: flex;
  flex-direction: column;
  width: 100%;
}
.t-card::after {
  content: '"';
  position: absolute;
  top: 22px;
  right: 32px;
  font-size: 100px;
  font-family: Georgia,serif;
  color: #E8F1FF;
  line-height: 1;
  pointer-events: none;
}
.t-card:hover {
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
  transform: translateY(-6px);
  border-color: #1E88FF;
}
.t-text {
  font-family: 'Lato', sans-serif;
  font-size: 15.5px;
  line-height: 1.8;
  color: #0F1B2D;
  margin-bottom: 24px;
  font-weight: 400;
  flex: 1;
  position: relative;
  z-index: 1;
}
.t-author {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-top: 22px;
  border-top: 1px solid #E5EAF2;
}
.t-av {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
  box-shadow: 0 6px 18px rgba(10, 30, 90, 0.18);
  border: 3px solid #fff;
}
.t-name {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: 15.5px;
  color: #0F1B2D;
}
.t-role {
  font-family: 'Lato', sans-serif;
  font-size: 12.5px;
  color: #5A6A7E;
  margin-top: 3px;
}
.t-card.featured {
  background: linear-gradient(160deg, #1a1f4d 0%, #003FB5 55%, #0066FF 100%);
  color: #fff;
  border-color: transparent;
  text-align: center;
  padding-top: 68px;
  box-shadow: 0 24px 60px rgba(0, 31, 102, 0.4);
  position: relative;
}
.t-card.featured::after {
  display: none;
}
.t-card.featured .t-av-top {
  position: absolute;
  top: -38px;
  left: 50%;
  transform: translateX(-50%);
  width: 78px;
  height: 78px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  border: 4px solid #fff;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
  z-index: 3;
}
.t-card.featured .t-name-top {
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 3px;
  letter-spacing: -0.2px;
}
.t-card.featured .t-role-top {
  font-family: 'Lato', sans-serif;
  font-size: 12px;
  color: #FFD60A;
  margin-bottom: 18px;
  font-weight: 700;
  letter-spacing: 0.5px;
}
.t-card.featured .t-text {
  color: rgba(255, 255, 255, 0.92);
  font-style: normal;
  text-align: center;
  font-size: 14.5px;
}
.t-card.featured .t-author {
  display: none;
}
.testi-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-top: 40px;
}
.testi-arr {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: #fff;
  color: #0066FF;
  border: 2px solid #0066FF;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s;
  box-shadow: 0 6px 22px rgba(0, 102, 255, 0.18);
  font-size: 15px;
  flex-shrink: 0;
}
.testi-arr:hover {
  background: #0066FF;
  color: #fff;
  transform: scale(1.08);
  box-shadow: 0 10px 30px rgba(0, 102, 255, 0.35);
}
.testi-arr:active {
  transform: scale(0.95);
}
.testi-nav .swiper-pagination {
  position: static;
  display: flex;
  align-items: center;
  gap: 8px;
  width: auto;
}
.swiper-pagination-bullet {
  background: #A8C0EE !important;
  opacity: 1!important;
  width: 10px!important;
  height: 10px!important;
  transition: all 0.3s;
}
.swiper-pagination-bullet-active {
  background: #0066FF !important;
  width: 32px!important;
  border-radius: 5px !important;
}
/* ── ED Visa ────────────────────────────────────────────────────────────── */
.edvisa-sec {
  position: relative;
  padding: 120px 0;
  --t: 0;
  background: linear-gradient(180deg, hsl(calc(215 + var(--t) * 10), 100%, calc(60% - var(--t) * 25%)) 0%, hsl(calc(218 + var(--t) * 8), 100%, calc(55% - var(--t) * 30%)) 50%, hsl(calc(222 + var(--t) * 6), 100%, calc(35% - var(--t) * 25%)) 100%);
  color: #fff;
  overflow: hidden;
  transition: background 0.25s linear;
}
.edvisa-sec::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 50% at 20% 30%, rgba(79, 163, 255, 0.45), transparent 60%), radial-gradient(ellipse 50% 40% at 80% 70%, rgba(255, 214, 10, 0.1), transparent 60%);
}
.edvisa-sec::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, 0.08) 1px, transparent 0);
  background-size: 30px 30px;
  pointer-events: none;
}
.edvisa-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.edvisa-left h2 {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(36px, 4.5vw, 58px);
  font-weight: 900;
  line-height: 1.05;
  color: #fff;
  margin-bottom: 20px;
  letter-spacing: -0.5px;
}
.edvisa-left h2 .y {
  color: #FFD60A;
}
.edvisa-left .lead {
  font-family: 'Lato', sans-serif;
  font-size: 17px;
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.75;
  margin-bottom: 32px;
  max-width: 520px;
}
.edvisa-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 34px;
}
.edvisa-list li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-family: 'Lato', sans-serif;
  font-size: 15.5px;
  color: rgba(255, 255, 255, 0.92);
  font-weight: 600;
}
.edvisa-list li i {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: #FFD60A;
  color: #0F1B2D;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
}
.edvisa-note {
  padding: 18px 22px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.1);
  border-left: 4px solid #FFD60A;
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.88);
  margin-bottom: 30px;
  line-height: 1.65;
}
.edvisa-right {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.edvisa-step {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 18px;
  padding: 22px 24px;
  backdrop-filter: blur(12px);
  transition: all 0.3s;
}
.edvisa-step:hover {
  background: rgba(255, 255, 255, 0.14);
  border-color: #FFD60A;
  transform: translateX(6px);
}
.edvisa-step h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 5px;
}
.edvisa-step p {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.6;
}
.edvisa-num {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  flex-shrink: 0;
  background: linear-gradient(135deg, #FFD60A, #FFB000);
  color: #0F1B2D;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: 1.2rem;
}
/* ── FAQ ────────────────────────────────────────────────────────────────── */
.faq-sec {
  background: #fff;
  padding: 110px 0;
}
.faq-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 60px;
  align-items: flex-start;
}
.faq-left h2 {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(34px, 4vw, 48px);
  font-weight: 900;
  line-height: 1.05;
  color: #0F1B2D;
  margin-bottom: 14px;
  letter-spacing: -0.5px;
}
.faq-left h2 q {
  color: #0066FF;
  quotes: none;
}
.faq-left p {
  font-family: 'Lato', sans-serif;
  color: #5A6A7E;
  font-size: 16px;
  margin-bottom: 26px;
  line-height: 1.7;
}
.faq-langs {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 30px;
}
.faq-langs li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  color: #0F1B2D;
  font-weight: 700;
}
.faq-langs li img {
  width: 28px;
  height: 20px;
  border-radius: 3px;
  object-fit: cover;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}
.faq-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.faq-item {
  border: 1px solid #E5EAF2;
  border-radius: 18px;
  background: #fff;
  overflow: hidden;
  transition: all 0.3s;
}
.faq-item.open {
  border-color: #0066FF;
  box-shadow: 0 8px 24px rgba(0, 102, 255, 0.35);
}
.faq-item.open .faq-q .qico {
  background: #0066FF;
  color: #fff;
  transform: rotate(180deg);
}
.faq-item.open .faq-a {
  max-height: 340px;
  padding: 0 24px 22px;
}
.faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  cursor: pointer;
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: #0F1B2D;
  gap: 18px;
}
.faq-q .qico {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  flex-shrink: 0;
  background: #E8F1FF;
  color: #0066FF;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
}
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease, padding 0.35s ease;
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  color: #5A6A7E;
  line-height: 1.78;
  padding: 0 24px;
}
/* ── Blog ───────────────────────────────────────────────────────────────── */
.blog-sec {
  background: #F4F8FF;
  padding: 100px 0;
}
.blog-hdr {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 50px;
  flex-wrap: wrap;
  gap: 20px;
}
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.blog-card {
  background: #fff;
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0, 102, 255, 0.14);
  transition: all 0.38s;
  display: flex;
  flex-direction: column;
}
.blog-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
}
.blog-img {
  height: 210px;
  background-size: cover;
  background-position: center;
  position: relative;
}
.blog-cat {
  position: absolute;
  top: 16px;
  left: 16px;
  background: #0066FF;
  color: #fff;
  padding: 7px 16px;
  border-radius: 30px;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.blog-body {
  padding: 26px 30px 30px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.blog-body h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.3;
  color: #0F1B2D;
  margin-bottom: 12px;
}
.blog-body p {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.65;
  margin-bottom: 18px;
  flex: 1;
}
.blog-meta {
  display: flex;
  gap: 14px;
  font-family: 'Lato', sans-serif;
  font-size: 12.5px;
  color: #5A6A7E;
  margin-bottom: 10px;
  font-weight: 600;
}
.blog-meta span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.blog-read {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #0066FF;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: gap 0.25s;
  align-self: flex-start;
}
.blog-read:hover {
  gap: 14px;
}
/* ── CTA Bar ────────────────────────────────────────────────────────────── */
.cta-bar {
  background: linear-gradient(135deg, #0066FF 0%, #1E88FF 50%, #003FB5 100%);
  position: relative;
  overflow: hidden;
  padding: 70px 0;
}
.cta-bar::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 10% 50%, rgba(255, 214, 10, 0.18), transparent 50%), radial-gradient(circle at 90% 50%, rgba(79, 163, 255, 0.3), transparent 50%);
}
.cta-bar::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, 0.06) 1px, transparent 0);
  background-size: 28px 28px;
  pointer-events: none;
}
.cta-in {
  position: relative;
  z-index: 2;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
  flex-wrap: wrap;
}
.cta-left h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 900;
  color: #fff;
  line-height: 1.1;
  letter-spacing: -0.5px;
  margin-bottom: 8px;
}
.cta-left h3 .accent {
  background: linear-gradient(135deg, #FFD60A, #FFE566);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.cta-left p {
  font-family: 'Lato', sans-serif;
  color: rgba(255, 255, 255, 0.85);
  font-size: 16px;
  font-weight: 500;
  margin-bottom: 18px;
}
.cta-chips {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.cta-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 100px;
  padding: 8px 16px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.4px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: all 0.25s;
}
.cta-chip img {
  width: 18px;
  height: 13px;
  border-radius: 2px;
  object-fit: cover;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}
.cta-chip i {
  color: #FFD60A;
  font-size: 13px;
}
.cta-chip:hover {
  background: rgba(255, 255, 255, 0.22);
  border-color: rgba(255, 255, 255, 0.45);
  transform: translateY(-2px);
}
.cta-btns {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.cta-btns .btn-yellow {
  background: linear-gradient(135deg, #FFD60A, #FFB000);
  box-shadow: 0 10px 30px rgba(255, 214, 10, 0.55);
}
.cta-btns .btn-yellow:hover {
  background: linear-gradient(135deg, #FFB000, #FF9500);
  box-shadow: 0 14px 36px rgba(255, 176, 0, 0.65);
  transform: translateY(-3px);
}
.cta-btns .btn-white-outline {
  background: transparent;
  color: #fff;
  border: 2px solid rgba(255, 255, 255, 0.55);
}
.cta-btns .btn-white-outline:hover {
  background: #fff;
  color: #0066FF;
  border-color: #fff;
  transform: translateY(-3px);
}
/* ── Footer ─────────────────────────────────────────────────────────────── */
.footer {
  background: #001F66;
  color: rgba(255, 255, 255, 0.7);
  padding: 80px 0 30px;
}
.footer p.f-about {
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  line-height: 1.75;
  margin-bottom: 20px;
  max-width: 340px;
}
.footer h5 {
  font-family: 'Montserrat', sans-serif;
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 20px;
}
.footer nav,
.footer ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer ul li {
  margin-bottom: 10px;
}
.footer ul li a {
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  transition: color 0.25s;
  color: rgba(255, 255, 255, 0.7);
}
.footer ul li a:hover {
  color: #FFD60A;
}
.footer .sub-menu {
  display: none;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1.1fr;
  gap: 50px;
  margin-bottom: 40px;
}
.f-logo {
  display: flex;
  align-items: center;
  margin-bottom: 16px;
}
.f-social {
  display: flex;
  gap: 10px;
}
.f-social a {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
}
.f-social a:hover {
  background: #FFD60A;
  color: #0F1B2D;
  transform: translateY(-3px);
}
.f-contact li {
  display: flex;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  margin-bottom: 12px;
}
.f-contact li i {
  color: #FFD60A;
  width: 18px;
  flex-shrink: 0;
  margin-top: 4px;
}
.f-contact li a {
  color: rgba(255, 255, 255, 0.7);
  transition: color 0.2s;
}
.f-contact li a:hover {
  color: #FFD60A;
}
.f-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.15);
  padding: 20px 0 4px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.6);
}
.f-bottom a {
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
  transition: color 0.2s;
}
.f-bottom a:hover {
  color: #fff;
}
/* ── About — Page Hero ──────────────────────────────────────────────────── */
.page-hero {
  position: relative;
  min-height: 640px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.ph-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.05);
  transition: transform 8s ease;
}
.ph-bg::after {
  content: '';
  position: absolute;
  inset: 0;
}
.page-hero:hover .ph-bg {
  transform: scale(1);
}
.ph-ov {
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, rgba(0, 31, 102, 0.96) 0%, rgba(0, 63, 181, 0.84) 35%, rgba(0, 102, 255, 0.55) 65%, rgba(0, 31, 102, 0.25) 100%);
}
.ph-dots {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, 0.05) 1px, transparent 0);
  background-size: 32px 32px;
  pointer-events: none;
}
.ph-inner {
  position: relative;
  z-index: 2;
  padding-bottom: 80px;
  padding-top: 60px;
}
.ph-breadcrumb {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 22px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.ph-breadcrumb a {
  color: rgba(255, 255, 255, 0.5);
  transition: color 0.2s;
}
.ph-breadcrumb a:hover {
  color: #FFD60A;
}
.ph-breadcrumb i {
  font-size: 8px;
}
.ph-title {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(36px, 5.5vw, 72px);
  font-weight: 900;
  color: #fff;
  line-height: 1.02;
  letter-spacing: -1px;
  margin-bottom: 22px;
}
.ph-title em {
  font-style: normal;
  color: #FFD60A;
}
.ph-sub {
  font-family: 'Lato', sans-serif;
  font-size: 16.5px;
  line-height: 1.8;
  color: rgba(255, 255, 255, 0.72);
  max-width: 580px;
  margin-bottom: 36px;
}
.ph-sub strong {
  color: #fff;
  font-weight: 700;
}
.ph-chips {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.ph-chips span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 100px;
  padding: 9px 18px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: #fff;
}
.ph-chips span i {
  color: #FFD60A;
}
/* ── About — Stats Bar ──────────────────────────────────────────────────── */
.stats-bar {
  background: #001F66;
  padding: 0;
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-left: 1px solid rgba(255, 255, 255, 0.08);
}
.stat-item {
  padding: 48px 36px;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
}
.stat-item::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 36px;
  right: 36px;
  height: 3px;
  background: #FFD60A;
  border-radius: 3px 3px 0 0;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}
.stat-item:hover::before {
  transform: scaleX(1);
}
.stat-top {
  display: flex;
  align-items: flex-end;
  gap: 4px;
  line-height: 1;
}
.stat-num {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(38px, 4vw, 56px);
  font-weight: 900;
  color: #FFD60A;
  line-height: 1;
}
.stat-suf {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(22px, 2.2vw, 32px);
  font-weight: 900;
  color: #FFD60A;
  line-height: 1;
  margin-bottom: 5px;
}
.stat-lbl {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.45);
  margin-top: 12px;
}
/* ── About — Our Story ──────────────────────────────────────────────────── */
.story-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.story-img-wrap {
  position: relative;
}
.story-img {
  width: 100%;
  aspect-ratio: 4/5;
  border-radius: 32px;
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
}
.story-img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0, 31, 102, 0.6) 100%);
}
.story-badge {
  position: absolute;
  bottom: 28px;
  left: 28px;
  right: 28px;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 18px;
  padding: 18px 22px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
}
.story-badge i {
  color: #FFD60A;
  font-size: 22px;
  flex-shrink: 0;
  margin-top: 2px;
}
.story-badge span {
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  line-height: 1.45;
}
.story-img-sm {
  position: absolute;
  right: -32px;
  bottom: -32px;
  width: 46%;
  aspect-ratio: 1;
  border-radius: 24px;
  background-size: cover;
  background-position: center;
  border: 4px solid #fff;
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
}
.story-body .sec-label {
  margin-bottom: 12px;
}
.story-body .sec-title {
  margin-bottom: 28px;
}
.story-lead {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #0F1B2D;
  line-height: 1.55;
  margin-bottom: 20px;
}
.story-p {
  font-family: 'Lato', sans-serif;
  font-size: 15px;
  color: #5A6A7E;
  line-height: 1.85;
  margin-bottom: 16px;
}
.story-tags {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 32px;
}
.story-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #E8F1FF;
  border: 1.5px solid rgba(0, 102, 255, 0.15);
  border-radius: 100px;
  padding: 8px 16px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #0066FF;
}
.story-tag img {
  width: 20px;
  height: 14px;
  border-radius: 2px;
  object-fit: cover;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
}
/* ── About — Manifesto ──────────────────────────────────────────────────── */
.manifesto-sec {
  position: relative;
  padding: 100px 0;
  overflow: hidden;
  background: linear-gradient(160deg, #001F66 0%, #003FB5 100%);
}
.manifesto-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 20% 50%, rgba(255, 214, 10, 0.08), transparent 50%), radial-gradient(circle at 80% 50%, rgba(0, 102, 255, 0.35), transparent 55%);
}
.manifesto-in {
  position: relative;
  z-index: 2;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 60px;
}
.mani-top {
  max-width: 760px;
}
.manifesto-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 18px;
}
.manifesto-title {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(34px, 5vw, 64px);
  font-weight: 900;
  color: #fff;
  line-height: 1.05;
  letter-spacing: -1.5px;
  margin-bottom: 22px;
}
.mani-yellow {
  background: linear-gradient(135deg, #FFD60A, #FFE566);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.manifesto-text {
  font-family: 'Lato', sans-serif;
  font-size: 17px;
  line-height: 1.85;
  color: rgba(255, 255, 255, 0.68);
}
.mani-beliefs {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 24px;
  overflow: hidden;
}
.mani-belief {
  background: rgba(255, 255, 255, 0.04);
  padding: 40px 32px;
  text-align: left;
  transition: background 0.3s;
}
.mani-belief:hover {
  background: rgba(255, 255, 255, 0.09);
}
.mani-belief .mani-b-ico {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  margin-bottom: 20px;
  background: rgba(255, 214, 10, 0.15);
  border: 1.5px solid rgba(255, 214, 10, 0.22);
  display: flex;
  align-items: center;
  justify-content: center;
}
.mani-belief .mani-b-ico i {
  color: #FFD60A;
  font-size: 20px;
}
.mani-belief strong {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 15.5px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 10px;
  letter-spacing: -0.2px;
}
.mani-belief p {
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  line-height: 1.75;
  color: rgba(255, 255, 255, 0.58);
  margin: 0;
}
/* ── About — Duke Difference ────────────────────────────────────────────── */
.diff-sec {
  background: #fff;
}
.diff-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 54px;
}
.diff-card {
  background: #F4F8FF;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  padding: 36px 30px;
  transition: all 0.35s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.diff-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
  border-color: #1E88FF;
  background: #fff;
}
.diff-card:hover .diff-ico {
  background: #0066FF;
  color: #fff;
  border-color: #0066FF;
}
.diff-card h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 20px 0 12px;
}
.diff-card p {
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  color: #5A6A7E;
  line-height: 1.72;
}
.diff-ico {
  width: 58px;
  height: 58px;
  border-radius: 16px;
  background: #E8F1FF;
  border: 2px solid rgba(0, 102, 255, 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #0066FF;
  font-size: 22px;
  transition: all 0.3s;
}
/* ── About — Languages ──────────────────────────────────────────────────── */
.al-sec {
  padding: 100px 0;
}
.al-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 54px;
}
.al-card {
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0, 102, 255, 0.14);
  background: #fff;
  transition: all 0.38s cubic-bezier(0.25, 0.8, 0.25, 1);
  position: relative;
}
.al-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
}
.al-flag {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 5;
}
.al-flag img {
  width: 40px;
  height: 28px;
  border-radius: 5px;
  object-fit: cover;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  border: 2px solid rgba(255, 255, 255, 0.3);
}
.al-top {
  height: 160px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0 28px;
  overflow: hidden;
}
.al-top::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, 0.07) 1px, transparent 0);
  background-size: 24px 24px;
}
.al-char {
  font-size: 110px;
  font-weight: 900;
  color: rgba(255, 255, 255, 0.15);
  line-height: 1;
  user-select: none;
  font-family: 'Montserrat', sans-serif;
  letter-spacing: -3px;
  position: relative;
  z-index: 1;
}
.al-body {
  padding: 28px 28px 32px;
}
.al-body h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 900;
  color: #0F1B2D;
  margin-bottom: 4px;
}
.al-body p:not(.al-script) {
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  color: #5A6A7E;
  line-height: 1.7;
  margin-bottom: 20px;
}
.al-script {
  font-size: 13.5px;
  color: #0066FF;
  font-weight: 600;
  margin-bottom: 16px!important;
  font-family: 'Lato', sans-serif;
  letter-spacing: 0.5px;
}
.al-list {
  margin-bottom: 24px;
}
.al-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  margin-bottom: 10px;
}
.al-list li i {
  color: #0066FF;
  font-size: 11px;
  flex-shrink: 0;
}
.al-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #0066FF;
  transition: gap 0.25s;
}
.al-link:hover {
  gap: 14px;
}
/* ── About — Team ───────────────────────────────────────────────────────── */
.team-sec {
  background: #fff;
}
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 54px;
}
.team-card {
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0, 102, 255, 0.14);
  background: #fff;
  border: 1.5px solid #E5EAF2;
  transition: all 0.35s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.team-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
  border-color: #1E88FF;
}
.team-photo {
  height: 240px;
  background-size: cover;
  background-position: center top;
  position: relative;
}
.team-lang-badge {
  position: absolute;
  bottom: 14px;
  left: 14px;
  background: #FFD60A;
  color: #0F1B2D;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 20px;
}
.team-lang-badge img {
  width: 18px;
  height: 12px;
  border-radius: 2px;
  object-fit: cover;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}
.team-lang-badge i {
  font-size: 11px;
}
.team-body {
  padding: 22px 22px 26px;
}
.team-body h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 4px;
}
.team-role {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #0066FF;
  text-transform: uppercase;
  margin-bottom: 12px;
  display: block;
}
.team-bio {
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #5A6A7E;
  line-height: 1.65;
  margin-bottom: 16px;
}
.team-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.team-tags span {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.8px;
  padding: 5px 10px;
  border-radius: 20px;
  background: #E8F1FF;
  color: #0066FF;
}
/* ── About — Location ───────────────────────────────────────────────────── */
.loc-sec {
  padding: 100px 0;
}
.loc-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 80px;
  align-items: center;
}
.loc-list {
  margin-top: 28px;
}
.loc-list li {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 16px 0;
  border-bottom: 1px solid #E5EAF2;
}
.loc-list li:last-child {
  border-bottom: none;
}
.loc-list li > i {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  flex-shrink: 0;
  background: #E8F1FF;
  color: #0066FF;
  font-size: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}
.loc-list li div {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.loc-list li strong {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #0F1B2D;
}
.loc-list li span {
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  color: #5A6A7E;
}
.loc-map {
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
  height: 480px;
}
.loc-map iframe {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}
/* ── Scroll Reveal ──────────────────────────────────────────────────────── */
.fade-up {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.fade-up.vis {
  opacity: 1;
  transform: translateY(0);
}
.d1 {
  transition-delay: 0.1s;
}
.d2 {
  transition-delay: 0.2s;
}
.d3 {
  transition-delay: 0.3s;
}
.d4 {
  transition-delay: 0.4s;
}
.d5 {
  transition-delay: 0.5s;
}
.d6 {
  transition-delay: 0.6s;
}
/* ── Back to Top ────────────────────────────────────────────────────────── */
.back-top {
  position: fixed;
  bottom: 30px;
  right: 30px;
  z-index: 150;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #0066FF;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 24px rgba(0, 102, 255, 0.35);
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
  transition: all 0.3s;
}
.back-top.show {
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
}
.back-top:hover {
  background: #003FB5;
  transform: translateY(-3px) !important;
}
/* ── Page Hero — Buttons ────────────────────────────────────────────────── */
.ph-btns {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 32px;
}
/* sec-label inside hero must be white, not blue */
.ph-inner .sec-label {
  color: rgba(255, 255, 255, 0.6);
}
/* ── Thai Course Hero ────────────────────────────────────────────────────── */
.thai-course-hero {
  min-height: 640px;
}
.tc-hero-char {
  position: absolute;
  right: 6%;
  top: 50%;
  transform: translateY(-50%);
  font-family: 'Kanit', sans-serif;
  font-size: 320px;
  font-weight: 900;
  line-height: 1;
  color: rgba(255, 255, 255, 0.06);
  pointer-events: none;
  user-select: none;
  z-index: 1;
}
/* ── Course Quick Nav ────────────────────────────────────────────────────── */
.course-nav-sec {
  background: #001F66;
  padding: 0;
}
.cnav-grid {
  max-width: 1520px;
  margin: 0 auto;
  padding: 0 48px;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
}
.cnav-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 14px;
  padding: 32px 16px;
  border-right: 1px solid rgba(255, 255, 255, 0.07);
  text-decoration: none;
  position: relative;
  transition: background 0.25s;
}
.cnav-card:last-child {
  border-right: none;
}
.cnav-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 3px;
  background: #FFD60A;
  border-radius: 3px 3px 0 0;
  transition: width 0.3s;
}
.cnav-card:hover {
  background: rgba(255, 255, 255, 0.07);
}
.cnav-card:hover::after {
  width: 56%;
}
.cnav-card:hover .cnav-ico {
  background: rgba(255, 214, 10, 0.14);
  border-color: rgba(255, 214, 10, 0.3);
}
.cnav-ico {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s;
  flex-shrink: 0;
}
.cnav-ico i {
  color: #FFD60A;
  font-size: 18px;
}
.cnav-body {
  text-align: center;
}
.cnav-body strong {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #fff;
  letter-spacing: 0.2px;
  margin-bottom: 5px;
}
.cnav-body span {
  display: block;
  font-family: 'Lato', sans-serif;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.42);
  line-height: 1.55;
}
/* ── Course Programs ─────────────────────────────────────────────────────── */
.programs-sec {
  background: #fff;
}
.prog-block {
  margin-top: 28px;
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 4px 32px rgba(0, 0, 0, 0.08), 0 1px 4px rgba(0, 0, 0, 0.04);
  transition: box-shadow 0.35s;
}
.prog-block:hover {
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.13), 0 1px 4px rgba(0, 0, 0, 0.04);
}
.why-head + .prog-block {
  margin-top: 48px;
}
.prog-block-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  padding: 44px 48px;
  position: relative;
  overflow: hidden;
}
.prog-block-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, 0.055) 1px, transparent 0);
  background-size: 28px 28px;
  pointer-events: none;
}
.prog-block-header.prog-journey {
  background: linear-gradient(135deg, #001F66 0%, #003FB5 100%);
}
.prog-block-header.prog-explore {
  background: linear-gradient(135deg, #78350f 0%, #d97706 100%);
}
.prog-block-header.prog-connect {
  background: linear-gradient(135deg, #022c22 0%, #059669 100%);
}
.prog-series-badge {
  display: inline-flex;
  align-items: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.62);
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 100px;
  padding: 5px 13px;
  margin-bottom: 14px;
}
.prog-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 34px;
  font-weight: 900;
  color: #fff;
  margin-bottom: 12px;
  letter-spacing: -1px;
}
.prog-desc {
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  line-height: 1.78;
  color: rgba(255, 255, 255, 0.72);
  margin: 0;
  max-width: 520px;
}
.prog-block-right {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-end;
}
.prog-block-right span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.9);
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 100px;
  padding: 7px 16px;
}
.prog-block-right span i {
  color: rgba(255, 255, 255, 0.5);
  font-size: 11px;
}
/* Per-series tinted level backgrounds */
.prog-block.prog-journey .prog-levels {
  background: #E8F1FF;
}
.prog-block.prog-explore .prog-levels {
  background: #fffbeb;
}
.prog-block.prog-connect .prog-levels {
  background: #ecfdf5;
}
.prog-levels {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  padding: 28px;
}
.prog-level-card {
  background: #fff;
  border-radius: 24px;
  padding: 28px 24px 22px;
  border: 1.5px solid #E5EAF2;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
  transition: all 0.28s cubic-bezier(0.25, 0.8, 0.25, 1);
  position: relative;
  overflow: hidden;
}
.prog-level-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
}
.prog-level-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.1);
  border-color: transparent;
}
.prog-block.prog-journey .prog-level-card::before {
  background: #0066FF;
}
.prog-block.prog-explore .prog-level-card::before {
  background: #d97706;
}
.prog-block.prog-connect .prog-level-card::before {
  background: #00C4B4;
}
.plc-top {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.plc-num {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 900;
  color: #fff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
}
.journey-num {
  background: #0066FF;
}
.explore-num {
  background: #d97706;
}
.connect-num {
  background: #00C4B4;
}
.plc-title-wrap strong {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 5px;
}
.plc-tag {
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  border-radius: 100px;
  padding: 3px 10px;
  background: #E8F1FF;
  color: #0066FF;
}
.plc-tag-exp {
  background: #fef3c7;
  color: #92400e;
}
.plc-tag-con {
  background: #d1fae5;
  color: #065f46;
}
.plc-tagline {
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  font-weight: 700;
  color: #5A6A7E;
  margin-bottom: 14px;
  font-style: italic;
}
.plc-list {
  list-style: none;
  margin: 0 0 16px;
  padding: 0;
}
.plc-list li {
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  line-height: 1.65;
  color: #5A6A7E;
  padding: 4px 0 4px 18px;
  position: relative;
}
.plc-list li::before {
  content: '·';
  position: absolute;
  left: 0;
  color: #0066FF;
  font-weight: 700;
  font-size: 18px;
  line-height: 1.1;
}
.prog-explore .plc-list li::before {
  color: #d97706;
}
.prog-connect .plc-list li::before {
  color: #00C4B4;
}
.plc-meta {
  display: flex;
  gap: 14px;
  padding-top: 12px;
  border-top: 1px solid #E5EAF2;
}
.plc-meta span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  color: #5A6A7E;
}
.plc-meta span i {
  font-size: 10px;
  color: #0066FF;
}
.prog-explore .plc-meta i {
  color: #d97706;
}
.prog-connect .plc-meta i {
  color: #00C4B4;
}
.plc-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 18px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.4px;
  text-decoration: none;
  border-radius: 100px;
  padding: 8px 18px;
  color: #0066FF;
  background: #E8F1FF;
  border: 1.5px solid rgba(0, 102, 255, 0.15);
  transition: all 0.22s;
}
.plc-link i {
  font-size: 9px;
  transition: transform 0.2s;
}
.plc-link:hover {
  background: #0066FF;
  color: #fff;
  border-color: #0066FF;
}
.plc-link:hover i {
  transform: translateX(3px);
}
.plc-link-exp {
  color: #d97706;
  background: #fef3c7;
  border-color: rgba(217, 119, 6, 0.2);
}
.plc-link-exp:hover {
  background: #d97706;
  color: #fff;
  border-color: #d97706;
}
.plc-link-con {
  color: #065f46;
  background: #d1fae5;
  border-color: rgba(5, 150, 105, 0.2);
}
.plc-link-con:hover {
  background: #00C4B4;
  color: #fff;
  border-color: #00C4B4;
}
.prog-cta {
  margin-top: 56px;
  text-align: center;
}
.prog-cta p {
  font-family: 'Lato', sans-serif;
  font-size: 15px;
  color: #5A6A7E;
  margin-bottom: 16px;
}
/* ── Course Detail Page ──────────────────────────────────────────────────── */
.cd-hero {
  min-height: 640px;
}
.cd-journey .ph-ov {
  background: linear-gradient(105deg, rgba(0, 31, 102, 0.96) 0%, rgba(0, 63, 181, 0.84) 40%, rgba(0, 102, 255, 0.5) 100%);
}
.cd-explore .ph-ov {
  background: linear-gradient(105deg, rgba(69, 26, 3, 0.97) 0%, rgba(120, 53, 15, 0.85) 40%, rgba(180, 83, 9, 0.5) 100%);
}
.cd-connect .ph-ov {
  background: linear-gradient(105deg, rgba(2, 44, 34, 0.97) 0%, rgba(4, 120, 87, 0.85) 40%, rgba(0, 196, 180, 0.5) 100%);
}
.cd-series-badge {
  display: inline-flex;
  align-items: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 16px;
  padding: 6px 14px;
  border-radius: 100px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.08);
}
.cd-badge-journey {
  border-color: rgba(0, 102, 255, 0.5);
  color: rgba(150, 200, 255, 0.9);
}
.cd-badge-explore {
  border-color: rgba(217, 119, 6, 0.5);
  color: rgba(252, 211, 77, 0.9);
}
.cd-badge-connect {
  border-color: rgba(0, 196, 180, 0.5);
  color: rgba(110, 231, 183, 0.9);
}
.cd-hero-subtitle {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.5px;
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: 12px;
  text-transform: uppercase;
}
.cd-content-sec {
  background: #fff;
  padding-top: 72px;
}
.cd-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 52px;
  align-items: start;
}
.cd-intro {
  margin-bottom: 48px;
}
.cd-section {
  margin-bottom: 40px;
}
.cd-section-heading {
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  font-weight: 900;
  color: #0F1B2D;
  margin-bottom: 20px;
  letter-spacing: -0.2px;
}
.cd-heading-line {
  display: block;
  width: 4px;
  height: 22px;
  border-radius: 4px;
  flex-shrink: 0;
}
.cd-heading-journey .cd-heading-line {
  background: #0066FF;
}
.cd-heading-explore .cd-heading-line {
  background: #d97706;
}
.cd-heading-connect .cd-heading-line {
  background: #00C4B4;
}
.cd-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  overflow: hidden;
}
.cd-list li {
  padding: 16px 20px;
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  line-height: 1.6;
  color: #0F1B2D;
  border-bottom: 1px solid #E5EAF2;
  border-right: 1px solid #E5EAF2;
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.cd-list li:nth-child(even) {
  border-right: none;
}
.cd-list li:nth-last-child(-n+2) {
  border-bottom: none;
}
.cd-list li::before {
  content: '\f00c';
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  font-size: 10px;
  margin-top: 3px;
  flex-shrink: 0;
}
.cd-list-journey li::before {
  color: #0066FF;
}
.cd-list-explore li::before {
  color: #d97706;
}
.cd-list-connect li::before {
  color: #00C4B4;
}
.cd-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 52px;
  padding-top: 36px;
  border-top: 1.5px solid #E5EAF2;
  gap: 16px;
}
.cd-nav-btn {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  padding: 16px 22px;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  transition: all 0.25s;
}
.cd-nav-btn:hover {
  border-color: #0066FF;
  background: #E8F1FF;
}
.cd-nav-btn:hover i {
  color: #0066FF;
}
.cd-nav-btn:hover .cd-nav-name {
  color: #0066FF;
}
.cd-nav-btn:hover em {
  color: #003FB5;
}
.cd-nav-btn em {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #5A6A7E;
  font-style: normal;
  margin-bottom: 3px;
  transition: color 0.25s;
}
.cd-nav-btn .cd-nav-name {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: #0F1B2D;
  transition: color 0.25s;
}
.cd-nav-btn i {
  color: #5A6A7E;
  font-size: 14px;
  flex-shrink: 0;
  transition: color 0.25s;
}
.cd-nav-next {
  text-align: right;
}
/* Sidebar */
.cd-sidebar {
  position: sticky;
  top: calc(var(--header-h) + 24px);
}
.cd-enrol-box {
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  overflow: hidden;
  margin-bottom: 24px;
}
.cd-enrol-top {
  padding: 28px 24px;
}
.cd-enrol-journey {
  background: linear-gradient(135deg, #001F66, #003FB5);
}
.cd-enrol-explore {
  background: linear-gradient(135deg, #92400e, #d97706);
}
.cd-enrol-connect {
  background: linear-gradient(135deg, #065f46, #00C4B4);
}
.cd-enrol-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: 8px;
}
.cd-enrol-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 24px;
  font-weight: 900;
  color: #fff;
  margin-bottom: 4px;
  letter-spacing: -0.3px;
}
.cd-enrol-level {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.6);
}
.cd-enrol-body {
  padding: 24px;
}
.cd-enrol-meta {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
}
.cd-enrol-meta li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid #E5EAF2;
}
.cd-enrol-meta li:last-child {
  border-bottom: none;
}
.cd-enrol-meta li i {
  color: inherit;
  font-size: 13px;
  margin-top: 3px;
  width: 16px;
  text-align: center;
  opacity: 0.7;
}
.cd-enrol-meta li span {
  flex: 1;
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: #5A6A7E;
}
.cd-enrol-meta li span strong {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 2px;
}
.cd-all-levels {
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  overflow: hidden;
}
.cd-all-levels h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #5A6A7E;
  padding: 18px 20px;
  border-bottom: 1px solid #E5EAF2;
  margin: 0;
}
.cd-level-list {
  padding: 8px 0;
}
.cd-level-group {
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(90, 106, 126, 0.5);
  padding: 12px 20px 4px;
  margin: 0;
}
.cd-level-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  text-decoration: none;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: #0F1B2D;
  transition: background 0.2s;
}
.cd-level-item:hover {
  background: #F4F8FF;
}
.cd-level-item.active {
  background: #E8F1FF;
  color: #0066FF;
}
.explore-num ~ .cd-level-item.active {
  background: #fef3c7;
  color: #92400e;
}
.cd-level-item em {
  margin-left: auto;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 700;
  color: #5A6A7E;
  font-style: normal;
}
/* Active item color per series */
.cd-level-item.active:has(.journey-num) {
  background: #E8F1FF;
  color: #0066FF;
}
.cd-level-item.active:has(.explore-num) {
  background: #fef3c7;
  color: #92400e;
}
.cd-level-item.active:has(.connect-num) {
  background: #d1fae5;
  color: #065f46;
}
.cd-li-num {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 900;
  color: #fff;
}
/* ── Course Detail responsive ────────────────────────────────────────────── */
@media (max-width: 680px) {
  .cd-nav {
    flex-wrap: wrap;
    gap: 12px;
  }
  .cd-nav-btn {
    flex: 1 1 200px;
  }
  .cd-intro {
    margin-bottom: 32px;
  }
  .cd-section {
    margin-bottom: 28px;
  }
  .cd-enrol-top {
    padding: 24px 20px;
  }
  .cd-enrol-body {
    padding: 20px;
  }
  .cd-all-levels h4 {
    padding: 14px 16px;
  }
  .cd-level-item {
    padding: 9px 16px;
  }
  .cd-level-group {
    padding: 10px 16px 4px;
  }
}
@media (max-width: 480px) {
  .cd-nav {
    flex-direction: column;
  }
  .cd-nav-btn {
    width: 100%;
    padding: 13px 16px;
  }
  .cd-nav-next {
    text-align: left;
  }
  .cd-nav-btn .cd-nav-name {
    font-size: 13px;
  }
  .cd-section-heading {
    font-size: 15px;
    gap: 10px;
  }
  .cd-list li {
    padding: 13px 16px;
    font-size: 13.5px;
  }
  .cd-enrol-top {
    padding: 20px 18px;
  }
  .cd-enrol-name {
    font-size: 20px;
  }
  .cd-enrol-body {
    padding: 18px;
  }
}
@media (max-width: 380px) {
  .cd-list li {
    padding: 11px 14px;
    font-size: 13px;
  }
  .cd-nav-btn {
    padding: 11px 14px;
  }
  .cd-enrol-top {
    padding: 18px 16px;
  }
  .cd-enrol-name {
    font-size: 18px;
  }
  .cd-enrol-body {
    padding: 14px;
  }
}
/* ── Class Times Page ────────────────────────────────────────────────────── */
.ct-hero {
  min-height: 640px;
}
.pl-hero {
  min-height: 640px;
}
.ct-sec {
  background: #fff;
}
.ct-sec-head {
  max-width: 680px;
  margin-bottom: 48px;
}
/* ── Schedule Table ──────────────────────────────────────────────────────── */
.ct-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 28px;
  align-items: start;
  margin-bottom: 28px;
}
.ct-schedule {
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 2px 16px rgba(0, 0, 0, 0.04);
}
.ct-sched-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  background: #001F66;
}
.ct-sched-hdr span:first-child {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #fff;
}
.ct-sched-hdr span:first-child i {
  color: #FFD60A;
}
.ct-sched-hdr span:last-child {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.42);
}
.ct-sched-row {
  display: grid;
  grid-template-columns: 50px 1fr auto 28px;
  align-items: center;
  gap: 0;
  padding: 20px 24px;
  border-bottom: 1px solid #E5EAF2;
  transition: background 0.2s;
}
.ct-sched-row:last-child {
  border-bottom: none;
}
.ct-sched-row:hover {
  background: #E8F1FF;
}
.ct-sched-row:hover .ct-sr-num {
  transform: scale(1.1);
}
.ct-sched-row:hover .ct-sr-tag {
  border-color: #1E88FF;
  color: #0066FF;
}
.ct-sr-num {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  flex-shrink: 0;
  background: #0066FF;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: -0.2px;
  box-shadow: 0 3px 10px rgba(0, 102, 255, 0.35);
  transition: transform 0.2s;
}
.ct-sr-num-night {
  background: #001F66;
  font-size: 10px;
  letter-spacing: 0.2px;
}
.ct-sr-time {
  padding-left: 20px;
  font-family: 'Montserrat', sans-serif;
  font-size: 20px;
  font-weight: 900;
  color: #0F1B2D;
  letter-spacing: -0.5px;
}
.ct-sr-tag {
  margin-right: 14px;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: #5A6A7E;
  background: #F4F8FF;
  border: 1.5px solid #E5EAF2;
  border-radius: 100px;
  padding: 5px 14px;
  white-space: nowrap;
  transition: all 0.2s;
}
.ct-sr-ico {
  color: #FFD60A;
  font-size: 15px;
  opacity: 0.55;
}
/* Night schedule overrides */
.ct-night .ct-schedule {
  border-color: rgba(255, 255, 255, 0.12);
}
.ct-night .ct-sched-hdr {
  background: rgba(255, 255, 255, 0.07);
}
.ct-night .ct-sched-row {
  border-color: rgba(255, 255, 255, 0.1);
}
.ct-night .ct-sched-row:hover {
  background: rgba(255, 255, 255, 0.06);
}
.ct-night .ct-sr-time {
  color: #fff;
}
.ct-night .ct-sr-tag {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.65);
}
/* ── Sidebar Course Card ─────────────────────────────────────────────────── */
.ct-course-card {
  border-radius: 32px;
  overflow: hidden;
  position: sticky;
  top: calc(var(--header-h) + 24px);
  background: linear-gradient(160deg, #001F66 0%, #003FB5 100%);
}
.ct-cc-top {
  padding: 28px 24px 22px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.ct-cc-lbl {
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.4);
  margin-bottom: 10px;
}
.ct-cc-price {
  display: flex;
  align-items: flex-start;
  gap: 2px;
  margin-bottom: 6px;
}
.ct-cc-price .ct-cc-curr {
  font-family: 'Montserrat', sans-serif;
  font-size: 20px;
  font-weight: 900;
  color: #FFD60A;
  line-height: 1;
  margin-top: 10px;
}
.ct-cc-price .ct-cc-amt {
  font-family: 'Montserrat', sans-serif;
  font-size: 50px;
  font-weight: 900;
  color: #fff;
  line-height: 1;
  letter-spacing: -2px;
}
.ct-cc-meta {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.38);
}
.ct-cc-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.ct-cc-stat {
  padding: 16px 20px;
  text-align: center;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
}
.ct-cc-stat:last-child {
  border-right: none;
}
.ct-cc-stat strong {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 900;
  color: #fff;
  margin-bottom: 3px;
}
.ct-cc-stat span {
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.38);
}
.ct-cc-btns {
  padding: 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ct-cc-btns .btn {
  width: 100%;
  justify-content: center;
}
.ct-night .ct-course-card {
  background: rgba(255, 255, 255, 0.07);
  border: 1.5px solid rgba(255, 255, 255, 0.1);
}
/* ── Facts Strip ─────────────────────────────────────────────────────────── */
.ct-facts {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  overflow: hidden;
}
.ct-fact {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 20px 22px;
  border-right: 1px solid #E5EAF2;
  transition: background 0.2s;
}
.ct-fact:last-child {
  border-right: none;
}
.ct-fact:hover {
  background: #F4F8FF;
}
.ct-fact .ct-fact-ico {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: #E8F1FF;
  color: #0066FF;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
  transition: all 0.2s;
}
.ct-fact:hover .ct-fact-ico {
  background: #0066FF;
  color: #fff;
}
.ct-fact .ct-fact-body strong {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 3px;
}
.ct-fact .ct-fact-body strong a {
  color: #0066FF;
  text-decoration: none;
}
.ct-fact .ct-fact-body strong a:hover {
  text-decoration: underline;
}
.ct-fact .ct-fact-body span {
  font-family: 'Lato', sans-serif;
  font-size: 12px;
  color: #5A6A7E;
}
.ct-fact .ct-fact-body span a {
  color: #0066FF;
  font-weight: 600;
  text-decoration: none;
}
.ct-fact .ct-fact-body span a:hover {
  text-decoration: underline;
}
.ct-facts-dark {
  border-color: rgba(255, 255, 255, 0.1);
}
.ct-facts-dark .ct-fact {
  border-color: rgba(255, 255, 255, 0.1);
}
.ct-facts-dark .ct-fact:hover {
  background: rgba(255, 255, 255, 0.05);
}
.ct-facts-dark .ct-fact .ct-fact-ico {
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.7);
}
.ct-facts-dark .ct-fact:hover .ct-fact-ico {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}
.ct-facts-dark .ct-fact .ct-fact-body strong {
  color: #fff;
}
.ct-facts-dark .ct-fact .ct-fact-body strong a {
  color: #FFD60A;
}
.ct-facts-dark .ct-fact .ct-fact-body span {
  color: rgba(255, 255, 255, 0.5);
}
.ct-facts-dark .ct-fact .ct-fact-body span a {
  color: #FFD60A;
}
/* ── Night Section ───────────────────────────────────────────────────────── */
.ct-night {
  background: linear-gradient(160deg, #001F66 0%, #001A55 100%);
  padding: 100px 0;
}
.ct-night .sec-label {
  color: rgba(255, 255, 255, 0.45);
}
.ct-night .sec-title {
  color: #fff;
}
.ct-night .sec-title em {
  color: #FFD60A !important;
}
.ct-night .sec-sub {
  color: rgba(255, 255, 255, 0.58);
}
/* ── Pricing Cards ───────────────────────────────────────────────────────── */
.ct-pricing-sec {
  background: #F4F8FF;
  padding: 100px 0;
}
.ct-price-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 54px;
  align-items: start;
}
.ct-price-card {
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 36px 32px;
  position: relative;
  overflow: hidden;
  transition: all 0.35s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.ct-price-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
  border-color: #1E88FF;
}
.ct-price-popular {
  border-color: #0066FF;
  box-shadow: 0 8px 40px rgba(0, 102, 255, 0.15);
  transform: translateY(-6px);
}
.ct-price-popular::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #003FB5, #0066FF, #1E88FF);
}
.ct-price-popular:hover {
  border-color: #0066FF;
  transform: translateY(-12px);
}
.ct-pc-badge {
  display: inline-flex;
  align-items: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  background: #0066FF;
  color: #fff;
  border-radius: 100px;
  padding: 5px 14px;
  margin-bottom: 16px;
}
.ct-pc-head {
  margin-bottom: 22px;
}
.ct-pc-label {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #0066FF;
  margin-bottom: 8px;
}
.ct-pc-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 28px;
  font-weight: 900;
  color: #0F1B2D;
  margin-bottom: 6px;
  letter-spacing: -0.5px;
}
.ct-pc-detail {
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: #5A6A7E;
}
.ct-pc-price {
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1.5px solid #E5EAF2;
}
.ct-pc-old {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: #5A6A7E;
  text-decoration: line-through;
  margin-bottom: 4px;
}
.ct-pc-amount {
  display: flex;
  align-items: flex-start;
  gap: 2px;
}
.ct-pc-currency {
  font-family: 'Montserrat', sans-serif;
  font-size: 20px;
  font-weight: 900;
  color: #0F1B2D;
  line-height: 1;
  margin-top: 10px;
}
.ct-price-popular .ct-pc-currency {
  color: #0066FF;
}
.ct-pc-main {
  font-family: 'Montserrat', sans-serif;
  font-size: 52px;
  font-weight: 900;
  color: #0F1B2D;
  letter-spacing: -2px;
  line-height: 1;
}
.ct-price-popular .ct-pc-main {
  color: #0066FF;
}
.ct-pc-savings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
}
.ct-pc-per {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  color: #5A6A7E;
  font-weight: 700;
}
.ct-price-popular .ct-pc-per {
  color: #0066FF;
}
.ct-pc-save {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  color: #065f46;
  background: #d1fae5;
  border-radius: 100px;
  padding: 4px 10px;
}
.ct-pc-save i {
  font-size: 9px;
}
.ct-pc-list {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
}
.ct-pc-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #5A6A7E;
  padding: 9px 0;
  border-bottom: 1px solid #E5EAF2;
}
.ct-pc-list li:first-child {
  padding-top: 0;
}
.ct-pc-list li:last-child {
  border-bottom: none;
}
.ct-pc-list li i {
  color: #0066FF;
  font-size: 11px;
  margin-top: 3px;
  flex-shrink: 0;
}
.ct-pc-btn {
  width: 100%;
  justify-content: center;
}
/* ── Class Times responsive ──────────────────────────────────────────────── */
@media (max-width: 1060px) {
  .ct-layout {
    grid-template-columns: 1fr;
  }
  .ct-course-card {
    position: static;
    max-width: 480px;
  }
  .ct-facts {
    grid-template-columns: repeat(2, 1fr);
  }
  .ct-fact:nth-child(2) {
    border-right: none;
  }
  .ct-night {
    padding: 72px 0;
  }
  .ct-pricing-sec {
    padding: 72px 0;
  }
  .ct-price-card {
    padding: 30px 26px;
  }
}
@media (max-width: 900px) {
  .ct-price-grid {
    grid-template-columns: 1fr;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
  }
  .ct-price-popular {
    transform: none;
  }
  .ct-price-popular:hover {
    transform: translateY(-8px);
  }
}
@media (max-width: 680px) {
  .ct-sr-time {
    font-size: 16px;
    letter-spacing: -0.3px;
  }
  .ct-sched-hdr {
    padding: 14px 18px;
    flex-wrap: wrap;
    gap: 4px;
  }
  .ct-sched-row {
    padding: 16px 18px;
  }
  .ct-facts {
    grid-template-columns: 1fr;
  }
  .ct-fact {
    border-right: none;
    border-bottom: 1px solid #E5EAF2;
  }
  .ct-fact:last-child {
    border-bottom: none;
  }
  .ct-facts-dark .ct-fact {
    border-color: rgba(255, 255, 255, 0.1);
  }
  .ct-fact {
    padding: 16px 18px;
  }
  .ct-night {
    padding: 56px 0;
  }
  .ct-pricing-sec {
    padding: 56px 0;
  }
  .ct-price-card {
    padding: 26px 22px;
  }
  .ct-cc-top {
    padding: 22px 20px 18px;
  }
  .ct-cc-amt {
    font-size: 40px;
  }
  .ct-course-card {
    max-width: 100%;
  }
}
@media (max-width: 480px) {
  .ct-sr-time {
    font-size: 14px;
  }
  .ct-sr-num {
    width: 34px;
    height: 34px;
    font-size: 10px;
  }
  .ct-sched-row {
    padding: 14px 16px;
  }
  .ct-sr-tag {
    font-size: 9px;
    padding: 4px 10px;
    margin-right: 8px;
  }
  .ct-sr-ico {
    font-size: 13px;
  }
  .ct-fact {
    padding: 14px 16px;
    gap: 12px;
  }
  .ct-night {
    padding: 48px 0;
  }
  .ct-pricing-sec {
    padding: 48px 0;
  }
  .ct-price-card {
    padding: 22px 18px;
    border-radius: 24px;
  }
  .ct-pc-name {
    font-size: 24px;
  }
  .ct-pc-main {
    font-size: 44px;
  }
  .ct-pc-list li {
    font-size: 13px;
  }
  .ct-cc-amt {
    font-size: 38px;
  }
}
@media (max-width: 380px) {
  .ct-sr-time {
    font-size: 13px;
  }
  .ct-sched-row {
    padding: 12px 14px;
  }
  .ct-fact {
    padding: 12px 14px;
  }
  .ct-price-card {
    padding: 18px 14px;
  }
  .ct-pc-main {
    font-size: 38px;
  }
}
/* ── Private Lessons ─────────────────────────────────────────────────────── */
.pl-left-col {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.pl-benefits {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.pl-benefit {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  padding: 18px 20px;
  transition: all 0.25s;
}
.pl-benefit:hover {
  background: #E8F1FF;
  border-color: #1E88FF;
}
.pl-benefit:hover .pl-ben-ico {
  background: #0066FF;
  color: #fff;
}
.pl-ben-ico {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: #E8F1FF;
  color: #0066FF;
  font-size: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s;
}
.pl-ben-body strong {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 13.5px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 4px;
}
.pl-ben-body span {
  font-family: 'Lato', sans-serif;
  font-size: 12.5px;
  color: #5A6A7E;
  line-height: 1.55;
}
.pl-cc-min {
  margin: 0 22px 16px;
  padding: 12px 16px;
  background: rgba(255, 255, 255, 0.07);
  border-radius: 12px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  color: rgba(255, 255, 255, 0.5);
  display: flex;
  align-items: center;
  gap: 8px;
}
.pl-cc-min i {
  color: #FFD60A;
  font-size: 12px;
  flex-shrink: 0;
}
/* Private vs Group comparison */
.pl-vs-sec {
  background: #F4F8FF;
}
.pl-compare-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 54px;
}
.pl-compare-card {
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 36px 32px;
  position: relative;
  overflow: hidden;
  transition: all 0.35s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.pl-compare-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
}
.pl-compare-card .btn {
  width: 100%;
  justify-content: center;
}
.pl-private {
  border-color: #0066FF;
  box-shadow: 0 8px 40px rgba(0, 102, 255, 0.12);
}
.pl-private::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #003FB5, #0066FF, #1E88FF);
}
.pl-private:hover {
  transform: translateY(-10px);
  border-color: #0066FF;
}
.pl-group::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #00C4B4, #34d399);
}
.pl-cc-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  background: #0066FF;
  color: #fff;
  border-radius: 100px;
  padding: 6px 16px;
  margin-bottom: 16px;
}
.pl-cc-badge i {
  font-size: 11px;
}
.pl-badge-group {
  background: #00C4B4;
}
.pl-cc-price-line {
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  margin-bottom: 20px;
}
.pl-cc-price-line strong {
  color: #0F1B2D;
  font-size: 18px;
  font-weight: 900;
}
.pl-private .pl-cc-price-line strong {
  color: #0066FF;
}
.pl-group .pl-cc-price-line strong {
  color: #00C4B4;
}
.pl-cc-list {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
}
.pl-cc-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #5A6A7E;
  padding: 10px 0;
  border-bottom: 1px solid #E5EAF2;
}
.pl-cc-list li:first-child {
  padding-top: 0;
}
.pl-cc-list li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.pl-cc-list li i {
  color: #0066FF;
  font-size: 11px;
  margin-top: 3px;
  flex-shrink: 0;
}
.pl-group .pl-cc-list li i {
  color: #00C4B4;
}
/* Private Lessons responsive */
@media (max-width: 1060px) {
  .pl-compare-grid {
    gap: 18px;
  }
  .pl-compare-card {
    padding: 28px 24px;
  }
}
@media (max-width: 900px) {
  .pl-compare-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .pl-compare-card {
    padding: 28px 24px;
  }
}
@media (max-width: 680px) {
  .pl-benefits {
    grid-template-columns: 1fr;
  }
  .pl-compare-card {
    padding: 24px 20px;
  }
  .pl-compare-grid {
    gap: 14px;
  }
}
@media (max-width: 480px) {
  .pl-compare-card {
    padding: 22px 18px;
    border-radius: 24px;
  }
  .pl-cc-list li {
    font-size: 13px;
  }
}
@media (max-width: 380px) {
  .pl-benefit {
    padding: 14px 16px;
  }
  .pl-compare-card {
    padding: 18px 14px;
  }
  .pl-cc-list li {
    font-size: 12.5px;
  }
}
/* ── Study Online ─────────────────────────────────────────────────────────── */
.so-hero {
  min-height: 640px;
}
/* Advantages */
.so-adv-sec {
  background: #FFFFFF;
}
.so-adv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 54px;
}
.so-adv-card {
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 32px 28px;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  position: relative;
  overflow: hidden;
}
.so-adv-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #003FB5, #0066FF, #1E88FF);
  opacity: 0;
  transition: opacity 0.3s;
}
.so-adv-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
  border-color: #1E88FF;
}
.so-adv-card:hover::before {
  opacity: 1;
}
.so-adv-card:hover .so-adv-ico {
  background: #0066FF;
  color: #fff;
}
.so-adv-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.so-adv-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 36px;
  font-weight: 900;
  color: #E8F1FF;
  line-height: 1;
}
.so-adv-ico {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: #E8F1FF;
  color: #0066FF;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s;
  flex-shrink: 0;
}
.so-adv-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 12px;
  line-height: 1.4;
}
.so-adv-body {
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #5A6A7E;
  line-height: 1.65;
}
/* Schedule left column */
.so-left-col {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
/* Requirements bar */
.so-req-bar {
  display: flex;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  overflow: hidden;
}
.so-req-item {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #0F1B2D;
  background: #fff;
  border-right: 1px solid #E5EAF2;
}
.so-req-item:last-child {
  border-right: none;
}
.so-req-item i {
  font-size: 14px;
  color: #0066FF;
  flex-shrink: 0;
}
.so-req-novisa {
  color: #FF7A59;
}
.so-req-novisa i {
  color: #FF7A59;
}
/* Bundle section */
.so-bundle-sec {
  background: #F4F8FF;
}
.so-bundle-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
  margin-top: 54px;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}
.so-bundle-card {
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 40px 36px;
  position: relative;
  overflow: hidden;
  transition: all 0.35s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.so-bundle-card .btn {
  width: 100%;
  justify-content: center;
}
.so-bundle-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
}
.so-bundle-featured {
  border-color: #0066FF;
  box-shadow: 0 8px 40px rgba(0, 102, 255, 0.15);
}
.so-bundle-featured::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #003FB5, #0066FF, #1E88FF);
}
.so-bundle-featured:hover {
  transform: translateY(-10px);
}
.so-bundle-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  background: #FFD60A;
  color: #0F1B2D;
  border-radius: 100px;
  padding: 6px 14px;
  margin-bottom: 16px;
}
.so-bundle-tag {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #5A6A7E;
  margin-bottom: 12px;
}
.so-bundle-price {
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin-bottom: 6px;
  line-height: 1;
}
.so-bundle-curr {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: #0F1B2D;
}
.so-bundle-amt {
  font-family: 'Montserrat', sans-serif;
  font-size: 48px;
  font-weight: 900;
  color: #0F1B2D;
}
.so-bundle-featured .so-bundle-curr,
.so-bundle-featured .so-bundle-amt {
  color: #0066FF;
}
.so-bundle-was {
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: #5A6A7E;
  margin-bottom: 8px;
}
.so-bundle-was strong {
  color: #0066FF;
  font-weight: 700;
}
.so-bundle-was s {
  opacity: 0.55;
}
.so-bundle-sub {
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: #5A6A7E;
  margin-bottom: 28px;
}
.so-bundle-list {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
}
.so-bundle-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #5A6A7E;
  padding: 10px 0;
  border-bottom: 1px solid #E5EAF2;
}
.so-bundle-list li:first-child {
  padding-top: 0;
}
.so-bundle-list li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.so-bundle-list li i {
  color: #0066FF;
  font-size: 11px;
  margin-top: 3px;
  flex-shrink: 0;
}
/* Study Online responsive */
@media (max-width: 1060px) {
  .so-adv-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .so-bundle-grid {
    gap: 18px;
    padding: 0;
  }
}
@media (max-width: 900px) {
  .so-req-bar {
    flex-direction: column;
  }
  .so-req-item {
    border-right: none;
    border-bottom: 1px solid #E5EAF2;
  }
  .so-req-item:last-child {
    border-bottom: none;
  }
  .so-bundle-grid {
    grid-template-columns: 1fr;
    max-width: 480px;
  }
}
@media (max-width: 680px) {
  .so-adv-grid {
    grid-template-columns: 1fr;
  }
  .so-adv-card {
    padding: 26px 22px;
  }
  .so-bundle-card {
    padding: 32px 28px;
  }
}
@media (max-width: 480px) {
  .so-bundle-card {
    padding: 26px 20px;
    border-radius: 24px;
  }
  .so-bundle-amt {
    font-size: 40px;
  }
  .so-bundle-list li {
    font-size: 13px;
  }
  .so-adv-card {
    padding: 22px 18px;
  }
  .so-adv-top {
    margin-bottom: 16px;
  }
  .so-adv-num {
    font-size: 30px;
  }
  .so-adv-ico {
    width: 40px;
    height: 40px;
    font-size: 14px;
    border-radius: 12px;
  }
  .so-adv-title {
    font-size: 14px;
  }
  .so-adv-body {
    font-size: 13px;
  }
  .so-req-item {
    padding: 12px 16px;
    font-size: 11.5px;
  }
}
@media (max-width: 380px) {
  .so-adv-card {
    padding: 18px 16px;
  }
  .so-bundle-card {
    padding: 20px 16px;
  }
  .so-bundle-amt {
    font-size: 34px;
  }
}
/* ── Corporate Training ──────────────────────────────────────────────────── */
.corp-hero {
  min-height: 640px;
}
/* Gallery */
.corp-gallery-sec {
  background: #F4F8FF;
}
.corp-gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 54px;
}
.corp-gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  aspect-ratio: 4/3;
  cursor: pointer;
}
.corp-gallery-item:hover .corp-gallery-img {
  transform: scale(1.07);
}
.corp-gallery-item:hover .corp-gallery-ov {
  opacity: 1;
}
.corp-gallery-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.corp-gallery-ov {
  position: absolute;
  inset: 0;
  background: rgba(0, 8, 32, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s;
}
.corp-gallery-ov i {
  color: #fff;
  font-size: 22px;
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.5));
}
/* Lightbox */
.corp-lb {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0, 0, 0, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
}
.corp-lb-open {
  opacity: 1;
  pointer-events: all;
}
.corp-lb-content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 90vw;
}
.corp-lb-img {
  max-width: 90vw;
  max-height: 82vh;
  object-fit: contain;
  border-radius: 12px;
  box-shadow: 0 32px 80px rgba(0, 0, 0, 0.6);
  display: block;
}
.corp-lb-counter {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
  color: rgba(255, 255, 255, 0.5);
  margin-top: 16px;
}
.corp-lb-close {
  position: absolute;
  top: 24px;
  right: 24px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #fff;
  font-size: 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}
.corp-lb-close:hover {
  background: rgba(255, 255, 255, 0.28);
}
.corp-lb-prev,
.corp-lb-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #fff;
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}
.corp-lb-prev:hover,
.corp-lb-next:hover {
  background: rgba(255, 255, 255, 0.28);
}
.corp-lb-prev {
  left: 24px;
}
.corp-lb-next {
  right: 24px;
}
/* Value proposition */
.corp-value-sec {
  background: #FFFFFF;
}
.corp-value-inner {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 80px;
  align-items: center;
}
.corp-value-text .sec-label {
  margin-bottom: 14px;
}
.corp-value-text .sec-title {
  margin-bottom: 24px;
}
.corp-value-desc {
  font-family: 'Lato', sans-serif;
  font-size: 15px;
  color: #5A6A7E;
  line-height: 1.75;
  margin-bottom: 18px;
}
.corp-value-desc:last-of-type {
  margin-bottom: 32px;
}
.corp-value-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.corp-vstat {
  background: #E8F1FF;
  border: 1.5px solid rgba(0, 102, 255, 0.12);
  border-radius: 24px;
  padding: 26px 20px;
  text-align: center;
}
.corp-vstat p {
  font-family: 'Lato', sans-serif;
  font-size: 12px;
  color: #5A6A7E;
  margin-top: 10px;
  line-height: 1.5;
}
.corp-vstat-num {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 2px;
}
.corp-vstat-num .stat-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 34px;
  font-weight: 900;
  color: #0066FF;
  line-height: 1;
}
.corp-vstat-plus {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 900;
  color: #0066FF;
}
/* Why work with us */
.corp-why-sec {
  background: #F4F8FF;
}
.corp-why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 54px;
}
.corp-why-card {
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 36px 30px;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  position: relative;
  overflow: hidden;
}
.corp-why-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #003FB5, #0066FF, #1E88FF);
  opacity: 0;
  transition: opacity 0.3s;
}
.corp-why-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 70px rgba(0, 102, 255, 0.22);
  border-color: #1E88FF;
}
.corp-why-card:hover::before {
  opacity: 1;
}
.corp-why-card:hover .corp-why-ico {
  background: #0066FF;
  color: #fff;
}
.corp-why-ico {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: #E8F1FF;
  color: #0066FF;
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s;
  margin-bottom: 22px;
}
.corp-why-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 14px;
  line-height: 1.4;
}
.corp-why-body {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.7;
}
/* Enquiry form */
.corp-form-sec {
  background: #FFFFFF;
}
.corp-form-inner {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 80px;
  align-items: start;
}
.corp-form-info .sec-label {
  margin-bottom: 14px;
}
.corp-form-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 26px;
  font-weight: 900;
  color: #0F1B2D;
  line-height: 1.3;
  margin-bottom: 16px;
}
.corp-form-title em {
  color: #0066FF;
  font-style: normal;
}
.corp-form-desc {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.7;
  margin-bottom: 32px;
}
.corp-contact-list {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.corp-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}
.corp-contact-item strong {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #0F1B2D;
  margin-bottom: 4px;
}
.corp-contact-item a,
.corp-contact-item span {
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #5A6A7E;
  text-decoration: none;
}
.corp-contact-item a:hover,
.corp-contact-item span:hover {
  color: #0066FF;
}
.corp-contact-ico {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  flex-shrink: 0;
  background: #E8F1FF;
  color: #0066FF;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.corp-form-box {
  background: #F4F8FF;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 40px;
}
.corp-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.corp-field-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.corp-field {
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.corp-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  font-weight: 700;
  color: #0F1B2D;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}
.corp-req {
  color: #FF7A59;
}
.corp-input,
.corp-textarea {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #0F1B2D;
  border: 1.5px solid #E5EAF2;
  border-radius: 12px;
  padding: 13px 16px;
  background: #fff;
  width: 100%;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.corp-input::placeholder,
.corp-textarea::placeholder {
  color: #8f9daf;
}
.corp-input:focus,
.corp-textarea:focus {
  border-color: #0066FF;
  box-shadow: 0 0 0 3px #E8F1FF;
}
.corp-textarea {
  resize: vertical;
  min-height: 130px;
}
.corp-submit {
  width: 100%;
  justify-content: center;
  margin-top: 4px;
}
/* Corporate Training responsive */
@media (max-width: 1060px) {
  .corp-value-inner {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .corp-value-stats {
    max-width: 420px;
  }
  .corp-form-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .corp-form-box {
    padding: 32px 28px;
  }
}
@media (max-width: 900px) {
  .corp-gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  .corp-why-grid {
    grid-template-columns: 1fr 1fr;
  }
  .corp-why-grid .corp-why-card:last-child {
    grid-column: 1 / -1;
    max-width: calc(50% - 12px);
  }
}
@media (max-width: 680px) {
  .corp-why-grid {
    grid-template-columns: 1fr;
  }
  .corp-why-grid .corp-why-card:last-child {
    max-width: 100%;
    grid-column: auto;
  }
  .corp-why-card {
    padding: 28px 24px;
  }
  .corp-field-row {
    grid-template-columns: 1fr;
  }
  .corp-form-box {
    padding: 26px 20px;
  }
  .corp-lb-prev {
    left: 10px;
  }
  .corp-lb-next {
    right: 10px;
  }
  .corp-lb-prev,
  .corp-lb-next {
    width: 40px;
    height: 40px;
    font-size: 14px;
  }
}
@media (max-width: 480px) {
  .corp-gallery-grid {
    gap: 6px;
    border-radius: 24px;
  }
  .corp-value-stats {
    max-width: 100%;
  }
  .corp-vstat {
    padding: 20px 16px;
  }
  .corp-vstat-num .stat-num {
    font-size: 28px;
  }
  .corp-vstat-plus {
    font-size: 18px;
  }
  .corp-vstat p {
    font-size: 11.5px;
  }
  .corp-why-card {
    padding: 24px 20px;
    border-radius: 24px;
  }
  .corp-why-ico {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    font-size: 17px;
    margin-bottom: 18px;
  }
  .corp-why-title {
    font-size: 14.5px;
  }
  .corp-why-body {
    font-size: 13.5px;
  }
  .corp-form-title {
    font-size: 22px;
  }
  .corp-form-desc {
    font-size: 13.5px;
  }
  .corp-input,
  .corp-textarea {
    font-size: 16px;
  }
  .corp-form-box {
    padding: 22px 16px;
    border-radius: 24px;
  }
  .corp-lb-close {
    top: 12px;
    right: 12px;
    width: 38px;
    height: 38px;
  }
  .corp-lb-img {
    border-radius: 8px;
  }
}
@media (max-width: 380px) {
  .corp-vstat {
    padding: 18px 12px;
  }
  .corp-vstat-num .stat-num {
    font-size: 26px;
  }
  .corp-why-card {
    padding: 20px 16px;
  }
  .corp-why-title {
    font-size: 14px;
  }
  .corp-form-title {
    font-size: 20px;
  }
  .corp-form-box {
    padding: 18px 14px;
  }
}
/* ── Class Schedule ──────────────────────────────────────────────────────── */
.cs-hero {
  min-height: 640px;
}
/* Section */
.cs-sec {
  background: #F4F8FF;
}
/* Top header + legend row */
.cs-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 40px;
  margin-bottom: 54px;
  flex-wrap: wrap;
}
.cs-top-left {
  flex: 1;
}
.cs-legend {
  flex-shrink: 0;
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.cs-legend-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: #5A6A7E;
}
.cs-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  flex-shrink: 0;
}
.cs-dot--start {
  background: #0066FF;
  box-shadow: 0 0 0 2px rgba(0, 102, 255, 0.25);
}
.cs-dot--end {
  background: #FF7A59;
  box-shadow: 0 0 0 2px rgba(255, 122, 89, 0.25);
}
.cs-dot--pub {
  background: rgba(255, 122, 89, 0.15);
  border: 2px solid #FF7A59;
}
.cs-dot--school {
  background: #0F1B2D;
}
/* 12-month grid */
.cs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
/* Month card */
.cs-month {
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  padding: 20px;
  transition: box-shadow 0.25s;
}
.cs-month:hover {
  box-shadow: 0 8px 40px rgba(0, 102, 255, 0.14);
}
.cs-month-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 900;
  color: #0066FF;
  letter-spacing: 0.5px;
  margin-bottom: 12px;
  line-height: 1;
}
.cs-month-name span {
  color: #5A6A7E;
  font-size: 10px;
  font-weight: 600;
  margin-left: 4px;
  opacity: 0.7;
}
/* Day grid: 7 equal columns */
.cs-dg {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
}
.cs-dh {
  font-family: 'Montserrat', sans-serif;
  font-size: 9.5px;
  font-weight: 700;
  color: #5A6A7E;
  text-align: center;
  padding: 5px 0 4px;
}
.cs-dh--we {
  color: #8f9daf;
}
/* Day cells */
.cs-day {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Lato', sans-serif;
  font-size: 11px;
  color: #0F1B2D;
  border-radius: 50%;
}
.cs-day--we {
  color: #71839a;
  opacity: 0.5;
}
.cs-day--active {
  background: #E8F1FF;
  color: #0066FF;
  border-radius: 4px;
}
.cs-day--pub {
  background: rgba(255, 122, 89, 0.1);
  color: #FF7A59;
  border: 1.5px solid rgba(255, 122, 89, 0.3);
  border-radius: 50%;
  font-size: 10px;
  font-weight: 700;
}
.cs-day--school {
  background: rgba(15, 27, 45, 0.8);
  color: rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  font-size: 10px;
  font-weight: 700;
}
.cs-day--start {
  background: #0066FF;
  color: #fff;
  border-radius: 50%;
  font-weight: 800;
  font-size: 11px;
  box-shadow: 0 2px 8px rgba(0, 102, 255, 0.4);
}
.cs-day--end {
  background: #FF7A59;
  color: #fff;
  border-radius: 50%;
  font-weight: 800;
  font-size: 11px;
  box-shadow: 0 2px 8px rgba(255, 122, 89, 0.4);
}
.cs-day--today {
  outline: 2px solid #FFD60A;
  outline-offset: 1px;
  font-weight: 700;
}
/* Month notes */
.cs-notes {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid #E5EAF2;
}
.cs-note {
  font-family: 'Lato', sans-serif;
  font-size: 10.5px;
  color: #5A6A7E;
  line-height: 1.55;
  margin-bottom: 3px;
}
.cs-note:last-child {
  margin: 0;
}
.cs-note::before {
  content: '·';
  color: #FF7A59;
  margin-right: 5px;
  font-weight: 900;
}
/* Upcoming batches */
.cs-next-sec {
  background: #FFFFFF;
}
.cs-next-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 54px;
}
.cs-next-card {
  background: #F4F8FF;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.cs-next-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 40px rgba(0, 102, 255, 0.14);
}
.cs-next-card .btn {
  width: 100%;
  justify-content: center;
  margin-top: 4px;
}
.cs-next-current {
  background: #fff;
  border-color: #0066FF;
  box-shadow: 0 4px 24px rgba(0, 102, 255, 0.12);
}
.cs-next-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  border-radius: 100px;
  padding: 5px 12px;
  align-self: flex-start;
}
.cs-badge-current {
  background: rgba(0, 196, 180, 0.15);
  color: #00C4B4;
}
.cs-badge-upcoming {
  background: #E8F1FF;
  color: #0066FF;
}
.cs-badge-current i {
  color: #00C4B4;
  font-size: 7px;
  animation: cs-pulse 1.5s infinite;
}
@keyframes cs-pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.4;
  }
}
.cs-next-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #5A6A7E;
}
.cs-next-dates {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cs-next-start,
.cs-next-end {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: #0F1B2D;
  display: flex;
  align-items: center;
  gap: 7px;
}
.cs-next-start i,
.cs-next-end i {
  font-size: 11px;
}
.cs-next-start i {
  color: #0066FF;
}
.cs-next-end i {
  color: #FF7A59;
}
.cs-next-arrow {
  display: none;
}
.cs-next-meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cs-next-meta span {
  font-family: 'Lato', sans-serif;
  font-size: 11.5px;
  color: #5A6A7E;
  display: flex;
  align-items: center;
  gap: 7px;
}
.cs-next-meta span i {
  color: #0066FF;
  font-size: 10px;
}
/* Class Schedule responsive */
@media (max-width: 1200px) {
  .cs-next-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 1060px) {
  .cs-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
  .cs-top {
    flex-direction: column;
    gap: 24px;
    margin-bottom: 36px;
  }
  .cs-legend {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 12px 24px;
  }
  .cs-night-sec {
    padding: 72px 0;
  }
}
@media (max-width: 900px) {
  .cs-next-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
  .cs-legend-item {
    font-size: 11px;
  }
}
@media (max-width: 680px) {
  .cs-grid {
    grid-template-columns: 1fr;
    max-width: 380px;
    margin-left: auto;
    margin-right: auto;
  }
  .cs-next-grid {
    grid-template-columns: 1fr;
  }
  .cs-next-card {
    padding: 24px 20px;
  }
  .cs-day {
    font-size: 12px;
  }
  .cs-month-name {
    font-size: 12px;
  }
  .cs-note {
    font-size: 10px;
  }
  .cs-legend {
    padding: 14px 18px;
    gap: 10px 20px;
  }
  .cs-next-num {
    font-size: 10px;
  }
  .cs-next-start,
  .cs-next-end {
    font-size: 12px;
  }
  .cs-next-meta span {
    font-size: 11px;
  }
}
@media (max-width: 480px) {
  .cs-month {
    padding: 16px 12px;
  }
  .cs-day {
    font-size: 11px;
  }
  .cs-next-card {
    padding: 20px 16px;
    border-radius: 24px;
  }
  .cs-legend {
    padding: 12px 14px;
    gap: 8px 16px;
  }
  .cs-legend-item {
    font-size: 10.5px;
    gap: 8px;
  }
  .cs-dot {
    width: 12px;
    height: 12px;
  }
  .cs-month-name {
    font-size: 11px;
  }
  .cs-dh {
    font-size: 8.5px;
  }
  .cs-next-badge {
    font-size: 8px;
    padding: 4px 10px;
  }
  .cs-next-num {
    font-size: 9.5px;
  }
  .cs-next-start,
  .cs-next-end {
    font-size: 11.5px;
  }
  .cs-next-meta span {
    font-size: 10.5px;
  }
  .cs-night-sec {
    padding: 56px 0;
  }
}
@media (max-width: 380px) {
  .cs-month {
    padding: 14px 10px;
  }
  .cs-dh {
    font-size: 8px;
  }
  .cs-next-card {
    padding: 18px 14px;
  }
  .cs-night-sec {
    padding: 48px 0;
  }
}
/* ── Chinese Schedule — Evening section ─────────────────────────────────── */
.cs-night-sec {
  background: linear-gradient(160deg, #001F66 0%, #001A55 100%);
  padding: 100px 0;
}
.cs-night-sec .cs-top-left h2,
.cs-night-sec .cs-top-left p {
  color: rgba(255, 255, 255, 0.9);
}
.cs-night-sec .cs-legend-item {
  color: rgba(255, 255, 255, 0.75);
}
.cs-night-sec .cs-next-card--eve {
  background: rgba(255, 255, 255, 0.07);
  border: 1.5px solid rgba(255, 255, 255, 0.12);
}
.cs-night-sec .cs-next-card--eve .cs-next-num,
.cs-night-sec .cs-next-card--eve .cs-next-start,
.cs-night-sec .cs-next-card--eve .cs-next-end {
  color: #fff;
}
.cs-night-sec .cs-next-card--eve .cs-next-meta span {
  color: rgba(255, 255, 255, 0.65);
}
.cs-night-sec .cs-next-card--eve.cs-next-current {
  background: rgba(255, 255, 255, 0.12);
  border-color: #FFD60A;
  box-shadow: 0 4px 24px rgba(255, 214, 10, 0.2);
}
.cs-dot-eve {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
}
.cs-dot-eve--a {
  background: #00C4B4;
}
.cs-dot-eve--b {
  background: #FFD60A;
}
.cs-eve-days {
  display: block;
  font-size: 10px;
  font-weight: 600;
  color: #FFD60A;
  letter-spacing: 0.3px;
  margin-top: 3px;
}
/* Evening full batch listing */
.cs-eve-full {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 48px;
}
.cs-eve-group {
  background: rgba(255, 255, 255, 0.06);
  border: 1.5px solid rgba(255, 255, 255, 0.1);
  border-radius: 32px;
  overflow: hidden;
}
.cs-eve-group-hdr {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 24px;
  background: rgba(255, 255, 255, 0.08);
  border-bottom: 1.5px solid rgba(255, 255, 255, 0.1);
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: #FFD60A;
}
.cs-eve-group-hdr i {
  font-size: 11px;
}
.cs-eve-rows {
  display: flex;
  flex-direction: column;
}
.cs-eve-row {
  display: grid;
  grid-template-columns: 70px 1fr auto auto;
  align-items: center;
  gap: 12px;
  padding: 14px 24px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  transition: background 0.2s;
}
.cs-eve-row:last-child {
  border-bottom: none;
}
.cs-eve-row:hover {
  background: rgba(255, 255, 255, 0.04);
}
.cs-eve-past {
  opacity: 0.4;
}
.cs-eve-current {
  background: rgba(255, 214, 10, 0.06);
}
.cs-eve-batch {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.45);
}
.cs-eve-range {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
}
.cs-eve-range i {
  font-size: 10px;
  color: rgba(255, 255, 255, 0.35);
}
.cs-eve-range .fa-play-circle {
  color: #00C4B4;
}
.cs-eve-range .fa-stop-circle {
  color: #FF7A59;
}
.cs-eve-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 4px 9px;
  border-radius: 20px;
}
.cs-eve-done {
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.4);
}
.cs-eve-now {
  background: rgba(255, 214, 10, 0.18);
  color: #FFD60A;
}
.cs-eve-now i {
  font-size: 7px;
  animation: cs-pulse 1.5s infinite;
}
.cs-eve-open {
  background: rgba(0, 102, 255, 0.3);
  color: #80b3ff;
}
.cs-eve-enrol {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  color: #FFD60A;
  white-space: nowrap;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: opacity 0.2s;
}
.cs-eve-enrol:hover {
  opacity: 0.7;
}
.cs-eve-enrol i {
  font-size: 10px;
}
.cs-eve-enrol-hidden {
  visibility: hidden;
  pointer-events: none;
}
@media (max-width: 1060px) {
  .cs-eve-full {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 680px) {
  .cs-eve-row {
    grid-template-columns: 1fr auto;
    gap: 10px 12px;
  }
  .cs-eve-row .cs-eve-batch {
    display: none;
  }
  .cs-eve-row .cs-eve-enrol {
    grid-column: 1/3;
  }
  .cs-eve-group-hdr {
    padding: 14px 20px;
  }
  .cs-eve-row {
    padding: 12px 20px;
  }
  .cs-eve-range {
    font-size: 11.5px;
    gap: 5px;
  }
}
@media (max-width: 480px) {
  .cs-eve-group-hdr {
    padding: 12px 16px;
    font-size: 10px;
    gap: 8px;
  }
  .cs-eve-row {
    padding: 12px 16px;
  }
  .cs-eve-range {
    font-size: 11px;
  }
  .cs-eve-enrol {
    font-size: 10.5px;
  }
}
@media (max-width: 380px) {
  .cs-eve-group-hdr {
    padding: 10px 14px;
    font-size: 9.5px;
  }
  .cs-eve-row {
    padding: 10px 14px;
    gap: 8px 10px;
  }
  .cs-eve-range {
    font-size: 10.5px;
  }
}
/* ── Study in China ──────────────────────────────────────────────────────── */
.sic-why-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 56px;
}
.sic-why-card {
  background: #FFFFFF;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 32px 24px;
  transition: box-shadow 0.25s, transform 0.25s;
}
.sic-why-card:hover {
  box-shadow: 0 12px 36px rgba(0, 102, 255, 0.1);
  transform: translateY(-4px);
}
.sic-why-ico {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: linear-gradient(135deg, #0066FF 0%, #001F66 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
.sic-why-ico i {
  color: #FFFFFF;
  font-size: 20px;
}
.sic-why-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: #0F1B2D;
  margin: 0 0 10px;
}
.sic-why-body {
  font-size: 13.5px;
  line-height: 1.65;
  color: #5a6a7e;
  margin: 0;
}
.sic-steps-sec {
  background: linear-gradient(160deg, #001F66 0%, #001A55 100%);
  padding: 100px 0;
}
.sic-steps-sec .sec-label {
  color: #FFD60A;
}
.sic-steps-sec .sec-title {
  color: #FFFFFF;
}
.sic-steps-sec .sec-title em {
  color: #FFD60A;
  font-style: normal;
}
.sic-steps-sec .sec-sub {
  color: rgba(255, 255, 255, 0.7);
}
.sic-steps-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 56px;
}
.sic-step {
  background: rgba(255, 255, 255, 0.07);
  border: 1.5px solid rgba(255, 255, 255, 0.12);
  border-radius: 32px;
  padding: 40px 32px;
  text-align: center;
}
.sic-step-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 56px;
  font-weight: 900;
  color: rgba(255, 214, 10, 0.18);
  line-height: 1;
  margin-bottom: 12px;
}
.sic-step-ico {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: #FFD60A;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
}
.sic-step-ico i {
  color: #0F1B2D;
  font-size: 22px;
}
.sic-step-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  font-weight: 700;
  color: #FFFFFF;
  margin: 0 0 12px;
}
.sic-step-body {
  font-size: 14px;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.72);
  margin: 0;
}
@media (max-width: 1060px) {
  .sic-why-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .sic-steps-grid {
    grid-template-columns: 1fr;
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (max-width: 680px) {
  .sic-why-grid {
    grid-template-columns: 1fr;
  }
  .sic-why-card {
    padding: 24px 20px;
  }
  .sic-why-ico {
    width: 44px;
    height: 44px;
    margin-bottom: 16px;
  }
  .sic-steps-sec {
    padding: 72px 0;
  }
  .sic-step {
    padding: 32px 24px;
  }
  .sic-step-num {
    font-size: 40px;
  }
  .sic-step-ico {
    width: 50px;
    height: 50px;
  }
  .sic-step-ico i {
    font-size: 18px;
  }
}
@media (max-width: 480px) {
  .sic-why-card {
    padding: 20px 18px;
  }
  .sic-why-ico {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    margin-bottom: 12px;
  }
  .sic-why-ico i {
    font-size: 17px;
  }
  .sic-why-title {
    font-size: 14px;
  }
  .sic-why-body {
    font-size: 13px;
  }
  .sic-steps-sec {
    padding: 60px 0;
  }
  .sic-step {
    padding: 26px 20px;
  }
  .sic-step-num {
    font-size: 36px;
  }
  .sic-step-ico {
    width: 44px;
    height: 44px;
  }
  .sic-step-ico i {
    font-size: 17px;
  }
  .sic-step-title {
    font-size: 15px;
  }
  .sic-step-body {
    font-size: 13.5px;
  }
}
@media (max-width: 380px) {
  .sic-why-card {
    padding: 16px 14px;
  }
  .sic-why-title {
    font-size: 13.5px;
  }
  .sic-steps-sec {
    padding: 52px 0;
  }
  .sic-step {
    padding: 20px 16px;
  }
  .sic-step-num {
    font-size: 30px;
  }
}
/* ── China Scholarship ────────────────────────────────────────────────────── */
/* Scholarship type cards */
.sch-types-sec {
  background: #F4F8FF;
}
.sch-types-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 56px;
}
.sch-type-card {
  background: #FFFFFF;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  overflow: hidden;
}
.sch-type-featured {
  border-color: #0066FF;
  box-shadow: 0 8px 32px rgba(0, 102, 255, 0.12);
}
.sch-type-top {
  padding: 12px 24px;
  background: #F4F8FF;
  border-bottom: 1px solid #E5EAF2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.sch-type-featured .sch-type-top {
  background: linear-gradient(135deg, #0066FF 0%, #001F66 100%);
  border-color: transparent;
}
.sch-type-tag {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  color: #0066FF;
  letter-spacing: 0.4px;
  text-transform: uppercase;
}
.sch-type-featured .sch-type-tag {
  color: rgba(255, 255, 255, 0.85);
}
.sch-type-badge {
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 700;
  color: #0F1B2D;
  background: #FFD60A;
  border-radius: 20px;
  padding: 3px 10px;
  white-space: nowrap;
}
.sch-type-body-wrap {
  padding: 28px 24px;
}
.sch-type-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 0 0 8px;
}
.sch-type-desc {
  font-size: 13.5px;
  line-height: 1.65;
  color: #5a6a7e;
  margin: 0 0 20px;
}
.sch-type-list {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
}
.sch-type-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13.5px;
  color: #0F1B2D;
  padding: 8px 0;
  border-bottom: 1px solid #E5EAF2;
  line-height: 1.5;
}
.sch-type-list li:last-child {
  border-bottom: none;
}
.sch-type-list i {
  color: #0066FF;
  flex-shrink: 0;
  margin-top: 3px;
}
.sch-sub-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 700;
  color: #0F1B2D;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.sch-sub-row {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 7px 0;
  font-size: 13px;
  color: #5a6a7e;
  border-bottom: 1px solid #E5EAF2;
  line-height: 1.5;
}
.sch-sub-row:last-child {
  border-bottom: none;
}
.sch-sub-tag {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 700;
  color: #FFFFFF;
  background: #00C4B4;
  border-radius: 4px;
  padding: 2px 7px;
  flex-shrink: 0;
  margin-top: 2px;
}
/* Who can apply */
.sch-who-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
}
.sch-who-card {
  background: #FFFFFF;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 28px 24px;
}
.sch-who-ico {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: linear-gradient(135deg, #0066FF 0%, #001F66 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}
.sch-who-ico i {
  color: #FFFFFF;
  font-size: 18px;
}
.sch-who-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #0F1B2D;
  margin: 0 0 14px;
}
.sch-who-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.sch-who-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  color: #5a6a7e;
  padding: 6px 0;
  border-bottom: 1px solid #E5EAF2;
  line-height: 1.5;
}
.sch-who-list li:last-child {
  border-bottom: none;
}
.sch-who-list i {
  color: #00C4B4;
  flex-shrink: 0;
  margin-top: 3px;
  font-size: 11px;
}
.sch-who-note {
  font-size: 13px;
  line-height: 1.7;
  color: #5a6a7e;
  margin: 0;
}
/* Required documents */
.sch-docs-sec {
  background: #F4F8FF;
}
.sch-docs-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 48px;
}
.sch-doc-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: #FFFFFF;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  padding: 16px 18px;
}
.sch-doc-ico {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: linear-gradient(135deg, #0066FF 0%, #001F66 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.sch-doc-ico i {
  color: #FFFFFF;
  font-size: 14px;
}
.sch-doc-body {
  flex: 1;
  min-width: 0;
}
.sch-doc-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: #0F1B2D;
  margin: 0 0 3px;
}
.sch-doc-note {
  font-size: 12px;
  color: #7a8a9e;
  margin: 0;
  line-height: 1.5;
}
/* How Duke Helps */
.sch-help-sec {
  background: linear-gradient(160deg, #001F66 0%, #001A55 100%);
  padding: 100px 0;
}
.sch-help-sec .sec-label {
  color: #FFD60A;
}
.sch-help-sec .sec-title {
  color: #FFFFFF;
}
.sch-help-sec .sec-title em {
  color: #FFD60A;
  font-style: normal;
}
.sch-help-sec .sec-sub {
  color: rgba(255, 255, 255, 0.7);
}
.sch-help-inner {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
  margin-top: 56px;
}
.sch-help-list {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
}
.sch-help-list li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  font-size: 15px;
  color: rgba(255, 255, 255, 0.88);
  line-height: 1.55;
}
.sch-help-list li:last-child {
  border-bottom: none;
}
.sch-help-list i {
  color: #FFD60A;
  flex-shrink: 0;
  margin-top: 4px;
}
.sch-help-close {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: #FFD60A;
  font-style: italic;
  margin: 0;
}
.sch-help-panel {
  background: rgba(255, 255, 255, 0.07);
  border: 1.5px solid rgba(255, 255, 255, 0.12);
  border-radius: 32px;
  padding: 36px 32px;
}
.sch-help-panel-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  color: #FFD60A;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 24px;
}
.sch-help-cov-item {
  padding: 18px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.sch-help-cov-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.sch-help-cov-lbl {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: 4px;
}
.sch-help-cov-val {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #FFFFFF;
}
.sch-help-cov-val em {
  color: #FFD60A;
  font-style: normal;
}
/* Responsive */
@media (max-width: 1060px) {
  .sch-types-grid {
    grid-template-columns: 1fr 1fr;
  }
  .sch-types-grid .sch-type-featured {
    grid-column: 1/3;
  }
  .sch-help-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .sch-help-panel {
    max-width: 480px;
  }
}
@media (max-width: 768px) {
  .sch-who-grid {
    grid-template-columns: 1fr;
  }
  .sch-docs-grid {
    grid-template-columns: 1fr;
  }
  .sch-type-top {
    flex-wrap: wrap;
    gap: 8px;
  }
  .sch-help-sec {
    padding: 72px 0;
  }
  .sch-help-list li {
    font-size: 14px;
    gap: 12px;
  }
  .sch-help-panel {
    padding: 28px 24px;
  }
}
@media (max-width: 680px) {
  .sch-types-grid {
    grid-template-columns: 1fr;
  }
  .sch-types-grid .sch-type-featured {
    grid-column: auto;
  }
  .sch-type-body-wrap {
    padding: 22px 20px;
  }
  .sch-doc-item {
    padding: 14px 16px;
    gap: 12px;
  }
  .sch-who-card {
    padding: 22px 20px;
  }
  .sch-help-list li {
    font-size: 13.5px;
  }
}
@media (max-width: 480px) {
  .sch-type-top {
    padding: 10px 16px;
  }
  .sch-type-badge {
    font-size: 8.5px;
    padding: 2px 8px;
  }
  .sch-type-body-wrap {
    padding: 18px 16px;
  }
  .sch-type-title {
    font-size: 16px;
  }
  .sch-type-desc {
    font-size: 13px;
  }
  .sch-type-list li {
    font-size: 13px;
  }
  .sch-who-card {
    padding: 20px 18px;
  }
  .sch-who-ico {
    width: 42px;
    height: 42px;
    border-radius: 11px;
  }
  .sch-who-ico i {
    font-size: 16px;
  }
  .sch-who-title {
    font-size: 13.5px;
  }
  .sch-who-list li {
    font-size: 12.5px;
  }
  .sch-who-note {
    font-size: 12.5px;
  }
  .sch-doc-item {
    padding: 12px 14px;
    gap: 10px;
  }
  .sch-doc-ico {
    width: 32px;
    height: 32px;
    border-radius: 9px;
  }
  .sch-doc-ico i {
    font-size: 13px;
  }
  .sch-doc-name {
    font-size: 12.5px;
  }
  .sch-doc-note {
    font-size: 11.5px;
  }
  .sch-help-sec {
    padding: 56px 0;
  }
  .sch-help-list li {
    font-size: 13.5px;
    gap: 10px;
    padding: 12px 0;
  }
  .sch-help-close {
    font-size: 14px;
  }
  .sch-help-panel {
    padding: 22px 18px;
  }
  .sch-help-panel-title {
    font-size: 10.5px;
    margin-bottom: 18px;
  }
  .sch-help-cov-item {
    padding: 14px 0;
  }
  .sch-help-cov-val {
    font-size: 15px;
  }
}
@media (max-width: 380px) {
  .sch-type-body-wrap {
    padding: 16px 14px;
  }
  .sch-who-card {
    padding: 18px 14px;
  }
  .sch-doc-item {
    padding: 10px 12px;
  }
  .sch-help-sec {
    padding: 48px 0;
  }
  .sch-help-panel {
    padding: 18px 14px;
  }
  .sch-help-cov-val {
    font-size: 14px;
  }
}
/* ── Chinese Study Tour ──────────────────────────────────────────────────── */
/* Intro 2-col */
.st-intro-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 64px;
  align-items: center;
}
.st-intro-eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  color: #0066FF;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 16px;
}
.st-intro-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 34px;
  font-weight: 900;
  color: #0F1B2D;
  line-height: 1.2;
  margin: 0 0 20px;
}
.st-intro-title em {
  color: #0066FF;
  font-style: normal;
}
.st-intro-body {
  font-size: 15px;
  line-height: 1.75;
  color: #5a6a7e;
  margin: 0 0 24px;
}
.st-intro-accent {
  background: #F4F8FF;
  border-left: 4px solid #0066FF;
  border-radius: 0 24px 24px 0;
  padding: 16px 20px;
  font-size: 14px;
  color: #0F1B2D;
  line-height: 1.65;
  margin: 0;
}
.st-intro-accent strong {
  color: #0066FF;
}
.st-intro-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.st-intro-card {
  background: #FFFFFF;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 20px 22px;
  display: flex;
  align-items: center;
  gap: 16px;
  transition: box-shadow 0.2s;
}
.st-intro-card:hover {
  box-shadow: 0 8px 28px rgba(0, 102, 255, 0.1);
}
.st-intro-card-ico {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, #0066FF 0%, #001F66 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.st-intro-card-ico i {
  color: #FFFFFF;
  font-size: 18px;
}
.st-intro-card-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #0F1B2D;
  margin: 0 0 2px;
}
.st-intro-card-sub {
  font-size: 12px;
  color: #7a8a9e;
  margin: 0;
}
/* Why grid */
.st-why-sec {
  background: #F4F8FF;
}
.st-why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 56px;
}
.st-why-card {
  background: #FFFFFF;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 32px 28px;
  transition: box-shadow 0.25s, transform 0.25s;
}
.st-why-card:hover {
  box-shadow: 0 12px 40px rgba(0, 102, 255, 0.1);
  transform: translateY(-4px);
}
.st-why-ico {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: linear-gradient(135deg, #0066FF 0%, #001F66 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
.st-why-ico i {
  color: #FFFFFF;
  font-size: 20px;
}
.st-why-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: #0F1B2D;
  margin: 0 0 10px;
}
.st-why-body {
  font-size: 13.5px;
  line-height: 1.65;
  color: #5a6a7e;
  margin: 0;
}
/* Who is this for — dark */
.st-who-sec {
  background: linear-gradient(160deg, #001F66 0%, #001A55 100%);
  padding: 100px 0;
}
.st-who-sec .sec-label {
  color: #FFD60A;
}
.st-who-sec .sec-title {
  color: #FFFFFF;
}
.st-who-sec .sec-title em {
  color: #FFD60A;
  font-style: normal;
}
.st-who-sec .sec-sub {
  color: rgba(255, 255, 255, 0.7);
}
.st-who-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
  margin-top: 56px;
}
.st-who-card {
  background: rgba(255, 255, 255, 0.07);
  border: 1.5px solid rgba(255, 255, 255, 0.12);
  border-radius: 32px;
  padding: 28px 16px;
  text-align: center;
}
.st-who-ico {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #FFD60A;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
}
.st-who-ico i {
  color: #0F1B2D;
  font-size: 17px;
}
.st-who-lbl {
  font-family: 'Montserrat', sans-serif;
  font-size: 12.5px;
  font-weight: 700;
  color: #FFFFFF;
  line-height: 1.45;
  margin: 0;
}
/* What's included */
.st-inc-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 56px;
}
.st-inc-item {
  text-align: center;
  padding: 36px 24px;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  background: #FFFFFF;
  position: relative;
  overflow: hidden;
}
.st-inc-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #0066FF, #00C4B4);
}
.st-inc-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 56px;
  font-weight: 900;
  color: #0066FF;
  opacity: 0.1;
  line-height: 1;
  margin-bottom: 4px;
}
.st-inc-ico {
  font-size: 28px;
  color: #0066FF;
  margin-bottom: 16px;
  display: block;
}
.st-inc-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #0F1B2D;
  margin: 0 0 10px;
}
.st-inc-body {
  font-size: 13px;
  line-height: 1.65;
  color: #5a6a7e;
  margin: 0;
}
.st-inc-close {
  text-align: center;
  margin-top: 40px;
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: #0066FF;
  font-style: italic;
}
/* City — full-width parallax-style image */
.st-city-sec {
  position: relative;
  min-height: 480px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.st-city-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
}
.st-city-ov {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0, 31, 102, 0.9) 0%, rgba(0, 20, 70, 0.78) 100%);
}
.st-city-in {
  position: relative;
  z-index: 2;
  text-align: center;
  max-width: 760px;
  padding: 80px 24px;
}
.st-city-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  color: #FFD60A;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  margin-bottom: 16px;
}
.st-city-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 38px;
  font-weight: 900;
  color: #FFFFFF;
  line-height: 1.2;
  margin: 0 0 20px;
}
.st-city-title em {
  color: #FFD60A;
  font-style: normal;
}
.st-city-sub {
  font-size: 16px;
  line-height: 1.75;
  color: rgba(255, 255, 255, 0.82);
  margin: 0 0 36px;
}
.st-city-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.st-city-chip {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  color: #FFFFFF;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.25);
  border-radius: 20px;
  padding: 7px 18px;
}
/* More than a holiday — 2-col with image */
.st-gain-grid {
  display: grid;
  grid-template-columns: 1fr 440px;
  gap: 64px;
  align-items: start;
  margin-top: 56px;
}
.st-gain-list {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
}
.st-gain-list li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid #E5EAF2;
  font-size: 15px;
  color: #0F1B2D;
  line-height: 1.55;
}
.st-gain-list li:last-child {
  border-bottom: none;
}
.st-gain-list i {
  color: #0066FF;
  flex-shrink: 0;
  margin-top: 4px;
}
.st-gain-close {
  font-size: 14px;
  line-height: 1.65;
  color: #7a8a9e;
  font-style: italic;
  margin: 0;
}
.st-gain-img-wrap {
  position: relative;
  border-radius: 32px;
  overflow: hidden;
  height: 460px;
}
.st-gain-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background-size: cover;
  background-position: center;
}
.st-gain-img-badge {
  position: absolute;
  bottom: 24px;
  left: 24px;
  right: 24px;
  background: #FFFFFF;
  border-radius: 24px;
  padding: 16px 20px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.14);
}
.st-gain-img-badge strong {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #0F1B2D;
  display: block;
  margin-bottom: 3px;
}
.st-gain-img-badge span {
  font-size: 12px;
  color: #7a8a9e;
}
/* Real experience — dark 2×2 grid */
.st-exp-sec {
  background: linear-gradient(160deg, #001F66 0%, #001A55 100%);
  padding: 100px 0;
}
.st-exp-sec .sec-label {
  color: #FFD60A;
}
.st-exp-sec .sec-title {
  color: #FFFFFF;
}
.st-exp-sec .sec-title em {
  color: #FFD60A;
  font-style: normal;
}
.st-exp-sec .sec-sub {
  color: rgba(255, 255, 255, 0.7);
}
.st-exp-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 56px;
}
.st-exp-item {
  background: rgba(255, 255, 255, 0.07);
  border: 1.5px solid rgba(255, 255, 255, 0.12);
  border-radius: 32px;
  padding: 28px 28px;
  display: flex;
  gap: 20px;
  align-items: flex-start;
}
.st-exp-item-ico {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #FFD60A;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.st-exp-item-ico i {
  color: #0F1B2D;
  font-size: 17px;
}
.st-exp-item-body strong {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: #FFFFFF;
  display: block;
  margin-bottom: 6px;
}
.st-exp-item-body p {
  font-size: 13.5px;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.72);
  margin: 0;
}
.st-exp-close {
  text-align: center;
  margin-top: 48px;
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  font-weight: 600;
  color: #FFD60A;
  font-style: italic;
}
/* Smart first step */
.st-smart-sec {
  background: #F4F8FF;
  padding: 100px 0;
  text-align: center;
}
.st-smart-in {
  max-width: 740px;
  margin: 0 auto;
  padding: 0 24px;
}
.st-smart-q-icon {
  font-size: 56px;
  color: #0066FF;
  opacity: 0.18;
  line-height: 1;
  margin-bottom: 20px;
}
.st-smart-quote {
  font-family: 'Montserrat', sans-serif;
  font-size: 24px;
  font-weight: 700;
  color: #0F1B2D;
  line-height: 1.5;
  margin: 0 0 28px;
}
.st-smart-quote em {
  color: #0066FF;
  font-style: normal;
}
/* Responsive */
@media (max-width: 1060px) {
  .st-intro-grid {
    grid-template-columns: 1fr;
  }
  .st-intro-cards {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .st-intro-card {
    flex: 1;
    min-width: 200px;
  }
  .st-why-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .st-who-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .st-inc-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .st-gain-grid {
    grid-template-columns: 1fr;
  }
  .st-gain-img-wrap {
    height: 300px;
  }
  .st-exp-grid {
    grid-template-columns: 1fr;
  }
  .st-city-bg {
    background-attachment: scroll;
  }
}
@media (max-width: 768px) {
  .st-who-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 680px) {
  .st-why-grid {
    grid-template-columns: 1fr;
  }
  .st-inc-grid {
    grid-template-columns: 1fr;
  }
  .st-city-title {
    font-size: 28px;
  }
  .st-intro-cards {
    display: none;
  }
  .st-why-card {
    padding: 26px 22px;
  }
  .st-who-sec {
    padding: 72px 0;
  }
  .st-exp-sec {
    padding: 72px 0;
  }
  .st-exp-item {
    padding: 24px 22px;
    gap: 16px;
  }
}
@media (max-width: 480px) {
  .st-who-grid {
    grid-template-columns: 1fr;
  }
  .st-who-sec {
    padding: 56px 0;
  }
  .st-who-card {
    padding: 20px 16px;
  }
  .st-who-ico {
    width: 40px;
    height: 40px;
  }
  .st-who-lbl {
    font-size: 12px;
  }
  .st-why-card {
    padding: 22px 18px;
  }
  .st-why-ico {
    width: 44px;
    height: 44px;
    border-radius: 12px;
  }
  .st-why-ico i {
    font-size: 17px;
  }
  .st-why-title {
    font-size: 14px;
  }
  .st-why-body {
    font-size: 13px;
  }
  .st-inc-item {
    padding: 28px 18px;
  }
  .st-inc-num {
    font-size: 44px;
  }
  .st-inc-ico {
    font-size: 22px;
    margin-bottom: 12px;
  }
  .st-inc-title {
    font-size: 13px;
  }
  .st-city-in {
    padding: 56px 20px;
  }
  .st-city-title {
    font-size: 24px;
  }
  .st-city-sub {
    font-size: 14px;
    line-height: 1.65;
  }
  .st-gain-list li {
    font-size: 14px;
    gap: 12px;
    padding: 12px 0;
  }
  .st-gain-img-wrap {
    height: 240px;
  }
  .st-gain-img-badge {
    padding: 14px 16px;
  }
  .st-gain-img-badge strong {
    font-size: 12px;
  }
  .st-exp-sec {
    padding: 56px 0;
  }
  .st-exp-item {
    padding: 20px 16px;
    gap: 12px;
  }
  .st-exp-item-body strong {
    font-size: 14px;
  }
  .st-exp-item-body p {
    font-size: 13px;
  }
  .st-exp-close {
    font-size: 15px;
    margin-top: 36px;
  }
  .st-smart-sec {
    padding: 64px 0;
  }
  .st-smart-q-icon {
    font-size: 44px;
  }
  .st-smart-quote {
    font-size: 20px;
  }
}
@media (max-width: 380px) {
  .st-who-card {
    padding: 18px 12px;
  }
  .st-why-card {
    padding: 18px 14px;
  }
  .st-inc-item {
    padding: 22px 16px;
  }
  .st-city-title {
    font-size: 20px;
  }
  .st-city-in {
    padding: 44px 16px;
  }
  .st-exp-item {
    padding: 16px 14px;
    gap: 10px;
  }
  .st-smart-sec {
    padding: 52px 0;
  }
  .st-smart-quote {
    font-size: 18px;
  }
}
/* ── Blog Archive & Single Post ──────────────────────────────────────────── */
/* Archive hero strip */
.ba-hero {
  background: linear-gradient(160deg, #001F66 0%, #001A55 100%);
  padding: 80px 0 72px;
  position: relative;
  overflow: hidden;
}
.ba-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 50%, rgba(255, 214, 10, 0.08), transparent 60%), radial-gradient(circle at 20% 50%, rgba(0, 102, 255, 0.15), transparent 60%);
  pointer-events: none;
}
.ba-hero .ph-breadcrumb {
  margin-bottom: 16px;
}
.ba-hero-eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 800;
  color: #FFD60A;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 12px;
}
.ba-hero-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 44px;
  font-weight: 900;
  color: #FFFFFF;
  line-height: 1.15;
  margin: 0 0 16px;
}
.ba-hero-title em {
  color: #FFD60A;
  font-style: normal;
}
.ba-hero-sub {
  font-size: 17px;
  color: rgba(255, 255, 255, 0.72);
  max-width: 600px;
  line-height: 1.65;
  margin: 0;
}
/* Category filter bar */
.ba-cat-bar {
  background: #FFFFFF;
  border-bottom: 1.5px solid #E5EAF2;
  overflow-x: auto;
  position: sticky;
  top: var(--header-h, 130px);
  z-index: 70;
}
.ba-cat-inner {
  display: flex;
  align-items: center;
  min-width: max-content;
  padding: 0 32px;
}
.ba-cat-link {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #7a8a9e;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  padding: 16px 20px;
  border-bottom: 3px solid transparent;
  white-space: nowrap;
  transition: color 0.2s, border-color 0.2s;
  display: flex;
  align-items: center;
  gap: 6px;
}
.ba-cat-link:hover {
  color: #0066FF;
}
.ba-active {
  color: #0066FF;
  border-bottom-color: #0066FF;
}
.ba-cat-count {
  background: #F4F8FF;
  border-radius: 20px;
  padding: 1px 7px;
  font-size: 10px;
  color: #7a8a9e;
}
.ba-active .ba-cat-count {
  background: rgba(0, 102, 255, 0.1);
  color: #0066FF;
}
/* Main content section — same light bg as homepage blog-sec */
.ba-main-sec {
  background: #F4F8FF;
  padding: 72px 0 80px;
}
.ba-more-hdr {
  margin-bottom: 40px;
}
.ba-post-count {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #7a8a9e;
}
.ba-main-sec .blog-card h3 a {
  color: #0F1B2D;
}
.ba-main-sec .blog-card h3 a:hover {
  color: #0066FF;
}
/* Empty state */
.ba-empty {
  text-align: center;
  padding: 80px 0;
}
.ba-empty i {
  font-size: 48px;
  color: #e0e8f0;
  margin-bottom: 20px;
  display: block;
}
.ba-empty h2 {
  font-family: 'Montserrat', sans-serif;
  font-size: 24px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 12px;
}
.ba-empty p {
  color: #7a8a9e;
  margin-bottom: 24px;
}
/* Pagination */
.ba-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-top: 52px;
  flex-wrap: wrap;
}
.ba-pagination .page-numbers {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: #0F1B2D;
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  border-radius: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1.5px solid #E5EAF2;
  background: #FFFFFF;
  transition: all 0.2s;
}
.ba-pagination .page-numbers:hover {
  border-color: #0066FF;
  color: #0066FF;
}
.ba-pagination .page-numbers.current {
  background: #0066FF;
  color: #FFFFFF;
  border-color: #0066FF;
}
.ba-pagination .page-numbers.dots {
  border: none;
  background: none;
  cursor: default;
}
.ba-pagination .page-numbers.prev,
.ba-pagination .page-numbers.next {
  gap: 6px;
}
/* ── Single Blog Post ─── */
.bs-hero {
  position: relative;
  min-height: 560px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.bs-hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}
.bs-hero-ov {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 15, 51, 0.96) 0%, rgba(0, 15, 51, 0.6) 50%, rgba(0, 15, 51, 0.15) 100%);
}
.bs-hero-in {
  position: relative;
  z-index: 2;
  padding: 80px 0 56px;
  width: 100%;
}
.bs-hero-in .ph-breadcrumb {
  margin-bottom: 20px;
}
.bs-hero-cat {
  display: inline-block;
  font-family: 'Montserrat', sans-serif;
  font-size: 9px;
  font-weight: 800;
  color: #FFFFFF;
  padding: 5px 14px;
  border-radius: 20px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.bs-hero-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 40px;
  font-weight: 900;
  color: #FFFFFF;
  line-height: 1.2;
  max-width: 820px;
  margin: 0 0 20px;
}
.bs-hero-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 20px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.7);
}
.bs-hero-meta span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.bs-author-link {
  color: #FFD60A;
  font-weight: 600;
}
/* Article typography */
.bs-article-sec {
  padding: 72px 0 80px;
}
.bs-wrap {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 24px;
}
.bs-article {
  font-size: 17px;
  line-height: 1.85;
  color: #0F1B2D;
}
.bs-article h2 {
  font-family: 'Montserrat', sans-serif;
  font-size: 26px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 44px 0 16px;
  line-height: 1.3;
}
.bs-article h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: 21px;
  font-weight: 700;
  color: #0F1B2D;
  margin: 36px 0 14px;
  line-height: 1.35;
}
.bs-article h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  font-weight: 700;
  color: #0F1B2D;
  margin: 28px 0 12px;
}
.bs-article p {
  margin: 0 0 24px;
}
.bs-article a {
  color: #0066FF;
  text-decoration: underline;
}
.bs-article img {
  width: 100%;
  border-radius: 32px;
  margin: 32px 0;
  display: block;
  height: auto;
}
.bs-article ul,
.bs-article ol {
  padding-left: 26px;
  margin: 0 0 24px;
}
.bs-article li {
  margin-bottom: 8px;
  padding-left: 4px;
}
.bs-article blockquote {
  border-left: 4px solid #0066FF;
  padding: 18px 24px;
  background: #F4F8FF;
  border-radius: 0 24px 24px 0;
  font-size: 18px;
  font-style: italic;
  color: #0F1B2D;
  margin: 36px 0;
  line-height: 1.7;
}
.bs-article code {
  background: #F4F8FF;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 15px;
  color: #0066FF;
  font-family: monospace;
}
.bs-article pre {
  background: #0F1B2D;
  color: #FFFFFF;
  padding: 24px;
  border-radius: 24px;
  overflow-x: auto;
  margin: 32px 0;
  font-size: 14px;
}
.bs-article hr {
  border: none;
  border-top: 1.5px solid #E5EAF2;
  margin: 40px 0;
}
/* Share bar */
.bs-share-bar {
  border-top: 1.5px solid #E5EAF2;
  border-bottom: 1.5px solid #E5EAF2;
  padding: 20px 0;
  margin: 48px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.bs-share-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  color: #0F1B2D;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.bs-share-btns {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.bs-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  padding: 8px 16px;
  border-radius: 24px;
  border: 1.5px solid #E5EAF2;
  color: #0F1B2D;
  cursor: pointer;
  background: #FFFFFF;
  transition: all 0.2s;
}
.bs-share-btn:hover {
  border-color: #0066FF;
  color: #0066FF;
}
.bs-share-wa {
  border-color: #25D366;
  color: #25D366;
}
.bs-share-wa:hover {
  background: #25D366;
  color: #FFFFFF;
}
.bs-share-fb {
  border-color: #1877F2;
  color: #1877F2;
}
.bs-share-fb:hover {
  background: #1877F2;
  color: #FFFFFF;
}
.bs-share-line {
  border-color: #06C755;
  color: #06C755;
}
.bs-share-line:hover {
  background: #06C755;
  color: #FFFFFF;
}
/* Author box */
.bs-author-box {
  background: #F4F8FF;
  border-radius: 32px;
  padding: 28px;
  display: flex;
  gap: 20px;
  align-items: flex-start;
  margin-top: 48px;
}
.bs-author-av {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, #0066FF, #001F66);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}
.bs-author-av img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.bs-author-av i {
  color: #FFFFFF;
  font-size: 24px;
}
.bs-author-meta strong {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 800;
  color: #0F1B2D;
  display: block;
  margin-bottom: 2px;
}
.bs-author-meta .bs-author-role {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 700;
  color: #0066FF;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  display: block;
  margin-bottom: 8px;
}
.bs-author-meta p {
  font-size: 13.5px;
  color: #5a6a7e;
  line-height: 1.65;
  margin: 0;
}
/* Tags */
.bs-tags {
  margin-top: 32px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.bs-tags-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  color: #0F1B2D;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.bs-tag {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 600;
  color: #5a6a7e;
  background: #F4F8FF;
  border-radius: 20px;
  padding: 5px 14px;
  border: 1.5px solid #E5EAF2;
  transition: all 0.2s;
}
.bs-tag:hover {
  border-color: #0066FF;
  color: #0066FF;
}
/* Related posts */
.bs-related-sec {
  background: #F4F8FF;
  padding: 80px 0;
}
.bs-related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 40px;
}
.bs-related-grid .blog-card h3 a {
  color: #0F1B2D;
}
.bs-related-grid .blog-card h3 a:hover {
  color: #0066FF;
}
/* Responsive */
@media (max-width: 1060px) {
  .bs-hero-title {
    font-size: 32px;
  }
  .bs-related-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 760px) {
  .ba-main-sec {
    padding: 48px 0 60px;
  }
  .ba-more-hdr {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .blog-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 680px) {
  .ba-hero-title {
    font-size: 30px;
  }
  .ba-cat-inner {
    padding: 0 16px;
  }
  .blog-grid {
    grid-template-columns: 1fr;
  }
  .bs-hero-title {
    font-size: 24px;
  }
  .bs-article {
    font-size: 16px;
  }
  .bs-related-grid {
    grid-template-columns: 1fr;
  }
  .bs-share-bar {
    flex-direction: column;
    align-items: flex-start;
  }
  .bs-hero-meta {
    gap: 12px;
    font-size: 12px;
  }
}
/* ── Audio Files ─────────────────────────────────────────────────────────── */
.af-hero {
  min-height: 640px;
}
/* How it works */
.af-steps-sec {
  background: #F4F8FF;
}
.af-steps {
  display: flex;
  align-items: flex-start;
  gap: 0;
}
.af-step {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0 24px;
}
.af-step-bubble {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 22px;
}
.af-step-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 64px;
  font-weight: 900;
  color: #E8F1FF;
  line-height: 1;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
}
.af-step-ico {
  position: relative;
  z-index: 1;
  width: 64px;
  height: 64px;
  border-radius: 20px;
  background: #0066FF;
  color: #fff;
  font-size: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 28px rgba(0, 102, 255, 0.32);
}
.af-step-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 12px;
}
.af-step-body {
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #5A6A7E;
  line-height: 1.65;
}
.af-step-arr {
  flex-shrink: 0;
  color: #E8F1FF;
  font-size: 28px;
  padding: 0 4px;
  margin-top: 32px;
}
/* Form section */
.af-form-sec {
  background: #FFFFFF;
}
.af-inner {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 80px;
  align-items: start;
}
/* Info column */
.af-info .sec-label {
  margin-bottom: 14px;
}
.af-info-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 26px;
  font-weight: 900;
  color: #0F1B2D;
  line-height: 1.3;
  margin-bottom: 16px;
}
.af-info-title em {
  color: #0066FF;
  font-style: normal;
}
.af-info-desc {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.7;
  margin-bottom: 28px;
}
/* Tier cards */
.af-tiers {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.af-tier {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: #F4F8FF;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  padding: 18px 20px;
  transition: all 0.25s;
}
.af-tier--journey:hover {
  border-color: #0066FF;
  transform: translateX(4px);
}
.af-tier--explore:hover {
  border-color: #00C4B4;
  transform: translateX(4px);
}
.af-tier--connect:hover {
  border-color: #FFB000;
  transform: translateX(4px);
}
.af-tier-ico {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  font-size: 17px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.af-tier--journey .af-tier-ico {
  background: #E8F1FF;
  color: #0066FF;
}
.af-tier--explore .af-tier-ico {
  background: rgba(0, 196, 180, 0.12);
  color: #00C4B4;
}
.af-tier--connect .af-tier-ico {
  background: rgba(255, 176, 0, 0.15);
  color: #FFB000;
}
.af-tier-body {
  flex: 1;
}
.af-tier-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 2px;
}
.af-tier-level {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.af-tier--journey .af-tier-level {
  color: #0066FF;
}
.af-tier--explore .af-tier-level {
  color: #00C4B4;
}
.af-tier--connect .af-tier-level {
  color: #FFB000;
}
.af-tier-desc {
  font-family: 'Lato', sans-serif;
  font-size: 12px;
  color: #5A6A7E;
  line-height: 1.55;
  margin-bottom: 10px;
}
.af-tier-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.af-tier-tags span {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 700;
  background: #fff;
  border: 1px solid #E5EAF2;
  border-radius: 100px;
  padding: 3px 10px;
  color: #5A6A7E;
}
/* Form box */
.af-form-box {
  background: #F4F8FF;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 40px;
}
.af-form-note {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: #E8F1FF;
  border: 1.5px solid rgba(0, 102, 255, 0.15);
  border-radius: 14px;
  padding: 16px 20px;
  margin-bottom: 28px;
}
.af-form-note i {
  color: #0066FF;
  font-size: 15px;
  flex-shrink: 0;
  margin-top: 2px;
}
.af-form-note p {
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: #0F1B2D;
  line-height: 1.6;
}
.af-form-note p strong {
  color: #0066FF;
  font-weight: 700;
}
.af-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.af-field {
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.af-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  font-weight: 700;
  color: #0F1B2D;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}
.af-req {
  color: #FF7A59;
}
.af-field-hint {
  font-family: 'Lato', sans-serif;
  font-size: 11.5px;
  color: #5A6A7E;
  display: flex;
  align-items: center;
  gap: 5px;
}
.af-field-hint i {
  color: #0066FF;
  font-size: 10px;
}
.af-input {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #0F1B2D;
  border: 1.5px solid #E5EAF2;
  border-radius: 12px;
  padding: 13px 16px;
  background: #fff;
  width: 100%;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.af-input::placeholder {
  color: #8998ab;
}
.af-input:focus {
  border-color: #0066FF;
  box-shadow: 0 0 0 3px #E8F1FF;
}
.af-select-wrap {
  position: relative;
}
.af-select-wrap::after {
  content: '\f078';
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: #5A6A7E;
  pointer-events: none;
  font-size: 11px;
}
.af-select {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #0F1B2D;
  border: 1.5px solid #E5EAF2;
  border-radius: 12px;
  padding: 13px 40px 13px 16px;
  background: #fff;
  width: 100%;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.af-select:focus {
  border-color: #0066FF;
  box-shadow: 0 0 0 3px #E8F1FF;
}
.af-submit {
  width: 100%;
  justify-content: center;
  margin-top: 4px;
}
/* Audio Files responsive */
@media (max-width: 1060px) {
  .af-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .af-form-box {
    padding: 32px 28px;
  }
}
@media (max-width: 900px) {
  .af-steps {
    flex-direction: column;
    align-items: center;
    gap: 40px;
    max-width: 380px;
    margin: 0 auto;
  }
  .af-step {
    padding: 0;
  }
  .af-step-arr {
    display: none;
  }
}
@media (max-width: 680px) {
  .af-form-box {
    padding: 26px 20px;
  }
  .af-info-title {
    font-size: 22px;
  }
  .af-info-desc {
    font-size: 13.5px;
  }
  .af-tiers {
    gap: 10px;
  }
  .af-tier {
    padding: 14px 16px;
    gap: 12px;
  }
  .af-tier-ico {
    width: 38px;
    height: 38px;
    font-size: 15px;
    border-radius: 10px;
  }
}
@media (max-width: 480px) {
  .af-form-box {
    padding: 22px 16px;
    border-radius: 24px;
  }
  .af-step-ico {
    width: 54px;
    height: 54px;
    font-size: 18px;
  }
  .af-input,
  .af-select {
    font-size: 16px;
  }
  .af-form-note {
    padding: 13px 14px;
    gap: 10px;
  }
  .af-form-note p {
    font-size: 12.5px;
  }
  .af-tiers {
    gap: 8px;
  }
  .af-tier {
    padding: 12px 14px;
    gap: 10px;
  }
  .af-tier-ico {
    width: 34px;
    height: 34px;
    font-size: 14px;
    border-radius: 9px;
  }
  .af-tier-name {
    font-size: 13px;
  }
  .af-tier-desc {
    font-size: 11.5px;
    line-height: 1.5;
  }
  .af-info-title {
    font-size: 20px;
  }
}
@media (max-width: 380px) {
  .af-form-box {
    padding: 16px 12px;
  }
  .af-tiers {
    gap: 6px;
  }
  .af-tier {
    padding: 10px 12px;
  }
}
/* ── Course Fees ────────────────────────────────────────────────────────── */
.cf-hero .ph-bg {
  filter: brightness(0.55) saturate(1.1);
}
/* Overview Grid */
.cf-overview-sec {
  background: #fff;
}
.cf-overview-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 40px;
}
@media (max-width: 1100px) {
  .cf-overview-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 580px) {
  .cf-overview-grid {
    grid-template-columns: 1fr;
  }
}
.cf-ov-card {
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 28px 24px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: border-color 0.22s, transform 0.22s, box-shadow 0.22s;
}
.cf-ov-card:hover {
  border-color: #0066FF;
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 102, 255, 0.1);
}
.cf-ov-ico {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.cf-ov-ico--group {
  background: #E8F1FF;
  color: #0066FF;
}
.cf-ov-ico--night {
  background: #EEF0FF;
  color: #5C6BC0;
}
.cf-ov-ico--private {
  background: #FFF4E0;
  color: #F59E0B;
}
.cf-ov-ico--online {
  background: #E0FBF5;
  color: #00C4B4;
}
.cf-ov-body {
  flex: 1;
}
.cf-ov-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 4px;
}
.cf-ov-sub {
  font-size: 12px;
  color: #5A6A7E;
  margin-bottom: 10px;
}
.cf-ov-price {
  display: flex;
  align-items: baseline;
  gap: 3px;
  margin-bottom: 4px;
}
.cf-ov-from {
  font-size: 11px;
  color: #5A6A7E;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.cf-ov-amt {
  font-family: 'Montserrat', sans-serif;
  font-size: 26px;
  font-weight: 800;
  color: #0066FF;
}
.cf-ov-unit {
  font-size: 12px;
  color: #5A6A7E;
}
.cf-ov-detail {
  font-size: 12px;
  color: #5A6A7E;
}
.cf-ov-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.cf-ov-tags span {
  font-size: 11px;
  font-weight: 600;
  color: #0066FF;
  background: #E8F1FF;
  padding: 3px 10px;
  border-radius: 20px;
}
.cf-ov-tags span i {
  margin-right: 4px;
}
.cf-ov-link {
  font-size: 13px;
  font-weight: 600;
  color: #0066FF;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
}
.cf-ov-link:hover {
  gap: 9px;
}
.cf-ov-link i {
  font-size: 11px;
  transition: transform 0.2s;
}
/* Group Pricing Section */
.cf-group-sec {
  background: #F4F8FF;
}
.cf-price-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 48px;
}
@media (max-width: 960px) {
  .cf-price-grid {
    grid-template-columns: 1fr;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
  }
}
/* Savings Bar */
.cf-savings-bar {
  background: #fff;
  border-radius: 32px;
  border: 1.5px solid #E5EAF2;
  padding: 32px 36px;
  margin-top: 40px;
}
@media (max-width: 680px) {
  .cf-savings-bar {
    padding: 24px 20px;
  }
}
.cf-sb-item {
  display: grid;
  grid-template-columns: 160px 1fr 100px;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
}
.cf-sb-item:last-of-type {
  margin-bottom: 0;
}
@media (max-width: 600px) {
  .cf-sb-item {
    grid-template-columns: 140px 1fr 80px;
    gap: 10px;
  }
}
.cf-sb-label {
  font-size: 13px;
  font-weight: 600;
  color: #0F1B2D;
}
.cf-sb-track {
  height: 10px;
  background: #E8F1FF;
  border-radius: 20px;
  overflow: hidden;
}
.cf-sb-fill {
  height: 100%;
  background: #0066FF;
  border-radius: 20px;
  transition: width 0.8s ease;
}
.cf-sb-fill--mid {
  background: #00C4B4;
}
.cf-sb-fill--best {
  background: #16A34A;
}
.cf-sb-rate {
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #0F1B2D;
  text-align: right;
}
.cf-sb-caption {
  font-size: 12px;
  color: #5A6A7E;
  margin-top: 18px;
  border-top: 1px solid #E5EAF2;
  padding-top: 14px;
  display: flex;
  align-items: center;
  gap: 7px;
}
.cf-sb-caption i {
  color: #0066FF;
  flex-shrink: 0;
}
/* Private Lesson Pricing */
.cf-private-sec {
  background: #fff;
}
.cf-private-inner {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 60px;
  align-items: start;
}
.cf-private-desc {
  font-size: 15px;
  color: #5A6A7E;
  line-height: 1.7;
  margin-bottom: 28px;
}
.cf-private-points {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.cf-pp-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}
.cf-pp-item strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 2px;
}
.cf-pp-item span {
  font-size: 13px;
  color: #5A6A7E;
}
.cf-pp-ico {
  width: 40px;
  height: 40px;
  background: #E8F1FF;
  color: #0066FF;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.cf-private-card {
  background: linear-gradient(145deg, #0066FF, #003FB5);
  border-radius: 32px;
  padding: 36px 32px;
  color: #fff;
  box-shadow: 0 16px 40px rgba(0, 102, 255, 0.25);
}
.cf-pc-top {
  text-align: center;
  padding-bottom: 24px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.18);
  margin-bottom: 24px;
}
.cf-pc-lbl {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
  opacity: 0.8;
  margin-bottom: 8px;
}
.cf-pc-price {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 4px;
}
.cf-pc-curr {
  font-size: 28px;
  font-weight: 700;
  opacity: 0.9;
  margin-bottom: 8px;
}
.cf-pc-amt {
  font-family: 'Montserrat', sans-serif;
  font-size: 64px;
  font-weight: 800;
  line-height: 1;
}
.cf-pc-unit {
  font-size: 20px;
  font-weight: 600;
  opacity: 0.9;
  align-self: flex-end;
  margin-bottom: 8px;
}
.cf-pc-meta {
  font-size: 13px;
  opacity: 0.75;
  margin-top: 8px;
}
.cf-pc-breakdown {
  margin-bottom: 20px;
}
.cf-pc-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 11px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 13px;
}
.cf-pc-row span {
  opacity: 0.85;
}
.cf-pc-row strong {
  font-weight: 700;
}
.cf-pc-row:last-child {
  border-bottom: none;
}
.cf-pc-min {
  background: rgba(255, 255, 255, 0.15);
  border-radius: 10px;
  padding: 12px 14px;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
}
.cf-pc-min i {
  flex-shrink: 0;
}
.cf-pc-btns {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cf-pc-btns .btn {
  justify-content: center;
  width: 100%;
}
.cf-pc-btns .btn-ghost {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.3);
}
.cf-pc-btns .btn-ghost:hover {
  background: rgba(255, 255, 255, 0.25);
}
/* Online Pricing */
.cf-online-sec {
  background: #F4F8FF;
}
.cf-online-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  max-width: 820px;
  margin: 40px auto 0;
}
@media (max-width: 680px) {
  .cf-online-grid {
    grid-template-columns: 1fr;
    max-width: 420px;
  }
}
.cf-online-card {
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 32px 28px;
}
.cf-online-featured {
  background: linear-gradient(145deg, #0066FF, #003FB5);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 16px 40px rgba(0, 102, 255, 0.22);
  position: relative;
  overflow: hidden;
}
.cf-online-featured .cf-onc-tag {
  color: rgba(255, 255, 255, 0.8);
}
.cf-online-featured .cf-onc-curr,
.cf-online-featured .cf-onc-amt {
  color: #fff;
}
.cf-online-featured .cf-onc-was,
.cf-online-featured .cf-onc-sub {
  color: rgba(255, 255, 255, 0.75);
}
.cf-online-featured .cf-onc-list li {
  color: rgba(255, 255, 255, 0.9);
}
.cf-online-featured .cf-x {
  color: rgba(255, 255, 255, 0.4);
}
.cf-onc-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #FFD60A;
  color: #0F1B2D;
  font-size: 11px;
  font-weight: 800;
  padding: 4px 12px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 14px;
}
.cf-onc-badge i {
  font-size: 10px;
}
.cf-onc-tag {
  font-size: 13px;
  font-weight: 600;
  color: #5A6A7E;
  margin-bottom: 8px;
}
.cf-onc-price {
  display: flex;
  align-items: baseline;
  gap: 2px;
}
.cf-onc-curr {
  font-size: 20px;
  font-weight: 700;
  color: #0066FF;
  margin-bottom: 4px;
}
.cf-onc-amt {
  font-family: 'Montserrat', sans-serif;
  font-size: 42px;
  font-weight: 800;
  color: #0066FF;
  line-height: 1;
}
.cf-onc-was {
  font-size: 13px;
  color: #5A6A7E;
  margin: 6px 0 2px;
}
.cf-onc-sub {
  font-size: 13px;
  color: #5A6A7E;
  margin-bottom: 20px;
}
.cf-onc-list {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  display: flex;
  flex-direction: column;
  gap: 9px;
}
.cf-onc-list li {
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.cf-onc-list .fa-check {
  color: #00C4B4;
  font-size: 12px;
}
.cf-x {
  color: #E5EAF2;
}
.cf-online-note {
  display: flex;
  align-items: center;
  gap: 14px;
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  padding: 16px 20px;
  max-width: 820px;
  margin: 24px auto 0;
  font-size: 13px;
  color: #5A6A7E;
}
.cf-online-note i {
  color: #0066FF;
  font-size: 18px;
  flex-shrink: 0;
}
.cf-online-note a {
  color: #0066FF;
  font-weight: 600;
  text-decoration: none;
}
.cf-online-note a:hover {
  text-decoration: underline;
}
/* Additional Costs */
.cf-extras-sec {
  background: #fff;
}
.cf-extras-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 40px;
}
@media (max-width: 900px) {
  .cf-extras-grid {
    grid-template-columns: 1fr;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
  }
}
.cf-extra-card {
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 28px 24px;
  display: flex;
  gap: 20px;
  align-items: flex-start;
  transition: border-color 0.22s, box-shadow 0.22s;
}
.cf-extra-card:hover {
  border-color: #0066FF;
  box-shadow: 0 8px 24px rgba(0, 102, 255, 0.08);
}
@media (max-width: 480px) {
  .cf-extra-card {
    flex-direction: column;
  }
}
.cf-extra-ico {
  width: 48px;
  height: 48px;
  background: #E8F1FF;
  color: #0066FF;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.cf-extra-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 4px;
}
.cf-extra-price {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: #0066FF;
  margin-bottom: 8px;
}
.cf-extra-desc {
  font-size: 13px;
  color: #5A6A7E;
  line-height: 1.65;
  margin-bottom: 10px;
}
.cf-extra-note {
  font-size: 12px;
  color: #00C4B4;
  display: flex;
  align-items: center;
  gap: 5px;
}
.cf-extra-note i {
  font-size: 11px;
}
.cf-extra-link {
  font-size: 13px;
  font-weight: 600;
  color: #0066FF;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 5px;
}
.cf-extra-link:hover {
  gap: 8px;
}
/* Policies */
.cf-policy-sec {
  background: #F4F8FF;
}
.cf-policy-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 40px;
}
@media (max-width: 760px) {
  .cf-policy-grid {
    grid-template-columns: 1fr;
  }
}
.cf-policy-card {
  background: #fff;
  border-radius: 32px;
  padding: 28px 26px;
  border: 1.5px solid #E5EAF2;
  display: flex;
  gap: 18px;
  align-items: flex-start;
}
.cf-pol-ico {
  width: 44px;
  height: 44px;
  background: #E8F1FF;
  color: #0066FF;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.cf-pol-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 8px;
}
.cf-pol-body {
  font-size: 13px;
  color: #5A6A7E;
  line-height: 1.7;
}
.cf-policy-contact {
  text-align: center;
  margin-top: 36px;
  font-size: 14px;
  color: #5A6A7E;
}
.cf-policy-contact a {
  color: #0066FF;
  font-weight: 600;
  text-decoration: none;
}
.cf-policy-contact a:hover {
  text-decoration: underline;
}
/* Course Fees responsive */
@media (max-width: 1100px) {
  .cf-private-inner {
    grid-template-columns: 1fr 380px;
    gap: 40px;
  }
}
@media (max-width: 860px) {
  .cf-private-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .cf-private-card {
    max-width: 480px;
    margin: 0 auto;
  }
}
@media (max-width: 680px) {
  .cf-ov-card {
    padding: 24px 20px;
  }
  .cf-private-desc {
    font-size: 14px;
  }
  .cf-pp-item strong {
    font-size: 13.5px;
  }
  .cf-pp-item span {
    font-size: 12.5px;
  }
  .cf-online-card {
    padding: 28px 24px;
  }
  .cf-onc-amt {
    font-size: 36px;
  }
  .cf-extra-card {
    padding: 24px 20px;
    gap: 16px;
  }
  .cf-policy-card {
    padding: 24px 22px;
    gap: 16px;
  }
  .cf-pol-body {
    font-size: 12.5px;
  }
}
@media (max-width: 480px) {
  .cf-private-card {
    padding: 28px 20px;
  }
  .cf-pc-amt {
    font-size: 52px;
  }
  .cf-ov-card {
    padding: 20px 16px;
    gap: 12px;
  }
  .cf-ov-ico {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    font-size: 17px;
  }
  .cf-ov-title {
    font-size: 15px;
  }
  .cf-ov-amt {
    font-size: 22px;
  }
  .cf-pp-ico {
    width: 36px;
    height: 36px;
    font-size: 14px;
    border-radius: 9px;
  }
  .cf-pp-item {
    gap: 12px;
  }
  .cf-online-card {
    padding: 24px 20px;
  }
  .cf-extra-card {
    padding: 20px 18px;
  }
  .cf-extra-ico {
    width: 42px;
    height: 42px;
    font-size: 18px;
    border-radius: 11px;
  }
  .cf-policy-card {
    padding: 20px 18px;
    gap: 14px;
  }
  .cf-pol-ico {
    width: 38px;
    height: 38px;
    font-size: 16px;
    border-radius: 10px;
  }
}
@media (max-width: 380px) {
  .cf-ov-card {
    padding: 18px 14px;
  }
  .cf-pc-amt {
    font-size: 44px;
  }
  .cf-online-card {
    padding: 20px 16px;
  }
  .cf-extra-card {
    padding: 18px 14px;
  }
  .cf-policy-card {
    padding: 18px 14px;
    gap: 12px;
  }
  .cf-sb-item {
    grid-template-columns: 118px 1fr 70px;
    gap: 8px;
  }
  .cf-sb-rate {
    font-size: 12px;
  }
  .cf-sb-label {
    font-size: 12px;
  }
}
/* ── ED Visa Info ───────────────────────────────────────────────────────── */
.ev-hero .ph-bg {
  filter: brightness(0.5) saturate(1.15);
}
/* Sticky anchor nav */
.ev-nav-wrap {
  background: #fff;
  border-bottom: 1.5px solid #E5EAF2;
  z-index: 70;
  transition: box-shadow 0.25s;
  position: sticky;
  top: var(--header-h, 130px);
}
.ev-nav-wrap.ev-nav-stuck {
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}
.ev-nav {
  display: flex;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.ev-nav::-webkit-scrollbar {
  display: none;
}
.ev-nav-link {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 16px 24px;
  font-size: 13px;
  font-weight: 600;
  color: #5A6A7E;
  text-decoration: none;
  border-bottom: 3px solid transparent;
  white-space: nowrap;
  transition: color 0.2s, border-color 0.2s;
}
.ev-nav-link i {
  font-size: 12px;
}
.ev-nav-link:hover {
  color: #0066FF;
}
.ev-nav-link.ev-nav-active {
  color: #0066FF;
  border-bottom-color: #0066FF;
}
@media (max-width: 580px) {
  .ev-nav-link {
    padding: 14px 16px;
    font-size: 12px;
  }
}
/* Overview strip */
.ev-overview-sec {
  background: #0066FF;
  padding: 28px 0;
}
.ev-overview-grid {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.ev-ov-item {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #fff;
}
.ev-ov-item strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
}
.ev-ov-item span {
  font-size: 12px;
  opacity: 0.8;
}
.ev-ov-ico {
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.ev-ov-div {
  width: 1px;
  height: 36px;
  background: rgba(255, 255, 255, 0.2);
}
@media (max-width: 760px) {
  .ev-ov-div {
    display: none;
  }
}
/* Section head */
.ev-sec-head {
  max-width: 680px;
  margin: 0 auto 48px;
  text-align: center;
}
.ev-apply-sec,
.ev-after-sec {
  background: #fff;
}
/* Options grid */
.ev-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
@media (max-width: 900px) {
  .ev-options {
    grid-template-columns: 1fr;
  }
}
.ev-option {
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  overflow: hidden;
}
.ev-option--bangkok {
  border-top: 4px solid #0066FF;
}
.ev-option--abroad {
  border-top: 4px solid #00C4B4;
}
.ev-opt-head {
  padding: 28px 28px 0;
}
@media (max-width: 480px) {
  .ev-opt-head {
    padding: 20px 18px 0;
  }
}
.ev-opt-badge {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  padding: 4px 12px;
  border-radius: 20px;
  margin-bottom: 12px;
}
.ev-opt-badge--1 {
  background: #E8F1FF;
  color: #0066FF;
}
.ev-opt-badge--2 {
  background: #E0FBF5;
  color: #00C4B4;
}
.ev-opt-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 6px;
}
.ev-opt-title i {
  margin-right: 8px;
  font-size: 16px;
}
.ev-opt-sub {
  font-size: 13px;
  color: #5A6A7E;
  padding-bottom: 20px;
  border-bottom: 1px solid #E5EAF2;
}
/* Steps list */
.ev-steps-list {
  list-style: none;
  padding: 20px 28px 28px;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
@media (max-width: 480px) {
  .ev-steps-list {
    padding: 16px 18px 20px;
  }
}
.ev-step-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid #E5EAF2;
}
.ev-step-item.ev-step-last {
  border-bottom: none;
}
.ev-step-num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #0066FF;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}
.ev-step-num--done {
  background: #16A34A;
}
.ev-option--abroad .ev-step-num {
  background: #00C4B4;
}
.ev-step-body {
  font-size: 13px;
  color: #5A6A7E;
  line-height: 1.65;
  flex: 1;
}
/* Police notice */
.ev-police-notice {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-top: 36px;
  background: #FFF8E7;
  border: 1.5px solid #F59E0B;
  border-radius: 24px;
  padding: 20px 22px;
}
.ev-police-ico {
  width: 40px;
  height: 40px;
  background: #F59E0B;
  color: #fff;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.ev-police-body strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 4px;
}
.ev-police-body p {
  font-size: 13px;
  color: #92400E;
  margin: 0;
  line-height: 1.6;
}
/* Contact bar */
.ev-contact-bar {
  display: flex;
  align-items: center;
  gap: 24px;
  margin-top: 24px;
  background: #E8F1FF;
  border-radius: 24px;
  padding: 18px 22px;
  flex-wrap: wrap;
}
.ev-cb-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: #0F1B2D;
  flex: 1;
}
.ev-cb-item i {
  color: #0066FF;
  font-size: 15px;
}
.ev-cb-item a {
  color: #0066FF;
  font-weight: 600;
  text-decoration: none;
}
.ev-cb-item a:hover {
  text-decoration: underline;
}
.ev-cb-div {
  width: 1px;
  height: 24px;
  background: #E5EAF2;
}
@media (max-width: 680px) {
  .ev-cb-div {
    display: none;
  }
}
/* After Approval section */
.ev-after-sec {
  background: #F4F8FF;
}
.ev-after-block {
  background: #fff;
  border-radius: 32px;
  border: 1.5px solid #E5EAF2;
  overflow: hidden;
  margin-bottom: 24px;
}
.ev-after-block:last-child {
  margin-bottom: 0;
}
.ev-ab-head {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 24px 28px;
  border-bottom: 1.5px solid #E5EAF2;
}
@media (max-width: 480px) {
  .ev-ab-head {
    padding: 18px 18px;
  }
}
.ev-ab-ico {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.ev-ab-ico--blue {
  background: #E8F1FF;
  color: #0066FF;
}
.ev-ab-ico--teal {
  background: #E0FBF5;
  color: #00C4B4;
}
.ev-ab-ico--yellow {
  background: #FFF4E0;
  color: #F59E0B;
}
.ev-ab-ico--coral {
  background: #FFE8E0;
  color: #E55A40;
}
.ev-ab-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #0F1B2D;
}
.ev-ab-body {
  padding: 24px 28px;
}
.ev-ab-body p {
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.75;
  margin-bottom: 14px;
}
.ev-ab-body p:last-child {
  margin-bottom: 0;
}
@media (max-width: 480px) {
  .ev-ab-body {
    padding: 18px 18px;
  }
}
.ev-ab-alert {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: #E8F1FF;
  border-radius: 24px;
  padding: 14px 16px;
  margin-bottom: 20px;
  font-size: 13px;
  color: #0F1B2D;
}
.ev-ab-alert i {
  color: #0066FF;
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}
.ev-ab-alert--warn {
  background: #FFF8E7;
  color: #92400E;
}
.ev-ab-alert--warn i {
  color: #F59E0B;
}
.ev-ab-highlight {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: #E0FBF5;
  border-radius: 24px;
  padding: 14px 16px;
  margin-top: 16px;
  font-size: 13px;
  color: #0F1B2D;
}
.ev-ab-highlight i {
  color: #00C4B4;
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}
.ev-ab-highlight--red {
  background: #FFF0F0;
}
.ev-ab-highlight--red i {
  color: #E55A40;
}
.ev-ab-note {
  font-size: 13px;
  color: #5A6A7E;
  margin-top: 16px!important;
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.ev-ab-note i {
  color: #0066FF;
  flex-shrink: 0;
  margin-top: 2px;
}
.ev-ab-tip {
  font-size: 13px;
  color: #5A6A7E;
  margin-top: 14px!important;
  font-style: italic;
}
/* Visa duration tracks */
.ev-visa-tracks {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 16px;
  margin: 20px 0;
}
@media (max-width: 680px) {
  .ev-visa-tracks {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
.ev-vt-arrow {
  width: 36px;
  height: 36px;
  background: #E8F1FF;
  color: #0066FF;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}
@media (max-width: 680px) {
  .ev-vt-arrow {
    display: none;
  }
}
.ev-vt-card {
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  overflow: hidden;
}
.ev-vt-card--first {
  border-top: 3px solid #0066FF;
}
.ev-vt-card--second {
  border-top: 3px solid #00C4B4;
}
.ev-vt-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: #F4F8FF;
  font-size: 13px;
  font-weight: 700;
  color: #0F1B2D;
}
.ev-vt-head i {
  color: #0066FF;
}
.ev-vt-card--second .ev-vt-head i {
  color: #00C4B4;
}
.ev-vt-body {
  padding: 0 16px 12px;
}
.ev-vt-row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid #E5EAF2;
  font-size: 13px;
}
.ev-vt-row span:first-child {
  color: #5A6A7E;
}
.ev-vt-row span:last-child {
  font-weight: 600;
  color: #0F1B2D;
}
.ev-vt-row:last-of-type {
  border-bottom: none;
}
.ev-vt-total {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #0066FF;
  color: #fff;
  border-radius: 8px;
  padding: 10px 14px;
  margin-top: 12px;
  font-size: 13px;
}
.ev-vt-total strong {
  font-weight: 700;
}
.ev-vt-total i {
  font-size: 12px;
  opacity: 0.8;
}
.ev-vt-card--second .ev-vt-total {
  background: #00C4B4;
}
/* Info cards */
.ev-ab-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 16px 0;
}
@media (max-width: 680px) {
  .ev-ab-cards {
    grid-template-columns: 1fr;
  }
}
.ev-ab-card {
  background: #F4F8FF;
  border-radius: 24px;
  padding: 16px 14px;
  text-align: center;
}
.ev-ab-card strong {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: #0F1B2D;
  margin: 8px 0 4px;
}
.ev-ab-card span {
  font-size: 12px;
  color: #5A6A7E;
}
.ev-abc-ico {
  color: #0066FF;
  font-size: 18px;
  margin-bottom: 2px;
}
/* 90-day report grid */
.ev-report-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 16px 0;
}
@media (max-width: 680px) {
  .ev-report-grid {
    grid-template-columns: 1fr;
  }
}
.ev-rg-item {
  background: #F4F8FF;
  border-radius: 24px;
  padding: 16px 14px;
}
.ev-rg-title {
  font-size: 13px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.ev-rg-title i {
  color: #0066FF;
}
.ev-rg-item p {
  font-size: 12px;
  color: #5A6A7E;
  line-height: 1.6;
  margin: 0;
}
/* Re-entry grid */
.ev-reentry-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 16px 0;
}
@media (max-width: 600px) {
  .ev-reentry-grid {
    grid-template-columns: 1fr;
  }
}
.ev-re-card {
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  padding: 20px 18px;
  text-align: center;
}
.ev-re-featured {
  background: #0066FF;
  border-color: #0066FF;
  color: #fff;
  box-shadow: 0 8px 20px rgba(0, 102, 255, 0.2);
}
.ev-re-top {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 10px;
  opacity: 0.9;
}
.ev-re-price {
  font-family: 'Montserrat', sans-serif;
  font-size: 28px;
  font-weight: 800;
  color: #0066FF;
  margin-bottom: 8px;
}
.ev-re-featured .ev-re-price {
  color: #fff;
}
.ev-re-card p {
  font-size: 12px;
  color: #5A6A7E;
  line-height: 1.55;
  margin: 0;
}
.ev-re-featured .ev-re-card p {
  color: rgba(255, 255, 255, 0.8);
}
.ev-reentry-where {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  margin: 14px 0;
  font-size: 13px;
  color: #5A6A7E;
}
.ev-rw-item {
  display: flex;
  align-items: center;
  gap: 6px;
}
.ev-rw-item i {
  color: #0066FF;
}
/* Refund Policy section */
.ev-refund-sec {
  background: #F4F8FF;
}
.ev-refund-answer {
  background: #fff;
  border-radius: 32px;
  border: 1.5px solid #E5EAF2;
  padding: 32px 36px;
  margin-bottom: 32px;
}
@media (max-width: 680px) {
  .ev-refund-answer {
    padding: 24px 20px;
  }
}
.ev-ra-q {
  font-family: 'Montserrat', sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 20px;
}
.ev-ra-answers {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 580px) {
  .ev-ra-answers {
    grid-template-columns: 1fr;
  }
}
.ev-ra-yes,
.ev-ra-no {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px;
  border-radius: 24px;
}
.ev-ra-yes strong,
.ev-ra-no strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 4px;
}
.ev-ra-yes span,
.ev-ra-no span {
  font-size: 13px;
  line-height: 1.5;
}
.ev-ra-yes i,
.ev-ra-no i {
  font-size: 22px;
  flex-shrink: 0;
  margin-top: 2px;
}
.ev-ra-yes {
  background: #F0FDF4;
}
.ev-ra-yes i {
  color: #16A34A;
}
.ev-ra-yes strong {
  color: #15803D;
}
.ev-ra-yes span {
  color: #166534;
}
.ev-ra-no {
  background: #FFF0F0;
}
.ev-ra-no i {
  color: #DC2626;
}
.ev-ra-no strong {
  color: #B91C1C;
}
.ev-ra-no span {
  color: #991B1B;
}
/* Stages */
.ev-stages {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.ev-stage {
  background: #fff;
  border-radius: 32px;
  border: 1.5px solid #E5EAF2;
  overflow: hidden;
}
.ev-stage--refund {
  border-left: 4px solid #16A34A;
}
.ev-stage--norefund {
  border-left: 4px solid #DC2626;
}
.ev-stage-head {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 24px 28px;
  border-bottom: 1.5px solid #E5EAF2;
}
@media (max-width: 480px) {
  .ev-stage-head {
    padding: 18px 18px;
    flex-wrap: wrap;
  }
}
.ev-stage-badge {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  flex-shrink: 0;
}
.ev-stage-badge--green {
  background: #DCFCE7;
  color: #15803D;
}
.ev-stage-badge--red {
  background: #FEE2E2;
  color: #B91C1C;
}
.ev-stage-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #0F1B2D;
}
.ev-stage-title em {
  color: #0066FF;
  font-style: normal;
}
.ev-stage--norefund .ev-stage-title em {
  color: #DC2626;
}
.ev-stage-body {
  padding: 24px 28px;
}
@media (max-width: 480px) {
  .ev-stage-body {
    padding: 18px 18px;
  }
}
.ev-stage-body > p {
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.75;
  margin-bottom: 14px;
}
.ev-stage-rule {
  margin-top: 16px;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  overflow: hidden;
}
.ev-sr-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px;
  background: #F0FDF4;
}
.ev-sr-item i {
  color: #16A34A;
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 2px;
}
.ev-sr-item span {
  font-size: 13px;
  color: #15803D;
}
.ev-sr-detail {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  font-size: 12px;
  color: #5A6A7E;
  border-top: 1px solid #E5EAF2;
  background: #fff;
}
.ev-sr-detail i {
  color: #0066FF;
  flex-shrink: 0;
  margin-top: 2px;
}
.ev-reasons {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 16px;
}
.ev-reason {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px;
  background: #F4F8FF;
  border-radius: 24px;
}
.ev-reason strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 4px;
}
.ev-reason p {
  font-size: 13px;
  color: #5A6A7E;
  line-height: 1.65;
  margin: 0;
}
.ev-reason-ico {
  width: 38px;
  height: 38px;
  background: #fff;
  color: #DC2626;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
}
/* Disclaimer */
.ev-disclaimer-sec {
  background: #fff;
}
.ev-disclaimer-inner {
  max-width: 760px;
  margin: 0 auto;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  overflow: hidden;
}
.ev-disc-head {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 28px 32px;
  background: #0066FF;
}
.ev-disc-head .sec-title {
  color: #fff;
  margin: 0;
}
.ev-disc-head .sec-title em {
  color: #FFD60A;
}
@media (max-width: 480px) {
  .ev-disc-head {
    padding: 20px 20px;
  }
}
.ev-disc-ico {
  width: 48px;
  height: 48px;
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.ev-disc-body {
  padding: 28px 32px;
}
@media (max-width: 480px) {
  .ev-disc-body {
    padding: 20px 20px;
  }
}
.ev-disc-highlight {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: #E8F1FF;
  border-radius: 24px;
  padding: 16px 18px;
  margin-bottom: 20px;
}
.ev-disc-highlight i {
  color: #0066FF;
  font-size: 20px;
  flex-shrink: 0;
  margin-top: 2px;
}
.ev-disc-highlight p {
  font-size: 14px;
  color: #0F1B2D;
  line-height: 1.65;
  margin: 0;
}
.ev-disc-list {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ev-disc-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  color: #5A6A7E;
}
.ev-disc-list li i.fa-check {
  color: #16A34A;
  flex-shrink: 0;
  margin-top: 3px;
}
.ev-disc-x {
  color: #DC2626 !important;
}
.ev-disc-footer {
  font-size: 13px;
  color: #5A6A7E;
  border-top: 1px solid #E5EAF2;
  padding-top: 16px;
  margin: 0;
}
/* Responsive */
@media (max-width: 900px) {
  .ev-overview-grid {
    justify-content: flex-start;
  }
}
@media (max-width: 680px) {
  .ev-options {
    gap: 24px;
  }
  .ev-opt-title {
    font-size: 16px;
  }
  .ev-ab-title {
    font-size: 16px;
  }
  .ev-stage-head {
    gap: 10px;
  }
  .ev-stage-title {
    font-size: 16px;
  }
  .ev-refund-answer {
    padding: 20px 18px;
  }
  .ev-ra-q {
    font-size: 18px;
  }
  .ev-police-notice {
    padding: 16px 18px;
    gap: 12px;
  }
  .ev-police-ico {
    width: 36px;
    height: 36px;
  }
  .ev-reason {
    padding: 14px;
    gap: 12px;
  }
}
@media (max-width: 480px) {
  .ev-overview-sec {
    padding: 18px 0;
  }
  .ev-ov-item {
    gap: 10px;
  }
  .ev-ov-ico {
    width: 34px;
    height: 34px;
    font-size: 14px;
  }
  .ev-ov-item strong {
    font-size: 13px;
  }
  .ev-opt-title {
    font-size: 15px;
  }
  .ev-ab-title {
    font-size: 15px;
  }
  .ev-stage-title {
    font-size: 14.5px;
    flex: 1;
  }
  .ev-ra-q {
    font-size: 16px;
  }
  .ev-step-item {
    padding: 11px 0;
    gap: 10px;
  }
  .ev-step-num {
    width: 24px;
    height: 24px;
    font-size: 11px;
  }
  .ev-step-body {
    font-size: 12.5px;
  }
  .ev-police-notice {
    padding: 14px 16px;
    gap: 10px;
  }
  .ev-police-ico {
    width: 32px;
    height: 32px;
    font-size: 14px;
    border-radius: 9px;
  }
  .ev-contact-bar {
    padding: 14px 16px;
    gap: 12px;
  }
  .ev-cb-item {
    font-size: 12px;
  }
  .ev-reason {
    padding: 12px;
    gap: 10px;
  }
  .ev-reason-ico {
    width: 34px;
    height: 34px;
    font-size: 14px;
    border-radius: 9px;
  }
}
@media (max-width: 380px) {
  .ev-overview-sec {
    padding: 14px 0;
  }
  .ev-opt-title {
    font-size: 14.5px;
  }
  .ev-ab-title {
    font-size: 14px;
  }
  .ev-stage-title {
    font-size: 14px;
  }
  .ev-contact-bar {
    padding: 12px 14px;
  }
  .ev-reason {
    padding: 10px;
  }
}
/* ── Apply Now ──────────────────────────────────────────────────────────── */
.an-hero .ph-bg {
  filter: brightness(0.45) saturate(1.1);
}
/* Steps strip */
.an-steps-sec {
  background: #fff;
  border-bottom: 1.5px solid #E5EAF2;
  padding: 28px 0;
}
.an-steps-grid {
  display: flex;
  align-items: center;
  gap: 0;
  flex-wrap: wrap;
}
@media (max-width: 860px) {
  .an-steps-grid {
    gap: 16px;
  }
}
.an-step-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  flex: 1;
  min-width: 180px;
  padding: 0 28px;
}
.an-step-item:first-child {
  padding-left: 0;
}
@media (max-width: 860px) {
  .an-step-item {
    padding: 0;
    flex: 0 0 calc(50% - 8px);
  }
}
@media (max-width: 480px) {
  .an-step-item {
    flex: 0 0 100%;
  }
}
.an-step-ico {
  width: 44px;
  height: 44px;
  background: #E8F1FF;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  color: #0066FF;
  flex-shrink: 0;
}
.an-step-body strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 4px;
}
.an-step-body span {
  font-size: 12px;
  color: #5A6A7E;
  line-height: 1.5;
}
.an-step-arr {
  color: #E5EAF2;
  font-size: 14px;
  padding: 0 8px;
  flex-shrink: 0;
  padding-top: 14px;
}
@media (max-width: 860px) {
  .an-step-arr {
    display: none;
  }
}
/* Layout: sidebar + form */
.an-form-sec {
  background: #F4F8FF;
}
.an-wrap {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 40px;
  align-items: flex-start;
}
@media (max-width: 1100px) {
  .an-wrap {
    grid-template-columns: 260px 1fr;
  }
}
@media (max-width: 900px) {
  .an-wrap {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}
/* Sidebar */
.an-sidebar {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: sticky;
  top: calc(var(--header-h, 130px) + 16px);
}
.an-sb-card {
  background: #fff;
  border-radius: 24px;
  padding: 24px;
  border: 1.5px solid #E5EAF2;
}
.an-sb-card .an-sb-ico {
  width: 44px;
  height: 44px;
  background: #E8F1FF;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: #0066FF;
  margin-bottom: 14px;
}
.an-sb-card.an-sb-card--blue {
  background: #0066FF;
  border-color: #0066FF;
}
.an-sb-card.an-sb-card--blue .an-sb-ico {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}
.an-sb-card.an-sb-card--blue .an-sb-title {
  color: #fff;
}
.an-sb-card.an-sb-card--blue .an-sb-body {
  color: rgba(255, 255, 255, 0.8);
}
.an-sb-card.an-sb-card--light {
  background: #E8F1FF;
  border-color: transparent;
}
.an-sb-card.an-sb-card--light .an-sb-ico {
  background: #fff;
  color: #0066FF;
}
.an-sb-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 8px;
}
.an-sb-body {
  font-size: 13px;
  color: #5A6A7E;
  line-height: 1.7;
  margin-bottom: 14px;
}
.an-sb-links {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.an-sb-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: rgba(255, 255, 255, 0.15);
  border: 1.5px solid rgba(255, 255, 255, 0.3);
  border-radius: 10px;
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s;
}
.an-sb-btn i {
  font-size: 12px;
}
.an-sb-btn:hover {
  background: rgba(255, 255, 255, 0.25);
}
.an-sb-toc {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.an-sb-toc li a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  color: #0F1B2D;
  text-decoration: none;
  background: #fff;
  border: 1.5px solid #E5EAF2;
  transition: border-color 0.2s, color 0.2s;
}
.an-sb-toc li a span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: #0066FF;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}
.an-sb-toc li a:hover {
  border-color: #0066FF;
  color: #0066FF;
}
/* Form card */
.an-form-wrap {
  background: #fff;
  border-radius: 32px;
  border: 1.5px solid #E5EAF2;
  overflow: hidden;
}
/* Disclaimer */
.an-disclaimer {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: #E8F1FF;
  border-bottom: 1.5px solid #c9deff;
  padding: 18px 24px;
}
.an-disclaimer i {
  font-size: 18px;
  color: #0066FF;
  flex-shrink: 0;
  margin-top: 2px;
}
.an-disclaimer div {
  font-size: 13px;
  color: #0F1B2D;
  line-height: 1.7;
}
.an-disclaimer strong {
  color: #0066FF;
}
.an-disclaimer .an-req {
  color: #e53e3e;
  font-size: 14px;
}
.an-form {
  padding: 0;
}
/* Form section */
.an-section {
  border-bottom: 1.5px solid #E5EAF2;
}
.an-section:last-of-type {
  border-bottom: 0;
}
.an-section-head {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 28px;
  background: #F4F8FF;
  border-bottom: 1.5px solid #E5EAF2;
}
.an-sh-num {
  width: 44px;
  height: 44px;
  background: #0066FF;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
}
.an-sh-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: #0F1B2D;
  margin-bottom: 3px;
}
.an-sh-title i {
  color: #0066FF;
  margin-right: 6px;
}
.an-sh-sub {
  font-size: 12px;
  color: #5A6A7E;
}
/* Fields grid */
.an-section-body {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  padding: 8px 20px 20px;
}
.an-section-sub-head {
  width: 100%;
  padding: 16px 8px 8px;
  font-size: 12px;
  font-weight: 700;
  color: #5A6A7E;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-top: 1px solid #E5EAF2;
  margin-top: 8px;
}
.an-section-sub-head i {
  margin-right: 6px;
  color: #0066FF;
}
.an-section-sub-head:first-child {
  border-top: 0;
  margin-top: 0;
}
.an-field {
  padding: 10px 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.an-field.an-field--full {
  width: 100%;
}
.an-field.an-field--half {
  width: 50%;
}
@media (max-width: 580px) {
  .an-field.an-field--half {
    width: 100%;
  }
}
.an-field.an-field--third {
  width: 33.333%;
}
@media (max-width: 680px) {
  .an-field.an-field--third {
    width: 50%;
  }
}
@media (max-width: 480px) {
  .an-field.an-field--third {
    width: 100%;
  }
}
.an-field.an-field--quarter {
  width: 25%;
}
@media (max-width: 680px) {
  .an-field.an-field--quarter {
    width: 50%;
  }
}
@media (max-width: 480px) {
  .an-field.an-field--quarter {
    width: 100%;
  }
}
.an-label {
  font-size: 12px;
  font-weight: 700;
  color: #0F1B2D;
  letter-spacing: 0.02em;
}
.an-req {
  color: #e53e3e;
  margin-left: 2px;
}
.an-hint {
  font-size: 11px;
  color: #5A6A7E;
}
.an-hint i {
  margin-right: 4px;
  color: #0066FF;
}
.an-input {
  height: 44px;
  padding: 0 14px;
  border: 1.5px solid #E5EAF2;
  border-radius: 10px;
  font-size: 14px;
  color: #0F1B2D;
  background: #fff;
  width: 100%;
  font-family: 'Lato', sans-serif;
  transition: border-color 0.2s, box-shadow 0.2s;
  outline: none;
}
.an-input::placeholder {
  color: #8998ab;
}
.an-input:focus {
  border-color: #0066FF;
  box-shadow: 0 0 0 3px rgba(0, 102, 255, 0.1);
}
.an-input:valid:not(:placeholder-shown) {
  border-color: #00f7e3;
}
.an-select-wrap {
  position: relative;
}
.an-select-wrap::after {
  content: '\f107';
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  color: #5A6A7E;
  pointer-events: none;
}
.an-select {
  height: 44px;
  padding: 0 36px 0 14px;
  border: 1.5px solid #E5EAF2;
  border-radius: 10px;
  font-size: 14px;
  color: #0F1B2D;
  background: #fff;
  width: 100%;
  font-family: 'Lato', sans-serif;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s;
  outline: none;
}
.an-select:focus {
  border-color: #0066FF;
  box-shadow: 0 0 0 3px rgba(0, 102, 255, 0.1);
}
.an-select:invalid,
.an-select[value=""] {
  color: #8998ab;
}
/* Date of birth row */
.an-dob-row {
  display: flex;
  gap: 10px;
}
.an-dob-row .an-select-wrap {
  flex: 1;
}
.an-dob-row .an-dob-month {
  flex: 1.6;
}
.an-dob-row .an-dob-year {
  flex: 1.4;
}
@media (max-width: 400px) {
  .an-dob-row {
    flex-wrap: wrap;
  }
  .an-dob-row .an-select-wrap,
  .an-dob-row .an-dob-month,
  .an-dob-row .an-dob-year {
    flex: 0 0 100%;
  }
}
/* Submit */
.an-submit-wrap {
  padding: 28px;
  background: #F4F8FF;
  border-top: 1.5px solid #E5EAF2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  text-align: center;
}
.an-submit-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  max-width: 560px;
}
.an-submit-note i {
  color: #0066FF;
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 2px;
}
.an-submit-note p {
  font-size: 13px;
  color: #5A6A7E;
  line-height: 1.7;
  margin: 0;
}
.an-submit-btn {
  padding: 16px 40px;
  font-size: 16px;
  border-radius: 14px;
}
.an-submit-btn i {
  margin-left: 8px;
}
.an-submit-small {
  font-size: 12px;
  color: #5A6A7E;
  margin: 0;
}
/* Responsive */
@media (max-width: 900px) {
  .an-sidebar {
    position: static;
  }
  .an-sb-toc {
    display: none;
  }
}
@media (max-width: 680px) {
  .an-section-head {
    padding: 16px 18px;
  }
  .an-section-body {
    padding: 6px 12px 16px;
  }
  .an-disclaimer {
    padding: 14px 16px;
  }
  .an-submit-wrap {
    padding: 20px 18px;
  }
  .an-sb-card:first-child {
    display: none;
  }
  .an-steps-sec {
    padding: 20px 0;
  }
  .an-step-ico {
    width: 38px;
    height: 38px;
    font-size: 15px;
    border-radius: 10px;
  }
  .an-sh-num {
    width: 38px;
    height: 38px;
    font-size: 14px;
    border-radius: 10px;
  }
}
@media (max-width: 480px) {
  .an-sb-card {
    padding: 18px 16px;
  }
  .an-sb-title {
    font-size: 14px;
  }
  .an-section-head {
    padding: 14px;
    gap: 10px;
  }
  .an-sh-num {
    width: 34px;
    height: 34px;
    font-size: 12px;
    border-radius: 9px;
  }
  .an-input,
  .an-select {
    height: 42px;
    font-size: 13.5px;
  }
  .an-disclaimer {
    padding: 12px 14px;
  }
  .an-disclaimer div {
    font-size: 12.5px;
  }
  .an-submit-btn {
    width: 100%;
    justify-content: center;
    font-size: 14px;
    padding: 14px 24px;
  }
  .an-submit-note p {
    font-size: 12.5px;
  }
  .an-step-body strong {
    font-size: 13px;
  }
  .an-step-body span {
    font-size: 11.5px;
  }
}
/* ── Journey Chapter (jc-) ──────────────────────────────────────────────── */
.jc-hero .ph-bg {
  filter: brightness(0.42) saturate(1.2);
}
/* ── Chapter nav tab bar */
.jc-nav-wrap {
  background: #fff;
  border-bottom: 1.5px solid #E5EAF2;
  transition: box-shadow 0.25s;
  z-index: 70;
  position: sticky;
  top: var(--header-h, 130px);
}
.jc-nav-wrap.jc-nav-stuck {
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.09);
}
.jc-nav {
  display: flex;
  align-items: stretch;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.jc-nav::-webkit-scrollbar {
  display: none;
}
.jc-nav-tab {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 16px 22px;
  font-size: 13px;
  font-weight: 600;
  color: #5A6A7E;
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 3px solid transparent;
  transition: color 0.2s, border-color 0.2s;
  flex-shrink: 0;
}
.jc-nav-tab .jc-nav-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: #E5EAF2;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 800;
  color: #5A6A7E;
  transition: background 0.2s, color 0.2s;
  flex-shrink: 0;
}
.jc-nav-tab .jc-nav-lock {
  font-size: 10px;
  color: #8f9daf;
}
.jc-nav-tab:hover:not(.jc-nav-locked) {
  color: #0066FF;
}
.jc-nav-tab.jc-nav-active {
  color: #0066FF;
  border-bottom-color: #0066FF;
}
.jc-nav-tab.jc-nav-active .jc-nav-num {
  background: #0066FF;
  color: #fff;
}
.jc-nav-tab.jc-nav-locked {
  opacity: 0.55;
  cursor: default;
  pointer-events: none;
}
@media (max-width: 580px) {
  .jc-nav-tab {
    padding: 13px 14px;
    font-size: 12px;
  }
}
.jc-nav-right {
  margin-left: auto;
  display: flex;
  align-items: center;
  padding: 0 0 0 16px;
  flex-shrink: 0;
}
.jc-nav-audio-btn {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 9px 16px;
  background: #E8F1FF;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 700;
  color: #0066FF;
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.2s;
}
.jc-nav-audio-btn i {
  font-size: 12px;
}
.jc-nav-audio-btn:hover {
  background: #cee1ff;
}
@media (max-width: 680px) {
  .jc-nav-audio-btn {
    display: none;
  }
}
/* ── Chapter section */
.jc-chapter-sec {
  background: #F4F8FF;
}
/* Chapter intro card */
.jc-chapter-intro {
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 32px;
  padding: 32px;
  margin-bottom: 40px;
  position: relative;
  overflow: hidden;
}
.jc-chapter-intro::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 5px;
  height: 100%;
  background: linear-gradient(180deg, #0066FF 0%, #00C4B4 100%);
}
.jc-ci-tag {
  display: inline-block;
  background: #0066FF;
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 20px;
  margin-bottom: 16px;
  margin-left: 12px;
}
.jc-ci-inner {
  display: flex;
  gap: 32px;
  align-items: flex-start;
  margin-left: 12px;
}
@media (max-width: 760px) {
  .jc-ci-inner {
    flex-direction: column;
    gap: 24px;
  }
}
.jc-ci-left {
  flex: 1;
}
.jc-ci-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 28px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 8px;
}
.jc-ci-title em {
  color: #0066FF;
  font-style: normal;
}
.jc-ci-sub {
  font-size: 15px;
  color: #5A6A7E;
  margin-bottom: 20px;
  line-height: 1.7;
}
.jc-ci-learn {
  background: #E8F1FF;
  border-radius: 12px;
  padding: 18px 20px;
}
.jc-ci-learn strong {
  font-size: 13px;
  font-weight: 700;
  color: #0F1B2D;
  display: block;
  margin-bottom: 10px;
}
.jc-ci-learn strong i {
  color: #0066FF;
  margin-right: 6px;
}
.jc-ci-list {
  margin: 0;
  padding-left: 20px;
}
.jc-ci-list li {
  font-size: 14px;
  color: #0F1B2D;
  line-height: 1.8;
}
.jc-ci-list li::marker {
  color: #0066FF;
  font-weight: 700;
}
.jc-ci-stats {
  display: flex;
  align-items: center;
  gap: 0;
  background: #0066FF;
  border-radius: 24px;
  padding: 24px 28px;
  flex-shrink: 0;
}
@media (max-width: 760px) {
  .jc-ci-stats {
    width: 100%;
    justify-content: center;
  }
}
.jc-ci-stat {
  text-align: center;
  padding: 0 20px;
}
.jc-ci-snum {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 36px;
  font-weight: 800;
  color: #fff;
  line-height: 1;
  margin-bottom: 4px;
}
.jc-ci-slabel {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.7);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.jc-ci-sdiv {
  width: 1px;
  height: 40px;
  background: rgba(255, 255, 255, 0.2);
}
/* Part block */
.jc-part {
  margin-bottom: 48px;
}
.jc-part-head {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 20px;
}
.jc-part-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #0F1B2D;
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 20px;
  flex-shrink: 0;
  margin-top: 4px;
}
.jc-part-head-body {
  flex: 1;
}
.jc-part-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: #0F1B2D;
  margin-bottom: 6px;
}
.jc-part-sub {
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.7;
  margin: 0;
}
/* Vocab preview strip */
.jc-vocab-strip {
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  overflow: hidden;
  margin-bottom: 24px;
}
.jc-vocab-head {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  background: #0F1B2D;
  padding: 10px 20px;
}
.jc-vocab-head span {
  font-size: 11px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.7);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.jc-vocab-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  padding: 11px 20px;
  border-bottom: 1px solid #E5EAF2;
  align-items: center;
  transition: background 0.15s;
}
.jc-vocab-row:last-of-type {
  border-bottom: 0;
}
.jc-vocab-row:hover {
  background: #E8F1FF;
}
.jc-vc-en {
  font-size: 14px;
  font-weight: 600;
  color: #0F1B2D;
}
.jc-vc-ph {
  font-size: 14px;
  color: #5A6A7E;
  font-style: italic;
}
.jc-vc-th {
  font-size: 16px;
  color: #0066FF;
  font-weight: 600;
}
.jc-vocab-more {
  padding: 10px 20px;
  font-size: 12px;
  color: #5A6A7E;
  background: #F4F8FF;
  border-top: 1px solid #E5EAF2;
}
.jc-vocab-more i {
  color: #0066FF;
  margin-right: 5px;
}
/* Resource card grid */
.jc-resource-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
@media (max-width: 760px) {
  .jc-resource-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.jc-resource-card {
  background: #fff;
  border: 1.5px solid #E5EAF2;
  border-radius: 24px;
  overflow: hidden;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: transform 0.25s, box-shadow 0.25s, border-color 0.25s;
}
.jc-resource-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
  border-color: #0066FF;
}
.jc-resource-card:hover .jc-rc-overlay {
  opacity: 1;
}
.jc-resource-card:hover .jc-rc-play {
  transform: scale(1.08);
}
.jc-resource-card:hover .jc-rc-cta {
  color: #0066FF;
}
.jc-resource-card:hover .jc-rc-cta i {
  transform: translateX(4px);
}
.jc-rc-thumb {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
}
.jc-rc-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s;
}
.jc-resource-card:hover .jc-rc-thumb img {
  transform: scale(1.04);
}
.jc-rc-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  opacity: 0;
  transition: opacity 0.25s;
}
.jc-rc-play {
  width: 56px;
  height: 56px;
  background: #FFD60A;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  color: #0F1B2D;
  transition: transform 0.25s;
  padding-left: 4px;
}
.jc-rc-watch-label {
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.03em;
}
.jc-rc-type-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
}
.jc-rc-type-badge i {
  font-size: 10px;
}
.jc-rc-type--vocab {
  background: #0066FF;
  color: #fff;
}
.jc-rc-type--flash {
  background: #00C4B4;
  color: #fff;
}
.jc-rc-body {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.jc-rc-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  width: fit-content;
}
.jc-rc-label i {
  font-size: 10px;
}
.jc-rc-label--vocab {
  background: #E8F1FF;
  color: #0066FF;
}
.jc-rc-label--flash {
  background: #e0faf7;
  color: #00C4B4;
}
.jc-rc-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  font-weight: 800;
  color: #0F1B2D;
  line-height: 1.3;
}
.jc-rc-desc {
  font-size: 13px;
  color: #5A6A7E;
  line-height: 1.7;
  margin: 0;
  flex: 1;
}
.jc-rc-meta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.jc-rc-meta span {
  font-size: 12px;
  color: #5A6A7E;
  display: flex;
  align-items: center;
  gap: 5px;
}
.jc-rc-meta span i {
  color: #0066FF;
  font-size: 11px;
}
.jc-rc-cta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 700;
  color: #0F1B2D;
  margin-top: 4px;
  transition: color 0.2s;
}
.jc-rc-cta i {
  transition: transform 0.2s;
  font-size: 11px;
}
/* Chapter break divider */
.jc-chapter-break {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 48px 0 36px;
}
.jc-cb-line {
  flex: 1;
  height: 1px;
  background: #E5EAF2;
}
.jc-cb-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #5A6A7E;
  white-space: nowrap;
  background: #F4F8FF;
  padding: 4px 16px;
  border: 1.5px solid #E5EAF2;
  border-radius: 20px;
}
/* Chapter 2 intro tag colour */
.jc-ci-tag--2 {
  background: #00C4B4;
}
/* Chapter 3 intro tag colour */
.jc-ci-tag--3 {
  background: #7C3AED;
}
/* Chapter 4 intro tag colour */
.jc-ci-tag--4 {
  background: #D97706;
}
/* Chapter 5 intro tag colour */
.jc-ci-tag--5 {
  background: #059669;
}
/* Chapter 6 intro tag colour */
.jc-ci-tag--6 {
  background: #E11D48;
}
/* Chapter 7 intro tag colour */
.jc-ci-tag--7 {
  background: #C026D3;
}
/* Chapter 8 intro tag colour */
.jc-ci-tag--8 {
  background: #EA580C;
}
/* Chapter 9 intro tag colour */
.jc-ci-tag--9 {
  background: #0891B2;
}
/* Chapter 10 intro tag colour */
.jc-ci-tag--10 {
  background: #16A34A;
}
/* Part badge dialogue variant */
.jc-part-badge--dialogue {
  background: #F97316;
}
/* Dialogue resource type */
.jc-rc-type--dialogue {
  background: #F97316;
  color: #fff;
}
.jc-rc-label--dialogue {
  background: #FFF0E8;
  color: #C2410C;
}
/* Exercise resource type (Explore series) */
.jc-rc-type--exercise {
  background: #6366F1;
  color: #fff;
}
.jc-rc-label--exercise {
  background: #E0E7FF;
  color: #3730A3;
}
.jc-part-badge--exercise {
  background: #6366F1;
}
/* 3-column resource grid (Explore series) */
.jc-resource-grid--3 {
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 980px) {
  .jc-resource-grid--3 {
    grid-template-columns: repeat(2, 1fr);
  }
  .jc-resource-grid--3 > a:nth-child(3) {
    grid-column: 1 / -1;
    max-width: 520px;
    margin: 0 auto;
  }
}
@media (max-width: 680px) {
  .jc-resource-grid--3 {
    grid-template-columns: 1fr;
  }
  .jc-resource-grid--3 > a:nth-child(3) {
    max-width: none;
    margin: 0;
  }
}
/* Coming-soon single card */
.jc-coming-single {
  grid-template-columns: 1fr;
  max-width: 480px;
}
/* Coming-soon chapters */
.jc-coming-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 8px;
}
@media (max-width: 680px) {
  .jc-coming-grid {
    grid-template-columns: 1fr;
  }
}
.jc-coming-card {
  background: #fff;
  border: 1.5px dashed #E5EAF2;
  border-radius: 24px;
  padding: 32px 28px;
  text-align: center;
}
.jc-coming-lock {
  width: 48px;
  height: 48px;
  background: #F4F8FF;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 14px;
  font-size: 18px;
  color: #8f9daf;
}
.jc-coming-num {
  font-size: 11px;
  font-weight: 700;
  color: #5A6A7E;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 6px;
}
.jc-coming-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: #3560a0;
  margin-bottom: 10px;
}
.jc-coming-body {
  font-size: 13px;
  color: #8090a4;
  line-height: 1.7;
  margin-bottom: 16px;
}
.jc-coming-badge {
  display: inline-block;
  background: #F4F8FF;
  border: 1.5px solid #E5EAF2;
  border-radius: 20px;
  padding: 5px 16px;
  font-size: 11px;
  font-weight: 700;
  color: #5A6A7E;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
/* Responsive */
@media (max-width: 760px) {
  .jc-vocab-head,
  .jc-vocab-row {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .jc-vc-th {
    font-size: 14px;
  }
  .jc-chapter-intro {
    padding: 24px 20px;
  }
  .jc-ci-title {
    font-size: 22px;
  }
}
@media (max-width: 480px) {
  .jc-vocab-head,
  .jc-vocab-row {
    grid-template-columns: 1fr 1fr;
  }
  .jc-vocab-head span:last-child,
  .jc-vc-th {
    display: none;
  }
  .jc-part-head {
    flex-direction: column;
    gap: 10px;
  }
  .jc-chapter-intro {
    padding: 18px 16px;
  }
  .jc-ci-stats {
    padding: 16px 12px;
  }
  .jc-ci-stat {
    padding: 0 12px;
  }
  .jc-ci-snum {
    font-size: 26px;
  }
  .jc-part-title {
    font-size: 18px;
  }
  .jc-chapter-break {
    margin: 36px 0 24px;
  }
}
@media (max-width: 380px) {
  .jc-chapter-intro {
    padding: 14px 12px;
  }
  .jc-ci-title {
    font-size: 18px;
  }
  .jc-ci-stats {
    padding: 12px 8px;
  }
  .jc-ci-stat {
    padding: 0 8px;
  }
  .jc-ci-snum {
    font-size: 22px;
  }
}
/* ═══════════════════════════════════════════════════════════════════════════
   CONTACT PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
/* Quick contact strip */
.cn-quick-sec {
  padding: 56px 0 24px;
  background: transparent;
}
.cn-quick-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.cn-quick-card {
  display: flex;
  align-items: center;
  gap: 18px;
  background: #fff;
  border-radius: 20px;
  padding: 22px 24px;
  border: 2px solid #E5EAF2;
  box-shadow: 0 8px 32px rgba(15, 27, 45, 0.04);
  transition: all 0.3s ease;
  text-decoration: none;
  position: relative;
  overflow: hidden;
}
.cn-quick-card::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: #0066FF;
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 0.35s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.cn-quick-card:hover {
  transform: translateY(-4px);
  border-color: #E8F1FF;
  box-shadow: 0 18px 48px rgba(0, 102, 255, 0.16);
}
.cn-quick-card:hover::after {
  transform: scaleY(1);
}
.cn-qc-ico {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: #E8F1FF;
  color: #0066FF;
  display: grid;
  place-items: center;
  font-size: 22px;
  flex-shrink: 0;
  transition: all 0.3s ease;
}
.cn-quick-card:hover .cn-qc-ico {
  transform: scale(1.06) rotate(-4deg);
}
.cn-qc--phone:hover .cn-qc-ico {
  background: #0066FF;
  color: #fff;
}
.cn-qc--line .cn-qc-ico {
  background: rgba(6, 199, 85, 0.1);
  color: #06c755;
}
.cn-qc--line:hover .cn-qc-ico {
  background: #06c755;
  color: #fff;
}
.cn-qc--email .cn-qc-ico {
  background: rgba(255, 176, 0, 0.12);
  color: #F57C00;
}
.cn-qc--email:hover .cn-qc-ico {
  background: #F57C00;
  color: #fff;
}
.cn-qc-body {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  flex: 1;
}
.cn-qc-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #5A6A7E;
}
.cn-qc-value {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: #0F1B2D;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cn-qc-hint {
  font-family: 'Lato', sans-serif;
  font-size: 12px;
  color: #5A6A7E;
}
.cn-qc-arr {
  font-size: 14px;
  color: #5A6A7E;
  transition: all 0.3s ease;
  flex-shrink: 0;
}
.cn-quick-card:hover .cn-qc-arr {
  color: #0066FF;
  transform: translateX(4px);
}
/* Main: form + sidebar split */
.cn-main-sec {
  padding: 100px 0 100px;
  background: #F4F8FF;
}
.cn-main-grid {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 36px;
  align-items: start;
}
/* Info sidebar */
.cn-info {
  position: sticky;
  top: calc(var(--header-h, 130px) + 16px);
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.cn-info-card {
  background: #fff;
  border-radius: 24px;
  padding: 36px 32px;
  border: 1px solid #E5EAF2;
  box-shadow: 0 12px 48px rgba(0, 102, 255, 0.06);
  position: relative;
  overflow: hidden;
}
.cn-info-card::before {
  content: '';
  position: absolute;
  right: -60px;
  top: -60px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(0, 102, 255, 0.08), rgba(0, 102, 255, 0));
}
.cn-info-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 24px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 10px 0 12px;
  line-height: 1.2;
  position: relative;
}
.cn-info-blurb {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.65;
  margin: 0 0 26px;
  position: relative;
}
.cn-info-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: relative;
}
.cn-info-list li {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.cn-il-ico {
  width: 38px;
  height: 38px;
  border-radius: 11px;
  background: #E8F1FF;
  color: #0066FF;
  display: grid;
  place-items: center;
  font-size: 14px;
  flex-shrink: 0;
  transition: all 0.3s;
}
.cn-info-list li:hover .cn-il-ico {
  background: #0066FF;
  color: #fff;
}
.cn-il-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  flex: 1;
}
.cn-il-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #5A6A7E;
}
.cn-il-val {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #0F1B2D;
  line-height: 1.55;
  text-decoration: none;
  transition: color 0.2s;
}
a.cn-il-val:hover {
  color: #0066FF;
}
.cn-socials {
  margin-top: 26px;
  padding-top: 22px;
  border-top: 1px dashed #E5EAF2;
  position: relative;
}
.cn-socials-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #5A6A7E;
  display: block;
  margin-bottom: 12px;
}
.cn-socials-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.cn-social {
  width: 40px;
  height: 40px;
  border-radius: 11px;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 15px;
  text-decoration: none;
  transition: all 0.3s ease;
}
.cn-social--fb {
  background: #1877f2;
}
.cn-social--ig {
  background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
}
.cn-social--yt {
  background: #FF0000;
}
.cn-social--tt {
  background: #0F1B2D;
}
.cn-social:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(15, 27, 45, 0.18);
}
/* BTS callout */
.cn-bts-card {
  background: linear-gradient(135deg, #0F1B2D 0%, #192d4c 100%);
  color: #fff;
  border-radius: 20px;
  padding: 22px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  position: relative;
  overflow: hidden;
}
.cn-bts-card::before {
  content: '';
  position: absolute;
  right: -40px;
  top: 50%;
  transform: translateY(-50%);
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: rgba(255, 214, 10, 0.08);
}
.cn-bts-card::after {
  content: '';
  position: absolute;
  right: 20px;
  bottom: -30px;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: rgba(0, 102, 255, 0.12);
}
.cn-bts-ico {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: #FFD60A;
  color: #0F1B2D;
  display: grid;
  place-items: center;
  font-size: 20px;
  flex-shrink: 0;
  position: relative;
  box-shadow: 0 6px 18px rgba(255, 214, 10, 0.4);
}
.cn-bts-body {
  position: relative;
  flex: 1;
}
.cn-bts-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #FFD60A;
  display: block;
}
.cn-bts-body h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 800;
  margin: 3px 0 3px;
  color: #fff;
}
.cn-bts-body p {
  font-family: 'Lato', sans-serif;
  font-size: 12.5px;
  opacity: 0.8;
  margin: 0;
  line-height: 1.5;
}
/* Form card */
.cn-form-card {
  background: #fff;
  border-radius: 28px;
  padding: 48px 48px;
  border: 1px solid #E5EAF2;
  box-shadow: 0 16px 64px rgba(15, 27, 45, 0.06);
}
.cn-form-head {
  margin-bottom: 34px;
  padding-bottom: 28px;
  border-bottom: 1px solid #E5EAF2;
}
.cn-form-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 38px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 10px 0 12px;
  line-height: 1.15;
}
.cn-form-title em {
  color: #0066FF;
  font-style: normal;
}
.cn-form-sub {
  font-family: 'Lato', sans-serif;
  font-size: 15px;
  color: #5A6A7E;
  line-height: 1.65;
  margin: 0;
}
/* Form fields */
.cn-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.cn-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cn-field--full {
  grid-column: 1 / -1;
}
.cn-field--half {
  grid-column: span 1;
}
.cn-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.4px;
  color: #0F1B2D;
}
.cn-req {
  color: #e11d48;
  margin-left: 2px;
}
.cn-input,
.cn-textarea,
.cn-select {
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  color: #0F1B2D;
  background: #F4F8FF;
  border: 2px solid #E5EAF2;
  border-radius: 12px;
  padding: 14px 16px;
  width: 100%;
  transition: all 0.25s ease;
  outline: none;
}
.cn-input::placeholder,
.cn-textarea::placeholder {
  color: #8090a4;
}
.cn-input:focus,
.cn-textarea:focus,
.cn-select:focus {
  background: #fff;
  border-color: #0066FF;
  box-shadow: 0 0 0 4px rgba(0, 102, 255, 0.1);
}
.cn-textarea {
  resize: vertical;
  min-height: 140px;
  line-height: 1.55;
}
.cn-select-wrap {
  position: relative;
}
.cn-select-wrap::after {
  content: '\f078';
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  color: #5A6A7E;
  font-size: 11px;
  pointer-events: none;
}
.cn-select {
  padding-right: 42px;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  cursor: pointer;
}
.cn-submit-wrap {
  margin-top: 14px;
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.cn-submit-btn {
  font-family: 'Montserrat', sans-serif;
  font-size: 13.5px;
  font-weight: 800;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  background: #0066FF;
  color: #fff;
  padding: 18px 36px;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: all 0.3s ease;
  box-shadow: 0 10px 32px rgba(0, 102, 255, 0.32);
}
.cn-submit-btn:hover {
  background: #003FB5;
  transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(0, 102, 255, 0.42);
}
.cn-submit-btn i {
  font-size: 13px;
  transition: transform 0.3s;
}
.cn-submit-btn:hover i {
  transform: translateX(4px);
}
.cn-submit-note {
  font-family: 'Lato', sans-serif;
  font-size: 12.5px;
  color: #5A6A7E;
  margin: 0;
  flex: 1;
  min-width: 200px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  line-height: 1.5;
}
.cn-submit-note i {
  color: #0066FF;
  font-size: 11px;
  flex-shrink: 0;
}
/* Map section */
.cn-map-sec {
  padding: 100px 0 100px;
  background: #fff;
}
.cn-map-head {
  text-align: center;
  max-width: 680px;
  margin: 0 auto 48px;
}
.cn-map-card {
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 18px 56px rgba(15, 27, 45, 0.1);
  border: 6px solid #fff;
  margin-bottom: 48px;
  background: #fff;
}
.cn-map-card iframe {
  display: block;
  border: 0;
}
.cn-map-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  padding: 18px 24px;
  background: #F4F8FF;
  border-top: 1px solid #E5EAF2;
  flex-wrap: wrap;
}
.cn-map-addr {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #0F1B2D;
}
.cn-map-addr i {
  color: #0066FF;
  font-size: 15px;
}
.cn-map-link {
  font-family: 'Montserrat', sans-serif;
  font-size: 12.5px;
  font-weight: 700;
  color: #0066FF;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 50px;
  background: rgba(0, 102, 255, 0.08);
  transition: all 0.25s;
}
.cn-map-link:hover {
  background: #0066FF;
  color: #fff;
}
.cn-map-link i {
  font-size: 10px;
}
/* Directions cards */
.cn-directions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.cn-dir-card {
  background: #fff;
  border-radius: 20px;
  padding: 32px 28px;
  border: 1px solid #E5EAF2;
  text-align: center;
  transition: all 0.3s ease;
  position: relative;
}
.cn-dir-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 44px rgba(0, 102, 255, 0.12);
  border-color: #E8F1FF;
}
.cn-dir-ico {
  width: 64px;
  height: 64px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  font-size: 26px;
  margin: 0 auto 18px;
  transition: all 0.3s ease;
}
.cn-dir-ico--bts {
  background: #E8F1FF;
  color: #0066FF;
}
.cn-dir-ico--mrt {
  background: rgba(0, 196, 180, 0.12);
  color: #00C4B4;
}
.cn-dir-ico--car {
  background: rgba(255, 214, 10, 0.18);
  color: #B45309;
}
.cn-dir-card:hover .cn-dir-ico {
  transform: scale(1.08);
}
.cn-dir-card h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: 19px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 0 0 10px;
}
.cn-dir-card p {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.65;
  margin: 0 0 18px;
}
.cn-dir-meta {
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: #0066FF;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: 50px;
  background: #E8F1FF;
}
.cn-dir-meta i {
  font-size: 11px;
}
/* Responsive — Contact page */
@media (max-width: 1100px) {
  .cn-main-grid {
    grid-template-columns: 340px 1fr;
    gap: 28px;
  }
  .cn-form-card {
    padding: 36px 32px;
  }
  .cn-form-title {
    font-size: 32px;
  }
}
@media (max-width: 980px) {
  .cn-main-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .cn-info {
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .cn-info-card {
    flex: 1 1 100%;
  }
  .cn-bts-card {
    flex: 1 1 100%;
  }
  .cn-quick-grid {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .cn-quick-card:nth-child(3) {
    grid-column: 1 / -1;
  }
  .cn-directions {
    grid-template-columns: 1fr 1fr;
    gap: 18px;
  }
  .cn-dir-card:nth-child(3) {
    grid-column: 1 / -1;
  }
}
@media (max-width: 680px) {
  .cn-quick-sec {
    padding: 40px 0 16px;
  }
  .cn-main-sec {
    padding: 60px 0 72px;
  }
  .cn-map-sec {
    padding: 64px 0 72px;
  }
  .cn-quick-grid {
    grid-template-columns: 1fr;
  }
  .cn-quick-card:nth-child(3) {
    grid-column: auto;
  }
  .cn-quick-card {
    padding: 18px 20px;
  }
  .cn-qc-value {
    font-size: 15px;
  }
  .cn-qc-ico {
    width: 48px;
    height: 48px;
    font-size: 19px;
  }
  .cn-form {
    grid-template-columns: 1fr;
  }
  .cn-field--half {
    grid-column: 1 / -1;
  }
  .cn-form-card {
    padding: 28px 22px;
  }
  .cn-form-title {
    font-size: 26px;
  }
  .cn-info-card {
    padding: 28px 24px;
  }
  .cn-info-title {
    font-size: 21px;
  }
  .cn-submit-btn {
    width: 100%;
    justify-content: center;
  }
  .cn-submit-note {
    font-size: 12px;
  }
  .cn-map-card iframe {
    height: 340px;
  }
  .cn-map-footer {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  .cn-directions {
    grid-template-columns: 1fr;
  }
  .cn-dir-card:nth-child(3) {
    grid-column: auto;
  }
  .cn-dir-card {
    padding: 26px 22px;
  }
}
@media (max-width: 480px) {
  .cn-quick-card {
    padding: 16px 18px;
  }
  .cn-qc-ico {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    font-size: 18px;
  }
  .cn-qc-value {
    font-size: 13.5px;
  }
  .cn-qc-hint {
    font-size: 11px;
  }
  .cn-info-card {
    padding: 24px 20px;
  }
  .cn-info-title {
    font-size: 20px;
  }
  .cn-info-list {
    gap: 16px;
  }
  .cn-info-list li {
    gap: 12px;
  }
  .cn-il-ico {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    font-size: 13px;
  }
  .cn-bts-ico {
    width: 42px;
    height: 42px;
    font-size: 18px;
  }
  .cn-bts-body h4 {
    font-size: 16px;
  }
  .cn-bts-card {
    padding: 18px 20px;
  }
  .cn-form-card {
    padding: 22px 20px;
  }
  .cn-form-title {
    font-size: 22px;
  }
  .cn-input,
  .cn-textarea,
  .cn-select {
    font-size: 16px;
  }
  .cn-submit-btn {
    padding: 15px 28px;
    font-size: 13px;
  }
  .cn-map-sec {
    padding: 52px 0 60px;
  }
  .cn-map-card {
    margin-bottom: 32px;
  }
  .cn-map-card iframe {
    height: 260px;
  }
  .cn-map-addr {
    font-size: 13px;
  }
  .cn-dir-card {
    padding: 24px 20px;
  }
  .cn-dir-ico {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    font-size: 22px;
    margin-bottom: 14px;
  }
  .cn-dir-card h4 {
    font-size: 16px;
  }
  .cn-dir-card p {
    font-size: 13px;
  }
}
@media (max-width: 380px) {
  .cn-quick-card {
    padding: 14px 16px;
  }
  .cn-qc-value {
    font-size: 13px;
  }
  .cn-info-card {
    padding: 20px 16px;
  }
  .cn-info-title {
    font-size: 18px;
  }
  .cn-bts-card {
    padding: 16px 16px;
  }
  .cn-form-card {
    padding: 18px 16px;
  }
  .cn-form-title {
    font-size: 20px;
  }
  .cn-map-card iframe {
    height: 240px;
  }
  .cn-dir-card {
    padding: 20px 16px;
  }
}
/* ═══════════════════════════════════════════════════════════════════════════
   ENGLISH COURSE LANDING PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
/* Common section head */
.en-sec-head {
  text-align: center;
  max-width: 740px;
  margin: 0 auto 56px;
}
/* Quick action strip */
.en-quick-sec {
  padding: 56px 0 24px;
  background: transparent;
}
.en-quick-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.en-quick-card {
  display: flex;
  align-items: center;
  gap: 18px;
  background: #fff;
  border-radius: 20px;
  padding: 24px 26px;
  border: 2px solid #E5EAF2;
  box-shadow: 0 8px 32px rgba(15, 27, 45, 0.04);
  transition: all 0.3s ease;
  text-decoration: none;
  position: relative;
  overflow: hidden;
}
.en-quick-card::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: #0066FF;
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 0.35s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.en-quick-card:hover {
  transform: translateY(-4px);
  border-color: #E8F1FF;
  box-shadow: 0 18px 48px rgba(0, 102, 255, 0.16);
}
.en-quick-card:hover::after {
  transform: scaleY(1);
}
.en-qc-ico {
  width: 60px;
  height: 60px;
  border-radius: 18px;
  background: #E8F1FF;
  color: #0066FF;
  display: grid;
  place-items: center;
  font-size: 24px;
  flex-shrink: 0;
  transition: all 0.3s ease;
}
.en-quick-card:hover .en-qc-ico {
  transform: scale(1.06) rotate(-4deg);
}
.en-qc--fees:hover .en-qc-ico {
  background: #0066FF;
  color: #fff;
}
.en-qc--schedule .en-qc-ico {
  background: rgba(0, 196, 180, 0.12);
  color: #00C4B4;
}
.en-qc--schedule:hover .en-qc-ico {
  background: #00C4B4;
  color: #fff;
}
.en-qc--ielts .en-qc-ico {
  background: rgba(255, 214, 10, 0.18);
  color: #B45309;
}
.en-qc--ielts:hover .en-qc-ico {
  background: #FFD60A;
  color: #0F1B2D;
}
.en-qc-body {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  flex: 1;
}
.en-qc-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #5A6A7E;
}
.en-qc-value {
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  font-weight: 800;
  color: #0F1B2D;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.en-qc-hint {
  font-family: 'Lato', sans-serif;
  font-size: 12.5px;
  color: #5A6A7E;
}
.en-qc-arr {
  font-size: 14px;
  color: #5A6A7E;
  transition: all 0.3s ease;
  flex-shrink: 0;
}
.en-quick-card:hover .en-qc-arr {
  color: #0066FF;
  transform: translateX(4px);
}
/* Course types grid */
.en-courses-sec {
  padding: 100px 0;
  background: #F4F8FF;
}
.en-courses-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.en-course-card {
  background: #fff;
  border-radius: 24px;
  padding: 34px 32px;
  border: 1px solid #E5EAF2;
  text-decoration: none;
  transition: all 0.35s ease;
  display: flex;
  flex-direction: column;
  position: relative;
  box-shadow: 0 8px 28px rgba(15, 27, 45, 0.04);
}
.en-course-card:hover {
  transform: translateY(-6px);
  border-color: #E8F1FF;
  box-shadow: 0 24px 64px rgba(0, 102, 255, 0.14);
}
.en-cc-tag {
  position: absolute;
  top: 18px;
  right: 18px;
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: #0066FF;
  background: #E8F1FF;
  padding: 6px 12px;
  border-radius: 50px;
}
.en-cc-tag--featured {
  background: #FFD60A;
  color: #0F1B2D;
  box-shadow: 0 6px 18px rgba(255, 214, 10, 0.4);
}
.en-cc-tag--featured i {
  font-size: 9px;
  margin-right: 3px;
}
.en-cc-ico {
  width: 60px;
  height: 60px;
  border-radius: 16px;
  background: #E8F1FF;
  color: #0066FF;
  display: grid;
  place-items: center;
  font-size: 24px;
  margin-bottom: 18px;
  transition: all 0.35s ease;
}
.en-course-card:hover .en-cc-ico {
  transform: scale(1.08) rotate(-5deg);
  background: #0066FF;
  color: #fff;
}
.en-cc-ico--featured {
  background: #FFD60A;
  color: #0F1B2D;
}
.en-course-card--featured:hover .en-cc-ico--featured {
  background: #FFB000;
  color: #0F1B2D;
}
.en-cc-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 21px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 0 0 12px;
  line-height: 1.25;
}
.en-cc-desc {
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  color: #5A6A7E;
  line-height: 1.65;
  margin: 0 0 20px;
  flex: 1;
}
.en-cc-meta {
  list-style: none;
  padding: 0;
  margin: 0 0 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 18px;
  border-top: 1px dashed #E5EAF2;
}
.en-cc-meta li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #0F1B2D;
}
.en-cc-meta i {
  color: #0066FF;
  font-size: 11px;
  flex-shrink: 0;
  background: #E8F1FF;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: grid;
  place-items: center;
}
.en-cc-cta {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: #0066FF;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.en-cc-cta i {
  font-size: 12px;
  transition: transform 0.25s;
}
.en-course-card:hover .en-cc-cta i {
  transform: translateX(4px);
}
/* Featured card — extra emphasis */
.en-course-card--featured {
  background: linear-gradient(135deg, #fff 0%, #fff6cc 100%);
  border-color: #FFD60A;
  box-shadow: 0 12px 40px rgba(255, 214, 10, 0.22);
}
.en-course-card--featured:hover {
  border-color: #FFD60A;
  box-shadow: 0 24px 64px rgba(255, 176, 0, 0.32);
}
/* IELTS featured banner */
.en-ielts-sec {
  padding: 100px 0;
  background: #fff;
}
.en-ielts-card {
  position: relative;
  border-radius: 32px;
  background: linear-gradient(135deg, #0F1B2D 0%, #192d4c 100%);
  color: #fff;
  padding: 60px 60px;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(15, 27, 45, 0.18);
}
.en-ielts-bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 90% 10%, rgba(255, 214, 10, 0.16), transparent 40%), radial-gradient(circle at 10% 90%, rgba(0, 102, 255, 0.18), transparent 40%);
  pointer-events: none;
}
.en-ielts-content {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 48px;
  align-items: center;
}
.en-ielts-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #0F1B2D;
  background: #FFD60A;
  padding: 8px 16px;
  border-radius: 50px;
  margin-bottom: 18px;
}
.en-ielts-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 42px;
  font-weight: 800;
  line-height: 1.15;
  margin: 0 0 16px;
}
.en-ielts-title em {
  color: #FFD60A;
  font-style: normal;
}
.en-ielts-sub {
  font-family: 'Lato', sans-serif;
  font-size: 15.5px;
  line-height: 1.7;
  opacity: 0.88;
  margin: 0 0 24px;
}
.en-ielts-points {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.en-ielts-points li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
}
.en-ielts-points i {
  color: #FFD60A;
  font-size: 16px;
  flex-shrink: 0;
}
.en-ielts-btns {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}
.en-ielts-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  padding: 32px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(8px);
}
.en-ielts-stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-align: center;
}
.en-ielts-snum {
  font-family: 'Montserrat', sans-serif;
  font-size: 30px;
  font-weight: 800;
  color: #FFD60A;
  line-height: 1;
}
.en-ielts-slabel {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 1.3px;
  text-transform: uppercase;
  opacity: 0.85;
}
/* Why Duke for English */
.en-why-sec {
  padding: 100px 0;
  background: #F4F8FF;
}
.en-why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.en-why-card {
  background: #fff;
  border-radius: 20px;
  padding: 32px 28px;
  border: 1px solid #E5EAF2;
  transition: all 0.3s ease;
  box-shadow: 0 8px 28px rgba(15, 27, 45, 0.04);
}
.en-why-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 48px rgba(0, 102, 255, 0.12);
  border-color: #E8F1FF;
}
.en-why-ico {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: #E8F1FF;
  color: #0066FF;
  display: grid;
  place-items: center;
  font-size: 22px;
  margin-bottom: 18px;
  transition: all 0.3s ease;
}
.en-why-card:hover .en-why-ico {
  transform: scale(1.08);
  background: #0066FF;
  color: #fff;
}
.en-why-card h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 0 0 10px;
  line-height: 1.3;
}
.en-why-card p {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.65;
  margin: 0;
}
/* Format & approach split */
.en-format-sec {
  padding: 100px 0;
  background: #fff;
}
.en-format-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 48px;
  align-items: start;
}
.en-format-blurb {
  font-family: 'Lato', sans-serif;
  font-size: 15.5px;
  color: #5A6A7E;
  line-height: 1.7;
  margin: 18px 0 28px;
}
.en-format-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.en-format-list li {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}
.en-fl-ico {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  background: #E8F1FF;
  color: #0066FF;
  display: grid;
  place-items: center;
  font-size: 18px;
  flex-shrink: 0;
}
.en-format-list li > div:last-child {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.en-format-list strong {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: #0F1B2D;
}
.en-format-list span {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.6;
}
.en-format-card {
  background: linear-gradient(180deg, #fff 0%, #E8F1FF 220%);
  border: 1px solid #E5EAF2;
  border-radius: 24px;
  padding: 36px;
  box-shadow: 0 12px 48px rgba(0, 102, 255, 0.08);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px 32px;
}
.en-format-stat {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.en-fs-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 38px;
  font-weight: 800;
  color: #0066FF;
  line-height: 1;
  display: flex;
  align-items: baseline;
  gap: 2px;
}
.en-fs-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.3px;
  text-transform: uppercase;
  color: #5A6A7E;
}
.en-format-divider {
  grid-column: 1 / -1;
  height: 1px;
  background: #E5EAF2;
  margin: 6px 0;
}
.en-format-cta {
  grid-column: 1 / -1;
}
.en-format-cta h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 0 0 8px;
}
.en-format-cta p {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.6;
  margin: 0 0 16px;
}
/* Responsive — English course */
@media (max-width: 1100px) {
  .en-ielts-content {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .en-ielts-stats {
    grid-template-columns: repeat(4, 1fr);
  }
  .en-format-card {
    padding: 28px;
  }
  .en-fs-num {
    font-size: 32px;
  }
}
@media (max-width: 980px) {
  .en-quick-grid {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .en-quick-card:nth-child(3) {
    grid-column: 1 / -1;
  }
  .en-courses-grid {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
  .en-why-grid {
    grid-template-columns: 1fr 1fr;
    gap: 18px;
  }
  .en-format-grid {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .en-ielts-card {
    padding: 48px 40px;
  }
  .en-ielts-title {
    font-size: 34px;
  }
}
@media (max-width: 680px) {
  .en-courses-sec,
  .en-ielts-sec,
  .en-why-sec,
  .en-format-sec {
    padding: 64px 0;
  }
  .en-quick-sec {
    padding: 40px 0 16px;
  }
  .en-quick-grid {
    grid-template-columns: 1fr;
  }
  .en-quick-card:nth-child(3) {
    grid-column: auto;
  }
  .en-courses-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .en-course-card {
    padding: 28px 24px;
  }
  .en-cc-title {
    font-size: 19px;
  }
  .en-why-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .en-ielts-card {
    padding: 36px 24px;
    border-radius: 24px;
  }
  .en-ielts-title {
    font-size: 26px;
  }
  .en-ielts-stats {
    grid-template-columns: 1fr 1fr;
    padding: 20px;
  }
  .en-ielts-snum {
    font-size: 26px;
  }
  .en-ielts-btns {
    flex-direction: column;
  }
  .en-ielts-btns .btn {
    width: 100%;
    justify-content: center;
  }
  .en-format-card {
    grid-template-columns: 1fr;
    padding: 24px;
  }
  .en-sec-head {
    margin-bottom: 36px;
  }
  .en-format-blurb {
    font-size: 14.5px;
  }
}
@media (max-width: 480px) {
  .en-quick-card {
    padding: 18px 20px;
    gap: 14px;
    border-radius: 16px;
  }
  .en-qc-ico {
    width: 50px;
    height: 50px;
    font-size: 20px;
    border-radius: 14px;
  }
  .en-qc-value {
    font-size: 15px;
  }
  .en-qc-hint {
    font-size: 12px;
  }
  .en-course-card {
    padding: 24px 20px;
    border-radius: 18px;
  }
  .en-cc-ico {
    width: 52px;
    height: 52px;
    font-size: 20px;
    border-radius: 13px;
    margin-bottom: 14px;
  }
  .en-cc-title {
    font-size: 18px;
  }
  .en-cc-desc {
    font-size: 13.5px;
  }
  .en-cc-meta li {
    font-size: 13px;
  }
  .en-why-card {
    padding: 26px 22px;
    border-radius: 16px;
  }
  .en-why-ico {
    width: 50px;
    height: 50px;
    font-size: 19px;
    border-radius: 14px;
  }
  .en-why-card h4 {
    font-size: 16px;
  }
  .en-why-card p {
    font-size: 13.5px;
  }
  .en-ielts-card {
    padding: 28px 20px;
    border-radius: 18px;
  }
  .en-ielts-title {
    font-size: 22px;
  }
  .en-ielts-sub {
    font-size: 14px;
  }
  .en-ielts-points li {
    font-size: 13.5px;
  }
  .en-ielts-snum {
    font-size: 22px;
  }
  .en-format-list li {
    gap: 12px;
  }
  .en-fl-ico {
    width: 40px;
    height: 40px;
    font-size: 16px;
    border-radius: 12px;
  }
  .en-format-list strong {
    font-size: 15px;
  }
  .en-format-list span {
    font-size: 13.5px;
  }
  .en-format-card {
    padding: 20px;
    gap: 18px 24px;
  }
  .en-fs-num {
    font-size: 28px;
  }
  .en-format-cta h4 {
    font-size: 16px;
  }
  .en-format-cta p {
    font-size: 13.5px;
  }
}
@media (max-width: 380px) {
  .en-quick-card {
    padding: 16px 16px;
    gap: 12px;
  }
  .en-qc-ico {
    width: 44px;
    height: 44px;
    font-size: 17px;
  }
  .en-course-card {
    padding: 20px 18px;
  }
  .en-cc-title {
    font-size: 17px;
  }
  .en-why-card {
    padding: 22px 18px;
  }
  .en-ielts-card {
    padding: 22px 16px;
  }
  .en-ielts-title {
    font-size: 20px;
  }
  .en-format-card {
    padding: 16px;
    gap: 16px 20px;
  }
  .en-fs-num {
    font-size: 24px;
  }
}
/* ═══════════════════════════════════════════════════════════════════════════
   ENGLISH COURSE FEES PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.ef-sec-head {
  text-align: center;
  max-width: 740px;
  margin: 0 auto 56px;
}
/* Pricing section */
.ef-pricing-sec {
  padding: 100px 0;
  background: #fff;
}
.ef-pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  margin-bottom: 56px;
}
.ef-price-card {
  background: #fff;
  border-radius: 24px;
  padding: 32px 28px;
  border: 1px solid #E5EAF2;
  position: relative;
  display: flex;
  flex-direction: column;
  box-shadow: 0 8px 32px rgba(15, 27, 45, 0.05);
  transition: all 0.3s ease;
}
.ef-price-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 64px rgba(0, 102, 255, 0.14);
  border-color: #E8F1FF;
}
.ef-pc-head {
  margin-bottom: 22px;
  padding-bottom: 20px;
  border-bottom: 1px dashed #E5EAF2;
}
.ef-pc-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #0066FF;
  display: block;
  margin-bottom: 10px;
}
.ef-pc-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 26px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 0 0 6px;
  line-height: 1.2;
}
.ef-pc-sub {
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #5A6A7E;
  margin: 0;
  line-height: 1.5;
}
.ef-pc-price {
  margin-bottom: 22px;
  display: flex;
  align-items: baseline;
  gap: 4px;
  flex-wrap: wrap;
}
.ef-pc-currency {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: #0F1B2D;
}
.ef-pc-amount {
  font-family: 'Montserrat', sans-serif;
  font-size: 42px;
  font-weight: 800;
  color: #0F1B2D;
  line-height: 1;
  letter-spacing: -1px;
}
.ef-pc-save {
  width: 100%;
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #00C4B4;
  background: rgba(0, 196, 180, 0.12);
  padding: 5px 10px;
  border-radius: 50px;
  display: inline-block;
  width: fit-content;
  margin-top: 8px;
}
.ef-pc-features {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  display: flex;
  flex-direction: column;
  gap: 11px;
  flex: 1;
}
.ef-pc-features li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #0F1B2D;
}
.ef-pc-features i {
  color: #00C4B4;
  font-size: 11px;
  flex-shrink: 0;
  background: rgba(0, 196, 180, 0.12);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: grid;
  place-items: center;
}
.ef-pc-feat-mute {
  opacity: 0.55;
}
.ef-pc-feat-mute i {
  background: #E5EAF2;
  color: #5A6A7E;
}
.ef-pc-feat-strong {
  font-weight: 800!important;
  color: #0066FF !important;
}
.ef-pc-feat-strong i {
  background: #E8F1FF;
  color: #0066FF;
}
.ef-pc-cta {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  background: #E8F1FF;
  color: #0066FF;
  padding: 14px 22px;
  border-radius: 50px;
  border: 2px solid #E8F1FF;
  text-decoration: none;
  text-align: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all 0.25s ease;
}
.ef-pc-cta:hover {
  background: #0066FF;
  color: #fff;
  border-color: #0066FF;
}
.ef-pc-cta i {
  font-size: 11px;
  transition: transform 0.25s;
}
.ef-pc-cta:hover i {
  transform: translateX(4px);
}
/* Featured price card */
.ef-price-card--featured {
  background: linear-gradient(180deg, #fff 0%, #fff6cc 200%);
  border: 2px solid #FFD60A;
  box-shadow: 0 16px 56px rgba(255, 214, 10, 0.24);
  transform: translateY(-8px);
}
.ef-price-card--featured:hover {
  transform: translateY(-12px);
  box-shadow: 0 24px 64px rgba(255, 176, 0, 0.32);
}
.ef-pc-badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #0F1B2D;
  background: #FFD60A;
  padding: 8px 16px;
  border-radius: 50px;
  box-shadow: 0 8px 24px rgba(255, 214, 10, 0.5);
  white-space: nowrap;
}
.ef-pc-badge i {
  font-size: 10px;
  margin-right: 4px;
}
.ef-pc-cta--featured {
  background: #0066FF;
  color: #fff;
  border-color: #0066FF;
}
.ef-pc-cta--featured:hover {
  background: #003FB5;
  border-color: #003FB5;
}
/* Add-on info bar */
.ef-addon-bar {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  padding: 32px;
  border-radius: 24px;
  background: #F4F8FF;
  border: 1px solid #E5EAF2;
}
.ef-addon-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.ef-addon-ico {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: #E8F1FF;
  color: #0066FF;
  display: grid;
  place-items: center;
  font-size: 18px;
  flex-shrink: 0;
}
.ef-addon-item > div:last-child {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  min-width: 0;
}
.ef-addon-item strong {
  font-family: 'Montserrat', sans-serif;
  font-size: 14.5px;
  font-weight: 800;
  color: #0F1B2D;
}
.ef-addon-item span {
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: #5A6A7E;
  line-height: 1.55;
}
.ef-addon-link {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.4px;
  color: #0066FF;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: 4px;
  transition: gap 0.25s;
}
.ef-addon-link:hover {
  gap: 9px;
}
.ef-addon-link i {
  font-size: 10px;
}
/* Schedule section */
.ef-sched-sec {
  padding: 100px 0 100px;
  background: #F4F8FF;
}
.ef-sched-card {
  background: #fff;
  border-radius: 28px;
  border: 1px solid #E5EAF2;
  box-shadow: 0 16px 56px rgba(15, 27, 45, 0.06);
  overflow: hidden;
  margin-bottom: 32px;
}
/* Unified single grid — header row + 3 session rows, with spanning cells */
.ef-sched-grid {
  display: grid;
  grid-template-columns: 220px 130px 1fr 110px 110px;
}
/* Header cells (row 1) */
.ef-sched-h {
  background: #0066FF;
  color: #fff;
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: 1.3px;
  text-transform: uppercase;
  padding: 18px 20px;
  display: flex;
  align-items: center;
  border-right: 1px solid rgba(255, 255, 255, 0.15);
  border-bottom: 1px solid #003FB5;
}
.ef-sched-h--num {
  justify-content: center;
}
.ef-sched-h:last-child {
  border-right: none;
}
/* Body cells */
.ef-sched-c {
  padding: 22px 20px;
  font-family: 'Lato', sans-serif;
  font-size: 14.5px;
  color: #0F1B2D;
  display: flex;
  align-items: center;
  border-right: 1px solid #E5EAF2;
  border-bottom: 1px solid #E5EAF2;
}
/* Days cell — col 1, spans rows 2-4 (the 3 session rows) */
.ef-sched-c--days {
  grid-column: 1;
  grid-row: 2 / span 3;
  background: #F4F8FF;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 8px;
  border-bottom: none;
}
.ef-sched-days-main {
  font-family: 'Montserrat', sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: #0F1B2D;
  line-height: 1.3;
}
.ef-sched-days-sub {
  font-family: 'Lato', sans-serif;
  font-size: 12px;
  color: #5A6A7E;
  display: flex;
  align-items: center;
  gap: 6px;
}
.ef-sched-days-sub i {
  color: #0066FF;
  font-size: 11px;
}
/* Session cells — col 2 */
.ef-sched-c--session {
  grid-column: 2;
  justify-content: flex-start;
}
.ef-sched-pill {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 800;
  background: #E8F1FF;
  color: #0066FF;
  padding: 8px 14px;
  border-radius: 10px;
  letter-spacing: 0.5px;
}
/* Time cells — col 3 */
.ef-sched-c--time {
  grid-column: 3;
  white-space: nowrap;
}
.ef-sched-c--time i {
  color: #0066FF;
  margin-right: 8px;
  font-size: 13px;
}
/* Total cells — col 4 (Days=15) and col 5 (Hours=30), span rows 2-4 */
.ef-sched-c--num-days {
  grid-column: 4;
  grid-row: 2 / span 3;
  justify-content: center;
  border-bottom: none;
}
.ef-sched-c--num-hours {
  grid-column: 5;
  grid-row: 2 / span 3;
  justify-content: center;
  border-right: none;
  border-bottom: none;
}
.ef-sched-big {
  font-family: 'Montserrat', sans-serif;
  font-size: 40px;
  font-weight: 800;
  color: #0066FF;
  line-height: 1;
}
/* Remove bottom border on last session row (S3 cells) */
.ef-sched-c--session:last-of-type,
.ef-sched-c--time:last-of-type {
  border-bottom: none;
}
.ef-sched-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  padding: 22px 28px;
  background: #F4F8FF;
  border-top: 1px solid #E5EAF2;
  flex-wrap: wrap;
}
.ef-sched-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #5A6A7E;
  line-height: 1.55;
  max-width: 680px;
}
.ef-sched-note i {
  color: #0066FF;
  font-size: 14px;
  flex-shrink: 0;
  margin-top: 2px;
}
.ef-sched-link {
  font-family: 'Montserrat', sans-serif;
  font-size: 12.5px;
  font-weight: 700;
  color: #0066FF;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 50px;
  background: rgba(0, 102, 255, 0.08);
  transition: all 0.25s;
  flex-shrink: 0;
}
.ef-sched-link:hover {
  background: #0066FF;
  color: #fff;
}
.ef-sched-link i {
  font-size: 10px;
  transition: transform 0.25s;
}
.ef-sched-link:hover i {
  transform: translateX(3px);
}
/* Free trial banner */
.ef-trial-banner {
  background: linear-gradient(135deg, #0F1B2D 0%, #192d4c 100%);
  color: #fff;
  border-radius: 24px;
  padding: 32px 36px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 16px 56px rgba(15, 27, 45, 0.18);
}
.ef-trial-banner::before {
  content: '';
  position: absolute;
  right: -60px;
  top: -60px;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: rgba(255, 214, 10, 0.12);
}
.ef-trial-content {
  display: flex;
  align-items: center;
  gap: 20px;
  position: relative;
  flex: 1;
}
.ef-trial-ico {
  width: 64px;
  height: 64px;
  border-radius: 18px;
  background: #FFD60A;
  color: #0F1B2D;
  display: grid;
  place-items: center;
  font-size: 26px;
  flex-shrink: 0;
  box-shadow: 0 8px 22px rgba(255, 214, 10, 0.4);
}
.ef-trial-text h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  margin: 0 0 6px;
  line-height: 1.25;
}
.ef-trial-text p {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  opacity: 0.85;
  margin: 0;
  line-height: 1.6;
}
/* Responsive — Course fees */
@media (max-width: 1100px) {
  .ef-pricing-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
  .ef-price-card--featured {
    transform: none;
  }
  .ef-price-card--featured:hover {
    transform: translateY(-6px);
  }
  .ef-addon-bar {
    grid-template-columns: repeat(2, 1fr);
  }
  .ef-sched-grid {
    grid-template-columns: 200px 110px 1fr 100px 100px;
  }
  .ef-sched-c,
  .ef-sched-h {
    padding: 20px 16px;
    font-size: 13.5px;
  }
}
@media (max-width: 820px) {
  .ef-sched-grid {
    grid-template-columns: 170px 90px 1fr 85px 85px;
  }
  .ef-sched-days-main {
    font-size: 15px;
  }
  .ef-sched-big {
    font-size: 32px;
  }
  .ef-trial-banner {
    flex-direction: column;
    text-align: center;
    align-items: stretch;
  }
  .ef-trial-content {
    flex-direction: column;
    text-align: center;
  }
  .ef-trial-banner .btn {
    width: 100%;
    justify-content: center;
  }
}
@media (max-width: 680px) {
  .ef-pricing-sec,
  .ef-sched-sec {
    padding: 64px 0 72px;
  }
  .ef-pricing-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .ef-price-card {
    padding: 28px 24px;
  }
  .ef-pc-amount {
    font-size: 36px;
  }
  .ef-addon-bar {
    grid-template-columns: 1fr;
    padding: 24px;
    gap: 20px;
  }
  .ef-sched-card {
    border-radius: 20px;
  }
  /* Schedule collapses to single column, each cell becomes a labeled row */
  .ef-sched-grid {
    grid-template-columns: 1fr;
  }
  .ef-sched-h {
    display: none;
  }
  .ef-sched-c,
  .ef-sched-c--days,
  .ef-sched-c--num-days,
  .ef-sched-c--num-hours {
    grid-column: 1!important;
    grid-row: auto!important;
    padding: 14px 20px;
    border-right: none;
    border-bottom: 1px solid #E5EAF2;
    justify-content: space-between;
  }
  .ef-sched-c--days {
    background: #0066FF;
    color: #fff;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .ef-sched-c--days .ef-sched-days-main {
    color: #fff;
    font-size: 16px;
  }
  .ef-sched-c--days .ef-sched-days-sub {
    color: rgba(255, 255, 255, 0.85);
  }
  .ef-sched-c--session::before {
    content: 'Session';
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: #5A6A7E;
    margin-right: auto;
  }
  .ef-sched-c--time::before {
    content: 'Time';
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: #5A6A7E;
    margin-right: auto;
  }
  .ef-sched-c--num-days::before {
    content: 'Days';
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: #5A6A7E;
    margin-right: auto;
  }
  .ef-sched-c--num-hours::before {
    content: 'Hours';
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: #5A6A7E;
    margin-right: auto;
  }
  .ef-sched-c--num-hours {
    border-bottom: none;
  }
  .ef-sched-big {
    font-size: 24px;
  }
  .ef-sched-footer {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    padding: 20px 24px;
  }
  .ef-trial-banner {
    padding: 28px 24px;
  }
}
@media (max-width: 480px) {
  .ef-pricing-sec,
  .ef-sched-sec {
    padding: 52px 0 60px;
  }
  .ef-sec-head {
    margin-bottom: 40px;
  }
  .ef-price-card {
    padding: 24px 20px;
  }
  .ef-pc-title {
    font-size: 22px;
  }
  .ef-pc-currency {
    font-size: 18px;
  }
  .ef-pc-amount {
    font-size: 32px;
  }
  .ef-pc-cta {
    padding: 13px 18px;
    font-size: 12px;
  }
  .ef-addon-bar {
    padding: 18px 16px;
    gap: 16px;
  }
  .ef-addon-ico {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    font-size: 15px;
  }
  .ef-addon-item strong {
    font-size: 13.5px;
  }
  .ef-addon-item span {
    font-size: 12.5px;
  }
  .ef-sched-footer {
    padding: 16px 18px;
  }
  .ef-trial-banner {
    padding: 22px 20px;
    gap: 22px;
    border-radius: 20px;
  }
  .ef-trial-ico {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    font-size: 22px;
  }
  .ef-trial-text h3 {
    font-size: 18px;
  }
  .ef-trial-text p {
    font-size: 13px;
  }
}
@media (max-width: 380px) {
  .ef-price-card {
    padding: 20px 16px;
  }
  .ef-pc-title {
    font-size: 20px;
  }
  .ef-pc-amount {
    font-size: 28px;
  }
  .ef-addon-bar {
    padding: 14px;
  }
  .ef-trial-banner {
    padding: 18px 16px;
  }
  .ef-trial-text h3 {
    font-size: 16px;
  }
}
/* ═══════════════════════════════════════════════════════════════════════════
   ENGLISH CLASS SCHEDULE PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.ecs-sec-head {
  text-align: center;
  max-width: 740px;
  margin: 0 auto 32px;
}
/* Calendar section */
.ecs-cal-sec {
  padding: 100px 0 90px;
  background: #fff;
}
/* Legend */
.ecs-legend {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 auto 48px;
  padding: 18px 28px;
  background: #F4F8FF;
  border-radius: 50px;
  border: 1px solid #E5EAF2;
  max-width: fit-content;
}
.ecs-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 14px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12.5px;
  font-weight: 700;
  color: #0F1B2D;
}
.ecs-legend-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1.5px solid transparent;
  flex-shrink: 0;
}
.ecs-legend-dot--start {
  background: #BFD9FF;
  border-color: #7FB3FF;
}
.ecs-legend-dot--end {
  background: #F87171;
  border-color: #DC2626;
}
.ecs-legend-dot--public {
  background: #E5E7EB;
  border-color: #9CA3AF;
}
.ecs-legend-dot--school {
  background: #6B7280;
  border-color: #4B5563;
}
/* Months grid */
.ecs-months {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.ecs-month {
  background: #fff;
  border-radius: 20px;
  padding: 24px 22px;
  border: 1px solid #E5EAF2;
  box-shadow: 0 6px 24px rgba(15, 27, 45, 0.04);
  transition: all 0.3s ease;
}
.ecs-month:hover {
  box-shadow: 0 12px 40px rgba(0, 102, 255, 0.08);
  border-color: #E8F1FF;
}
.ecs-month-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: #0066FF;
  margin: 0 0 14px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.ecs-month-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.ecs-dow {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  color: #0F1B2D;
  text-align: center;
  padding: 6px 0 4px;
  letter-spacing: 0.3px;
}
.ecs-dow--weekend {
  color: #0066FF;
}
.ecs-day {
  position: relative;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: #0F1B2D;
  border-radius: 50%;
  transition: all 0.2s ease;
}
.ecs-day span {
  position: relative;
  z-index: 2;
  line-height: 1;
}
.ecs-day--empty {
  visibility: hidden;
}
.ecs-day--weekend {
  color: #0066FF;
}
/* Marker variants — colored circle backgrounds */
.ecs-day--start {
  background: #BFD9FF;
  color: #003FB5;
  font-weight: 700;
}
.ecs-day--end {
  background: #F87171;
  color: #fff;
  font-weight: 700;
}
.ecs-day--public {
  background: #E5E7EB;
  color: #0F1B2D;
  font-weight: 700;
}
.ecs-day--school {
  background: #6B7280;
  color: #fff;
  font-weight: 700;
}
.ecs-month-notes {
  margin: 14px 0 0;
  padding-top: 12px;
  border-top: 1px dashed #E5EAF2;
  font-family: 'Lato', sans-serif;
  font-size: 11.5px;
  color: #5A6A7E;
  line-height: 1.55;
}
/* Info bar */
.ecs-info-sec {
  padding: 0 0 72px;
  background: #fff;
}
.ecs-info-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  padding: 32px;
  border-radius: 24px;
  background: #F4F8FF;
  border: 1px solid #E5EAF2;
}
.ecs-info-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: #fff;
  border-radius: 16px;
  padding: 18px 20px;
  border: 1px solid #E5EAF2;
  text-decoration: none;
  transition: all 0.25s ease;
  position: relative;
}
.ecs-info-card:hover:not(.ecs-info-card--static) {
  transform: translateY(-3px);
  border-color: #E8F1FF;
  box-shadow: 0 10px 28px rgba(0, 102, 255, 0.12);
}
.ecs-info-ico {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: #E8F1FF;
  color: #0066FF;
  display: grid;
  place-items: center;
  font-size: 17px;
  flex-shrink: 0;
}
.ecs-info-card:hover .ecs-info-ico {
  background: #0066FF;
  color: #fff;
}
.ecs-info-card--static .ecs-info-ico {
  background: rgba(255, 214, 10, 0.18);
  color: #B45309;
}
.ecs-info-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
}
.ecs-info-body strong {
  font-family: 'Montserrat', sans-serif;
  font-size: 13.5px;
  font-weight: 800;
  color: #0F1B2D;
}
.ecs-info-body span {
  font-family: 'Lato', sans-serif;
  font-size: 12px;
  color: #5A6A7E;
  line-height: 1.5;
}
.ecs-info-arr {
  font-size: 12px;
  color: #5A6A7E;
  transition: all 0.25s ease;
  flex-shrink: 0;
}
.ecs-info-card:hover .ecs-info-arr {
  color: #0066FF;
  transform: translateX(3px);
}
/* Trial section spacing */
.ecs-trial-sec {
  padding: 0 0 90px;
  background: #fff;
}
/* Responsive — class schedule */
@media (max-width: 1100px) {
  .ecs-months {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
  .ecs-info-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 680px) {
  .ecs-cal-sec {
    padding: 64px 0 56px;
  }
  .ecs-info-sec {
    padding: 0 0 56px;
  }
  .ecs-trial-sec {
    padding: 0 0 64px;
  }
  .ecs-months {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .ecs-month {
    padding: 20px 16px;
  }
  .ecs-legend {
    padding: 14px 18px;
    gap: 4px;
    border-radius: 20px;
  }
  .ecs-legend-item {
    font-size: 11.5px;
    padding: 4px 8px;
  }
  .ecs-info-grid {
    grid-template-columns: 1fr;
    padding: 20px;
    gap: 14px;
  }
  .ecs-day {
    font-size: 12px;
  }
}
/* ═══════════════════════════════════════════════════════════════════════════
   IELTS PREPARATION PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.il-sec-head {
  text-align: center;
  max-width: 740px;
  margin: 0 auto 56px;
}
.il-sec-head a {
  color: #0066FF;
  text-decoration: none;
  font-weight: 700;
}
.il-sec-head a:hover {
  text-decoration: underline;
}
/* Stats strip */
.il-stats-sec {
  padding: 48px 0;
  background: #fff;
}
.il-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.il-stat {
  background: linear-gradient(180deg, #fff 0%, #E8F1FF 220%);
  border: 1px solid #E5EAF2;
  border-radius: 20px;
  padding: 28px 24px;
  text-align: center;
  box-shadow: 0 8px 28px rgba(15, 27, 45, 0.04);
  transition: all 0.3s ease;
}
.il-stat:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0, 102, 255, 0.12);
  border-color: #E8F1FF;
}
.il-stat-ico {
  width: 50px;
  height: 50px;
  border-radius: 14px;
  background: #E8F1FF;
  color: #0066FF;
  display: grid;
  place-items: center;
  font-size: 20px;
  margin: 0 auto 14px;
}
.il-stat-num {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 40px;
  font-weight: 800;
  color: #0066FF;
  line-height: 1;
  margin-bottom: 8px;
  letter-spacing: -1px;
}
.il-stat-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.3px;
  text-transform: uppercase;
  color: #5A6A7E;
}
/* 4 Skills */
.il-skills-sec {
  padding: 100px 0;
  background: #F4F8FF;
}
.il-skills-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
.il-skill-card {
  background: #fff;
  border-radius: 20px;
  padding: 30px 26px;
  border: 1px solid #E5EAF2;
  transition: all 0.3s ease;
  box-shadow: 0 8px 28px rgba(15, 27, 45, 0.04);
}
.il-skill-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 56px rgba(0, 102, 255, 0.14);
  border-color: #E8F1FF;
}
.il-sk-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
}
.il-sk-ico {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  font-size: 22px;
  color: #fff;
}
.il-sk-head--listening .il-sk-ico {
  background: linear-gradient(135deg, #0066FF, #003FB5);
}
.il-sk-head--reading .il-sk-ico {
  background: linear-gradient(135deg, #00C4B4, #00877c);
}
.il-sk-head--writing .il-sk-ico {
  background: linear-gradient(135deg, #F97316, #C2410C);
}
.il-sk-head--speaking .il-sk-ico {
  background: linear-gradient(135deg, #C026D3, #86198F);
}
.il-sk-tag {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: #5A6A7E;
  background: #F4F8FF;
  padding: 5px 11px;
  border-radius: 50px;
}
.il-sk-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 0 0 6px;
  line-height: 1.2;
}
.il-sk-sub {
  font-family: 'Lato', sans-serif;
  font-size: 12.5px;
  color: #5A6A7E;
  margin: 0 0 18px;
  line-height: 1.5;
}
.il-sk-points {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 9px;
  padding-top: 18px;
  border-top: 1px dashed #E5EAF2;
}
.il-sk-points li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #0F1B2D;
  line-height: 1.4;
}
.il-sk-points i {
  color: #0066FF;
  font-size: 11px;
  flex-shrink: 0;
  background: #E8F1FF;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: grid;
  place-items: center;
}
/* Course format split */
.il-format-sec {
  padding: 100px 0;
  background: #fff;
}
.il-format-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}
.il-format-blurb {
  font-family: 'Lato', sans-serif;
  font-size: 15.5px;
  color: #5A6A7E;
  line-height: 1.7;
  margin: 18px 0 28px;
}
.il-weeks {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.il-week {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  background: #F4F8FF;
  border-radius: 16px;
  padding: 18px 20px;
  border: 1px solid #E5EAF2;
}
.il-week-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  background: #0066FF;
  color: #fff;
  padding: 8px 14px;
  border-radius: 10px;
  flex-shrink: 0;
  white-space: nowrap;
}
.il-week-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.il-week-body strong {
  font-family: 'Montserrat', sans-serif;
  font-size: 15.5px;
  font-weight: 800;
  color: #0F1B2D;
}
.il-week-body span {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #5A6A7E;
  line-height: 1.55;
}
/* Sample day card */
.il-format-card {
  background: linear-gradient(135deg, #0F1B2D 0%, #192d4c 100%);
  color: #fff;
  border-radius: 24px;
  padding: 36px 32px;
  box-shadow: 0 16px 56px rgba(15, 27, 45, 0.18);
  position: relative;
  overflow: hidden;
}
.il-format-card::before {
  content: '';
  position: absolute;
  right: -60px;
  top: -60px;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: rgba(255, 214, 10, 0.1);
}
.il-fc-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #FFD60A;
  margin: 0 0 8px;
  position: relative;
}
.il-fc-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  margin: 0 0 24px;
  line-height: 1.25;
  position: relative;
}
.il-day {
  display: flex;
  gap: 18px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  position: relative;
}
.il-day:last-of-type {
  border-bottom: none;
}
.il-day-time {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 800;
  color: #FFD60A;
  letter-spacing: 0.5px;
  white-space: nowrap;
  min-width: 110px;
  padding-top: 2px;
}
.il-day-act {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.il-day-act strong {
  font-family: 'Montserrat', sans-serif;
  font-size: 14.5px;
  font-weight: 800;
  color: #fff;
}
.il-day-act span {
  font-family: 'Lato', sans-serif;
  font-size: 12.5px;
  color: rgba(255, 255, 255, 0.75);
  line-height: 1.5;
}
.il-fc-divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.12);
  margin: 16px 0 14px;
  position: relative;
}
.il-fc-note {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 12.5px;
  color: rgba(255, 255, 255, 0.75);
  position: relative;
  line-height: 1.5;
}
.il-fc-note i {
  color: #FFD60A;
  font-size: 14px;
  flex-shrink: 0;
}
/* What you get */
.il-what-sec {
  padding: 100px 0;
  background: #F4F8FF;
}
.il-what-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.il-what-card {
  background: #fff;
  border-radius: 20px;
  padding: 30px 28px;
  border: 1px solid #E5EAF2;
  transition: all 0.3s ease;
  box-shadow: 0 8px 28px rgba(15, 27, 45, 0.04);
}
.il-what-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 48px rgba(0, 102, 255, 0.12);
  border-color: #E8F1FF;
}
.il-what-ico {
  width: 54px;
  height: 54px;
  border-radius: 14px;
  background: #E8F1FF;
  color: #0066FF;
  display: grid;
  place-items: center;
  font-size: 22px;
  margin-bottom: 16px;
  transition: all 0.3s ease;
}
.il-what-card:hover .il-what-ico {
  background: #0066FF;
  color: #fff;
  transform: scale(1.08);
}
.il-what-card h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 0 0 10px;
  line-height: 1.3;
}
.il-what-card p {
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  color: #5A6A7E;
  line-height: 1.65;
  margin: 0;
}
/* Pricing card */
.il-pricing-sec {
  padding: 100px 0;
  background: #fff;
}
.il-pricing-card {
  position: relative;
  border-radius: 32px;
  background: linear-gradient(135deg, #0F1B2D 0%, #192d4c 100%);
  color: #fff;
  padding: 60px;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(15, 27, 45, 0.2);
}
.il-pc-bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 90% 10%, rgba(255, 214, 10, 0.18), transparent 40%), radial-gradient(circle at 10% 90%, rgba(0, 102, 255, 0.22), transparent 40%);
  pointer-events: none;
}
.il-pc-content {
  position: relative;
  display: grid;
  grid-template-columns: 1.4fr 320px;
  gap: 48px;
  align-items: center;
}
.il-pc-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: #0F1B2D;
  background: #FFD60A;
  padding: 8px 16px;
  border-radius: 50px;
  margin-bottom: 18px;
}
.il-pc-tag i {
  font-size: 10px;
}
.il-pc-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 38px;
  font-weight: 800;
  line-height: 1.15;
  margin: 0 0 14px;
}
.il-pc-title em {
  color: #FFD60A;
  font-style: normal;
}
.il-pc-sub {
  font-family: 'Lato', sans-serif;
  font-size: 15px;
  line-height: 1.7;
  opacity: 0.88;
  margin: 0 0 24px;
}
.il-pc-features {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.il-pc-features li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 14px;
}
.il-pc-features i {
  color: #FFD60A;
  font-size: 15px;
  flex-shrink: 0;
}
.il-pc-btns {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}
.il-pc-price-card {
  background: #fff;
  color: #0F1B2D;
  border-radius: 20px;
  padding: 30px;
  text-align: center;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.2);
}
.il-pc-from {
  font-family: 'Montserrat', sans-serif;
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: 1.3px;
  text-transform: uppercase;
  color: #5A6A7E;
  display: block;
  margin-bottom: 4px;
}
.il-pc-price {
  display: flex;
  justify-content: center;
  align-items: baseline;
  gap: 4px;
  margin-bottom: 4px;
}
.il-pc-currency {
  font-family: 'Montserrat', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: #0F1B2D;
}
.il-pc-amount {
  font-family: 'Montserrat', sans-serif;
  font-size: 46px;
  font-weight: 800;
  color: #0F1B2D;
  line-height: 1;
  letter-spacing: -1px;
}
.il-pc-period {
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: #5A6A7E;
  display: block;
}
.il-pc-divider {
  height: 1px;
  background: #E5EAF2;
  margin: 22px 0 18px;
}
.il-pc-perks {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  text-align: left;
}
.il-pc-perks li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: #0F1B2D;
}
.il-pc-perks i {
  color: #0066FF;
  font-size: 12px;
  width: 18px;
}
.il-pc-link {
  font-family: 'Montserrat', sans-serif;
  font-size: 12.5px;
  font-weight: 800;
  color: #0066FF;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: gap 0.25s;
}
.il-pc-link:hover {
  gap: 10px;
}
.il-pc-link i {
  font-size: 10px;
}
/* Teachers */
.il-teachers-sec {
  padding: 100px 0;
  background: #F4F8FF;
}
.il-teachers-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
.il-teacher {
  background: #fff;
  border-radius: 20px;
  padding: 30px 24px;
  border: 1px solid #E5EAF2;
  text-align: center;
  transition: all 0.3s ease;
  box-shadow: 0 8px 28px rgba(15, 27, 45, 0.04);
}
.il-teacher:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0, 102, 255, 0.12);
  border-color: #E8F1FF;
}
.il-teach-ico {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: #E8F1FF;
  color: #0066FF;
  display: grid;
  place-items: center;
  font-size: 24px;
  margin: 0 auto 16px;
  transition: all 0.3s ease;
}
.il-teacher:hover .il-teach-ico {
  background: #0066FF;
  color: #fff;
  transform: scale(1.08);
}
.il-teacher h4 {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: #0F1B2D;
  margin: 0 0 8px;
  line-height: 1.3;
}
.il-teacher p {
  font-family: 'Lato', sans-serif;
  font-size: 13px;
  color: #5A6A7E;
  line-height: 1.6;
  margin: 0;
}
/* FAQ */
.il-faq-sec {
  padding: 100px 0;
  background: #fff;
}
.il-faq-list {
  max-width: 880px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
/* Responsive — IELTS */
@media (max-width: 1100px) {
  .il-stats-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
  }
  .il-stat {
    padding: 24px 18px;
  }
  .il-stat-num {
    font-size: 34px;
  }
  .il-skills-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
  .il-format-grid {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .il-what-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .il-pricing-card {
    padding: 48px 40px;
  }
  .il-pc-content {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .il-pc-features {
    grid-template-columns: 1fr;
  }
  .il-pc-title {
    font-size: 32px;
  }
  .il-teachers-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 680px) {
  .il-stats-sec {
    padding: 32px 0;
  }
  .il-skills-sec,
  .il-format-sec,
  .il-what-sec,
  .il-pricing-sec,
  .il-teachers-sec,
  .il-faq-sec {
    padding: 64px 0;
  }
  .il-sec-head {
    margin-bottom: 36px;
  }
  .il-stats-grid {
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }
  .il-stat {
    padding: 22px 16px;
  }
  .il-stat-ico {
    width: 42px;
    height: 42px;
    font-size: 17px;
    margin-bottom: 10px;
  }
  .il-stat-num {
    font-size: 28px;
  }
  .il-skills-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .il-skill-card {
    padding: 26px 22px;
  }
  .il-week {
    flex-direction: column;
    gap: 10px;
    align-items: flex-start;
    padding: 18px;
  }
  .il-format-card {
    padding: 28px 24px;
  }
  .il-day {
    flex-direction: column;
    gap: 4px;
  }
  .il-day-time {
    min-width: auto;
    font-size: 11.5px;
  }
  .il-what-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .il-pricing-card {
    padding: 36px 24px;
    border-radius: 24px;
  }
  .il-pc-title {
    font-size: 26px;
  }
  .il-pc-amount {
    font-size: 40px;
  }
  .il-pc-price-card {
    padding: 24px;
  }
  .il-pc-btns {
    flex-direction: column;
  }
  .il-pc-btns .btn {
    width: 100%;
    justify-content: center;
  }
  .il-teachers-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
}
@media (max-width: 480px) {
  .il-stats-sec {
    padding: 24px 0;
  }
  .il-stat {
    padding: 18px 14px;
  }
  .il-stat-ico {
    width: 36px;
    height: 36px;
    font-size: 14px;
    margin-bottom: 8px;
  }
  .il-stat-num {
    font-size: 24px;
  }
  .il-skill-card {
    padding: 22px 18px;
  }
  .il-sk-title {
    font-size: 18px;
  }
  .il-sk-sub {
    font-size: 12px;
  }
  .il-format-blurb {
    font-size: 14px;
  }
  .il-week {
    padding: 14px 16px;
  }
  .il-week-body strong {
    font-size: 14px;
  }
  .il-week-body span {
    font-size: 13px;
  }
  .il-format-card {
    padding: 22px 18px;
  }
  .il-fc-title {
    font-size: 18px;
  }
  .il-what-card {
    padding: 24px 20px;
  }
  .il-what-ico {
    width: 44px;
    height: 44px;
    font-size: 18px;
    border-radius: 12px;
    margin-bottom: 14px;
  }
  .il-what-card h4 {
    font-size: 15px;
  }
  .il-what-card p {
    font-size: 13px;
  }
  .il-pricing-card {
    padding: 24px 20px;
    border-radius: 20px;
  }
  .il-pc-title {
    font-size: 22px;
  }
  .il-pc-sub {
    font-size: 14px;
  }
  .il-pc-features li {
    font-size: 13px;
  }
  .il-pc-amount {
    font-size: 34px;
  }
  .il-pc-price-card {
    padding: 20px;
  }
  .il-teacher {
    padding: 24px 18px;
  }
  .il-teach-ico {
    width: 48px;
    height: 48px;
    font-size: 20px;
  }
  .il-teacher h4 {
    font-size: 15px;
  }
}
@media (max-width: 380px) {
  .il-stat {
    padding: 14px 10px;
  }
  .il-stat-num {
    font-size: 22px;
  }
  .il-skill-card {
    padding: 18px 14px;
  }
  .il-sk-title {
    font-size: 16px;
  }
  .il-format-card {
    padding: 18px 14px;
  }
  .il-fc-title {
    font-size: 16px;
  }
  .il-what-card {
    padding: 20px 16px;
  }
  .il-pricing-card {
    padding: 18px 16px;
  }
  .il-pc-title {
    font-size: 20px;
  }
  .il-pc-amount {
    font-size: 28px;
  }
  .il-teacher {
    padding: 20px 14px;
  }
}
/* ── Mobile Nav ─────────────────────────────────────────────────────────── */
.mob-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 8, 32, 0.58);
  z-index: 990;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
}
.mob-overlay.show {
  opacity: 1;
  pointer-events: all;
}
.hbg.open span:nth-child(1) {
  transform: translateY(7.5px) rotate(45deg);
}
.hbg.open span:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.hbg.open span:nth-child(3) {
  transform: translateY(-7.5px) rotate(-45deg);
}
/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 1440px) {
  .why-sec .wrap {
    max-width: 1240px;
  }
}
@media (max-height: 980px) and (min-width: 901px) {
  .hero-slide {
    align-items: flex-start;
  }
  .hs-content {
    padding-top: 48px;
    padding-bottom: 160px;
  }
  .hs-h1-main {
    font-size: clamp(56px, 8vw, 118px);
  }
  .hs-sub {
    margin-bottom: 34px;
  }
  .hs-btns {
    margin-bottom: 34px;
  }
  .hs-stats {
    padding-top: 22px;
    gap: 38px;
  }
  .hs-stat-num {
    font-size: 28px;
  }
}
/* ── MacBook Pro 16" / large laptop (1381–1440px) ────────────────────── */
@media (max-width: 1440px) {
  .nav-wrap {
    padding: 0 44px;
    gap: 20px;
  }
}
/* ── MacBook Air 13" / MacBook Pro 14" (1201–1380px) ─────────────────── */
@media (max-width: 1380px) {
  .nav-wrap {
    padding: 0 36px;
    gap: 16px;
  }
  .nav-menu > li > a {
    padding: 9px 12px;
    font-size: 12.5px;
  }
  .nav-phone {
    padding: 10px 16px;
    font-size: 12px;
    letter-spacing: 1.2px;
  }
  .lang-sw .lang-sw-btn {
    padding: 7px 10px;
  }
}
/* ── MacBook Air 13" tight (1201–1280px) ─────────────────────────────── */
@media (max-width: 1280px) {
  .wrap,
  .cta-in {
    padding: 0 36px;
  }
  .nav-wrap {
    padding: 0 36px;
    gap: 14px;
  }
  .nav-menu > li > a {
    padding: 9px 10px;
    font-size: 12px;
  }
  .nav-phone {
    padding: 9px 14px;
    font-size: 11.5px;
    letter-spacing: 1px;
  }
  .lang-sw .lang-sw-btn {
    padding: 7px 8px;
    gap: 5px;
  }
  .hs-content {
    padding: 0 20px 130px 96px;
    max-width: 560px;
  }
  .hs-card {
    right: 3%;
    top: 40%;
    width: 216px;
    padding: 30px 22px;
  }
  .hero-lang-nav {
    left: 96px;
  }
  .hero-arrows {
    right: 3%;
  }
  .footer-grid {
    gap: 28px;
  }
}
@media (max-width: 1200px) {
  .nav-menu {
    gap: 0;
  }
  .nav-menu > li > a {
    padding: 8px 10px;
    font-size: 12px;
  }
  .nav-phone {
    padding: 10px 18px;
    font-size: 12px;
    letter-spacing: 1.2px;
  }
  .hs-content {
    padding: 0 0 130px 80px;
    max-width: 520px;
  }
  .hs-card {
    right: 4%;
    top: 40%;
    width: 210px;
    padding: 30px 24px;
  }
  .hs-card-flag img {
    height: 48px;
    width: 72px;
  }
  .hs-card-lang {
    font-size: 24px;
  }
  .hs-card-script {
    font-size: 16px;
    margin-bottom: 14px;
  }
  .hero-lang-nav {
    left: 80px;
  }
  .hero-arrows {
    right: 4%;
  }
  .why-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .c-grid,
  .blog-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
  }
  .footer-grid {
    grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
    gap: 36px;
  }
}
@media (max-width: 1200px) {
  .story-grid {
    gap: 52px;
  }
  .story-img-sm {
    right: -20px;
    bottom: -20px;
  }
  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .stats-grid {
    grid-template-columns: repeat(4, 1fr);
  }
  .diff-grid {
    gap: 20px;
  }
}
@media (max-width: 1100px) {
  .hs-stats {
    gap: 32px;
  }
  .hs-stat-num {
    font-size: 26px;
  }
  .hero-lang-nav {
    bottom: 30px;
  }
  .hero-arrows {
    bottom: 24px;
  }
  .hs-content {
    padding: 0 32px 110px 80px;
  }
  .sec-title {
    font-size: clamp(26px, 3.6vw, 40px);
  }
  .why-sec .wrap {
    max-width: none;
  }
}
@media (max-width: 1024px) {
  .wrap {
    padding: 0 36px;
  }
  .why-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
  .c-grid,
  .blog-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 22px;
  }
  .edvisa-grid,
  .faq-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 36px;
  }
  .edvisa-sec {
    padding: 90px 0;
  }
  .edvisa-left {
    text-align: left;
  }
  .edvisa-list li {
    font-size: 14.5px;
  }
  .faq-sec {
    padding: 80px 0;
  }
  .faq-langs {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 18px;
    margin-top: 24px;
  }
  .courses-hdr,
  .blog-hdr {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .courses-hdr > a,
  .blog-hdr > a {
    align-self: flex-start;
  }
  .cta-in {
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
    text-align: left;
  }
  .cta-btns {
    justify-content: flex-start;
    width: 100%;
  }
  /* About */
  .story-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .story-img {
    aspect-ratio: 16/9;
  }
  .story-img-sm {
    right: -16px;
    bottom: -16px;
    width: 38%;
  }
  .diff-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .al-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .loc-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .loc-map {
    height: 360px;
  }
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .stat-item {
    border-right: 1px solid rgba(255, 255, 255, 0.08);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  }
  .page-hero,
  .about-hero,
  .thai-course-hero,
  .ct-hero,
  .pl-hero,
  .cd-hero {
    min-height: 500px;
  }
  .ph-inner {
    padding-bottom: 60px;
  }
  /* Course pages */
  .cnav-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .cnav-card {
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  }
  .prog-block-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    padding: 28px;
  }
  .prog-block-right {
    align-items: flex-start;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 14px;
  }
  .prog-levels {
    grid-template-columns: 1fr;
  }
  .prog-level-card {
    border-right: none;
    border-bottom: 1px solid #E5EAF2;
  }
  .prog-level-card:last-child {
    border-bottom: none;
  }
  .tc-hero-char {
    font-size: 220px;
    right: 2%;
  }
  /* Course detail */
  .cd-layout {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .cd-sidebar {
    position: static;
  }
  .cd-list {
    grid-template-columns: 1fr;
  }
  .cd-list li:nth-child(even) {
    border-right: none;
  }
  .cd-list li:nth-last-child(-n+2) {
    border-bottom: 1px solid #E5EAF2;
  }
  .cd-list li:last-child {
    border-bottom: none;
  }
}
.mob-toggle {
  display: none;
}
/* shown only inside mobile drawer */
@media (max-width: 900px) {
  .tb-right,
  .nav-phone {
    display: none;
  }
  .hbg {
    display: flex;
    margin-left: auto;
  }
  .wrap,
  .nav-wrap,
  .cta-in {
    padding: 0 28px;
  }
  .hs-card {
    display: none;
  }
  .hs-content {
    padding: 32px 32px 180px;
    max-width: none;
    text-align: left;
  }
  .hs-sub {
    margin-bottom: 32px;
  }
  .hs-btns {
    margin-bottom: 36px;
  }
  .hs-stats {
    gap: 24px;
    padding-top: 20px;
  }
  .hs-stat-num {
    font-size: 24px;
  }
  .hero-lang-nav {
    left: 32px;
    bottom: 90px;
    flex-wrap: wrap;
    max-width: calc(100% - 64px);
  }
  .hero-arrows {
    right: 32px;
    bottom: 24px;
  }
  .tagline-strip {
    padding: 30px 0;
  }
  .why-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 22px;
  }
  .why-img {
    aspect-ratio: 4/3;
  }
  .c-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .blog-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .edvisa-sec {
    padding: 80px 0;
  }
  .edvisa-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .edvisa-num {
    width: 40px;
    height: 40px;
    font-size: 1.05rem;
  }
  .edvisa-step {
    padding: 18px 20px;
  }
  .swiper-testi {
    padding: 48px 4px 24px !important;
  }
  .t-card {
    padding: 30px 26px;
  }
  .t-card.featured {
    padding-top: 62px;
  }
  .footer {
    padding: 64px 0 24px;
  }
  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }
  .f-bottom {
    flex-direction: column;
    text-align: center;
    gap: 10px;
  }
  /* About mobile */
  .team-grid {
    grid-template-columns: 1fr 1fr;
    gap: 18px;
  }
  .team-photo {
    height: 200px;
  }
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .stat-item {
    padding: 36px 24px;
  }
  .diff-grid {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .diff-card {
    padding: 26px 20px;
  }
  .ph-chips {
    gap: 8px;
  }
  .manifesto-sec {
    padding: 72px 0;
  }
  .manifesto-in {
    gap: 40px;
  }
  .mani-beliefs {
    grid-template-columns: 1fr 1fr;
  }
  .story-img-sm {
    display: none;
  }
  .nav-menu {
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(320px, 88vw);
    flex-direction: column;
    background: #fff;
    padding: 90px 24px 40px;
    gap: 0;
    z-index: 995;
    overflow-y: auto;
    overflow-x: hidden;
    transform: translateX(-110%);
    transition: transform 0.36s cubic-bezier(0.22, 1, 0.36, 1);
    box-shadow: 20px 0 64px rgba(0, 31, 102, 0.25);
    list-style: none;
    justify-content: flex-start;
    flex: 0 0 auto;
  }
  .nav-menu.mob-open {
    transform: translateX(0);
  }
  /* Each top-level <li> is a flex row: <a> + .mob-toggle button */
  .nav-menu > li {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    border-bottom: 1px solid #E5EAF2;
  }
  .nav-menu > li > a {
    padding: 15px 4px;
    border-bottom: none;
    border-radius: 0;
    font-size: 15px;
    color: #0F1B2D;
    flex: 1;
    display: flex;
    align-items: center;
    background: transparent!important;
  }
  .nav-menu > li > a .fa-chevron-down {
    display: none;
  }
  .nav-menu > li.mob-sub-open > a {
    color: #0066FF;
  }
  .nav-menu > li.on > a {
    color: #0066FF;
  }
  .nav-menu > li > .drop {
    width: 100%;
  }
  /* wraps to own flex row */
  /* Toggle button — only visible on mobile */
  .mob-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    flex-shrink: 0;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
  }
  .mob-toggle i {
    font-size: 11px;
    color: rgba(0, 0, 0, 0.45);
    transition: transform 0.28s, color 0.28s;
  }
  .nav-menu > li.mob-sub-open > .mob-toggle i {
    transform: rotate(180deg);
    color: #0066FF;
  }
  .drop {
    position: static!important;
    opacity: 1!important;
    visibility: visible!important;
    transform: none!important;
    box-shadow: none!important;
    border-top: none!important;
    border-radius: 0!important;
    background: transparent!important;
    max-height: 0;
    overflow: hidden;
    padding: 0!important;
    transition: max-height 0.32s ease;
    border-left: 3px solid #E8F1FF !important;
    margin: 0 0 0 8px;
    z-index: auto;
  }
  .nav-menu > li.mob-sub-open > .drop {
    max-height: 600px;
    padding: 6px 0 12px !important;
  }
  .drop li a {
    padding: 10px 0 10px 16px;
    font-size: 14px;
    border-radius: 0;
  }
  .drop li a::before {
    display: none;
  }
  /* depth-2 fly-out becomes inline accordion on mobile */
  .drop--sub {
    margin-left: 16px;
    border-left: 3px solid #E5EAF2 !important;
    max-height: 0;
  }
  /* has-flyout: relative so .mob-toggle can be absolute */
  .drop li.has-flyout > a {
    padding-right: 44px;
  }
  .drop li.has-flyout > a .fa-chevron-right {
    display: none;
  }
  .drop li.has-flyout > .mob-toggle {
    position: absolute;
    top: 0;
    right: 0;
    height: 100%;
    width: 40px;
  }
  .drop li.has-flyout > .mob-toggle i {
    font-size: 10px;
  }
  .drop li.has-flyout.mob-sub-open > .drop--sub {
    max-height: 500px;
    padding: 4px 0 8px !important;
  }
  .drop li.has-flyout.mob-sub-open > .mob-toggle i {
    transform: rotate(90deg);
    color: #0066FF;
  }
}
@media (max-width: 680px) {
  .sec,
  .why-sec,
  .courses-sec,
  .testi-sec,
  .edvisa-sec,
  .faq-sec,
  .blog-sec,
  .al-sec,
  .loc-sec,
  .diff-sec,
  .team-sec {
    padding: 64px 0;
  }
  .why-grid,
  .c-grid,
  .blog-grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  /* About small */
  .stats-grid {
    grid-template-columns: 1fr 1fr;
  }
  .stat-item {
    padding: 28px 20px;
  }
  .diff-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .team-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .team-photo {
    height: 260px;
  }
  .al-grid {
    grid-template-columns: 1fr;
  }
  .ph-title {
    font-size: clamp(30px, 8vw, 46px);
  }
  .ph-sub {
    font-size: 15px;
  }
  .manifesto-title {
    font-size: clamp(28px, 7.5vw, 42px);
  }
  .manifesto-text {
    font-size: 15px;
  }
  .mani-beliefs {
    grid-template-columns: 1fr;
    gap: 1px;
  }
  .mani-belief {
    padding: 28px 24px;
  }
  .loc-map {
    height: 300px;
  }
  .al-top {
    height: 130px;
  }
  .al-char {
    font-size: 80px;
  }
  /* Course pages */
  .cnav-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .cnav-card {
    padding: 20px 16px;
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  }
  .tc-hero-char {
    display: none;
  }
  .prog-block-header {
    padding: 24px;
  }
  .prog-level-card {
    padding: 20px;
  }
  .ph-btns {
    gap: 10px;
  }
  .ph-btns .btn {
    width: 100%;
  }
  .story-lead {
    font-size: 16px;
  }
  .hero-swiper {
    height: 580px;
    min-height: 0;
  }
  .hero-slide {
    align-items: flex-start;
    height: 100%;
  }
  .hs-h1-main {
    font-size: clamp(46px, 12vw, 72px);
    line-height: 0.92;
  }
  .hs-h1-sub {
    font-size: 22px;
    margin-bottom: 6px;
  }
  .hs-tag {
    margin-bottom: 16px;
    font-size: 10px;
  }
  .hs-sub {
    font-size: 14.5px;
    margin-bottom: 24px;
    line-height: 1.7;
  }
  .hs-content {
    padding: 40px 22px 90px;
    width: 100%;
  }
  .hs-char {
    font-size: clamp(160px, 36vw, 260px);
    right: -10%;
    bottom: -2%;
  }
  .hs-btns {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 0;
  }
  .hs-btns .btn {
    flex: 1 1 130px;
    justify-content: center;
    padding: 13px 14px;
    font-size: 10.5px;
    letter-spacing: 1.4px;
  }
  .hs-stats {
    display: none;
  }
  .hero-lang-nav {
    left: 50%;
    right: auto;
    bottom: 24px;
    transform: translateX(-50%);
    width: calc(100% - 140px);
    max-width: 300px;
    gap: 2px;
    justify-content: center;
    flex-wrap: nowrap;
    background: rgba(10, 18, 40, 0.55);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 100px;
    padding: 5px;
    box-shadow: 0 12px 36px rgba(0, 0, 0, 0.35);
  }
  .hln-btn {
    flex: 1 1 0;
    min-width: 0;
    padding: 10px 6px;
    font-size: 9.5px;
    letter-spacing: 0.6px;
    justify-content: center;
    gap: 5px;
    background: transparent;
    border: none;
  }
  .hln-btn img {
    width: 15px;
    height: 11px;
    flex-shrink: 0;
    border-radius: 2px;
  }
  .hln-btn.on {
    box-shadow: 0 4px 14px rgba(255, 214, 10, 0.4);
  }
  .hero-arrows {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 24px;
    top: auto;
    transform: none;
    width: auto;
    height: auto;
    display: block;
    background: transparent;
    border: none;
    padding: 0;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-radius: 0;
    pointer-events: none;
    z-index: 25;
    gap: 0;
  }
  .hero-arrows .hero-arr {
    pointer-events: auto;
    position: absolute;
    bottom: 0;
    width: 40px;
    height: 40px;
    font-size: 12px;
    background: rgba(10, 18, 40, 0.55);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 50%;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
  }
  .hero-arrows #hPrev {
    left: 16px;
  }
  .hero-arrows #hNext {
    right: 16px;
  }
  .hero-arrows .hero-dots {
    display: none;
  }
  .hs-counter {
    top: 20px;
    right: 20px;
  }
  .tagline-strip {
    padding: 24px 0;
  }
  .tagline-in h2 {
    font-size: clamp(22px, 6.5vw, 32px);
    letter-spacing: 0.5px;
  }
  .why-card {
    padding: 20px;
  }
  .why-img {
    aspect-ratio: 16/10;
    margin-bottom: 18px;
  }
  .why-img .pill {
    top: 12px;
    left: 12px;
    font-size: 9.5px;
    padding: 5px 11px;
  }
  .why-card h3 {
    font-size: 18px;
  }
  .c-card {
    max-width: 480px;
    margin: 0 auto;
    width: 100%;
  }
  .c-img {
    height: 200px;
  }
  .c-price .amt {
    font-size: 32px;
  }
  .t-card {
    padding: 30px 24px;
  }
  .t-card.featured {
    padding-top: 62px;
  }
  .t-card.featured .t-av-top {
    width: 68px;
    height: 68px;
    top: -34px;
  }
  .testi-nav {
    gap: 18px;
    margin-top: 32px;
  }
  .testi-arr {
    width: 44px;
    height: 44px;
    font-size: 13px;
  }
  .edvisa-sec {
    padding: 64px 0;
  }
  .edvisa-left h2 {
    font-size: clamp(28px, 7vw, 40px);
  }
  .edvisa-step {
    padding: 18px 18px;
    gap: 14px;
  }
  .edvisa-num {
    width: 38px;
    height: 38px;
    font-size: 1rem;
    border-radius: 10px;
  }
  .edvisa-note {
    padding: 14px 16px;
    font-size: 13.5px;
  }
  .faq-grid {
    gap: 36px;
  }
  .faq-q {
    padding: 18px 20px;
    font-size: 14.5px;
    gap: 12px;
  }
  .faq-langs {
    flex-direction: column;
    gap: 10px;
  }
  .blog-card {
    max-width: 480px;
    margin: 0 auto;
    width: 100%;
  }
  .blog-img {
    height: 200px;
  }
  .cta-bar {
    padding: 54px 0;
  }
  .cta-in {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }
  .cta-btns {
    justify-content: center;
    width: 100%;
  }
  .cta-btns .btn {
    flex: 1 1 auto;
    justify-content: center;
    min-width: 160px;
  }
  .cta-chips {
    justify-content: center;
  }
  .footer {
    padding: 54px 0 22px;
  }
  .f-contact li {
    font-size: 13.5px;
  }
  .tb-left {
    justify-content: center;
    text-align: center;
    width: 100%;
    gap: 14px;
    font-size: 11px;
    flex-wrap: wrap;
  }
  .tb-left a {
    font-size: 11px;
  }
  .topbar .wrap {
    justify-content: center;
  }
  .courses-hdr,
  .blog-hdr {
    flex-direction: column;
    align-items: flex-start;
  }
  .back-top {
    width: 44px;
    height: 44px;
    bottom: 22px;
    right: 22px;
  }
}
@media (max-width: 480px) {
  .wrap,
  .nav-wrap,
  .cta-in {
    padding: 0 16px;
  }
  .sec,
  .why-sec,
  .courses-sec,
  .testi-sec,
  .edvisa-sec,
  .faq-sec,
  .blog-sec {
    padding: 52px 0;
  }
  .sec-title {
    font-size: clamp(22px, 7vw, 32px);
  }
  .sec-sub {
    font-size: 15px;
  }
  .nav-wrap {
    height: 68px;
    padding: 0 16px;
  }
  .nav-logo img {
    height: 42px;
  }
  .hbg span {
    width: 22px;
  }
  .hero-swiper {
    height: 520px;
  }
  .hs-content {
    padding: 32px 16px 84px;
  }
  .hs-h1-sub {
    font-size: 18px;
    margin-bottom: 4px;
  }
  .hs-h1-main {
    font-size: 54px;
  }
  .hs-sub {
    font-size: 14px;
    margin-bottom: 22px;
  }
  .hs-tag {
    font-size: 9px;
    letter-spacing: 2px;
    margin-bottom: 14px;
  }
  .hs-btns .btn {
    padding: 12px 12px;
    font-size: 10px;
    letter-spacing: 1.2px;
  }
  .hero-lang-nav {
    bottom: 20px;
    width: calc(100% - 120px);
    max-width: 260px;
    padding: 4px;
  }
  .hln-btn {
    padding: 9px 4px;
    font-size: 9px;
    letter-spacing: 0.5px;
    gap: 4px;
  }
  .hln-btn img {
    width: 13px;
    height: 9px;
  }
  .hero-arrows {
    bottom: 20px;
  }
  .hero-arrows .hero-arr {
    width: 36px;
    height: 36px;
    font-size: 11px;
  }
  .hero-arrows #hPrev {
    left: 12px;
  }
  .hero-arrows #hNext {
    right: 12px;
  }
  .hs-counter {
    display: none;
  }
  .hs-char {
    font-size: 180px;
    right: -14%;
    bottom: -3%;
  }
  .tagline-strip {
    padding: 22px 0;
  }
  .tagline-in h2 {
    font-size: clamp(20px, 6vw, 28px);
  }
  .why-sec {
    padding: 54px 0;
  }
  .why-card {
    padding: 18px;
  }
  .why-img {
    aspect-ratio: 16/10;
    font-size: 2.4rem;
    margin-bottom: 16px;
    border-radius: 12px;
  }
  .why-card h3 {
    font-size: 17px;
    margin-bottom: 8px;
  }
  .why-card p {
    font-size: 14px;
  }
  .c-card {
    border-radius: 24px;
  }
  .c-img {
    height: 180px;
  }
  .c-body {
    padding: 22px 22px 24px;
  }
  .c-title {
    font-size: 20px;
  }
  .c-price .amt {
    font-size: 30px;
  }
  .t-card {
    padding: 28px 20px;
    border-radius: 24px;
  }
  .t-text {
    font-size: 14.5px;
  }
  .t-card.featured {
    padding-top: 58px;
  }
  .t-card.featured .t-av-top {
    width: 62px;
    height: 62px;
    top: -30px;
  }
  .testi-arr {
    width: 42px;
    height: 42px;
    font-size: 12px;
  }
  .edvisa-sec {
    padding: 54px 0;
  }
  .edvisa-left h2 {
    font-size: clamp(26px, 8vw, 36px);
  }
  .edvisa-list li {
    font-size: 14px;
    gap: 10px;
  }
  .edvisa-list li i {
    width: 26px;
    height: 26px;
    font-size: 11px;
  }
  .edvisa-step {
    padding: 16px;
    gap: 12px;
    border-radius: 14px;
  }
  .edvisa-step h4 {
    font-size: 14.5px;
  }
  .edvisa-step p {
    font-size: 13px;
  }
  .faq-sec {
    padding: 54px 0;
  }
  .faq-q {
    padding: 16px 18px;
    font-size: 14px;
    gap: 10px;
  }
  .faq-q .qico {
    width: 28px;
    height: 28px;
  }
  .faq-item.open .faq-a {
    padding: 0 18px 18px;
  }
  .faq-a {
    font-size: 13.5px;
  }
  .blog-img {
    height: 180px;
  }
  .blog-body {
    padding: 20px 20px 22px;
  }
  .blog-body h3 {
    font-size: 17px;
  }
  .cta-bar {
    padding: 48px 0;
  }
  .cta-left h3 {
    font-size: clamp(24px, 7vw, 32px);
  }
  .cta-left p {
    font-size: 14.5px;
  }
  .cta-chip {
    font-size: 11px;
    padding: 7px 12px;
  }
  .cta-btns {
    flex-direction: column;
    width: 100%;
  }
  .cta-btns .btn {
    width: 100%;
  }
  .footer {
    padding: 48px 0 24px;
  }
  .footer-grid {
    gap: 28px;
    margin-bottom: 28px;
  }
  .footer h5 {
    font-size: 12px;
    margin-bottom: 14px;
  }
  .f-about {
    font-size: 13.5px;
  }
  .f-contact li {
    font-size: 13px;
  }
  /* About — 480px */
  .page-hero,
  .about-hero {
    min-height: 420px;
  }
  .ph-inner {
    padding-top: 40px;
    padding-bottom: 44px;
  }
  .ph-sub {
    margin-bottom: 20px;
  }
  .ph-btns {
    margin-top: 20px;
  }
  .ph-chips span {
    font-size: 10.5px;
    padding: 7px 12px;
  }
  .stats-bar .stat-item {
    padding: 22px 14px;
  }
  .stat-num {
    font-size: clamp(26px, 7.5vw, 38px);
  }
  .stat-suf {
    font-size: clamp(16px, 4.5vw, 22px);
  }
  .stat-lbl {
    font-size: 9px;
    letter-spacing: 1.8px;
    margin-top: 8px;
  }
  .story-p {
    font-size: 14px;
  }
  .al-top {
    height: 110px;
  }
  .al-char {
    font-size: 68px;
  }
  .al-body {
    padding: 18px 18px 22px;
  }
  .al-body h3 {
    font-size: 18px;
  }
  .al-list li {
    font-size: 13px;
  }
  .manifesto-sec {
    padding: 48px 0;
  }
  .manifesto-in {
    gap: 24px;
  }
  .mani-belief {
    padding: 22px 18px;
  }
  .mani-b-ico {
    width: 42px;
    height: 42px;
    border-radius: 11px;
  }
  .mani-b-ico i {
    font-size: 17px;
  }
  .diff-card {
    padding: 22px 18px;
  }
  .diff-ico {
    width: 48px;
    height: 48px;
    font-size: 18px;
  }
  .diff-card h3 {
    font-size: 15.5px;
    margin: 16px 0 10px;
  }
  .diff-card p {
    font-size: 13.5px;
  }
  .team-body {
    padding: 18px 16px 20px;
  }
  .team-body h4 {
    font-size: 16px;
  }
  .team-bio {
    font-size: 13px;
  }
  .loc-map {
    height: 260px;
  }
  .loc-list li {
    padding: 12px 0;
    gap: 12px;
  }
  .loc-list li > i {
    width: 34px;
    height: 34px;
    font-size: 13px;
    border-radius: 10px;
  }
  .topbar {
    padding: 8px 0;
  }
  .tb-left a:nth-child(3) {
    display: none;
  }
  .tb-left {
    gap: 10px;
  }
  .tb-left a {
    font-size: 10.5px;
  }
  /* Course nav — 480px */
  .cnav-grid {
    grid-template-columns: 1fr;
  }
  .cnav-card {
    flex-direction: row;
    text-align: left;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
  }
  .cnav-body {
    text-align: left;
  }
  .cnav-ico {
    width: 38px;
    height: 38px;
    border-radius: 10px;
  }
  .cnav-ico i {
    font-size: 15px;
  }
  /* Programs — 480px */
  .prog-block-header {
    padding: 18px 20px;
  }
  .prog-name {
    font-size: 26px;
  }
  .prog-desc {
    font-size: 13.5px;
  }
  .prog-levels {
    gap: 14px;
    padding: 20px;
  }
  .prog-level-card {
    padding: 16px;
  }
  .prog-cta {
    margin-top: 36px;
  }
}
@media (max-width: 380px) {
  .nav-logo img {
    height: 38px;
  }
  .hs-h1-main {
    font-size: 54px;
    letter-spacing: -2px;
  }
  .hs-sub {
    font-size: 14px;
  }
  .hln-btn {
    padding: 6px 8px;
    font-size: 8px;
  }
  .hln-btn img {
    width: 12px;
    height: 9px;
  }
  .tagline-in h2 {
    font-size: 20px;
  }
  .sec-title {
    font-size: 22px;
  }
  .c-title {
    font-size: 18px;
  }
  .blog-body h3 {
    font-size: 16px;
  }
  .cta-left h3 {
    font-size: 22px;
  }
  .tb-left {
    font-size: 10px;
  }
  .tb-left a:nth-child(2) {
    display: none;
  }
  /* About — 380px */
  .page-hero,
  .about-hero {
    min-height: 360px;
  }
  .ph-inner {
    padding-top: 32px;
    padding-bottom: 40px;
  }
  .stats-bar .stat-item {
    padding: 18px 12px;
  }
  .mani-belief {
    padding: 18px 14px;
  }
  .diff-card h3 {
    font-size: 15px;
  }
  .loc-map {
    height: 220px;
  }
  /* Course nav — 380px */
  .cnav-card {
    padding: 12px 14px;
    gap: 10px;
  }
  .cnav-ico {
    width: 34px;
    height: 34px;
  }
  /* Programs — 380px */
  .prog-block-header {
    padding: 14px 16px;
  }
  .prog-name {
    font-size: 22px;
  }
  .prog-levels {
    padding: 16px;
    gap: 12px;
  }
  .prog-level-card {
    padding: 14px;
  }
}
/* ── FREE TRIAL MODAL ──────────────────────────────────────────────────── */
.trial-overlay {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(0, 0, 0, 0.58);
  backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s, visibility 0.25s;
}
.trial-overlay.open {
  opacity: 1;
  visibility: visible;
}
.trial-overlay.open .trial-box {
  transform: translateY(0);
}
.trial-box {
  background: #fff;
  border-radius: 18px;
  max-width: 490px;
  width: 100%;
  padding: 44px 40px 36px;
  position: relative;
  text-align: center;
  transform: translateY(20px);
  transition: transform 0.28s;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.22);
}
.trial-close {
  position: absolute;
  top: 14px;
  right: 16px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 18px;
  color: #5A6A7E;
  padding: 4px 8px;
  line-height: 1;
}
.trial-close:hover {
  color: #0F1B2D;
}
.trial-logo {
  height: 68px;
  width: auto;
  margin: 0 auto 18px;
  display: block;
}
.trial-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 21px;
  font-weight: 800;
  color: #0066FF;
  margin: 0 0 8px;
  line-height: 1.25;
}
.trial-sub {
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #0F1B2D;
  font-weight: 600;
  margin: 0 0 22px;
}
.trial-form {
  display: flex;
  flex-direction: column;
  gap: 11px;
}
.trial-form input,
.trial-form select {
  width: 100%;
  padding: 13px 15px;
  border: 1.5px solid #E5EAF2;
  border-radius: 8px;
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  color: #0F1B2D;
  background: #fff;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color 0.18s;
}
.trial-form input:focus,
.trial-form select:focus {
  border-color: #0066FF;
  box-shadow: 0 0 0 3px rgba(0, 102, 255, 0.1);
}
.trial-form input::placeholder,
.trial-form select::placeholder {
  color: #5A6A7E;
}
.trial-form select {
  color: #5A6A7E;
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235A6A7E' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}
.trial-form select.has-val {
  color: #0F1B2D;
}
.trial-submit {
  width: 100%;
  padding: 14px;
  margin-top: 4px;
  background: #0066FF;
  color: #fff;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  font-size: 15px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background 0.2s, opacity 0.2s;
}
.trial-submit:hover {
  background: #003FB5;
}
.trial-submit:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}
.trial-msg {
  margin-top: 10px;
  font-family: 'Lato', sans-serif;
  font-size: 13.5px;
  min-height: 18px;
}
.trial-msg.ok {
  color: #1a7f4b;
}
.trial-msg.err {
  color: #c0392b;
}
@media (max-width: 480px) {
  .trial-box {
    padding: 36px 20px 28px;
  }
  .trial-title {
    font-size: 18px;
  }
  .trial-logo {
    height: 54px;
  }
}
/* ── All Courses Page ────────────────────────────────────────────────────── */
/* Sticky language tab bar */
.ac-tab-bar {
  background: #fff;
  border-bottom: 2px solid #E5EAF2;
  position: sticky;
  top: 130px;
  z-index: 99;
  box-shadow: 0 6px 28px rgba(0, 0, 0, 0.07);
}
.ac-tabs {
  display: flex;
  align-items: center;
  gap: 0;
  padding-top: 0;
  padding-bottom: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.ac-tabs::-webkit-scrollbar {
  display: none;
}
.ac-tab {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 19px 26px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: #5A6A7E;
  border-bottom: 3px solid transparent;
  white-space: nowrap;
  transition: color 0.25s, border-color 0.25s;
  flex-shrink: 0;
}
.ac-tab img {
  width: 22px;
  height: 14px;
  border-radius: 2px;
  object-fit: cover;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
}
.ac-tab:hover {
  color: #0066FF;
  border-bottom-color: rgba(0, 102, 255, 0.35);
}
.ac-tab.active {
  color: #0066FF;
  border-bottom-color: #0066FF;
}
.ac-tab-cta {
  margin-left: auto;
  padding: 12px 24px;
  font-size: 10px;
  flex-shrink: 0;
}
/* Language block */
.lang-block.lb-thai {
  --ac: #E8194B;
  --ac-pale: #fff0f3;
  --ac-d: #b5103a;
}
.lang-block.lb-english {
  --ac: #0066FF;
  --ac-pale: #E8F1FF;
  --ac-d: #003FB5;
}
.lang-block.lb-chinese {
  --ac: #C92A55;
  --ac-pale: #fce8ef;
  --ac-d: #9f1e41;
}
/* Language banner header */
.lang-block-header {
  padding: 56px 0 48px;
  position: relative;
  overflow: hidden;
}
.lb-thai .lang-block-header {
  background: linear-gradient(120deg, #18020f 0%, #5c0e26 55%, #8c1d3d 100%);
}
.lb-english .lang-block-header {
  background: linear-gradient(120deg, #001233 0%, #00277a 55%, #0066FF 100%);
}
.lb-chinese .lang-block-header {
  background: linear-gradient(120deg, #180208 0%, #6b0a26 55%, #a81d3d 100%);
}
.lang-block-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='1.5' fill='rgba(255,255,255,0.06)'/%3E%3C/svg%3E") repeat;
  pointer-events: none;
}
.lbh-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}
.lbh-left {
  display: flex;
  align-items: center;
  gap: 28px;
  flex-wrap: wrap;
}
.lbh-flag {
  width: 88px;
  height: 58px;
  border-radius: 10px;
  object-fit: cover;
  box-shadow: 0 10px 36px rgba(0, 0, 0, 0.45);
  flex-shrink: 0;
}
.lbh-text .sec-label {
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: 8px;
}
.lbh-title {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(30px, 5vw, 52px);
  font-weight: 900;
  color: #fff;
  line-height: 1;
}
.lbh-title em {
  font-style: normal;
  color: #FFD60A;
}
.lbh-script {
  font-size: 20px;
  color: rgba(255, 255, 255, 0.38);
  margin-top: 8px;
}
.lbh-stats {
  display: flex;
  gap: 48px;
  flex-wrap: wrap;
}
.lbh-stat {
  text-align: center;
}
.lbh-stat strong {
  font-family: 'Montserrat', sans-serif;
  font-size: 30px;
  font-weight: 900;
  color: #FFD60A;
  display: block;
  line-height: 1;
}
.lbh-stat span {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
  margin-top: 5px;
  display: block;
}
/* Course type card grid */
.ct-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(256px, 1fr));
  gap: 22px;
  padding: 52px 0 36px;
}
.ct-card {
  background: #fff;
  border-radius: 24px;
  border: 2px solid #E5EAF2;
  padding: 30px 26px 26px;
  transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
  overflow: hidden;
}
.ct-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--ac, #0066FF);
  border-radius: 24px 24px 0 0;
}
.ct-card:hover {
  border-color: var(--ac, #0066FF);
  box-shadow: 0 14px 48px rgba(0, 0, 0, 0.1);
  transform: translateY(-5px);
}
.ct-icon {
  width: 50px;
  height: 50px;
  border-radius: 14px;
  background: var(--ac-pale, #E8F1FF);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  color: var(--ac, #0066FF);
  flex-shrink: 0;
}
.ct-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  font-weight: 900;
  color: #0F1B2D;
  line-height: 1.25;
}
.ct-desc {
  font-size: 13.5px;
  line-height: 1.75;
  color: #5A6A7E;
  flex: 1;
}
.ct-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.ct-tag {
  font-family: 'Montserrat', sans-serif;
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  background: #F4F8FF;
  color: #5A6A7E;
  border-radius: 50px;
  padding: 5px 11px;
}
.ct-price {
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  font-size: 17px;
  color: var(--ac, #0066FF);
  margin-top: 2px;
}
.ct-price span {
  font-size: 12px;
  color: #5A6A7E;
  font-weight: 600;
  margin-left: 3px;
}
.ct-link {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--ac, #0066FF);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 6px;
}
.ct-link i {
  transition: transform 0.2s;
}
.ct-link:hover i {
  transform: translateX(5px);
}
/* Lang section footer */
.lang-section-footer {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  padding-bottom: 70px;
  border-top: 2px solid #E5EAF2;
  padding-top: 32px;
}
.lang-section-footer p {
  color: #5A6A7E;
  font-size: 14px;
  flex: 1;
}
/* "Not sure?" chooser strip */
.ac-chooser {
  background: #001F66;
  padding: 64px 0;
}
.ac-chooser-in {
  display: flex;
  align-items: center;
  gap: 48px;
  flex-wrap: wrap;
}
.ac-chooser-left {
  flex: 1;
  min-width: 260px;
}
.ac-chooser-left h2 {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(22px, 3vw, 34px);
  font-weight: 900;
  color: #fff;
  line-height: 1.2;
}
.ac-chooser-left h2 em {
  font-style: normal;
  color: #FFD60A;
}
.ac-chooser-left p {
  color: rgba(255, 255, 255, 0.65);
  font-size: 15px;
  margin-top: 12px;
  line-height: 1.7;
}
.ac-chooser-cards {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.ac-choose-card {
  background: rgba(255, 255, 255, 0.08);
  border: 1.5px solid rgba(255, 255, 255, 0.15);
  border-radius: 24px;
  padding: 22px 24px;
  text-align: center;
  min-width: 140px;
  transition: all 0.25s;
}
.ac-choose-card img {
  width: 36px;
  height: 24px;
  border-radius: 4px;
  margin: 0 auto 10px;
  object-fit: cover;
}
.ac-choose-card strong {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 4px;
}
.ac-choose-card span {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.5);
}
.ac-choose-card:hover {
  background: rgba(255, 255, 255, 0.15);
  border-color: rgba(255, 255, 255, 0.35);
  transform: translateY(-3px);
}
/* Responsive — All Courses */
@media (max-width: 900px) {
  .ac-tab-bar {
    top: 0;
  }
  .lbh-stats {
    gap: 28px;
  }
  .lbh-stat strong {
    font-size: 24px;
  }
  .lang-section-footer {
    flex-direction: column;
    align-items: flex-start;
  }
}
@media (max-width: 680px) {
  .lbh-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 28px;
  }
  .lbh-stats {
    gap: 24px;
  }
  .ct-grid {
    grid-template-columns: 1fr 1fr;
  }
  .ac-chooser-cards {
    justify-content: center;
  }
}
@media (max-width: 480px) {
  .ct-grid {
    grid-template-columns: 1fr;
  }
  .lbh-flag {
    width: 64px;
    height: 42px;
  }
  .lbh-title {
    font-size: 28px;
  }
}
