/*!**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[13].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"src/app/layout.tsx","import":"Poppins","arguments":[{"subsets":["latin"],"weight":["400","500","600","700","800"],"variable":"--font-poppins","display":"swap"}],"variableName":"poppins"} ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* devanagari */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/034d78ad42e9620c-s.woff2) format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* latin-ext */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/fe0777f1195381cb-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/eafabf029ad39a43-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* devanagari */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/db911767852bc875-s.woff2) format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* latin-ext */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/f10b8e9d91f3edcb-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/8888a3826f4a3af4-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* devanagari */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/29e7bbdce9332268-s.woff2) format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* latin-ext */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/c3bc380753a8436c-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/0484562807a97172-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* devanagari */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/29a4aea02fdee119-s.woff2) format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* latin-ext */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/a1386beebedccca4-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/b957ea75a84b6ea7-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* devanagari */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/_next/static/media/28485c0de2075f40-s.woff2) format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF9, U+200C-200D, U+20A8, U+20B9, U+20F0, U+25CC, U+A830-A839, U+A8E0-A8FF, U+11B00-11B09;
}
/* latin-ext */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/_next/static/media/5fb25f343c7550ca-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: '__Poppins_d5a796';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/_next/static/media/7db6c35d839a711c-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: '__Poppins_Fallback_d5a796';src: local("Arial");ascent-override: 93.62%;descent-override: 31.21%;line-gap-override: 8.92%;size-adjust: 112.16%
}.__className_d5a796 {font-family: '__Poppins_d5a796', '__Poppins_Fallback_d5a796';font-style: normal
}.__variable_d5a796 {--font-poppins: '__Poppins_d5a796', '__Poppins_Fallback_d5a796'
}

/*!*******************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[12].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[12].use[3]!./src/styles/design.css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************/
/* ============================================================
   Class2Learn – Design Template CSS (ported from global_styles.css)
   Asset paths updated: ../assets/ → /assets/
   ============================================================ */

:root {
  --primary: #2e4d8f;
  --primary-dark: #0F0CEE;
  --accent: #0ECBFA;
  --accent-soft: #7be8ff;
  --text: #1b1f2a;
  --muted: #5b6475;
  --surface: #ffffff;
  --surface-soft: #eef8fe;
  --surface-blue: #f1f8fe;
  --shadow: 0 10px 24px rgba(32, 79, 143, 0.16);
  --shadow-soft: 0 4px 10px rgba(31, 62, 117, 0.2);
  --radius: 24px;
}

*, *::before, *::after { box-sizing: border-box; }

::-webkit-scrollbar { width: 7px; }
::-webkit-scrollbar-track { background: #b9b9b9; }
::-webkit-scrollbar-thumb { background: linear-gradient(90deg, #0ECBFA, #0F0CEE); border-radius: 0; }
::-webkit-scrollbar-thumb:hover { background: #94a3b8; }
::-webkit-scrollbar-button { display: none; height: 0; width: 0; }

html { scroll-behavior: smooth; }

body {
  margin: 0 auto;
  max-width: 1600px;
  font-family: "Poppins", sans-serif;
  color: var(--text);
  background: #fff;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

.container {
  width: min(1180px, calc(100% - 48px));
  margin: 0 auto;
}

/* ── Buttons ─────────────────────────────────────────────── */
.button {
  font-family: 'Poppins' !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 160px;
  padding: 12px 30px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), var(--primary-dark));
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  line-height: 1;
  box-shadow: var(--shadow-soft);
  transition: transform 0.28s ease, box-shadow 0.28s ease;
  border: none;
  cursor: pointer;
}
.button:hover { transform: translateY(-2px); box-shadow: 0 12px 22px rgba(23,49,218,0.22); color: #fff; }
.button--small { min-width: 130px; padding: 10px 15px; font-size: 15px; }
.button--large { min-width: 160px; padding: 14px 30px; font-size: 15px; }
.button--outline {
  background: linear-gradient(#fff,#fff) padding-box, linear-gradient(90deg,var(--accent),var(--primary-dark)) border-box;
  border: 2px solid transparent;
  color: #1d212d;
  font-weight: 500;
  box-shadow: var(--shadow-soft) !important;
}
.button--outline:hover { border-color: var(--accent); color: #1d212d; }
.button--full { width: 100%; min-width: 0; padding: 10px 15px; font-size: 14px; }
.button--primary { background: linear-gradient(90deg,var(--accent),var(--primary-dark)); color: #fff; }
.button--secondary {
  background: linear-gradient(#ffffff,#ffffff) padding-box, linear-gradient(90deg,var(--accent),var(--primary-dark)) border-box;
  border: 2px solid transparent; color: var(--primary-dark); box-shadow: var(--shadow-soft) !important;
}
.button--reset {
  min-width: 15%; padding: 14px 26px; border-radius: 999px;
  background: #ffffff; color: var(--primary); border: 1px solid rgba(14,203,250,0.25);
  font-weight: 600; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.6);
  font-family: 'Poppins' !important; cursor: pointer;
}
.button--reset:hover { background: rgba(14,203,250,0.08); }

/* ── Brand / Logo ────────────────────────────────────────── */
.brand img { width: 180px; }
.brand--footer img { width: 200px; }

/* ── Header ──────────────────────────────────────────────── */
.site-header { position: -webkit-sticky; position: sticky; top: 0; z-index: 20; background: #fff; }
.site-header__inner {
  position: relative;
  display: flex; align-items: center; justify-content: space-between; gap: 18px;
}
body:has(.nav-toggle:checked ~ .nav-overlay) { overflow: hidden !important; }

.site-nav {
  display: flex; align-items: center; justify-content: center; gap: 30px;
  flex: 1 1; color: var(--primary); font-size: 15px; font-weight: 600; letter-spacing: 0.01em;
}
.site-nav a { position: relative; transition: color 0.28s ease; }
.site-nav > a::after, .site-nav > div > a::after {
  content: ""; position: absolute; left: 0; bottom: -7px;
  width: 100%; height: 2px; border-radius: 999px;
  background: linear-gradient(90deg,var(--accent),var(--primary-dark));
  transform: scaleX(0); transform-origin: left; transition: transform 0.28s ease;
}
.site-nav a.active::after { transform: scaleX(1); }
.site-nav a:hover { color: #1635b8; }
.site-nav a:hover::after { transform: scaleX(1); }
.site-nav__phone { font-weight: 700; }
.site-nav__phone::after, .button--nav::after, .button--desktop-only::after { display: none; }
.button--nav { display: none; }
.nav-toggle, .nav-toggle__button, .nav-overlay { display: none; }

/* Nav submenu */
.nav-item.has-submenu { display: flex; align-items: center; min-height: 100px; position: relative; }
.nav-link-with-icon { display: flex; align-items: center; gap: 6px; }
.nav-item img.nav-arrow { width: 30px; height: 30px; transition: transform 0.3s ease; }
.submenu {
  position: absolute; top: calc(100% - 10px); left: 0; width: 250px;
  background: #fff; border-radius: 12px; padding: 10px 0;
  display: flex; flex-direction: column; gap: 4px;
  box-shadow: 0 20px 40px rgba(0,0,0,0.08);
  opacity: 0; visibility: hidden; transform: translateY(10px);
  transition: all 0.25s ease; z-index: 999;
}
.submenu a { padding: 10px 18px; color: #333; font-size: 14px; border-radius: 6px; transition: all 0.2s ease; }
.submenu a:hover { background: #f5f7fa; color: #000; }
.nav-item.has-submenu:hover .submenu {
  opacity: 1; visibility: visible; transform: translateY(0);
  border: 2px solid transparent; color: #1d212d; font-weight: 500;
  box-shadow: var(--shadow-soft) !important;
  background: linear-gradient(#fff,#fff) padding-box, linear-gradient(90deg,var(--accent),var(--primary-dark)) border-box;
  max-height: 300px; overflow-y: auto;
}
.nav-item.has-submenu:hover .nav-arrow { transform: rotate(180deg); }

/* ── Hero ────────────────────────────────────────────────── */
.hero-section {
  background:
    linear-gradient(90deg,rgba(238,248,251,0.98) 0%,rgba(238,248,251,0.92) 48%,rgba(232,249,255,0.16) 70%),
    linear-gradient(115deg,#eef9ff 0%,#d9f4fd 42%,#c3f4ff 65%,#dbf4ff 100%);
}
.hero {
  display: grid; grid-template-columns: 1.02fr 0.98fr;
  align-items: center; grid-gap: 24px; gap: 24px; min-height: 400px; width: 100%;
}
.hero__content { padding: 35px 0 35px 50px; animation: fade-up 0.9s ease both; }
.eyebrow {
  margin: 0 0 20px; color: var(--primary);
  font-size: clamp(20px,4vw,30px); font-weight: 500; line-height: 1.12;
}
.eyebrow span {
  background: linear-gradient(270deg,var(--accent),var(--primary-dark));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; font-weight: 600;
}
.hero h2 { color: var(--primary); font-weight: 500; font-size: clamp(15px,4vw,20px); }
.hero__copy { max-width: 520px; margin: 0 0 30px; color: #4f5360; line-height: 1.58; }
.hero__actions { display: flex; gap: 16px; }
.hero__visual { align-self: stretch; }
.hero__visual img { width: 100%; height: 100%; object-fit: cover; animation: fade-in 1s ease both; }

/* ── Feature Strip ───────────────────────────────────────── */
.feature-strip { padding: 48px 0 38px; background: #fff; }
.feature-grid { display: grid; grid-template-columns: repeat(5,minmax(0,1fr)); grid-gap: 18px; gap: 18px; }
.feature-card {
  display: flex; align-items: center; gap: 10px; min-height: 140px;
  padding: 24px 22px; border: 2px solid transparent; border-radius: 22px;
  background: #fff; box-shadow: 0 4px 8px rgb(0 0 0/20%);
  transition: transform 0.28s ease, box-shadow 0.28s ease;
  animation: fade-up 0.8s ease both; justify-content: space-between;
}
.feature-card div { text-align: right; }
.feature-card:hover { transform: translateY(-6px); box-shadow: 0 16px 30px rgba(45,63,114,0.16); }
.feature-card img { width: 70px; height: 70px; object-fit: contain; }
.feature-card strong { display: block; margin-bottom: 4px; color: var(--primary); font-size: 28px; font-weight: 600; line-height: 1.05; }
.feature-card span { display: block; color: #181a22; font-size: 15px; line-height: 1.28; }

/* ── Why Section ─────────────────────────────────────────── */
.why-section {
  padding: 50px 0 70px;
  background: url("/assets/home/Banner 2000 2.png") right/contain no-repeat;
}
.why-section__inner { display: grid; grid-template-columns: 0.8fr 1.2fr; grid-gap: 28px; gap: 28px; align-items: center; }
.section-copy h2, .programs-section h2, .experts-section h2, .cta-actions h2 {
  margin: 0 0 22px; color: var(--primary); font-size: clamp(28px,3vw,46px); line-height: 1.1; font-weight: 600;
}
.check-list { margin: 0; padding: 0; list-style: none; display: grid; grid-gap: 16px; gap: 16px; }
.check-list li { position: relative; padding-left: 28px; font-size: 16px; font-weight: 500; }
.check-list li::before { content: "+"; position: absolute; left: 0; top: -1px; color: #1da0ff; }

/* ── Programs ────────────────────────────────────────────── */
.programs-section { padding: 46px 0 74px; }
.program-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); grid-gap: 28px; gap: 28px; }
.program-card { text-align: center; padding: 8px 8px 0; animation: fade-up 0.8s ease both; }
.program-card img { width: 120px; height: 120px; margin: 0 auto 20px; object-fit: contain; }
.program-card h3 { margin: 0; font-size: 16px; font-weight: 600; line-height: 1.35; letter-spacing: 0.08em; }

/* ── Experts Section ─────────────────────────────────────── */
.experts-section { padding: 50px 0 0; background: linear-gradient(180deg,#edf9ff 0%,#ffffff 100%); }
.expert-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); grid-gap: 20px; gap: 20px; margin: 50px 0; }
.expert-card {
  overflow: hidden; border-radius: 24px; background: #fff; box-shadow: var(--shadow);
  transition: transform 0.28s ease, box-shadow 0.28s ease; animation: fade-up 0.8s ease both;
}
.expert-card:hover { transform: translateY(-8px); box-shadow: 0 18px 32px rgba(32,79,143,0.2); }
.expert-card__photo { height: 170px; background-size: cover; background-position: center; }
.expert-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.expert-card__photo--one { background: radial-gradient(circle at 70% 30%,rgba(255,255,255,0.82),transparent 28%), linear-gradient(140deg,#d6e1eb,#7ba0cb); }
.expert-card__photo--two { background: radial-gradient(circle at 35% 25%,rgba(255,255,255,0.7),transparent 22%), linear-gradient(140deg,#ccecff,#7ea7d8); }
.expert-card__photo--three { background: radial-gradient(circle at 50% 20%,rgba(255,255,255,0.58),transparent 18%), linear-gradient(140deg,#a7c4ea,#7ea7d8); }
.expert-card__photo--four { background: radial-gradient(circle at 65% 18%,rgba(255,255,255,0.32),transparent 18%), linear-gradient(140deg,#2d64ca,#173a84); }
.expert-card__body { padding: 18px 24px 22px; }
.expert-card h3 { margin: 0 0 6px; color: var(--primary); font-size: 20px; font-weight: 600; }
.expert-card p { margin: 0 0 10px; color: #000; font-size: 14px; min-height: 50px; }
.stars { margin-bottom: 16px; color: #ffbc25; font-size: 28px; letter-spacing: 2px; line-height: 1; }

/* ── CTA Section ─────────────────────────────────────────── */
.cta-section { padding: 10px 0 0; background: #eff3ff; }
.cta-banner {
  position: relative; overflow: hidden; padding: 35px 40px; border-radius: 24px;
  background: linear-gradient(90deg,rgba(6,9,35,0.97) 0%,rgba(8,12,45,0.94) 50%,rgba(8,12,45,0.88) 100%),
    radial-gradient(circle at 65% 35%,rgba(44,228,255,0.22),transparent 18%);
  animation: fade-in 0.95s ease both;
  background-image: url("/assets/home/BG 2 2.png");
  background-repeat: no-repeat; background-position: right;
}
.cta-banner__copy { position: relative; z-index: 1; }
.cta-banner__copy h2 {
  margin: 0 0 16px; font-size: clamp(32px,4vw,45px); line-height: 0.98; font-weight: 800;
  background: linear-gradient(360deg,var(--accent),#ffffff);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.cta-banner__copy p { margin: 0; color: rgba(255,255,255,0.88); font-size: 16px; }
.cta-actions { position: relative; padding: 30px 100px 30px; text-align: center; border-radius: 0 0 20px 20px; }
.cta-actions p { margin: 0 0 28px; font-size: 18px; }
.cta-actions__buttons { display: flex; justify-content: center; gap: 10px; }
.cta-actions__student { position: absolute; right: 0; bottom: 0; }

/* ── Profile menu ────────────────────────────────────────── */
.profile-menu { position: relative; display: flex; align-items: center; }

/* invisible bridge fills the gap so hover is not lost between avatar and dropdown */
.profile-menu::after {
  content: ''; position: absolute; top: 100%; left: -8px; right: -8px; height: 14px;
}

.profile-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; overflow: hidden;
  box-shadow: 0 2px 8px rgba(46,77,143,0.22);
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.profile-avatar:hover { box-shadow: 0 4px 16px rgba(46,77,143,0.32); transform: scale(1.05); }
.profile-avatar__initial { color: #fff; font-weight: 700; font-size: 16px; line-height: 1; }

.profile-dropdown {
  position: absolute; top: calc(100% + 10px); right: 0; z-index: 200;
  min-width: 220px; background: #fff; border-radius: 16px;
  box-shadow: 0 12px 36px rgba(24,43,105,0.16); border: 1px solid rgba(46,77,143,0.08);
  padding: 8px 0; opacity: 0; visibility: hidden; pointer-events: none;
  transform: translateY(-8px); transition: opacity 0.22s ease, transform 0.22s ease, visibility 0.22s ease;
}
.profile-menu:hover .profile-dropdown { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); }

.profile-dropdown__header {
  padding: 12px 16px 10px; border-bottom: 1px solid rgba(46,77,143,0.08); margin-bottom: 4px;
  display: flex; flex-direction: column; gap: 2px;
}
.profile-dropdown__header strong { font-size: 14px; font-weight: 700; color: var(--primary-dark); }
.profile-dropdown__header span { font-size: 12px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.profile-dropdown__item {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 10px 16px; font-size: 14px; font-weight: 500;
  color: var(--text); background: none; border: none; text-align: left; cursor: pointer;
  text-decoration: none; transition: background 0.18s ease, color 0.18s ease;
}
.profile-dropdown__item:hover { background: rgba(46,77,143,0.06); color: var(--primary); }
.profile-dropdown__item svg { flex-shrink: 0; opacity: 0.65; }

.profile-dropdown__divider { height: 1px; background: rgba(46,77,143,0.08); margin: 4px 0; }

.profile-dropdown__signout { color: #dc2626; }
.profile-dropdown__signout:hover { background: rgba(220,38,38,0.06); color: #b91c1c; }
.profile-dropdown__signout svg { opacity: 0.8; }

/* ── Footer ──────────────────────────────────────────────── */
.site-footer { padding: 50px 0 40px; background: #fff; }
.site-footer__logo { display: flex; justify-content: center; margin-bottom: 44px; }
.site-footer__grid { display: grid; grid-template-columns: 1.1fr 1fr 1.3fr 1.2fr; grid-gap: 30px; gap: 30px; }
.site-footer__grid h3 { margin: 0 0 18px; font-size: 20px; }
.site-footer__grid a, .site-footer__grid p { display: block; margin: 0 0 8px; color: #20242e; font-size: 15px; }
.site-footer__grid a:hover { color: var(--primary); }
.site-footer__social { display: flex; justify-content: center; gap: 14px; margin-top: 54px; }
.site-footer__social a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px; border-radius: 50%; background: #4D4D4D; color: #fff;
  font-size: 16px; font-weight: 600; transition: background 0.2s;
}
.site-footer__social a[aria-label="Twitter"]:hover { background: #000; }
.site-footer__social a[aria-label="WhatsApp"]:hover { background: #25D366; }
.site-footer__social a[aria-label="Facebook"]:hover { background: #1877F2; }
.site-footer__social a[aria-label="Instagram"]:hover {
  background: radial-gradient(circle at 30% 107%,#fdf497 0%,#fdf497 5%,#fd5949 45%,#d6249f 60%,#285AEB 90%);
}
.site-footer__social a[aria-label="LinkedIn"]:hover { background: #0077B5; }

/* ── Scroll-to-top ───────────────────────────────────────── */
#scrollTopBtn {
  position: fixed; bottom: 30px; right: 30px; z-index: 999;
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(90deg,var(--accent),var(--primary-dark));
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-soft);
  opacity: 0; pointer-events: none; transition: opacity 0.3s ease;
}
#scrollTopBtn.visible { opacity: 1; pointer-events: auto; }
#scrollTopBtn img { width: 20px; height: 20px; filter: brightness(0) invert(1); transform: rotate(-90deg); }

/* ── Animations ──────────────────────────────────────────── */
@keyframes fade-up {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fade-in {
  from { opacity: 0; transform: translateX(14px); }
  to   { opacity: 1; transform: translateX(0); }
}
.feature-card:nth-child(2),.program-card:nth-child(2),.expert-card:nth-child(2) { animation-delay: 0.08s; }
.feature-card:nth-child(3),.program-card:nth-child(3),.expert-card:nth-child(3) { animation-delay: 0.16s; }
.feature-card:nth-child(4),.program-card:nth-child(4),.expert-card:nth-child(4) { animation-delay: 0.24s; }
.feature-card:nth-child(5) { animation-delay: 0.32s; }

/* ── Private Class Page ──────────────────────────────────── */
.hero-pvt {
  display: flex; flex-wrap: wrap; align-items: center; min-height: 400px; width: 100%;
  background: url("/assets/private-class/private-class.png");
  background-size: contain; background-position: right; background-repeat: no-repeat;
  background-color: #e9f6fc;
}
.hero_pvt__visual { display: none; }
#private-class .eyebrow { font-weight: 700; line-height: 1.2em; font-size: 40px; }
#private-class h1.eyebrow span { font-size: 30px; margin-left: 10px; }
#private-class .check-list { gap: 30px; margin: 20px; width: 70%; margin-bottom: 40px; }
#private-class .check-list li { position: relative; padding-left: 50px; }
#private-class .check-list li::before {
  content: ""; position: absolute; left: 0; top: 0; width: 40px; height: 40px;
  background-image: url("/assets/private-class/Arrow points.png");
  background-size: contain; background-repeat: no-repeat;
}
#private-class .hero__actions { justify-self: center; }
#private-class .feature-card { flex-direction: column; justify-content: flex-start; padding: 20px 18px; background: #ffffff80 !important; }
#private-class .feature-card div { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 10px; }
#private-class .feature-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(300px,1fr)); grid-gap: 30px; gap: 30px; width: 80%; }
#private-class .feature-card img { width: 100px; height: 100px; margin-bottom: 20px; }
#private-class .feature-strip {
  padding: 150px 0; padding-bottom: 50px;
  background-image: url("/assets/private-class/background.png");
  background-size: contain; background-repeat: no-repeat;
}
#private-class .feature-card strong { font-size: 18px; color: #000; }
#private-class .feature-card span { font-size: 13px; color: #000; min-height: 80px; }
#private-class .feature-card .arrow { width: 40px; height: 40px; }

/* ── Enquiry / Forms ─────────────────────────────────────── */
#private-class .enquiry-wrapper { padding: 60px 20px 20px; display: flex; justify-content: center; }
#private-class .enquiry_contact {
  width: 100%; max-width: 700px; -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border-radius: 20px; padding: 60px 80px; box-shadow: 0 20px 40px rgba(0,0,0,0.15);
  border: 1px solid #fff; background-color: #ffffff50;
}
#private-class .enquiry_contact .eyebrow { text-align: center; margin-bottom: 30px; }
#private-class .enquiry_contact .eyebrow span { font-size: 35px; font-weight: 800; }
#private-class .form-group { margin-bottom: 30px; }
#private-class .form-group.full { width: 100%; }
#private-class .form-row { display: flex; gap: 20px; }
#private-class .form-row .form-group { flex: 1 1; }
input, select, textarea {
  width: 100%; padding: 10px 20px; border-radius: 30px; border: none; outline: none;
  background: #eaeaf0; font-size: 15px; box-shadow: 0 4px 13px rgb(0 0 0/25%);
  font-family: 'Poppins' !important;
}
textarea { border-radius: 16px; resize: none; }
#private-class .form-submit { text-align: center; margin-top: 20px; }
#private-class .why-section {
  background: url("/assets/private-class/banner-footer.png") center/cover no-repeat;
  padding: 60px 0;
}
#private-class .why-section__inner { display: block; width: 48%; margin-right: 0; }
#private-class .text-button { display: flex; width: 80%; margin-bottom: 40px; flex-wrap: wrap; justify-content: space-between; align-items: center; }
#private-class .cta-actions__buttons { justify-content: flex-start; flex-wrap: wrap; }
#private-class .text-button p { width: 50%; }
#private-class .text-button a.button { width: 30%; max-height: 40px; }

/* ── Group Class ─────────────────────────────────────────── */
#private-class.group-class .hero-pvt { background: url("/assets/group-class/group-banner.png") center/cover no-repeat; }
#private-class.group-class .why-section { background: url("/assets/group-class/group-footer.png") no-repeat; }

/* ── SAT-ACT ─────────────────────────────────────────────── */
#private-class.sat-act .hero-pvt { background: url("/assets/sat-act/sat-banner.png") no-repeat center; background-size: cover; justify-content: end; padding: 80px 20px; width: 100%; }
#private-class.sat-act .hero__content { width: 600px; }
.sat-act-details { background-image: url("/assets/sat-act/Background.png"); background-position: center 60%; background-size: cover; padding: 50px 0 0; }
.sat-details-container { width: 65%; margin: auto; display: flex; align-items: center; justify-content: space-between; gap: 40px; }
.sat-details-grid { display: grid; grid-template-columns: repeat(3,1fr); grid-gap: 30px; gap: 30px; padding: 30px; border-radius: 16px; background: rgba(255,255,255,0.6); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); box-shadow: 0 10px 25px rgba(0,0,0,0.15); max-width: 400px; }
.sat-detail-card { text-align: -webkit-center; }
.sat-detail-card img { width: 60px; height: 60px; margin-bottom: 10px; }
.sat-detail-card h3 { font-size: 14px; font-weight: 600; color: #222; }
.sat-left { position: relative; text-align: center; }
#private-class.sat-act h2.eyebrow, #private-class.sat-act p.sub-text { text-align: center; }
.sat-table-section { width: 75%; margin: 80px auto; background: #fff; padding: 50px 20px; border-radius: 20px; box-shadow: rgb(0 0 0/40%) 0px 5px 15px; }
.sat-table { display: flex; flex-direction: column; overflow: hidden; }
.sat-row { display: grid; grid-template-columns: repeat(4,1fr); text-align: center; }
.sat-header { background: transparent; font-weight: 700; font-size: 13px; color: #0b4dbf; letter-spacing: 1px; margin-bottom: 20px; }
.sat-row div { position: relative; padding: 10px; font-size: 14px; color: #222; font-weight: 500; }
.sat-row div:not(:last-child)::after { content: ""; position: absolute; right: 0; top: 0%; height: 100%; width: 1px; background: #999; }
.sat-row.sat-header div::after { display: none; }
.sat-row div img { width: 30px; height: 30px; justify-self: center; }
.sat-row.sat-header div { font-size: 14px; color: #2e4d8f; }
#sat-act-details .sat-row { display: grid; grid-template-columns: 2fr 1fr 1fr; }
#last-sat-act { background: url("/assets/sat-act/sat-footer.png") no-repeat center !important; background-size: cover; padding: 60px 20px; }
#last-sat-act .section-copy { display: flex; justify-content: space-around; align-items: center; }
#last-sat-act .text-button { display: flex; flex-direction: column; justify-content: center; gap: 50px; }
#last-sat-act .text-button a.button { width: 45%; }
#last-sat-act .eyebrow span { font-weight: 600; font-size: 30px; }
#last-sat-act .eyebrow { text-align: left !important; letter-spacing: 1px; line-height: 1em; }

/* ── Adaptive Test ───────────────────────────────────────── */
#private-class .hero-section { background: #fff; }
#private-class.adaptive-test .hero-pvt { background: none; justify-content: center; }
.heading-content { padding: 50px 0 0; text-align: center; max-width: 60%; margin: 0 auto; }
.heading-content p { font-size: 15px; }
.why-adaptive { text-align: center; }
#private-class .why-adaptive .feature-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); grid-gap: 30px; gap: 30px; width: 80%; margin: 70px auto; }
#private-class .why-adaptive .feature-card { padding: 12px; position: relative; }
#private-class .why-adaptive .feature-card div { flex-direction: row; gap: 10px; width: 100%; }
#private-class .why-adaptive .feature-card img { width: 60px; height: 60px; margin: 0; }
#private-class .why-adaptive .feature-card strong { font-size: 16px; text-align: left; letter-spacing: 1px; }
#private-class .why-adaptive .feature-card:not(:last-child)::after {
  content: ""; position: absolute; top: 45%; right: -40px; width: 45px; height: 45px;
  background: url("/assets/private-class/Arow.png") no-repeat center; background-size: contain;
}
.action-card {
  max-width: 800px; margin: 0 auto; padding: 50px 80px;
  background: url("/assets/adaptive-test/Color gradient 1 box 1.png") no-repeat center/cover;
  border-radius: 40px; box-shadow: 0px 8px 10px 0px #00000040; border: 1px solid #fff;
}
.action-card .hero__actions { margin-top: 30px; }
section.feature-strips { padding: 80px 0; }
.image-background {
  background: url("/assets/adaptive-test/Boy with laptop 1 2.png");
  background-position: right; background-repeat: no-repeat; background-size: contain; background-color: #eefafd;
}
.image-background img { max-width: 55%; }
#private-class.adaptive-test .enquiry-wrapper {
  background-image: url("/assets/adaptive-test/Background 2 2.png");
  background-repeat: no-repeat; background-position: center; padding: 100px 20px;
}

/* ── About Us ────────────────────────────────────────────── */
#private-class.about-us .eyebrow span { font-size: 40px; margin: 0; font-weight: 700; }
#private-class.about-us .eyebrow { font-size: 25px; line-height: 1.6em; }
.about-content { background: url("/assets/about-us/color1.png") no-repeat; background-size: cover; padding: 60px 0; background-position: center; }
.action-cards { max-width: 900px; margin: 0 auto; padding: 20px; border-radius: 20px; box-shadow: 0px 4px 30px 0px #00000040; border: 1px solid #fff; background: #ffffff70; }
#private-class .about-content .check-list { width: 95%; gap: 20px; margin: 20px; }
.team-content { background: url("/assets/about-us/Background 1 2 1.2 1.png") no-repeat; background-size: cover; padding: 50px 0; }
.team-cards { display: flex; align-items: center; gap: 40px; width: 80%; margin: 40px auto; padding: 40px; border-radius: 16px; background: linear-gradient(135deg,#cfe8f3,#a9cfe3); border: 2px solid rgba(255,255,255,0.6); box-shadow: 0 10px 30px rgba(0,0,0,0.1); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); }
.ceo-card img { width: 260px; height: auto; border-radius: 20px; display: block; }
.ceo-bio { max-width: 600px; }
.ceo-name { font-size: 32px; font-weight: 700; color: #0b2c6a; }
.ceo-role { font-size: 18px; letter-spacing: 2px; color: #1e4b8f; font-weight: 600; }
.ceo-designation { font-size: 18px; font-weight: 500; color: #1e4b8f; }
.ceo-description { font-size: 16px; line-height: 1.7; color: #000; }
.advisor-content h2.eyebrow { font-size: 40px !important; font-weight: 600 !important; }
.advisor-cards { display: flex; justify-content: center; gap: 40px; margin: 0 auto; flex-wrap: wrap; }
.advisor-card { width: 300px; padding: 20px; border-radius: 20px; background: url("/assets/about-us/card-image.png") no-repeat center; box-shadow: 0 10px 25px rgba(0,0,0,0.15); transition: transform 0.3s ease; position: relative; overflow: hidden; }
.advisor-card-inner { background: linear-gradient(180deg,#cfe8f3,#a9cfe3); border-radius: 16px; padding: 20px; border: 2px solid rgba(255,255,255,0.7); text-align: center; }
.advisor-image-wrapper { width: 100%; display: flex; justify-content: center; margin-bottom: 15px; }
.advisor-image { width: 180px; height: 180px; border-radius: 16px; object-fit: cover; }
.advisor-name { font-size: 20px; font-weight: 700; color: #0b2c6a; max-width: 90%; margin: 0 auto; }
.advisor-title { font-size: 14px; color: #1e4b8f; line-height: 1.6; font-weight: 500; }
#about-last .hero-pvt { background: url("/assets/about-us/back-image.png") no-repeat center; background-size: cover; justify-content: center; padding: 60px 20px; }
p.hero__description { width: 40%; font-weight: 600; }

/* ── Contact ─────────────────────────────────────────────── */
div#action-contact { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; width: 80%; }
div#action-contact .action-card__content img { width: 100px; height: 100px; }
div#action-contact .action-card__content p { font-size: 13px; font-weight: 500; color: #000; }
div#action-contact .action-card__content { display: flex; flex-direction: column; align-items: center; box-shadow: 0px 4px 10px 0px #00000040; padding: 0 20px; border-radius: 20px; width: 180px; }
div#contact-form { background: url("/assets/private-class/background.png") no-repeat !important; padding: 60px 20px !important; background-position: bottom !important; }
#contact-last { background-image: url("/assets/contact/contact-footer.png") !important; padding: 100px 0 !important; }
#private-class #contact-last .why-section__inner { width: 45%; margin-right: 0; }
.fill-form { text-align: center; margin-top: 0; color: darkblue; font-weight: 500; }

/* ── Sign In / Sign Up ───────────────────────────────────── */
div#sign-in-up-form { background: url("/assets/sign-in-up/sign-gradient.png") no-repeat center; background-size: cover; padding: 40px 20px !important; margin-bottom: 40px; }
p.yes-no-account { font-size: 14px; text-align: center; color: #000; margin-bottom: 0; letter-spacing: 1px; }
p.yes-no-account a { color: #0072ff; font-weight: 600; text-decoration: none; }
#private-class .sign-in-footer { background: url("/assets/sign-in-up/signin-footer.png") center/cover no-repeat; padding: 60px 0; }
#private-class .sign-up-footer { background: url("/assets/sign-in-up/signup-footer.png") center/cover no-repeat; padding: 60px 0; }
.password-field { position: relative; }
.password-field i { position: absolute; right: 15px; top: 50%; transform: translateY(-50%); cursor: pointer; color: #818182; font-size: 15px; }
div#sign-in-up-form .enquiry_contact { max-width: 800px; }

/* ── FAQ ─────────────────────────────────────────────────── */
#private-class .faq-footer { background: url("/assets/faq/faq-footer.png") center/cover no-repeat; padding: 60px 0; }
#private-class .faq-footer .text-button { display: block; width: 100%; }
#private-class .faq-footer .text-button p { width: 70%; color: #0F0CEE; font-weight: 700; }
.faq-section { padding: 60px 0; background: url("/assets/sign-in-up/sign-gradient.png"); }
#private-class.faq-main h1.eyebrow span { margin: 0; font-size: 56px; font-weight: 700; line-height: 1em; }
.faq-container { display: grid; grid-template-columns: 1fr 1.2fr; grid-gap: 40px; gap: 40px; align-items: start; }
.faq-left { padding-right: 20px; }
.faq-left h1 { margin: 0 0 20px; color: var(--primary); font-size: clamp(28px,3vw,42px); font-weight: 700; line-height: 1.2; }
.faq-left > p { margin: 0 0 30px; color: #000; font-size: 15px; font-weight: 500; line-height: 1.6; }
.faq-card { padding: 24px 28px; border-radius: 20px; background: var(--surface-soft); border: 1px solid rgba(14,203,250,0.2); box-shadow: 0px 4px 30px 0px #00000026; }
.faq-card h3 { margin: 0 0 16px; color: var(--primary); font-size: 22px; font-weight: 700; }
.faq-card p { margin: 0 0 12px; color: #000; font-size: 14px; line-height: 1.6; font-weight: 600; }
.faq-card p:last-of-type { margin-bottom: 20px; }
.accordion { display: flex; flex-direction: column; gap: 20px; }
.accordion-item { border: 1px solid #e0e7f1; border-radius: 16px; overflow: hidden; background: #ffffff70; transition: box-shadow 0.28s ease; }
.accordion-item:hover { box-shadow: var(--shadow-soft); }
.accordion-header { font-family: 'Poppins' !important; width: 100%; padding: 15px 45px 15px 20px; border: none; background: #f5f7fb; border-radius: 10px; cursor: pointer; position: relative; font-size: 15px; font-weight: 600; text-align: left; }
.accordion-header::after { content: ""; position: absolute; right: 18px; top: 50%; width: 35px; height: 35px; transform: translateY(-50%); background-image: url("/assets/home/faq-arrow.png"); background-size: contain; background-repeat: no-repeat; transition: transform 0.3s ease; }
.accordion-item.active .accordion-header::after { transform: translateY(-50%) rotate(180deg); }
.accordion-content { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; background: #fff; border-radius: 0 0 10px 10px; padding: 0 20px; }
.accordion-content p { padding: 15px 0; font-size: 14px; margin: 0; color: #000; }
.accordion-item.active .accordion-content { max-height: 200px; overflow-y: auto; }
.faq-right { max-height: 650px; overflow-y: auto; }

/* ── Private Tutor Listing ───────────────────────────────── */
#private-class #private-tutor-last { background: url("/assets/private-tutor/private-tutor-footer.png") center/cover no-repeat; padding: 150px 0; }
#private-tutor-last .eyebrow span { font-size: 40px; font-weight: 700; }
div#private-section-header { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; max-width: 90%; margin: 0 auto; }
p#breadcrumbs { color: #0f0fee; font-weight: 700; }
p#breadcrumbs a { color: #000; text-decoration: none; font-weight: normal; }
.expert-filter-bar { width: 100%; padding: 30px; border-radius: 32px; border: 1px solid rgba(255,255,255,0.8); box-shadow: 0 18px 42px rgba(28,83,156,0.18); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px); background: url("/assets/private-tutor/filter-bg.png"); background-position: top; background-size: cover; }
.expert-filter-bar__search { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.expert-filter-bar__search input { flex: 1 1; min-height: 40px; padding: 0 22px; border-radius: 999px; border: 1px solid rgba(15,28,84,0.12); background: #ffffff; color: var(--text); font-size: 15px; font-weight: 500; box-shadow: inset 0 4px 18px rgba(16,52,97,0.07); transition: border-color 0.24s ease; }
.expert-filter-bar__search input:focus { outline: none; border-color: rgba(14,203,250,0.9); box-shadow: 0 0 0 4px rgba(14,203,250,0.14); }
.expert-filter-bar__controls { display: grid; grid-template-columns: repeat(5,minmax(170px,1fr)) auto; grid-gap: 10px; gap: 10px; align-items: center; }
.filter-control select { width: 100%; min-height: 40px; padding: 0 22px; border-radius: 999px; border: 1px solid rgba(15,28,84,0.12); background: #ffffff; color: #1f2a3f; font-size: 15px; font-weight: 500; -moz-appearance: none; appearance: none; -webkit-appearance: none; }
.expert-filter-bar label.sr-only { display: none; }
.expert-grid .hero__actions { display: flex; gap: 10px; justify-content: center; }
.expert-grid .hero__actions a.button { min-width: 120px; padding: 8px 20px; font-size: 14px; }

/* ── Tutor Profile ───────────────────────────────────────── */
#private-class #tutor-profile-last { background: url("/assets/tutor-profile/Tutor-footer.png") center/cover no-repeat; padding: 100px 0; }
section.tutor-profile__hero { background: #EDFCFF; margin-bottom: 20px; }
.tutor-profile__content { padding: 50px 0; }
.tutor-profile__layout { display: grid; grid-template-columns: 1.2fr 0.8fr; grid-gap: 28px; gap: 28px; align-items: center; padding: 28px; border-radius: 36px; background: url("/assets/tutor-profile/Color gradient box.png") center/cover no-repeat; box-shadow: 0 28px 60px rgba(32,79,143,0.12); border: 1px solid rgba(255,255,255,0.7); -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px); }
.tutor-profile__card { display: flex; align-items: center; gap: 28px; padding: 30px 30px 30px 24px; border-radius: 32px; }
.tutor-profile__avatar { width: 220px; min-width: 220px; aspect-ratio: 1; border-radius: 10px; overflow: hidden; border: 1px solid rgba(255,255,255,0.85); background: linear-gradient(180deg,#ffffff 0%,#e8f4ff 100%); box-shadow: 0 18px 40px rgba(32,79,143,0.14); padding: 10px; }
.tutor-profile__avatar img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: 10px; }
.tutor-profile__name { margin: 0; font-size: clamp(30px,3.2vw,42px); color: var(--primary); font-weight: 600; line-height: 1.05; }
.tutor-profile__role, .tutor-profile__organization, .tutor-profile__experience { color: #000; font-size: 15px; line-height: 1.8; }
.tutor-profile__experience { margin-top: 24px; color: var(--text); font-weight: 600; }
.tutor-profile__actions { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 30px; }
.tutor-profile__expertise { width: 100%; }
.expertise-card { padding: 40px 50px; border-radius: 32px; background: #ffffff4a; border: 1px solid rgba(15,28,84,0.08); box-shadow: 0px 4px 30px 0px #0000001F; }
.expertise-card__title { margin: 0 0 24px; font-size: 22px; color: var(--primary); font-weight: 700; }
.expertise-list { margin: 0; padding: 0; list-style: none; display: grid; grid-gap: 10px; gap: 10px; }
.expertise-list li { display: flex; align-items: center; gap: 10px; color: #000; font-size: 15px; line-height: 1.75; }
.expertise-list li i { margin-top: 3px; color: var(--accent); font-size: 18px; min-width: 22px; line-height: 1; }
.expertise-card__footer { margin-top: 20px; padding-top: 20px; border-top: 1px solid #000; display: flex; align-items: center; gap: 10px; justify-content: center; }
.expertise-card__price { font-size: 34px; font-weight: 800; color: var(--primary-dark); }
.expertise-card__unit { font-size: 16px; color: #5b6475; font-weight: 600; }
#tutor-profile__video { background: url("/assets/tutor-profile/tutor-footers.png") no-repeat center; padding: 50px; max-width: 60%; margin: 0 auto; border-radius: 40px; display: flex; justify-content: center; margin-bottom: 50px; }
section#tutor-profile__about { max-width: 80%; margin: 60px auto; }
section#tutor-profile__about .eyebrow span { font-weight: 700; }

/* ── Tutor Registration ──────────────────────────────────── */
#private-class .tutor-registration-footer { background: url("/assets/tutor-registration/Tutor-reg-footer.png") center/cover no-repeat; padding: 60px 0; }
.checkbox-block { display: flex; align-items: center; gap: 14px; margin-bottom: 10px; }
.checkbox-block input[type="checkbox"] { width: 20px; height: 20px; border-radius: 8px; background: #fff; cursor: pointer; accent-color: var(--accent); box-shadow: none; }
.checkbox-block label { margin: 0; color: var(--text); font-size: 15px; font-weight: 600; line-height: 1.6; }

/* ── Blogs ───────────────────────────────────────────────── */
.blog-cards { display: grid; grid-template-columns: repeat(auto-fit,minmax(280px,1fr)); grid-gap: 24px; gap: 24px; margin: 40px 0; }
.blog-card { border-radius: 20px; overflow: hidden; background: #fff; box-shadow: var(--shadow); transition: transform 0.28s ease; }
.blog-card:hover { transform: translateY(-6px); }
.blog-card__img { width: 100%; height: 200px; object-fit: cover; }
.blog-card__body { padding: 20px; }
.blog-card__tag { display: inline-block; padding: 4px 12px; border-radius: 999px; background: var(--surface-soft); color: var(--primary); font-size: 12px; font-weight: 600; margin-bottom: 10px; }
.blog-card__title { font-size: 16px; font-weight: 700; margin-bottom: 8px; line-height: 1.4; color: var(--text); }
.blog-card__desc { font-size: 14px; color: var(--muted); line-height: 1.6; }
.blog-card__meta { font-size: 12px; color: var(--muted); margin-top: 12px; }

/* ── Pagination ──────────────────────────────────────────── */
.pagination { display: flex; justify-content: center; align-items: center; gap: 0; margin-top: 30px; }
.pagination button { border: none; background: transparent; color: #fff; border-radius: 6px; cursor: pointer; width: 40px; height: 40px; }
.pagination button:disabled { cursor: not-allowed; display: none; }
.pagination span { padding: 6px 10px; cursor: pointer; border-radius: 5px; color: #000; }
.pagination .active { color: #085e87; font-weight: 800; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1180px) {
  .site-header { padding: 16px 0 10px; }
  .hero, .why-section__inner, .program-grid, .expert-grid, .site-footer__grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .feature-grid { grid-template-columns: repeat(3,minmax(0,1fr)); }
  .site-nav { gap: 14px; font-size: 14px; }
  .brand img { width: 210px; }
  .cta-actions { padding: 20px 30px 0; }
}

@media (max-width: 991px) {
  .nav-item.has-submenu { flex-direction: column; align-items: flex-start; min-height: auto; width: 100%; }
  .submenu { position: static; width: 100%; box-shadow: none; border-radius: 0; padding: 0; max-height: 0; overflow: hidden; opacity: 1; visibility: visible; transform: none; transition: max-height 0.3s ease; }
  .nav-item.has-submenu:hover .submenu { max-height: 300px; }
  .submenu a { padding: 12px 10px 12px 25px; }
  .nav-item img.nav-arrow { position: absolute; right: 0; top: 10px; }
}

@media (max-width: 980px) {
  .container { width: min(100% - 28px,1000px); }
  .hero, .why-section__inner, .program-grid { grid-template-columns: 1fr; }
  .expert-grid, .feature-grid, .program-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .site-header { padding: 14px 0 12px; }
  .button--desktop-only { display: none; }
  .nav-toggle { position: absolute; opacity: 0; pointer-events: none; }
  .nav-toggle__button {
    position: relative; z-index: 100; display: inline-flex; flex-direction: column;
    justify-content: center; gap: 6px; width: 52px; height: 52px; padding: 0 13px;
    border: 1px solid rgba(46,77,143,0.14); border-radius: 16px; background: #fff;
    box-shadow: 0 10px 24px rgba(46,77,143,0.12); cursor: pointer; right: 20px;
  }
  .nav-toggle__button span { display: block; width: 100%; height: 3px; border-radius: 999px; background: linear-gradient(90deg,var(--accent),var(--primary-dark)); transition: transform 0.3s ease,opacity 0.3s ease; transform-origin: center; }
  .nav-overlay { position: fixed; inset: 0; z-index: 21; display: block; background: rgba(8,18,44,0.22); opacity: 0; visibility: hidden; transition: opacity 0.3s ease,visibility 0.3s ease; }
  .site-nav { position: absolute; top: 0; right: 0; z-index: 99; display: none; flex-direction: column; align-items: flex-start; gap: 0; width: 100%; padding: 18px; border-radius: 26px; background: linear-gradient(180deg,#ffffff 0%,#f3fbff 100%); box-shadow: 0 22px 42px rgba(24,43,105,0.18); transform: translateX(118%); opacity: 0; pointer-events: none; transition: transform 0.34s ease,opacity 0.34s ease; }
  .site-nav a { width: 100%; padding: 14px 8px; font-size: 16px; }
  .button--nav { display: inline-flex; width: 100%; margin-top: 14px; }
  .nav-toggle:checked + .nav-toggle__button span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
  .nav-toggle:checked + .nav-toggle__button span:nth-child(2) { opacity: 0; }
  .nav-toggle:checked + .nav-toggle__button span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }
  .nav-toggle:checked ~ .nav-overlay { opacity: 1; visibility: visible; }
  .nav-toggle:checked ~ .site-nav { transform: translateX(0); opacity: 1; pointer-events: auto; display: flex; height: 100vh; gap: 10px; padding-top: 100px; }
  .hero__content { padding: 32px 0 10px; }
  .eyebrow { font-size: 34px; }
  .cta-banner { min-height: 260px; padding: 28px 22px; background-position: center; }
  .cta-actions { padding: 20px 18px 0; }
  .cta-actions__buttons { gap: 14px; }
  .button, .button--large { width: 100%; min-width: 0; }
  .why-section { background-size: cover; background-position: 10%; }
  .feature-card img { width: 80px; height: 80px; }
  .cta-actions__student { position: relative !important; right: 0; }
  .expert-card__photo { min-height: 200px; }
  #private-class .check-list { width: 90%; gap: 20px; }
  #private-class .feature-strip { padding: 50px 0; background-size: cover; background-position: top; }
  #private-class .feature-grid { width: 90%; }
  #private-class .enquiry_contact { padding: 40px 20px; }
  #private-class .form-row { flex-direction: column; gap: 0; }
  #private-class .why-section__inner { width: 60%; }
  #private-class .text-button p, #private-class .text-button a.button { width: 100%; }
  .faq-container { grid-template-columns: 1fr; gap: 30px; }
  .faq-left { padding-right: 0; }
  .sat-details-container, .sat-table-section { width: 90%; }
  .sat-details-container { flex-direction: column; }
  .sat-details-grid { grid-template-columns: repeat(2,1fr); }
  .tutor-profile__layout { grid-template-columns: 1fr; padding: 22px; }
  .tutor-profile__card { flex-direction: column; text-align: center; align-items: center; padding: 0; }
  .expertise-card { padding: 30px 20px; }
  .tutor-profile__avatar { margin: 0 auto; width: 300px; }
  .tutor-profile__actions { justify-content: center; }
  .team-cards { width: 90%; padding: 20px; margin: 0 auto; }
  .site-footer__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  .team-cards { flex-direction: column; text-align: center; padding: 30px; }
  .ceo-card img { width: 220px; }
  .advisor-card { width: 50%; }
  .sat-details-grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 560px) {
  .hero { min-height: auto; }
  .hero__actions { gap: 12px; flex-wrap: wrap; }
  .hero__visual img { border-radius: 20px; }
  .feature-card { padding: 20px 18px; }
  .feature-card strong { font-size: 24px; }
  .program-card img { width: 108px; height: 108px; }
  .expert-card__body { padding: 18px 18px 20px; text-align: center; }
  .cta-banner__copy h2 { font-size: 40px; }
  .cta-actions__student { width: 190px; }
  .cta-actions__buttons { flex-direction: column; }
  .expert-grid, .feature-grid, .program-grid { grid-template-columns: 1fr; }
  .faq-section { padding: 40px 0; }
  .faq-card { padding: 20px; }
  .accordion-header { padding: 14px 16px; font-size: 13px; }
  .site-footer__grid { grid-template-columns: 1fr; }
  .tutor-profile__content { padding: 50px 0 60px; }
  .tutor-profile__actions { flex-direction: column; }
  .button--secondary, .button--primary { width: 100% !important; }
  #private-class #last-sat-act .why-section__inner, #private-class.sat-act .hero__content { width: 100%; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

/* ============================================================
   NEW PAGES — Sessions, Wallet, Tickets, Booking, Portals
   ============================================================ */

/* ── Shared page shell ───────────────────────────────────────── */
.page-section       { padding: 50px 0 80px; }
.page-section--soft { background: var(--surface-soft); }
.page-card {
  background: #fff;
  border-radius: 20px;
  box-shadow: var(--shadow);
  padding: 28px 24px;
  transition: transform .28s ease, box-shadow .28s ease;
}
.page-card:hover { transform: translateY(-4px); box-shadow: 0 16px 32px rgba(32,79,143,.18); }

.page-grid-2 { display: grid; grid-template-columns: 1fr 1fr;       grid-gap: 24px;       gap: 24px; }
.page-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); grid-gap: 24px; gap: 24px; }
.page-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); grid-gap: 20px; gap: 20px; }

/* ── Status badges ───────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
}
.badge--green  { background: #d1fae5; color: #065f46; }
.badge--blue   { background: #dbeafe; color: #1d4ed8; }
.badge--yellow { background: #fef3c7; color: #92400e; }
.badge--red    { background: #fee2e2; color: #991b1b; }
.badge--gray   { background: #f3f4f6; color: #6b7280; }

/* ── Session cards ───────────────────────────────────────────── */
.session-card {
  background: #fff;
  border-radius: 20px;
  box-shadow: var(--shadow-soft);
  padding: 22px 24px;
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 14px;
  transition: box-shadow .28s ease;
}
.session-card:hover { box-shadow: var(--shadow); }
.session-card__avatar {
  width: 54px; height: 54px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 22px; font-weight: 800; flex-shrink: 0;
}
.session-card__info   { flex: 1 1; }
.session-card__title  { font-weight: 700; font-size: 15px; margin-bottom: 4px; }
.session-card__meta   { font-size: 13px; color: var(--muted); }
.session-card__actions{ display: flex; gap: 10px; }

/* ── Wallet ──────────────────────────────────────────────────── */
.wallet-card {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  border-radius: 24px;
  padding: 36px 32px;
  color: #fff;
  margin-bottom: 32px;
}
.wallet-card__label   { font-size: 14px; opacity: .75; margin-bottom: 8px; letter-spacing: .08em; text-transform: uppercase; }
.wallet-card__balance { font-size: 48px; font-weight: 800; margin-bottom: 4px; }
.wallet-card__currency{ font-size: 16px; opacity: .8; }

.tx-row {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid #f0f0f0;
}
.tx-row:last-child { border-bottom: none; }
.tx-row__icon {
  width: 40px; height: 40px; border-radius: 12px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: 18px;
}
.tx-row__icon--credit { background: #d1fae5; }
.tx-row__icon--debit  { background: #fee2e2; }
.tx-row__info         { flex: 1 1; }
.tx-row__desc         { font-weight: 600; font-size: 14px; }
.tx-row__date         { font-size: 12px; color: var(--muted); }
.tx-row__amount       { font-weight: 700; font-size: 15px; }
.tx-row__amount--credit { color: #059669; }
.tx-row__amount--debit  { color: #dc2626; }

/* ── Ticket system ───────────────────────────────────────────── */
.ticket-card {
  background: #fff;
  border-radius: 16px;
  box-shadow: var(--shadow-soft);
  padding: 20px 22px;
  margin-bottom: 12px;
  display: flex; align-items: flex-start; gap: 16px;
  transition: box-shadow .28s;
}
.ticket-card:hover { box-shadow: var(--shadow); }
.ticket-card__body  { flex: 1 1; }
.ticket-card__subject { font-weight: 700; font-size: 15px; margin-bottom: 6px; }
.ticket-card__meta  { font-size: 12px; color: var(--muted); }

.ticket-reply {
  background: var(--surface-soft);
  border-radius: 14px;
  padding: 16px 18px;
  margin-bottom: 12px;
}
.ticket-reply--admin { background: #eef2ff; }
.ticket-reply__name  { font-weight: 600; font-size: 13px; margin-bottom: 4px; color: var(--primary); }
.ticket-reply__text  { font-size: 14px; line-height: 1.6; }
.ticket-reply__date  { font-size: 11px; color: var(--muted); margin-top: 6px; }

/* ── Booking flow ────────────────────────────────────────────── */
.slot-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  grid-gap: 12px;
  gap: 12px;
  margin: 20px 0;
}
.slot-btn {
  padding: 10px 14px;
  border: 2px solid #e0e7f1;
  border-radius: 12px;
  background: #fff;
  cursor: pointer;
  font-family: 'Poppins', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  transition: all .2s ease;
  text-align: center;
}
.slot-btn:hover   { border-color: var(--accent); background: var(--surface-soft); }
.slot-btn.selected{ border-color: var(--primary-dark); background: var(--primary); color: #fff; }
.slot-btn:disabled{ opacity: .45; cursor: not-allowed; }

.payment-method-card {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 20px;
  border: 2px solid #e0e7f1;
  border-radius: 16px;
  cursor: pointer;
  margin-bottom: 12px;
  transition: all .2s;
}
.payment-method-card:hover   { border-color: var(--accent); }
.payment-method-card.selected{ border-color: var(--primary); background: var(--surface-soft); }
.payment-method-card__icon   { font-size: 28px; }
.payment-method-card__title  { font-weight: 700; font-size: 15px; }
.payment-method-card__desc   { font-size: 12px; color: var(--muted); }

/* ── Progress bar (courses) ──────────────────────────────────── */
.progress-bar       { height: 8px; background: #e8ecf2; border-radius: 999px; overflow: hidden; }
.progress-bar__fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--accent), var(--primary-dark)); transition: width .4s ease; }

/* ── Stat cards ──────────────────────────────────────────────── */
.stat-card {
  background: #fff;
  border-radius: 20px;
  box-shadow: var(--shadow-soft);
  padding: 24px;
  text-align: center;
}
.stat-card__value { font-size: 36px; font-weight: 800; color: var(--primary); }
.stat-card__label { font-size: 13px; color: var(--muted); margin-top: 4px; }

/* ── Join session button ─────────────────────────────────────── */
.join-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 32px;
  background: linear-gradient(90deg, #00c853, #00897b);
  color: #fff; border-radius: 999px; border: none;
  font-family: 'Poppins', sans-serif; font-size: 16px; font-weight: 700;
  cursor: pointer; box-shadow: 0 8px 20px rgba(0,150,100,.3);
  transition: transform .28s, box-shadow .28s;
}
.join-btn:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(0,150,100,.4); }

/* ── Star rating ─────────────────────────────────────────────── */
.star-rating { display: flex; gap: 6px; }
.star-rating__star {
  font-size: 32px; cursor: pointer; color: #d1d5db;
  transition: color .15s;
}
.star-rating__star.active,
.star-rating__star:hover { color: #f59e0b; }

/* ── Responsive for new pages ────────────────────────────────── */
@media (max-width: 980px) {
  .page-grid-2, .page-grid-3, .page-grid-4 { grid-template-columns: 1fr; }
  .wallet-card__balance { font-size: 36px; }
  .session-card { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 560px) {
  .slot-grid { grid-template-columns: repeat(2, 1fr); }
  .page-card { padding: 20px 16px; }
}

/*!********************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[12].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[12].use[3]!./src/styles/globals.css ***!
  \********************************************************************************************************************************************************************************************************************************************************************/
/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  --primary:        #2e4d8f;
  --primary-dark:   #0F0CEE;
  --accent:         #0ECBFA;
  --accent-soft:    #7be8ff;
  --text:           #1b1f2a;
  --muted:          #5b6475;
  --surface:        #ffffff;
  --surface-soft:   #eef8fe;
  --surface-blue:   #f1f8fe;
  --shadow:         0 10px 24px rgba(32,79,143,0.16);
  --shadow-soft:    0 4px 10px rgba(31,62,117,0.2);
  --radius:         24px;
  --gradient:       linear-gradient(90deg, var(--accent), var(--primary-dark));
}

/* ── Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Poppins', sans-serif;
  color: var(--text);
  background: #fff;
  overflow-x: hidden;
  max-width: 1600px;
  margin: 0 auto;
}

img  { display: block; max-width: 100%; }
a    { color: inherit; text-decoration: none; }
ul   { list-style: none; }

/* ── Custom Scrollbar ──────────────────────────────────────── */
::-webkit-scrollbar              { width: 7px; }
::-webkit-scrollbar-track        { background: #b9b9b9; }
::-webkit-scrollbar-thumb        { background: var(--gradient); border-radius: 0; }
::-webkit-scrollbar-thumb:hover  { background: #94a3b8; }
::-webkit-scrollbar-button       { display: none; height: 0; width: 0; }

/* ── Container ─────────────────────────────────────────────── */
.c2l-container {
  width: min(1180px, calc(100% - 48px));
  margin: 0 auto;
}

/* ── Buttons ───────────────────────────────────────────────── */
.c2l-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 160px;
  padding: 12px 30px;
  border-radius: 999px;
  background: var(--gradient);
  color: #fff;
  font-family: 'Poppins', sans-serif;
  font-size: 15px;
  font-weight: 600;
  line-height: 1;
  box-shadow: var(--shadow-soft);
  border: none;
  cursor: pointer;
  transition: transform 0.28s ease, box-shadow 0.28s ease;
  white-space: nowrap;
}
.c2l-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 22px rgba(23,49,218,0.22);
  color: #fff;
}
.c2l-btn--outline {
  background: linear-gradient(#fff,#fff) padding-box,
              var(--gradient) border-box;
  border: 2px solid transparent;
  color: #1d212d;
  font-weight: 500;
}
.c2l-btn--outline:hover { border-color: var(--accent); color: #1d212d; }
.c2l-btn--sm  { min-width: 130px; padding: 10px 15px; font-size: 14px; }
.c2l-btn--lg  { min-width: 180px; padding: 14px 36px; font-size: 16px; }
.c2l-btn--full{ width: 100%; min-width: 0; }

/* ── Eyebrow / Gradient Text ───────────────────────────────── */
.c2l-eyebrow {
  font-size: clamp(22px, 4vw, 32px);
  font-weight: 800;
  line-height: 1.2;
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.c2l-eyebrow span { display: block; }

/* ── Section Headings ──────────────────────────────────────── */
.c2l-section-title {
  font-size: clamp(28px, 3vw, 46px);
  font-weight: 700;
  color: var(--text);
  margin-bottom: 12px;
}
.c2l-section-subtitle {
  font-size: 16px;
  color: var(--muted);
  max-width: 560px;
}

/* ── Check List ────────────────────────────────────────────── */
.c2l-check-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 16px;
}
.c2l-check-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 16px;
  font-weight: 500;
  color: var(--text);
}
.c2l-check-list li::before {
  content: '+';
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--gradient);
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  flex-shrink: 0;
}

/* ── Cards ─────────────────────────────────────────────────── */
.c2l-card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 28px 24px;
  transition: transform 0.28s ease, box-shadow 0.28s ease;
}
.c2l-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 32px rgba(32,79,143,0.20);
}

.c2l-feature-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  background: var(--surface);
  border-radius: 16px;
  box-shadow: var(--shadow-soft);
}
.c2l-feature-card img { width: 48px; height: 48px; object-fit: contain; }
.c2l-feature-card strong { display: block; font-size: 20px; font-weight: 700; color: var(--primary); }
.c2l-feature-card span  { font-size: 13px; color: var(--muted); }

.c2l-program-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 28px 24px;
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  text-align: center;
  transition: transform 0.28s ease, box-shadow 0.28s ease;
  cursor: pointer;
}
.c2l-program-card:hover { transform: translateY(-4px); box-shadow: 0 16px 32px rgba(32,79,143,0.20); }
.c2l-program-card img { width: 64px; height: 64px; object-fit: contain; }
.c2l-program-card h3 { font-size: 18px; font-weight: 600; }

.c2l-expert-card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: transform 0.28s ease, box-shadow 0.28s ease;
}
.c2l-expert-card:hover { transform: translateY(-4px); box-shadow: 0 16px 32px rgba(32,79,143,0.2); }
.c2l-expert-card__img { width: 100%; height: 220px; object-fit: cover; }
.c2l-expert-card__body { padding: 18px 20px; }
.c2l-expert-card__name { font-size: 17px; font-weight: 700; margin-bottom: 4px; }
.c2l-expert-card__role { font-size: 13px; color: var(--muted); margin-bottom: 8px; }
.c2l-expert-card__stars { color: #f5a623; font-size: 14px; margin-bottom: 14px; }

.c2l-blog-card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: transform 0.28s ease;
}
.c2l-blog-card:hover { transform: translateY(-4px); }
.c2l-blog-card__img { width: 100%; height: 200px; object-fit: cover; }
.c2l-blog-card__body { padding: 20px; }
.c2l-blog-card__tag {
  display: inline-block;
  padding: 4px 12px;
  background: var(--surface-soft);
  color: var(--primary);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 10px;
}
.c2l-blog-card__title { font-size: 16px; font-weight: 700; margin-bottom: 8px; line-height: 1.4; }
.c2l-blog-card__desc  { font-size: 14px; color: var(--muted); line-height: 1.6; }
.c2l-blog-card__meta  { font-size: 12px; color: var(--muted); margin-top: 12px; }

/* ── Hero Sections ─────────────────────────────────────────── */
.c2l-hero {
  background: linear-gradient(135deg, var(--surface-blue) 0%, var(--surface-soft) 100%);
  padding: 80px 0 60px;
  overflow: hidden;
}
.c2l-hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  grid-gap: 48px;
  gap: 48px;
}
.c2l-hero__content { max-width: 540px; }
.c2l-hero__subtitle {
  font-size: clamp(16px, 2vw, 20px);
  font-weight: 600;
  color: var(--primary);
  margin-bottom: 16px;
}
.c2l-hero__desc {
  font-size: 16px;
  color: var(--muted);
  margin: 16px 0 28px;
  line-height: 1.7;
}
.c2l-hero__actions { display: flex; gap: 16px; flex-wrap: wrap; }
.c2l-hero__visual { display: flex; justify-content: center; }
.c2l-hero__visual img { max-height: 440px; object-fit: contain; }

.c2l-page-hero {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  padding: 80px 0;
  text-align: center;
  color: #fff;
}
.c2l-page-hero h1 { font-size: clamp(28px, 4vw, 48px); font-weight: 800; margin-bottom: 16px; }
.c2l-page-hero p  { font-size: 18px; opacity: 0.85; max-width: 560px; margin: 0 auto; }

/* ── CTA Banner ────────────────────────────────────────────── */
.c2l-cta-banner {
  background: linear-gradient(135deg, #0d1333 0%, #1a2460 100%);
  padding: 72px 0;
  text-align: center;
  color: #fff;
}
.c2l-cta-banner h2 { font-size: clamp(24px, 3vw, 38px); font-weight: 700; margin-bottom: 12px; }
.c2l-cta-banner p  { font-size: 16px; opacity: 0.75; margin-bottom: 32px; }
.c2l-cta-banner__actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ── Sections ──────────────────────────────────────────────── */
.c2l-section {
  padding: 80px 0;
}
.c2l-section--soft { background: var(--surface-soft); }
.c2l-section--blue { background: var(--surface-blue); }

/* ── Forms ─────────────────────────────────────────────────── */
.c2l-form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 18px;
}
.c2l-form-group label { font-size: 14px; font-weight: 500; color: var(--text); }
.c2l-form-input {
  padding: 12px 16px;
  border: 1.5px solid #dde3ef;
  border-radius: 12px;
  font-family: 'Poppins', sans-serif;
  font-size: 14px;
  color: var(--text);
  background: #fff;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  outline: none;
  width: 100%;
}
.c2l-form-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(14,203,250,0.15);
}
.c2l-form-input::placeholder { color: #a0aab8; }
textarea.c2l-form-input { resize: vertical; min-height: 120px; }
select.c2l-form-input { cursor: pointer; }
.c2l-form-error { font-size: 12px; color: #e53e3e; margin-top: 4px; }

/* ── Accordion ─────────────────────────────────────────────── */
.c2l-accordion-item {
  border: 1.5px solid #e8ecf2;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 12px;
  transition: box-shadow 0.2s ease;
}
.c2l-accordion-item.open { box-shadow: var(--shadow-soft); }
.c2l-accordion-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  background: none;
  border: none;
  font-family: 'Poppins', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  text-align: left;
  gap: 12px;
}
.c2l-accordion-icon {
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--gradient);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 700;
  transition: transform 0.3s ease;
}
.c2l-accordion-item.open .c2l-accordion-icon { transform: rotate(45deg); }
.c2l-accordion-body {
  display: none;
  padding: 0 22px 18px;
  font-size: 14px;
  color: var(--muted);
  line-height: 1.7;
}
.c2l-accordion-item.open .c2l-accordion-body { display: block; }

/* ── Pagination ────────────────────────────────────────────── */
.c2l-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 40px;
}
.c2l-pagination button {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1.5px solid #dde3ef;
  background: #fff;
  font-family: 'Poppins', sans-serif;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}
.c2l-pagination button.active,
.c2l-pagination button:hover {
  background: var(--gradient);
  border-color: transparent;
  color: #fff;
}

/* ── Badges / Tags ─────────────────────────────────────────── */
.c2l-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  background: var(--surface-soft);
  color: var(--primary);
}
.c2l-badge--accent { background: var(--accent); color: #fff; }

/* ── Stars ─────────────────────────────────────────────────── */
.c2l-stars { color: #f5a623; font-size: 15px; letter-spacing: 2px; }

/* ── Auth Card ─────────────────────────────────────────────── */
.c2l-auth-wrapper {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--surface-blue) 0%, var(--surface-soft) 100%);
  padding: 60px 24px;
}
.c2l-auth-card {
  background: rgba(255,255,255,0.92);
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
  border-radius: var(--radius);
  padding: 44px 40px;
  width: 100%;
  max-width: 460px;
  box-shadow: var(--shadow);
}
.c2l-auth-card__logo { display: flex; justify-content: center; margin-bottom: 28px; }
.c2l-auth-card__title { font-size: 24px; font-weight: 700; text-align: center; margin-bottom: 6px; }
.c2l-auth-card__subtitle { font-size: 14px; color: var(--muted); text-align: center; margin-bottom: 28px; }

/* ── Tutor Filter Bar ──────────────────────────────────────── */
.c2l-filter-bar {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  padding: 20px 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-bottom: 32px;
}
.c2l-filter-bar input,
.c2l-filter-bar select {
  flex: 1 1;
  min-width: 140px;
  padding: 10px 14px;
  border: 1.5px solid #dde3ef;
  border-radius: 12px;
  font-family: 'Poppins', sans-serif;
  font-size: 13px;
  outline: none;
  background: #fff;
  cursor: pointer;
  transition: border-color 0.2s;
}
.c2l-filter-bar input:focus,
.c2l-filter-bar select:focus { border-color: var(--accent); }

/* ── Grid Utilities ────────────────────────────────────────── */
.c2l-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); grid-gap: 24px; gap: 24px; }
.c2l-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); grid-gap: 24px; gap: 24px; }
.c2l-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); grid-gap: 24px; gap: 24px; }

/* ── Footer link hover ─────────────────────────────────────── */
.c2l-footer-link {
  font-size: 14px;
  color: rgba(255,255,255,0.65);
  transition: color 0.2s;
}
.c2l-footer-link:hover { color: #0ECBFA; }

.c2l-footer-social {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: rgba(255,255,255,0.10);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  transition: background 0.2s;
  color: #fff;
}
.c2l-footer-social:hover { background: rgba(14,203,250,0.30); }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 1180px) {
  .c2l-grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 980px) {
  .c2l-hero__inner { grid-template-columns: 1fr; text-align: center; }
  .c2l-hero__content { max-width: 100%; }
  .c2l-hero__actions { justify-content: center; }
  .c2l-hero__visual { display: none; }
  .c2l-grid-3 { grid-template-columns: repeat(2, 1fr); }
  .c2l-grid-2 { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  .c2l-section { padding: 56px 0; }
  .c2l-grid-3 { grid-template-columns: 1fr; }
  .c2l-grid-4 { grid-template-columns: 1fr; }
  .c2l-auth-card { padding: 32px 20px; }
}

