:root{
  --bg:#fbfaf7;
  --white:#ffffff;
  --ink:#1d1d1f;
  --muted:#6b6b6f;
  --line:#e8e3d8;
  --gold:#b79039;
  --navy:#1f2c3a;
  --radius:28px;
  --shadow:0 12px 40px rgba(0,0,0,.08);
  --shadow-soft:0 10px 28px rgba(0,0,0,.06);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Helvetica Neue", sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
}

img{max-width:100%;display:block}
a{color:inherit}
.container{width:min(1100px, 92vw);margin:0 auto}

h1,h2,h3{
  font-family: Georgia, "Times New Roman", Times, serif;
  letter-spacing:.2px;
  line-height:1.12;
  margin:0 0 .6rem 0;
  color:var(--navy);
}
h1{font-size:clamp(2.1rem, 4vw, 3.1rem)}
h2{font-size:clamp(1.6rem, 3vw, 2.4rem)}
h3{font-size:1.25rem}

.lead{font-size:1.05rem;color:#233041;max-width:60ch}
.muted{color:var(--muted)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.95rem 1.2rem;border-radius:16px;
  border:1px solid transparent;text-decoration:none;
  font-weight:700;letter-spacing:.2px;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}
.btn.primary{background:var(--navy);color:white}
.btn.ghost{background:transparent;border-color:#cfd7e1;color:var(--navy)}
.pill{padding:.7rem 1rem;border-radius:999px;border:1px solid #cfd7e1}

.site-header{position:sticky;top:0;z-index:50;background:rgba(251,250,247,.84);backdrop-filter: blur(10px);border-bottom:1px solid var(--line)}
.topbar{display:grid;grid-template-columns:48px 1fr 48px;align-items:center;padding:.75rem 0;gap:.5rem}
.brand{justify-self:center;display:inline-flex;align-items:center}
.brand img{height:52px;width:auto}

.iconbtn{
  appearance:none;background:var(--white);border:1px solid var(--line);
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;cursor:pointer;
  box-shadow:0 6px 18px rgba(0,0,0,.05);
}
.iconbtn svg{width:20px;height:20px;fill:var(--navy)}
.burger{width:18px;height:2px;background:var(--navy);display:block;position:relative;border-radius:2px}
.burger:before,.burger:after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--navy);border-radius:2px}
.burger:before{top:-6px}
.burger:after{top:6px}

.main-nav{display:none;border-top:1px solid var(--line);background:rgba(251,250,247,.92)}
.nav-inner{display:flex;align-items:center;justify-content:center;gap:1.2rem;padding:.7rem 0}
.nav-inner a, .dropbtn{
  font-weight:700;text-decoration:none;color:var(--navy);
  padding:.55rem .7rem;border-radius:12px;border:1px solid transparent;background:transparent;
}
.nav-inner a:hover, .dropbtn:hover{background:var(--white);border-color:var(--line)}
.dropdown{position:relative}
.dropdown-menu{
  position:absolute;left:0;top:calc(100% + .4rem);
  min-width:220px;background:var(--white);border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--shadow);
  padding:.5rem;display:none;
}
.dropdown-menu a{display:block;padding:.65rem .75rem;border-radius:12px}
.dropdown-menu a:hover{background:var(--bg)}
.dropdown.open .dropdown-menu{display:block}

.drawer{
  display:none;flex-direction:column;gap:.35rem;
  padding:1rem 4vw 1.2rem 4vw;border-top:1px solid var(--line);
  background:var(--white);
}
.drawer a, .drawer-link{
  text-decoration:none;font-weight:800;color:var(--navy);
  padding:.85rem 1rem;border-radius:14px;border:1px solid var(--line);
  background:var(--bg);
}
.drawer-sub{display:none;flex-direction:column;gap:.35rem;margin-left:.5rem}
.drawer-sub a{font-weight:700}
.drawer-cta{background:var(--navy)!important;color:white!important;border-color:transparent!important;text-align:center}
.drawer.open{display:flex}
.drawer-sub.open{display:flex}

@media(min-width:860px){
  @media(min-width:860px){
  .main-nav{display:block}
}
  .iconbtn[data-mobile-toggle]{display:none}
  .topbar{grid-template-columns:1fr auto 1fr}
  .brand{justify-self:center}
}

.hero{position:relative;padding:0;margin:0}
.hero-media{height:52vh;min-height:380px;max-height:560px;position:relative;overflow:hidden}
.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.55))}
.hero-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:0 0 2.5rem 0}
.hero-content h1{color:white;max-width:22ch}
.hero-content .lead{color:rgba(255,255,255,.92)}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:.9rem}
.hero-meta{margin-top:1.1rem;color:rgba(255,255,255,.86);font-weight:700;display:flex;gap:.6rem;flex-wrap:wrap}

.copy{padding:3.2rem 0}
.copy-inner.center{text-align:center}
.copy-inner.left{text-align:left}
.prose{max-width:78ch;margin:0 auto;color:#2a3543}
.copy-inner.left .prose{margin:0}
.prose p{margin:.9rem 0}
.prose ul{margin:.8rem 0 0 1.1rem}
.subhead{font-family: ui-sans-serif, system-ui;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin:1.4rem 0 .4rem 0;font-size:.9rem}

.band{padding:0 0 3rem 0}
.band-img{
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  background:var(--white);
}
.band-img img{width:100%;height:auto}
.img-caption{padding:1rem 1.2rem;border-top:1px solid var(--line);color:var(--muted);font-weight:700}

.ticks{list-style:none;padding:0;margin:1rem 0}
.ticks li{padding-left:1.65rem;position:relative;margin:.6rem 0}
.ticks li:before{content:"✓";position:absolute;left:0;top:0;color:var(--gold);font-weight:900}

.cards{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1.4rem}
.card{display:block;border:1px solid var(--line);background:var(--white);padding:1.2rem 1.2rem;border-radius:22px;text-decoration:none;box-shadow:0 10px 22px rgba(0,0,0,.05)}
.card p{margin:.4rem 0 0 0;color:#2a3543}
.card .link{display:inline-block;margin-top:.9rem;font-weight:900;color:var(--navy)}
@media(min-width:860px){.cards{grid-template-columns:repeat(3,1fr)}}

.cta-row{margin-top:1.4rem;display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
.copy-inner.left .cta-row{justify-content:flex-start}

.contact-cards{display:grid;grid-template-columns:1fr;gap:.8rem;margin:1.2rem 0}
.contact-card{display:flex;flex-direction:column;gap:.25rem;border:1px solid var(--line);background:var(--bg);padding:1rem 1.1rem;border-radius:18px;text-decoration:none;font-weight:800}
.contact-card span{font-weight:700;color:var(--muted)}
@media(min-width:720px){.contact-cards{grid-template-columns:1fr 1fr}}

.form{display:grid;gap:.9rem;margin-top:1.2rem}
label{display:grid;gap:.35rem;font-weight:800;color:var(--navy)}
input,textarea{
  font:inherit;padding:.9rem 1rem;border-radius:16px;border:1px solid #cfd7e1;background:white;
}
textarea{resize:vertical}

.footer{padding:2.2rem 0;border-top:1px solid var(--line);background:var(--white)}
.footer-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer a{color:var(--navy);font-weight:800;text-decoration:none}
.footer a:hover{text-decoration:underline}

.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* --- Logo hero (homepage) --- */
.hero--logo{
  background: radial-gradient(1200px 600px at 50% -20%, rgba(200,170,95,.18), transparent 60%),
              linear-gradient(180deg, rgba(250,250,248,1), rgba(248,247,244,1));
  min-height: 68vh;
  display: grid;
  place-items: center;
  padding: 7.5rem 0 4.5rem;
}
.hero--logo .hero-logo{
  text-align: center;
  max-width: 46rem;
}
.hero-logo-img{
  width: min(240px, 60vw);
  height: auto;
  display: block;
  margin: 0 auto 1.25rem;
  filter: drop-shadow(0 10px 28px rgba(0,0,0,.10));
}
.hero--logo .hero-title{
  font-size: clamp(2.15rem, 5.2vw, 3.15rem);
  letter-spacing: .02em;
  margin: 0 0 .75rem;
}
.hero--logo .hero-subtitle{
  font-size: 1.05rem;
  line-height: 1.6;
  margin: 0 auto 1.35rem;
  color: rgba(0,0,0,.72);
}
.hero--logo .hero-actions{
  display: flex;
  gap: .85rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 1.15rem;
}
.hero--logo .hero-meta{
  display: flex;
  gap: .55rem;
  justify-content: center;
  flex-wrap: wrap;
  color: rgba(0,0,0,.6);
  font-weight: 600;
  font-size: .95rem;
}

/* --- Gentle animated logo in header (respects reduced motion) --- */
@media (prefers-reduced-motion: no-preference){
  .brand img{
    animation: mbw-float 4.5s ease-in-out infinite;
    transform-origin: 50% 50%;
  }
  @keyframes mbw-float{
    0%, 100% { transform: translateY(0); filter: drop-shadow(0 6px 18px rgba(0,0,0,.12)); }
    50%      { transform: translateY(-2px); filter: drop-shadow(0 10px 26px rgba(0,0,0,.16)); }
  }
}


@media (max-width: 600px){
  .hero-title{ font-size: clamp(2.2rem, 8vw, 3.2rem); }
  .hero{ min-height: 72vh; }
  .hero-content{ justify-content: center; padding-bottom: 2.25rem; }
}
