
:root{
  --bg:#FBF7EE; --fg:#2A1212; --card:#FFFFFF; --muted:#5C4A48; --muted-bg:#F1ECDF;
  --border:#E3DBC8; --primary:#67101A; --primary-2:#8C1E2C; --accent:#E0A53A; --accent-soft:#F6E1B8;
  --shadow-elegant:0 24px 60px -24px rgba(67,9,16,.35);
  --shadow-soft:0 8px 28px -12px rgba(40,15,15,.18);
  --radius:6px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--fg);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5{font-family:'Fraunces',Georgia,serif;font-weight:500;letter-spacing:-.02em;line-height:1.1}
.container{max-width:1240px;margin:0 auto;padding:0 24px}
@media(min-width:1024px){.container{padding:0 40px}}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--primary)}
.eyebrow::before{content:"";display:inline-block;width:32px;height:1px;background:var(--accent)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:var(--radius);font-weight:600;font-size:14px;border:1px solid transparent;cursor:pointer;transition:all .25s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-2)}
.btn-outline{border-color:var(--border);background:transparent;color:var(--fg)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-hero{background:var(--accent);color:#2A1212}
.btn-hero:hover{background:#cf9530}
.btn-hero-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-hero-outline:hover{background:rgba(255,255,255,.1)}
.btn-lg{padding:16px 28px;font-size:15px}
/* Header */
header.site{position:fixed;top:0;left:0;right:0;z-index:50;transition:all .4s;background:rgba(251,247,238,.88);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
header.site.transparent{background:transparent;border-color:transparent}
header.site .row{height:80px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{width:44px;height:44px;display:grid;place-items:center;background:var(--primary);color:#fff;border-radius:var(--radius);font-family:'Fraunces',serif;font-weight:600}
header.site.transparent .brand .mark{background:rgba(255,255,255,.18);backdrop-filter:blur(8px);color:#fff}
.brand .name{font-family:'Fraunces',serif;font-size:16px;font-weight:600;line-height:1.1}
.brand .sub{font-size:10px;letter-spacing:.22em;text-transform:uppercase;opacity:.65;margin-top:2px}
header.site.transparent .brand{color:#fff}
nav.main{display:none;gap:4px}
@media(min-width:1024px){nav.main{display:flex}}
nav.main a{padding:10px 16px;font-size:14px;font-weight:500;opacity:.85;transition:color .2s;position:relative}
nav.main a:hover,nav.main a.active{color:var(--primary);opacity:1}
header.site.transparent nav.main a{color:rgba(255,255,255,.9)}
header.site.transparent nav.main a:hover,header.site.transparent nav.main a.active{color:#fff}
.menu-btn{display:grid;place-items:center;width:40px;height:40px;background:transparent;border:0;cursor:pointer;color:inherit}
@media(min-width:1024px){.menu-btn{display:none}}
.header-cta{display:none}
@media(min-width:1024px){.header-cta{display:block}}
.mobile-nav{display:none;border-top:1px solid var(--border);background:var(--bg)}
.mobile-nav.open{display:block}
.mobile-nav .container{padding:24px}
.mobile-nav a{display:block;padding:14px;border-radius:var(--radius);font-weight:500}
.mobile-nav a.active{background:var(--primary);color:#fff}
/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(67,9,16,.85),rgba(103,16,26,.55) 60%,rgba(224,165,58,.25));z-index:-1}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(67,9,16,.95),rgba(67,9,16,.4),transparent);z-index:-1}
.hero .container{position:relative;padding-top:140px;padding-bottom:90px}
.hero .tag{font-size:12px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:24px;display:inline-flex;gap:12px;align-items:center}
.hero .tag::before{content:"";width:32px;height:1px;background:var(--accent)}
.hero h1{font-size:clamp(2.75rem,7vw,5.5rem);font-weight:500;max-width:1100px;line-height:.98}
.hero h1 em{color:var(--accent);font-style:italic;font-weight:400}
.hero .lead{margin-top:32px;max-width:640px;font-size:18px;color:rgba(255,255,255,.82);line-height:1.6}
.hero .ctas{margin-top:40px;display:flex;flex-wrap:wrap;gap:16px}
.stats{margin-top:64px;display:grid;grid-template-columns:repeat(2,1fr);gap:32px;max-width:720px}
@media(min-width:768px){.stats{grid-template-columns:repeat(4,1fr)}}
.stats .stat{border-left:1px solid rgba(224,165,58,.4);padding-left:16px}
.stats .v{font-family:'Fraunces',serif;font-size:32px;font-weight:500}
.stats .l{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:4px}
/* Marquee */
.marquee{background:var(--primary);color:#fff;border-top:1px solid rgba(224,165,58,.25);border-bottom:1px solid rgba(224,165,58,.25);overflow:hidden}
.marquee .track{display:flex;gap:48px;white-space:nowrap;padding:16px 0;animation:marq 30s linear infinite;font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.8)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
/* Sections */
section.sec{padding:96px 0}
.sec.alt{background:var(--muted-bg)}
.sec.dark{background:linear-gradient(180deg,#67101A,#48090F);color:#fff;position:relative;overflow:hidden}
.sec.dark .eyebrow{color:var(--accent)}
.sec.dark .eyebrow::before{background:var(--accent)}
.section-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:56px}
.section-head h2{font-size:clamp(2rem,4vw,3rem);font-weight:500;max-width:680px}
.grid{display:grid;gap:24px}
.cols-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.cols-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.cols-4{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .3s}
.card:hover{box-shadow:var(--shadow-elegant);border-color:var(--primary)}
/* Quick links */
.qlink{padding:20px;display:block;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:all .25s}
.qlink:hover{border-color:var(--primary);box-shadow:var(--shadow-elegant)}
.qlink .ico{font-size:18px;color:var(--accent)}
.qlink .label{margin-top:24px;font-size:14px;font-weight:600}
.qlink .arrow{margin-top:12px;font-size:16px;color:var(--muted);transition:transform .2s}
.qlink:hover .arrow{transform:translateX(4px);color:var(--primary)}
/* Course card */
.course .img{aspect-ratio:4/3;overflow:hidden;position:relative}
.course .img img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.course:hover .img img{transform:scale(1.05)}
.dept-tag{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);padding:4px 12px;border-radius:var(--radius);font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--primary)}
.course .body{padding:24px}
.course h3{font-size:20px;line-height:1.3}
.course .blurb{margin-top:12px;font-size:14px;color:var(--muted)}
.course .levels{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}
.course .levels .label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--primary);margin-bottom:12px}
.course .levels li{font-size:12px;list-style:none;margin-bottom:10px}
.course .levels li b{color:var(--fg);display:block;margin-bottom:2px}
.course .levels li span{color:var(--muted);margin-right:14px}
.course .levels li span em{color:var(--fg);font-style:normal;opacity:.75}
.careers{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.careers li{list-style:none;font-size:11px;padding:4px 10px;border-radius:var(--radius);background:var(--muted-bg);border:1px solid var(--border)}
/* Filter buttons */
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:48px;align-items:center}
.filters .lbl{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-right:8px}
.filters button{padding:8px 16px;font-size:13px;border-radius:var(--radius);border:1px solid var(--border);background:transparent;cursor:pointer;color:var(--fg);transition:all .2s;font-family:inherit}
.filters button:hover{border-color:var(--primary)}
.filters button.active{background:var(--primary);color:#fff;border-color:var(--primary)}
/* Principal */
.principal{display:grid;gap:48px;align-items:center}
@media(min-width:1024px){.principal{grid-template-columns:5fr 7fr}}
.principal .photo{position:relative;max-width:420px;margin:0 auto}
.principal .photo::before{content:"";position:absolute;inset:-16px;background:rgba(224,165,58,.3);border-radius:var(--radius);transform:translate(16px,16px);z-index:-1}
.principal .photo img{aspect-ratio:4/5;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-elegant);width:100%}
.principal h2{font-size:clamp(1.5rem,3vw,2.25rem)}
.principal p{color:var(--muted);margin-top:16px;font-size:16px}
.principal .sig{margin-top:32px}
.principal .sig b{font-family:'Fraunces',serif;font-size:18px;display:block}
.principal .sig span{font-size:14px;color:var(--muted)}
/* Why */
.feat{border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:all .25s}
.feat:hover{border-color:var(--primary);box-shadow:var(--shadow-soft)}
.feat .ico{width:48px;height:48px;display:grid;place-items:center;background:var(--accent-soft);color:var(--primary);border-radius:var(--radius);font-size:18px}
.feat h3{margin-top:24px;font-size:20px}
.feat p{margin-top:12px;font-size:14px;color:var(--muted)}
/* News */
.news-feature{display:grid;gap:24px;margin-bottom:48px}
@media(min-width:1024px){.news-feature{grid-template-columns:7fr 5fr}}
.news-feature .img{aspect-ratio:16/10;overflow:hidden;border-radius:var(--radius)}
.news-feature .img img{width:100%;height:100%;object-fit:cover}
.news-feature h2{font-size:clamp(1.75rem,3.5vw,3rem);margin-top:20px}
.news-meta{display:flex;align-items:center;gap:12px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.news-meta .tag{color:var(--accent);font-weight:600}
.news-card .img{aspect-ratio:16/10;overflow:hidden}
.news-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.news-card:hover .img img{transform:scale(1.05)}
.news-card .body{padding:24px}
.news-card h3{margin-top:12px;font-size:18px;line-height:1.3}
.news-card p{margin-top:8px;font-size:13px;color:var(--muted)}
/* Adverts */
.advert{padding:28px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:all .25s;display:flex;gap:20px;align-items:flex-start}
.advert:hover{border-color:var(--primary);box-shadow:var(--shadow-elegant)}
.advert .ico{width:48px;height:48px;display:grid;place-items:center;background:var(--accent-soft);color:var(--primary);border-radius:var(--radius);flex-shrink:0;font-size:18px}
.advert .type{font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--accent)}
.advert h3{margin-top:8px;font-size:18px}
.advert .meta{margin-top:14px;display:flex;flex-wrap:wrap;gap:18px;font-size:12px;color:var(--muted)}
.advert .meta b{font-family:ui-monospace,monospace;color:var(--fg);font-weight:500}
/* Page hero */
.page-hero{position:relative;background:linear-gradient(135deg,#67101A,#48090F);color:#fff;padding:160px 0 80px;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(224,165,58,.2),transparent 70%)}
.page-hero .eyebrow{color:var(--accent)}
.page-hero h1{font-size:clamp(2.5rem,5vw,4rem);max-width:900px;margin-top:24px}
.page-hero p{margin-top:24px;max-width:640px;font-size:18px;color:rgba(255,255,255,.78)}
/* About */
.about-grid{display:grid;gap:48px}
@media(min-width:1024px){.about-grid{grid-template-columns:7fr 5fr}}
.about-grid p{color:var(--muted);margin-bottom:16px}
.about-grid .photo{position:relative;aspect-ratio:4/5}
.about-grid .photo::before{content:"";position:absolute;inset:-16px;background:rgba(224,165,58,.25);border-radius:var(--radius);transform:translate(16px,16px);z-index:-1}
.about-grid .photo img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-elegant)}
.value{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px}
.value .ico{width:48px;height:48px;display:grid;place-items:center;background:var(--primary);color:#fff;border-radius:var(--radius);font-size:18px}
.value h3{margin-top:24px;font-size:22px}
.value p{margin-top:12px;color:var(--muted)}
.leader{border-left:2px solid var(--accent);padding:4px 0 4px 16px}
.leader b{font-family:'Fraunces',serif;font-size:16px;display:block}
.leader span{font-size:14px;color:var(--muted)}
/* Contact */
.contact-grid{display:grid;gap:48px}
@media(min-width:1024px){.contact-grid{grid-template-columns:5fr 7fr}}
.cinfo{display:flex;gap:20px;margin-bottom:32px}
.cinfo .ico{width:44px;height:44px;display:grid;place-items:center;background:var(--accent-soft);color:var(--primary);border-radius:var(--radius);flex-shrink:0;font-size:16px}
.cinfo b{font-family:'Fraunces',serif;display:block}
.cinfo span{display:block;font-size:14px;color:var(--muted);margin-top:4px;white-space:pre-line}
form.contact{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-soft)}
.fgrid{display:grid;gap:20px;grid-template-columns:1fr;margin-bottom:20px}
@media(min-width:640px){.fgrid{grid-template-columns:1fr 1fr}}
form.contact label{display:block;font-size:14px;font-weight:500;margin-bottom:8px}
form.contact input,form.contact textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);font-family:inherit;font-size:14px;color:var(--fg)}
form.contact input:focus,form.contact textarea:focus{outline:2px solid var(--primary);outline-offset:-1px}
.map{aspect-ratio:16/8;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-soft)}
.map iframe{width:100%;height:100%;border:0}
/* CTA */
.cta-final{position:relative;padding:96px 0;background:linear-gradient(180deg,#67101A,#48090F);color:#fff;overflow:hidden}
.cta-final .container{display:grid;gap:40px;position:relative}
@media(min-width:1024px){.cta-final .container{grid-template-columns:8fr 4fr;align-items:center}}
.cta-final h2{font-size:clamp(2rem,4vw,3.5rem)}
.cta-final p{margin-top:24px;color:rgba(255,255,255,.8);max-width:540px}
.cta-final .stack{display:flex;flex-direction:column;gap:12px}
.cta-final .stack .btn{width:100%;justify-content:center}
.cta-final .addr{margin-top:8px;text-align:center;font-size:13px;color:rgba(255,255,255,.7)}
/* Footer */
footer.site{background:linear-gradient(180deg,#5C0E18,#3A070D);color:#fff;padding:80px 0 32px}
footer.site .top{display:grid;gap:48px}
@media(min-width:1024px){footer.site .top{grid-template-columns:4fr 2fr 3fr 3fr}}
footer.site h4{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;font-weight:600;font-family:'Inter',sans-serif}
footer.site ul{list-style:none;display:flex;flex-direction:column;gap:12px}
footer.site a{font-size:14px;color:rgba(255,255,255,.78);transition:color .2s}
footer.site a:hover{color:var(--accent)}
footer.site .social{display:flex;gap:12px;margin-top:20px}
footer.site .social a{width:36px;height:36px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius)}
footer.site .social a:hover{background:var(--accent);color:#2A1212;border-color:var(--accent)}
footer.site .bottom{margin-top:64px;padding-top:32px;border-top:1px solid rgba(255,255,255,.15);display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;font-size:12px;color:rgba(255,255,255,.6)}
.intake{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;display:flex;justify-content:space-between;align-items:center}
.intake b{font-family:'Fraunces',serif;font-size:20px;display:block}
.intake span{font-size:14px;color:var(--muted);margin-top:4px;display:block}
