
  :root{
    /* School color theme: MAROON (primary) + gold — adjust exact shade to match FB photos */
    --green:#7a1f2f;        /* maroon primary (was green) */
    --green-dark:#561220;   /* deep maroon */
    --green-soft:#f8ecee;   /* soft rose tint */
    --sun:#f4b53f;          /* gold accent */
    --sun-soft:#fdf3df;
    --coral:#c46a3a;
    --coral-soft:#fdeee4;
    --sky:#4f7fa8;
    --sky-soft:#e9f1f8;
    --ink:#35262a;
    --muted:#6f5f63;
    --cream:#fffaf6;
    --line:#eedfdb;
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{font-family:'Nunito',sans-serif; color:var(--ink); background:var(--cream);}
  html[dir="rtl"] body{font-family:'Noto Nastaliq Urdu','Nunito',sans-serif; direction:rtl; line-height:1.9;}
  h1,h2,h3,.logo-text{font-family:'Fredoka',sans-serif;}
  html[dir="rtl"] h1,html[dir="rtl"] h2,html[dir="rtl"] h3{font-family:'Noto Nastaliq Urdu','Fredoka',sans-serif; line-height:1.8;}
  img{max-width:100%;}
  ::selection{background:rgba(249,178,52,.4);}

  /* ---------- TOP BAR ---------- */
  .topbar{background:var(--green-dark); color:#eaf6ee; font-size:13px; padding:8px 5vw;
    display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;}
  .topbar span{display:flex; align-items:center; gap:6px;}
  .topbar a{color:inherit; text-decoration:none; font-weight:800;}
  .topbar a:hover{text-decoration:underline;}
  .topbar .badge{background:var(--sun); color:#5b3c00; font-weight:800; padding:2px 12px;
    border-radius:999px; font-size:12px;}

  /* ---------- HEADER ---------- */
  header{position:sticky; top:0; z-index:50; background:rgba(255,253,247,.92);
    backdrop-filter:blur(10px); border-bottom:1px solid var(--line);
    display:flex; align-items:center; justify-content:space-between; padding:14px 5vw;}
  .brand{display:flex; align-items:center; gap:12px; text-decoration:none;}
  .site-logo{width:70px; height:70px; flex:0 0 70px; object-fit:contain; display:block;}
  .logo-text{line-height:1.1;}
  .logo-text b{display:block; color:var(--green-dark); font-size:19px; font-weight:600;}
  .logo-text small{color:var(--muted); font-size:11px; font-weight:500; letter-spacing:.06em;}
  nav{display:flex; gap:26px; align-items:center;}
  nav a{font-weight:700; font-size:14.5px; color:var(--ink); text-decoration:none; transition:color .25s;}
  nav a:hover{color:var(--green);}
  nav a.is-active,
  nav a[aria-current="page"]{color:var(--green);}
  .lang-switch{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:999px;padding:3px;background:#fff;}
  .lang-switch a{font-size:12px;font-weight:800;padding:5px 10px;border-radius:999px;color:var(--muted);}
  .lang-switch a:hover{background:var(--green-soft);color:var(--green-dark);}
  .btn{display:inline-block; font-weight:800; text-decoration:none; border-radius:999px;
    padding:13px 28px; font-size:15px; transition:transform .2s, box-shadow .2s;}
  .btn-sun{background:var(--sun); color:#5b3c00; box-shadow:0 4px 0 #d99a1f;}
  .btn-sun:hover{transform:translateY(-2px); box-shadow:0 6px 0 #d99a1f;}
  nav .btn-sun.is-active,
  nav .btn-sun[aria-current="page"]{background:var(--green); color:#fff; box-shadow:0 4px 0 var(--green-dark);}
  .btn-green{background:var(--green); color:#fff; box-shadow:0 4px 0 var(--green-dark);}
  .btn-green:hover{transform:translateY(-2px); box-shadow:0 6px 0 var(--green-dark);}
  .btn-ghost{border:2px solid var(--green); color:var(--green-dark);}
  .btn-ghost:hover{background:var(--green-soft);}
  nav .btn{padding:10px 22px; font-size:14px;}
  html[dir="rtl"] nav{font-family:'Noto Nastaliq Urdu','Nunito',sans-serif;}
  html[dir="rtl"] .brand{direction:ltr;}

  /* ---------- HERO ---------- */
  .hero{position:relative; overflow:hidden; padding:70px 5vw 90px;
    background:
      radial-gradient(600px 300px at 85% 15%, var(--sun-soft) 0%, transparent 70%),
      radial-gradient(500px 320px at 8% 80%, var(--sky-soft) 0%, transparent 70%),
      var(--cream);}
  .hero-grid{max-width:1180px; margin:0 auto; display:grid;
    grid-template-columns:1.1fr .9fr; gap:50px; align-items:center;}
  .eyebrow{display:inline-flex; align-items:center; gap:8px; background:var(--green-soft);
    color:var(--green-dark); font-weight:800; font-size:13px; padding:8px 18px;
    border-radius:999px; margin-bottom:20px;}
  .hero h1{font-size:clamp(34px,4.6vw,58px); font-weight:600; line-height:1.12; color:var(--ink);}
  .hero h1 .hl{color:var(--green); position:relative; white-space:nowrap;}
  .hero h1 .hl::after{content:""; position:absolute; left:0; right:0; bottom:4px; height:10px;
    background:rgba(249,178,52,.45); z-index:-1; border-radius:4px;}
  .hero p.lead{margin-top:18px; font-size:17px; line-height:1.7; color:var(--muted); max-width:520px;}
  .hero-ctas{display:flex; gap:14px; margin-top:30px; flex-wrap:wrap;}
  .trust{display:flex; gap:26px; margin-top:38px; flex-wrap:wrap;}
  .trust div{display:flex; align-items:center; gap:10px; font-size:14px; font-weight:700; color:var(--ink);}
  .trust .dot{width:38px;height:38px;border-radius:12px; display:flex;align-items:center;
    justify-content:center; font-size:18px; background:#fff; border:1px solid var(--line);
    box-shadow:0 3px 8px rgba(39,53,44,.06);}

  /* hero illustration card */
  .hero-art{position:relative;}
  .art-main{background:#fff; border:1px solid var(--line); border-radius:28px;
    box-shadow:0 24px 50px rgba(39,53,44,.10); padding:28px; position:relative; z-index:2;}
  .art-photo{height:240px; border-radius:18px; display:flex; align-items:center; justify-content:center;
    background:linear-gradient(135deg, var(--green-soft), var(--sky-soft)); font-size:64px;
    border:2px dashed rgba(46,125,82,.25); flex-direction:column; gap:8px;}
  .art-photo small{font-size:12.5px; color:var(--muted); font-weight:700; font-family:'Nunito';}
  .art-row{display:flex; gap:12px; margin-top:14px;}
  .art-chip{flex:1; border-radius:14px; padding:14px 12px; text-align:center;}
  .art-chip b{display:block; font-family:'Fredoka'; font-size:21px;}
  .art-chip small{font-size:11.5px; font-weight:800; letter-spacing:.04em;}
  .chip-g{background:var(--green-soft); color:var(--green-dark);}
  .chip-s{background:var(--sun-soft); color:#8a5a00;}
  .chip-c{background:var(--coral-soft); color:#a33c1d;}
  .float{position:absolute; background:#fff; border:1px solid var(--line); border-radius:16px;
    padding:10px 16px; font-size:13px; font-weight:800; box-shadow:0 10px 24px rgba(39,53,44,.12);
    display:flex; align-items:center; gap:8px; z-index:3; animation:bob 4s ease-in-out infinite;}
  .float.f1{top:-18px; left:-26px; color:var(--green-dark);}
  .float.f2{bottom:-30px; right:-20px; color:#8a5a00; animation-delay:1.3s;}
  @keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

  /* ---------- SECTION BASICS ---------- */
  section{padding:80px 5vw;}
  .wrap{max-width:1180px; margin:0 auto;}
  .sec-head{text-align:center; max-width:640px; margin:0 auto 50px;}
  .sec-head .tag{display:inline-block; background:var(--sun-soft); color:#8a5a00; font-weight:800;
    font-size:13px; padding:7px 18px; border-radius:999px; margin-bottom:14px;}
  .sec-head h2{font-size:clamp(26px,3.4vw,40px); font-weight:600; color:var(--ink);}
  .sec-head p{margin-top:12px; color:var(--muted); font-size:16px; line-height:1.7;}

  /* ---------- STATS BAND ---------- */
  .stats-band{background:var(--green); border-radius:0;}
  .stats-grid{max-width:1180px; margin:0 auto; display:grid;
    grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:20px;}
  .stat{text-align:center; color:#fff; padding:10px;}
  .stat b{display:block; font-family:'Fredoka'; font-size:clamp(30px,3.6vw,44px); font-weight:600;}
  .stat span{font-size:14px; font-weight:700; opacity:.9;}

  /* ---------- PROGRAMS ---------- */
  .cards{display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:22px;}
  .pcard{border-radius:24px; padding:30px 26px; border:1px solid var(--line); background:#fff;
    box-shadow:0 6px 18px rgba(39,53,44,.05); transition:transform .25s, box-shadow .25s; position:relative;}
  .pcard:hover{transform:translateY(-6px); box-shadow:0 18px 38px rgba(39,53,44,.10);}
  .pcard .ico{width:58px; height:58px; border-radius:18px; display:flex; align-items:center;
    justify-content:center; font-size:28px; margin-bottom:18px;}
  .pcard h3{font-size:20px; font-weight:600; margin-bottom:8px;}
  .pcard .age{display:inline-block; font-size:12px; font-weight:800; padding:3px 12px;
    border-radius:999px; margin-bottom:12px;}
  .pcard p{font-size:14.5px; color:var(--muted); line-height:1.65;}
  .pc-green .ico{background:var(--green-soft);} .pc-green .age{background:var(--green-soft); color:var(--green-dark);}
  .pc-sun .ico{background:var(--sun-soft);} .pc-sun .age{background:var(--sun-soft); color:#8a5a00;}
  .pc-sky .ico{background:var(--sky-soft);} .pc-sky .age{background:var(--sky-soft); color:#1d5e8c;}
  .pc-coral .ico{background:var(--coral-soft);} .pc-coral .age{background:var(--coral-soft); color:#a33c1d;}

  /* ---------- MONTESSORI ---------- */
  .monte{background:var(--green-soft);}
  .monte-grid{max-width:1180px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr;
    gap:50px; align-items:center;}
  .monte h2{font-size:clamp(26px,3.2vw,38px); font-weight:600;}
  .monte p.big{margin-top:14px; color:var(--muted); font-size:16px; line-height:1.75;}
  .m-points{margin-top:26px; display:grid; gap:14px;}
  .m-point{display:flex; gap:14px; align-items:flex-start; background:#fff; border-radius:16px;
    padding:16px 18px; border:1px solid rgba(46,125,82,.12);}
  .m-point .mi{font-size:22px; line-height:1;}
  .m-point b{display:block; font-size:15px;}
  .m-point small{color:var(--muted); font-size:13.5px; line-height:1.5;}
  .monte-art{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
  .m-tile{border-radius:22px; padding:26px 20px; text-align:center; background:#fff;
    border:1px solid rgba(46,125,82,.12); box-shadow:0 8px 20px rgba(29,92,58,.06);}
  .m-tile .big-ico{font-size:38px;}
  .m-tile b{display:block; margin-top:10px; font-family:'Fredoka'; font-weight:600; font-size:16px;}
  .m-tile:nth-child(2){transform:translateY(18px);}
  .m-tile:nth-child(3){transform:translateY(-6px);}

  /* ---------- RESULTS BANNER ---------- */
  .results{background:linear-gradient(120deg, var(--green-dark), var(--green)); color:#fff;
    border-radius:32px; max-width:1180px; margin:0 auto; padding:54px 6%;
    display:grid; grid-template-columns:auto 1fr auto; gap:36px; align-items:center;}
  .results .ring{width:130px; height:130px; border-radius:50%; background:#fff; color:var(--green-dark);
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    font-family:'Fredoka'; box-shadow:0 0 0 10px rgba(255,255,255,.18);}
  .results .ring b{font-size:34px; font-weight:700;}
  .results .ring small{font-size:11px; font-weight:800; font-family:'Nunito';}
  .results h2{font-size:clamp(24px,3vw,34px); font-weight:600;}
  .results p{margin-top:8px; opacity:.92; font-size:15.5px; line-height:1.6; max-width:560px;}

  /* ---------- WHY US ---------- */
  .why .cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}

  /* ---------- TESTIMONIALS ---------- */
  .quotes{display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:22px;}
  .quote{background:#fff; border:1px solid var(--line); border-radius:22px; padding:28px;
    box-shadow:0 6px 18px rgba(39,53,44,.05);}
  .quote .stars{color:var(--sun); letter-spacing:2px; font-size:15px;}
  .quote p{margin-top:12px; font-size:14.5px; line-height:1.7; color:var(--ink);}
  .quote .who{margin-top:16px; display:flex; align-items:center; gap:12px;}
  .quote .av{width:42px; height:42px; border-radius:50%; display:flex; align-items:center;
    justify-content:center; font-weight:800; color:#fff; font-size:15px;}
  .quote .who b{display:block; font-size:14px;}
  .quote .who small{color:var(--muted); font-size:12px;}

  /* ---------- ADMISSIONS CTA ---------- */
  .cta{background:var(--sun-soft); border-radius:32px; max-width:1180px; margin:0 auto;
    padding:60px 6%; text-align:center; position:relative; overflow:hidden;}
  .cta::before{content:"✏️"; position:absolute; font-size:70px; left:6%; top:18%; opacity:.25; transform:rotate(-15deg);}
  .cta::after{content:"🎒"; position:absolute; font-size:70px; right:6%; bottom:14%; opacity:.25; transform:rotate(12deg);}
  .cta h2{font-size:clamp(26px,3.4vw,40px); font-weight:600;}
  .cta p{margin-top:12px; color:var(--muted); font-size:16px; max-width:540px; margin-left:auto; margin-right:auto;}
  .cta .hero-ctas{justify-content:center;}

  /* ---------- FOOTER ---------- */
  footer{background:var(--green-dark); color:#d8ead e; color:#d8eade; padding:60px 5vw 30px; margin-top:80px;}
  .f-grid{max-width:1180px; margin:0 auto; display:grid;
    grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:36px;}
  footer h4{font-family:'Fredoka'; font-weight:600; color:#fff; margin-bottom:16px; font-size:16px;}
  footer p, footer a, footer li{color:#bcd9c6; font-size:14px; line-height:1.8; text-decoration:none; list-style:none;}
  footer a:hover{color:var(--sun);}
  .f-bottom{max-width:1180px; margin:40px auto 0; padding-top:20px;
    border-top:1px solid rgba(255,255,255,.15); display:flex; justify-content:space-between;
    flex-wrap:wrap; gap:10px; font-size:13px; color:#9cc3aa;}
  .fb-link{display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.1);
    padding:9px 18px; border-radius:999px; margin-top:10px; font-weight:700;}

  /* ---------- LIFE & MOTION ---------- */
  .rv{opacity:0; transform:translateY(30px); transition:opacity .8s cubic-bezier(.2,.6,.2,1), transform .8s cubic-bezier(.2,.6,.2,1);}
  .rv.in{opacity:1; transform:none;}
  .blob{position:absolute; border-radius:50%; filter:blur(70px); z-index:0; pointer-events:none;
    animation:blobf 16s ease-in-out infinite;}
  .blob.b1{width:440px; height:330px; right:4%; top:6%; background:rgba(244,181,63,.30);}
  .blob.b2{width:380px; height:300px; left:0%; bottom:2%; background:rgba(122,31,47,.10); animation-delay:5s;}
  @keyframes blobf{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-34px,22px) scale(1.1)}}
  .hero-grid{position:relative; z-index:1;}

  .ticker{background:var(--green-dark); color:#fff; overflow:hidden; padding:13px 0;}
  .ticker .trk{display:flex; gap:46px; width:max-content; animation:tk 26s linear infinite;
    font-weight:800; font-size:13.5px; letter-spacing:.06em; white-space:nowrap;}
  .ticker .trk span::after{content:"★"; margin-left:46px; color:var(--sun);}
  @keyframes tk{to{transform:translateX(-50%);}}

  .art-photo{position:relative; overflow:hidden;}
  .art-photo img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-radius:16px;}
  .gallery{display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:18px;}
  .gimg{height:230px; border-radius:20px; overflow:hidden; position:relative;
    background:#eef3ed; border:1px solid rgba(35,79,49,.12); box-shadow:0 14px 28px rgba(35,79,49,.12);}
  .gallery-lightbox-trigger{display:block; width:100%; height:100%; cursor:zoom-in;}
  .gimg img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .5s;}
  .gimg:hover img{transform:scale(1.07);}
  .lightbox{position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center;
    padding:28px; background:rgba(10,18,14,.9);}
  .lightbox.is-open{display:flex;}
  .lightbox img{max-width:min(1120px,92vw); max-height:86vh; object-fit:contain; border-radius:14px;
    box-shadow:0 28px 70px rgba(0,0,0,.45);}
  .lightbox-close{position:absolute; top:18px; right:18px; width:44px; height:44px; border:0; border-radius:50%;
    background:#fff; color:var(--green-dark); font-size:30px; line-height:1; cursor:pointer;
    box-shadow:0 12px 30px rgba(0,0,0,.25);}
  .lightbox-close:hover{background:var(--sun);}
  body.lightbox-open{overflow:hidden;}
  @media (prefers-reduced-motion: reduce){
    .rv{transition:none; opacity:1; transform:none;}
    .blob, .ticker .trk, .float{animation:none;}
  }

  @media (max-width:960px){
    .hero-grid, .monte-grid{grid-template-columns:1fr;}
    .results{grid-template-columns:1fr; text-align:center; justify-items:center;}
    .f-grid{grid-template-columns:1fr 1fr;}
    .float.f1{left:0;} .float.f2{right:0;}
  }

/* ============ SUBPAGES ============ */
.page-hero{background:linear-gradient(120deg,var(--green-dark),var(--green));color:#fff;padding:64px 5vw 56px;text-align:center;}
.page-hero .crumb{font-size:13px;font-weight:700;opacity:.8;letter-spacing:.08em;text-transform:uppercase;}
.page-hero h1{font-family:'Fredoka';font-size:clamp(30px,4.5vw,50px);font-weight:600;margin-top:10px;}
.page-hero p{margin:14px auto 0;max-width:640px;font-size:16px;line-height:1.7;color:#fbeedd;}
.principal-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:.9fr 1.4fr;gap:50px;align-items:start;}
.portrait{background:linear-gradient(135deg,var(--green-soft),var(--sun-soft));border:2px dashed rgba(122,31,47,.25);border-radius:28px;min-height:430px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;color:var(--muted);font-weight:700;position:relative;overflow:hidden;}
.portrait .em{font-size:54px;}
.portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.p-name{margin-top:18px;text-align:center;}
.p-name b{font-family:'Fredoka';font-size:21px;color:var(--green-dark);display:block;font-weight:600;}
.p-name small{color:var(--muted);font-weight:700;}
.bio h2{font-family:'Fredoka';font-size:clamp(26px,3.2vw,38px);font-weight:600;}
.bio p{margin-top:16px;color:var(--muted);font-size:15.5px;line-height:1.85;}
.bio .hl-card{margin-top:24px;background:var(--green-soft);border-radius:18px;padding:20px 24px;font-weight:700;color:var(--green-dark);font-size:15px;line-height:1.65;}
.timeline{max-width:860px;margin:50px auto 0;position:relative;}
.timeline::before{content:"";position:absolute;left:13px;top:6px;bottom:6px;width:3px;background:var(--green-soft);border-radius:99px;}
.tl{position:relative;padding:0 0 40px 56px;}
.tl::before{content:"";position:absolute;left:5px;top:4px;width:19px;height:19px;border-radius:50%;background:var(--green);box-shadow:0 0 0 5px var(--green-soft);}
.tl .year{display:inline-block;background:var(--sun-soft);color:#8a5a00;font-weight:800;font-size:12.5px;padding:4px 14px;border-radius:999px;margin-bottom:10px;}
.tl h3{font-family:'Fredoka';font-weight:600;font-size:19px;}
.tl p{margin-top:8px;color:var(--muted);font-size:14.5px;line-height:1.7;max-width:640px;}
.tribute{background:linear-gradient(120deg,var(--green-dark),var(--green));border-radius:32px;max-width:1180px;margin:0 auto;color:#fff;text-align:center;padding:64px 8%;}
.tribute .tag-w{display:inline-block;background:rgba(255,255,255,.15);border-radius:999px;padding:7px 18px;font-weight:800;font-size:13px;margin-bottom:16px;color:var(--sun);}
.tribute h2{font-family:'Fredoka';font-weight:600;font-size:clamp(24px,3vw,36px);}
.tribute p{margin:16px auto 0;max-width:660px;line-height:1.8;color:#f3ddc9;}
.ggrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;}
.ggrid .gimg{height:250px;}
.form-wrap{max-width:780px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:28px;padding:42px;box-shadow:0 16px 40px rgba(39,53,44,.08);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form-grid .full{grid-column:1/-1;}
form[id^="admissions2026-27-"]{max-width:780px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:28px;padding:42px;box-shadow:0 16px 40px rgba(39,53,44,.08);display:grid;grid-template-columns:1fr 1fr;gap:18px;}
form[id^="admissions2026-27-"]>div:first-child{display:none;}
form[id^="admissions2026-27-"] .full{grid-column:1/-1;}
form[id^="admissions2026-27-"] .form-note-wrap{grid-column:1/2;display:flex;align-items:center;}
form[id^="admissions2026-27-"] .form-actions{grid-column:2/3;align-self:center;justify-content:flex-end;}
form[id^="admissions2026-27-"] .form-navigation{display:flex;justify-content:flex-end;width:100%;}
.fld label{display:block;font-weight:800;font-size:13px;margin-bottom:7px;}
.fld label em,.fld label .required{color:var(--coral);font-style:normal;}
.fld input,.fld select,.fld textarea{width:100%;border:2px solid var(--line);border-radius:14px;padding:13px 16px;font-family:'Nunito';font-size:14.5px;color:var(--ink);background:var(--cream);outline:none;transition:border-color .25s;}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--green);}
.fld input.is-invalid,.fld select.is-invalid,.fld textarea.is-invalid{border-color:var(--coral);}
.fld textarea{min-height:110px;resize:vertical;}
.form-note{font-size:12.5px;color:var(--muted);font-weight:600;line-height:1.6;}
.form-actions{display:flex;align-items:center;justify-content:flex-end;gap:18px;flex-wrap:wrap;}
.form-actions button{border:none;cursor:pointer;}
.invalid-feedback{display:block;margin-top:7px;color:var(--coral);font-size:12.5px;font-weight:800;}
.done{display:none;background:var(--green-soft);border:2px solid var(--green);border-radius:20px;padding:34px;text-align:center;font-weight:800;color:var(--green-dark);font-size:17px;line-height:1.6;}
.form-confirmation{background:var(--green-soft);border:2px solid var(--green);border-radius:20px;padding:34px;text-align:center;font-weight:800;color:var(--green-dark);font-size:17px;line-height:1.6;}
.info-chips{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:24px;}
.info-chips span{background:rgba(255,255,255,.15);border-radius:999px;padding:9px 18px;font-size:13px;font-weight:700;}
@media(max-width:900px){.principal-grid{grid-template-columns:1fr;}.form-grid,form[id^="admissions2026-27-"]{grid-template-columns:1fr;}form[id^="admissions2026-27-"] .form-note-wrap,form[id^="admissions2026-27-"] .form-actions{grid-column:1/-1;}}

/* ============ FEES / FAQ / NEWS / FACILITIES ============ */
.fee-table{width:100%; border-collapse:separate; border-spacing:0; margin-top:40px;
  background:#fff; border:1px solid var(--line); border-radius:20px; overflow:hidden;}
.fee-table th{background:var(--green); color:#fff; font-family:'Fredoka'; font-weight:600;
  font-size:15px; padding:16px 20px; text-align:left;}
.fee-table td{padding:16px 20px; border-top:1px solid var(--line); font-size:14.5px; font-weight:700;}
.fee-table tr td:first-child{color:var(--ink);}
.fee-table td.amt{color:var(--green-dark); font-family:'Fredoka'; font-size:16px;}
.fee-table tr:nth-child(even){background:var(--cream);}
.fee-note{margin-top:16px; font-size:13px; color:var(--muted); font-weight:700; line-height:1.7;}
.faq{max-width:820px; margin:40px auto 0;}
.faq details{background:#fff; border:1px solid var(--line); border-radius:18px;
  margin-bottom:14px; overflow:hidden;}
.faq summary{cursor:pointer; list-style:none; padding:20px 24px; font-weight:800; font-size:15.5px;
  display:flex; justify-content:space-between; align-items:center; gap:16px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+"; font-family:'Fredoka'; color:var(--green); font-size:22px;
  flex-shrink:0; transition:transform .3s;}
.faq details[open] summary{color:var(--green-dark);}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq .ans{padding:0 24px 22px; color:var(--muted); font-size:14.5px; line-height:1.75;}
.news-list{display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px; margin-top:40px;}
.ncard{background:#fff; border:1px solid var(--line); border-radius:20px; padding:26px;
  box-shadow:0 6px 18px rgba(39,53,44,.05); transition:transform .25s, box-shadow .25s; display:block; text-decoration:none;}
.ncard:hover{transform:translateY(-5px); box-shadow:0 16px 34px rgba(39,53,44,.10);}
.ncard .ndate{display:inline-block; background:var(--green-soft); color:var(--green-dark);
  font-weight:800; font-size:12px; padding:5px 14px; border-radius:999px;}
.ncard .ncat{display:inline-block; background:var(--sun-soft); color:#8a5a00;
  font-weight:800; font-size:12px; padding:5px 14px; border-radius:999px; margin-left:6px;}
.ncard h3{font-family:'Fredoka'; font-weight:600; font-size:18px; color:var(--ink); margin:14px 0 8px;}
.ncard p{font-size:14px; color:var(--muted); line-height:1.65;}
.facil{max-width:1180px; margin:0 auto 40px; display:grid; grid-template-columns:1fr 1.1fr;
  gap:40px; align-items:center;}
.facil:nth-of-type(even){direction:rtl;}
.facil:nth-of-type(even) > *{direction:ltr;}
.facil .gimg{height:300px; border-radius:24px;}
.facil h3{font-family:'Fredoka'; font-weight:600; font-size:clamp(22px,2.6vw,30px);}
.facil .ftag{display:inline-block; background:var(--sun-soft); color:#8a5a00; font-weight:800;
  font-size:12.5px; padding:6px 16px; border-radius:999px; margin-bottom:12px;}
.facil p{margin-top:12px; color:var(--muted); font-size:15px; line-height:1.8;}
.facil ul{margin-top:14px; list-style:none;}
.facil li{font-size:14px; font-weight:700; color:var(--ink); padding:6px 0 6px 26px; position:relative;}
.facil li::before{content:"✓"; position:absolute; left:0; color:var(--green); font-weight:800;}
@media(max-width:900px){.facil{grid-template-columns:1fr;}}

/* ============ SEO RICH TEXT BLOCK ============ */
.seo-rich{background:var(--cream); border-top:1px solid var(--line);}
.seo-rich .wrap{max-width:920px;}
.seo-rich h2{font-family:'Fredoka'; font-weight:600; font-size:clamp(24px,3vw,34px); margin-bottom:10px;}
.seo-rich h3{font-family:'Fredoka'; font-weight:600; font-size:19px; color:var(--green-dark); margin:26px 0 8px;}
.seo-rich p{color:var(--muted); font-size:15px; line-height:1.85; margin-bottom:12px;}
.seo-rich p b{color:var(--ink);}
.seo-rich a{color:var(--green); font-weight:700; text-decoration:none;}
.seo-rich a:hover{text-decoration:underline;}
.seo-rich .kw{display:flex; flex-wrap:wrap; gap:9px; margin-top:18px;}
.seo-rich .kw span{background:var(--green-soft); color:var(--green-dark); font-weight:700;
  font-size:12.5px; padding:6px 14px; border-radius:999px;}

/* ============ BLOG ============ */
.blog-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:24px;}
.blog-card{background:#fff; border:1px solid var(--line); border-radius:22px; overflow:hidden;
  box-shadow:0 6px 18px rgba(39,53,44,.05); transition:transform .25s, box-shadow .25s;
  display:flex; flex-direction:column; text-decoration:none;}
.blog-card:hover{transform:translateY(-6px); box-shadow:0 18px 38px rgba(39,53,44,.10);}
.blog-card .bimg{height:170px; display:flex; align-items:center; justify-content:center; font-size:46px;
  background:linear-gradient(135deg,var(--green-soft),var(--sun-soft));}
.blog-card .bbody{padding:24px; display:flex; flex-direction:column; gap:10px; flex:1;}
.blog-card .bcat{align-self:flex-start; background:var(--sun-soft); color:#8a5a00; font-weight:800;
  font-size:11.5px; padding:5px 13px; border-radius:999px;}
.blog-card h3{font-family:'Fredoka'; font-weight:600; font-size:19px; color:var(--ink); line-height:1.3;}
.blog-card p{font-size:14px; color:var(--muted); line-height:1.6; flex:1;}
.blog-card .read{color:var(--green); font-weight:800; font-size:13px;}
/* article */
.article{max-width:780px; margin:0 auto;}
.article .meta{display:flex; gap:12px; flex-wrap:wrap; align-items:center; margin-bottom:24px;
  font-size:13px; color:var(--muted); font-weight:700;}
.article .meta .cat{background:var(--green-soft); color:var(--green-dark); padding:5px 14px; border-radius:999px;}
.article h2{font-family:'Fredoka'; font-weight:600; font-size:clamp(22px,2.8vw,30px); margin:34px 0 12px; color:var(--ink);}
.article h3{font-family:'Fredoka'; font-weight:600; font-size:20px; margin:26px 0 10px; color:var(--green-dark);}
.article p{color:#46403f; font-size:16px; line-height:1.85; margin-bottom:16px;}
.article ul{margin:0 0 18px 0; padding-left:4px; list-style:none;}
.article li{position:relative; padding:7px 0 7px 28px; color:#46403f; font-size:15.5px; line-height:1.6;}
.article li::before{content:"✓"; position:absolute; left:0; color:var(--green); font-weight:800;}
html[dir="rtl"] .article li{padding:7px 28px 7px 0;}
html[dir="rtl"] .article li::before{left:auto;right:0;}
.article .lead{font-size:18px; color:var(--ink); font-weight:600; line-height:1.7;}
.article a{color:var(--green); font-weight:700; text-decoration:none;}
.article a:hover{text-decoration:underline;}
.article .callout{background:var(--green-soft); border-left:4px solid var(--green); border-radius:12px;
  padding:18px 22px; margin:24px 0; font-size:15px; color:var(--green-dark); font-weight:600; line-height:1.7;}
html[dir="rtl"] .article .callout{border-left:0;border-right:4px solid var(--green);}
.article .tldr{background:var(--sun-soft); border-radius:16px; padding:22px 24px; margin:24px 0;}
.article .tldr b{color:#8a5a00; font-family:'Fredoka'; font-weight:600; font-size:16px;}
.article-cta{background:var(--green); border-radius:24px; padding:40px; text-align:center; color:#fff; margin-top:46px;}
.article-cta h3{font-family:'Fredoka'; font-weight:600; font-size:24px; color:#fff;}
.article-cta p{color:#dff0e6; margin:10px 0 22px;}

/* ============ MOBILE NAV / BURGER ============ */
.burger{display:none; background:none; border:1.5px solid var(--line); border-radius:11px;
  width:46px; height:42px; flex-direction:column; align-items:center; justify-content:center;
  gap:5px; cursor:pointer; z-index:60;}
.burger span{display:block; width:20px; height:2px; background:var(--green-dark);
  border-radius:2px; transition:transform .3s, opacity .3s;}
body.nav-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
body.nav-open .burger span:nth-child(2){opacity:0;}
body.nav-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

@media (max-width:960px){
  .topbar{font-size:11.5px; gap:6px 14px; justify-content:center; text-align:center;}
  header{padding:12px 5vw;}
  .logo-text b{font-size:16px;}
  .logo-text small{font-size:9.5px;}
  .site-logo{width:70px; height:70px; flex-basis:70px;}
  .burger{display:flex;}
  nav{position:fixed; top:0; right:0; bottom:auto; width:min(88vw,390px); height:100dvh; min-height:100vh; background:var(--cream); z-index:55;
    flex-direction:column; align-items:stretch; justify-content:flex-start;
    padding:96px 7vw 40px; gap:4px; transform:translateX(110%);
    transition:transform .38s cubic-bezier(.2,.7,.2,1); overflow-y:auto;
    box-shadow:-10px 0 40px rgba(0,0,0,.12);}
  body.nav-open nav{transform:translateX(0);}
  html[dir="rtl"] nav{right:auto; left:0; transform:translateX(-110%); box-shadow:10px 0 40px rgba(0,0,0,.12);}
  html[dir="rtl"] body.nav-open nav{transform:translateX(0);}
  body.nav-open{overflow:hidden;}
  nav a,
  nav a:not(.btn){display:flex; align-items:center; min-height:48px; padding:13px 6px; font-size:17px; line-height:1.4; border-bottom:1px solid var(--line);}
  html[dir="rtl"] nav a,
  html[dir="rtl"] nav a:not(.btn){justify-content:flex-end; text-align:right; line-height:2;}
  nav .lang-switch{display:flex; align-self:stretch; justify-content:center; gap:6px; margin:10px 0 4px; padding:4px;}
  nav .lang-switch a{display:flex; justify-content:center; min-height:36px; padding:6px 12px; border-bottom:0; font-size:13px;}
  nav a.btn{display:block; width:100%; margin-top:18px; text-align:center; padding:16px 28px; font-size:16px; border-bottom:0;}
}
@media (max-width:860px){
  /* tighten generous desktop spacing on phones */
  section{padding:48px 6vw;}
  .hero{padding:40px 6vw 56px;}
  .hero-grid{gap:30px;}
  h1{font-size:clamp(30px,8vw,42px);}
  .trust{gap:16px;}
  .page-hero{padding:44px 6vw 40px;}
	  .form-wrap{padding:26px 20px;}
	  .facil{gap:22px;}
	  .facil:nth-of-type(even){direction:ltr;}
	  .fee-table th, .fee-table td{padding:12px 12px; font-size:13px;}
	  .article p{font-size:15.5px;}
	  footer{padding:46px 6vw 26px;}
	}
	@media (max-width:520px){
	  .topbar span:nth-child(2){display:none;}
	  .stats-grid{grid-template-columns:1fr 1fr;}
	  .hero-ctas .btn, .cta-btns .btn{width:100%; text-align:center;}
	  nav{width:100%;}
	}

/* ============ TYPO3 MIGRATION WRAPPER ============ */
.frame.frame-type-html {
  margin: 0;
  padding: 0;
}

.frame.frame-type-html > *:first-child {
  margin-top: 0;
}

.frame[class*="frame-type-haq-"] {
  margin: 0;
  padding: 0;
}

.field-text {
  white-space: pre-line;
}

.green-soft-band {
  background: var(--green-soft);
  border-radius: 0;
}

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

.form-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}

.form-actions .btn {
  border: none;
  cursor: pointer;
}

.article-note {
  max-width: 780px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 28px;
  box-shadow: 0 6px 18px rgba(39,53,44,.05);
}

.article-note h2 {
  font-family: 'Fredoka';
  font-weight: 600;
  font-size: 24px;
}

.article-note p {
  margin-top: 10px;
  color: var(--muted);
  line-height: 1.75;
}

/* ============ BRANCHES ============ */
.branch-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:22px;}
.bcard{background:#fff; border:1px solid var(--line); border-radius:24px; overflow:hidden;
  box-shadow:0 6px 18px rgba(39,53,44,.05); transition:transform .25s, box-shadow .25s;
  display:flex; flex-direction:column;}
.bcard:hover{transform:translateY(-6px); box-shadow:0 18px 38px rgba(39,53,44,.10);}
.bphoto{height:180px; position:relative; display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:6px; color:var(--muted); font-weight:700; font-size:13px;
  background:linear-gradient(135deg,var(--green-soft),var(--sun-soft));
  border-bottom:1px solid var(--line);}
.bphoto .em{font-size:42px;}
.bphoto img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover;}
.bbody{padding:24px; display:flex; flex-direction:column; gap:10px; flex:1;}
.bbadge{align-self:flex-start; font-size:11.5px; font-weight:800; letter-spacing:.05em;
  padding:5px 14px; border-radius:999px; text-transform:uppercase;}
.bb-here{background:var(--green); color:#fff;}
.bb-first{background:var(--sun-soft); color:#8a5a00;}
.bb-fam{background:var(--green-soft); color:var(--green-dark);}
.bbody h3{font-family:'Fredoka'; font-weight:600; font-size:20px;}
.bbody .loc{font-size:14px; color:var(--muted); font-weight:700;}
.bbody p{font-size:14px; color:var(--muted); line-height:1.65; flex:1;}
