:root {
  --sand: #F7F0E4;
  --sand-2: #EFE0C7;
  --ivory: #FFFDF8;
  --forest: #1F4D36;
  --forest-2: #2F6A4D;
  --leaf: #DCEAD3;
  --ocean: #2F6F73;
  --ocean-2: #D7EBEA;
  --clay: #C86B46;
  --gold: #D9A441;
  --ink: #1E2A24;
  --muted: #66766D;
  --line: rgba(31, 77, 54, 0.16);
  --shadow: 0 22px 60px rgba(31, 77, 54, 0.12);
  --radius-lg: 32px;
  --radius-md: 22px;
  --radius-sm: 14px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--ivory);
  line-height: 1.6;
}
img, svg { max-width: 100%; }
a { color: inherit; }
::selection { background: var(--leaf); color: var(--forest); }
.container { width: min(1160px, calc(100% - 40px)); margin: 0 auto; }
.skip-link { position: absolute; left: -999px; top: 10px; z-index: 999; background: var(--forest); color: #fff; padding: 8px 10px; border-radius: 8px; }
.skip-link:focus { left: 10px; }

.topbar {
  background: var(--forest);
  color: rgba(255,255,255,0.92);
  font-size: 0.92rem;
  letter-spacing: 0.01em;
  padding: 10px 0;
}
.topbar .container { display: flex; justify-content: space-between; gap: 18px; align-items: center; }
.topbar a { color: #fff; text-decoration: underline; text-underline-offset: 3px; font-weight: 700; }
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,253,248,0.92);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
}
.nav { display: flex; justify-content: space-between; align-items: center; padding: 14px 0; gap: 22px; }
.brand { text-decoration: none; display: flex; align-items: center; gap: 12px; min-width: 224px; }
.brand-mark {
  width: 46px; height: 46px; border-radius: 50%;
  display: grid; place-items: center; flex: none;
  background: radial-gradient(circle at 62% 28%, var(--gold) 0 10%, transparent 11%), linear-gradient(135deg, var(--forest), var(--ocean));
  box-shadow: 0 13px 28px rgba(31,77,54,0.20);
}
.brand-mark img { width: 32px; height: 32px; }
.brand strong { display: block; font-family: Georgia, "Times New Roman", serif; color: var(--forest); font-size: 1.2rem; line-height: 1; }
.brand span { display: block; color: var(--muted); font-size: 0.84rem; margin-top: 3px; }
.nav-links { display: flex; align-items: center; justify-content: flex-end; gap: 16px; font-size: 0.94rem; }
.nav-links a { text-decoration: none; color: var(--ink); font-weight: 650; white-space: nowrap; }
.nav-links a:hover, .nav-links a[aria-current="page"] { color: var(--forest-2); }
.lang-link { border: 1px solid var(--line); border-radius: 999px; padding: 8px 12px; background: #fff; color: var(--forest) !important; }
.menu-button { display: none; border: 1px solid var(--line); background: #fff; border-radius: 999px; padding: 8px 12px; font-weight: 800; color: var(--forest); }

h1, h2, h3, h4 { font-family: Georgia, "Times New Roman", serif; line-height: 1.08; color: var(--forest); margin-top: 0; }
h1 { font-size: clamp(2.8rem, 7vw, 6.35rem); letter-spacing: -0.06em; margin-bottom: 22px; }
h2 { font-size: clamp(2rem, 4.2vw, 3.6rem); letter-spacing: -0.04em; margin-bottom: 18px; }
h3 { font-size: 1.52rem; letter-spacing: -0.02em; margin-bottom: 10px; }
h4 { font-size: 1.15rem; margin-bottom: 8px; }
p { margin: 0 0 16px; }
.lead { font-size: clamp(1.12rem, 2vw, 1.34rem); color: #3A5047; max-width: 760px; }
.muted { color: var(--muted); }
.small { font-size: 0.92rem; color: var(--muted); }
.eyebrow { color: var(--clay); font-weight: 850; text-transform: uppercase; letter-spacing: 0.14em; font-size: 0.78rem; margin-bottom: 12px; }

.hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 8% 20%, rgba(216,164,65,0.22), transparent 26%),
    radial-gradient(circle at 90% 12%, rgba(47,111,115,0.16), transparent 32%),
    linear-gradient(180deg, var(--sand) 0%, #fff9ef 58%, var(--ivory) 100%);
  padding: 92px 0 74px;
}
.hero::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 82px;
  background: linear-gradient(180deg, transparent, var(--ivory)); pointer-events: none;
}
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1.04fr) minmax(320px, 0.8fr); gap: 58px; align-items: center; }
.hero-copy { max-width: 760px; }
.actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; align-items: center; }
.button { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; padding: 13px 20px; min-height: 48px; text-decoration: none; font-weight: 850; border: 1px solid transparent; transition: transform .15s ease, box-shadow .15s ease, background .15s ease; }
.button:hover { transform: translateY(-2px); }
.button.primary { background: var(--forest); color: #fff; box-shadow: 0 16px 34px rgba(31,77,54,0.20); }
.button.secondary { background: rgba(255,255,255,0.86); color: var(--forest); border-color: var(--line); }
.button.ghost { background: transparent; color: var(--forest); border-color: rgba(31,77,54,0.25); }
.note-line { margin-top: 18px; color: var(--muted); font-size: 0.95rem; }

.nature-window {
  position: relative; border-radius: 44px 44px 18px 44px; padding: 18px; min-height: 520px; box-shadow: var(--shadow);
  background: linear-gradient(145deg, rgba(255,255,255,.65), rgba(255,255,255,.18)); border: 1px solid rgba(255,255,255,0.74);
}
.nature-scene {
  height: 100%; min-height: 484px; border-radius: 32px 32px 12px 32px; overflow: hidden; position: relative;
  background:
    radial-gradient(circle at 70% 22%, #F4C56A 0 8%, transparent 9%),
    linear-gradient(180deg, #8DC7C4 0 30%, #CDE5D4 30% 42%, #F1D49D 42% 54%, #23543B 54% 100%);
}
.nature-scene::before {
  content: ""; position: absolute; inset: auto -10% 0 -10%; height: 55%;
  background:
    radial-gradient(ellipse at 24% 0%, #2F6A4D 0 38%, transparent 39%),
    radial-gradient(ellipse at 54% 8%, #1F4D36 0 42%, transparent 43%),
    radial-gradient(ellipse at 80% 2%, #2F6A4D 0 34%, transparent 35%);
  opacity: .96;
}
.nature-scene::after {
  content: ""; position: absolute; inset: auto 0 0 0; height: 24%;
  background: linear-gradient(180deg, rgba(247,240,228,0.0), rgba(247,240,228,.92));
}
.scene-card {
  position: absolute; left: 24px; right: 24px; bottom: 24px; z-index: 2;
  background: rgba(255,253,248,0.90); backdrop-filter: blur(10px); border: 1px solid rgba(255,255,255,.72); border-radius: 24px; padding: 22px;
}
.scene-card strong { display: block; font-family: Georgia, serif; color: var(--forest); font-size: 1.65rem; line-height: 1.15; margin-bottom: 10px; }
.pill-list { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 16px; }
.pill { background: rgba(220,234,211,0.86); color: var(--forest); border: 1px solid rgba(31,77,54,0.12); border-radius: 999px; padding: 7px 11px; font-size: 0.88rem; font-weight: 750; }

section { padding: 78px 0; }
.section-intro { max-width: 820px; margin-bottom: 34px; }
.section-intro.center { text-align: center; margin-left: auto; margin-right: auto; }
.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 24px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 22px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 18px; }
.card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-md); padding: 28px; box-shadow: 0 12px 32px rgba(31,77,54,0.07); }
.card.soft { background: linear-gradient(180deg, #fff, #fff8ed); }
.card.green { background: var(--forest); color: #fff; border-color: rgba(255,255,255,.14); }
.card.green h3, .card.green h2, .card.green h4 { color: #fff; }
.card.green .muted, .card.green .small { color: rgba(255,255,255,.76); }
.feature-icon { width: 44px; height: 44px; border-radius: 14px; background: var(--leaf); color: var(--forest); display: grid; place-items: center; font-weight: 900; margin-bottom: 18px; }
.band { background: var(--forest); color: #fff; position: relative; overflow: hidden; }
.band::before { content:""; position:absolute; inset:0; background: radial-gradient(circle at 14% 0%, rgba(216,164,65,0.18), transparent 35%), radial-gradient(circle at 92% 40%, rgba(47,111,115,0.35), transparent 30%); pointer-events:none; }
.band .container { position: relative; z-index: 1; }
.band h2, .band h3 { color: #fff; }
.band .muted { color: rgba(255,255,255,0.74); }
.band .card { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.16); color: #fff; }

.split-panel { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 30px; align-items: stretch; }
.photo-placeholder {
  border-radius: var(--radius-lg); min-height: 360px; position: relative; overflow: hidden; background:
    radial-gradient(circle at 75% 22%, rgba(216,164,65,.58) 0 8%, transparent 9%),
    linear-gradient(180deg, var(--ocean-2) 0 38%, var(--sand-2) 38% 54%, var(--forest-2) 54% 100%);
  box-shadow: var(--shadow);
}
.photo-placeholder::before { content:""; position:absolute; left:-10%; right:-10%; bottom:0; height:52%; background: radial-gradient(ellipse at 30% 0%, var(--forest) 0 42%, transparent 43%), radial-gradient(ellipse at 68% 8%, #2b6048 0 38%, transparent 39%); }
.photo-label { position:absolute; left:24px; bottom:24px; right:24px; background: rgba(255,253,248,.88); border: 1px solid rgba(255,255,255,.78); border-radius: 20px; padding: 18px; font-weight: 750; color: var(--forest); }

.timeline { display: grid; gap: 18px; counter-reset: stage; }
.timeline-item { display: grid; grid-template-columns: 74px minmax(0,1fr); gap: 18px; align-items: start; }
.timeline-num { width: 54px; height: 54px; border-radius: 50%; display: grid; place-items: center; background: var(--leaf); color: var(--forest); font-weight: 900; }
.timeline-num::before { counter-increment: stage; content: counter(stage, decimal-leading-zero); }
.timeline-card { padding-bottom: 18px; border-bottom: 1px solid var(--line); }
.timeline-card h3 { margin-bottom: 7px; }

.page-hero { background: linear-gradient(180deg, var(--sand), #fff9ef); padding: 70px 0 56px; border-bottom: 1px solid var(--line); }
.page-hero h1 { font-size: clamp(2.7rem, 6vw, 5.2rem); max-width: 900px; }
.content { max-width: 860px; }
.content p, .content li { font-size: 1.07rem; }
.check-list { padding-left: 0; list-style: none; }
.check-list li { position: relative; margin: 12px 0; padding-left: 30px; }
.check-list li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--forest-2); font-weight: 900; }
.step-list { display: grid; gap: 16px; }
.step { padding: 22px; border-radius: var(--radius-md); border: 1px solid var(--line); background: #fff; }
.update-list { display: grid; gap: 18px; }
.update-item { border-left: 5px solid var(--clay); padding: 22px 24px; background: #fff8ec; border-radius: 18px; box-shadow: 0 10px 26px rgba(31,77,54,.06); }
.form-placeholder { border: 2px dashed rgba(31,77,54,0.24); border-radius: var(--radius-md); padding: 28px; background: #fffaf1; }
.callout { background: var(--leaf); border: 1px solid rgba(31,77,54,0.14); border-radius: var(--radius-md); padding: 24px; }

.site-footer { background: #15271F; color: #fff; padding: 52px 0 34px; }
.footer-grid { display: grid; grid-template-columns: 1.3fr 0.7fr 0.8fr 0.9fr; gap: 30px; align-items: start; }
.site-footer h3 { color: #fff; font-size: 1.25rem; margin-bottom: 12px; }
.site-footer a { color: rgba(255,255,255,0.90); text-decoration: none; }
.site-footer a:hover { text-decoration: underline; }
.footer-links { display: grid; gap: 8px; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.12); margin-top: 34px; padding-top: 22px; display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; color: rgba(255,255,255,0.64); font-size: .9rem; }

@media (max-width: 1020px) {
  .hero-grid, .split-panel { grid-template-columns: 1fr; }
  .nature-window { min-height: 420px; }
  .nature-scene { min-height: 390px; }
  .grid-4 { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 900px) {
  .topbar .container { display: block; }
  .topbar a { display: inline-block; margin-top: 4px; }
  .nav { align-items: center; }
  .menu-button { display: inline-block; }
  .nav-links { display: none; width: 100%; flex-direction: column; align-items: flex-start; padding: 14px 0 4px; gap: 13px; }
  .nav.open { flex-wrap: wrap; }
  .nav.open .nav-links { display: flex; }
  .brand { min-width: 0; }
  .grid-2, .grid-3, .footer-grid { grid-template-columns: 1fr; }
  section { padding: 58px 0; }
}
@media (max-width: 560px) {
  .container { width: min(100% - 28px, 1160px); }
  h1 { font-size: clamp(2.55rem, 14vw, 4rem); }
  .hero { padding: 64px 0 54px; }
  .grid-4 { grid-template-columns: 1fr; }
  .timeline-item { grid-template-columns: 1fr; }
  .timeline-num { width: 44px; height: 44px; }
  .brand span { display: none; }
}
