:root{
  --sage:#6f7f6a;
  --sage-dark:#4f5f4b;
  --ivory:#fbfaf6;
  --sand:#f3eee3;
  --charcoal:#1f2620;
  --clay:#b07a62;
  --line:#e7e1d6;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
  --radius: 18px;
  --max: 1100px;
  --font-sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  --font-serif: ui-serif, "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;
}
*{box-sizing:border-box}
html,body{margin:0; padding:0}
body{
  font-family: var(--font-sans);
  color: var(--charcoal);
  background: linear-gradient(180deg, var(--ivory), #ffffff 55%);
  line-height: 1.55;
}
a{color: var(--sage-dark); text-decoration: none}
a:hover{text-decoration: underline}
.container{max-width: var(--max); margin: 0 auto; padding: 0 20px}
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:12px 16px; border-radius: 999px;
  background: var(--sage-dark); color:white;
  border: 1px solid rgba(255,255,255,.2);
  box-shadow: var(--shadow);
  font-weight: 600;
}
.btn.secondary{background: transparent; color: var(--sage-dark); border:1px solid var(--line); box-shadow:none}
.btn:hover{opacity:.94; text-decoration:none}
.badge{display:inline-block; padding:6px 10px; border-radius:999px; background: var(--sand); border:1px solid var(--line); color: var(--sage-dark); font-weight:600; font-size:.85rem}

header{
  position: sticky; top:0; z-index: 50;
  backdrop-filter: blur(10px);
  background: rgba(251,250,246,.78);
  border-bottom: 1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding: 12px 0;
}
.brand{
  display:flex; align-items:center; gap:12px;
}
.brand img{width:46px; height:46px; object-fit:contain}
.brand .name{
  font-family: var(--font-serif);
  font-weight: 600;
  letter-spacing:.2px;
  font-size: 1.15rem;
}
.brand .tag{font-size:.86rem; color: #465047}
nav ul{display:flex; list-style:none; gap:18px; padding:0; margin:0; align-items:center}
nav a{font-weight:600; font-size:.95rem}
.menu-btn{
  display:none;
  border:1px solid var(--line);
  background: white;
  border-radius: 12px;
  padding:10px 12px;
}
.menu{
  display:none;
  padding: 12px 0 18px;
}
.menu a{display:block; padding:10px 0; border-top:1px solid var(--line); font-weight:600}
.hero{padding: 64px 0 34px;}
.hero-grid{display:grid; grid-template-columns: 1.2fr .8fr; gap: 28px; align-items:start;}
.card{
  background: white;
  border:1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.hero .headline{
  font-family: var(--font-serif);
  font-size: clamp(2.0rem, 3vw, 3.1rem);
  line-height:1.08;
  margin: 10px 0 12px;
}
.hero p{font-size: 1.08rem; color:#2f3a31; margin: 0 0 18px}
.kicker{color: var(--sage-dark); font-weight:700; letter-spacing:.08em; text-transform: uppercase; font-size:.82rem}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap}
.hero-aside{padding: 20px}
.hero-aside h3{margin:0 0 10px; font-family: var(--font-serif)}
.list{margin:0; padding-left: 18px}
.list li{margin: 8px 0; color:#2f3a31}
.section{padding: 42px 0}
.section h2{
  font-family: var(--font-serif);
  font-size: 1.8rem;
  margin:0 0 12px;
}
.section p.lead{margin:0 0 22px; font-size:1.05rem; color:#2f3a31}
.grid-3{display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px}
.grid-2{display:grid; grid-template-columns: repeat(2, 1fr); gap: 16px}
.tile{padding: 18px}
.tile h3{margin:0 0 8px; font-size:1.05rem}
.tile p{margin:0; color:#2f3a31}
.icon{
  width:44px; height:44px; border-radius: 14px;
  background: var(--sand); border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  color: var(--sage-dark); font-weight:800;
  margin-bottom: 10px;
}
.quote{padding: 22px;}
.quote p{margin:0 0 10px; font-size:1.05rem}
.quote .who{font-weight:700; color:#2f3a31}
.muted{color:#516053}
.footer{
  padding: 34px 0;
  border-top: 1px solid var(--line);
  background: rgba(243,238,227,.35);
}
.footer-grid{display:grid; grid-template-columns: 1.2fr .8fr; gap: 18px}
.small{font-size:.92rem; color:#2f3a31}
.footer a{font-weight:600}
hr.sep{border:0; border-top:1px solid var(--line); margin: 20px 0}
.form{display:grid; gap: 12px;}
input, textarea, select{
  width:100%;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid var(--line);
  font: inherit;
  background: white;
}
textarea{min-height: 120px; resize: vertical}
.label{font-weight:700; font-size:.92rem}
.notice{
  padding: 14px 16px;
  border-radius: 14px;
  border:1px solid rgba(176,122,98,.28);
  background: rgba(176,122,98,.08);
  color:#3a2a24;
}
.table{width:100%; border-collapse: collapse;}
.table th, .table td{
  padding: 12px 10px;
  border-bottom: 1px solid var(--line);
  text-align:left;
}
.table th{font-size:.9rem; color:#3b463c}
.video-wrap{
  aspect-ratio: 16 / 9;
  width:100%;
  border-radius: var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow: var(--shadow);
}
.video-wrap iframe{width:100%; height:100%; border:0}
.map-wrap{
  height: 420px;
  border-radius: var(--radius);
  border:1px solid var(--line);
  overflow:hidden;
  box-shadow: var(--shadow);
}
@media (max-width: 900px){
  .hero-grid{grid-template-columns: 1fr;}
  .grid-3{grid-template-columns: 1fr}
  .grid-2{grid-template-columns: 1fr}
  nav ul{display:none}
  .menu-btn{display:inline-flex}
  .menu.open{display:block}
  .footer-grid{grid-template-columns: 1fr}
}
