:root{
  --bg:#0f241c;
  --surface:#173328;
  --surface-2:#1d3d31;
  --primary:#d8c07a;
  --accent:#efe1b0;
  --text:#f7f2e8;
  --muted:#e4dccb;
  --border:#355747;
  --shadow:0 10px 28px rgba(0,0,0,.28);
  --radius:18px;
  --max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Georgia,"Times New Roman",serif;
  background:linear-gradient(180deg,#0d2018 0%,#143126 100%);
  color:var(--text);
  line-height:1.65;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.site-header{
  background:rgba(15,36,28,.96);
  border-bottom:1px solid var(--border);
  position:sticky;
  top:0;
  z-index:50;
  box-shadow:0 2px 12px rgba(0,0,0,.18);
}
.nav-wrap{
  max-width:var(--max);
  margin:0 auto;
  padding:14px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.brand{display:flex;align-items:center;gap:14px}
.brand img{width:76px;height:76px;object-fit:contain}
.brand-copy h1{
  margin:0;
  font-size:1.5rem;
  color:var(--accent);
  text-align:left;
}
.brand-copy p{
  margin:2px 0 0;
  font-size:.95rem;
  color:var(--muted);
  letter-spacing:.04em;
  text-transform:uppercase;
  text-align:left;
}
nav ul{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
nav a{
  display:inline-block;
  padding:10px 14px;
  border-radius:999px;
  color:var(--accent);
  font-weight:700;
}
nav a:hover, nav a.active{
  background:var(--primary);
  color:#102018;
}
.hero{
  max-width:var(--max);
  margin:0 auto;
  padding:60px 20px 36px;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:32px;
  align-items:center;
}
.hero-card,.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.hero-card{padding:38px}
.hero h2{
  margin:0 0 14px;
  font-size:clamp(2rem,4.5vw,3.6rem);
  line-height:1.05;
  color:var(--accent);
}
.hero .tagline{
  font-size:1.15rem;
  font-style:italic;
  margin:0 0 12px;
  color:var(--muted);
}
.hero p{
  margin:0 0 18px;
  font-size:1.04rem;
  color:var(--text);
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-block;
  padding:12px 18px;
  border-radius:999px;
  font-weight:700;
}
.btn-primary{background:var(--primary);color:#102018}
.btn-secondary{background:transparent;border:1px solid var(--accent);color:var(--accent)}
.hero-logo{padding:26px;background:var(--surface-2)}
.hero-logo img{
  width:min(100%,480px);
  margin:0 auto;
  object-fit:contain;
  filter:none !important;
  mix-blend-mode:normal !important;
}
.section{
  max-width:var(--max);
  margin:0 auto;
  padding:0 20px 34px;
}
.section-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.card{padding:24px}
.card h3{
  margin:0 0 10px;
  color:var(--accent);
  font-size:1.3rem;
}
.card h4{color:var(--accent)}
.card p,.card li,.card a{color:var(--text)}
.page-hero{
  max-width:var(--max);
  margin:0 auto;
  padding:46px 20px 24px;
}
.page-hero .card{
  padding:34px;
  background:var(--surface-2);
}
.page-hero h2{
  margin:0 0 10px;
  color:var(--accent);
  font-size:clamp(2rem,4vw,3rem);
}
.page-hero p{
  margin:0;
  color:var(--muted);
}
.content{
  max-width:var(--max);
  margin:0 auto;
  padding:0 20px 44px;
}
.content .card + .card{margin-top:22px}
.menu-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:22px;
}
.menu-list{margin:0;padding-left:18px}
.home-hero-image{
  display:block;
  width:min(100%,520px);
  height:auto;
  margin:0 auto 22px;
  border-radius:16px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}
.about-page{text-align:center}
.about-page img{
  display:block;
  margin-left:auto;
  margin-right:auto;
}
.about-main-heading{
  font-size:clamp(2rem,4vw,3rem);
  line-height:1.1;
  margin-bottom:18px;
  color:var(--accent);
}
.about-story-image{
  display:block;
  width:360px;
  max-width:100%;
  margin:18px auto 24px;
  border-radius:16px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}
.founder-gallery{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
  width:100%;
  margin:20px auto 0;
}
.founder-gallery .founder-featured{
  display:block;
  width:min(100%,286px);
  height:auto;
  margin:0 auto;
  border-radius:16px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}
.founder-gallery-row{
  display:flex;
  justify-content:center;
  align-items:flex-start;
  gap:18px;
  width:100%;
}
.founder-gallery-row img{
  display:block;
  width:min(100%,220px);
  height:auto;
  margin:0;
  border-radius:16px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}
.packages-intro{text-align:center}
.packages-gallery{
  display:flex;
  justify-content:center;
  align-items:flex-start;
  gap:24px;
  flex-wrap:wrap;
}
.packages-gallery img{
  width:min(100%,460px);
  border-radius:16px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  background:#fff;
}
.schedule-page .page-hero .card,
.schedule-page .page-hero .card h2,
.schedule-page .page-hero .card p{
  text-align:center;
}
.schedule-image-stack{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:24px;
  margin-top:24px;
}
.schedule-image-stack img{
  display:block;
  width:min(100%,820px);
  height:auto;
  margin:0 auto;
  border-radius:16px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}
.book-now-page .page-hero .card,
.book-now-page .page-hero .card h2,
.book-now-page .page-hero .card p{
  text-align:center;
}
a[href^="mailto:"]{
  color:inherit;
  text-decoration:underline;
  text-underline-offset:3px;
}
.footer{
  background:#0b1a14;
  color:#f8f2e2;
  margin-top:20px;
  border-top:1px solid var(--border);
}
.footer-wrap{
  max-width:var(--max);
  margin:0 auto;
  padding:22px 20px;
  text-align:center;
}
.footer-wrap p{
  margin:4px 0;
  color:#f8f2e2;
}
strong{color:#fff7dd}
@media (max-width:900px){
  .hero{grid-template-columns:1fr}
  .section-grid,.menu-grid{grid-template-columns:1fr}
  .nav-wrap{flex-direction:column;align-items:flex-start}
  .founder-gallery-row{flex-wrap:wrap}
}
@media (max-width:640px){
  .brand{align-items:flex-start}
  .brand img{width:64px;height:64px}
  nav ul{gap:6px}
  nav a{padding:8px 11px;font-size:.95rem}
  .founder-gallery-row img{width:min(100%,260px)}
}