@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600&family=IBM+Plex+Serif:wght@500;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'IBM Plex Sans',system-ui,sans-serif;font-size:1rem;line-height:1.65;color:#0F172A;background:#F8FAFC;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:currentColor;text-decoration:underline;text-underline-offset:3px}
a:hover{opacity:.88}

.surface-dark{background:#0F172A;color:#F8FAFC}
.surface-light{background:#F8FAFC;color:#0F172A}
.surface-accent{background:#0D9488;color:#F8FAFC}
.surface-soft{background:#ECFEFF;color:#0F172A}

.container{width:min(1140px,92vw);margin-inline:auto}
.section{padding:4.5rem 0}
.section-label{font-family:'IBM Plex Sans',sans-serif;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#0D9488;margin-bottom:.5rem;font-weight:600}
h1,h2,h3,h4{font-family:'IBM Plex Serif',serif;line-height:1.18;font-weight:600}
h1{font-size:clamp(2.35rem,5vw,3.4rem)}
h2{font-size:clamp(1.7rem,3vw,2.2rem);margin-bottom:1rem}
h3{font-size:1.2rem;margin-bottom:.5rem}
p{margin-bottom:1rem}
ul,ol{margin-bottom:1rem;padding-left:1.25rem}
li{margin-bottom:.35rem}

.site-header{position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(15,23,42,.08);background:#F8FAFC}
.site-header--transparent{position:fixed;left:0;right:0;background:transparent;border-bottom:1px solid rgba(248,250,252,.18);color:#F8FAFC;transition:background .25s ease,border-color .25s ease}
.site-header--transparent.is-scrolled{background:rgba(15,23,42,.92);backdrop-filter:blur(8px);border-bottom-color:rgba(248,250,252,.12)}
.site-header--transparent .logo span{color:#ECFEFF}
.site-header--transparent .nav-list a{color:#F8FAFC}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;gap:1rem}
.logo{font-family:'IBM Plex Serif',serif;font-weight:600;font-size:1.12rem;text-decoration:none;letter-spacing:-.01em}
.logo span{color:#0D9488}
.nav-list{display:flex;flex-wrap:wrap;gap:.25rem 1.25rem;list-style:none;padding:0;margin:0}
.nav-list a{text-decoration:none;font-size:.9rem;font-weight:500}
.nav-list a[aria-current="page"]{text-decoration:underline;text-underline-offset:4px}

.btn{display:inline-block;padding:.72rem 1.4rem;font-family:'IBM Plex Sans',sans-serif;font-weight:600;font-size:.9rem;text-decoration:none;border:2px solid transparent;border-radius:4px;cursor:pointer;transition:opacity .2s,background .2s}
.btn-primary{background:#0D9488;color:#F8FAFC;border-color:#0D9488}
.btn-outline{background:transparent;border-color:currentColor;color:inherit}
.surface-accent .btn-outline{border-color:#F8FAFC;color:#F8FAFC}
.btn-group{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}

.hero-cinematic{position:relative;min-height:100vh;display:flex;align-items:flex-end;padding:5.5rem 0 4.5rem}
.hero-cinematic__bg{position:absolute;inset:0;z-index:0}
.hero-cinematic__bg img{width:100%;height:100%;object-fit:cover}
.hero-cinematic__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,.35) 0%,rgba(15,23,42,.55) 45%,rgba(15,23,42,.88) 100%)}
.hero-cinematic__content{position:relative;z-index:1;color:#F8FAFC;width:100%}
.hero-badge{display:inline-block;font-family:'IBM Plex Sans',sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:.45rem .85rem;border:1px solid rgba(236,254,255,.45);border-radius:999px;margin-bottom:1.25rem;background:rgba(13,148,136,.25)}
.hero-cinematic h1{margin-bottom:1rem;max-width:18ch}
.hero-cinematic .lead{font-size:1.08rem;max-width:52ch;opacity:.92;margin-bottom:0}
.hero-trust{display:flex;flex-wrap:wrap;gap:1rem 2rem;margin-top:2rem;font-size:.85rem;opacity:.85}

.page-hero{padding:3.5rem 0 2rem}
.page-hero h1{margin-bottom:.75rem}

.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}

.card{padding:1.75rem;border-radius:6px;border:1px solid rgba(15,23,42,.1);background:#fff}
.surface-dark .card{border-color:rgba(248,250,252,.12);background:rgba(248,250,252,.04)}
.surface-soft .card{border-color:rgba(13,148,136,.15);background:#fff}
.lab-tag{font-family:'IBM Plex Sans',sans-serif;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:#0D9488;margin-bottom:.5rem;font-weight:600}

.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.5rem;text-align:center;padding:2rem 0}
.stat-num{font-family:'IBM Plex Serif',serif;font-size:2rem;font-weight:600;color:#0D9488}
.stat-label{font-size:.85rem;opacity:.82}

.content-img{border-radius:6px;margin:1.5rem 0;width:100%;object-fit:cover}
.img-caption{font-size:.8rem;opacity:.72;margin-top:.5rem}

.programme-card{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid rgba(15,23,42,.1)}
.surface-dark .programme-card{border-color:rgba(248,250,252,.12)}
.programme-card:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}

.faq-item{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(15,23,42,.1)}
.surface-dark .faq-item{border-color:rgba(248,250,252,.12)}
.faq-q{font-family:'IBM Plex Serif',serif;font-weight:600;font-size:1.05rem;margin-bottom:.5rem}

.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-weight:500;margin-bottom:.35rem;font-size:.9rem}
.form-group input:not([type="checkbox"]):not([type="radio"]),.form-group select,.form-group textarea{width:100%;padding:.65rem .85rem;border:1px solid rgba(15,23,42,.18);border-radius:4px;font:inherit;background:#fff;color:#0F172A}
.form-group textarea{min-height:140px;resize:vertical}
.form-group.form-check,.form-check{display:flex;gap:.65rem;align-items:flex-start;font-size:.9rem}
.form-group.form-check label,.form-check label{display:inline;margin-bottom:0;font-weight:400;line-height:1.5}
.form-group.form-check input[type="checkbox"],.form-check input[type="checkbox"]{width:auto;padding:0;margin-top:.25rem;flex-shrink:0;border:0;background:transparent}
.hp{position:absolute;left:-9999px;opacity:0;height:0;width:0;overflow:hidden}
.form-notice{padding:1rem 1.25rem;border-radius:4px;margin-bottom:1.5rem;font-size:.9rem}
.form-notice--success{background:#ECFEFF;border:1px solid #0D9488;color:#0F172A}
.form-notice--error{background:#FEF2F2;border:1px solid #DC2626;color:#0F172A}

.legal-content h2{font-size:1.35rem;margin-top:2rem}
.legal-content h3{font-size:1.1rem;margin-top:1.5rem}
.legal-content p,.legal-content li{font-size:.95rem}

.site-footer{padding:3rem 0 2rem;border-top:1px solid rgba(248,250,252,.12);font-size:.875rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}
.footer-grid h4{font-size:.95rem;margin-bottom:.75rem;font-family:'IBM Plex Serif',serif}
.footer-grid ul{list-style:none;padding:0}
.footer-grid li{margin-bottom:.35rem}
.footer-grid a{text-decoration:none}
.footer-bottom{padding-top:1.5rem;border-top:1px solid rgba(248,250,252,.08);font-size:.8rem;opacity:.88}
.disclaimer{font-size:.8rem;opacity:.82;margin-top:1rem;line-height:1.55}

.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:200;padding:1.25rem;box-shadow:0 -4px 24px rgba(0,0,0,.18)}
.cookie-inner{max-width:1140px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}
.cookie-actions{display:flex;flex-wrap:wrap;gap:.5rem}
.cookie-modal{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;padding:1rem}
.cookie-modal[hidden]{display:none}
.cookie-modal-inner{max-width:520px;width:100%;padding:2rem;border-radius:6px;max-height:90vh;overflow-y:auto}
.cookie-option{margin-bottom:1rem;padding:.75rem;border:1px solid rgba(15,23,42,.12);border-radius:4px}

.error-page{min-height:60vh;display:flex;align-items:center;text-align:center;padding:4rem 0}
.error-page h1{margin-bottom:1rem}

.reveal{opacity:1;transform:none}
.js .reveal:not(.is-visible){opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
@media (prefers-reduced-motion:reduce){
  .js .reveal:not(.is-visible){opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
@media (max-width:768px){
  .hero-cinematic{min-height:100svh;padding-bottom:3rem;align-items:flex-end}
  .hero-cinematic h1{max-width:none}
  .nav-list{font-size:.85rem}
  .site-header--transparent + main .hero-cinematic{padding-top:5rem}
}
