:root {
  --lime: #b3c52d;
  --lime-dark: #8d9d1e;
  --ink: #151515;
  --ink-soft: #333333;
  --paper: #ffffff;
  --wash: #f6f7ef;
  --muted: #666a55;
  --border: #d9debd;
  --focus: #2454ff;
  --radius: 18px;
  --shadow: 0 18px 45px rgba(21, 21, 21, .14);
  --container: min(1160px, 92vw);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--wash);
  font-family: Arial, Helvetica, system-ui, -apple-system, sans-serif;
  font-size: 17px;
  line-height: 1.62;
  text-wrap: pretty;
}
img { max-width: 100%; height: auto; }
a { color: #344400; text-underline-offset: .18em; }
a:hover { text-decoration-thickness: .14em; }
.wrap { width: var(--container); margin-inline: auto; }
.skip-link { position: absolute; left: -9999px; top: .5rem; z-index: 9999; background: var(--ink); color: #fff; padding: .8rem 1rem; border-radius: .6rem; }
.skip-link:focus { left: .5rem; }
.site-header { position: sticky; top: 0; z-index: 1000; background: #050505; color: #fff; border-bottom: 4px solid var(--lime); box-shadow: 0 6px 20px rgba(0,0,0,.22); }
.header-inner { min-height: 88px; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.brand { display: inline-flex; align-items: center; min-width: 160px; }
.brand img { display: block; width: 205px; max-height: 70px; object-fit: contain; }
.main-nav { margin-left: auto; }
.nav-toggle { display: none; min-height: 46px; padding: .55rem .85rem; border: 2px solid var(--lime); border-radius: .7rem; background: transparent; color: #fff; font-weight: 800; cursor: pointer; }
.menu, .submenu { list-style: none; margin: 0; padding: 0; }
.menu { display: flex; align-items: center; justify-content: flex-end; gap: .12rem; }
.menu-item { position: relative; }
.menu-row { display: flex; align-items: center; }
.menu-link { min-height: 46px; display: inline-flex; align-items: center; padding: .55rem .66rem; border-radius: .75rem; color: #fff; text-decoration: none; font-size: .95rem; font-weight: 800; letter-spacing: .01em; white-space: nowrap; }
.menu-link:hover, .menu-link:focus-visible, .menu-item.active > .menu-row .menu-link { background: rgba(179,197,45,.18); color: #fff; }
.menu-item.active > .menu-row .menu-link { box-shadow: inset 0 -3px 0 var(--lime); }
.submenu-toggle { display: inline-grid; place-items: center; width: 34px; height: 40px; margin-left: -.25rem; border: 0; border-radius: .65rem; background: transparent; color: #fff; cursor: pointer; }
.submenu-toggle:hover, .submenu-toggle:focus-visible { background: rgba(255,255,255,.14); }
.submenu-toggle::after { content: ''; width: .48rem; height: .48rem; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(45deg) translateY(-2px); transition: transform .22s ease; }
.submenu { position: absolute; right: 0; top: calc(100% + .5rem); min-width: 250px; overflow: hidden; background: #fff; border: 1px solid var(--border); border-radius: 1rem; box-shadow: var(--shadow); opacity: 0; transform: translateY(8px); pointer-events: none; transition: opacity .22s ease, transform .22s ease; }
.menu-item.open > .submenu, .menu-item:focus-within > .submenu { opacity: 1; transform: translateY(0); pointer-events: auto; }
@media (hover:hover) and (pointer:fine) { .menu-item:hover > .submenu { opacity:1; transform:translateY(0); pointer-events:auto; } }
.menu-item.open .submenu-toggle::after { transform: rotate(225deg) translate(-2px, -1px); }
.submenu a { display: block; min-height: 46px; padding: .72rem .9rem; color: var(--ink); text-decoration: none; font-weight: 750; border-left: 4px solid transparent; }
.submenu a:hover, .submenu a:focus-visible { background: #f7f9e9; border-left-color: var(--lime); }
.submenu a[aria-current="page"] { background: #eef4c5; border-left-color: var(--lime-dark); }
.hero { background: radial-gradient(circle at 80% 15%, rgba(179,197,45,.28), transparent 34%), linear-gradient(135deg, #101010 0%, #2c2f12 100%); color: #fff; padding: clamp(3rem, 7vw, 6rem) 0; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr); gap: clamp(1.5rem, 4vw, 3.5rem); align-items: center; }
.eyebrow { margin: 0 0 .55rem; color: #e8f18e; font-size: .9rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 900; }
h1, h2, h3 { line-height: 1.15; }
h1 { font-size: clamp(2.15rem, 5vw, 4.5rem); margin: 0 0 1rem; font-weight: 950; letter-spacing: -.04em; }
h2 { font-size: clamp(1.55rem, 2.5vw, 2.35rem); margin: 0 0 .85rem; letter-spacing: -.025em; }
h3 { font-size: 1.2rem; margin: 0 0 .55rem; }
.hero p { max-width: 65ch; font-size: clamp(1.05rem, 1.6vw, 1.25rem); color: #f3f4df; }
.hero-card { background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.22); border-radius: 1.35rem; padding: 1.25rem; backdrop-filter: blur(4px); }
.hero-card img { width: 100%; border-radius: 1rem; background: #000; object-fit: cover; }
.actions { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.25rem; }
.btn { display: inline-flex; justify-content: center; align-items: center; min-height: 46px; padding: .75rem 1.05rem; border-radius: .75rem; text-decoration: none; font-weight: 850; border: 2px solid transparent; }
.btn-primary { background: var(--lime); color: #101400; }
.btn-primary:hover { background: #c4d93c; }
.btn-secondary { background: #fff; color: #1e2500; border-color: #dce5a4; }
.btn-dark { background: var(--ink); color: #fff; }
.page-hero { padding: clamp(2rem, 5vw, 4rem) 0; background: linear-gradient(180deg, #fff, #f7f9e9); border-bottom: 1px solid var(--border); }
.page-hero p { max-width: 76ch; color: var(--ink-soft); font-size: 1.1rem; }
main section { padding: clamp(2rem, 5vw, 4rem) 0; }
.section-kicker { text-transform: uppercase; letter-spacing: .11em; color: var(--lime-dark); font-weight: 900; font-size: .86rem; margin: 0 0 .45rem; }
.grid { display: grid; grid-template-columns: repeat(12, minmax(0, 1fr)); gap: 1.05rem; }
.card { background: var(--paper); border: 1px solid var(--border); border-radius: var(--radius); padding: clamp(1rem, 2vw, 1.35rem); box-shadow: 0 1px 0 rgba(0,0,0,.03); }
.card.highlight { background: #f9fbe9; border-color: #cbd77b; }
.col-3 { grid-column: span 3; } .col-4 { grid-column: span 4; } .col-5 { grid-column: span 5; } .col-6 { grid-column: span 6; } .col-7 { grid-column: span 7; } .col-8 { grid-column: span 8; } .col-12 { grid-column: span 12; }
.stat strong { display:block; font-size: 2rem; color: #566400; }
.clean-list { padding-left: 1.1rem; margin: .5rem 0 0; }
.clean-list li + li { margin-top: .35rem; }
.quote { border-left: 6px solid var(--lime); font-size: 1.08rem; }
.meta { color: var(--muted); font-size: .95rem; }
.callout { background: var(--ink); color: #fff; border-radius: 1.3rem; padding: clamp(1.25rem, 3vw, 2rem); }
.callout a { color: #e8f18e; }
.gallery { display:grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.gallery img { width:100%; aspect-ratio: 4/3; object-fit: cover; border-radius: 1rem; border: 1px solid var(--border); background: #000; }
form label { display:block; margin-top:.8rem; font-weight: 800; }
input, textarea, select { width:100%; min-height: 46px; font: inherit; padding: .7rem .8rem; border: 1px solid #aab17d; border-radius: .7rem; background: #fff; }
textarea { min-height: 140px; resize: vertical; }
.site-footer { background: #050505; color: #eeeeee; padding: 2.3rem 0; margin-top: 2rem; border-top: 5px solid var(--lime); }
.site-footer a { color: #e8f18e; }
.footer-grid { display:grid; grid-template-columns: 2fr 1fr 1fr; gap: 1.25rem; }
.footer-title { color:#fff; margin:0 0 .6rem; font-size:1.05rem; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
:focus-visible { outline: 3px solid var(--focus); outline-offset: 3px; }
@media (max-width: 1080px) { .menu-link { font-size:.9rem; padding-inline:.48rem; } .brand img { width:178px; } }
@media (max-width: 920px) {
  .header-inner { flex-wrap: wrap; min-height: 78px; padding: .5rem 0 .75rem; }
  .brand img { width: 166px; }
  .nav-toggle { display: inline-flex; margin-left: auto; }
  .main-nav { width: 100%; display:flex; flex-direction:column; align-items:flex-end; }
  .menu { display:none; width:100%; margin-top:.55rem; padding:.55rem; background:#161616; border:1px solid #3f3f3f; border-radius:1rem; flex-direction:column; align-items:stretch; gap:.25rem; }
  .main-nav.menu-open .menu { display:flex; }
  .menu-row { justify-content:space-between; width:100%; }
  .menu-link { width:100%; font-size:1rem; padding:.7rem .8rem; }
  .submenu-toggle { width: 46px; height: 46px; }
  .submenu { position:static; max-height:0; opacity:1; transform:none; pointer-events:auto; box-shadow:none; border-radius:.85rem; transition:max-height .25s ease; }
  .menu-item.open > .submenu { max-height: 420px; }
  .hero-grid { grid-template-columns:1fr; }
  .col-3,.col-4,.col-5,.col-6,.col-7,.col-8 { grid-column:span 12; }
  .gallery { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
}
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration:.01ms!important; transition-duration:.01ms!important; scroll-behavior:auto!important; } }