    :root{
      --teal-900:#1f4f56;
      --teal-800:#285860; /* from logo */
      --teal-600:#408890; /* from logo */
      --teal-100:#e8f4f5;
      --gold-500:#e0b040; /* from logo */
      --ink:#0e1b1e;
      --muted:#4b5b60;
      --card:#ffffff;
      --shadow: 0 18px 45px rgba(13, 33, 38, .10);
      --radius: 18px;
      --max: 1120px;
    }
    *{box-sizing:border-box}
    html,body{margin:0;padding:0}
    body{
      font-family: "Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color:var(--ink);
      background:
        radial-gradient(900px 500px at 15% 5%, rgba(64,136,144,.18), transparent 60%),
        radial-gradient(900px 500px at 90% 0%, rgba(224,176,64,.12), transparent 62%),
        linear-gradient(180deg, #ffffff 0%, #fbfeff 60%, #ffffff 100%);
      line-height:1.55;
    }
    a{color:inherit;text-decoration:none}
    .container{max-width:var(--max);margin:0 auto;padding:0 20px}
    /* Header */
    header{
      position:sticky; top:0; z-index:50;
      backdrop-filter:saturate(1.2) blur(14px);
      background:rgba(255,255,255,.78);
      border-bottom:1px solid rgba(31,79,86,.08);
    }
    .nav{
      display:grid;
      grid-template-columns: auto 1fr auto;
      align-items:center;
      gap:12px;
      padding:14px 0;
    }
    .brand{
      display:flex; align-items:center; gap:12px; min-width:220px;
    }
    .brand img{height:52px; width:auto}
    .navlinks{
      display:flex;
      align-items:center;
      gap:14px;
      flex-wrap:nowrap;
      justify-content:center;
      white-space:nowrap;
    }
    .navlinks a{
      font-weight:600; color:rgba(14,27,30,.75);
      padding:10px 10px; border-radius:12px;
    }
    .navlinks a:hover{background:rgba(64,136,144,.10); color:var(--ink)}
    .btn{
      display:inline-flex; align-items:center; justify-content:center;
      gap:10px;
      border:1px solid rgba(31,79,86,.18);
      background:rgba(40,88,96,.06);
      padding:10px 14px;
      border-radius:14px;
      font-weight:700;
      transition:.18s ease;
      white-space:nowrap;
    }
    .btn:hover{transform:translateY(-1px); box-shadow:0 10px 24px rgba(13,33,38,.10)}
    .btn.primary{
      border-color:transparent;
      background:linear-gradient(135deg, var(--teal-800), var(--teal-600));
      color:#fff;
    }
    .btn.primary:hover{box-shadow:0 16px 35px rgba(40,88,96,.25)}
    .btn .dot{
      width:8px;height:8px;border-radius:50%;
      background:var(--gold-500);
      box-shadow:0 0 0 6px rgba(224,176,64,.20);
    }
    /* Hero */
    .hero{
      padding:56px 0 24px;
    }
    .hero-grid{
      display:grid;
      grid-template-columns: 1.15fr .85fr;
      gap:26px;
      align-items:stretch;
    }
    .headline{
      font-size: clamp(30px, 4.2vw, 52px);
      line-height:1.05;
      margin:6px 0 14px;
      letter-spacing:-.02em;
    }
    .sub{
      font-size: clamp(15px, 1.7vw, 18px);
      color:var(--muted);
      max-width:60ch;
      margin:0 0 22px;
    }
    .pill-row{
      display:flex; gap:10px; flex-wrap:wrap;
      margin:18px 0 22px;
    }
    .pill{
      font-weight:700; font-size:13px;
      padding:8px 12px;
      border-radius:999px;
      background:rgba(64,136,144,.10);
      border:1px solid rgba(64,136,144,.18);
      color:rgba(14,27,30,.80);
    }
    .pill.gold{
      background:rgba(224,176,64,.14);
      border-color:rgba(224,176,64,.28);
    }
    .hero-card{
      background:var(--card);
      border:1px solid rgba(31,79,86,.10);
      border-radius:var(--radius);
      box-shadow:var(--shadow);
      overflow:hidden;
      position:relative;
    }
    .hero-card .top{
      padding:18px 18px 0;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
    }
    .badge{
      display:inline-flex; align-items:center; gap:8px;
      background:rgba(40,88,96,.08);
      border:1px solid rgba(40,88,96,.16);
      color:rgba(14,27,30,.82);
      padding:8px 12px;
      border-radius:999px;
      font-weight:800;
      font-size:12px;
      letter-spacing:.02em;
    }
    .hero-card .preview{
      padding:14px 18px 18px;
      display:grid;
      gap:12px;
    }
    .mini{
      border-radius:16px;
      border:1px dashed rgba(31,79,86,.22);
      background:linear-gradient(135deg, rgba(64,136,144,.12), rgba(224,176,64,.08));
      padding:14px;
    }
    .mini h4{margin:0 0 6px; font-size:14px}
    .mini p{margin:0; color:var(--muted); font-size:13px}
    .mini .ph{
      margin-top:10px;
      height:110px;
      border-radius:14px;
      background:
        radial-gradient(120px 90px at 30% 35%, rgba(64,136,144,.35), transparent 60%),
        radial-gradient(130px 90px at 70% 55%, rgba(224,176,64,.30), transparent 62%),
        linear-gradient(135deg, rgba(255,255,255,.65), rgba(255,255,255,.20));
      border:1px solid rgba(255,255,255,.55);
    }
    /* Sections */
    section{padding:38px 0}
    .section-title{
      font-size: clamp(22px, 2.3vw, 32px);
      line-height:1.1;
      margin:0 0 10px;
      letter-spacing:-.01em;
    }
    .section-sub{
      margin:0 0 18px;
      color:var(--muted);
    }
    .grid-3{
      display:grid;
      grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
      gap:16px;
    }
    .card{
      background:var(--card);
      border:1px solid rgba(31,79,86,.10);
      border-radius:var(--radius);
      box-shadow: 0 10px 28px rgba(13,33,38,.07);
      padding:18px;
    }
    .card h3{margin:0 0 6px; font-size:18px}
    .card p{margin:0; color:var(--muted)}
    .icon{
      width:44px;height:44px;border-radius:14px;
      display:grid; place-items:center;
      background:rgba(64,136,144,.12);
      border:1px solid rgba(64,136,144,.22);
      margin-bottom:12px;
      font-weight:900;
      color:var(--teal-800);
    }
    .ph-img{
      height:160px;
      border-radius:16px;
      margin-top:14px;
      border:1px dashed rgba(31,79,86,.22);
      background:
        radial-gradient(160px 110px at 30% 35%, rgba(64,136,144,.35), transparent 62%),
        radial-gradient(160px 110px at 75% 55%, rgba(224,176,64,.30), transparent 62%),
        linear-gradient(135deg, rgba(255,255,255,.75), rgba(255,255,255,.18));
    }
    .tagrow{display:flex; gap:8px; flex-wrap:wrap; margin-top:12px}
    .svg-illus{
      height:160px;
      border-radius:16px;
      margin-top:14px;
      overflow:hidden;
      border:1px solid rgba(31,79,86,.10);
      background:rgba(255,255,255,.55);
    }
    .svg-illus svg{display:block}
    .tag{
      font-size:12px; font-weight:800;
      padding:6px 10px; border-radius:999px;
      background:rgba(40,88,96,.06);
      border:1px solid rgba(40,88,96,.12);
      color:rgba(14,27,30,.72);
    }
    /* Workshop */
    .workshop{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap:18px;
      align-items:stretch;
    }
    .poster{
      border-radius:var(--radius);
      overflow:hidden;
      border:1px solid rgba(31,79,86,.10);
      box-shadow:var(--shadow);
      background:#fff;
    }
    .poster img{width:100%; height:auto; display:block}
    .note{
      background:linear-gradient(135deg, rgba(40,88,96,.10), rgba(224,176,64,.08));
      border:1px solid rgba(31,79,86,.12);
      border-radius:var(--radius);
      padding:18px;
      box-shadow: 0 10px 28px rgba(13,33,38,.07);
    }
    .note ul{margin:10px 0 0; padding-left:18px; color:var(--muted)}
    .note li{margin:6px 0}
    .kpi{
      display:grid;
      grid-template-columns:repeat(2, 1fr);
      gap:12px;
      margin-top:14px;
    }
    .kpi .box{
      background:#fff;
      border-radius:16px;
      border:1px solid rgba(31,79,86,.10);
      padding:12px;
    }
    .kpi .box b{display:block; font-size:13px}
    .kpi .box span{color:var(--muted); font-size:13px}
    /* CTA */
    .cta{
      padding:26px;
      border-radius:22px;
      background:linear-gradient(135deg, var(--teal-800), var(--teal-600));
      color:#fff;
      box-shadow:0 18px 55px rgba(40,88,96,.28);
      border:1px solid rgba(255,255,255,.20);
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:16px;
      flex-wrap:wrap;
    }
    .cta p{margin:6px 0 0; opacity:.9}
    .cta .btn{background:#fff; color:var(--ink); border-color:transparent}
    .cta .btn:hover{box-shadow:0 16px 40px rgba(0,0,0,.18)}
    /* Footer */
    footer{
      padding:26px 0 36px;
      color:rgba(14,27,30,.70);
    }
    .footergrid{
      display:flex; align-items:flex-start; justify-content:space-between; gap:16px; flex-wrap:wrap;
      border-top:1px solid rgba(31,79,86,.10);
      padding-top:18px;
    }
    .small{font-size:13px; color:rgba(14,27,30,.62)}
    .mini-links a{margin-right:12px; font-weight:700}
    /* Responsive */
    @media (max-width: 980px){
      .hero-grid{grid-template-columns:1fr}
      .workshop{grid-template-columns:1fr}
      .grid-3{
      display:grid;
      grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
      gap:16px;
    }
      .navlinks{
      display:flex;
      align-items:center;
      gap:14px;
      flex-wrap:nowrap;
      justify-content:center;
      white-space:nowrap;
    }
    }

    /* Programs scroller */
    .programs-header{
      display:flex;
      align-items:center;
      justify-content:space-between;
      margin: 10px 0 12px;
    }
    .programs-controls{display:flex; gap:10px;}
    .arrow{
      width:44px; height:44px;
      border-radius:999px;
      border:1px solid rgba(31,79,86,.18);
      background:rgba(255,255,255,.85);
      display:grid;
      place-items:center;
      cursor:pointer;
      transition: transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
      box-shadow:0 6px 16px rgba(13,33,38,.08);
    }
    .arrow svg{width:18px; height:18px; fill:none; stroke:rgba(14,27,30,.75); stroke-width:2.6; stroke-linecap:round; stroke-linejoin:round;}
    .arrow:hover{
      transform: translateY(-1px);
      background: rgba(64,136,144,.12);
      border-color: rgba(64,136,144,.38);
      box-shadow:0 14px 30px rgba(13,33,38,.14);
    }
    .arrow:active{transform: translateY(0px) scale(.98);}
    .arrow:focus{outline:none; box-shadow:0 0 0 4px rgba(64,136,144,.18), 0 14px 30px rgba(13,33,38,.14);}

    .programs-scroller{
      display:flex;
      flex-wrap:nowrap;
      gap:16px;
      overflow-x:auto;
      overflow-y:hidden;
      padding: 2px 2px 12px;
      scroll-snap-type:x mandatory;
      -webkit-overflow-scrolling: touch;
      scrollbar-gutter: stable both-edges;
    }
    .programs-scroller::-webkit-scrollbar{height:10px;}
    .programs-scroller::-webkit-scrollbar-thumb{
      background: rgba(31,79,86,.18);
      border-radius:999px;
    }
    .programs-scroller::-webkit-scrollbar-track{
      background: rgba(31,79,86,.06);
      border-radius:999px;
    }
    .program-card{
      flex: 0 0 360px;
      scroll-snap-align:start;
    }
    @media (max-width: 900px){
      .program-card{flex-basis: 86vw;}
    }


    /* Program icon images */
    .icon img.icon-img{
      width:22px;height:22px;display:block;
      filter: none;
    }
    .icon.icon-ls{background:rgba(64,136,144,.12); border-color:rgba(64,136,144,.22);}
    .icon.icon-ms{background:rgba(64,136,144,.10); border-color:rgba(64,136,144,.20);}
    .icon.icon-fa{background:rgba(224,176,64,.14); border-color:rgba(224,176,64,.28);}
    .icon.icon-pi{background:rgba(224,176,64,.10); border-color:rgba(224,176,64,.22);}

    /* Program images inside cards */
    .svg-illus{height:160px;}
    .svg-illus img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
    }
    
    .icon-wa{
      background:rgba(37,211,102,.14);
      border-color:rgba(37,211,102,.30);
    }
    
    .icon-mail{
      background:rgba(224,176,64,.14);
      border-color:rgba(224,176,64,.28);
    }
    
    .icon-web{
      background:rgba(64,136,144,.12);
      border-color:rgba(64,136,144,.22);
    }
    
    /* =========================================================
   MOBILE RESPONSIVE ENHANCEMENTS
   ========================================================= */

/* ---------- Navigation & Header ---------- */
@media (max-width: 820px){
  .nav{
    grid-template-columns: 1fr auto;
    row-gap: 10px;
  }

  .navlinks{
    order: 3;
    grid-column: 1 / -1;
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: 6px;
  }

  .navlinks a{
    padding: 8px 8px;
    font-size: 14px;
    white-space: nowrap;
  }

  header .btn{
    padding: 8px 12px;
    font-size: 14px;
  }
}

/* ---------- Hero Section ---------- */
@media (max-width: 820px){
  .hero{
    padding: 36px 0 18px;
  }

  .headline{
    line-height: 1.1;
  }

  .sub{
    font-size: 15px;
  }

  .hero-card{
    margin-top: 12px;
  }
}

/* ---------- Programs Section ---------- */
@media (max-width: 820px){
  .programs-controls{
    display: none;
  }

  .program-card{
    padding: 16px;
  }
}

/* ---------- Workshop Section ---------- */
@media (max-width: 820px){
  .note{
    padding: 16px;
  }

  .kpi{
    grid-template-columns: 1fr;
  }
}

/* ---------- Contact Section ---------- */
@media (max-width: 820px){
  #contact .card{
    padding: 20px;
  }

  #contact a{
    word-break: break-word;
  }
}
/* ===============================
   MOBILE SLIDE-IN NAV (FIXED)
   =============================== */

.nav-actions { display: flex; gap: 10px; align-items: center; }

/* hamburger button */
.menu-toggle{
  display:none;
  border:1px solid rgba(31,79,86,.18);
  background:rgba(255,255,255,.85);
  width:44px; height:44px;
  border-radius:14px;
  font-size:22px;
  line-height:1;
  cursor:pointer;
}

/* overlay */
.menu-overlay{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.28);
  z-index: 1000;
  opacity:0;
  pointer-events:none;
  transition: opacity .2s ease;
}
.menu-overlay.show{
  opacity:1;
  pointer-events:auto;
}

/* slide-in panel */
.mobile-menu{
  position:fixed;
  top:0;
  right:0;
  height:100vh;
  width:min(86vw, 340px);
  background:#fff;
  z-index:1001;
  box-shadow:-12px 0 40px rgba(0,0,0,.18);
  transform: translateX(105%);
  transition: transform .25s ease;
  padding:18px;
  display:flex;
  flex-direction:column;
}
.mobile-menu.open{ transform: translateX(0); }

.mobile-menu-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-weight:800;
  margin-bottom:14px;
}

.mobile-menu-header button{
  border:none;
  background:transparent;
  font-size:22px;
  cursor:pointer;
}

.mobile-nav{
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:8px 0 14px;
}
.mobile-nav a{
  font-size:18px;
  font-weight:700;
  color: var(--ink);
  padding:8px 6px;
  border-radius:12px;
}
.mobile-nav a:active,
.mobile-nav a:hover{
  background: rgba(64,136,144,.10);
}

.mobile-actions{
  margin-top:14px;        /* sits right below menu */
  padding-top:14px;
  border-top:1px solid rgba(0,0,0,.06);
  display:flex;
  flex-direction:column;
  gap:10px;
}


/* MOBILE BREAKPOINT */
@media (max-width: 820px){
  /* hide desktop nav + desktop buttons */
  .navlinks{ display:none !important; }
  .nav-actions{ display:none !important; }

  /* show hamburger */
  .menu-toggle{ display:inline-flex; align-items:center; justify-content:center; }

  /* tighten brand so it doesn’t push layout */
  .brand{ min-width:auto; }
  .brand img{ height:46px; }
}

/* optional: prevent background scroll when menu open */
body.menu-open{ overflow:hidden; }

/* ------------------------------------
   Policy / Legal Page Spacing Fix
------------------------------------- */

.card h3 {
  margin-top: 28px;
  margin-bottom: 10px;
}

.card p {
  margin-top: 0;
  margin-bottom: 12px;
}

.card ul {
  margin-top: 6px;
  margin-bottom: 14px;
  padding-left: 20px;
}

.card ul li {
  margin-bottom: 6px;
}

/* Remove extra gap before first heading */
.card h3:first-of-type {
  margin-top: 0;
}

