@font-face { font-family: 'Hedley New'; src: url('fonts/HedleyNew-Lt.woff2') format('woff2'); font-weight: 300; font-display: swap; }
@font-face { font-family: 'Hedley New'; src: url('fonts/HedleyNew-Rg.woff2') format('woff2'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'Hedley New'; src: url('fonts/HedleyNew-Md.woff2') format('woff2'); font-weight: 500; font-display: swap; }

:root {
  --ink: #0A1411; --cream-text: #E9E2CE; --accent: #E8D3A2; --cream-bg: #E9E2CE;
  --foliage-back: #173B31; --foliage-front: #0B231C; --foliage-footer: #11291F;
  --hairline: rgba(233,226,206,.14); --muted: rgba(233,226,206,.7);
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--ink); color: var(--cream-text); font-family: 'Hedley New', Georgia, serif; }
a { color: inherit; }

@keyframes sgSway  { 0%,100% { transform: rotate(-1.6deg); } 50% { transform: rotate(1.9deg); } }
@keyframes sgSway2 { 0%,100% { transform: rotate(2.1deg); }  50% { transform: rotate(-1.3deg); } }
.sway1 { animation: sgSway 9s ease-in-out infinite;  transform-box: fill-box; transform-origin: 50% 100%; }
.sway2 { animation: sgSway2 10.5s ease-in-out infinite; transform-box: fill-box; transform-origin: 50% 100%; }
@media (prefers-reduced-motion: reduce) { .sway1, .sway2 { animation: none; } }

.foliage { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.foliage svg { display: block; width: 100%; height: 100%; }

header.site { display: flex; align-items: center; justify-content: space-between; padding: 20px 48px; border-bottom: 1px solid var(--hairline); position: relative; z-index: 5; }
header.site .logo img { height: 24px; filter: brightness(0) invert(0.92); display: block; }
header.site nav { display: flex; gap: 36px; font-size: 14px; letter-spacing: .08em; text-transform: uppercase; }
header.site nav a { color: var(--cream-text); opacity: .7; text-decoration: none; }
header.site nav a:hover { opacity: 1; }
header.site nav a.active { color: var(--accent); opacity: 1; }
.header-meta { display: flex; gap: 24px; font-size: 14px; letter-spacing: .08em; text-transform: uppercase; opacity: .8; }
.header-meta a { text-decoration: none; }

.kicker { letter-spacing: .22em; text-transform: uppercase; font-size: 12px; color: var(--accent); margin-bottom: 12px; }
.btn { display: inline-block; padding: 12px 34px; font-size: 13px; letter-spacing: .18em; text-transform: uppercase; cursor: pointer; text-decoration: none; transition: all 220ms cubic-bezier(.2,.7,.2,1); }
.btn-outline { border: 1px solid var(--accent); color: var(--accent); }
.btn-outline:hover { background: var(--accent); color: var(--ink); }
.btn-solid { background: var(--accent); color: var(--ink); border: 1px solid var(--accent); }
.btn-solid:hover { opacity: .85; }
.btn:active { transform: translateY(1px); }

/* ---- homepage hero ---- */
.hero { position: relative; height: 880px; overflow: hidden; background: radial-gradient(ellipse 60% 46% at 50% 46%, #1D3A31 0%, #0E1F1A 55%, #0A1411 100%); }
.hero-inner { position: relative; z-index: 3; display: flex; flex-direction: column; align-items: center; text-align: center; padding-top: 84px; }
.eyebrow { font-size: 13px; letter-spacing: .34em; text-transform: uppercase; color: var(--accent); }
.hero h1 { margin: 22px 0 0; font-weight: 300; font-size: 76px; line-height: 1.04; max-width: 820px; text-wrap: balance; color: var(--cream-text); }
.hero .sub { margin: 20px 0 0; font-size: 19px; line-height: 1.6; max-width: 560px; color: rgba(233,226,206,.78); }
.products { display: flex; gap: 40px; margin-top: 48px; align-items: flex-end; }
.product { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.product img { filter: drop-shadow(0 30px 40px rgba(0,0,0,.55)); }
.product .price-line { font-size: 16px; }
.product .price-line b { color: var(--accent); font-weight: 400; }

/* ---- interior page hero (shorter, foliage rising from the base) ---- */
.page-hero { position: relative; overflow: hidden; padding: 104px 120px 92px; border-bottom: 1px solid var(--hairline); background: radial-gradient(ellipse 78% 120% at 50% 8%, #17342A 0%, #0E1F1A 52%, #0A1411 100%); }
.page-hero .inner { position: relative; z-index: 3; }
.page-hero .eyebrow { font-size: 13px; letter-spacing: .34em; text-transform: uppercase; color: var(--accent); }
.page-hero h1 { margin: 18px 0 0; font-weight: 300; font-size: 60px; line-height: 1.06; max-width: 900px; text-wrap: balance; color: var(--cream-text); }
.page-hero .sub { margin: 20px 0 0; font-size: 18px; line-height: 1.6; max-width: 600px; color: rgba(233,226,206,.78); }

.claims { display: flex; justify-content: center; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.claims div { padding: 22px 30px; font-size: 13px; letter-spacing: .14em; text-transform: uppercase; color: rgba(233,226,206,.75); border-right: 1px solid rgba(233,226,206,.12); }
.claims div:last-child { border-right: none; }

.kills { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; padding: 96px 120px; }
.kills h2 { margin: 16px 0 0; font-weight: 300; font-size: 40px; line-height: 1.15; color: var(--cream-text); }
.kills .lede { margin: 20px 0 0; font-size: 16px; line-height: 1.7; color: var(--muted); max-width: 44ch; }
.kill-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; font-size: 15px; line-height: 2.1; }
.kill-cols .list { color: rgba(233,226,206,.85); }

.tech { background: var(--cream-bg); color: var(--ink); padding: 96px 120px; display: grid; grid-template-columns: 380px 1fr; gap: 90px; align-items: center; }
.tech h2 { margin: 16px 0 0; font-weight: 300; font-size: 40px; line-height: 1.15; color: var(--ink); }
.tech .kicker { color: inherit; opacity: .6; letter-spacing: .3em; }
.tech p { margin: 20px 0 0; font-size: 17px; line-height: 1.7; max-width: 58ch; opacity: .85; }
.tech-stats { display: flex; gap: 56px; margin-top: 36px; }
.tech-stats .n { font-size: 30px; font-weight: 400; }
.tech-stats .d { font-size: 14px; opacity: .65; margin-top: 4px; }

.dilution { padding: 96px 120px; }
.dilution h2 { margin: 16px 0 40px; font-weight: 300; font-size: 40px; color: var(--cream-text); }
.dilution-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: rgba(233,226,206,.16); }
.dilution-grid > div { background: var(--ink); padding: 28px 26px; }
.dilution-grid .ratio { font-size: 26px; color: var(--accent); }
.dilution-grid .use { margin-top: 8px; font-size: 14px; color: var(--muted); }
.dilution .fine { margin: 26px 0 0; font-size: 14px; color: rgba(233,226,206,.55); }

/* ---- generic section ---- */
.section { padding: 88px 120px; }
.section > h2 { margin: 14px 0 0; font-weight: 300; font-size: 40px; line-height: 1.15; }
.section .lede { margin: 20px 0 0; font-size: 16px; line-height: 1.7; color: var(--muted); max-width: 60ch; }

/* ---- stores ---- */
.state-nav { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 40px; }
.state-nav a { font-size: 13px; letter-spacing: .1em; padding: 8px 14px; border: 1px solid var(--hairline); color: rgba(233,226,206,.8); text-decoration: none; transition: all 180ms; }
.state-nav a:hover { border-color: var(--accent); color: var(--accent); }
.state-block { margin-top: 64px; scroll-margin-top: 24px; }
.state-block h2 { font-weight: 300; font-size: 26px; color: var(--accent); margin: 0 0 4px; }
.state-block .count { font-size: 13px; letter-spacing: .12em; text-transform: uppercase; color: rgba(233,226,206,.5); }
.store-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(233,226,206,.16); margin-top: 22px; }
.store { background: var(--ink); padding: 24px 24px 26px; }
.store .name { font-size: 17px; color: var(--cream-text); }
.store .phone { margin-top: 8px; font-size: 14px; }
.store .phone a { color: var(--accent); text-decoration: none; }
.store .addr { margin-top: 6px; font-size: 14px; line-height: 1.6; color: rgba(233,226,206,.62); }

/* ---- media / press ---- */
.press-feature { margin-top: 44px; border: 1px solid var(--hairline); padding: 44px 48px; display: grid; grid-template-columns: 1fr auto; gap: 40px; align-items: center; }
.press-feature .meta { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); }
.press-feature h3 { margin: 14px 0 0; font-weight: 300; font-size: 27px; line-height: 1.28; max-width: 30ch; color: var(--cream-text); }
.coverage-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(233,226,206,.16); margin-top: 20px; }
.coverage-grid a { background: var(--ink); padding: 30px 26px; text-decoration: none; display: flex; flex-direction: column; gap: 10px; transition: background 180ms; }
.coverage-grid a:hover { background: #0E1F1A; }
.coverage-grid .outlet { font-size: 18px; color: var(--cream-text); }
.coverage-grid .go { font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); }

/* ---- contact ---- */
.contact-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 90px; }
.contact-info .row { margin-top: 26px; }
.contact-info .row .lbl { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: rgba(233,226,206,.5); margin-bottom: 8px; }
.contact-info .row .val { font-size: 17px; line-height: 1.7; }
.contact-info .row .val a { color: var(--accent); text-decoration: none; }
.form-field { margin-bottom: 22px; }
.form-field label { display: block; font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: rgba(233,226,206,.6); margin-bottom: 10px; }
.form-field input, .form-field textarea { width: 100%; background: transparent; border: 1px solid rgba(233,226,206,.35); color: var(--cream-text); font-family: inherit; font-size: 15px; padding: 13px 15px; }
.form-field textarea { min-height: 130px; resize: vertical; }
.form-field input:focus, .form-field textarea:focus { outline: none; border-color: var(--accent); }
.contact-form button { background: var(--accent); color: var(--ink); border: none; padding: 14px 40px; font-size: 13px; letter-spacing: .18em; text-transform: uppercase; cursor: pointer; font-family: inherit; }

/* ---- footer ---- */
footer.site { position: relative; border-top: 1px solid var(--hairline); padding: 64px 120px 100px; overflow: hidden; }
footer.site .cols { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 60px; }
footer.site img.logo { height: 22px; filter: brightness(0) invert(0.92); }
footer.site p, footer.site .body { font-size: 14px; line-height: 1.9; color: rgba(233,226,206,.65); }
footer.site a { text-decoration: none; }
.signup { display: flex; }
.signup input { border: 1px solid rgba(233,226,206,.35); border-right: none; background: transparent; padding: 12px 16px; font-size: 14px; color: var(--cream-text); flex: 1; font-family: inherit; }
.signup input::placeholder { color: rgba(233,226,206,.5); }
.signup button { background: var(--accent); color: var(--ink); border: none; padding: 12px 22px; font-size: 13px; letter-spacing: .14em; text-transform: uppercase; cursor: pointer; font-family: inherit; }

/* ---- responsive (design floor is 1240px; below that: stack + drop side leaves) ---- */
@media (max-width: 1240px) {
  header.site { padding: 16px 24px; flex-wrap: wrap; gap: 12px 24px; }
  header.site nav { gap: 20px; }
  .foliage use.edges { display: none; }
  .hero { height: auto; padding-bottom: 140px; }
  .hero-inner { padding: 64px 24px 0; }
  .hero h1 { font-size: 52px; }
  .hero .sub { font-size: 17px; }
  .products { flex-direction: column; align-items: center; gap: 56px; }
  .page-hero { padding: 72px 24px 76px; }
  .page-hero h1 { font-size: 44px; }
  .claims { display: grid; grid-template-columns: repeat(3, 1fr); text-align: center; }
  .claims div { border-right: none; padding: 18px 16px; }
  .kills, .tech, .dilution, .section { padding: 64px 24px; }
  .kills { grid-template-columns: 1fr; gap: 48px; }
  .tech { grid-template-columns: 1fr; gap: 48px; }
  .tech svg { max-width: 320px; margin: 0 auto; display: block; }
  .dilution-grid { grid-template-columns: 1fr 1fr; }
  .store-grid, .coverage-grid { grid-template-columns: 1fr 1fr; }
  .press-feature { grid-template-columns: 1fr; gap: 28px; }
  .contact-cols { grid-template-columns: 1fr; gap: 52px; }
  footer.site { padding: 56px 24px 120px; }
  footer.site .cols { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 640px) {
  .hero h1 { font-size: 40px; }
  .page-hero h1 { font-size: 34px; }
  .eyebrow, .page-hero .eyebrow { font-size: 11px; letter-spacing: .22em; }
  .claims { grid-template-columns: 1fr 1fr; }
  .dilution-grid, .store-grid, .coverage-grid { grid-template-columns: 1fr; }
  .tech-stats { flex-wrap: wrap; gap: 28px; }
}
