:root{
  --maroon:#7A1F2B; --maroon-deep:#5C1620; --gold:#D4AF37; --gold-soft:#E6C766;
  --charcoal:#222222; --cream:#FBF8F2; --bg:#FEFCF8; --fg:#1a1411;
  --muted:#6b6258; --border:#e7ddd0; --white:#fff;
  --shadow-card:0 4px 18px -8px rgba(92,22,32,.18);
  --shadow-elegant:0 20px 50px -25px rgba(92,22,32,.45);
  --gradient-hero:linear-gradient(135deg,#5C1620 0%,#7A1F2B 55%,#8E2533 100%);
  --gradient-gold:linear-gradient(135deg,#E6C766,#C9A02C);
  --serif:'Playfair Display',Georgia,serif; --sans:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden;max-width:100%}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.5}
h1,h2,h3,h4{font-family:var(--serif);letter-spacing:-.01em;font-weight:700;color:var(--charcoal)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul,ol{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* Inline SVG icons */
.ic{width:1rem;height:1rem;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;display:inline-block;vertical-align:middle}
.ic-md{width:1.25rem;height:1.25rem}
.ic-lg{width:1.5rem;height:1.5rem}
.ic-gold{color:var(--gold)}

.container{width:100%;max-width:1200px;margin-inline:auto;padding-inline:1.25rem}
.section{padding:4rem 0}
@media(min-width:768px){.section{padding:6rem 0}}
@media(min-width:1024px){.section{padding:7rem 0}}
.section.cream{background:var(--cream)}
.section.dark{background:var(--charcoal);color:#fff}
.section.dark h2,.section.dark h3{color:#fff}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--maroon)}
.eyebrow-gold{color:var(--gold)}
.section-title{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.5rem);color:var(--maroon);margin-top:.75rem;line-height:1.15}
.section.dark .section-title{color:#fff}
.gold-rule{display:block;width:56px;height:3px;background:var(--gradient-gold);border-radius:999px;margin-top:1rem}
.section-header{max-width:640px;margin-bottom:2.5rem}
.section-header p{margin-top:1.25rem;font-size:1rem;color:var(--muted);line-height:1.7}
.section.dark .section-header p{color:rgba(255,255,255,.75)}
.muted{color:var(--muted)}
.small{font-size:.875rem}

/* Navbar */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:all .3s; background-color: white;}
.nav.scrolled{background:rgba(254,252,248,.92);backdrop-filter:blur(8px);box-shadow:0 2px 20px -12px rgba(0,0,0,.2);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:4.5rem;min-width:0}
@media(min-width:768px){.nav-inner{height:5rem}}
.brand{display:flex;align-items:center;gap:.75rem;min-width:0;flex:1}
.brand img{height:40px;width:40px;object-fit:contain;flex-shrink:0}
@media(min-width:768px){.brand img{height:48px;width:48px}}
.brand-text{min-width:0}
.brand .name{font-family:var(--serif);font-weight:700;color:var(--maroon);font-size:.85rem;line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(min-width:480px){.brand .name{font-size:1rem;white-space:normal}}
.brand .motto{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.nav-links{display:none;align-items:center;gap:1.5rem}
.nav-links a{font-size:.875rem;font-weight:500;color:rgba(26,20,17,.8)}
.nav-links a:hover{color:var(--maroon)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:999px;padding:.625rem 1.1rem;font-size:.875rem;font-weight:600;transition:all .2s;text-align:center}
.btn-primary{background:var(--maroon);color:#fff}
.btn-primary:hover{background:var(--maroon-deep)}
.btn-light{background:#fff;color:var(--maroon);box-shadow:var(--shadow-elegant)}
.btn-light:hover{background:var(--gold);color:var(--charcoal)}
.btn-outline{border:1px solid rgba(255,255,255,.4);color:#fff}
.btn-outline:hover{background:rgba(255,255,255,.1)}
.btn-lg{padding:.85rem 1.4rem}
.btn-block{width:100%}
.menu-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;border-radius:.375rem;color:var(--charcoal);flex-shrink:0}
.menu-btn .ic{width:1.5rem;height:1.5rem}
@media(min-width:1024px){.nav-links{display:flex} .menu-btn{display:none}}
.mobile-menu{display:none;background:#fff;border-top:1px solid var(--border);padding-block:.5rem 1rem}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:.75rem 0;font-size:.9rem;font-weight:500;border-bottom:1px solid rgba(231,221,208,.6)}
.mobile-menu .btn{display:flex;margin-top:1rem}

/* Hero */
.hero{position:relative;overflow:hidden;color:#fff;width:100%; padding: 30px;}
.hero-bg{position:absolute;inset:0;background:var(--gradient-hero)}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.2;mix-blend-mode:overlay}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 60%,rgba(92,22,32,.6))}
.hero-inner{position:relative;display:grid;gap:2.5rem;align-items:center;padding:7rem 0 4rem}
@media(min-width:1024px){.hero-inner{grid-template-columns:1.2fr 1fr;gap:4rem;padding:10rem 0 7rem}}
.hero-copy{min-width:0}
.tag{display:inline-flex;align-items:center;gap:.5rem;border:1px solid rgba(212,175,55,.5);background:rgba(255,255,255,.05);backdrop-filter:blur(4px);padding:.3rem .9rem;border-radius:999px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.2em;color:var(--gold-soft)}
.hero h1{font-size:clamp(1.85rem,6vw,3.75rem);color:#fff;line-height:1.1;margin-top:1.25rem;word-wrap:break-word;}
.hero .lead{margin-top:1.25rem;font-size:1.05rem;color:rgba(255,255,255,.85);max-width:36rem;line-height:1.6}
.motto-pill{display:inline-flex;align-items:center;gap:.75rem;background:var(--gold);color:var(--charcoal);padding:.5rem 1.25rem;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;margin-top:1.75rem;box-shadow:0 8px 30px -10px rgba(212,175,55,.6)}
.motto-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--maroon)}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;max-width:28rem;border-top:1px solid rgba(255,255,255,.15);padding-top:1.5rem;margin-top:2.5rem}
.hero-stats dt{font-family:var(--serif);font-size:1.5rem;color:var(--gold);font-weight:700}
@media(min-width:768px){.hero-stats dt{font-size:2rem}}
.hero-stats dd{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.7);margin-top:.25rem;line-height:1.3}
.badge-card{display:flex;justify-content:center;min-width:0}
@media(min-width:1024px){.badge-card{justify-content:flex-end}}
.badge-wrap{position:relative;max-width:100%}
.badge-glow{position:absolute;inset:-1rem;border-radius:50%;background:rgba(212,175,55,.2);filter:blur(40px);pointer-events:none}
.badge-frame{position:relative;background:rgba(255,255,255,.95);border-radius:1rem;padding:1.25rem;border:1px solid rgba(212,175,55,.4);box-shadow:var(--shadow-elegant);max-width:100%}
@media(min-width:768px){.badge-frame{padding:1.75rem}}
.badge-frame img{width:min(16rem,70vw);height:auto;max-width:100%}
@media(min-width:768px){.badge-frame img{width:18rem}}

/* Cards / grids */
.grid-3{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:640px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.grid-3{grid-template-columns:repeat(3,1fr)}}
.card{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.5rem;transition:all .2s}
@media(min-width:768px){.card{padding:1.75rem}}
.card.hover-lift:hover{box-shadow:var(--shadow-elegant)}
.card.hover-gold:hover{border-color:var(--gold)}
.card h3{font-family:var(--serif);font-size:1.2rem;margin-top:1.1rem;color:var(--charcoal)}
.vmo .card h3{color:var(--maroon)}
.card p{margin-top:.5rem;font-size:.875rem;color:var(--muted);line-height:1.65}
.icon-box{display:inline-flex;align-items:center;justify-content:center;height:2.75rem;width:2.75rem;border-radius:.6rem;background:rgba(212,175,55,.15);color:var(--maroon)}
.icon-box .ic{width:1.35rem;height:1.35rem}
.icon-box.solid{background:var(--maroon);color:#fff}
.icon-box.gold{background:var(--gold);color:var(--charcoal)}

/* About */
.about-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media(min-width:1024px){.about-grid{grid-template-columns:2fr 1fr;gap:2rem}}
.about-main{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.75rem;box-shadow:var(--shadow-card)}
@media(min-width:768px){.about-main{padding:2.25rem}}
.about-main h3{font-family:var(--serif);color:var(--maroon);font-size:1.4rem;margin-top:1.5rem}
.about-main h3:first-child{margin-top:0}
.about-main p{margin-top:1rem;color:var(--muted);line-height:1.7;font-size:.95rem}
.principal{background:var(--maroon);color:#fff;border-radius:1rem;padding:1.75rem;box-shadow:var(--shadow-elegant);display:flex;flex-direction:column}
@media(min-width:768px){.principal{padding:2rem}}
.principal img{width:5.5rem;height:5.5rem;border-radius:50%;object-fit:cover;border:4px solid var(--gold)}
.principal h3{color:#fff;margin-top:1.25rem;font-size:1.2rem}
.principal p{margin-top:.75rem;font-size:.875rem;color:rgba(255,255,255,.85);line-height:1.65}
.principal .sig{margin-top:1rem;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.vmo{display:grid;gap:1.25rem;grid-template-columns:1fr;margin-top:2.5rem}
@media(min-width:768px){.vmo{grid-template-columns:repeat(3,1fr)}}
.vmo .card .icon-box{background:rgba(122,31,43,.1)}
.values{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:768px){.values{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.values{grid-template-columns:repeat(6,1fr)}}
.value{background:#fff;border:1px solid var(--border);border-radius:.75rem;padding:1.25rem;text-align:center;transition:all .2s;box-shadow:var(--shadow-card)}
.value:hover{border-color:var(--gold);transform:translateY(-4px)}
.value .icon-box{margin:0 auto;background:rgba(122,31,43,.1)}
.value:hover .icon-box{background:var(--maroon);color:#fff}
.value .label{font-family:var(--serif);font-weight:700;color:var(--charcoal);margin-top:.75rem}

/* Admissions */
.adm-grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:1024px){.adm-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}}
.adm-card{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.75rem;box-shadow:var(--shadow-card)}
@media(min-width:768px){.adm-card{padding:2rem}}
.adm-card h3{font-family:var(--serif);color:var(--charcoal);font-size:1.2rem}
.adm-card .card-title{font-family:var(--serif);color:var(--charcoal)}
.adm-card .row-icon{display:flex;align-items:center;gap:.75rem;color:var(--maroon)}
.bullets,.steps{margin-top:1rem}
.bullets li{font-size:.9rem;color:var(--muted);padding:.4rem 0;padding-left:1rem;position:relative}
.bullets li::before{content:"";position:absolute;left:0;top:.85rem;width:5px;height:5px;border-radius:50%;background:var(--gold)}
.steps li{font-size:.9rem;color:var(--muted);margin-top:.75rem;display:flex;gap:.75rem;align-items:flex-start}
.num{flex-shrink:0;width:1.5rem;height:1.5rem;border-radius:50%;background:var(--maroon);color:#fff;font-size:.75rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center}
.fee-card{background:var(--maroon);color:#fff;border-radius:1rem;padding:1.75rem;box-shadow:var(--shadow-elegant)}
@media(min-width:768px){.fee-card{padding:2rem}}
.fee-card h3{color:#fff}
.fees{margin-top:1.25rem}
.fee-row{display:flex;justify-content:space-between;gap:.75rem;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.15);font-size:.875rem}
.fee-row b{color:var(--gold);font-weight:600;white-space:nowrap}
.fee-note{margin-top:1rem;font-size:.75rem;color:rgba(255,255,255,.6)}
.adm-downloads{display:flex;flex-direction:column;justify-content:space-between;gap:1.25rem}
.downloads{margin-top:1.25rem;display:grid;gap:.6rem;grid-template-columns:1fr}
@media(min-width:480px){.downloads{grid-template-columns:repeat(2,1fr)}}
.dl{display:flex;align-items:center;justify-content:space-between;gap:.5rem;border:1px solid var(--border);border-radius:.5rem;padding:.75rem .9rem;font-size:.85rem;font-weight:500;color:var(--charcoal);transition:all .2s;min-width:0}
.dl span{display:inline-flex;align-items:center;gap:.5rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dl:hover{border-color:var(--gold);background:var(--cream)}
.dl svg:last-child{color:var(--maroon)}

/* Charter table */
.table-wrap{background:#fff;border:1px solid var(--border);border-radius:1rem;box-shadow:var(--shadow-card);overflow:hidden}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;min-width:640px}
thead{background:var(--maroon);color:#fff}
th{text-align:left;padding:.9rem 1rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
td{padding:.85rem 1rem;border-top:1px solid var(--border);font-size:.85rem;color:var(--fg);vertical-align:top}
tbody tr:nth-child(even){background:var(--cream)}

/* Gallery */
.gallery-category{
    margin-bottom:60px;
}

.gallery-category h3{
    text-align:center;
    margin-bottom:20px;
    color:#0b3d91;
    font-size:1.8rem;
}

.gallery-grid{
    display:grid;
    gap:1rem;
    grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
}

.extra-images{
    display:none;
    grid-column:1/-1;
    grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
    gap:1rem;
}

.extra-images.show{
    display:grid;
}

.more-btn{
    display:block;
    margin:20px auto 0;
    padding:10px 25px;
    border:none;
    border-radius:30px;
    background:#0b3d91;
    color:#fff;
    cursor:pointer;
    font-weight:600;
    transition:.3s;
}

.more-btn:hover{
    background:#d4af37;
    color:#000;
}

/* Existing Gallery Styles */

.tile{
    position:relative;
    border-radius:.75rem;
    overflow:hidden;
    aspect-ratio:4/3;
    box-shadow:var(--shadow-card);
}

.tile img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .4s;
}

.tile:hover img{
    transform:scale(1.05);
}

.cap{
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    background:linear-gradient(to top,rgba(0,0,0,.7),transparent);
    color:#fff;
    padding:.85rem;
    font-size:.8rem;
    font-weight:600;
}
/* News */
.news-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media(min-width:1024px){.news-grid{grid-template-columns:2fr 1fr}}
.update{display:flex;gap:1.25rem;background:#fff;border:1px solid var(--border);border-radius:.75rem;padding:1.25rem;transition:border-color .2s;margin-bottom:1rem}
.update:hover{border-color:var(--gold)}
.date-block{flex-shrink:0;width:3.5rem;text-align:center;background:var(--maroon);color:#fff;border-radius:.5rem;padding:.6rem .25rem}
.date-block .m{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;opacity:.85}
.date-block .d{font-family:var(--serif);font-size:1.2rem;color:var(--gold);font-weight:700;line-height:1.1;margin-top:.15rem}
.update-body{min-width:0}
.update h3{font-family:var(--serif);font-size:1.05rem;color:var(--charcoal);margin-top:.25rem}
.update small{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);display:inline-flex;align-items:center;gap:.4rem}
.update p{font-size:.875rem;color:var(--muted);margin-top:.4rem;line-height:1.6}
.cal{background:var(--cream);border:1px solid var(--border);border-radius:1rem;padding:1.5rem}
.cal-head{display:flex;align-items:center;gap:.6rem;color:var(--maroon)}
.cal-head h3{font-family:var(--serif);color:var(--charcoal);font-size:1.1rem}
.cal-list{margin-top:1rem}
.cal-list li{display:flex;justify-content:space-between;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--border);font-size:.875rem}
.cal-list li:last-child{border-bottom:none}
.cal-list b{color:var(--maroon);font-size:.75rem;white-space:nowrap}
.cal-more{margin-top:1.25rem;display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;color:var(--maroon)}

/* Portals */
.portal{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:1rem;padding:1.75rem;transition:background .2s}
.portal:hover{background:rgba(255,255,255,.1)}
.portal h3{color:#fff;margin-top:1.25rem;font-family:var(--serif);font-size:1.2rem}
.portal p{color:rgba(255,255,255,.7);margin-top:.5rem;font-size:.875rem}
.portal button{margin-top:1.25rem;color:var(--gold);font-weight:600;font-size:.875rem}
.portal button:hover{color:#fff}

/* Contact */
.contact-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media(min-width:1024px){.contact-grid{grid-template-columns:repeat(2,1fr);gap:2rem}}
form{display:grid;gap:1rem;margin-top:1.25rem}
.form-row{display:grid;gap:1rem;grid-template-columns:1fr}
@media(min-width:640px){.form-row{grid-template-columns:repeat(2,1fr)}}
input,textarea{border:1px solid var(--border);border-radius:.5rem;padding:.85rem 1rem;font-size:.9rem;font-family:inherit;background:#fff;width:100%}
input:focus,textarea:focus{outline:2px solid var(--maroon);outline-offset:-1px}
.info{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.5rem;margin-bottom:1rem}
.info h3{font-family:var(--serif);color:var(--charcoal);font-size:1.2rem}
.info-list{margin-top:1rem}
.info-list li{display:flex;gap:.75rem;align-items:center;padding:.5rem 0;font-size:.9rem;color:var(--fg)}
.info-list .ic{color:var(--maroon);width:1.1rem;height:1.1rem}
.map{overflow:hidden;border-radius:1rem;border:1px solid var(--border);height:16rem}
@media(min-width:768px){.map{height:18rem}}
.map iframe{width:100%;height:100%;border:0;display:block}

/* Footer */
footer{background:var(--charcoal);color:rgba(255,255,255,.8);width:100%; padding: 30px;}
.foot-grid{display:grid;gap:2rem;grid-template-columns:1fr;padding:3rem 0}
@media(min-width:640px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.foot-grid{grid-template-columns:2fr 1fr 1fr;gap:2.5rem}}
.foot-brand{grid-column:1/-1}
@media(min-width:900px){.foot-brand{grid-column:auto}}
.foot-brand-head{display:flex;align-items:center;gap:.75rem;min-width:0}
.foot-brand img{height:48px;width:48px;object-fit:contain;flex-shrink:0}
.foot-brand .name{color:#fff;font-family:var(--serif);font-weight:700;font-size:1rem;line-height:1.2}
.foot-brand .motto{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-top:2px}
.foot-brand p{margin-top:1rem;font-size:.875rem;max-width:32rem;line-height:1.7}
.socials{display:flex;gap:.6rem;margin-top:1.25rem;flex-wrap:wrap}
.socials a{height:2.25rem;width:2.25rem;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:inline-flex;align-items:center;justify-content:center;transition:all .2s;color:#fff}
.socials a:hover{background:var(--gold);color:var(--charcoal);border-color:var(--gold)}
footer h4{color:#fff;font-family:var(--serif);font-size:1rem}
footer ul{margin-top:1rem}
footer ul li{font-size:.875rem;padding:.3rem 0}
footer ul li a:hover{color:var(--gold)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1)}
.foot-bottom .container{display:flex;flex-direction:column;justify-content:space-between;gap:.5rem;padding-block:1.25rem;font-size:.75rem;color:rgba(255,255,255,.6);align-items:center;text-align:center}
@media(min-width:768px){.foot-bottom .container{flex-direction:row}}
.foot-bottom span{color:var(--gold);letter-spacing:.18em;text-transform:uppercase}

@keyframes fade-up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fade-up .7s ease-out both}
