:root {
  --bg: #f3efe8;
  --paper: #fffaf3;
  --panel: #ffffff;
  --ink: #1d2428;
  --muted: #59666d;
  --line: rgba(29, 36, 40, 0.1);
  --brand: #173f39;
  --brand-soft: #ddebe8;
  --accent: #d56a1f;
  --accent-dark: #a44e13;
  --shadow: 0 20px 48px rgba(23, 63, 57, 0.12);
  --radius: 26px;
  --container: min(1180px, calc(100% - 32px));
}

*,
*::before,
*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Outfit", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at top right, rgba(213, 106, 31, 0.12), transparent 24%),
    linear-gradient(180deg, #f9f4ec 0%, #eef2ef 100%);
  line-height: 1.7;
}
img { display: block; max-width: 100%; }
a { color: var(--brand); text-decoration: none; }
a:hover { color: var(--accent-dark); }
p, ul { margin: 0 0 1rem; }
ul { padding-left: 1.1rem; }
h1, h2, h3 {
  margin: 0 0 1rem;
  font-family: "Sora", sans-serif;
  letter-spacing: -0.03em;
  line-height: 1.05;
}
h1 { font-size: clamp(2.4rem, 5vw, 4.8rem); }
h2 { font-size: clamp(1.9rem, 3.2vw, 3.1rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.55rem); }

.container { width: var(--container); margin: 0 auto; }
.topbar { background: #0e2824; color: #f5f5f0; }
.topbar__inner,
.header__inner,
.hero__actions,
.topbar__actions,
.nav__links,
.cards,
.services-grid,
.footer__grid,
.split,
.sticky-bar { display: flex; gap: 1rem; }
.topbar__inner,
.header__inner { align-items: center; justify-content: space-between; }
.topbar__inner { padding: 0.8rem 0; font-size: 0.95rem; }

.header {
  position: sticky;
  top: 0;
  z-index: 30;
  background: rgba(255, 250, 243, 0.9);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}
.header--solid { position: relative; }
.header__inner { padding: 1rem 0; }
.brand img { width: 210px; }
.nav { position: relative; }
.nav__toggle {
  display: none;
  width: 48px;
  height: 48px;
  border: 0;
  background: transparent;
}
.nav__toggle span,
.nav__toggle::before,
.nav__toggle::after {
  content: "";
  display: block;
  width: 24px;
  height: 2px;
  margin: 6px auto;
  background: var(--brand);
}
.nav__links { align-items: center; flex-wrap: wrap; }
.nav__links a {
  padding: 0.7rem 1rem;
  border-radius: 999px;
  font-weight: 700;
}
.nav__links a.active,
.nav__links a:hover { background: var(--brand-soft); }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 1.3rem;
  border-radius: 999px;
  border: 0;
  font-weight: 800;
  transition: transform 0.2s ease, background 0.2s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn--primary { background: var(--accent); color: #fff; }
.btn--secondary { background: var(--brand); color: #fff; }
.btn--ghost { background: rgba(255, 255, 255, 0.12); color: #fff; border: 1px solid rgba(255, 255, 255, 0.18); }

.hero { padding: 2rem 0 4rem; }
.hero--home { padding-top: 2.5rem; }
.hero__grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 1.4rem; }
.hero__copy,
.hero__media,
.card,
.panel,
.faq,
.service-card,
.map-block,
.cta-banner {
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(255, 255, 255, 0.9);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.hero__copy { padding: clamp(1.5rem, 3vw, 3rem); }
.hero__media { position: relative; overflow: hidden; min-height: 340px; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; }
.hero__card {
  position: absolute;
  right: 1.2rem;
  bottom: 1.2rem;
  max-width: 320px;
  padding: 1rem 1.1rem;
  border-radius: 20px;
  background: rgba(255, 250, 243, 0.92);
}
.hero__list { margin: 1.4rem 0 0; }
.hero__list li { margin-bottom: 0.55rem; }
.eyebrow {
  display: inline-flex;
  padding: 0.55rem 0.9rem;
  border-radius: 999px;
  background: var(--brand-soft);
  color: var(--brand);
  font-size: 0.92rem;
  font-weight: 800;
  margin-bottom: 1rem;
}
.lead,
.body-copy,
.card p,
.panel p,
.faq p,
.map-block p,
.footer p { color: var(--muted); }

.section { padding: 0 0 4.5rem; }
.section__intro { margin-bottom: 1.5rem; }
.section--contrast .panel,
.section--contrast .card { background: #f7f2ea; }
.cards { flex-wrap: wrap; }
.cards--2 > * { flex: 1 1 340px; }
.cards--3 > * { flex: 1 1 260px; }
.card,
.panel,
.faq,
.cta-banner { padding: 1.5rem; }

.link-stack {
  display: grid;
  gap: 0.9rem;
}
.link-stack a {
  display: block;
  padding: 1rem 1.1rem;
  border-radius: 20px;
  background: var(--paper);
  border: 1px solid rgba(23, 63, 57, 0.12);
  font-weight: 700;
}
.link-stack--wide { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }

.services-grid {
  flex-wrap: wrap;
}
.service-card {
  flex: 1 1 220px;
  overflow: hidden;
}
.service-card img { width: 100%; height: 220px; object-fit: cover; }
.service-card span {
  display: block;
  padding: 1rem 1.1rem 1.2rem;
}
.split { align-items: flex-start; }
.split > * { flex: 1 1 320px; }

.section--cta .cta-banner,
.cta-banner {
  background: linear-gradient(135deg, #173f39, #265d54);
  color: #fff;
  align-items: center;
  justify-content: space-between;
}
.cta-banner p,
.cta-banner h2 { color: #fff; }

.section--map .map-block {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 1.4rem;
  padding: 1.5rem;
}
.map-frame iframe {
  width: 100%;
  min-height: 360px;
  border-radius: 22px;
}
.contact-link { font-size: 1.4rem; font-weight: 800; }

.footer {
  padding: 3rem 0 6rem;
  background: #102723;
  color: rgba(255, 255, 255, 0.82);
}
.footer a { color: #fff; }
.footer ul { list-style: none; padding-left: 0; margin-bottom: 0; }
.footer li { margin-bottom: 0.55rem; }
.footer__grid { align-items: flex-start; flex-wrap: wrap; }
.footer__grid > * { flex: 1 1 220px; }
.footer__logo { width: 190px; margin-bottom: 1rem; }
.footer__bottom { padding-top: 1.2rem; border-top: 1px solid rgba(255, 255, 255, 0.12); margin-top: 1.5rem; }

.sticky-bar {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  z-index: 40;
}
.sticky-bar a {
  flex: 1 1 50%;
  text-align: center;
  padding: 1rem;
  border-radius: 999px;
  background: #fff;
  color: var(--brand);
  font-weight: 800;
  box-shadow: var(--shadow);
}
.sticky-bar a:last-child { background: var(--accent); color: #fff; }

@media (max-width: 980px) {
  .hero__grid,
  .section--map .map-block { grid-template-columns: 1fr; }
  .topbar__inner,
  .header__inner,
  .split,
  .cta-banner { flex-direction: column; align-items: stretch; }
  .nav__toggle { display: block; }
  .nav__links {
    display: none;
    position: absolute;
    top: calc(100% + 12px);
    right: 0;
    width: min(320px, calc(100vw - 32px));
    padding: 0.9rem;
    background: rgba(255, 250, 243, 0.98);
    border-radius: 24px;
    box-shadow: var(--shadow);
    flex-direction: column;
    align-items: stretch;
  }
  .nav.open .nav__links { display: flex; }
}

@media (max-width: 720px) {
  body { padding-bottom: 94px; }
  .topbar { display: none; }
  .brand img { width: 176px; }
  .btn,
  .sticky-bar a { min-height: 48px; }
}
