:root {
  --cream: #f6f0e4;
  --paper: #fffaf0;
  --brown: #2a130e;
  --brown-soft: #4a251b;
  --maroon: #721f32;
  --green: #173f35;
  --olive: #7d8148;
  --teal: #236f69;
  --gold: #e6a824;
  --ink: #27251f;
  --muted: #6e6a60;
  --line: rgba(42, 19, 14, 0.16);
  --serif: "Libre Caslon Display", Georgia, serif;
  --sans: "DM Sans", Arial, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--cream);
  color: var(--ink);
  font-family: var(--sans);
  line-height: 1.65;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
button { color: inherit; font: inherit; }
.sr-only { clip: rect(0, 0, 0, 0); height: 1px; margin: -1px; overflow: hidden; position: absolute; width: 1px; }

.site-header {
  background: var(--brown);
  border-bottom: 1px solid rgba(255,255,255,.1);
  height: 92px;
  position: relative;
  z-index: 50;
}

.nav-wrap {
  align-items: center;
  display: flex;
  height: 100%;
  justify-content: space-between;
  margin: auto;
  max-width: 1240px;
  padding: 0 28px;
}

.brand {
  align-items: center;
  display: flex;
  height: 82px;
  width: 142px;
}

.brand img {
  height: 110px;
  object-fit: contain;
  object-position: center;
  width: 142px;
}

.site-nav { align-items: center; display: flex; gap: 38px; }
.site-nav a {
  color: rgba(255,255,255,.72);
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .11em;
  padding: 34px 0 31px;
  position: relative;
  text-transform: uppercase;
}
.site-nav a::after {
  background: var(--gold);
  bottom: 22px;
  content: "";
  height: 2px;
  left: 0;
  position: absolute;
  transform: scaleX(0);
  transition: transform .2s ease;
  width: 100%;
}
.site-nav a:hover, .site-nav a.active { color: white; }
.site-nav a:hover::after, .site-nav a.active::after { transform: scaleX(1); }

.nav-cta {
  align-items: center;
  border: 1px solid rgba(255,255,255,.25);
  color: white;
  display: flex;
  font-size: .73rem;
  font-weight: 700;
  gap: 15px;
  letter-spacing: .08em;
  padding: 12px 18px;
  text-transform: uppercase;
  transition: background .2s ease, color .2s ease;
}
.nav-cta:hover { background: var(--gold); color: var(--brown); }
.nav-cta span { color: var(--gold); font-size: 1rem; }
.nav-cta:hover span { color: var(--brown); }
.menu-toggle { background: transparent; border: 0; cursor: pointer; display: none; padding: 8px; }
.menu-toggle > span:not(.sr-only) { background: white; display: block; height: 2px; margin: 5px; transition: .2s ease; width: 25px; }

.home-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(420px, .75fr);
  min-height: calc(100svh - 92px);
}

.hero-copy {
  align-items: flex-start;
  background:
    linear-gradient(90deg, rgba(246,240,228,.8), rgba(246,240,228,.94) 70%, rgba(246,240,228,.98)),
    url("heroback.jpg") center/cover;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 80px max(50px, calc((100vw - 1240px) / 2));
  padding-right: clamp(50px, 8vw, 130px);
}

.kicker, .section-label {
  color: var(--teal);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
}

h1, h2, h3 { font-family: var(--serif); font-weight: 400; line-height: 1.04; }
.hero-copy h1 { color: var(--brown); font-size: clamp(3.3rem, 4.55vw, 5.45rem); letter-spacing: -.045em; margin: 20px 0 28px; max-width: none; white-space: nowrap; }
.hero-copy h1 em { color: var(--maroon); font-weight: 400; }
.hero-intro { color: var(--muted); font-size: 1.08rem; max-width: 510px; }
.hero-actions { align-items: center; display: flex; gap: 28px; margin-top: 36px; }

.button {
  align-items: center;
  display: inline-flex;
  font-size: .74rem;
  font-weight: 700;
  justify-content: center;
  letter-spacing: .1em;
  min-height: 52px;
  padding: 0 25px;
  text-transform: uppercase;
  transition: transform .2s ease, background .2s ease;
}
.button:hover { transform: translateY(-2px); }
.button-gold { background: var(--gold); color: var(--brown); }
.button-gold:hover { background: #f0b837; }
.button-dark { background: var(--brown); color: white; }
.button-dark:hover { background: var(--maroon); }
.arrow-link { border-bottom: 1px solid var(--line); color: var(--brown); font-size: .82rem; font-weight: 700; padding: 10px 0; }
.arrow-link span { color: var(--maroon); margin-left: 10px; }

.hero-proof { border-top: 1px solid var(--line); display: flex; gap: 26px; margin-top: 62px; padding-top: 20px; }
.hero-proof span { color: var(--muted); font-size: .69rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.hero-proof span::before { color: var(--olive); content: "•"; margin-right: 8px; }

.hero-visual { background: var(--green); min-height: 650px; overflow: hidden; position: relative; }
.hero-image {
  background: linear-gradient(rgba(23,63,53,.12), rgba(42,19,14,.22)), url("gallery/8.jpeg") center/cover;
  bottom: 0; left: 0; position: absolute; right: 0; top: 0;
}
.hero-visual::after { border: 1px solid rgba(255,255,255,.42); content: ""; inset: 24px; position: absolute; }
.logo-seal {
  align-items: center; background: var(--cream); border-radius: 50%; display: flex; height: 185px; justify-content: center;
  left: -92px; position: absolute; top: 50%; transform: translateY(-50%); width: 185px; z-index: 2;
}
.logo-seal img { height: 170px; object-fit: contain; width: 170px; }
.hero-note { background: var(--brown); bottom: 50px; color: white; display: flex; flex-direction: column; left: 50px; padding: 18px 24px; position: absolute; z-index: 2; }
.hero-note strong { font-family: var(--serif); font-size: 1.25rem; font-weight: 400; }
.hero-note span { color: var(--gold); font-size: .63rem; letter-spacing: .16em; text-transform: uppercase; }

.intro-strip {
  align-items: start; background: var(--gold); display: grid; gap: 50px; grid-template-columns: .45fr 1.8fr 70px;
  margin: auto; max-width: 1240px; padding: 65px 60px;
}
.intro-strip .section-label { color: var(--brown); }
.intro-strip h2 { color: var(--brown); font-size: clamp(2.4rem, 4vw, 4.2rem); max-width: 780px; }
.intro-strip div p { color: rgba(42,19,14,.7); margin-top: 22px; max-width: 680px; }
.circle-link { align-items: center; border: 1px solid rgba(42,19,14,.4); border-radius: 50%; display: flex; font-size: 1.5rem; height: 62px; justify-content: center; transition: .2s ease; width: 62px; }
.circle-link:hover { background: var(--brown); color: white; }

.profile-section { margin: auto; max-width: 1180px; padding: 130px 28px; }
.profile-heading { display: grid; gap: 30px; grid-template-columns: .5fr 1.5fr; margin-bottom: 55px; }
.profile-heading h2 { color: var(--brown); font-size: clamp(3rem, 5vw, 5rem); }
.profile-list { border-top: 1px solid var(--line); }
.profile-row {
  align-items: center; border-bottom: 1px solid var(--line); display: grid; gap: 25px;
  grid-template-columns: 55px 1.1fr 1fr 30px; padding: 27px 8px; transition: background .2s ease, padding .2s ease;
}
.profile-row:hover { background: rgba(230,168,36,.1); padding-left: 18px; padding-right: 18px; }
.profile-no { color: var(--teal); font-size: .7rem; font-weight: 700; letter-spacing: .12em; }
.profile-row h3 { color: var(--brown); font-size: 1.65rem; }
.profile-row p { color: var(--muted); font-size: .9rem; }
.profile-row b { color: var(--maroon); font-size: 1.2rem; }

.featured-section { display: grid; grid-template-columns: 1.15fr .85fr; min-height: 640px; }
.featured-image { background: url("gallery/10.jpeg") center/cover; }
.featured-copy { align-items: flex-start; background: var(--olive); color: white; display: flex; flex-direction: column; justify-content: center; padding: clamp(50px, 8vw, 120px); }
.featured-copy .kicker { color: #f5dc92; }
.featured-copy h2 { font-size: clamp(2.8rem, 5vw, 5rem); margin: 20px 0 24px; }
.featured-copy p { color: rgba(255,255,255,.76); margin-bottom: 35px; max-width: 480px; }

.contact-block {
  background: var(--green); color: white; display: grid; gap: 80px; grid-template-columns: .9fr 1.1fr;
  margin: 100px auto 0; max-width: 1240px; padding: clamp(55px, 8vw, 100px);
}
.contact-block .kicker { color: #8fd0c8; }
.contact-title h2 { font-size: clamp(3rem, 5vw, 5.4rem); margin-top: 18px; }
.contact-details { display: grid; gap: 12px; }
.contact-details a, .contact-details address { border-bottom: 1px solid rgba(255,255,255,.18); font-style: normal; overflow-wrap: anywhere; padding: 11px 0 18px; }
.contact-details small { color: #aebc7d; display: block; font-size: .65rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }

.inner-hero { min-height: 600px; padding: 80px max(28px, calc((100vw - 1180px) / 2)); }
.inner-hero-copy h1 { font-size: clamp(4rem, 7vw, 7rem); letter-spacing: -.04em; margin-top: 22px; }
.page-cta { align-items: center; background: var(--brown); color: white; display: flex; justify-content: space-between; margin: 110px auto; max-width: 1180px; padding: 65px; }
.page-cta h2 { font-size: clamp(2.6rem, 5vw, 4.5rem); margin-top: 12px; }
.page-cta .kicker { color: var(--gold); }

.site-footer {
  background: #252725;
  color: rgba(255,255,255,.72);
  margin-top: 0;
}

.footer-main {
  display: grid;
  gap: clamp(45px, 7vw, 90px);
  grid-template-columns: 1.45fr .65fr .85fr 1.1fr;
  margin: auto;
  max-width: 1240px;
  padding: 85px 28px 70px;
}

.footer-brand img {
  filter: drop-shadow(0 14px 18px rgba(0,0,0,.18));
  height: 150px;
  object-fit: contain;
  object-position: left center;
  width: 190px;
}

.footer-brand > p {
  font-size: .9rem;
  margin: 22px 0 26px;
  max-width: 330px;
}

.footer-order {
  align-items: center;
  border-bottom: 1px solid rgba(255,255,255,.28);
  color: white;
  display: inline-flex;
  font-size: .72rem;
  font-weight: 700;
  gap: 14px;
  letter-spacing: .1em;
  padding-bottom: 8px;
  text-transform: uppercase;
}

.footer-order span { color: var(--gold); font-size: 1rem; transition: transform .2s ease; }
.footer-order:hover span { transform: translateX(4px); }

.footer-column {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  gap: 13px;
  padding-top: 28px;
}

.footer-column h3 {
  color: white;
  font-family: var(--sans);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .16em;
  margin-bottom: 12px;
  text-transform: uppercase;
}

.footer-column > a,
.footer-column address {
  color: rgba(255,255,255,.68);
  font-size: .82rem;
  font-style: normal;
  overflow-wrap: anywhere;
  transition: color .2s ease;
}

.footer-column > a:hover { color: var(--gold); }
.footer-contact { gap: 18px; }
.footer-contact small {
  color: #aebc7d;
  display: block;
  font-size: .59rem;
  font-weight: 700;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.footer-bottom {
  align-items: center;
  border-top: 1px solid rgba(255,255,255,.14);
  display: flex;
  font-size: .7rem;
  justify-content: space-between;
  margin: auto;
  max-width: 1240px;
  padding: 24px 28px 28px;
}

.footer-bottom a {
  color: var(--gold);
  font-weight: 700;
  transition: color .2s ease;
}

.footer-bottom a:hover { color: white; }

.reveal { opacity: 0; transform: translateY(20px); transition: opacity .6s ease, transform .6s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}

@media (max-width: 900px) {
  .site-header { height: 82px; }
  .nav-wrap { padding: 0 16px; }
  .brand { height: 74px; width: 115px; }
  .brand img { height: 94px; width: 115px; }
  .menu-toggle { display: block; margin-left: auto; }
  .nav-cta { display: none; }
  .site-nav {
    align-items: stretch; background: var(--brown); border-top: 1px solid rgba(255,255,255,.12); flex-direction: column;
    gap: 0; left: 0; opacity: 0; padding: 14px 20px 24px; pointer-events: none; position: absolute; right: 0;
    top: 82px; transform: translateY(-10px); transition: .2s ease;
  }
  .site-nav.open { opacity: 1; pointer-events: auto; transform: translateY(0); }
  .site-nav a { padding: 14px 6px; }
  .site-nav a::after { bottom: 8px; width: 45px; }
  .menu-toggle.open > span:first-child { transform: translateY(7px) rotate(45deg); }
  .menu-toggle.open > span:nth-child(2) { opacity: 0; }
  .menu-toggle.open > span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .home-hero { grid-template-columns: 1fr; }
  .hero-copy h1 { white-space: normal; }
  .hero-copy { min-height: 650px; padding: 75px 28px; }
  .hero-visual { min-height: 620px; }
  .logo-seal { left: 50%; top: -82px; transform: translateX(-50%); }
  .intro-strip { grid-template-columns: 1fr; padding: 55px 30px; }
  .profile-heading { grid-template-columns: 1fr; }
  .featured-section, .contact-block { grid-template-columns: 1fr; }
  .featured-image { min-height: 500px; }
  .contact-block { gap: 45px; margin-top: 60px; }
  .footer-main { grid-template-columns: 1.2fr 1fr 1fr; }
  .footer-contact { grid-column: 2 / -1; }
}

@media (max-width: 620px) {
  .hero-copy h1 { font-size: clamp(3.5rem, 18vw, 5.2rem); }
  .hero-actions { align-items: flex-start; flex-direction: column; }
  .hero-proof { flex-direction: column; gap: 8px; margin-top: 44px; }
  .hero-visual { min-height: 520px; }
  .hero-note { bottom: 28px; left: 28px; }
  .profile-section { padding: 90px 18px; }
  .profile-row { grid-template-columns: 38px 1fr 25px; }
  .profile-row p { display: none; }
  .profile-row h3 { font-size: 1.35rem; }
  .featured-image { min-height: 380px; }
  .featured-copy { padding: 65px 28px; }
  .contact-block { margin-inline: 0; padding: 60px 25px; }
  .page-cta { align-items: flex-start; flex-direction: column; gap: 30px; margin: 70px 16px; padding: 45px 28px; }
  .footer-main { gap: 42px; grid-template-columns: 1fr; padding: 65px 22px 50px; }
  .footer-column { padding-top: 0; }
  .footer-contact { grid-column: auto; }
  .footer-bottom { align-items: flex-start; flex-direction: column; gap: 10px; padding: 22px; }
}
