/* ==========================================================================
   Adroit Solutions — Direction A design system
   Ported from the approved homepage design. Self-hosted variable fonts.
   ========================================================================== */

/* ---- Self-hosted fonts (font-display:swap, variable) ---- */
@font-face{
  font-family:'Inter';font-style:normal;font-weight:100 900;font-display:swap;
  src:url(../fonts/inter.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Plus Jakarta Sans';font-style:normal;font-weight:200 800;font-display:swap;
  src:url(../fonts/plus-jakarta-sans.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'JetBrains Mono';font-style:normal;font-weight:100 800;font-display:swap;
  src:url(../fonts/jetbrains-mono.woff2) format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

:root{
  /* Brand — from approved Direction A design */
  --teal:#0D424C;        /* deep teal — primary */
  --teal-700:#0A353D;
  --teal-900:#072930;
  --teal-300:#3E6A72;
  --teal-tint:#E8EFEF;
  --red:#EC1F27;         /* action / accent */
  --red-600:#CF1820;

  /* Neutrals (warm) */
  --paper:#F7F5F1;
  --paper-2:#FBFAF7;
  --white:#FFFFFF;
  --ink:#0E1A1D;
  --slate:#56646A;
  --line:#E2DED6;
  --line-dark:rgba(255,255,255,.16);

  --font-display:'Plus Jakarta Sans',system-ui,sans-serif;
  --font-body:'Inter',Arial,system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--paper-2);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.04;letter-spacing:-.02em;font-weight:700}

.wrap{max-width:1240px;margin:0 auto;padding:0 40px}
@media(max-width:760px){.wrap{padding:0 22px}}

.eyebrow{font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:18px;height:1px;background:currentColor;opacity:.6}

.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;
  font-size:15px;padding:15px 26px;border-radius:2px;transition:.22s ease;cursor:pointer;border:1px solid transparent;
  min-height:48px;letter-spacing:-.01em}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-600);transform:translateY(-1px)}
.btn-teal{background:var(--teal);color:#fff}
.btn-teal:hover{background:var(--teal-700);transform:translateY(-1px)}
.btn-ghost{background:transparent;border-color:currentColor}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-light{background:#fff;color:var(--teal);border-color:var(--line)}
.btn-light:hover{border-color:var(--teal);transform:translateY(-1px)}
.btn .ar{transition:transform .22s ease}
.btn:hover .ar{transform:translateX(3px)}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* ===== Header ===== */
.dimA{--gap:118px}
header.site{position:fixed;top:0;left:0;right:0;z-index:60;transition:.3s ease}
header.site .bar{display:flex;align-items:center;justify-content:space-between;height:84px}
header.site .logo{height:34px;width:auto}
header.site nav.primary{display:flex;align-items:center;gap:34px}
header.site nav.primary a{font-family:var(--font-display);font-weight:600;font-size:15px;color:#fff;opacity:.92;transition:.2s}
header.site nav.primary a:hover{opacity:1}
header.site nav.primary .btn-red{color:#fff;opacity:1}
header.site.solid{background:rgba(251,250,247,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
header.site.solid nav.primary a{color:var(--teal)}
header.site.solid nav.primary .btn-red{color:#fff}
.menu-btn{display:none}
/* On interior (non-home) pages the header is solid from the start */
body.not-home header.site{position:sticky;background:rgba(251,250,247,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
body.not-home header.site nav.primary a{color:var(--teal)}
body.not-home header.site nav.primary .btn-red{color:#fff}

/* Header nav: WP menu may inject ul/li — normalise */
header.site nav.primary ul{list-style:none;display:flex;align-items:center;gap:34px;margin:0;padding:0}
header.site nav.primary li{position:relative}
header.site nav.primary li ul{display:none;position:absolute;top:calc(100% + 12px);left:0;background:#fff;
  border:1px solid var(--line);border-radius:3px;padding:10px 0;min-width:240px;box-shadow:0 18px 40px rgba(7,41,48,.14);gap:0;flex-direction:column;align-items:stretch}
header.site nav.primary li:hover>ul{display:flex}
header.site nav.primary li ul a{color:var(--teal)!important;opacity:1;padding:9px 22px;display:block;font-size:14.5px}
header.site nav.primary li ul a:hover{background:var(--teal-tint)}

/* ===== Hero ===== */
.heroA{position:relative;min-height:100vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.heroA .bg{position:absolute;inset:0;background-position:center 32%;background-size:cover;background-repeat:no-repeat;transform:scale(1.04)}
.heroA .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,41,48,.5) 0%,rgba(7,41,48,.05) 24%,rgba(7,41,48,.1) 52%,rgba(7,41,48,.74) 100%)}
.heroA .inner{position:relative;width:100%;padding-bottom:74px;padding-top:120px}
.heroA .eyebrow{color:#fff;opacity:.94}
.heroA h1{font-size:clamp(40px,5.6vw,84px);font-weight:800;margin:22px 0 0;max-width:19ch;letter-spacing:-.03em}
.heroA .lede{margin-top:24px;max-width:54ch;font-size:18.5px;color:rgba(255,255,255,.92)}
.heroA .cta{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap}
.heroA .meta{position:absolute;right:40px;bottom:74px;text-align:right;font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;color:rgba(255,255,255,.72);line-height:2}
@media(max-width:860px){.heroA .meta{display:none}}

/* ===== Accreditation strip ===== */
.stripA{border-bottom:1px solid var(--line);background:var(--white)}
.stripA .grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stripA .cell{padding:38px 28px 38px 0;border-left:1px solid var(--line)}
.stripA .cell:first-child{border-left:0}
.stripA .cell:not(:first-child){padding-left:30px}
.stripA .cell .n{font-family:var(--font-display);font-weight:800;font-size:clamp(26px,2.6vw,34px);color:var(--teal);letter-spacing:-.02em}
.stripA .cell .l{font-size:13.5px;color:var(--slate);margin-top:6px;max-width:24ch}
@media(max-width:760px){.stripA .grid{grid-template-columns:1fr 1fr}.stripA .cell{padding:24px!important;border-top:1px solid var(--line)}.stripA .cell:nth-child(-n+2){border-top:0}.stripA .cell:nth-child(odd){border-left:0}}

.sec{padding:var(--gap) 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:54px}
.sec-head .eyebrow{color:var(--red)}
.sec-head h2{font-size:clamp(31px,4.2vw,54px);color:var(--teal);max-width:19ch;margin-top:16px}
.sec-head p.sub{color:var(--slate);max-width:40ch;font-size:16.5px}

/* ===== Pathways list ===== */
.svcList{border-top:1px solid var(--line)}
.svc{display:grid;grid-template-columns:64px 1.15fr 1.5fr 120px;gap:30px;align-items:center;
  padding:34px 0;border-bottom:1px solid var(--line);position:relative;transition:.3s}
.svc .idx{font-family:var(--font-mono);font-size:13px;color:var(--red);letter-spacing:.1em}
.svc h3{font-size:26px;color:var(--ink);letter-spacing:-.02em}
.svc .desc{color:var(--slate);font-size:15px}
.svc .thumb{width:120px;height:78px;border-radius:2px;object-fit:cover;justify-self:end}
.svc .go{position:absolute;right:0;top:34px;color:var(--teal);opacity:0;transform:translateX(-6px);transition:.3s}
.svc:hover{background:var(--white)}
.svc:hover h3{color:var(--teal)}
.svc:hover .go{opacity:1;transform:none}
@media(max-width:860px){.svc{grid-template-columns:44px 1fr;gap:8px 16px}.svc .thumb{display:none}.svc .desc{grid-column:2}}

/* ===== Coverage ===== */
.coverA{background:var(--teal);color:#fff;border-radius:3px;overflow:hidden;display:grid;grid-template-columns:1.05fr .95fr}
.coverA .txt{padding:72px 60px}
.coverA .eyebrow{color:#7FB0A8}
.coverA h2{font-size:clamp(30px,3.4vw,44px);margin:18px 0 20px;color:#fff}
.coverA p{color:rgba(255,255,255,.84);max-width:44ch;font-size:16px}
.coverA .regions{display:flex;flex-wrap:wrap;gap:8px;margin-top:30px}
.coverA .regions span{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;padding:7px 12px;border:1px solid var(--line-dark);border-radius:2px;color:rgba(255,255,255,.86)}
.coverA .pic{background-position:center;background-size:cover;background-repeat:no-repeat;min-height:460px;position:relative}
.coverA .pic::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--teal),transparent 30%)}
@media(max-width:860px){.coverA{grid-template-columns:1fr}.coverA .txt{padding:48px 30px}.coverA .pic{min-height:280px}}

/* ===== Why / values ===== */
.whyA{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.whyA .v{padding:50px 28px 50px 0;border-left:1px solid var(--line)}
.whyA .v:first-child{border-left:0}
.whyA .v:not(:first-child){padding-left:30px}
.whyA .v .k{font-family:var(--font-mono);font-size:12px;color:var(--red);letter-spacing:.12em}
.whyA .v h3{font-size:20px;color:var(--teal);margin:16px 0 11px}
.whyA .v p{color:var(--slate);font-size:14.5px}
@media(max-width:860px){.whyA{grid-template-columns:1fr 1fr}.whyA .v{padding:32px 22px 32px 0!important;border-top:1px solid var(--line)}.whyA .v:nth-child(-n+2){border-top:0}.whyA .v:nth-child(odd){border-left:0}.whyA .v:nth-child(even){padding-left:24px!important}}

/* ===== Who we train ===== */
.sectorsA{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.sectorsA .card{position:relative;border-radius:3px;overflow:hidden;aspect-ratio:3/4;color:#fff}
.sectorsA .card img{width:100%;height:100%;object-fit:cover;transition:.6s}
.sectorsA .card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(7,41,48,.84))}
.sectorsA .card .cap{position:absolute;left:22px;right:18px;bottom:20px;z-index:2}
.sectorsA .card .cap h4{font-size:20px;line-height:1.1;font-family:var(--font-display)}
.sectorsA .card .cap p{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;opacity:.85;margin-top:6px}
.sectorsA .card:hover img{transform:scale(1.06)}
@media(max-width:860px){.sectorsA{grid-template-columns:1fr 1fr}}

/* ===== CTA band ===== */
.ctaA{background:var(--paper);border:1px solid var(--line);border-radius:3px;padding:70px 60px;
  display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.ctaA h2{font-size:clamp(28px,3.2vw,44px);color:var(--teal);max-width:18ch}
.ctaA .r{display:flex;gap:14px;flex-wrap:wrap}
.ctaA .ph{font-family:var(--font-mono);font-size:13px;color:var(--slate);margin-top:12px}

/* ===== Footer ===== */
footer.site{background:var(--teal-900);color:#fff;padding:78px 0 38px}
footer.site .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:52px;border-bottom:1px solid var(--line-dark)}
footer.site img.flogo{height:30px;margin-bottom:22px}
footer.site p.about{color:rgba(255,255,255,.66);font-size:14.5px;max-width:34ch}
footer.site .col h5{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;color:#7FB0A8;text-transform:uppercase;margin-bottom:18px}
footer.site .col a{display:block;color:rgba(255,255,255,.8);font-size:14.5px;padding:6px 0;transition:.2s}
footer.site .col a:hover{color:#fff;padding-left:4px}
footer.site .col ul{list-style:none;margin:0;padding:0}
footer.site .bot{display:flex;justify-content:space-between;padding-top:26px;color:rgba(255,255,255,.5);font-size:13px;flex-wrap:wrap;gap:10px}
@media(max-width:860px){footer.site .top{grid-template-columns:1fr 1fr}}

@media(max-width:860px){
  .menu-btn{display:inline-flex;background:none;border:0;color:#fff;font-family:var(--font-mono);font-size:13px;letter-spacing:.1em;cursor:pointer;align-items:center}
  header.site.solid .menu-btn,body.not-home .menu-btn{color:var(--teal)}
  header.site nav.primary{display:none;position:absolute;top:84px;left:0;right:0;background:rgba(251,250,247,.98);
    backdrop-filter:blur(12px);flex-direction:column;align-items:stretch;padding:14px 22px;border-bottom:1px solid var(--line)}
  header.site nav.primary.open{display:flex}
  header.site nav.primary a{color:var(--teal)!important;padding:12px 0}
  header.site nav.primary ul{flex-direction:column;align-items:stretch;gap:0;width:100%}
  header.site nav.primary li ul{display:block;position:static;border:0;box-shadow:none;padding:0 0 0 14px;min-width:0}
}

/* ==========================================================================
   Interior page templates (A: course, B: category, C: support)
   ========================================================================== */
.page-hero{background:var(--teal);color:#fff;padding:140px 0 64px}
.page-hero .eyebrow{color:#7FB0A8}
.page-hero h1{font-size:clamp(32px,4.4vw,58px);color:#fff;margin:18px 0 0;max-width:22ch}
.page-hero .summary{margin-top:20px;max-width:60ch;color:rgba(255,255,255,.9);font-size:17px}
.page-hero .facts{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.page-hero .facts span{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;padding:7px 12px;border:1px solid var(--line-dark);border-radius:2px;color:rgba(255,255,255,.86)}
.page-hero .cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}

.breadcrumbs{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.breadcrumbs a{color:rgba(255,255,255,.7)}
.breadcrumbs a:hover{color:#fff}

/* Course template two-column */
.course-body{padding:72px 0}
.course-grid{display:grid;grid-template-columns:65% 35%;gap:56px;align-items:start}
.course-main h2{font-size:clamp(24px,2.6vw,34px);color:var(--teal);margin:42px 0 16px}
.course-main h2:first-child{margin-top:0}
.course-main h3{font-size:21px;color:var(--ink);margin:30px 0 12px}
.course-main p{margin:0 0 16px;font-size:16.5px;color:#28343a}
.course-main ul,.course-main ol{margin:0 0 18px 22px}
.course-main li{margin:0 0 9px;font-size:16px;color:#28343a}
.course-sidebar{position:sticky;top:104px;display:flex;flex-direction:column;gap:20px}
.fact-box{background:var(--teal-tint);border:1px solid var(--line);border-radius:4px;padding:26px}
.fact-box.sage{background:#ECFDF5}
.fact-box h4{font-size:16px;color:var(--teal);margin-bottom:14px;font-family:var(--font-display)}
.fact-box ul{list-style:none;margin:0;padding:0}
.fact-box li{padding:8px 0;border-bottom:1px solid var(--line);font-size:14.5px;color:var(--slate)}
.fact-box li:last-child{border-bottom:0}
.enquiry-box{background:var(--teal);color:#fff;border-radius:4px;padding:26px}
.enquiry-box h4{color:#fff;margin-bottom:10px}
.enquiry-box a{color:#fff;font-family:var(--font-mono);font-size:14px;display:block;padding:5px 0}
@media(max-width:860px){.course-grid{grid-template-columns:1fr;gap:36px}.course-sidebar{position:static}}

/* Arlo widget reserve */
.arlo-section{background:var(--paper);border-top:1px solid var(--line);padding:72px 0}
.arlo-section h2{font-size:clamp(24px,2.8vw,36px);color:var(--teal);margin-bottom:28px}
.arlo-reserve{min-height:480px;background:var(--white);border:1px dashed var(--line);border-radius:4px;
  display:flex;align-items:center;justify-content:center;color:var(--slate);font-family:var(--font-mono);font-size:13px}

/* Category hub card grid */
.cat-intro{padding:64px 0 0}
.cat-intro p{font-size:17px;color:#28343a;max-width:74ch;margin:0 auto 16px}
.course-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;padding:48px 0}
.course-card{border:1px solid var(--line);border-radius:4px;background:#fff;padding:30px;transition:.25s;display:flex;flex-direction:column}
.course-card:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:0 16px 36px rgba(7,41,48,.08)}
.course-card h3{font-size:20px;color:var(--teal);margin-bottom:10px}
.course-card p{font-size:15px;color:var(--slate);flex:1;margin-bottom:18px}
.course-card .view{font-family:var(--font-display);font-weight:600;font-size:14.5px;color:var(--red);display:inline-flex;gap:8px;align-items:center}
@media(max-width:860px){.course-cards{grid-template-columns:1fr}}

.regulatory{background:var(--white);border-top:1px solid var(--line);padding:72px 0}
.regulatory .wrap{max-width:880px}
.regulatory h2{font-size:clamp(24px,2.6vw,32px);color:var(--teal);margin:0 0 18px}
.regulatory p{font-size:16.5px;color:#28343a;margin:0 0 16px}

/* Support template with left sidebar */
.support-grid{display:grid;grid-template-columns:280px 1fr;gap:56px;padding:64px 0;align-items:start}
.support-nav{position:sticky;top:104px}
.support-nav h5{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.support-nav ul{list-style:none;margin:0;padding:0}
.support-nav a{display:block;padding:11px 16px;border-radius:3px;color:var(--ink);font-size:15px;border:1px solid transparent}
.support-nav a:hover{background:var(--teal-tint)}
.support-nav a.active{background:var(--teal);color:#fff}
.support-main h2{font-size:clamp(24px,2.6vw,32px);color:var(--teal);margin:34px 0 14px}
.support-main h2:first-child{margin-top:0}
.support-main p{font-size:16.5px;color:#28343a;margin:0 0 16px}
.support-main ul,.support-main ol{margin:0 0 18px 22px}
.support-main li{margin:0 0 9px;font-size:16px;color:#28343a}
.download-list{list-style:none!important;margin:24px 0!important}
.download-list li{padding:0!important;margin:0 0 12px!important}
.download-list a{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#ECFDF5;border:1px solid var(--line);border-radius:4px;color:var(--teal);font-weight:600;font-family:var(--font-display)}
.download-list a:hover{border-color:var(--teal)}
@media(max-width:860px){.support-grid{grid-template-columns:1fr;gap:32px}.support-nav{position:static}}

/* Default page (legal etc.) */
.basic-page{padding:64px 0 96px}
.basic-page .wrap{max-width:820px}
.basic-page h2{font-size:28px;color:var(--teal);margin:34px 0 14px}
.basic-page h3{font-size:20px;color:var(--ink);margin:24px 0 10px}
.basic-page p{font-size:16.5px;color:#28343a;margin:0 0 16px}
.basic-page ul,.basic-page ol{margin:0 0 18px 22px}
.basic-page li{margin:0 0 9px;font-size:16px}

/* WPBakery container alignment with theme wrap */
.wpb_row .wrap, .vc_row .wrap{padding:0}
