:root{
    --ink:#141312;
    --ink-soft:#1C1B19;
    --paper:#F2F0EA;
    --paper-2:#E6E3DB;
    --red:#F64C38;
    --red-hi:#FF7E6B;
    --red-lo:#C5381F;
    --red-deep:#C93E2E;
    --on-ink:#ECEAE4;
    --on-ink-mut:#A6A29A;
    --on-paper:#1E1C1A;
    --on-paper-mut:#6B655E;
    --line-ink:rgba(236,234,228,.13);
    --line-paper:rgba(30,28,26,.13);
    --serif:"Spectral",Georgia,"Times New Roman",serif;
    --sans:"Hanken Grotesk",-apple-system,Segoe UI,sans-serif;
    --maxw:1180px;
    --ease:cubic-bezier(.2,.7,.2,1);
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
  body{font-family:var(--sans);background:var(--ink);color:var(--on-ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  body::after{
    content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    opacity:.03;mix-blend-mode:overlay;
  }
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}

  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
  .serif{font-family:var(--serif)}
  .eyebrow{font-size:.72rem;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--red);display:inline-flex;align-items:center;gap:.7em;font-family:var(--sans)}
  .eyebrow::before{content:"";width:26px;height:1px;background:var(--red);opacity:.8}

  /* ---------- Header ---------- */
  header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .4s var(--ease),border-color .4s,padding .4s var(--ease);padding:20px 0;border-bottom:1px solid transparent}
  header.scrolled{background:rgba(20,19,18,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-ink);padding:12px 0}
  .nav{display:flex;align-items:center;justify-content:space-between;gap:20px}
  .brand{display:flex;align-items:center;min-width:0}
  .logo{height:46px;width:auto;display:block;transition:height .4s var(--ease)}
  header.scrolled .logo{height:38px}

  nav ul{list-style:none;display:flex;align-items:center;gap:30px}
  nav a{font-size:.84rem;font-weight:500;letter-spacing:.02em;color:var(--on-ink);position:relative;padding:4px 0;opacity:.86;transition:opacity .25s}
  nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--red);transition:width .3s var(--ease)}
  nav a:hover{opacity:1}
  nav a:hover::after{width:100%}
  .menu-btn{display:none;background:none;border:1px solid var(--line-ink);color:var(--on-ink);width:44px;height:40px;cursor:pointer;font-size:1.2rem;flex:none}

  /* ---------- Hero ---------- */
  .hero{position:relative;min-height:100svh;display:flex;align-items:center;padding:128px 0 72px;overflow:hidden}
  .hero::before{content:"";position:absolute;top:-20%;right:-10%;width:70vw;height:70vw;max-width:900px;max-height:900px;background:radial-gradient(circle,rgba(246,76,56,.10),transparent 62%);pointer-events:none}
  .hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.35));pointer-events:none}
  .hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center;width:100%}
  .hero-cent{font-family:var(--serif);font-weight:400;letter-spacing:.16em;color:var(--red);font-size:1.05rem;display:flex;align-items:center;gap:16px;margin-bottom:26px}
  .hero-cent .ln{height:1px;width:54px;background:linear-gradient(90deg,var(--red),transparent)}
  h1.hero-title{font-family:var(--serif);font-weight:500;font-size:clamp(2.8rem,7.4vw,6.4rem);line-height:.98;letter-spacing:-.01em;color:var(--paper)}
  h1.hero-title em{font-style:italic;color:var(--red);font-weight:500}
  .hero-sub{margin-top:30px;max-width:32ch;color:var(--on-ink-mut);font-size:1.07rem;line-height:1.65}
  .hero-cta{margin-top:40px;display:flex;gap:16px;flex-wrap:wrap}
  .btn{font-family:var(--sans);font-size:.86rem;font-weight:600;letter-spacing:.04em;padding:15px 28px;cursor:pointer;transition:.3s var(--ease);border:1px solid var(--red);display:inline-flex;align-items:center;gap:10px}
  .btn-primary{background:var(--red);color:var(--ink)}
  .btn-primary:hover{background:var(--red-hi);border-color:var(--red-hi);transform:translateY(-2px)}
  .btn-ghost{background:transparent;color:var(--on-ink);border-color:var(--line-ink)}
  .btn-ghost:hover{border-color:var(--red);color:var(--red)}
  .btn .arr{transition:transform .3s var(--ease)}
  .btn:hover .arr{transform:translateX(4px)}

  .figure{position:relative;text-align:center;padding:24px}
  .figure .frame{position:absolute;inset:0;border:1px solid var(--line-ink)}
  .figure .frame::before,.figure .frame::after{content:"";position:absolute;width:13px;height:13px;border:1px solid var(--red)}
  .figure .frame::before{top:-1px;left:-1px;border-right:none;border-bottom:none}
  .figure .frame::after{bottom:-1px;right:-1px;border-left:none;border-top:none}
  .figure .hundred{font-family:var(--serif);font-weight:600;font-size:clamp(6.5rem,20vw,15rem);line-height:.82;background:linear-gradient(160deg,var(--red-hi),var(--red) 45%,var(--red-lo));-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.01em}
  .figure .label{margin-top:18px;font-size:.74rem;letter-spacing:.4em;text-transform:uppercase;color:var(--on-ink-mut);font-family:var(--sans)}
  .figure .years{font-family:var(--serif);font-style:italic;color:var(--red);font-size:1.15rem;margin-top:6px}

  /* ---------- Stats ---------- */
  .stats{border-top:1px solid var(--line-ink);border-bottom:1px solid var(--line-ink);background:var(--ink-soft)}
  .stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
  .stat{padding:38px 26px;text-align:center;border-right:1px solid var(--line-ink)}
  .stat:last-child{border-right:none}
  .stat .n{font-family:var(--serif);font-weight:600;font-size:2.7rem;color:var(--red);line-height:1}
  .stat .t{margin-top:10px;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--on-ink-mut)}

  /* ---------- Section base ---------- */
  section{position:relative}
  section[id],footer[id]{scroll-margin-top:78px}
  .pad{padding:120px 0}
  .sec-head{margin-bottom:60px;max-width:60ch}
  .sec-head h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.2rem,4.6vw,3.4rem);line-height:1.08;letter-spacing:-.01em;margin-top:20px}
  .sec-head-row{display:flex;justify-content:space-between;align-items:flex-end;max-width:none;gap:20px}
  .all-link{color:var(--red);font-size:.85rem;font-weight:600;white-space:nowrap}

  /* ---------- About ---------- */
  .paper{background:var(--paper);color:var(--on-paper)}
  .paper .eyebrow{color:var(--red-deep)}
  .paper .eyebrow::before{background:var(--red-deep)}
  .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
  .about-txt p{font-size:1.1rem;color:var(--on-paper);margin-bottom:20px;max-width:46ch}
  .about-txt p.lead{font-family:var(--serif);font-size:1.7rem;line-height:1.3;color:var(--on-paper);font-weight:500;letter-spacing:-.01em}
  .placeholder{color:var(--on-paper-mut);font-style:italic}
  .about-img{aspect-ratio:3/2;width:100%;height:auto;object-fit:cover;object-position:center 55%;border:1px solid var(--line-paper);display:block}
  .about-img::before{content:"";position:absolute;inset:14px;border:1px solid var(--line-paper)}
  .ph-tag{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--on-paper-mut);text-align:center;padding:0 16px}

  /* ---------- Programmes ---------- */
  .progs{display:grid;grid-template-columns:repeat(2,1fr);border-top:1px solid var(--line-ink);border-left:1px solid var(--line-ink)}
  .prog{padding:34px 32px;border-right:1px solid var(--line-ink);border-bottom:1px solid var(--line-ink);transition:background .35s var(--ease);position:relative}
  .prog::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:var(--red);transition:width .35s var(--ease)}
  .prog:hover{background:var(--ink-soft)}
  .prog:hover::before{width:3px}
  .prog .pn{font-family:var(--serif);font-style:italic;color:var(--on-ink-mut);font-size:.95rem}
  .prog h3{font-family:var(--serif);font-weight:600;font-size:1.45rem;margin:10px 0 8px;color:var(--paper);letter-spacing:-.01em}
  .prog p{font-size:.9rem;color:var(--on-ink-mut);line-height:1.55}

  /* ---------- Centennial ---------- */
  .cent{position:relative;text-align:center;padding:150px 0;overflow:hidden;background:linear-gradient(180deg,var(--ink),#0E0D0C)}
  .cent::before{content:"1927 · 2027";position:absolute;inset:0;display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:clamp(5rem,17vw,15rem);color:rgba(246,76,56,.055);letter-spacing:.05em;white-space:nowrap;pointer-events:none}
  .cent-inner{position:relative;z-index:2;max-width:680px;margin:0 auto}
  .cent h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,5.5vw,4rem);line-height:1.08;color:var(--paper);margin:22px 0}
  .cent h2 em{font-style:italic;color:var(--red)}
  .cent p{color:var(--on-ink-mut);font-size:1.1rem;max-width:48ch;margin:0 auto 36px}

  /* ---------- News ---------- */
  .news-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line-ink)}
  .news{padding:36px 30px;border-bottom:1px solid var(--line-ink);transition:.3s;cursor:pointer}
  .news:not(:last-child){border-right:1px solid var(--line-ink)}
  .news:first-child{padding-left:0}
  .news .meta{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
  .news h3{font-family:var(--serif);font-weight:500;font-size:1.4rem;line-height:1.25;color:var(--paper);transition:color .3s}
  .news:hover h3{color:var(--red)}
  .news .more{margin-top:18px;font-size:.8rem;color:var(--on-ink-mut);display:inline-flex;gap:8px;align-items:center}

  /* ---------- Enroll ---------- */
  .enroll{background:var(--ink-soft);border-top:1px solid var(--line-ink);border-bottom:1px solid var(--line-ink);text-align:center;padding:96px 0}
  .enroll h2{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,4.5vw,3.2rem);line-height:1.08;margin-bottom:14px;color:var(--paper)}
  .enroll p{font-size:1.05rem;color:var(--on-ink-mut);max-width:46ch;margin:0 auto 32px}

  /* ---------- Footer ---------- */
  footer{background:#0E0D0C;padding:78px 0 34px;border-top:1px solid var(--line-ink)}
  .foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:50px;padding-bottom:48px;border-bottom:1px solid var(--line-ink)}
  .logo-full{width:min(280px,82%);height:auto;display:block;margin-bottom:18px}
  .foot-brand p{color:var(--on-ink-mut);font-size:.92rem;max-width:36ch}
  .foot-col h4{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--red);margin-bottom:18px}
  .foot-col a,.foot-col p{display:block;color:var(--on-ink-mut);font-size:.92rem;margin-bottom:10px;transition:color .25s}
  .foot-col a:hover{color:var(--paper)}
  .foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;flex-wrap:wrap;gap:14px}
  .foot-bottom small{color:var(--on-ink-mut);font-size:.8rem}
  .foot-bottom .links{display:flex;gap:22px;flex-wrap:wrap}
  .foot-bottom .links a{font-size:.8rem;color:var(--on-ink-mut);cursor:pointer}
  .foot-bottom .links a:hover{color:var(--red)}

  /* ---------- Cookie banner ---------- */
  .cookie{position:fixed;left:0;right:0;bottom:0;z-index:200;background:rgba(20,19,18,.97);backdrop-filter:blur(12px);border-top:1px solid var(--line-ink);transform:translateY(115%);transition:transform .5s var(--ease)}
  .cookie.show{transform:none}
  .cookie-in{max-width:var(--maxw);margin:0 auto;padding:20px 28px;display:flex;align-items:center;justify-content:space-between;gap:28px}
  .cookie-txt strong{font-family:var(--serif);font-weight:600;color:var(--paper);font-size:1.05rem;display:block;margin-bottom:4px;letter-spacing:.01em}
  .cookie-txt p{color:var(--on-ink-mut);font-size:.88rem;max-width:64ch;line-height:1.55}
  .cookie-txt a{color:var(--red);text-decoration:underline;text-underline-offset:2px}
  .cookie-btns{display:flex;gap:12px;flex:none}
  .cookie .btn{padding:12px 20px;font-size:.8rem}
  .cookie-min{white-space:nowrap}

  /* ---------- Modal (deeper info) ---------- */
  .prog{cursor:pointer}
  .prog::after{content:"→";position:absolute;right:26px;bottom:28px;color:var(--red);opacity:0;transform:translateX(-6px);transition:.3s var(--ease);font-size:1.1rem}
  .prog:hover::after,.prog:focus-visible::after{opacity:1;transform:none}
  .prog:focus-visible,.news:focus-visible{outline:2px solid var(--red);outline-offset:-2px}
  .modal-ovl{position:fixed;inset:0;z-index:300;background:rgba(8,8,8,.74);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s;display:grid;place-items:center;padding:24px}
  .modal-ovl.open{opacity:1;visibility:visible}
  .modal{background:var(--ink-soft);border:1px solid var(--line-ink);max-width:560px;width:100%;max-height:86vh;overflow:auto;padding:44px 42px;position:relative;transform:translateY(16px) scale(.985);transition:transform .35s var(--ease)}
  .modal-ovl.open .modal{transform:none}
  .modal .x{position:absolute;top:16px;right:16px;width:38px;height:38px;border:1px solid var(--line-ink);background:none;color:var(--on-ink);font-size:1rem;cursor:pointer;transition:.25s;line-height:1}
  .modal .x:hover{border-color:var(--red);color:var(--red)}
  .modal .m-eyebrow{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--red);font-weight:600}
  .modal h3{font-family:var(--serif);font-weight:600;font-size:1.9rem;color:var(--paper);margin:14px 0 6px;letter-spacing:-.01em;line-height:1.12}
  .modal .m-spec{color:var(--red);font-style:italic;font-family:var(--serif);font-size:1.05rem;margin-bottom:18px}
  .modal p{color:var(--on-ink-mut);font-size:1rem;line-height:1.65;margin-bottom:14px}
  .modal .m-note{font-size:.85rem;border-top:1px solid var(--line-ink);padding-top:16px;margin-top:18px}
  .modal .m-group{margin-bottom:15px}
  .modal .m-group:last-child{margin-bottom:0}
  .modal .m-group h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paper);margin-bottom:5px;font-weight:700}
  .modal .m-ped{color:var(--on-ink-mut);font-size:.95rem;line-height:1.55;margin:0}
  .socials{display:flex;gap:12px;margin-top:22px}
  .socials a{width:42px;height:42px;border:1px solid var(--line-ink);display:grid;place-items:center;color:var(--on-ink-mut);transition:.25s var(--ease)}
  .socials a:hover{border-color:var(--red);color:var(--red);transform:translateY(-2px)}
  .socials svg{width:18px;height:18px;fill:currentColor;display:block}
  body.modal-open{overflow:hidden}

  /* ---------- Reveal ---------- */
  .reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
  .reveal.in{opacity:1;transform:none}
  @keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
  .hero-grid > *{animation:fadeUp .9s var(--ease) both}
  .hero-grid .hero-left{animation-delay:.05s}
  .hero-grid .figure{animation-delay:.25s}
  @media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}html{scroll-behavior:auto}}

  /* ---------- Responsive ---------- */
  @media(max-width:900px){
    .pad{padding:90px 0}
    .hero{padding:100px 0 64px}
    .hero-grid{grid-template-columns:1fr;gap:36px}
    .figure{order:-1;max-width:300px;margin:0 auto;padding:20px}
    .hero-sub{max-width:42ch}
    .logo{height:40px}
    .about-grid{grid-template-columns:1fr;gap:36px}
    .about-img{aspect-ratio:16/10}
    .progs{grid-template-columns:1fr}
    .prog{padding:30px 26px}
    .news-grid{grid-template-columns:1fr}
    .news,.news:not(:last-child){padding:30px 0;border-right:none}
    .news:first-child{padding-top:0}
    .sec-head-row{flex-direction:column;align-items:flex-start;gap:16px}
    .stats-grid{grid-template-columns:repeat(2,1fr)}
    .stat:nth-child(2){border-right:none}
    .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line-ink)}
    .cent{padding:96px 0}
    .foot-grid{grid-template-columns:1fr;gap:34px}
    nav ul{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(20,19,18,.97);backdrop-filter:blur(12px);flex-direction:column;gap:0;border-top:1px solid var(--line-ink);padding:6px 0}
    nav ul.open{display:flex}
    nav ul li{width:100%}
    nav ul a{display:block;padding:16px 28px;border-bottom:1px solid var(--line-ink);opacity:1}
    nav ul li:last-child a{border-bottom:none}
    .menu-btn{display:block}
  }
  @media(max-width:720px){
    .cookie-in{flex-direction:column;align-items:stretch;gap:16px;padding:18px 22px}
    .cookie-btns{flex-direction:column}
    .cookie .btn{width:100%;justify-content:center}
  }
  @media(max-width:560px){
    .wrap{padding:0 22px}
    .pad{padding:72px 0}
    .stats-grid{grid-template-columns:1fr}
    .stat{border-right:none;border-bottom:1px solid var(--line-ink)}
    .stat:last-child{border-bottom:none}
    .hero-cta{gap:12px}
    .hero-cta .btn{width:100%;justify-content:center}
    .sec-head{margin-bottom:44px}
    .enroll{padding:68px 0}
    .cent{padding:80px 0}
    .foot-bottom{flex-direction:column;align-items:flex-start}
    .logo{height:36px}
  }
  @media(max-width:420px){
    h1.hero-title{font-size:2.55rem}
    .figure .hundred{font-size:6.5rem}
  }

/* --- news cards as links + article page (added for CMS build) --- */
a.news{display:block}
.article{padding:140px 0 100px;max-width:760px;margin:0 auto}
.article .a-meta{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.article h1{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,4.5vw,3rem);line-height:1.1;color:var(--paper);letter-spacing:-.01em;margin-bottom:14px}
.article .a-body{color:var(--on-ink);font-size:1.08rem;line-height:1.75;margin-top:30px}
.article .a-body p{margin-bottom:18px}
.article .a-body h2{font-family:var(--serif);color:var(--paper);font-size:1.6rem;margin:30px 0 12px}
.article .a-body img{margin:24px 0;border:1px solid var(--line-ink)}
.article .a-back{display:inline-block;margin-top:40px;color:var(--red);font-weight:600;font-size:.9rem}
.zlist{padding:140px 0 110px}
.zlist .z{display:block;padding:30px 0;border-bottom:1px solid var(--line-ink)}
.zlist .z .meta{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.zlist .z h2{font-family:var(--serif);font-weight:500;font-size:1.5rem;color:var(--paper);transition:color .3s}
.zlist .z:hover h2{color:var(--red)}
