
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#1B2A4A;--teal:#2E7D82;--gold:#B8860B;
  --light:#EAF2F3;--cream:#FDFAF5;--grey:#F5F5F5;
  --text:#1a1a1a;--mid:#555;--lgrey:#ddd;--white:#fff;
}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--text);background:#fff;font-size:16px;line-height:1.65;padding-top:98px}

/* ── Banner ── */
.preview-banner{background:var(--gold);color:#fff;text-align:center;padding:.5rem 1rem;font-size:.73rem;font-weight:700;letter-spacing:.06em;position:fixed;top:0;left:0;right:0;z-index:300}

/* ── Nav ── */
nav{position:fixed;top:34px;left:0;right:0;z-index:200;background:#fff;border-bottom:1px solid #e8e8e8;height:64px;display:flex;align-items:center;padding:0 2.5rem;justify-content:space-between;gap:1rem}
.nav-brand{font-family:'Lora',serif;font-weight:700;font-size:1rem;color:var(--navy);text-decoration:none;flex-shrink:0;white-space:nowrap}
.nav-menu{display:flex;list-style:none;height:64px;flex-wrap:nowrap}
.has-dropdown{position:relative;height:100%}
.nav-link{display:flex;align-items:center;height:100%;padding:0 .9rem;font-size:.8rem;font-weight:500;color:var(--mid);text-decoration:none;white-space:nowrap;gap:.25rem;transition:color .18s;border-bottom:2px solid transparent}
.nav-link:hover,.nav-link.active{color:var(--teal);border-bottom-color:var(--teal)}
.caret{font-size:.58rem;opacity:.55}
.dropdown{display:none;position:absolute;top:64px;left:0;background:#fff;border:1px solid #e8e8e8;border-top:2px solid var(--teal);min-width:250px;box-shadow:0 6px 24px rgba(0,0,0,.1);z-index:400}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{display:block}
.dropdown a{display:block;padding:.6rem 1.25rem;font-size:.8rem;color:var(--mid);text-decoration:none;transition:background .14s,color .14s}
.dropdown a:hover{background:var(--light);color:var(--teal)}
.dd-label{padding:.5rem 1.25rem .15rem;font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);pointer-events:none}
.dd-divider{height:1px;background:#f0f0f0;margin:.25rem 0}

/* ── Containers ── */
.container{max-width:900px;margin:0 auto;padding:0 2rem}
.container-wide{max-width:1160px;margin:0 auto;padding:0 2rem}

/* ── Type ── */
.section-label{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:.6rem}
.section-heading{font-family:'Lora',serif;font-size:clamp(1.5rem,3vw,2.1rem);font-weight:700;color:var(--navy);line-height:1.25;margin-bottom:1rem}
.section-sub{font-size:.95rem;color:var(--mid);line-height:1.75}
.divider{width:44px;height:3px;background:var(--teal);margin:1.25rem 0}
.divider.center{margin:1.25rem auto}
.text-center{text-align:center}
.text-center .section-sub{margin:0 auto}

/* ── Hero variants ── */
.hero-main{background:var(--navy);padding:6.5rem 2rem 5.5rem;text-align:center}
.hero-inner{background:var(--navy);padding:4.5rem 2rem 3.5rem}
.hero-inner.center{text-align:center}
.hero-eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:1.1rem}
.hero-h1{font-family:'Lora',serif;font-size:clamp(1.9rem,5vw,3.1rem);font-weight:700;color:#fff;line-height:1.2;max-width:760px;margin:0 auto 1.1rem}
.hero-inner .hero-h1{font-size:clamp(1.7rem,4vw,2.4rem);margin-left:0}
.hero-sub{font-size:.97rem;color:rgba(255,255,255,.7);max-width:620px;margin:0 auto 1rem;line-height:1.8}
.hero-inner .hero-sub{margin-left:0}
.hero-byline{font-size:.76rem;color:rgba(255,255,255,.36);letter-spacing:.04em;margin-bottom:2rem}

/* ── Buttons ── */
.btn-row{display:flex;gap:.875rem;flex-wrap:wrap;margin-top:1.75rem}
.btn-row.center{justify-content:center}
.btn{display:inline-block;padding:.68rem 1.5rem;font-size:.8rem;font-weight:600;letter-spacing:.04em;text-decoration:none;cursor:pointer;transition:all .18s;border:none;border-radius:2px;white-space:nowrap}
.btn-primary{background:var(--teal);color:#fff}.btn-primary:hover{background:#256669}
.btn-outline-light{background:transparent;color:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.3)}.btn-outline-light:hover{border-color:rgba(255,255,255,.7);color:#fff}
.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover{background:#142038}
.btn-teal-out{background:transparent;color:var(--teal);border:1.5px solid var(--teal)}.btn-teal-out:hover{background:var(--teal);color:#fff}
.btn-gold{background:var(--gold);color:#fff}.btn-gold:hover{background:#9a7009}
.btn-sm{padding:.48rem 1rem;font-size:.76rem}

/* ── Sections ── */
.section{padding:4.5rem 0}
.section.tight{padding:3rem 0}
.section.alt{background:var(--grey)}
.section.cream{background:var(--cream)}
.section.light{background:var(--light)}
.section.dark{background:var(--navy)}

/* ── Cards ── */
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.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(200px,1fr));gap:1px;background:var(--lgrey);border:1px solid var(--lgrey)}
.card{border:1px solid #e8e8e8;padding:1.75rem;transition:box-shadow .2s,border-color .2s;text-decoration:none;display:block;color:inherit}
.card:hover{border-color:var(--teal);box-shadow:0 2px 16px rgba(46,125,130,.1)}
.card-tag{font-size:.67rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin-bottom:.55rem}
.card-title{font-family:'Lora',serif;font-size:1.02rem;font-weight:600;color:var(--navy);margin-bottom:.5rem;line-height:1.3}
.card-desc{font-size:.86rem;color:var(--mid);line-height:1.65;margin-bottom:.875rem}
.card-date{font-size:.73rem;color:#bbb}

/* ── Pillar cards ── */
.pillar-card{background:#fff;padding:1.75rem 1.5rem}
.pillar-num{font-size:.67rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:.4rem}
.pillar-name{font-family:'Lora',serif;font-size:.95rem;font-weight:700;color:var(--navy);margin-bottom:.6rem;line-height:1.3}
.pillar-desc{font-size:.84rem;color:var(--mid);line-height:1.6}

/* ── Resource pages ── */
.resource-header{background:var(--navy);padding:4.5rem 2rem 3.5rem}
.resource-meta{display:flex;gap:.875rem;flex-wrap:wrap;margin-bottom:1.1rem;align-items:center}
.rbadge{display:inline-block;padding:.28rem .78rem;font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;border-radius:1px}
.rbadge-brief{background:rgba(46,125,130,.2);color:var(--teal);border:1px solid rgba(46,125,130,.35)}
.rbadge-book{background:rgba(184,134,11,.15);color:var(--gold);border:1px solid rgba(184,134,11,.3)}
.rbadge-guide{background:rgba(255,255,255,.1);color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.2)}
.rbadge-available{background:rgba(46,125,58,.2);color:#2e8040;border:1px solid rgba(46,125,58,.3)}
.rbadge-soon{background:rgba(46,125,130,.15);color:var(--teal);border:1px solid rgba(46,125,130,.3)}
.rbadge-dev{background:rgba(0,0,0,.1);color:#999;border:1px solid #ddd}
.resource-title{font-family:'Lora',serif;font-size:clamp(1.6rem,4vw,2.3rem);font-weight:700;color:#fff;line-height:1.25;margin-bottom:.875rem}
.resource-desc{font-size:.97rem;color:rgba(255,255,255,.7);max-width:660px;line-height:1.8}

/* ── Resource body ── */
.resource-body{padding:3rem 0}
.callout{padding:1.6rem 1.875rem;border-left:4px solid var(--teal);background:var(--light);margin:1.5rem 0}
.callout-title{font-weight:700;color:var(--navy);margin-bottom:.45rem;font-size:.93rem}
.callout-text{font-size:.88rem;color:#444;line-height:1.72}
.info-table{width:100%;border-collapse:collapse;margin:1.5rem 0}
.info-table td{padding:.8rem 1rem;font-size:.88rem;border-bottom:1px solid #f0f0f0;vertical-align:top}
.info-table tr:first-child td{border-top:1px solid #f0f0f0}
.info-table .info-label{font-weight:700;color:var(--navy);background:var(--grey);width:170px;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}
.contents-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.4rem .75rem;margin-top:1rem}
.contents-list li{font-size:.86rem;color:#444;padding:.3rem 0;border-bottom:1px solid #f5f5f5;display:flex;align-items:flex-start;gap:.45rem}
.contents-list li::before{content:"→";color:var(--teal);flex-shrink:0;font-weight:700;font-size:.72rem;margin-top:.15rem}

/* ── Hub cards (overview pages) ── */
.hub-card{border:1px solid #e8e8e8;overflow:hidden;transition:box-shadow .2s,border-color .2s;text-decoration:none;display:block;color:inherit;margin-bottom:1.25rem}
.hub-card:hover{border-color:var(--teal);box-shadow:0 4px 20px rgba(46,125,130,.1)}
.hub-card-header{background:var(--navy);padding:1.1rem 1.5rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}
.hub-card-num{font-size:.67rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin-bottom:.25rem}
.hub-card-title{font-family:'Lora',serif;font-size:.93rem;font-weight:600;color:#fff;line-height:1.3}
.hub-card-body{padding:1.1rem 1.5rem;display:flex;justify-content:space-between;align-items:flex-end;gap:1rem}
.hub-card-desc{font-size:.86rem;color:var(--mid);line-height:1.6;flex:1}
.hub-card-cta{font-size:.76rem;font-weight:600;color:var(--teal);white-space:nowrap;flex-shrink:0}

/* ── About ── */
.about-grid{display:grid;grid-template-columns:1fr 290px;gap:4.5rem;align-items:start}
.photo-block{background:linear-gradient(135deg,#2c3e5a,var(--navy));aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.75rem;color:rgba(255,255,255,.25);font-size:.77rem;text-align:center;border:1px dashed rgba(255,255,255,.12);padding:2rem;border-radius:2px}
.accred-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(46,125,130,.2);border:1px solid rgba(46,125,130,.4);border-radius:2px;padding:.38rem .85rem;font-size:.74rem;font-weight:700;color:var(--teal);letter-spacing:.05em;margin-bottom:1.5rem}
.about-section{padding:3rem 0;border-bottom:1px solid #eee}
.about-section:last-child{border-bottom:none}
.about-section p{font-size:.95rem;color:#333;line-height:1.85;margin-bottom:1rem}
.about-section p:last-child{margin-bottom:0}
@media(max-width:700px){.about-grid{grid-template-columns:1fr}.photo-block{aspect-ratio:4/3;max-width:280px}}

/* ── Articles ── */
.article-row{border-bottom:1px solid #eee;padding:2rem 0;text-decoration:none;display:block;color:inherit;transition:padding-left .18s}
.article-row:first-child{padding-top:0}
.article-row:hover{padding-left:.5rem}
.article-row:hover .art-title{color:var(--teal)}
.art-meta{display:flex;gap:.875rem;align-items:center;margin-bottom:.45rem;flex-wrap:wrap}
.art-title{font-family:'Lora',serif;font-size:1.12rem;font-weight:600;color:var(--navy);margin-bottom:.35rem;line-height:1.35;transition:color .18s}
.art-excerpt{font-size:.87rem;color:var(--mid);line-height:1.7}

/* ── Contact ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:4.5rem}
.enq-item{display:flex;gap:.875rem;padding:1rem 0;border-bottom:1px solid #eee;align-items:flex-start}
.enq-icon{width:30px;height:30px;background:var(--light);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.1rem}
.enq-icon svg{width:13px;height:13px;color:var(--teal)}
.enq-label{font-size:.73rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);margin-bottom:.2rem}
.enq-desc{font-size:.84rem;color:var(--mid);line-height:1.6}
.form-wrap{background:var(--grey);padding:2.25rem}
.form-row{margin-bottom:1.1rem}
.form-row label{display:block;font-size:.73rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--navy);margin-bottom:.35rem}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:.65rem .875rem;border:1px solid #ddd;background:#fff;font-family:'Inter',sans-serif;font-size:.88rem;color:var(--text);outline:none;border-radius:1px;transition:border-color .2s}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--teal)}
.form-row textarea{resize:vertical;min-height:130px}
.form-note{font-size:.76rem;color:#aaa;margin-top:.875rem}
@media(max-width:700px){.contact-grid{grid-template-columns:1fr}}

/* ── Iframe embed ── */
.iframe-wrap{margin-top:2.5rem}
.iframe-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;background:var(--navy);border-radius:2px 2px 0 0;flex-wrap:wrap;gap:.5rem}
.iframe-toolbar span{font-size:.75rem;color:rgba(255,255,255,.6);font-weight:500}
.iframe-wrap iframe{width:100%;height:82vh;border:1px solid var(--lgrey);border-top:none;display:block}

/* ── Series strip ── */
.series-strip{background:var(--light);border-left:4px solid var(--teal);padding:2.5rem 3rem;margin:2.5rem 0}

/* ── Footer CTA ── */
.footer-cta{background:var(--navy);padding:3rem 2rem;text-align:center}
.footer-cta p{color:rgba(255,255,255,.65);font-size:.93rem;margin-bottom:1.1rem}

/* ── Site footer ── */
.site-footer{background:#111827;padding:2.25rem 2rem;text-align:center}
.footer-nav{display:flex;gap:1.25rem;justify-content:center;margin-bottom:1rem;flex-wrap:wrap}
.footer-nav a{font-size:.77rem;color:rgba(255,255,255,.4);text-decoration:none}.footer-nav a:hover{color:rgba(255,255,255,.75)}
.footer-copy{font-size:.74rem;color:rgba(255,255,255,.28)}

/* ── Docx note ── */
.docx-note{background:#fffbea;border:1px solid #f0d060;border-radius:2px;padding:1.25rem 1.5rem;margin-top:2rem;display:flex;gap:1rem;align-items:flex-start}
.docx-note p{font-size:.85rem;color:#555;line-height:1.6}
.docx-note strong{color:var(--navy)}

/* ── Breadcrumb ── */
.breadcrumb{font-size:.78rem;color:rgba(255,255,255,.45);margin-bottom:.875rem}
.breadcrumb a{color:rgba(255,255,255,.55);text-decoration:none}.breadcrumb a:hover{color:rgba(255,255,255,.85)}
.breadcrumb span{margin:0 .4rem}
