/* Shared nav + mobile menu + footer styles. Edit only this file to update across the site. */

/* NAV */
nav#main-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--charcoal);display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:64px;}
.nav-logo{display:flex;align-items:center;text-decoration:none;height:100%;}
.nav-logo img{height:30px;width:auto;display:block;}
@media(max-width:600px){.nav-logo img{height:24px;}}
.nav-links{display:flex;gap:32px;list-style:none;}.nav-links a{color:rgba(255,255,255,0.75);text-decoration:none;font-size:0.82rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;transition:color 0.2s;}.nav-links a:hover,.nav-links a.active{color:var(--gold);}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px;z-index:101;}.hamburger span{display:block;width:24px;height:2px;background:#fff;transition:transform 0.3s,opacity 0.3s;}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* MOBILE MENU */
.mobile-menu{position:fixed;inset:0;z-index:100;background:var(--charcoal);display:flex;flex-direction:column;padding:96px 40px 48px;transform:translateY(-100%);transition:transform 0.48s cubic-bezier(0.76,0,0.24,1),visibility 0s linear 0.48s;visibility:hidden;pointer-events:none;}
.mobile-menu.open{transform:translateY(0);visibility:visible;pointer-events:auto;transition:transform 0.48s cubic-bezier(0.76,0,0.24,1),visibility 0s linear 0s;}
.mm-inner{display:flex;flex-direction:column;height:100%;}
.mm-nav{display:flex;flex-direction:column;flex:1;justify-content:center;gap:0;}
.mm-link{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,9vw,54px);font-weight:300;color:rgba(255,255,255,0.78);text-decoration:none;line-height:1.2;letter-spacing:-0.01em;padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.07);transition:color 0.3s,padding-left 0.3s;display:block;}
.mm-link:last-child{border-bottom:none;}
.mm-link:hover{color:var(--gold);padding-left:10px;}
.mm-footer{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.32);padding-top:32px;border-top:1px solid rgba(255,255,255,0.06);}

/* FONT SIZE CONTROLS */
.fs-controls{display:flex;align-items:center;gap:4px;margin-left:20px;}
.fs-btn{background:none;border:1px solid rgba(255,255,255,0.18);color:rgba(255,255,255,0.6);cursor:pointer;border-radius:4px;font-family:'Jost',sans-serif;font-weight:600;letter-spacing:0.04em;padding:3px 8px;font-size:0.72rem;transition:all 0.2s;line-height:1.4;}
.fs-btn:hover{border-color:var(--gold);color:var(--gold);}
.fs-btn.active{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,0.12);}

/* Mobile font size controls inside hamburger menu */
.mm-fs-row{display:flex;align-items:center;gap:10px;padding:24px 0 8px;}
.mm-fs-label{font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.32);flex:1;}
.mm-fs-btn{background:none;border:1px solid rgba(255,255,255,0.18);color:rgba(255,255,255,0.5);cursor:pointer;border-radius:4px;font-family:'Jost',sans-serif;font-weight:600;padding:6px 14px;font-size:0.85rem;transition:all 0.2s;line-height:1.4;}
.mm-fs-btn:hover{border-color:var(--gold);color:var(--gold);}
.mm-fs-btn.active{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,0.12);}

/* Close button in mobile menu */
.mm-close{position:absolute;top:18px;right:20px;background:none;border:none;cursor:pointer;color:rgba(255,255,255,0.5);font-size:1.6rem;line-height:1;padding:8px;transition:color 0.2s;z-index:102;}
.mm-close:hover{color:#fff;}

/* FOOTER */
footer{background:var(--charcoal);color:rgba(255,255,255,0.5);text-align:center;padding:32px 20px;font-size:0.82rem;}
footer a{color:rgba(255,255,255,0.65);text-decoration:none;}

@media(min-width:900px){
  nav#main-nav{padding:0 40px;}
  .hamburger{display:none;}
}
@media(max-width:899px){
  .nav-links{display:none;}
  .fs-controls{display:none!important;}
  nav#main-nav [data-size]{display:none!important;}
  .hamburger{display:flex;}
}

/* High-specificity overrides to defeat !important dark-mode color rules on chapter pages */
footer p, footer p a, footer p span {
  color: rgba(255,255,255,0.5) !important;
}
footer p a {
  color: rgba(255,255,255,0.65) !important;
}
footer p:last-child {
  color: rgba(255,255,255,0.35) !important;
}
footer p:last-child span {
  color: rgba(255,255,255,0.6) !important;
}
