/* ─────────── HEADER + NAV ─────────── */
.header{position:fixed;top:0;left:0;right:0;background:#fff;transition:.35s ease, padding 0.35s ease;z-index:1000;}
.header-container{
    max-width:1200px;margin:auto;padding:1.5rem 2rem;
    display:flex;flex-direction:column;align-items:center;transition:.3s;
}
.header-brand{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1rem;transition:.3s;}
.logo{width:auto;height:56px;transition:.3s ease, height 0.35s ease;}
.wordmark{font-family:"Caudex",serif;font-size:1.5rem;font-weight:700;text-align:center;color:var(--green);line-height:1.2;transition: font-size 0.35s ease, color 0.35s ease;}

.nav-section{width:100%;max-width:600px;position:relative;}
.nav-line-top,.nav-line-bottom{height:1px;background:var(--green);}
.nav-links{display:flex;justify-content:center;gap:3rem;padding:.75rem 0;}
.nav-links a{
    font-family:"Caudex",serif;font-weight:700;font-size:var(--fs-sm);
    text-transform:uppercase;letter-spacing:1px;color:var(--green);transition: color 0.35s ease;;
}
.nav-links a:hover,.nav-links a.active{color:var(--gold);}

/* on-scroll compress */
.header.scrolled{background:#0F1E34;}
.header.scrolled .header-container{flex-direction:row;justify-content:space-between;padding:1rem 2rem;}
.header.scrolled .header-brand{flex-direction:row;gap:1rem;margin-bottom:0;}
.header.scrolled .logo{width:auto;height:40px;}
.header.scrolled .wordmark{font-size:1.2rem;color:var(--bone);}
.header.scrolled .nav-links a{color:var(--bone);}
.header.scrolled .nav-line-top,.header.scrolled .nav-line-bottom{background:var(--gold);height:0;}
.header.scrolled .nav-links a:hover,.header.scrolled .nav-links a.active{color:var(--gold);}

/* hamburger / X */
.hamburger{
    display:none;flex-direction:column;gap:4px;
    position:absolute;right:2rem;top:50%;transform:translateY(-50%);
    z-index:1100;                    /* stays on top of drawer */
}
.hamburger span{width:24px;height:2px;background:var(--green);transition:.3s;}
.header.scrolled .hamburger span{background:var(--bone);}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.active span:nth-child(2){opacity:0;}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* mobile drawer */
.mobile-menu{
    position:fixed;inset:0;background:var(--bone);
    transform:translateX(100%);opacity:0;
    transition:transform .35s ease,opacity .35s ease;
    padding-top:140px;               /* header height + breathing */
    display:block;overflow-y:auto;scroll-behavior:smooth;
    z-index:999;                     /* below header but above content */
    top: 20vh;
    border-top: 2px solid var(--gold);
}
.header.scrolled .mobile-menu{top: 7.5vh;}
.mobile-menu.active{transform:translateX(0);opacity:1;}
.mobile-menu nav{display:flex;justify-content:center;}
.mobile-menu ul{display:flex;flex-direction:column;gap:2rem;align-items:center;}
.mobile-menu a{
    font-family:"Caudex",serif;font-weight:700;font-size:1.5rem;
    color:var(--green);text-transform:uppercase;
}
body.menu-open{overflow:hidden;}

/* Main content spacing */
#app {
    min-height: calc(100vh - 160px);
    
}

/* ─────────── FOOTER ─────────── */
.footer{
    background:#0F1E34;color:#fff;
    padding:3rem 1rem 1.5rem;
    margin-top:0;                    /* no white gap */
    position: relative;
}
.white-line{height:1px;background:var(--gold);margin-bottom:2rem;}
.footer-content{
    max-width:1200px;margin:auto;
    display:flex;align-items:center;justify-content:space-between;
    flex-wrap:wrap;gap:2rem;
}
.footer-logo{display:flex;align-items:center;gap:1.5rem;}
.footer-write h3{font-family:"Caudex",serif;font-size:1.125rem;margin-bottom:.25rem;}
.footer-socials{display:flex;gap:1rem;}
.footer-socials a{
    background:#fff;color:var(--green);
    width:34px;height:34px;border-radius:50%;
    display:grid;place-items:center;font-size:1rem;transition:.3s;
}
.footer-socials a:hover{background:var(--gold);color:var(--bone);transform:translateY(-2px);}

/* ─────────── HEADER/FOOTER RESPONSIVE ─────────── */
@media (max-width:1024px){.header-container{padding:1rem 1.5rem;}}
@media (max-width:768px){
    .hamburger{display:flex;}
    .nav-section{display:none;}
    .header.scrolled .header-container{padding:.75rem 1.5rem;}
}
@media (max-width:480px){
    .mobile-menu a{font-size:1.25rem;}
}