/* ============================================================
   APTTI — style.css v4 FINAL
   Clean build. No patch layers. Mobile-first.
   ============================================================ */

/* ── Variables ── */
:root{
  --amber:#D4960F;--amber-light:#F2B825;--amber-pale:#FEF6DC;
  --amber-mid:#FAE49A;--amber-dark:#A87209;
  --blue:#1B3A6B;--blue-mid:#2A5298;--blue-pale:#E8EFFE;
  --navy:#0F2240;--slate:#4B5A6E;--muted:#768090;
  --border:#DDE3EC;--bg:#F5F7FB;--bg2:#EEF2F9;--white:#FFFFFF;
  --green:#0D6E4F;--green-pale:#E3F4EE;--red:#C0392B;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --r:10px;--rlg:16px;
  --shadow:0 2px 8px rgba(27,58,107,.08),0 8px 24px rgba(27,58,107,.06);
  --shadow-lg:0 8px 40px rgba(27,58,107,.14);
  --t:.18s ease;--container:1240px;--header-h:70px;
  /* aliases for old templates */
  --gold:var(--amber);--gold-light:var(--amber-light);--gold-pale:var(--amber-pale);
  --radius:var(--r);--radius-lg:var(--rlg);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;
     overflow-x:hidden;max-width:100vw}
body{font-family:var(--font);font-size:16px;line-height:1.65;color:var(--navy);
     background:var(--white);-webkit-font-smoothing:antialiased;
     overflow-x:hidden;max-width:100vw;width:100%}
img{max-width:100%;height:auto;display:block}
svg{max-width:100%;display:block}
table{max-width:100%}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:1rem}
p{color:var(--slate);line-height:1.7;overflow-wrap:break-word;word-break:break-word}
h1,h2,h3,h4,h5{overflow-wrap:break-word;word-break:break-word}

/* ── Typography ── */
h1{font-size:clamp(1.75rem,4vw,2.875rem);font-weight:800;line-height:1.18;letter-spacing:-.025em}
h2{font-size:clamp(1.25rem,3vw,2.125rem);font-weight:700;line-height:1.22;letter-spacing:-.018em}
h3{font-size:1.125rem;font-weight:700;line-height:1.3}
h4{font-size:.9375rem;font-weight:700}

/* ── Layout ── */
.container{max-width:var(--container);margin:0 auto;padding:0 24px;width:100%;box-sizing:border-box}
.section{padding:72px 0}.section-sm{padding:44px 0}.section-lg{padding:104px 0}
.bg-light{background:var(--bg)}.text-center{text-align:center}
.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}.mb-40{margin-bottom:40px}
.mb-48{margin-bottom:48px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.mt-32{margin-top:32px}.mt-48{margin-top:48px}
.subtitle{font-size:1.0625rem;color:var(--slate);max-width:620px;margin-top:8px;
          overflow-wrap:break-word;word-break:break-word}
.text-center .subtitle{margin-left:auto;margin-right:auto}

/* ── Grid system (named classes) ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.layout-sidebar{display:grid;grid-template-columns:1fr 360px;gap:40px;align-items:start}
.layout-sidebar-lg{display:grid;grid-template-columns:1fr 420px;gap:48px;align-items:start}
.layout-2col{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.layout-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.layout-icon-text{display:grid;grid-template-columns:56px 1fr;gap:20px;align-items:start}
.layout-icon-text-sm{display:grid;grid-template-columns:36px 1fr;gap:14px;align-items:start}
.layout-accred{display:grid;grid-template-columns:200px 1fr;gap:32px;align-items:start}
.partners-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}

/* ── Tags ── */
.tag{display:inline-flex;align-items:center;font-size:.7rem;font-weight:700;
     letter-spacing:.1em;text-transform:uppercase;background:var(--amber-pale);
     color:var(--amber-dark);padding:5px 14px;border-radius:20px;margin-bottom:12px;
     border:1px solid var(--amber-mid)}
.tag-blue{background:var(--blue-pale);color:var(--blue-mid);border-color:#C4D3F0}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;border-radius:8px;
     font-size:.9375rem;font-weight:600;transition:all var(--t);
     border:2px solid transparent;text-align:center;justify-content:center;
     white-space:normal;word-break:break-word;min-width:0}
.btn-amber{background:var(--amber);color:var(--white);box-shadow:0 2px 10px rgba(212,150,15,.3)}
.btn-amber:hover{background:var(--amber-light);transform:translateY(-1px)}
.btn-blue{background:var(--blue);color:var(--white)}
.btn-blue:hover{background:var(--blue-mid);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--blue);border-color:var(--border)}
.btn-outline:hover{border-color:var(--blue);background:var(--blue-pale)}
.btn-white{background:var(--white);color:var(--blue);font-weight:700;
           box-shadow:0 2px 12px rgba(0,0,0,.12)}
.btn-white:hover{transform:translateY(-1px)}
.btn-sm{padding:8px 18px;font-size:.875rem}
.btn-lg{padding:15px 34px;font-size:1.0625rem}

/* ── Image containers — ALL use overflow:hidden + aspect-ratio ── */
/* Never put width/height HTML attributes on img tags */
.hero-img-wrap{width:100%;aspect-ratio:5/3;overflow:hidden;border-radius:var(--rlg);
               box-shadow:0 20px 60px rgba(0,0,0,.3)}
.img-hero{width:100%;aspect-ratio:5/3;overflow:hidden;border-radius:var(--rlg)}
.img-4-3{width:100%;aspect-ratio:4/3;overflow:hidden;border-radius:var(--r)}
.img-16-9{width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:var(--r)}
.img-1-1{width:100%;aspect-ratio:1;overflow:hidden;border-radius:var(--r)}
.banner-img{width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:var(--r);margin-bottom:24px}
.cert-img{width:100%;aspect-ratio:1.414/1;overflow:hidden;border-radius:var(--r)}
.hero-img-wrap img,.img-hero img,.img-4-3 img,.img-16-9 img,
.banner-img img,.img-1-1 img,.cert-img img{
  width:100%;height:100%;object-fit:cover;display:block}
.cert-img img{object-fit:contain;background:var(--white)}
.round-photo{width:72px;height:72px;border-radius:50%;overflow:hidden;
             border:3px solid var(--amber-light);flex-shrink:0}
.round-photo img{width:100%;height:100%;object-fit:cover;display:block}
.accred-logo{width:120px;height:120px;overflow:hidden;display:flex;align-items:center;
             justify-content:center;background:var(--white);border-radius:var(--r);
             border:1px solid var(--border)}
.accred-logo img{max-width:100%;max-height:100%;object-fit:contain}
.team-photo{width:100%;aspect-ratio:3/4;overflow:hidden;border-radius:var(--r) var(--r) 0 0}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:center top}
/* Placeholder image boxes */
.ph{background:linear-gradient(135deg,var(--bg),var(--bg2));border:2px dashed var(--border);
    border-radius:var(--r);display:flex;flex-direction:column;align-items:center;
    justify-content:center;gap:6px;color:var(--muted);text-align:center;padding:24px;
    min-height:80px}
.ph-label{font-weight:600;color:var(--slate);font-size:.8125rem}
.ph-file{font-size:.68rem;font-family:monospace;background:var(--bg2);
         padding:2px 7px;border-radius:4px}
.ph-16-9{aspect-ratio:16/9}.ph-4-3{aspect-ratio:4/3}.ph-1-1{aspect-ratio:1}
.ph-cert{aspect-ratio:1.414/1}.ph-hero{aspect-ratio:5/3;width:100%}

/* ── Top bar ── */
#topbar{background:var(--navy);color:rgba(255,255,255,.8);font-size:.78rem;padding:7px 0;
        overflow:hidden}
#topbar .container{display:flex;align-items:center;justify-content:space-between;
                   gap:8px}
.tb-left,.tb-right{display:flex;align-items:center;gap:14px;white-space:nowrap;flex-shrink:0}
.tb-left a,.tb-right a{color:rgba(255,255,255,.7);transition:color var(--t)}
.tb-left a:hover,.tb-right a:hover{color:var(--amber-light)}
.tb-div{width:1px;height:12px;background:rgba(255,255,255,.2);flex-shrink:0}

/* ── Header ── */
#site-header{position:sticky;top:0;z-index:1000;background:var(--white);
             border-bottom:2px solid var(--amber-mid);transition:box-shadow var(--t),padding .25s;
             padding:9px 0}
#site-header.scrolled{box-shadow:0 2px 20px rgba(27,58,107,.1);padding:4px 0}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.logo-wrap{flex-shrink:0;display:flex;align-items:center}
.site-logo{height:56px;width:auto;display:block;flex-shrink:0;
           transition:height .25s ease;max-width:calc(100vw - 80px)}
#site-header.scrolled .site-logo{height:42px}
.hdr-cta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.hdr-phone{font-size:.8125rem;font-weight:700;color:var(--blue);white-space:nowrap}

/* ── Desktop nav ── */
.main-nav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}
.nav-item{position:relative}
.nav-lnk,.nav-btn{display:inline-flex;align-items:center;gap:4px;padding:7px 11px;
                  border-radius:7px;font-size:.84rem;font-weight:600;color:var(--navy);
                  transition:background var(--t),color var(--t);white-space:nowrap;
                  background:none;border:none;cursor:pointer}
.nav-lnk:hover,.nav-lnk.active,.nav-btn:hover{background:var(--blue-pale);color:var(--blue-mid)}
.nav-caret{width:12px;height:12px;flex-shrink:0;transition:transform .2s}
.nav-item.open>.nav-btn .nav-caret{transform:rotate(180deg)}
.nav-item.open>.nav-btn{background:var(--blue-pale);color:var(--blue-mid)}

/* ── Dropdown ── */
.dropdown{position:absolute;top:100%;left:0;display:none;min-width:520px;
          background:var(--white);border:1.5px solid var(--border);
          border-top:3px solid var(--amber);border-radius:0 0 var(--rlg) var(--rlg);
          box-shadow:var(--shadow-lg);padding:8px;z-index:9999}
.nav-item.open>.dropdown{display:grid;grid-template-columns:1fr 1fr;gap:0}
.dropdown.single{min-width:220px;grid-template-columns:1fr!important}
.dd-group{padding:8px}
.dd-label{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;
          color:var(--muted);padding:6px 10px 4px}
.dd-divider{height:1px;background:var(--border);margin:4px 0}
.dropdown a{display:block;padding:8px 12px;border-radius:6px;font-size:.8375rem;
            font-weight:500;color:var(--slate);transition:background var(--t),color var(--t)}
.dropdown a:hover{background:var(--amber-pale);color:var(--amber-dark)}
.dropdown a.dd-feature{font-weight:700;color:var(--blue);border-top:1px solid var(--border);margin-top:4px}
.dd-level-badge{font-size:.68rem;font-weight:700;background:var(--amber-pale);
                color:var(--amber-dark);padding:2px 7px;border-radius:10px}

/* ── Hamburger ── */
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;flex-shrink:0}
.hamburger span{display:block;width:22px;height:2.5px;background:var(--navy);
                border-radius:2px;transition:all .25s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ── Mobile nav ── */
.mobile-nav{position:fixed;top:0;left:0;width:100%;height:100%;
            z-index:9999;background:var(--white);overflow-y:auto;
            transform:translateX(-100%);transition:transform .3s ease;
            box-shadow:4px 0 40px rgba(0,0,0,.2)}
.mobile-nav.open{transform:translateX(0)}
.mob-overlay{display:none;position:fixed;inset:0;z-index:9998;background:rgba(15,34,64,.5)}
.mob-overlay.open{display:block}
.mob-inner{padding:calc(var(--header-h) + 8px) 0 100px;max-width:480px}
.mob-lnk{display:block;padding:13px 20px;font-size:.9375rem;font-weight:600;
         color:var(--navy);border-bottom:1px solid var(--border)}
.mob-lnk:hover{background:var(--amber-pale);color:var(--amber-dark)}
.mob-acc-btn{width:100%;display:flex;align-items:center;justify-content:space-between;
             padding:13px 20px;font-size:.9375rem;font-weight:600;color:var(--navy);
             border-bottom:1px solid var(--border);background:none;
             border-left:none;border-right:none;border-top:none;cursor:pointer}
.mob-acc-btn:hover,.mob-acc-btn.open{background:var(--amber-pale);color:var(--amber-dark)}
.mob-caret{width:14px;height:14px;transition:transform .2s;color:var(--muted)}
.mob-acc-btn.open .mob-caret{transform:rotate(180deg)}
.mob-panel{display:none;background:var(--bg)}
.mob-panel.open{display:block}
.mob-panel a{display:block;padding:10px 20px 10px 32px;font-size:.875rem;color:var(--slate);
             border-bottom:1px solid var(--border)}
.mob-panel a:hover{background:var(--amber-pale);color:var(--amber-dark)}
.mob-sub-label{font-size:.68rem;font-weight:800;text-transform:uppercase;
               letter-spacing:.1em;color:var(--muted);padding:10px 20px 4px 32px}
.mob-footer{padding:16px 20px;display:flex;flex-direction:column;gap:10px;
            border-top:2px solid var(--amber-mid)}

/* ── Hero ── */
.hero{background:linear-gradient(130deg,var(--navy) 0%,var(--blue) 55%,var(--blue-mid) 100%);
      color:var(--white);padding:88px 0 72px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1fr 460px;gap:44px;align-items:start}
.hero h1{color:var(--white);margin-bottom:18px}
.hero h1 em{color:var(--amber-light);font-style:normal}
.hero-sub{font-size:1.0625rem;color:rgba(255,255,255,.8);max-width:500px;margin-bottom:32px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.hero-stats{display:flex;gap:32px;margin-top:40px;padding-top:32px;
            border-top:1px solid rgba(255,255,255,.15);flex-wrap:wrap}
.hs-num{font-size:1.875rem;font-weight:800;color:var(--amber-light)}
.hs-lbl{font-size:.78rem;color:rgba(255,255,255,.65);margin-top:2px}

/* ── Trust bar ── */
.trust-bar{background:var(--blue-pale);border-bottom:1px solid #C4D3F0;padding:14px 0}
.trust-bar-inner{display:flex;align-items:stretch;overflow-x:auto;
                 -webkit-overflow-scrolling:touch;scrollbar-width:none}
.trust-bar-inner::-webkit-scrollbar{display:none}
.ti{display:flex;align-items:center;gap:10px;padding:8px 24px;flex-shrink:0;
    border-right:1px solid #C4D3F0}
.ti:last-child{border-right:none}
.ti-check{width:30px;height:30px;background:var(--blue);border-radius:7px;
          display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ti-check svg{width:14px;height:14px;color:var(--white)}
.ti strong{display:block;font-size:.8125rem;font-weight:700;color:var(--blue);white-space:nowrap}
.ti span{font-size:.72rem;color:var(--slate);white-space:nowrap}

/* ── Cards ── */
.card{background:var(--white);border-radius:var(--rlg);border:1.5px solid var(--border);
      overflow:hidden;transition:box-shadow var(--t),transform var(--t),border-color var(--t)}
.card:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:var(--amber)}
/* Card containing a table must not clip scroll */
.card.has-table{overflow:visible}
.course-card{display:flex;flex-direction:column}
.course-card-img{width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--bg2)}
.course-card-img img{width:100%;height:100%;object-fit:cover}
.course-card-body{padding:20px;flex:1}
.course-card-body h3{font-size:1rem;margin-bottom:6px}
.course-card-body p{font-size:.8375rem;margin-bottom:10px}
.level-links{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}
.level-link{font-size:.72rem;font-weight:700;padding:4px 10px;border-radius:20px;
            background:var(--amber-pale);color:var(--amber-dark);border:1px solid var(--amber-mid)}
.level-link:hover,.level-link.active{background:var(--amber);color:var(--white)}
.course-card-footer{padding:13px 20px;border-top:1px solid var(--border);background:var(--bg);
                    display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.c-price{font-weight:700;font-size:.9375rem;color:var(--blue)}
.c-link{font-size:.8125rem;font-weight:700;color:var(--amber-dark)}

/* ── Why grid ── */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;
          background:var(--border);border-radius:var(--rlg);overflow:hidden;
          border:1.5px solid var(--border)}
.why-item{background:var(--white);padding:26px 20px}
.why-num{font-size:2.25rem;font-weight:900;color:var(--border);line-height:1;margin-bottom:8px}
.why-item h4{font-size:.875rem;font-weight:700;margin-bottom:5px}
.why-item p{font-size:.8rem}

/* ── Stats ── */
.stats-band{background:linear-gradient(135deg,var(--blue),var(--navy));color:var(--white)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-cell{padding:44px 24px;text-align:center;border-right:1px solid rgba(255,255,255,.1)}
.stat-cell:last-child{border-right:none}
.stat-n{font-size:2.25rem;font-weight:800;color:var(--amber-light)}
.stat-l{font-size:.8rem;color:rgba(255,255,255,.6);margin-top:4px}

/* ── CTA bands ── */
.cta-band{background:linear-gradient(135deg,var(--amber),var(--amber-light));
          color:var(--white);padding:64px 0;text-align:center}
.cta-band h2{color:var(--white);margin-bottom:10px}
.cta-band p{color:rgba(255,255,255,.9);font-size:1.0625rem;margin-bottom:28px}
.cta-band-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-banner{background:linear-gradient(135deg,var(--blue),var(--navy));
            color:var(--white);padding:64px 0;text-align:center}
.cta-banner h2{color:var(--white);margin-bottom:10px}
.cta-banner p{color:rgba(255,255,255,.8);font-size:1.0625rem;margin-bottom:28px}

/* ── Page hero ── */
.page-hero{background:linear-gradient(130deg,var(--navy),var(--blue));
           padding:52px 0;color:var(--white)}
.page-hero h1{color:var(--white);font-size:clamp(1.5rem,3.5vw,2.25rem);margin-bottom:10px;
              overflow-wrap:break-word;word-break:break-word}
.page-hero .subtitle{color:rgba(255,255,255,.75);overflow-wrap:break-word}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.78rem;
            color:rgba(255,255,255,.5);margin-bottom:12px;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.65)}
.breadcrumb a:hover{color:var(--amber-light)}
.bc-sep{font-size:.6rem;color:rgba(255,255,255,.3)}

/* ── Course detail layout (sidebar + main) ── */
.cd-layout{display:grid;grid-template-columns:1fr 360px;gap:40px;align-items:start}
.cd-sidebar{position:sticky;top:calc(var(--header-h)+14px);
            min-width:0;width:100%;max-width:100%;overflow:hidden;box-sizing:border-box}

/* ── Sidebar boxes ── */
.sb-box{background:var(--white);border-radius:var(--rlg);border:1.5px solid var(--border);
        overflow:hidden;box-shadow:var(--shadow);margin-bottom:18px;
        min-width:0;width:100%;max-width:100%;box-sizing:border-box}
.sb-head{background:var(--blue);padding:18px 22px;color:var(--white)}
.sb-head h3{color:var(--white);font-size:1rem;margin-bottom:3px;
            overflow-wrap:break-word;word-break:break-word}
.sb-head p{font-size:.78rem;color:rgba(255,255,255,.65)}
.sb-body{padding:18px;min-width:0;overflow-y:visible;overflow-x:hidden;width:100%;max-width:100%;box-sizing:border-box}
.sb-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;
        padding-bottom:14px;border-bottom:1px solid var(--border);min-width:0}
.sb-row:last-of-type{border-bottom:none}
.sb-row-label{font-size:.67rem;font-weight:800;text-transform:uppercase;
              letter-spacing:.08em;color:var(--muted)}
.sb-row ul{display:flex;flex-direction:column;gap:4px}
.sb-row li{font-size:.875rem;color:var(--slate);overflow-wrap:break-word}
.sb-btns{display:flex;flex-direction:column;gap:7px;margin-top:4px;
         width:100%;max-width:100%;box-sizing:border-box}
/* ALL buttons inside sidebar: block-level, fill width, wrap text */
.sb-body a.btn,
.sb-body button.btn,
.sb-btns a.btn,
.sb-btns button.btn,
.sb-row a.btn{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box !important;
  white-space:normal !important;
  text-align:center !important;
  overflow-wrap:break-word;
  word-break:break-word;
  padding:11px 14px;
  font-size:.8125rem;
}

/* ── Price table (sidebar) ── */
.price-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%;
                  margin:10px 0 14px}
.price-table{width:100%;border-collapse:collapse;font-size:.72rem;white-space:nowrap}
.price-table th{background:var(--navy);color:var(--white);padding:5px 7px;
                font-size:.6rem;font-weight:700;text-align:center;letter-spacing:.02em}
.price-table td{padding:6px 7px;border-bottom:1px solid var(--border);text-align:center}
.price-table tr:last-child td{border-bottom:none}
.price-table .pv{font-size:.8125rem;font-weight:800;color:var(--blue);display:block}
.price-table .pc{font-size:.6rem;color:var(--muted);display:block;margin-top:1px}

/* ── Level buttons sidebar ── */
.sidebar-level-btn{display:flex;flex-direction:column;align-items:flex-start;
                   padding:9px 13px;border-radius:8px;border:1.5px solid var(--border);
                   background:var(--white);font-size:.8125rem;font-weight:600;color:var(--slate);
                   transition:all var(--t);text-decoration:none;margin-bottom:5px;
                   width:100%;box-sizing:border-box;min-width:0;overflow:hidden;gap:2px}
.sidebar-level-btn:hover{border-color:var(--amber);background:var(--amber-pale);color:var(--amber-dark)}
.sidebar-level-btn.active{border-color:var(--amber);background:var(--amber);
                          color:var(--white);font-weight:700}
.slb-price{font-size:.72rem;opacity:.8;white-space:nowrap;font-weight:500}
.slb-name{overflow-wrap:break-word;word-break:break-word;white-space:normal;
          font-size:.8125rem;font-weight:600;line-height:1.3}

/* ── FAQ ── */
.faq-item{border:1px solid var(--border);border-radius:var(--r);margin-bottom:5px;overflow:hidden}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;
       padding:10px 13px;background:var(--white);font-weight:600;font-size:.85rem;
       color:var(--navy);cursor:pointer;transition:background var(--t);
       border:none;text-align:left;gap:10px;line-height:1.4;overflow-wrap:break-word}
.faq-q:hover{background:var(--amber-pale)}
.faq-ic{width:18px;height:18px;border-radius:50%;background:var(--bg);display:flex;
        align-items:center;justify-content:center;font-size:.7rem;flex-shrink:0;
        transition:all var(--t);font-weight:700}
.faq-item.open .faq-q{background:var(--amber-pale);color:var(--amber-dark)}
.faq-item.open .faq-ic{background:var(--amber);color:var(--white);transform:rotate(45deg)}
.faq-a{padding:0 13px 11px;font-size:.825rem;color:var(--slate);display:none;line-height:1.65;
       overflow-wrap:break-word;word-break:break-word}
.faq-item.open .faq-a{display:block}

/* ── Curriculum ── */
.cur-item{border:1px solid var(--border);border-radius:6px;
           margin-bottom:3px;overflow:hidden}
.cur-btn{width:100%;display:flex;align-items:center;justify-content:space-between;
         padding:8px 11px;background:var(--bg);font-weight:600;font-size:.78rem;
         cursor:pointer;transition:background var(--t);border:none;text-align:left;
         gap:8px;line-height:1.3;min-width:0;box-sizing:border-box}
.cur-btn strong{font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;
                color:var(--amber-dark);white-space:nowrap;flex-shrink:0;
                background:var(--amber-pale);padding:2px 6px;border-radius:4px}
.cur-btn span.cur-title{flex:1;overflow:hidden;text-overflow:ellipsis;
                         white-space:nowrap;min-width:0;color:var(--navy);font-size:.78rem}
.cur-btn:hover{background:var(--amber-pale)}
.cur-ic{width:16px;height:16px;border-radius:50%;background:var(--border);
        display:flex;align-items:center;justify-content:center;
        font-size:.65rem;font-weight:700;color:var(--slate);
        flex-shrink:0;transition:all var(--t)}
.cur-item.open .cur-btn{background:var(--amber-pale)}
.cur-item.open .cur-ic{background:var(--amber);color:var(--white);transform:rotate(45deg)}
.cur-panel{padding:6px 11px 9px;border-top:1px solid var(--border);display:none;
           background:var(--white)}
.cur-panel.open{display:block}
.cur-panel ul{display:flex;flex-direction:column;gap:1px}
.cur-panel li{font-size:.775rem;color:var(--slate);padding:4px 0;
              display:flex;gap:6px;align-items:flex-start;
              overflow-wrap:break-word;word-break:break-word;
              border-bottom:1px solid var(--bg2)}
.cur-panel li:last-child{border-bottom:none}
.cur-panel li::before{content:"›";color:var(--amber-dark);font-weight:700;
                       flex-shrink:0;font-size:.875rem;line-height:1.5}

/* ── Data tables — ALWAYS in a scroll wrapper ── */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;
          width:100%;max-width:100%;display:block}
.data-table{width:100%;border-collapse:collapse;font-size:.8rem}
.data-table th{background:var(--bg);font-weight:700;font-size:.65rem;
               text-transform:uppercase;letter-spacing:.04em;color:var(--slate);
               padding:6px 10px;border-bottom:1px solid var(--border);
               white-space:nowrap}
.data-table td{padding:6px 10px;border-bottom:1px solid var(--border);
               font-size:.8rem;white-space:nowrap}
.data-table tr:hover td{background:var(--amber-pale)}
.data-table tr:last-child td{border-bottom:none}
.data-table td:last-child{white-space:normal;word-break:break-word}

/* ── Forms ── */
.form-group{margin-bottom:13px}
.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--navy);margin-bottom:4px}
.form-control{width:100%;padding:10px 13px;border-radius:7px;
              border:1.5px solid var(--border);background:var(--white);
              font-size:.9375rem;color:var(--navy);transition:border-color var(--t)}
.form-control:focus{outline:none;border-color:var(--amber);
                    box-shadow:0 0 0 3px rgba(212,150,15,.12)}
textarea.form-control{resize:vertical;min-height:80px}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field-err{display:block;font-size:.75rem;color:var(--red);margin-top:4px;font-weight:600}

/* ── Notices ── */
.notice{display:block!important;padding:12px 16px;border-radius:8px;font-size:.875rem;line-height:1.7;overflow-wrap:break-word;word-break:break-word}
.notice strong{font-weight:700;white-space:normal}
.notice-amber{background:var(--amber-pale);border-left:4px solid var(--amber);color:var(--navy)}
.notice-blue{background:var(--blue-pale);border-left:4px solid var(--blue-mid);color:var(--blue)}

/* ── List check ── */
.list-check{display:flex;flex-direction:column;gap:8px}
.list-check li{display:flex;align-items:flex-start;gap:10px;font-size:.9375rem;
               color:var(--slate);overflow-wrap:break-word;word-break:break-word}
.list-check li::before{content:"✓";color:var(--green);font-weight:700;flex-shrink:0;margin-top:1px}

/* ── City grid ── */
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:6px}
.city-lnk{display:block;padding:8px 12px;border-radius:7px;border:1.5px solid var(--border);
          background:var(--white);font-size:.8125rem;color:var(--slate);
          transition:all var(--t);font-weight:500;text-align:center;
          overflow-wrap:break-word;word-break:break-word}
.city-lnk:hover{border-color:var(--amber);color:var(--amber-dark);background:var(--amber-pale)}

/* ── Testimonials ── */
.testi-card{background:var(--white);border-radius:var(--rlg);border:1.5px solid var(--border);
            padding:24px;display:flex;flex-direction:column;gap:14px;
            overflow-wrap:break-word;word-break:break-word}
.testi-stars{color:var(--amber-light);letter-spacing:2px}
.testi-text{font-size:.8875rem;color:var(--slate);font-style:italic;line-height:1.75;flex:1;
            overflow-wrap:break-word;word-break:break-word}
.testi-author{display:flex;align-items:center;gap:12px;padding-top:12px;
              border-top:1px solid var(--border)}
.testi-avatar{width:36px;height:36px;border-radius:50%;background:var(--blue);
              color:var(--white);display:flex;align-items:center;justify-content:center;
              font-weight:700;font-size:.75rem;flex-shrink:0}
.testi-name{font-weight:700;font-size:.875rem;overflow-wrap:break-word}
.testi-role{font-size:.72rem;color:var(--muted);overflow-wrap:break-word}

/* ── Misc ── */
.divider{border:none;border-top:1px solid var(--border);margin:28px 0}
.rating-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.r-stars{color:var(--amber-light);letter-spacing:1px}
.r-num{font-weight:800;font-size:1rem}
.r-count{font-size:.8rem;color:var(--muted)}
.amber-band{background:var(--amber-pale);border-top:2px solid var(--amber-mid);
            border-bottom:2px solid var(--amber-mid);padding:40px 0}

/* ── Footer ── */
#site-footer{background:var(--navy);color:rgba(255,255,255,.7)}
.footer-top{padding:60px 0 40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.footer-brand p{font-size:.8rem;line-height:1.7;margin:12px 0 16px;overflow-wrap:break-word}
.footer-col h5{color:var(--white);font-size:.78rem;font-weight:700;margin-bottom:12px;
               letter-spacing:.05em;text-transform:uppercase;padding-bottom:7px;
               border-bottom:1px solid rgba(255,255,255,.1)}
.footer-links{display:flex;flex-direction:column;gap:6px}
.footer-links a{font-size:.78rem;color:rgba(255,255,255,.55);transition:color var(--t)}
.footer-links a:hover{color:var(--amber-light)}
.footer-contact a{font-size:.78rem;color:rgba(255,255,255,.6);display:block;
                  margin-bottom:5px;overflow-wrap:break-word}
.social-row{display:flex;gap:7px;margin-top:7px;flex-wrap:wrap}
.soc-btn{width:32px;height:32px;border-radius:7px;background:rgba(255,255,255,.08);
         display:flex;align-items:center;justify-content:center;font-size:.72rem;
         font-weight:700;color:rgba(255,255,255,.6);transition:all var(--t)}
.soc-btn:hover{background:var(--amber);color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:18px 0;
               display:flex;align-items:center;justify-content:space-between;
               flex-wrap:wrap;gap:10px;font-size:.75rem}
.footer-bottom-links{display:flex;gap:16px;flex-wrap:wrap}
.footer-bottom-links a{color:rgba(255,255,255,.4)}
.footer-bottom-links a:hover{color:var(--amber-light)}
.accred-strip{background:var(--bg);border-top:1px solid var(--border);padding:18px 0}
.accred-inner{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}
.accred-badge{background:var(--white);border:1px solid var(--border);border-radius:7px;
              padding:7px 16px;font-size:.7rem;font-weight:700;color:var(--slate)}
.accred-strip-row{display:flex;align-items:center;overflow-x:auto;
                  -webkit-overflow-scrolling:touch;gap:0;flex-wrap:nowrap;
                  scrollbar-width:none}
.accred-strip-row::-webkit-scrollbar{display:none}

/* ── WhatsApp float (desktop only) ── */
.float-wa{position:fixed;bottom:22px;right:22px;width:52px;height:52px;border-radius:50%;
          background:#25D366;color:var(--white);display:flex;align-items:center;
          justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.45);z-index:900;
          transition:transform var(--t)}
.float-wa:hover{transform:scale(1.1)}
.float-wa svg{width:26px;height:26px}

/* ── Mobile bottom bar ── */
.mob-bottom-bar{display:none}
.mob-enquiry-overlay{display:none;position:fixed;inset:0;z-index:10000;
                     background:rgba(15,34,64,.65);backdrop-filter:blur(4px);
                     align-items:flex-end;justify-content:center}
.mob-enquiry-overlay.open{display:flex !important}
.mob-enquiry-modal{background:#ffffff;border-radius:20px 20px 0 0;width:100%;
                   max-width:520px;max-height:90vh;overflow-y:auto;
                   -webkit-overflow-scrolling:touch;transform:translateY(100%);
                   transition:transform .35s cubic-bezier(.32,.72,0,1)}
.mob-enquiry-overlay.open .mob-enquiry-modal{transform:translateY(0) !important}
.mob-modal-head{background:#1B3A6B;padding:20px 24px;display:flex;align-items:center;
                justify-content:space-between;position:sticky;top:0;z-index:2;
                border-radius:20px 20px 0 0}
.mob-modal-head h3{color:#ffffff;font-size:1.0625rem;font-weight:800;margin:0}
.mob-modal-head p{color:rgba(255,255,255,.72);font-size:.8125rem;margin:3px 0 0}
.mob-modal-close{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.18);
                 color:#ffffff;font-size:1.375rem;line-height:1;display:flex;
                 align-items:center;justify-content:center;border:none;cursor:pointer;
                 flex-shrink:0;font-family:inherit}
.mob-modal-body{padding:24px}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — three clean breakpoints, no patches
   ═══════════════════════════════════════════════════════ */

/* ── 1100px: large tablet ── */
@media(max-width:1100px){
  .container{padding:0 20px}
  .grid-4,.why-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .cd-layout{grid-template-columns:1fr 300px;gap:24px}
  .cd-sidebar{top:calc(var(--header-h)+10px)}
  .layout-sidebar{grid-template-columns:1fr 300px;gap:24px}
  .layout-sidebar-lg{grid-template-columns:1fr 320px;gap:28px}
  .hero-grid{grid-template-columns:1fr 380px;gap:32px}
  .partners-grid{grid-template-columns:repeat(4,1fr)}
}

/* ── 900px: mobile nav, single column ── */
@media(max-width:900px){
  :root{--header-h:65px}
  .container{padding:0 16px}

  /* Header */
  .main-nav,.hdr-cta>.btn-amber,.hdr-phone{display:none !important}
  .hamburger{display:flex}
  .site-logo{height:52px !important}
  #site-header.scrolled .site-logo{height:40px !important}

  /* Topbar: scroll don't wrap */
  #topbar .container{overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none;gap:10px;padding:0 14px}
  #topbar .container::-webkit-scrollbar{display:none}

  /* Float WA hidden — bottom bar handles it */
  .float-wa{display:none !important}

  /* Mobile bottom bar */
  body{padding-bottom:68px}
  .mob-bottom-bar{
    display:flex !important;
    position:fixed !important;
    bottom:0 !important;left:0 !important;right:0 !important;
    z-index:9990 !important;
    height:64px !important;
    background:#ffffff !important;
    border-top:1px solid #e2e8f0 !important;
    box-shadow:0 -4px 24px rgba(27,58,107,.14) !important;
  }
  .mob-bar-btn{
    flex:1;display:flex !important;flex-direction:column;
    align-items:center;justify-content:center;
    gap:0;padding:8px 4px 6px;color:#4B5A6E;
    border:none;background:none;cursor:pointer;
    text-decoration:none;-webkit-tap-highlight-color:transparent;
  }
  .mob-bar-btn:active{opacity:.7}
  .mob-bar-btn.enquire{flex:1.4}

  /* Hero */
  .hero{padding:52px 0 44px}
  .hero-grid{grid-template-columns:1fr}
  .hero-grid>div:last-child{display:none}

  /* Grids */
  .grid-2,.grid-3,.layout-2col,.layout-3col{grid-template-columns:1fr}
  .grid-4,.why-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .form-2col{grid-template-columns:1fr}
  .layout-sidebar,.layout-sidebar-lg,.layout-accred{grid-template-columns:1fr}
  .partners-grid{grid-template-columns:1fr 1fr !important}

  /* Sidebar: stack with enroll box on top */
  .cd-layout{display:flex !important;flex-direction:column !important;gap:0}
  .cd-layout>div{order:2 !important;margin-top:20px}
  .cd-sidebar{order:1 !important;position:static !important;
              width:100% !important;margin-top:0 !important;top:auto !important}
  .cd-sidebar .sb-box{display:none !important}
  .cd-sidebar .sb-box:first-child{display:block !important}

  /* Inline grids (exact PHP values, no spaces) */
  [style*="grid-template-columns:1fr 360px"],
  [style*="grid-template-columns:1fr 380px"],
  [style*="grid-template-columns:1fr 400px"],
  [style*="grid-template-columns:1fr 420px"],
  [style*="grid-template-columns:1fr 440px"],
  [style*="grid-template-columns:1fr 1fr 1fr"],
  [style*="grid-template-columns:repeat(3,1fr)"],
  [style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr !important}
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns:repeat(2,1fr)"],
  [style*="grid-template-columns:repeat(auto-fill,minmax(220px,1fr))"],
  [style*="grid-template-columns:repeat(auto-fill,minmax(200px,1fr))"]{
    grid-template-columns:1fr 1fr !important}
}

/* ── 600px: mobile ── */
@media(max-width:600px){
  .container{padding:0 14px}
  .section{padding:44px 0}
  .page-hero{padding:32px 0}
  .page-hero h1{font-size:clamp(1.25rem,5.5vw,1.625rem)}

  /* Topbar: hide email/WA links, show phones only */
  .tb-right{display:none}

  /* Grids: mostly single col */
  .grid-4,.why-grid{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr !important}
  .grid-auto{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr !important}
  .layout-icon-text{grid-template-columns:40px 1fr;gap:14px}
  .layout-icon-text-sm{grid-template-columns:30px 1fr;gap:10px}
  .partners-grid{grid-template-columns:1fr 1fr !important}
  .course-card-img.hide-mobile{display:none !important}
  .city-grid{grid-template-columns:repeat(auto-fill,minmax(95px,1fr))}

  /* Inline grids → 1 col */
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important}
  [style*="grid-template-columns:repeat(2,1fr)"]{grid-template-columns:1fr !important}
  [style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:1fr !important}
  [style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr !important}
  [style*="grid-template-columns:200px 1fr"]{grid-template-columns:1fr !important}
  [style*="grid-template-columns:repeat(auto-fill"]{grid-template-columns:1fr !important}

  /* Trust bar scroll */
  .trust-bar-inner{display:flex;overflow-x:auto;flex-shrink:0}
  .ti{flex-shrink:0;min-width:160px}

  /* Hero */
  .hero{padding:40px 0 36px}
  .hero-stats{gap:16px;padding-top:24px;margin-top:28px}
  .hs-num{font-size:1.5rem}
  .hs-lbl{font-size:.7rem}
  .hero-btns{gap:8px}

  /* Notice: stack on very small */
  .notice{flex-direction:column;gap:6px}

  /* Stats */
  .stat-cell{padding:28px 14px}
  .stat-n{font-size:1.75rem}

  /* Footer */
  .footer-top{padding:44px 0 28px}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .accred-inner{gap:7px}
  .accred-badge{font-size:.63rem;padding:6px 10px}

  /* CTA */
  .cta-band,.cta-banner{padding:40px 0}
  .cta-band-btns{gap:8px}

  /* Tables */
  .data-table th{padding:4px 7px;font-size:.6rem}
  .data-table td{padding:4px 7px;font-size:.75rem}
  .price-table{font-size:.68rem}
  .price-table th{padding:4px 5px;font-size:.58rem}
  .price-table td{padding:5px 5px}
  .price-table .pv{font-size:.775rem}
  .faq-q{font-size:.8rem;padding:9px 11px}
  .faq-a{font-size:.78rem;padding:0 11px 9px}
  .cur-btn{font-size:.73rem;padding:7px 9px;gap:6px}
  .cur-btn strong{font-size:.6rem;padding:1px 4px}
  .cur-panel{padding:4px 9px 7px}
  .cur-panel li{font-size:.73rem;padding:3px 0}
}

/* ── 400px: very small phones ── */
@media(max-width:400px){
  .container{padding:0 12px}
  .hero-btns{flex-direction:column;gap:8px}
  .hero-btns .btn{width:100%}
  .hs-num{font-size:1.25rem}
  .stats-grid{grid-template-columns:1fr 1fr !important}
  .grid-4,.why-grid{grid-template-columns:1fr}
  .layout-icon-text{grid-template-columns:32px 1fr;gap:10px}
  [style*="grid-template-columns:56px 1fr"]{grid-template-columns:32px 1fr !important;gap:10px !important}
  [style*="grid-template-columns:36px 1fr"]{grid-template-columns:28px 1fr !important;gap:8px !important}
}

/* ── Sidebar button override — must be display:block not inline-flex ── */
.sb-body a.btn,.sb-body button.btn,.sb-btns a,.sb-btns button{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box !important;
  white-space:normal !important;
  text-align:center;
  overflow-wrap:break-word;
  word-break:break-word;
  padding:11px 14px;
}

/* Price table in sidebar: allow horizontal scroll despite parent overflow */
.sb-body .tbl-wrap{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  margin-left:-18px;
  margin-right:-18px;
  padding-left:18px;
  padding-right:18px;
  width:calc(100% + 36px);
  box-sizing:border-box;
}
.sb-body .price-table{
  min-width:180px;
  font-size:.68rem;
}
.sb-body .price-table th{padding:4px 6px;font-size:.6rem}
.sb-body .price-table td{padding:5px 6px}
.sb-body .price-table .pv{font-size:.775rem}

/* ════════════════════════════════════════════════════════
   MOBILE TABLE & IMAGE REMOVAL / REPLACEMENT
   ════════════════════════════════════════════════════════ */

/* ── Hide GBP/THB price columns on mobile ── */
@media(max-width:600px){
  .hide-sm{display:none !important}
}

/* ── "All Levels" 6-col table: replace with scrollable cards on mobile ── */
@media(max-width:600px){
  /* Hide the table, show a "Compare levels" link instead */
  .levels-wrap{display:none !important}
  .levels-wrap + .levels-link-mobile{display:block !important}
}
.levels-link-mobile{
  display:none; /* shown only on mobile via above rule */
  text-align:center;
  padding:12px 0;
  font-size:.875rem;
}
.levels-link-mobile a{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--blue);font-weight:700;
  border:1.5px solid var(--border);border-radius:8px;
  padding:10px 20px;background:var(--white);
}

/* ── Price table: 2 cols (INR+USD) on mobile ── */
@media(max-width:600px){
  .price-tbl{font-size:.8rem !important}
  .price-tbl th{padding:7px 10px !important;font-size:.68rem !important}
  .price-tbl td{padding:8px 10px !important}
  .price-tbl .pv{font-size:.9375rem !important}
}

/* ── Banner images: always contain ── */
.banner-img,.img-16-9,.img-4-3,.img-hero,.hero-img-wrap{
  overflow:hidden !important;
  max-width:100% !important;
}
.banner-img img,.img-16-9 img,.img-4-3 img,.img-hero img,.hero-img-wrap img{
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  object-fit:cover;
  display:block;
}

/* ── Tbl-wrap: guaranteed scroll, never overflow ── */
.tbl-wrap{
  overflow-x:auto !important;
  -webkit-overflow-scrolling:touch;
  max-width:100% !important;
  width:100% !important;
  display:block !important;
  box-sizing:border-box !important;
}
/* Prevent tbl-wrap from being clipped by overflow:hidden parent */
@media(max-width:768px){
  .tbl-wrap{
    margin-left:0;
    margin-right:0;
  }
}


/* ════════════════════════════════════════════════
   COURSE PAGE CLEAN COMPONENTS v2
   ════════════════════════════════════════════════ */

/* Detail list (replaces 2-col table) */
.detail-list{border:1px solid var(--border);border-radius:var(--r);
             overflow:hidden;margin-bottom:20px}
.dl-row{display:flex;align-items:baseline;border-bottom:1px solid var(--border);
        padding:8px 12px;gap:12px}
.dl-row:last-child{border-bottom:none}
.dl-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
          color:var(--muted);white-space:nowrap;min-width:88px;flex-shrink:0}
.dl-val{font-size:.85rem;color:var(--navy);flex:1;overflow-wrap:break-word;word-break:break-word}
@media(max-width:400px){
  .dl-row{flex-direction:column;gap:2px;padding:7px 10px}
  .dl-label{min-width:0}
}

/* Price display (replaces sidebar price table) */
.price-display{padding:6px 0 2px}
.price-main{font-size:1.5rem;font-weight:800;color:var(--blue);line-height:1;margin-bottom:3px}
.price-alts{font-size:.72rem;color:var(--muted);line-height:1.5;word-break:break-word}
.price-note{font-size:.67rem;color:var(--muted);margin-top:2px}

/* Levels table compact */
.levels-wrap .data-table th{padding:5px 8px;font-size:.63rem}
.levels-wrap .data-table td{padding:5px 8px;font-size:.78rem}

/* Curriculum accordion */
.cur-item{border:1px solid var(--border);border-radius:6px;
          margin-bottom:3px;overflow:hidden;box-sizing:border-box}
.cur-btn{width:100%;display:flex;align-items:center;justify-content:space-between;
         padding:9px 12px;background:var(--bg);font-weight:600;font-size:.82rem;
         cursor:pointer;transition:background var(--t);border:none;text-align:left;
         gap:8px;line-height:1.35;box-sizing:border-box;min-width:0}
.cur-btn strong{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
                color:var(--amber-dark);white-space:nowrap;flex-shrink:0;
                background:var(--amber-pale);padding:2px 5px;border-radius:3px;
                min-width:54px;text-align:center}
.cur-btn .cur-title{flex:1;color:var(--navy);font-size:.82rem;min-width:0;
                    overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cur-btn:hover{background:var(--amber-pale)}
.cur-ic{width:16px;height:16px;border-radius:50%;background:var(--border);display:flex;
        align-items:center;justify-content:center;font-size:.6rem;font-weight:800;
        color:var(--slate);flex-shrink:0;transition:all var(--t)}
.cur-item.open>.cur-btn{background:var(--amber-pale)}
.cur-item.open .cur-ic{background:var(--amber);color:var(--white);transform:rotate(45deg)}
.cur-panel{padding:6px 12px 10px;border-top:1px solid var(--border);display:none;
           background:var(--white)}
.cur-panel.open{display:block}
.cur-panel ul{display:flex;flex-direction:column}
.cur-panel li{font-size:.8rem;color:var(--slate);padding:4px 0;display:flex;
              align-items:flex-start;gap:7px;border-bottom:1px solid var(--bg2);
              overflow-wrap:break-word;word-break:break-word;line-height:1.45}
.cur-panel li:last-child{border-bottom:none}
.cur-panel li::before{content:"›";color:var(--amber-dark);font-weight:700;
                       flex-shrink:0;font-size:.875rem;line-height:1.5}

/* FAQ accordion */
.faq-item{border:1px solid var(--border);border-radius:var(--r);margin-bottom:4px;overflow:hidden}
.faq-q{width:100%;display:flex;align-items:flex-start;justify-content:space-between;
       padding:10px 13px;background:var(--white);font-weight:600;font-size:.85rem;
       color:var(--navy);cursor:pointer;transition:background var(--t);border:none;
       text-align:left;gap:10px;line-height:1.4;overflow-wrap:break-word;
       word-break:break-word;box-sizing:border-box}
.faq-q:hover{background:var(--amber-pale)}
.faq-ic{width:18px;height:18px;border-radius:50%;background:var(--bg);display:flex;
        align-items:center;justify-content:center;font-size:.65rem;flex-shrink:0;
        transition:all var(--t);font-weight:800;margin-top:2px}
.faq-item.open .faq-q{background:var(--amber-pale);color:var(--amber-dark)}
.faq-item.open .faq-ic{background:var(--amber);color:var(--white);transform:rotate(45deg)}
.faq-a{padding:0 13px 10px;font-size:.82rem;color:var(--slate);display:none;
       line-height:1.65;overflow-wrap:break-word;word-break:break-word}
.faq-item.open .faq-a{display:block}

/* Levels table mobile */
@media(max-width:600px){
  .levels-wrap{display:none !important}
  .levels-link-mobile{display:block !important}
}
.levels-link-mobile{display:none;padding:6px 0}
.levels-link-mobile a{display:inline-flex;align-items:center;gap:6px;color:var(--blue);
                       font-weight:600;font-size:.82rem;border:1px solid var(--border);
                       border-radius:6px;padding:7px 14px;background:var(--white)}
