/* Plain CSS — applied on top of Tailwind. Tailwind's @theme + utility layers live inside each page's <style type="text/tailwindcss"> block. */

:root {
  --color-cream: #FBFDF5;
  --color-cream-2: #EEF7DF;
  --color-ink: #14210E;
  --color-ink-2: #314126;
  --color-muted: #687A5A;
  --color-line: #D6E8C4;
  --color-saffron: #7CB342;
  --color-saffron-2: #5E9F2F;
  --color-marigold: #27A9D8;
  --color-teal: #0E8FBD;
  --color-teal-2: #086D91;
  --color-rose: #A6C84B;
  --radius-xl2: 1.5rem;
  --shadow-soft: 0 1px 2px rgba(20, 33, 14, 0.04), 0 8px 30px rgba(20, 33, 14, 0.08);
  --font-display: "Fraunces", "Source Serif 4", Georgia, serif;
  --font-sans: "Plus Jakarta Sans", "Inter", system-ui, sans-serif;
}

html { scroll-behavior: smooth; }
body {
  font-family: var(--font-sans);
  color: var(--color-ink);
  background: var(--color-cream);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  opacity: 0;
  transition: opacity .25s ease;
}
body.is-ready { opacity: 1; }
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: -0.015em;
  color: var(--color-ink);
}
:focus-visible {
  outline: 2px solid var(--color-saffron);
  outline-offset: 3px;
  border-radius: 4px;
}
::selection { background: #27A9D866; color: var(--color-ink); }

.font-display { font-family: var(--font-display); }
.font-sans { font-family: var(--font-sans); }

.container-wide { max-width: 80rem; margin-inline: auto; padding-inline: 1.25rem; }
.container-narrow { max-width: 56rem; margin-inline: auto; padding-inline: 1.25rem; }
@media (min-width: 640px) { .container-wide, .container-narrow { padding-inline: 2rem; } }

.nav-link {
  position: relative;
  color: var(--color-ink-2);
  font-size: 0.925rem;
  font-weight: 500;
  transition: color .2s ease;
}
.nav-link:hover { color: var(--color-saffron-2); }
.nav-link[aria-current="page"] { color: var(--color-saffron-2); }
.nav-link[aria-current="page"]::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -6px; height: 2px;
  background: var(--color-saffron); border-radius: 2px;
}

.btn { display: inline-flex; align-items: center; gap: .5rem; padding: .8rem 1.4rem; border-radius: 999px; font-weight: 600; font-size: .95rem; transition: transform .15s ease, background .2s ease, color .2s ease, box-shadow .2s ease; line-height: 1; }
.btn-primary { background: var(--color-saffron); color: #fff; }
.btn-primary:hover { background: var(--color-saffron-2); transform: translateY(-1px); box-shadow: 0 10px 24px rgba(124,179,66,.28); }
.btn-ghost { background: transparent; color: var(--color-ink); border: 1.5px solid var(--color-line); }
.btn-ghost:hover { border-color: var(--color-ink); }
.btn-dark { background: var(--color-teal); color: #fff; }
.btn-dark:hover { background: var(--color-teal-2); }

.chip { display:inline-flex; align-items:center; gap:.4rem; padding:.35rem .75rem; border-radius:999px; background:#EEF7DF; color:var(--color-ink-2); font-size:.78rem; font-weight:600; letter-spacing:.02em; }
.chip-teal { background: rgba(14,143,189,0.1); color:var(--color-teal); }
.chip-saffron { background: rgba(124,179,66,0.13); color:var(--color-saffron-2); }

.card { background:#fff; border: 1px solid var(--color-line); border-radius: var(--radius-xl2); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft); border-color: #BCD9A3; }

.eyebrow { font-family: var(--font-sans); font-weight: 600; font-size: .78rem; letter-spacing: .14em; text-transform: uppercase; color: var(--color-saffron-2); }

.prose-warm p { color: var(--color-ink-2); line-height: 1.75; }

.grain {
  background-image:
    radial-gradient(circle at 1px 1px, rgba(20,33,14,.06) 1px, transparent 0);
  background-size: 24px 24px;
}

.photo-1 { background: linear-gradient(135deg,#A6C84B 0%, #7CB342 55%, #27A9D8 100%); }
.photo-2 { background: linear-gradient(135deg,#0E8FBD 0%, #086D91 100%); }
.photo-3 { background: linear-gradient(135deg,#EEF7DF 0%, #D6E8C4 100%); }
.photo-4 { background: linear-gradient(135deg,#5E9F2F 0%, #0E8FBD 100%); }
.photo-5 { background: linear-gradient(135deg,#A6C84B 0%, #27A9D8 100%); }

.mobile-menu {
  max-height: 0;
  overflow: hidden;
  transform: translateY(-8px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    max-height .25s ease,
    opacity .2s ease,
    transform .2s ease,
    visibility .2s ease;
}

.mobile-menu.open {
  max-height: 520px;
  transform: translateY(0);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.text-balance { text-wrap: balance; }
.text-pretty { text-wrap: pretty; }
.tabular { font-variant-numeric: tabular-nums lining-nums; }

@keyframes float {
  0%,100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}
.float-slow { animation: float 7s ease-in-out infinite; }

@keyframes fade-up {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}
.fade-up { animation: fade-up .7s cubic-bezier(.2,.6,.2,1) both; }
.delay-1 { animation-delay: .1s; }
.delay-2 { animation-delay: .2s; }
.delay-3 { animation-delay: .3s; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  html { scroll-behavior: auto; }
}

[data-header].is-scrolled { box-shadow: 0 1px 0 var(--color-line), 0 8px 24px rgba(20,33,14,0.06); border-bottom-color: var(--color-line); }
