*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:           #F2F1EC;
  --bg-alt:       #ECEAE4;
  --bg-dark:      #181816;
  --bg-green:     #1B2720;
  --text:         #18171A;
  --text-muted:   #6B6860;
  --text-subtle:  #9C9B94;
  --border:       #D5D3CC;
  --border-mid:   #B8B7AF;
  --green-deep:   #1A2820;
  --green-mid:    #2C4032;
  --amber:        #9A7418;
  --amber-bright: #B88820;
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-sans:  'IBM Plex Sans', system-ui, sans-serif;
  --font-mono:  'IBM Plex Mono', 'Courier New', monospace;
  --w:  1200px;
  --px: clamp(1.25rem, 4vw, 3rem);
}

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* ── HELPERS ─────────────────────────────────────────────── */
.wrap { max-width: var(--w); margin: 0 auto; padding: 0 var(--px); }

.label {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--amber);
  display: flex;
  align-items: center;
  gap: 0.6em;
  margin-bottom: 1.5rem;
}
.label::before { content: ''; display: block; width: 22px; height: 1px; background: var(--amber); flex-shrink: 0; }

h2 {
  font-family: var(--font-serif);
  font-size: clamp(1.9rem, 3.5vw, 2.9rem);
  font-weight: 400;
  line-height: 1.18;
  color: var(--text);
}
h2 em { font-style: italic; color: var(--green-mid); }

/* ── NAV ─────────────────────────────────────────────────── */
nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 200;
  height: 58px;
  background: rgba(242, 241, 236, 0.94);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; width: 100%; }
.logo {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--text);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.45em;
}
.logo-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--amber); flex-shrink: 0; }
.nav-links { list-style: none; display: flex; gap: 2.25rem; }
.nav-links a {
  font-size: 0.78rem;
  font-weight: 400;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.18s;
}
.nav-links a:hover { color: var(--text); }

/* ── HERO ────────────────────────────────────────────────── */
#hero {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
.hero-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: calc(58px + clamp(4rem, 10vh, 7rem));
  padding-bottom: 2rem;
}
.hero-coord { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.1em; color: var(--text-subtle); margin-bottom: 2.25rem; }
.hero-title { font-family: var(--font-serif); font-size: clamp(2.8rem, 5.8vw, 5rem); font-weight: 400; line-height: 1.1; color: var(--text); max-width: 15ch; margin-bottom: 1.75rem; }
.hero-title em { font-style: italic; color: var(--green-mid); }
.hero-sub { font-size: clamp(0.95rem, 1.4vw, 1.05rem); font-weight: 300; color: var(--text-muted); max-width: 48ch; line-height: 1.75; margin-bottom: 2.75rem; }
.hero-actions { display: flex; align-items: center; gap: 2rem; }
.btn { font-family: var(--font-sans); font-size: 0.78rem; font-weight: 500; letter-spacing: 0.07em; text-transform: uppercase; text-decoration: none; display: inline-block; transition: background 0.18s, border-color 0.18s, color 0.18s; }
.btn-solid { color: var(--bg); background: var(--green-deep); border: 1px solid var(--green-deep); padding: 0.75rem 1.85rem; }
.btn-solid:hover { background: var(--green-mid); border-color: var(--green-mid); }
.btn-ghost { color: var(--text-muted); display: inline-flex; align-items: center; gap: 0.4em; }
.btn-ghost::after { content: '→'; }
.btn-ghost:hover { color: var(--text); }
.hero-mountain { width: 100%; display: block; margin-top: auto; }

/* ── ABOUT ───────────────────────────────────────────────── */
#about { background: var(--bg-alt); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: clamp(4rem, 8vh, 7rem) var(--px); }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(3rem, 6vw, 5.5rem); align-items: start; }
.about-body { font-size: 0.9375rem; line-height: 1.82; color: var(--text-muted); }
.about-body p + p { margin-top: 1.2rem; }
.stats { border-top: 1px solid var(--border); }
.stat { padding: 1.25rem 0; border-bottom: 1px solid var(--border); display: grid; grid-template-columns: 5.5rem 1fr; gap: 1rem; align-items: baseline; }
.stat-val { font-family: var(--font-serif); font-size: 2rem; font-weight: 400; line-height: 1; color: var(--text); }
.stat-lbl { font-size: 0.8125rem; color: var(--text-subtle); font-weight: 300; line-height: 1.4; }

/* ── PRODUCTS ────────────────────────────────────────────── */
#products { padding: clamp(4rem, 8vh, 7rem) var(--px); }
.products-header { max-width: 54ch; margin-bottom: 3.5rem; }
.products-header p { margin-top: 0.85rem; font-size: 0.9375rem; line-height: 1.72; color: var(--text-muted); }
.grid-products { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--border); border-left: 1px solid var(--border); }
.card { border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 2.25rem 2rem; display: flex; flex-direction: column; gap: 0.9rem; transition: background 0.18s; }
.card:hover { background: var(--bg-alt); }
.card-tag { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-subtle); }
.card h3 { font-family: var(--font-serif); font-size: 1.25rem; font-weight: 500; line-height: 1.2; color: var(--text); }
.card p { font-size: 0.875rem; line-height: 1.72; color: var(--text-muted); flex: 1; }
.card-link { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--amber); text-decoration: none; display: inline-flex; align-items: center; gap: 0.4em; margin-top: auto; transition: color 0.18s; }
.card-link::after { content: '→'; }
.card-link:hover { color: var(--amber-bright); }

/* ── APPROACH ────────────────────────────────────────────── */
#approach { background: var(--bg-green); padding: clamp(4rem, 8vh, 7rem) var(--px); }
#approach .label { color: rgba(184,136,32,0.65); }
#approach .label::before { background: rgba(184,136,32,0.65); }
#approach h2 { color: var(--bg); }
#approach h2 em { color: rgba(242,241,236,0.45); }
.approach-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: clamp(3rem, 6vw, 5.5rem); align-items: start; }
.approach-intro { font-size: 0.9375rem; line-height: 1.82; color: rgba(242,241,236,0.6); margin-top: 1.5rem; }
.pillars { border-top: 1px solid rgba(255,255,255,0.08); }
.pillar { padding: 1.6rem 0; border-bottom: 1px solid rgba(255,255,255,0.08); display: grid; grid-template-columns: 2.75rem 1fr; gap: 1rem; align-items: start; }
.pillar-num { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.06em; color: rgba(255,255,255,0.22); padding-top: 0.22rem; }
.pillar h3 { font-family: var(--font-serif); font-size: 1rem; font-weight: 500; font-style: italic; color: var(--bg); margin-bottom: 0.4rem; line-height: 1.3; }
.pillar p { font-size: 0.875rem; line-height: 1.7; color: rgba(242,241,236,0.52); }

/* ── LOCATION ────────────────────────────────────────────── */
#location { border-top: 1px solid var(--border); padding: clamp(4rem, 8vh, 7rem) var(--px); }
.location-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(3rem, 6vw, 5rem); align-items: center; }
.location-text p { font-size: 0.9375rem; line-height: 1.8; color: var(--text-muted); max-width: 44ch; margin-top: 0.75rem; }
.location-text p + p { margin-top: 1rem; }
.location-table { margin-top: 2.25rem; border: 1px solid var(--border); background: var(--bg-alt); }
.loc-row { display: flex; justify-content: space-between; align-items: baseline; padding: 0.7rem 1.25rem; border-bottom: 1px solid var(--border); }
.loc-row:last-child { border-bottom: none; }
.loc-key { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-subtle); }
.loc-val { font-family: var(--font-mono); font-size: 0.78rem; color: var(--text-muted); }
.topo { background: var(--bg-alt); border: 1px solid var(--border); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; overflow: hidden; }

/* ── CONTACT ─────────────────────────────────────────────── */
#contact { background: var(--bg-alt); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: clamp(4rem, 8vh, 7rem) var(--px); }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(3rem, 6vw, 5rem); align-items: start; }
.contact-text p { font-size: 0.9375rem; line-height: 1.78; color: var(--text-muted); max-width: 40ch; margin-top: 0.75rem; }
.contact-email { display: inline-block; margin-top: 1.5rem; font-family: var(--font-mono); font-size: 0.82rem; color: var(--amber); text-decoration: none; border-bottom: 1px solid transparent; transition: border-color 0.18s; }
.contact-email:hover { border-color: var(--amber); }
.contact-form-wp { display: flex; flex-direction: column; gap: 1.1rem; }
.field { display: flex; flex-direction: column; gap: 0.38rem; }
.field label { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-subtle); }
.field input, .field textarea { font-family: var(--font-sans); font-size: 0.9375rem; color: var(--text); background: var(--bg); border: 1px solid var(--border); padding: 0.62rem 0.85rem; outline: none; width: 100%; transition: border-color 0.18s; resize: none; -webkit-appearance: none; }
.field input:focus, .field textarea:focus { border-color: var(--border-mid); }
.field textarea { height: 104px; }
.form-status { font-size: 0.875rem; font-family: var(--font-mono); min-height: 1.4em; }
.form-status.ok  { color: var(--green-mid); }
.form-status.err { color: #8B2020; }
.btn-submit { align-self: flex-start; font-family: var(--font-sans); font-size: 0.78rem; font-weight: 500; letter-spacing: 0.07em; text-transform: uppercase; color: var(--bg); background: var(--green-deep); border: 1px solid var(--green-deep); padding: 0.75rem 1.85rem; cursor: pointer; transition: background 0.18s, border-color 0.18s; }
.btn-submit:hover { background: var(--green-mid); border-color: var(--green-mid); }
.btn-submit:disabled { opacity: 0.6; cursor: not-allowed; }

/* ── FOOTER ──────────────────────────────────────────────── */
footer { background: var(--bg-dark); padding: 2.25rem var(--px); }
.footer-inner { max-width: var(--w); margin: 0 auto; display: flex; justify-content: space-between; align-items: center; }
.footer-brand { font-family: var(--font-serif); font-size: 0.95rem; color: rgba(242,241,236,0.55); }
.footer-meta { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.08em; color: rgba(242,241,236,0.22); }

/* ── HAMBURGER ───────────────────────────────────────────── */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  width: 32px;
  height: 32px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
}
.nav-toggle span {
  display: block;
  width: 100%;
  height: 1.5px;
  background: var(--text);
  transition: transform 0.2s, opacity 0.2s;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(5.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-5.5px) rotate(-45deg); }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 860px) {
  .nav-toggle { display: flex; }
  .nav-links {
    display: none;
    position: absolute;
    top: 58px;
    left: 0;
    right: 0;
    flex-direction: column;
    background: rgba(242,241,236,0.97);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--border);
    padding: 1.25rem var(--px);
    gap: 0;
  }
  .nav-links.open { display: flex; }
  .nav-links li { border-bottom: 1px solid var(--border); }
  .nav-links li:last-child { border-bottom: none; }
  .nav-links a { display: block; padding: 0.8rem 0; font-size: 0.85rem; }
  .about-grid, .approach-grid, .location-grid, .contact-grid { grid-template-columns: 1fr; }
  .grid-products { grid-template-columns: repeat(2, 1fr); }
  .topo { display: none; }
  .footer-inner { flex-direction: column; gap: 0.75rem; text-align: center; }
}
@media (max-width: 560px) {
  .grid-products { grid-template-columns: 1fr; }
  .hero-actions { flex-direction: column; align-items: flex-start; gap: 1.25rem; }
}

/* ── WP ADMIN BAR OFFSET ─────────────────────────────────── */
.admin-bar nav { top: 32px; }
@media screen and (max-width: 782px) { .admin-bar nav { top: 46px; } }
