/* styles.css — Base styles shared by all pages */

:root {
    --color-deep-forest: #1a2e1a;
    --color-forest: #2d4a2d;
    --color-moss: #4a6741;
    --color-sage: #7a9e7a;
    --color-fern: #8fb08f;
    --color-mist: #c8d9c8;
    --color-morning-light: #e8f0e8;
    --color-golden-hour: #d4a574;
    --color-sunbeam: #e8c49a;
    --color-warm-glow: #f5e6d3;
    --color-dawn: #fff8f0;
    --color-bark: #3d352e;
    --color-earth: #5c524a;
    --color-white: #ffffff;
    --font-display: 'Cormorant Garamond', Georgia, serif;
    --font-body: 'Nunito Sans', -apple-system, sans-serif;
    --transition-smooth: all 0.4s ease;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; max-width: 100%; }
body { font-family: var(--font-body); font-weight: 300; font-size: 17px; overflow-x: hidden; }
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 500; line-height: 1.2; }
a { text-decoration: none; transition: var(--transition-smooth); }
a:hover { color: var(--color-golden-hour); }

.container { max-width: 1100px; width: 100%; margin: 0 auto; padding: 0 2rem; }

nav { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; padding: 0.5rem 0; background: rgba(26,46,26,0.95); backdrop-filter: blur(20px); }
nav .container { display: flex; justify-content: space-between; align-items: center; max-width: 1100px; }
.logo { font-family: var(--font-display); font-size: 1.3rem; color: var(--color-mist); display: flex; align-items: center; gap: 0.5rem; flex-shrink: 0; }
.logo img { height: 150px; width: auto; display: block; margin: -0.5rem 0 -4.5rem -2rem; }
.logo span { color: var(--color-golden-hour); }
.nav-links { display: flex; gap: 0.6rem; list-style: none; align-items: center; margin-left: auto; padding-right: 0; margin-top: 2rem; }
.nav-links a { font-size: 0.85rem; color: var(--color-sage); white-space: nowrap; }
.nav-links a:hover { color: var(--color-warm-glow); }
.mobile-menu { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 5px; }
.mobile-menu span { width: 24px; height: 2px; background: var(--color-sage); }

.btn { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.9rem 1.8rem; font-family: var(--font-body); font-size: 0.95rem; border-radius: 3rem; border: none; cursor: pointer; transition: var(--transition-smooth); }
.btn-primary { background: var(--color-golden-hour); color: var(--color-deep-forest); }
.btn-primary:hover { background: var(--color-sunbeam); transform: translateY(-2px); }
.btn-secondary { background: transparent; color: var(--color-mist); border: 1px solid var(--color-sage); }
.btn-secondary:hover { background: rgba(127, 158, 127, 0.2); border-color: var(--color-mist); color: var(--color-white); }

.reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal.active { opacity: 1; transform: translateY(0); }

@media (max-width: 768px) {
    .nav-links { display: none; position: absolute; top: 100%; left: 0; right: 0; background: var(--color-deep-forest); flex-direction: column; padding: 2rem; gap: 1.5rem; }
    .nav-links.active { display: flex; }
    .mobile-menu { display: flex; }
    .logo img { height: 80px; margin: -1rem 0; }
}
