*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --sand:#F5EFE0;--terra:#C4622D;--terra-l:#E8825A;--terra-d:#8B3A14;
  --sage:#6B8F6A;--sage-l:#A8C5A7;--cream:#FDFAF4;
  --char:#2C2923;--wgray:#7A746A;--bdr:rgba(44,41,35,0.12)
}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--char);line-height:1.65;font-size:16px}

/* NAV */
nav{position:sticky;top:0;z-index:100;background:rgba(253,250,244,0.97);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--bdr);padding:0 5%;display:flex;align-items:center;justify-content:space-between;height:140px}
.logo-wrap{display:flex;align-items:center;gap:16px;text-decoration:none}
.logo-img{height:120px;width:auto;object-fit:contain}
.logo-text{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;color:var(--terra);line-height:1.2}
.logo-sub{font-size:.78rem;color:var(--wgray);letter-spacing:.06em;text-transform:uppercase;display:block;font-weight:400}
.nav-links{display:flex;gap:1.75rem;list-style:none}
.nav-links a{font-size:.85rem;font-weight:500;color:var(--wgray);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:var(--terra)}
.nav-cta{background:var(--terra);color:white;border:none;padding:.55rem 1.35rem;border-radius:50px;font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s,transform .15s;text-decoration:none;display:inline-block}
.nav-cta:hover{background:var(--terra-d);transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{width:22px;height:2px;background:var(--char);border-radius:2px;display:block;transition:all .3s}
.mobile-menu{display:none;flex-direction:column;background:var(--cream);border-top:1px solid var(--bdr);padding:1rem 5%;gap:.25rem}
.mobile-menu a{font-size:.92rem;font-weight:500;color:var(--wgray);text-decoration:none;padding:.6rem 0;border-bottom:1px solid var(--bdr)}
.mobile-menu a:last-child{border-bottom:none}
.mobile-menu .m-cta{margin-top:.75rem;background:var(--terra);color:white;padding:.75rem 1.5rem;border-radius:50px;text-align:center;font-weight:500;border:none}

/* HERO */
.hero{padding:4rem 5%;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:4rem;background:var(--sand);position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;bottom:-100px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(196,98,45,0.08) 0%,transparent 70%);pointer-events:none}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:white;border:1px solid var(--bdr);border-radius:50px;padding:.38rem 1rem;font-size:.76rem;font-weight:500;color:var(--sage);margin-bottom:1.5rem}
.hero-badge span{width:7px;height:7px;background:var(--sage);border-radius:50%;display:inline-block;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,3.8vw,3.3rem);font-weight:700;line-height:1.15;color:var(--char);margin-bottom:1.2rem}
h1 em{color:var(--terra);font-style:normal}
.hero-sub{font-size:1rem;color:var(--wgray);max-width:480px;margin-bottom:2rem;line-height:1.8}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}
.btn-p{background:var(--terra);color:white;border:none;padding:.82rem 1.9rem;border-radius:50px;font-family:'DM Sans',sans-serif;font-size:.92rem;font-weight:500;cursor:pointer;transition:background .2s,transform .15s;text-decoration:none;display:inline-block}
.btn-p:hover{background:var(--terra-d);transform:translateY(-2px)}
.btn-s{background:transparent;color:var(--char);border:1.5px solid var(--bdr);padding:.82rem 1.9rem;border-radius:50px;font-family:'DM Sans',sans-serif;font-size:.92rem;font-weight:500;cursor:pointer;transition:border-color .2s,color .2s,transform .15s;text-decoration:none;display:inline-block}
.btn-s:hover{border-color:var(--terra);color:var(--terra);transform:translateY(-2px)}
.hero-stats{display:flex;gap:2.5rem}
.stat-num{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:700;color:var(--terra)}
.stat-lbl{font-size:.7rem;color:var(--wgray);font-weight:500;letter-spacing:.05em;text-transform:uppercase}
.hero-img-wrap{position:relative;display:flex;align-items:center;justify-content:center}
.hero-main-img{width:100%;max-width:480px;border-radius:24px;object-fit:cover;aspect-ratio:1/1;border:1px solid var(--bdr);box-shadow:0 24px 60px rgba(44,41,35,0.1)}
.hero-card-float{position:absolute;bottom:-10px;left:-10px;background:white;border-radius:16px;border:1px solid var(--bdr);padding:1rem 1.2rem;box-shadow:0 12px 40px rgba(44,41,35,0.1);max-width:220px}
.tutor-av{width:40px;height:40px;border-radius:50%;background:var(--terra);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1rem;color:white;flex-shrink:0}
.esa-hero-badge{position:absolute;top:20px;right:-10px;background:white;border:1px solid rgba(107,143,106,0.3);border-radius:12px;padding:.6rem .9rem;box-shadow:0 8px 24px rgba(44,41,35,0.09);display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;color:#3B6D11}
.esa-dot{width:8px;height:8px;border-radius:50%;background:#3B6D11}

/* SECTIONS */
section{padding:5rem 5%;scroll-margin-top:150px}
.sec-lbl{font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--terra);margin-bottom:.7rem}
h2{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,2.8vw,2.3rem);font-weight:700;line-height:1.2;margin-bottom:1rem;color:var(--char)}
.sec-intro{font-size:.97rem;color:var(--wgray);max-width:560px;line-height:1.8}

/* SERVICES */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin:3rem auto 0;max-width:1200px}
.svc-card{border-radius:16px;border:1px solid var(--bdr);overflow:hidden;background:white;transition:box-shadow .25s,transform .25s}
.svc-card:hover{box-shadow:0 16px 50px rgba(44,41,35,0.1);transform:translateY(-4px)}
.svc-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.svc-body{padding:1.4rem}
.svc-title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:600;margin-bottom:.45rem;color:var(--char)}
.svc-desc{font-size:.85rem;color:var(--wgray);line-height:1.75}

/* ABOUT */
.about{background:var(--sand);display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-img{width:100%;border-radius:20px;object-fit:cover;aspect-ratio:1/1;border:1px solid var(--bdr);box-shadow:0 20px 60px rgba(44,41,35,0.1)}
.atag{display:inline-block;background:rgba(196,98,45,0.1);color:var(--terra);font-size:.72rem;font-weight:600;padding:.28rem .75rem;border-radius:50px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.9rem}
.cred-row{display:flex;align-items:flex-start;gap:.7rem;padding:.7rem;background:white;border-radius:10px;border:1px solid var(--bdr);margin-bottom:.55rem}
.cri{width:32px;height:32px;min-width:32px;border-radius:8px;background:var(--sage-l);display:flex;align-items:center;justify-content:center}

/* WHY */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem;margin:3rem auto 0;max-width:1200px}
.why-item{padding:1.6rem;border:1px solid var(--bdr);border-radius:16px;position:relative;overflow:hidden;background:white;transition:box-shadow .2s,transform .2s}
.why-item:hover{box-shadow:0 10px 36px rgba(44,41,35,0.08);transform:translateY(-2px)}
.why-item::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--terra)}
.why-num{font-family:'Playfair Display',serif;font-size:2.6rem;font-weight:700;color:var(--terra);line-height:1;margin-bottom:.7rem}
.why-title{font-family:'Playfair Display',serif;font-size:.97rem;font-weight:600;margin-bottom:.45rem;color:var(--char)}
.why-desc{font-size:.83rem;color:var(--wgray);line-height:1.7}

/* HOW IT WORKS */
.how{background:var(--sand)}
.how-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:1.25rem;margin:3rem auto 0;max-width:1300px;position:relative}
.how-step{position:relative;padding:1.5rem 1.25rem;background:white;border:1px solid var(--bdr);border-radius:16px;text-align:center;transition:box-shadow .25s,transform .25s}
.how-step:hover{box-shadow:0 14px 40px rgba(44,41,35,0.08);transform:translateY(-3px)}
.how-circle{width:46px;height:46px;border-radius:50%;background:var(--terra);color:white;font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 6px 16px rgba(196,98,45,0.3)}
.how-title{font-family:'Playfair Display',serif;font-size:.95rem;font-weight:600;margin-bottom:.5rem;color:var(--char)}
.how-desc{font-size:.8rem;color:var(--wgray);line-height:1.7}

/* ESA BAND */
.esa-band{background:linear-gradient(135deg,#1a3d1a 0%,#2d5a2d 100%);padding:3rem 5%;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.esa-band h3{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;color:white;margin-bottom:.5rem}
.esa-band p{font-size:.9rem;color:rgba(255,255,255,0.78);max-width:500px;line-height:1.7}
.esa-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.25);border-radius:50px;padding:.35rem .9rem;font-size:.75rem;font-weight:600;color:white;margin-bottom:.75rem}
.btn-esa{background:white;color:#2d5a2d;border:none;padding:.8rem 1.8rem;border-radius:50px;font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s;text-decoration:none;display:inline-block;white-space:nowrap}
.btn-esa:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.2)}

/* TESTIMONIALS */
.testi{background:var(--char)}
.testi .sec-lbl{color:var(--terra-l)}
.testi h2{color:white}
.testi .sec-intro{color:rgba(255,255,255,0.58)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.testi-card{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:16px;padding:1.6rem;transition:background .2s}
.testi-card:hover{background:rgba(255,255,255,0.09)}
.stars{display:flex;gap:3px;margin-bottom:.9rem}
.star{width:13px;height:13px;background:var(--terra-l);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.testi-text{font-size:.87rem;color:rgba(255,255,255,0.82);line-height:1.8;margin-bottom:1.1rem;font-style:italic}
.testi-author{font-size:.78rem;font-weight:500;color:var(--terra-l)}

/* FAQ */
.faq-wrap{display:grid;grid-template-columns:1fr 2fr;gap:5rem;align-items:start}
.faq-sticky{position:sticky;top:160px}
.faq-list{display:flex;flex-direction:column;gap:.9rem}
.faq-item{border:1px solid var(--bdr);border-radius:14px;overflow:hidden;background:white}
.faq-q{width:100%;background:none;border:none;padding:1.1rem 1.3rem;text-align:left;font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:500;color:var(--char);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:background .2s}
.faq-q:hover{background:var(--cream)}
.faq-icon{width:24px;height:24px;min-width:24px;border-radius:50%;border:1.5px solid var(--bdr);display:flex;align-items:center;justify-content:center;transition:transform .25s,background .2s,border-color .2s;flex-shrink:0}
.faq-icon.open{transform:rotate(45deg);background:var(--terra);border-color:var(--terra)}
.faq-icon.open line{stroke:white}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .3s}
.faq-a.open{max-height:400px;padding:0 1.3rem 1.1rem}
.faq-a p{font-size:.86rem;color:var(--wgray);line-height:1.8}
.esa-badge-sm{display:inline-flex;align-items:center;gap:5px;background:rgba(107,143,106,0.12);border:1px solid rgba(107,143,106,0.28);border-radius:50px;padding:.25rem .75rem;font-size:.72rem;font-weight:600;color:#3B6D11;margin-bottom:.6rem}

/* CONTACT FORM */
.contact-sec{background:var(--cream)}
.contact-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:start;margin-top:2.5rem}
.contact-form{background:white;border:1px solid var(--bdr);border-radius:20px;padding:2rem;box-shadow:0 14px 40px rgba(44,41,35,0.06)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.form-field label{font-size:.78rem;font-weight:500;color:var(--char);letter-spacing:.02em}
.form-field input,.form-field select,.form-field textarea{font-family:'DM Sans',sans-serif;font-size:.93rem;color:var(--char);background:var(--cream);border:1px solid var(--bdr);border-radius:10px;padding:.75rem .9rem;transition:border-color .2s,background .2s;width:100%}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--terra);background:white}
.form-field textarea{resize:vertical;min-height:110px;font-family:'DM Sans',sans-serif}
.form-submit{width:100%;background:var(--terra);color:white;border:none;padding:.95rem;border-radius:50px;font-family:'DM Sans',sans-serif;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s,transform .15s;margin-top:.5rem}
.form-submit:hover{background:var(--terra-d);transform:translateY(-2px)}
.form-note{font-size:.74rem;color:var(--wgray);margin-top:.85rem;text-align:center;line-height:1.6}
.form-success{display:none;padding:1rem;background:rgba(107,143,106,0.12);border:1px solid rgba(107,143,106,0.3);border-radius:10px;color:#3B6D11;font-size:.85rem;margin-bottom:1rem}
.form-success.show{display:block}

/* CTA */
.cta-sec{background:var(--terra);padding:5rem 5%;text-align:center}
.cta-sec h2{color:white;margin-bottom:1rem}
.cta-sec p{color:rgba(255,255,255,0.88);font-size:.97rem;max-width:540px;margin:0 auto 2.25rem;line-height:1.8}
.btn-w{background:white;color:var(--terra);border:none;padding:.88rem 2.3rem;border-radius:50px;font-family:'DM Sans',sans-serif;font-size:.97rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;text-decoration:none;display:inline-block}
.btn-w:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,0.18)}
.ci{display:flex;justify-content:center;gap:2.5rem;margin-top:2.25rem;flex-wrap:wrap}
.ci-item{display:flex;align-items:center;gap:.55rem;color:rgba(255,255,255,0.85);font-size:.87rem;text-decoration:none}
.ci-item:hover{color:white}

/* ESA PAGE */
.page-hero{padding:5rem 5% 3rem;background:linear-gradient(135deg,#1a3d1a 0%,#2d5a2d 100%);color:white;text-align:center}
.page-hero .sec-lbl{color:rgba(255,255,255,0.7)}
.page-hero h1{color:white;font-size:clamp(2rem,3.5vw,3rem);margin-bottom:1.2rem}
.page-hero .lead{font-size:1.05rem;color:rgba(255,255,255,0.85);max-width:680px;margin:0 auto 2rem;line-height:1.7}
.esa-page-section{padding:4rem 5%}
.esa-page-section.alt{background:var(--sand)}
.esa-page-section h2{margin-bottom:1.5rem}
.esa-page-section p{font-size:.97rem;color:var(--char);line-height:1.85;margin-bottom:1rem;max-width:780px}
.esa-page-section ul{list-style:none;padding:0;margin:1.5rem 0;max-width:780px}
.esa-page-section ul li{padding:.85rem 1rem .85rem 2.6rem;background:white;border:1px solid var(--bdr);border-radius:10px;margin-bottom:.6rem;font-size:.92rem;color:var(--char);line-height:1.7;position:relative}
.esa-page-section.alt ul li{background:white}
.esa-page-section ul li::before{content:'';position:absolute;left:.95rem;top:1.1rem;width:18px;height:18px;border-radius:50%;background:var(--sage-l);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 6L5 9L10 3' stroke='%23fff' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' fill='none'/></svg>");background-repeat:no-repeat;background-position:center}
.esa-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2.5rem;max-width:1100px}
.esa-step{background:white;border:1px solid var(--bdr);border-radius:16px;padding:1.5rem;position:relative}
.esa-step-num{font-family:'Playfair Display',serif;font-size:2.8rem;font-weight:700;color:var(--terra);line-height:1;margin-bottom:.5rem}
.esa-step-title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:600;margin-bottom:.5rem;color:var(--char)}
.esa-step-desc{font-size:.86rem;color:var(--wgray);line-height:1.75}

/* FOOTER */
footer{background:var(--char);padding:3rem 5% 2rem}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,0.08)}
.footer-brand .logo-text{color:white}
.footer-brand .logo-sub{color:rgba(255,255,255,0.4)}
.footer-desc{font-size:.83rem;color:rgba(255,255,255,0.45);line-height:1.75;margin-top:.75rem;max-width:260px}
.footer-col h4{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:1rem}
.footer-col a{display:block;font-size:.83rem;color:rgba(255,255,255,0.55);text-decoration:none;margin-bottom:.55rem;transition:color .2s}
.footer-col a:hover{color:var(--terra-l)}
.footer-col p{font-size:.83rem;color:rgba(255,255,255,0.55);margin-bottom:.5rem;line-height:1.6}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.75rem;color:rgba(255,255,255,0.3)}
.footer-bottom a{color:rgba(255,255,255,0.3);text-decoration:none}
.footer-bottom a:hover{color:var(--terra-l)}

/* RESPONSIVE */
@media(max-width:900px){
  .hero{grid-template-columns:1fr;min-height:auto;padding:4rem 5%}
  .hero-img-wrap{display:none}
  .about{grid-template-columns:1fr;gap:2.5rem}
  .why-grid{grid-template-columns:1fr 1fr}
  .testi-grid{grid-template-columns:1fr}
  .faq-wrap{grid-template-columns:1fr;gap:2rem}
  .faq-sticky{position:static}
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
  .svc-grid{grid-template-columns:1fr}
  .how-steps{grid-template-columns:repeat(2,1fr)}
  .contact-wrap{grid-template-columns:1fr;gap:2.5rem}
  .esa-steps{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  nav{height:90px}
  .logo-img{height:70px}
  .logo-text{font-size:1.15rem}
  .logo-sub{font-size:.66rem}
}
@media(max-width:640px){
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  .why-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .hero-stats{gap:1.5rem}
  .esa-band{flex-direction:column}
  .how-steps{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .esa-steps{grid-template-columns:1fr}
  nav{height:78px}
  .logo-img{height:58px}
}
