/* Old Ridge Timber — shared styles */
:root {
  --cream: #F5F1E8;
  --cream-2: #EFEADC;
  --green: #2E3B2B;
  --green-deep: #25301F;
  --copper: #B26B3A;
  --copper-dark: #9C5A2E;
  --body: #565649;
  --hairline: #DDD6C4;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', sans-serif;
  background: var(--cream);
  color: var(--body);
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img, video { display: block; }
h1, h2, h3 { font-family: 'Fraunces', serif; color: var(--green); line-height: 1.1; letter-spacing: -0.012em; font-weight: 600; }
.wrap { max-width: 1420px; margin: 0 auto; padding: 0 4.5vw; }

/* ---------- NAV ---------- */
nav.site-nav {
  position: sticky; top: 0; z-index: 200;
  background: rgba(245,241,232,0.94); backdrop-filter: blur(10px);
  box-shadow: 0 1px 0 var(--hairline);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; }
.nav-brand { display: flex; align-items: center; text-decoration: none; }
.nav-brand img { height: 76px; width: auto; }
@media (max-width: 600px) { .nav-brand img { height: 58px; } }
.nav-links { display: flex; gap: 34px; align-items: center; }
.nav-links a { font-family: 'Fraunces', serif; text-decoration: none; font-size: 1.05rem; color: var(--green); transition: color 200ms ease; }
.nav-links a:hover { color: var(--copper); }
.nav-links a.active { color: var(--copper); }
.nav-links a.cta {
  font-family: 'Fraunces', serif; font-size: 1.02rem;
  background: var(--copper); color: var(--cream);
  padding: 12px 28px; border-radius: 8px;
  transition: background 250ms ease, transform 250ms ease;
}
.nav-links a.cta:hover { background: var(--copper-dark); color: var(--cream); transform: translateY(-1px); }

/* mobile menu */
.menu-btn {
  display: none;
  background: none; border: none; cursor: pointer;
  padding: 10px;
}
.menu-btn span { display: block; width: 26px; height: 2px; background: var(--green); margin: 6px 0; transition: transform 250ms ease, opacity 250ms ease; }
@media (max-width: 900px) {
  .menu-btn { display: block; }
  .nav-links {
    position: fixed; inset: 0; top: 0;
    background: var(--cream);
    flex-direction: column; justify-content: center; align-items: center; gap: 30px;
    opacity: 0; visibility: hidden; pointer-events: none;
    transition: opacity 250ms ease, visibility 250ms ease;
    z-index: 150;
  }
  .nav-links.open { opacity: 1; visibility: visible; pointer-events: auto; }
  .nav-links a { font-size: 1.6rem; color: var(--green); }
  body.menu-open { overflow: hidden; }
  .menu-btn.open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
  .menu-btn.open span:nth-child(2) { opacity: 0; }
  .menu-btn.open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
  .menu-btn { position: relative; z-index: 160; }
}

/* ---------- PAGE HEADER ---------- */
.page-head { padding: 11vh 0 9vh; border-bottom: 1px solid var(--hairline); }
.page-head .kicker { margin-bottom: 18px; }
.page-head h1 { font-size: clamp(2.6rem, 5vw, 4.2rem); max-width: 820px; }
.page-head p.intro { margin-top: 24px; font-size: 1.15rem; max-width: 600px; }

/* ---------- SHARED ELEMENTS ---------- */
.kicker {
  font-size: 0.82rem; font-weight: 700; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--copper);
}
.title { font-size: clamp(2.1rem, 3.8vw, 3.2rem); max-width: 680px; }
section { padding: 11vh 0; }
.divider {
  display: flex; align-items: center; gap: 14px;
  width: min(360px, 70%);
  margin: 30px 0;
}
.divider::before, .divider::after { content: ''; height: 1px; background: var(--copper); flex: 1; opacity: 0.75; }
.divider i { width: 9px; height: 9px; border: 1.5px solid var(--copper); transform: rotate(45deg); }

.btn {
  display: inline-block; text-decoration: none;
  font-family: 'Inter', sans-serif;
  font-size: 0.84rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 18px 34px; border-radius: 8px;
  transition: background 250ms ease, color 250ms ease, transform 250ms ease, border-color 250ms ease;
}
.btn.solid { background: var(--copper); color: var(--cream); }
.btn.solid:hover { background: var(--copper-dark); transform: translateY(-2px); }
.btn.outline { border: 1.5px solid #C9C2AF; color: var(--green); }
.btn.outline:hover { border-color: var(--copper); color: var(--copper); transform: translateY(-2px); }

/* alternating photo/text rows */
.feature-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6vw;
  align-items: center;
  padding: 7vh 0;
  border-bottom: 1px solid var(--hairline);
}
.feature-row:last-of-type { border-bottom: none; }
@media (max-width: 880px) { .feature-row { grid-template-columns: 1fr; gap: 32px; } .feature-row .ph { order: -1; } }
.feature-row .ph { border-radius: 12px; overflow: hidden; }
.feature-row .ph img { width: 100%; aspect-ratio: 16/11; object-fit: cover; transition: transform 800ms cubic-bezier(.22,1,.36,1); }
.feature-row:hover .ph img { transform: scale(1.04); }
.feature-row .n { font-size: 0.8rem; font-weight: 700; letter-spacing: 0.26em; color: var(--copper); margin-bottom: 16px; }
.feature-row h2 { font-size: clamp(1.8rem, 3vw, 2.6rem); margin-bottom: 16px; }
.feature-row p { max-width: 500px; }
.feature-row p + p { margin-top: 14px; }

/* cards */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 28px; }
.card {
  background: #FBF9F3;
  border: 1px solid var(--hairline);
  border-radius: 12px; overflow: hidden;
  transition: transform 350ms ease, box-shadow 350ms ease;
}
.card:hover { transform: translateY(-6px); box-shadow: 0 26px 50px rgba(46,59,43,0.12); }
.card .ph { height: 260px; overflow: hidden; }
.card .ph img { width: 100%; height: 100%; object-fit: cover; transition: transform 900ms cubic-bezier(.22,1,.36,1); }
.card:hover .ph img { transform: scale(1.06); }
.card .body { padding: 28px 28px 36px; }
.card h3 { font-size: 1.5rem; font-weight: 500; margin-bottom: 12px; }
.card p { font-size: 0.97rem; }

/* steps */
.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 44px; }
.step { border-top: 1px solid rgba(245,241,232,0.25); padding-top: 26px; }
.step .num { font-family: 'Fraunces', serif; font-size: 2.8rem; font-weight: 400; color: #D9B68C; line-height: 1; }
.step h3 { color: var(--cream); font-size: 1.3rem; font-weight: 500; margin: 18px 0 10px; }
.step p { font-size: 0.95rem; color: rgba(245,241,232,0.78); }
.green-band { background: var(--green); }
.green-band .kicker { color: #D9B68C; }
.green-band .title, .green-band h2 { color: var(--cream); }
.green-band p { color: rgba(245,241,232,0.78); }

/* steps on light background */
.steps-light { display: grid; grid-template-columns: 110px 1fr; gap: 32px; align-items: baseline; padding: 40px 0; border-bottom: 1px solid var(--hairline); }
.steps-light:last-of-type { border-bottom: none; }
@media (max-width: 640px) { .steps-light { grid-template-columns: 60px 1fr; gap: 18px; } }
.steps-light .num { font-family: 'Fraunces', serif; font-size: 3rem; font-weight: 400; color: var(--copper); line-height: 1; }
.steps-light h3 { font-size: 1.5rem; font-weight: 500; margin-bottom: 10px; }
.steps-light p { max-width: 640px; }

/* species table */
.sp-table { border-top: 1px solid var(--hairline); }
.sp-row {
  display: grid; grid-template-columns: 1.4fr 0.8fr 1.8fr;
  gap: 20px;
  padding: 22px 8px;
  border-bottom: 1px solid var(--hairline);
  transition: background 200ms ease;
  align-items: baseline;
}
.sp-row:hover { background: #F0EBDF; }
.sp-row .n { font-family: 'Fraunces', serif; font-size: 1.25rem; color: var(--green); }
.sp-row .c { font-size: 0.82rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--copper); }
.sp-row .p { font-size: 0.97rem; }
@media (max-width: 700px) { .sp-row { grid-template-columns: 1fr; gap: 4px; } }

/* FAQ */
.faq { max-width: 880px; }
.faq details { border-bottom: 1px solid var(--hairline); }
.faq summary {
  cursor: pointer; list-style: none;
  display: flex; justify-content: space-between; align-items: center; gap: 20px;
  padding: 26px 4px;
  font-family: 'Fraunces', serif; font-size: 1.3rem; color: var(--green);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: '+'; font-size: 1.6rem; color: var(--copper); flex: 0 0 auto; transition: transform 250ms ease; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq .a { padding: 0 4px 26px; max-width: 720px; }

/* CTA band */
.cta-band { background: var(--cream-2); border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.cta-band .inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; padding: 8vh 0; }
.cta-band h2 { font-size: clamp(1.9rem, 3.4vw, 2.8rem); max-width: 620px; }
.cta-band p { margin-top: 10px; max-width: 520px; }

/* contact form */
.form-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 6vw; align-items: start; }
@media (max-width: 880px) { .form-grid { grid-template-columns: 1fr; } }
.quote-form {
  display: grid; gap: 14px;
  background: #FBF9F3;
  border: 1px solid var(--hairline);
  border-radius: 12px;
  padding: 44px;
  box-shadow: 0 30px 60px rgba(46,59,43,0.08);
}
@media (max-width: 720px) { .quote-form { padding: 26px 18px; } }
.quote-form input, .quote-form textarea, .quote-form select {
  font-family: 'Inter', sans-serif; font-size: 0.96rem;
  padding: 16px 18px;
  border: 1px solid var(--hairline);
  border-radius: 8px;
  background: var(--cream);
  color: var(--green); width: 100%;
}
.quote-form ::placeholder { color: #9B988A; }
.quote-form input:focus, .quote-form textarea:focus, .quote-form select:focus { outline: none; border-color: var(--copper); }
.quote-form button {
  font-family: 'Inter', sans-serif;
  font-size: 0.86rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  background: var(--copper); color: var(--cream);
  border: none; cursor: pointer;
  padding: 19px; border-radius: 8px;
  transition: background 250ms ease, transform 250ms ease;
}
.quote-form button:hover { background: var(--copper-dark); transform: translateY(-2px); }

/* ---------- FOOTER ---------- */
footer.site-footer { background: var(--green-deep); color: rgba(245,241,232,0.65); }
.footer-grid {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr;
  gap: 48px;
  padding: 72px 0 56px;
}
@media (max-width: 800px) { .footer-grid { grid-template-columns: 1fr; gap: 36px; } }
.footer-grid .brand img { height: 84px; width: auto; filter: brightness(0) invert(0.96) sepia(0.08); }
.footer-grid .brand p { margin-top: 18px; max-width: 320px; font-size: 0.95rem; }
.footer-grid h4 {
  font-size: 0.8rem; font-weight: 700; letter-spacing: 0.24em; text-transform: uppercase;
  color: #D9B68C; margin-bottom: 18px;
}
.footer-grid ul { list-style: none; }
.footer-grid li { margin-bottom: 10px; }
.footer-grid a { color: rgba(245,241,232,0.8); text-decoration: none; transition: color 200ms ease; }
.footer-grid a:hover { color: var(--cream); }
.footer-base { border-top: 1px solid rgba(245,241,232,0.15); padding: 26px 0 34px; font-size: 0.85rem; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.footer-base .legal-links a { color: rgba(245,241,232,0.65); text-decoration: none; margin-left: 24px; transition: color 200ms ease; }
.footer-base .legal-links a:first-child { margin-left: 0; }
.footer-base .legal-links a:hover { color: var(--cream); }

/* legal pages */
.legal { max-width: 820px; }
.legal a { color: var(--copper); text-decoration-color: rgba(178,107,58,0.45); }
.legal a:hover { color: var(--copper-dark); }
.legal h2 { font-size: 1.5rem; margin: 44px 0 14px; }
.legal p, .legal li { font-size: 1rem; }
.legal p + p { margin-top: 12px; }
.legal ul { margin: 12px 0 0 22px; }
.legal li { margin-bottom: 8px; }
.legal .updated { font-size: 0.88rem; color: #8B887A; margin-top: 10px; }

/* reveal */
.fade { opacity: 0; transform: translateY(26px); transition: opacity 750ms ease, transform 750ms ease; }
.fade.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .fade { opacity: 1 !important; transform: none !important; transition: none; }
}
