/* ═══════════════════════════════════════════════════════════════
   Dr. Shreyank Educare — Design System v5
   Palette: Blue primary · Green accent · White ground
═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Inter:wght@300;400;500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',sans-serif;font-size:16px;color:#0f1f14;background:#fff;overflow-x:hidden;-webkit-font-smoothing:antialiased}

:root{
  --bg:#ffffff;--bg-soft:#f0f7f3;--bg-mid:#c8e6d4;
  --border:#b8d4c4;--border-light:#d8ece3;
  --blue:#1a3c34;--blue-dk:#0f2219;--blue-lt:#c8e6d4;--blue-xl:#f0f7f3;
  --green:#1a5c48;--green-mid:#1a7a50;--green-lt:#c8e6d4;--green-xl:#f0f7f3;
  --teal:#1a5c48;--teal-lt:#c8e6d4;
  --ink:#0f1f14;--ink-mid:#3a5a47;--ink-lt:#7a9e8c;
  --white:#fff;--r:14px;--rs:8px;--nav-h:68px;
  --sh:0 2px 12px rgba(26,60,52,.09);
  --sh-md:0 6px 28px rgba(26,60,52,.13);
  --sh-lg:0 16px 52px rgba(26,60,52,.17);
  --sh-xl:0 28px 80px rgba(26,60,52,.20);
}

/* Typography */
h1,h2,h3,h4{font-family:'Playfair Display',serif;font-weight:700;line-height:1.15;color:var(--ink)}
h1{font-size:clamp(2.2rem,5vw,3.6rem)}
h2{font-size:clamp(1.65rem,3.5vw,2.5rem)}
h3{font-size:clamp(1.05rem,2vw,1.4rem)}
h4{font-size:1.02rem}
p{line-height:1.75;color:var(--ink-mid)}
a{color:inherit;text-decoration:none}
em{font-style:italic;color:var(--blue)}
.container{max-width:1160px;margin:0 auto;padding:0 24px}
section{padding:88px 0}

/* Animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.fu{animation:fadeUp .6s ease both}
.d1{animation-delay:.08s}.d2{animation-delay:.18s}.d3{animation-delay:.30s}.d4{animation-delay:.44s}

/* ─── Navigation ─────────────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:500;background:rgba(255,255,255,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-light);transition:box-shadow .3s}
nav.scrolled{box-shadow:var(--sh-md)}
.nav-inner{max-width:1160px;margin:0 auto;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 24px;gap:16px}
.nav-logo{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--ink);text-decoration:none;display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-logo-icon{width:36px;height:36px;border-radius:10px;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0;color:#fff}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{color:var(--ink-mid);text-decoration:none;font-size:.875rem;font-weight:500;padding:7px 12px;border-radius:8px;transition:all .2s}
.nav-links a:hover,.nav-links a.active{color:var(--blue);background:var(--blue-xl)}
.nav-cta{background:var(--blue)!important;color:#fff!important;padding:8px 18px!important;border-radius:100px!important;font-weight:600!important;transition:all .2s!important}
.nav-cta:hover{background:var(--blue-dk)!important;transform:translateY(-1px);box-shadow:0 4px 14px rgba(26,60,52,.35)!important}
/* Hamburger */
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border-radius:8px;border:none;background:transparent}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all .25s}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* Mobile drawer */
.nav-drawer{display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:rgba(255,255,255,.99);z-index:499;padding:16px 20px 40px;overflow-y:auto;flex-direction:column;gap:2px}
.nav-drawer.open{display:flex}
.nav-drawer a{display:block;padding:13px 16px;border-radius:10px;color:var(--ink);font-size:.95rem;font-weight:500;border-bottom:1px solid var(--border-light);transition:all .2s}
.nav-drawer a:hover{background:var(--blue-xl);color:var(--blue)}
.drawer-section-label{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-lt);padding:14px 16px 4px;margin-top:4px}
.drawer-cta{background:var(--blue)!important;color:#fff!important;text-align:center;border-radius:100px!important;font-weight:600!important;border:none!important;margin-top:12px}
.drawer-cta:hover{background:var(--blue-dk)!important}

/* ─── Buttons ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:100px;font-family:'Inter',sans-serif;font-size:.9rem;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:all .22s;line-height:1;white-space:nowrap}
.btn-primary{background:var(--blue);color:#fff;padding:13px 26px;box-shadow:0 4px 16px rgba(26,60,52,.28)}
.btn-primary:hover{background:var(--blue-dk);transform:translateY(-2px);box-shadow:0 8px 24px rgba(26,60,52,.36)}
.btn-secondary{background:transparent;color:var(--ink);padding:12px 24px;border:2px solid var(--border)}
.btn-secondary:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--blue);padding:13px 26px;box-shadow:0 4px 16px rgba(0,0,0,.12)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.18)}
.btn-outline-white{background:transparent;color:#fff;padding:12px 24px;border:2px solid rgba(255,255,255,.55)}
.btn-outline-white:hover{border-color:#fff;background:rgba(255,255,255,.12)}

/* ─── Labels ──────────────────────────────────────────────── */
.eyebrow{display:inline-flex;align-items:center;gap:7px;background:var(--green-xl);color:var(--green);font-size:.72rem;font-weight:600;padding:5px 12px;border-radius:100px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:16px;border:1px solid var(--green-lt)}
.eyebrow-dot{width:5px;height:5px;border-radius:50%;background:var(--green-mid);flex-shrink:0}
.sec-label{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:10px;display:block}
.sec-title{color:var(--ink);margin-bottom:12px}
.sec-sub{color:var(--ink-mid);font-size:1rem;max-width:520px;line-height:1.78;margin-bottom:40px}

/* ─── Trust Bar ───────────────────────────────────────────── */
.trust-bar{background:var(--bg-soft);padding:20px 0;border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light)}
.trust-inner{display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap}
.ti{display:flex;align-items:center;gap:8px;font-size:.84rem;font-weight:500;color:var(--ink-mid)}
.ti-icon{width:32px;height:32px;border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:.95rem;box-shadow:var(--sh);border:1px solid var(--border-light)}
.ti-div{width:1px;height:20px;background:var(--border)}

/* ─── Stats ───────────────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:36px 0}
.stat-card{background:#fff;border-radius:var(--r);padding:22px;text-align:center;border:1.5px solid var(--border-light);box-shadow:var(--sh);transition:all .2s}
.stat-card:hover{border-color:var(--blue-lt);transform:translateY(-2px)}
.stat-num{font-family:'Playfair Display',serif;font-size:2rem;color:var(--blue);line-height:1;margin-bottom:5px;font-weight:700}
.stat-lbl{font-size:.76rem;color:var(--ink-lt);font-weight:500}

/* ─── Feature Cards ───────────────────────────────────────── */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:28px 0}
.feat-card{background:#fff;border:1.5px solid var(--border-light);border-radius:var(--r);padding:26px;transition:all .25s;position:relative;overflow:hidden}
.feat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--green-mid));transform:scaleX(0);transform-origin:left;transition:transform .25s}
.feat-card:hover{border-color:var(--blue-lt);box-shadow:var(--sh-md);transform:translateY(-4px)}
.feat-card:hover::after{transform:scaleX(1)}
.feat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:14px}
.feat-card h4{font-size:.96rem;color:var(--ink);margin-bottom:7px}
.feat-card p{font-size:.85rem;color:var(--ink-mid);line-height:1.68}

/* ─── Dark Section ────────────────────────────────────────── */
.dark-sec{background:#0f172a;position:relative;overflow:hidden}
.dark-glow{position:absolute;border-radius:50%;pointer-events:none;background:radial-gradient(circle,rgba(26,60,52,.14) 0%,transparent 70%)}
.dark-sec .sec-label{color:#60a5fa}
.dark-sec .sec-title{color:#fff}
.dark-sec .sec-sub{color:rgba(255,255,255,.5)}
.dark-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.dark-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:28px;transition:all .25s}
.dark-card:hover{background:rgba(255,255,255,.08);border-color:rgba(26,60,52,.4)}
.dc-num{font-family:'Playfair Display',serif;font-size:2.6rem;color:rgba(26,60,52,.2);line-height:1;margin-bottom:12px}
.dark-card h3{color:#fff;margin-bottom:8px;font-size:1.02rem}
.dark-card p{color:rgba(255,255,255,.48);font-size:.85rem;line-height:1.72}

/* ─── Steps ───────────────────────────────────────────────── */
.steps-row{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin:40px 0;position:relative}
.steps-row::before{content:'';position:absolute;top:24px;left:10%;right:10%;height:2px;background:linear-gradient(90deg,var(--blue),var(--teal));z-index:0}
.step{text-align:center;position:relative;z-index:1;padding:0 6px}
.step-num{width:48px;height:48px;border-radius:50%;background:var(--blue);color:#fff;font-family:'Playfair Display',serif;font-size:1.15rem;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;box-shadow:0 4px 16px rgba(26,60,52,.30)}
.step h4{font-size:.8rem;font-weight:600;color:var(--ink);margin-bottom:4px;font-family:'Inter',sans-serif}
.step p{font-size:.73rem;color:var(--ink-lt);line-height:1.5}

/* ─── Courses Box ─────────────────────────────────────────── */
.courses-box{background:var(--bg-soft);border-radius:18px;padding:32px;margin:32px 0;border:1px solid var(--border-light)}
.courses-box h3{color:var(--ink);margin-bottom:20px;font-size:1.2rem}
.courses-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.course-card{background:#fff;border-radius:var(--rs);padding:16px;border:1px solid var(--border-light)}
.cc-title{font-size:.69rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--blue);margin-bottom:10px}
.cc-list{list-style:none}
.cc-list li{font-size:.83rem;color:var(--ink-mid);padding:4px 0;border-bottom:1px solid var(--bg-soft);display:flex;align-items:center;gap:7px}
.cc-list li:last-child{border-bottom:none}
.cc-list li::before{content:'›';color:var(--blue);font-size:.85rem;flex-shrink:0}

/* ─── Tutor Spotlight ─────────────────────────────────────── */
.tutor-spot{display:grid;grid-template-columns:260px 1fr;gap:36px;align-items:center;padding:36px;background:#fff;border-radius:20px;box-shadow:var(--sh-md);border:1.5px solid var(--border-light)}
.tutor-spot-visual{background:linear-gradient(135deg,var(--blue-xl),var(--bg-soft));border-radius:16px;padding:26px;text-align:center}
.ts-avatar{width:84px;height:84px;border-radius:50%;border:3px solid #fff;box-shadow:var(--sh-md);margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-size:2.2rem;background:var(--bg-mid)}
.ts-name{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--ink);margin-bottom:3px}
.ts-cred{font-size:.72rem;font-weight:700;color:var(--blue);margin-bottom:3px}
.ts-role{font-size:.72rem;color:var(--ink-lt);margin-bottom:12px}
.ts-tags{display:flex;flex-wrap:wrap;gap:5px;justify-content:center}
.ts-tag{background:#fff;color:var(--ink-mid);font-size:.68rem;font-weight:500;padding:3px 10px;border-radius:100px;box-shadow:var(--sh);border:1px solid var(--border-light)}
.tutor-spot-text h2{color:var(--ink);margin-bottom:12px}
.tutor-spot-text p{margin-bottom:14px}
.ts-stat-row{display:flex;gap:20px;margin:16px 0}
.ts-stat-num{font-family:'Playfair Display',serif;font-size:1.65rem;color:var(--blue);display:block;line-height:1}
.ts-stat-lbl{font-size:.7rem;color:var(--ink-lt)}

/* ─── Reviews ─────────────────────────────────────────────── */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:28px 0}
.review-card{background:#fff;border-radius:var(--r);padding:22px;border:1.5px solid var(--border-light);box-shadow:var(--sh);display:flex;flex-direction:column;gap:12px;transition:all .2s}
.review-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.r-stars{color:#f59e0b;font-size:.88rem;letter-spacing:2px}
.r-text{font-size:.86rem;color:var(--ink-mid);line-height:1.75;font-style:italic;flex:1}
.r-author{display:flex;align-items:center;gap:10px}
.r-av{width:36px;height:36px;border-radius:50%;background:var(--blue-lt);display:flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:700;color:var(--blue);flex-shrink:0}
.r-name{font-size:.82rem;font-weight:600;color:var(--ink)}
.r-src{font-size:.71rem;color:var(--ink-lt)}

/* ─── Form Section ────────────────────────────────────────── */
.form-section{background:linear-gradient(135deg,var(--bg-soft) 0%,var(--blue-xl) 100%);padding:88px 0}
.form-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.form-perk{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px}
.fp-icon{width:28px;height:28px;border-radius:50%;background:var(--green-lt);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;flex-shrink:0;margin-top:2px;border:1.5px solid var(--green-mid)}
.fp-text strong{color:var(--ink);display:block;font-size:.88rem;margin-bottom:1px}
.fp-text span{color:var(--ink-mid);font-size:.82rem;line-height:1.5}
.form-card{background:#fff;border-radius:20px;padding:34px;box-shadow:var(--sh-lg);border:1px solid var(--border-light)}
.form-card h3{font-size:1.4rem;color:var(--ink);margin-bottom:4px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.form-group label{font-size:.78rem;font-weight:600;color:var(--ink)}
.form-group input,.form-group select,.form-group textarea{padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--rs);font-family:'Inter',sans-serif;font-size:.88rem;color:var(--ink);background:var(--bg-soft);outline:none;width:100%;transition:all .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,60,52,.1);background:#fff}
.form-group textarea{resize:vertical;min-height:88px}
.form-submit{width:100%;padding:14px;background:var(--blue);color:#fff;border:none;border-radius:100px;font-family:'Inter',sans-serif;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px rgba(26,60,52,.28);margin-top:4px}
.form-submit:hover{background:var(--blue-dk);transform:translateY(-2px)}
.form-note{text-align:center;font-size:.72rem;color:var(--ink-lt);margin-top:10px}

/* ─── University Strip ────────────────────────────────────── */
.uni-strip{background:var(--bg-soft);padding:40px 0;border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light)}
.uni-strip-lbl{text-align:center;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-lt);margin-bottom:16px}
.uni-row{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}
.uni-pill{background:#fff;border-radius:8px;padding:8px 16px;font-size:.78rem;font-weight:600;color:var(--ink-mid);box-shadow:var(--sh);border:1px solid var(--border-light);transition:all .2s}
.uni-pill:hover{border-color:var(--blue-lt);color:var(--blue)}

/* ─── Inline CTA ──────────────────────────────────────────── */
.inline-cta{background:linear-gradient(135deg,var(--blue-lt),var(--teal-lt));border-radius:18px;padding:32px 38px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin:44px 0;border:1px solid var(--blue-lt)}
.inline-cta h3{color:var(--ink);font-size:1.2rem;margin-bottom:5px}
.inline-cta p{color:var(--ink-mid);font-size:.86rem}

/* ─── Related Cards ───────────────────────────────────────── */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0}
.related-card{background:#fff;border:1.5px solid var(--border-light);border-radius:var(--r);padding:22px;text-decoration:none;color:inherit;display:block;transition:all .25s}
.related-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--blue-lt)}
.rc-icon{font-size:1.7rem;margin-bottom:9px}
.related-card h4{color:var(--ink);font-size:.94rem;margin-bottom:5px}
.related-card p{font-size:.8rem;color:var(--ink-lt);line-height:1.6}
.rc-arrow{font-size:.78rem;font-weight:600;color:var(--blue);margin-top:10px;display:block}

/* ─── FAQ ─────────────────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.faq-card{background:#fff;border-radius:var(--rs);padding:20px;border:1.5px solid var(--border-light);transition:all .2s}
.faq-card:hover{border-color:var(--blue-lt)}
.faq-q{font-family:'Playfair Display',serif;font-size:.92rem;color:var(--ink);margin-bottom:7px;font-weight:600}
.faq-a{font-size:.83rem;color:var(--ink-mid);line-height:1.68}

/* ─── CTA Section ─────────────────────────────────────────── */
.cta-sec{background:linear-gradient(135deg,var(--blue) 0%,#163329 100%);padding:80px 0;text-align:center;position:relative;overflow:hidden}
.cta-sec::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:rgba(255,255,255,.06);pointer-events:none}
.cta-sec::after{content:'';position:absolute;bottom:-120px;left:-80px;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}
.cta-sec h2{color:#fff;margin-bottom:12px}
.cta-sec p{color:rgba(255,255,255,.75);font-size:1.05rem;margin-bottom:30px;max-width:460px;margin-left:auto;margin-right:auto}
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ─── Breadcrumb ──────────────────────────────────────────── */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--ink-lt);margin-bottom:12px}
.breadcrumb a{color:var(--ink-lt);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--blue)}

/* ─── Badge Float ─────────────────────────────────────────── */
.badge-float{position:absolute;background:#fff;border-radius:12px;padding:10px 14px;box-shadow:var(--sh-lg);display:flex;align-items:center;gap:9px;animation:float 3.5s ease-in-out infinite;z-index:3;border:1px solid var(--border-light)}
.bf-icon{font-size:1.25rem;flex-shrink:0}
.bf-title{display:block;font-size:.79rem;font-weight:600;color:var(--ink);line-height:1.2}
.bf-sub{display:block;font-size:.69rem;color:var(--ink-lt)}

/* ─── Program Grid ────────────────────────────────────────── */
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0}
.prog-card{border:1.5px solid var(--border-light);border-radius:var(--r);padding:24px;text-align:center;transition:all .2s;background:#fff}
.prog-card:hover{border-color:var(--blue);box-shadow:var(--sh-md);transform:translateY(-3px)}
.prog-card.feat{background:var(--blue);border-color:var(--blue);box-shadow:0 6px 24px rgba(26,60,52,.35)}
.prog-card.feat h4,.prog-card.feat p{color:#fff}
.prog-card.feat p{color:rgba(255,255,255,.78)}
.prog-icon{font-size:1.8rem;margin-bottom:10px}
.prog-card h4{font-size:.94rem;color:var(--ink);margin-bottom:5px}
.prog-card p{font-size:.79rem;color:var(--ink-lt);line-height:1.6}

/* ─── Footer ──────────────────────────────────────────────── */
footer{background:#0f172a;padding:60px 0 28px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.foot-logo{font-family:'Playfair Display',serif;font-size:1rem;color:#fff;display:flex;align-items:center;gap:9px;margin-bottom:12px;text-decoration:none}
.foot-logo-icon{width:30px;height:30px;border-radius:7px;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}
.foot-desc{font-size:.81rem;color:rgba(255,255,255,.36);line-height:1.75;margin-bottom:16px}
.foot-contact{display:flex;align-items:center;gap:7px;font-size:.81rem;color:rgba(255,255,255,.42);text-decoration:none;margin-bottom:7px;transition:color .2s}
.foot-contact:hover{color:#fff}
.foot-col h5{font-size:.68rem;font-weight:700;color:rgba(255,255,255,.45);letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.foot-col a{display:block;font-size:.82rem;color:rgba(255,255,255,.36);text-decoration:none;margin-bottom:8px;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.foot-bottom p{font-size:.76rem;color:rgba(255,255,255,.22)}
.foot-bottom a{color:rgba(255,255,255,.30);text-decoration:none;font-size:.76rem;transition:color .2s}
.foot-bottom a:hover{color:#fff}
.foot-social{display:flex;gap:8px;margin-top:14px}
.foot-social a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;font-size:.9rem;color:rgba(255,255,255,.5);transition:all .2s;text-decoration:none}
.foot-social a:hover{background:var(--blue);color:#fff}

/* ─── WhatsApp Float ──────────────────────────────────────── */
.whatsapp-float{position:fixed;bottom:28px;left:28px;z-index:600;width:54px;height:54px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 6px 24px rgba(37,211,102,.4);text-decoration:none;transition:all .25s;animation:float 3s ease-in-out infinite}
.whatsapp-float:hover{transform:scale(1.12) !important;box-shadow:0 10px 32px rgba(37,211,102,.5)}

/* ─── Responsive ──────────────────────────────────────────── */
@media(max-width:960px){
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .stats-row{grid-template-columns:1fr 1fr}
  .feat-grid{grid-template-columns:1fr 1fr}
  .dark-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr 1fr}
  .steps-row{grid-template-columns:1fr 1fr;gap:16px}
  .steps-row::before{display:none}
  .tutor-spot{grid-template-columns:1fr;padding:28px}
  .form-layout{grid-template-columns:1fr;gap:32px}
  .courses-grid{grid-template-columns:1fr 1fr}
  .related-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:28px}
  .prog-grid{grid-template-columns:1fr 1fr}
  .faq-grid{grid-template-columns:1fr}
  section{padding:60px 0}
  .inline-cta{flex-direction:column;text-align:center}
}
@media(max-width:600px){
  .feat-grid,.reviews-grid,.related-grid,.prog-grid,.foot-grid{grid-template-columns:1fr}
  .courses-grid{grid-template-columns:1fr}
  .cta-actions{flex-direction:column;align-items:center}
  .steps-row{grid-template-columns:1fr}
  .uni-row{gap:7px}
  .ti-div{display:none}
  .form-row{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .whatsapp-float{bottom:18px;left:18px;width:48px;height:48px;font-size:1.3rem}
}

/* ── Legacy variable aliases (keeps old templates working) ──────── */
:root {
  --cream:      #ffffff;
  --cream-dk:   #f0f7f3;
  --tan:        #cbd5e1;
  --tc:         #1a3c34;
  --tc-dk:      #0f2219;
  --tc-lt:      #c8e6d4;
  --tc-xl:      #f0f7f3;
  --forest:     #166534;
  --forest-mid: #16a34a;
  --forest-lt:  #dcfce7;
  --gold:       #f59e0b;
  --gold-lt:    #fef3c7;
  --sh-xl:      0 28px 80px rgba(26,60,52,.20);
}

/* ── Blog layout ─────────────────────────────────────────────────── */
.blog-layout{display:grid;grid-template-columns:1fr 300px;gap:44px;align-items:start}
.blog-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.blog-card{background:#fff;border-radius:20px;overflow:hidden;border:1.5px solid var(--border-light);transition:all .25s;text-decoration:none;color:inherit;display:block}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--blue-lt)}
.blog-card-img{height:160px;display:flex;align-items:center;justify-content:center;font-size:2.8rem;position:relative}
.blog-card-cat{position:absolute;bottom:10px;left:12px;background:var(--blue);color:#fff;font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:100px;letter-spacing:.04em}
.blog-card-body{padding:18px}
.blog-card-meta{font-size:.74rem;color:var(--ink-lt);margin-bottom:7px}
.blog-card h3{font-family:'Playfair Display',serif;font-size:.96rem;color:var(--ink);margin-bottom:7px;font-weight:600;line-height:1.4}
.blog-card p{font-size:.82rem;color:var(--ink-mid);line-height:1.6;margin:0}
.blog-read{font-size:.79rem;font-weight:600;color:var(--blue);margin-top:10px;display:inline-block}

/* ── Sidebar ─────────────────────────────────────────────────────── */
.sidebar{position:sticky;top:88px}
.sidebar-widget{background:#fff;border-radius:var(--r);border:1.5px solid var(--border-light);padding:20px;margin-bottom:16px}
.sidebar-widget h4{font-family:'Playfair Display',serif;font-size:.96rem;color:var(--ink);margin-bottom:14px;font-weight:700}
.sidebar-cat{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--border-light);font-size:.84rem;color:var(--ink-mid);text-decoration:none;transition:color .2s}
.sidebar-cat:last-child{border-bottom:none}
.sidebar-cat:hover{color:var(--blue)}
.sidebar-cat span{background:var(--bg-soft);color:var(--ink-lt);font-size:.7rem;padding:2px 8px;border-radius:100px}
.pop-post{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid var(--border-light)}
.pop-post:last-child{border-bottom:none}
.pp-icon{width:40px;height:40px;border-radius:9px;background:var(--blue-lt);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.pp-text{font-size:.8rem;color:var(--ink-mid);line-height:1.5}
.pp-text a{color:var(--ink);font-weight:500;text-decoration:none}
.pp-text a:hover{color:var(--blue)}

@media(max-width:900px){
  .blog-layout{grid-template-columns:1fr}
  .sidebar{display:none}
  .blog-grid{grid-template-columns:1fr}
}

/* ── Page Hero (contact, blog, service pages) ──────────────────── */
.page-hero{padding:calc(var(--nav-h) + 64px) 0 72px;background:linear-gradient(135deg,var(--blue) 0%,#163329 100%);position:relative;overflow:hidden;text-align:center}
.page-hero-bg{position:absolute;top:-80px;right:-120px;width:560px;height:560px;border-radius:50%;background:rgba(255,255,255,.06);pointer-events:none}
.page-hero-bg2{position:absolute;bottom:-100px;left:-80px;width:380px;height:380px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{color:#fff;max-width:720px;margin:0 auto 16px}
.page-hero em{color:#6dbb96;font-style:italic}
.page-hero-desc{color:rgba(255,255,255,.75);font-size:1.05rem;max-width:540px;margin:0 auto 28px;line-height:1.8}
.page-hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.page-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-size:.72rem;font-weight:700;padding:5px 14px;border-radius:100px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:18px;border:1px solid rgba(255,255,255,.3)}
.page-eyebrow-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.8);display:inline-block;flex-shrink:0}
.fade-up{animation:fadeUp .6s ease both}

/* ── Trust bar ──────────────────────────────────────────────────── */
.trust-bar{background:#fff;border-bottom:1px solid var(--border-light);padding:14px 0}
.trust-inner{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}
.ti{display:flex;align-items:center;gap:8px;padding:6px 20px;font-size:.82rem;font-weight:500;color:var(--ink-mid)}
.ti-icon{font-size:1rem}
.ti-div{width:1px;height:22px;background:var(--border-light)}

/* ── Contact map/info cards ─────────────────────────────────────── */
.cm-label{font-size:.72rem;font-weight:700;color:var(--ink-lt);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.cm-value{font-size:1rem;font-weight:600;color:var(--ink);margin-bottom:2px}
.cm-sub{font-size:.8rem;color:var(--ink-lt)}
.whatsapp-btn{display:inline-flex;align-items:center;gap:8px;background:#25d366;color:#fff;padding:12px 22px;border-radius:100px;font-weight:600;font-size:.9rem;text-decoration:none;transition:all .2s}
.whatsapp-btn:hover{background:#22c55e;transform:translateY(-2px)}

/* ── Steps row ──────────────────────────────────────────────────── */
.steps-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:28px;counter-reset:step}
.step{background:#fff;border-radius:var(--r);padding:24px;border:1.5px solid var(--border-light);position:relative}
.step-num{width:36px;height:36px;border-radius:50%;background:var(--blue);color:#fff;font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center;margin-bottom:12px}

/* ── FAQ grid ───────────────────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.faq-item{background:#fff;border:1.5px solid var(--border-light);border-radius:var(--r);padding:20px}
.faq-q{font-weight:600;color:var(--ink);font-size:.92rem;margin-bottom:8px}
.faq-a{font-size:.86rem;color:var(--ink-mid);line-height:1.7}

/* ── Dark section ───────────────────────────────────────────────── */
.dark-sec{background:var(--ink);padding:88px 0;position:relative;overflow:hidden}
.dark-sec h2,.dark-sec h3,.dark-sec h4{color:#fff}
.dark-sec p{color:rgba(255,255,255,.6)}
.dark-glow{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(26,60,52,.3),transparent 70%);pointer-events:none}

@media(max-width:768px){
  .page-hero{padding:calc(var(--nav-h) + 40px) 0 52px}
  .faq-grid{grid-template-columns:1fr}
  .ti-div{display:none}
  .trust-inner{gap:0}
  .ti{padding:4px 12px;font-size:.78rem}
}

/* ── SVG icon sizing (prevents emoji-sized rendering) ────────────── */
.fc-icon { width:14px;height:14px;flex-shrink:0;display:inline-block;vertical-align:middle }
.foot-contact { display:flex;align-items:flex-start;gap:9px }
.foot-contact .fc-icon { margin-top:2px }
.foot-logo svg { flex-shrink:0 }
.foot-social a svg { width:16px;height:16px;display:block }
.nav-logo svg { flex-shrink:0 }
.whatsapp-float svg { display:block;flex-shrink:0 }
.form-note { display:flex;align-items:center;justify-content:center;gap:6px }
.form-note svg { flex-shrink:0 }
.btn svg { display:inline-block;vertical-align:middle;flex-shrink:0 }
.ti-icon svg { width:16px;height:16px }

/* ── Prevent ANY emoji from rendering large anywhere ─────────────── */
body *:not(.whatsapp-float):not(.blog-card-img) {
  font-variant-emoji: text;
}
/* Constrain emoji font rendering on specific problem elements */
.foot-contact, .foot-social a, .form-note, .btn, .nav-links a,
.drawer-cta, .trust-inner, .ti, .cta-sec, .sidebar-widget {
  font-variant-emoji: text;
}

/* ── Image sizing — correct aspect ratios everywhere ─────────────── */
/* All post thumbnails in blog grid */
.blog-card img,
.blog-card .blog-thumb {
  width: 100%;
  height: 190px;
  object-fit: cover;
  object-position: center;
  display: block;
}
/* Featured images on single posts */
.post-hero img,
.post-hero .wp-post-image {
  width: 100%;
  max-height: 420px;
  object-fit: cover;
  object-position: center top;
  display: block;
  border-radius: 16px;
}
/* Tutor photos */
.tutor-spot img,
.tutor-card img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  object-position: center top;
  border-radius: 12px;
}
/* Homepage hero / section images */
.hero-img img,
[class*="hero"] img:not(.nav-logo img) {
  width: 100%;
  height: auto;
  max-height: 560px;
  object-fit: cover;
  display: block;
}
/* Any img inside a card or box */
.feat-card img,
.related-card img,
.sidebar-widget img {
  width: 100%;
  height: auto;
  border-radius: 8px;
  display: block;
}
/* Prevent images from ever overflowing their container */
img { max-width: 100%; height: auto; }

/* ── Fix btn-secondary phone button layout ───────────────────────── */
.btn-secondary {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
}
.btn-outline-white {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
}
/* CTA action row — keep buttons on same line */
.cta-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

/* ── Footer logo icon — no emoji, use SVG ────────────────────────── */
.foot-logo-icon { display:none }  /* hide old emoji container if still present */
.foot-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Playfair Display', serif;
  font-size: 1.08rem;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  margin-bottom: 14px;
}
.foot-logo svg { color: #6dbb96 }

/* ── Nav logo icon ───────────────────────────────────────────────── */
.nav-logo-icon { display:none }  /* hide old emoji container */

@media(max-width:600px){
  .blog-card img, .blog-card .blog-thumb { height:160px }
  .post-hero img { max-height:260px }
  .tutor-spot img { height:180px }
}

/* ══════════════════════════════════════════════════════════════════
   ICON + IMAGE FIXES v8 — no giant emojis, correct image ratios
══════════════════════════════════════════════════════════════════ */

/* ── Footer contact SVG icons — fixed small size ─────────────────── */
.foot-contact {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: .82rem !important;
  color: rgba(255,255,255,.5) !important;
  text-decoration: none !important;
  margin-bottom: 8px !important;
  line-height: 1.4 !important;
}
.foot-contact:hover { color: #fff !important; }
.foot-contact svg,
.fc-icon {
  width: 14px !important;
  height: 14px !important;
  min-width: 14px !important;
  min-height: 14px !important;
  flex-shrink: 0 !important;
  display: block !important;
  stroke: currentColor !important;
}

/* ── Footer social icons — fixed small size ──────────────────────── */
.foot-social { display:flex; gap:12px; margin-top:14px; }
.foot-social a {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.1) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background .2s !important;
  text-decoration: none !important;
  color: rgba(255,255,255,.7) !important;
  flex-shrink: 0 !important;
}
.foot-social a:hover { background: rgba(255,255,255,.2) !important; color: #fff !important; }
.foot-social a svg {
  width: 14px !important;
  height: 14px !important;
  display: block !important;
  flex-shrink: 0 !important;
}

/* ── trust-bar ti-icon — fixed small size ────────────────────────── */
.ti-icon {
  font-size: .9rem !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  width: 20px !important;
  height: 20px !important;
  flex-shrink: 0 !important;
}
.ti-icon svg {
  width: 16px !important;
  height: 16px !important;
  display: block !important;
}

/* ── Contact page cm-icon — fixed size ───────────────────────────── */
.cm-icon {
  width: 40px !important;
  height: 40px !important;
  min-width: 40px !important;
  border-radius: 10px !important;
  background: var(--blue-lt) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
.cm-icon svg {
  width: 18px !important;
  height: 18px !important;
  display: block !important;
  color: var(--blue) !important;
  stroke: var(--blue) !important;
}

/* ── Badge float bf-icon — fixed size ───────────────────────────── */
.bf-icon {
  font-size: 1.1rem !important;
  width: 32px !important;
  height: 32px !important;
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.bf-icon svg {
  width: 16px !important;
  height: 16px !important;
  display: block !important;
}

/* ── loc-icon (in-person page) ───────────────────────────────────── */
.loc-icon {
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  border-radius: 8px !important;
  background: var(--blue-lt) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.loc-icon svg { width:16px !important; height:16px !important; display:block !important; }

/* ── btn-secondary phone button — pill shape, not circle ─────────── */
.btn.btn-secondary,
a.btn-secondary,
a.btn-outline-white {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  white-space: nowrap !important;
  padding: 12px 22px !important;
  border-radius: 100px !important;
  font-size: .9rem !important;
  font-weight: 600 !important;
  line-height: 1 !important;
}
.btn.btn-secondary svg,
a.btn-secondary svg,
a.btn-outline-white svg {
  width: 15px !important;
  height: 15px !important;
  display: inline-block !important;
  flex-shrink: 0 !important;
  vertical-align: middle !important;
}

/* ── form-note lock icon ─────────────────────────────────────────── */
.form-note {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  font-size: .72rem !important;
  color: var(--ink-lt) !important;
  margin-top: 10px !important;
}
.form-note svg {
  width: 12px !important;
  height: 12px !important;
  display: inline-block !important;
  flex-shrink: 0 !important;
}

/* ══ IMAGE RATIOS — correct everywhere ══════════════════════════════ */

/* Global baseline */
img {
  max-width: 100% !important;
  height: auto !important;
  display: block !important;
}

/* Hero floating card images (homepage subject cards) */
.hero-card img,
[style*="border-radius:24px"] img,
[style*="border-radius: 24px"] img {
  width: 100% !important;
  height: 200px !important;
  object-fit: cover !important;
  object-position: center !important;
  border-radius: 10px !important;
}

/* Blog grid thumbnails */
.blog-card img,
.blog-thumb,
.blog-card .wp-post-image {
  width: 100% !important;
  height: 190px !important;
  object-fit: cover !important;
  object-position: center top !important;
  display: block !important;
}

/* Single post hero image */
.post-hero img,
.post-hero .wp-post-image {
  width: 100% !important;
  max-height: 420px !important;
  object-fit: cover !important;
  object-position: center top !important;
  border-radius: 16px !important;
}

/* Tutor photos */
.tutor-spot img,
.tutor-card img,
[class*="tutor"] img {
  width: 100% !important;
  height: 240px !important;
  object-fit: cover !important;
  object-position: center top !important;
  border-radius: 12px !important;
  display: block !important;
}

/* Cards / feature boxes */
.feat-card img,
.related-card img { 
  width: 100% !important;
  height: auto !important;
  max-height: 180px !important;
  object-fit: cover !important;
  border-radius: 8px !important;
}

/* WhatsApp float — force bottom-left, beat any plugin CSS */
.whatsapp-float {
  position: fixed !important;
  bottom: 28px !important;
  left: 28px !important;
  right: auto !important;
  z-index: 9999 !important;
  font-size: 1.4rem !important;
  line-height: 1 !important;
}
@media (max-width: 600px) {
  .whatsapp-float {
    bottom: 18px !important;
    left: 18px !important;
    right: auto !important;
  }
}

@media (max-width: 600px) {
  .blog-card img, .blog-thumb { height: 160px !important; }
  .post-hero img { max-height: 240px !important; }
  .tutor-spot img { height: 200px !important; }
  .btn.btn-secondary, a.btn-secondary, a.btn-outline-white {
    font-size: .82rem !important;
    padding: 10px 16px !important;
  }
}

/* ══════════════════════════════════════════════════════════════════
   BUG FIXES v10
══════════════════════════════════════════════════════════════════ */

/* 1. Tag pills — must have gap, padding, and display:inline-flex */
.tag, .tutor-tags .tag {
  display: inline-flex !important;
  align-items: center !important;
  background: var(--blue-lt) !important;
  color: var(--blue) !important;
  font-size: .73rem !important;
  font-weight: 600 !important;
  padding: 3px 10px !important;
  border-radius: 100px !important;
  white-space: nowrap !important;
  line-height: 1.4 !important;
  margin: 2px !important;
}
.tutor-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin-top: 10px !important;
}

/* 2. Pricing page — pc-icon must be small text, not emoji image */
.pc-icon {
  font-size: 1.5rem !important;
  line-height: 1.2 !important;
  height: 40px !important;
  width: 40px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-variant-emoji: text !important;
  overflow: hidden !important;
  font-family: 'Inter', sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji' !important;
}

/* 3. Pricing hero — btn-white must look like a button */
.btn-white, .pricing-hero .btn-white {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: #fff !important;
  color: var(--blue) !important;
  font-weight: 700 !important;
  padding: 13px 26px !important;
  border-radius: 100px !important;
  font-size: .9rem !important;
  text-decoration: none !important;
  border: none !important;
  white-space: nowrap !important;
  transition: all .2s !important;
  box-shadow: 0 4px 16px rgba(26,60,52,.2) !important;
}
.btn-white:hover { transform: translateY(-2px) !important; box-shadow: 0 8px 24px rgba(26,60,52,.25) !important; }

/* 4. pricing-hero — ensure proper top padding */
.pricing-hero {
  padding: calc(var(--nav-h) + 64px) 0 72px !important;
  background: linear-gradient(135deg, var(--blue) 0%, var(--blue-dk) 100%) !important;
  position: relative !important;
  overflow: hidden !important;
  text-align: center !important;
}
.pricing-hero h1 { color: #fff !important; }
.pricing-hero p  { color: rgba(255,255,255,.8) !important; max-width: 600px !important; margin: 0 auto 28px !important; }
.pricing-hero .breadcrumb { justify-content: center !important; }
.pricing-hero-bg { position:absolute;top:-80px;right:-120px;width:560px;height:560px;border-radius:50%;background:rgba(255,255,255,.06);pointer-events:none }

/* 5. Trust bar — emoji ti-icons must stay small */
.ti-icon {
  font-size: 1rem !important;
  font-variant-emoji: text !important;
  width: 20px !important;
  height: 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
}

/* 6. Nav phone number — keep it from showing floating */
.nav-links a[href^="tel:"] {
  font-size: .82rem !important;
  color: var(--ink-mid) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  white-space: nowrap !important;
}

/* 7. Blog post thumbnail sizing — prevent emoji overflow */
.blog-card-img {
  height: 160px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 2.4rem !important;
  font-variant-emoji: text !important;
  overflow: hidden !important;
  position: relative !important;
  background: var(--bg-soft) !important;
}
.blog-card-img span[style*="font-size"] {
  font-size: 2.4rem !important;
  line-height: 1 !important;
  height: 2.4rem !important;
  width: 2.4rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* 8. Global emoji size guard for decorative emoji inside sized containers */
.bf-icon, .feat-icon, .rc-icon, .ti-icon, .pc-icon, .pp-icon, .sidebar-widget h4 {
  font-variant-emoji: text !important;
}

@media (max-width: 767px) {
  .tag { font-size: .7rem !important; padding: 2px 8px !important; }
  .pricing-hero { padding: calc(var(--nav-h) + 40px) 0 52px !important; }
}

/* ── Nav phone — hide on screens where it would overflow ────────── */
.nav-phone-item { display: list-item; }
@media (max-width: 1100px) { .nav-phone-item { display: none !important; } }

/* ── pc-icon container — force SVG size not emoji size ──────────── */
.price-card .pc-icon svg,
.pc-icon svg {
  width: 22px !important;
  height: 22px !important;
  display: block !important;
  stroke: var(--blue) !important;
  color: var(--blue) !important;
}
.price-card .pc-icon {
  background: var(--blue-lt) !important;
  border-radius: 10px !important;
  padding: 0 !important;
}

/* ── bf-icon SVG size ───────────────────────────────────────────── */
.bf-icon svg { width:14px !important; height:14px !important; display:block !important; flex-shrink:0 !important; }

/* ── feat-icon SVG ──────────────────────────────────────────────── */
.feat-icon svg { width:20px !important; height:20px !important; display:block !important; }

/* ══════════════════════════════════════════════════════════════════
   PRICING PAGE — complete styles
══════════════════════════════════════════════════════════════════ */

/* ── Trial banner ────────────────────────────────────────────────── */
.trial-banner {
  display: flex;
  align-items: center;
  gap: 28px;
  background: linear-gradient(135deg, var(--blue), var(--blue-dk));
  border-radius: 20px;
  padding: 32px 36px;
  margin-bottom: 52px;
  flex-wrap: wrap;
}
.trial-badge {
  text-align: center;
  flex-shrink: 0;
  background: rgba(255,255,255,.15);
  border-radius: 14px;
  padding: 16px 20px;
  border: 2px solid rgba(255,255,255,.25);
  min-width: 90px;
}
.trial-price {
  font-family: 'Playfair Display', serif;
  font-size: 2.4rem;
  font-weight: 700;
  color: #fff;
  line-height: 1;
}
.trial-label {
  font-size: .72rem;
  font-weight: 700;
  color: rgba(255,255,255,.75);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: 4px;
}
.trial-text h3 { color: #fff; margin-bottom: 6px; font-size: 1.15rem; }
.trial-text p  { color: rgba(255,255,255,.75); font-size: .9rem; margin: 0; }

/* ── Pricing section container ───────────────────────────────────── */
.pricing-section {
  margin-bottom: 56px;
  padding-bottom: 56px;
  border-bottom: 1px solid var(--border-light);
}
.pricing-section:last-child { border-bottom: none; }
.pricing-section-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--ink);
  margin: 8px 0 6px;
}
.pricing-section-sub {
  font-size: .88rem;
  color: var(--ink-lt);
  margin-bottom: 24px;
}

/* ── Pricing table ───────────────────────────────────────────────── */
.pricing-table {
  width: 100%;
  border-collapse: collapse;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: var(--sh);
  background: #fff;
}
.pt-head th {
  background: var(--blue);
  color: #fff;
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 14px 20px;
  text-align: left;
}
.pt-row {
  border-bottom: 1px solid var(--border-light);
  transition: background .15s;
}
.pt-row:last-child { border-bottom: none; }
.pt-row:hover { background: var(--bg-soft); }
.pt-row td { padding: 16px 20px; vertical-align: middle; }
.pt-label {
  font-weight: 600;
  color: var(--ink);
  font-size: .92rem;
}
.pt-price {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--blue);
}
.pt-note {
  font-size: .8rem;
  color: var(--ink-lt);
  font-family: 'Inter', sans-serif;
  font-weight: 400;
}

/* ── Pricing cards grid ──────────────────────────────────────────── */
.pricing-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.price-card {
  background: #fff;
  border: 1.5px solid var(--border-light);
  border-radius: 18px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: all .25s;
  position: relative;
}
.price-card:hover {
  border-color: var(--blue);
  box-shadow: var(--sh-md);
  transform: translateY(-4px);
}
.price-card.featured {
  border-color: var(--blue);
  background: linear-gradient(135deg, #fff 0%, var(--bg-soft) 100%);
  box-shadow: var(--sh-md);
}
.price-card.featured::before {
  content: 'Most Popular';
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--blue);
  color: #fff;
  font-size: .68rem;
  font-weight: 700;
  padding: 3px 12px;
  border-radius: 100px;
  letter-spacing: .05em;
  text-transform: uppercase;
  white-space: nowrap;
}
.price-card h4 {
  font-size: 1rem;
  color: var(--ink);
  margin: 0;
}
.pc-icon {
  width: 44px !important;
  height: 44px !important;
  border-radius: 10px !important;
  background: var(--blue-lt) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
.pc-icon svg {
  width: 22px !important;
  height: 22px !important;
  stroke: var(--blue) !important;
  color: var(--blue) !important;
  display: block !important;
}
.pc-price {
  font-family: 'Playfair Display', serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--blue);
  line-height: 1;
}
.pc-period {
  font-family: 'Inter', sans-serif;
  font-size: .78rem;
  font-weight: 400;
  color: var(--ink-lt);
}
.pc-includes {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.pc-includes li {
  font-size: .84rem;
  color: var(--ink-mid);
  padding-left: 18px;
  position: relative;
  line-height: 1.45;
}
.pc-includes li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--blue);
  font-weight: 700;
  font-size: .8rem;
}
.pc-btn {
  display: block;
  text-align: center;
  padding: 11px 18px;
  background: var(--blue);
  color: #fff;
  border-radius: 100px;
  font-weight: 600;
  font-size: .86rem;
  text-decoration: none;
  margin-top: auto;
  transition: all .2s;
}
.pc-btn:hover { background: var(--blue-dk); transform: translateY(-1px); }

/* ── FAQ section ─────────────────────────────────────────────────── */
.pricing-faq {
  margin-top: 52px;
}
.pricing-faq .faq-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 24px;
}
.pricing-faq .faq-item {
  background: #fff;
  border: 1.5px solid var(--border-light);
  border-radius: 14px;
  padding: 20px 24px;
}
.pricing-faq .faq-item:hover {
  border-color: var(--blue);
}
.pricing-faq .faq-q {
  font-weight: 600;
  color: var(--ink);
  font-size: .9rem;
  margin-bottom: 8px;
}
.pricing-faq .faq-a {
  font-size: .84rem;
  color: var(--ink-mid);
  line-height: 1.7;
  margin: 0;
}

/* ── Footer contact fix — force SVG small ────────────────────────── */
.foot-contact {
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  font-size: .82rem !important;
  color: rgba(255,255,255,.5) !important;
  text-decoration: none !important;
  margin-bottom: 9px !important;
  line-height: 1.4 !important;
  max-width: 100% !important;
}
.foot-contact:hover { color: #fff !important; }
.foot-contact svg {
  width: 14px !important;
  height: 14px !important;
  min-width: 14px !important;
  min-height: 14px !important;
  max-width: 14px !important;
  max-height: 14px !important;
  flex-shrink: 0 !important;
  display: block !important;
}
/* Extra override for any SVG inside foot-contact, no matter how it's written */
a.foot-contact > svg,
.foot-contact > svg:first-child {
  width: 14px !important;
  height: 14px !important;
  min-width: 14px !important;
  min-height: 14px !important;
}

/* ── Footer social ───────────────────────────────────────────────── */
.foot-social {
  display: flex !important;
  gap: 10px !important;
  margin-top: 14px !important;
}
.foot-social a {
  width: 32px !important;
  height: 32px !important;
  min-width: 32px !important;
  min-height: 32px !important;
  max-width: 32px !important;
  max-height: 32px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.1) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
  color: rgba(255,255,255,.7) !important;
}
.foot-social a svg {
  width: 14px !important;
  height: 14px !important;
  min-width: 14px !important;
  max-width: 14px !important;
  display: block !important;
  flex-shrink: 0 !important;
}
.foot-social a:hover { background: rgba(255,255,255,.2) !important; color:#fff !important; }

/* ── Responsive ──────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .pricing-cards { grid-template-columns: 1fr 1fr; }
  .trial-banner  { flex-direction: column; text-align: center; }
  .pricing-faq .faq-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .pricing-cards { grid-template-columns: 1fr; }
  .pricing-table { font-size: .82rem; }
  .pt-head th, .pt-row td { padding: 10px 12px; }
}

/* ══════════════════════════════════════════════════════════════════
   GLOBAL FIXES v12 — image ratios + missing classes
══════════════════════════════════════════════════════════════════ */

/* ── Global image aspect ratio enforcement ───────────────────────── */
img {
  max-width: 100% !important;
  height: auto !important;
  display: block !important;
}
/* All WordPress post thumbnails */
.wp-post-image,
.attachment-medium,
.attachment-large,
.size-medium,
.size-large,
.size-full { max-width: 100% !important; height: auto !important; display: block !important; }

/* Blog card thumbnails — always 200px tall, cropped to fill */
.blog-card .wp-post-image,
.blog-card img,
.blog-thumb {
  width: 100% !important; height: 200px !important;
  object-fit: cover !important; object-position: center top !important;
  display: block !important;
}
/* Single post hero */
.post-hero .wp-post-image,
.post-hero img:not(svg) {
  width: 100% !important; max-height: 440px !important;
  object-fit: cover !important; object-position: center top !important;
  border-radius: 16px !important; display: block !important;
}
/* Tutor photos (if real photos uploaded) */
.tutor-card img,
.tc-photo,
.tutor-spot img {
  width: 68px !important; height: 68px !important;
  object-fit: cover !important; object-position: center top !important;
  border-radius: 50% !important; display: block !important;
}
/* Hero section floating card images */
[style*="border-radius:24px"] img,
[style*="border-radius: 24px"] img {
  width: 100% !important; height: 200px !important;
  object-fit: cover !important; display: block !important;
}
/* Any img inside card, box, or feat */
.feat-card img, .related-card img,
.blog-card-img img, .price-card img { 
  width: 100% !important; max-height: 200px !important;
  object-fit: cover !important; border-radius: 8px !important;
}

/* ── Prevent ANY emoji from becoming an image ─────────────────────── */
/* font-variant-emoji: text forces text rendering on all major browsers */
.ti-icon, .pc-icon, .feat-icon, .bf-icon, .fp-icon, .pp-icon,
.prog-icon, .rc-icon, .scard-badge, .nav-logo-icon,
.trust-inner, .trust-bar, .ti, .foot-social a,
.btn, .btn-primary, .btn-secondary, .btn-white, .btn-outline-white,
.cta-sec, .form-note, .form-submit {
  font-variant-emoji: text !important;
}

/* ── Tutor card classes (defined in template <style> but add here too) */
.tutor-card {
  background: #fff; border-radius: 20px;
  border: 1.5px solid var(--border-light); overflow: hidden;
  transition: all .28s; display: flex; flex-direction: column;
}
.tutor-card:hover { transform: translateY(-6px); box-shadow: 0 20px 56px rgba(26,60,52,.16); border-color: var(--blue-lt); }
.tc-avatar {
  width: 68px !important; height: 68px !important; min-width: 68px !important;
  border-radius: 50% !important; color: #fff !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  font-family: 'Playfair Display', serif !important;
  font-size: 1.4rem !important; font-weight: 700 !important; flex-shrink: 0 !important;
  box-shadow: 0 4px 14px rgba(26,60,52,.22) !important;
}
.tc-stats { display: grid; grid-template-columns: 1fr 1fr 1fr; background: var(--bg-soft); border-radius: 12px; overflow: hidden; margin: 18px 28px 0; }
.tc-stat  { padding: 12px 10px; text-align: center; border-right: 1px solid var(--border-light); }
.tc-stat:last-child { border-right: none; }
.tc-stat-num { font-family: 'Playfair Display',serif; font-size: 1.1rem; font-weight: 700; color: var(--blue); line-height: 1; }
.tc-stat-lbl { font-size: .65rem; color: var(--ink-lt); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; margin-top: 2px; }
.tc-body  { padding: 18px 28px 24px; flex: 1; display: flex; flex-direction: column; gap: 12px; }
.tc-bio   { font-size: .86rem; color: var(--ink-mid); line-height: 1.72; margin: 0; }
.tc-tags  { display: flex !important; flex-wrap: wrap !important; gap: 6px !important; margin-top: auto !important; }

/* ── Contact page classes (defined in template but also in main.css) */
.contact-grid   { display: grid; grid-template-columns: 1fr 1.1fr; gap: 60px; align-items: start; }
.contact-methods { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-bottom: 24px; }
.cmethod {
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 10px; background: #fff; border: 1.5px solid var(--border-light);
  border-radius: 14px; padding: 16px; text-decoration: none; color: inherit; transition: all .22s;
}
.cmethod:hover { border-color: var(--blue); box-shadow: 0 4px 18px rgba(26,60,52,.1); transform: translateY(-3px); }
.cmethod-icon { width: 44px; height: 44px; min-width: 44px; border-radius: 12px; background: var(--blue-lt); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cmethod-icon svg { width: 20px; height: 20px; stroke: var(--blue); display: block; }
.cmethod-label { font-size: .7rem; font-weight: 700; color: var(--ink-lt); text-transform: uppercase; letter-spacing: .06em; }
.cmethod-value { font-size: .96rem; font-weight: 700; color: var(--ink); line-height: 1.2; }
.cmethod-sub   { font-size: .75rem; color: var(--ink-lt); }

/* ── prog-icon sizing ────────────────────────────────────────────── */
.prog-icon { width: 36px !important; height: 36px !important; display: flex !important; align-items: center !important; justify-content: center !important; }
.prog-icon svg { width: 20px !important; height: 20px !important; display: block !important; }

/* ── fp-icon ─────────────────────────────────────────────────────── */
.fp-icon { width: 22px !important; height: 22px !important; display: flex !important; align-items: center !important; justify-content: center !important; flex-shrink: 0 !important; }
.fp-icon svg { width: 16px !important; height: 16px !important; display: block !important; }

@media (max-width: 900px) {
  .contact-grid    { grid-template-columns: 1fr; gap: 36px; }
  .contact-methods { grid-template-columns: 1fr 1fr; }
  .tutors-grid     { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .contact-methods { grid-template-columns: 1fr; }
  .blog-card img, .blog-thumb { height: 160px !important; }
  .post-hero img   { max-height: 240px !important; }
  .tc-avatar       { width: 54px !important; height: 54px !important; min-width: 54px !important; }
}

/* ══════════════════════════════════════════════════════════════════
   SUBJECT CARDS — home page grid
══════════════════════════════════════════════════════════════════ */
.subj-card {
  background: #fff;
  border-radius: var(--r, 16px);
  padding: 26px;
  border: 1.5px solid var(--border-light);
  transition: all .25s;
  text-decoration: none;
  display: block;
  color: inherit;
  position: relative;
  overflow: hidden;
}
.subj-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--accent, var(--blue));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s;
}
.subj-card:hover {
  border-color: var(--border-light);
  box-shadow: 0 6px 28px rgba(26,60,52,.12);
  transform: translateY(-4px);
}
.subj-card:hover::before { transform: scaleX(1); }

.subj-icon {
  width: 52px;
  height: 52px;
  min-width: 52px;
  min-height: 52px;
  border-radius: 14px;
  background: var(--icon-bg, var(--blue-lt));
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  flex-shrink: 0;
}
.subj-icon svg {
  width: 22px !important;
  height: 22px !important;
  stroke: var(--icon-color, var(--blue));
  fill: none;
  stroke-width: 2;
  display: block;
  flex-shrink: 0;
}

.subj-card h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem;
  color: var(--ink);
  margin-bottom: 8px;
  font-weight: 400;
}
.subj-card p {
  font-size: .85rem;
  color: var(--ink-lt);
  line-height: 1.65;
  margin-bottom: 12px;
}
.subj-card span {
  font-size: .8rem;
  font-weight: 600;
  color: var(--accent, var(--blue));
}

/* ══════════════════════════════════════════════════════════════════
   UNIVERSITY MARQUEE STRIP
══════════════════════════════════════════════════════════════════ */
.uni-strip {
  background: var(--bg-soft);
  padding: 28px 0;
  overflow: hidden;
  position: relative;
}
.uni-strip::before,
.uni-strip::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 100px;
  z-index: 2;
  pointer-events: none;
}
.uni-strip::before { left: 0;  background: linear-gradient(to right, var(--bg-soft), transparent); }
.uni-strip::after  { right: 0; background: linear-gradient(to left,  var(--bg-soft), transparent); }

.uni-strip-lbl {
  text-align: center;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-lt);
  margin-bottom: 18px;
}
.uni-track-wrap { overflow: hidden; }
.uni-track {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  gap: 12px !important;
  width: max-content !important;
  align-items: center !important;
  animation: uni-scroll 32s linear infinite;
}
.uni-track:hover { animation-play-state: paused; }

@keyframes uni-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.uni-card {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fff;
  border: 1.5px solid var(--border-light);
  border-radius: 12px;
  padding: 10px 16px;
  white-space: nowrap;
  flex-shrink: 0;
  transition: all .2s;
  cursor: default;
}
.uni-card:hover {
  border-color: var(--blue-lt);
  box-shadow: var(--sh);
  transform: translateY(-2px);
}
.uni-logo {
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .62rem;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
  line-height: 1.1;
  text-align: center;
  letter-spacing: -.01em;
  font-family: 'Inter', sans-serif;
}
.uni-name {
  font-size: .83rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.2;
}
.uni-city {
  font-size: .72rem;
  color: var(--ink-lt);
  margin-top: 2px;
}

/* Emergency uni-card fix */
.uni-card{display:flex !important;flex-direction:row !important;align-items:center !important;gap:10px !important;white-space:nowrap !important;flex-shrink:0 !important;width:auto !important;min-width:0 !important;}
.uni-logo{width:40px !important;height:40px !important;min-width:40px !important;min-height:40px !important;max-width:40px !important;max-height:40px !important;flex-shrink:0 !important;display:flex !important;align-items:center !important;justify-content:center !important;border-radius:8px !important;font-size:.62rem !important;font-weight:800 !important;line-height:1 !important;}
.uni-track-wrap{overflow:hidden !important;width:100% !important;}
.uni-name{display:block !important;font-size:.83rem !important;font-weight:600 !important;color:var(--ink) !important;white-space:nowrap !important;}
.uni-city{display:block !important;font-size:.72rem !important;color:var(--ink-lt) !important;}
