/* ==========================================================================
   Hocking Hikes — Dark Forest Design System
   ========================================================================== */

:root {
    --bg: #080C06;
    --bg-light: #0E1409;
    --cream: #F2EDE4;
    --sage: #8DB87A;
    --moss: #4C7034;
    --moss-dark: #3A5628;
    --bark: #2A1F14;
    --gold: #C9A96E;
    --font-display: 'Playfair Display', Georgia, serif;
    --font-body: 'DM Sans', -apple-system, sans-serif;
    --max-width: 1200px;
    --radius: 12px;
    --transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); background: var(--bg); color: var(--cream); line-height: 1.6; -webkit-font-smoothing: antialiased; }
a { color: var(--sage); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--cream); }
img { max-width: 100%; display: block; }

/* Nav */
.main-nav { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; padding: 1rem 2rem; transition: background var(--transition), box-shadow var(--transition); }
.main-nav.scrolled { background: rgba(8,12,6,0.95); backdrop-filter: blur(12px); box-shadow: 0 1px 0 rgba(141,184,122,0.1); }
.nav-inner { max-width: var(--max-width); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; }
.nav-logo { display: flex; align-items: center; gap: 0.5rem; text-decoration: none; }
.logo-icon { font-size: 1.5rem; }
.logo-text { font-family: var(--font-display); font-size: 1.3rem; font-weight: 700; color: var(--cream); }
.logo-accent { color: var(--sage); }
.nav-links { display: flex; gap: 2rem; align-items: center; }
.nav-links a { font-family: var(--font-body); font-size: 0.95rem; font-weight: 500; color: rgba(242,237,228,0.7); transition: color var(--transition); }
.nav-links a:hover { color: var(--sage); }
.nav-toggle { display: none; background: none; border: none; cursor: pointer; width: 28px; height: 20px; position: relative; }
.nav-toggle span { display: block; width: 100%; height: 2px; background: var(--cream); position: absolute; left: 0; transition: var(--transition); }
.nav-toggle span:nth-child(1) { top: 0; }
.nav-toggle span:nth-child(2) { top: 9px; }
.nav-toggle span:nth-child(3) { top: 18px; }

/* Hero */
.hero { min-height: 100vh; display: flex; align-items: center; position: relative; overflow: hidden; padding: 6rem 2rem 4rem; }
.hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 30% 50%, rgba(76,112,52,0.15) 0%, transparent 60%), radial-gradient(ellipse at 80% 20%, rgba(141,184,122,0.08) 0%, transparent 50%); }
.hero::after { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(141,184,122,0.02) 2px, rgba(141,184,122,0.02) 4px); pointer-events: none; }
.hero-content { position: relative; z-index: 1; max-width: var(--max-width); margin: 0 auto; width: 100%; }
.hero-eyebrow { font-family: var(--font-body); font-size: 0.9rem; font-weight: 500; color: var(--sage); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 1.5rem; opacity: 0; animation: fadeUp 0.6s ease forwards 0.2s; }
.hero h1 { font-family: var(--font-display); font-size: clamp(3rem, 8vw, 6rem); font-weight: 800; line-height: 1.05; margin-bottom: 1.5rem; opacity: 0; animation: fadeUp 0.6s ease forwards 0.4s; }
.hero-sub { font-size: 1.15rem; color: rgba(242,237,228,0.7); max-width: 600px; line-height: 1.7; margin-bottom: 2.5rem; opacity: 0; animation: fadeUp 0.6s ease forwards 0.6s; }
.hero-stats { display: flex; gap: 2.5rem; flex-wrap: wrap; opacity: 0; animation: fadeUp 0.6s ease forwards 0.8s; }
.stat { display: flex; flex-direction: column; }
.stat-num { font-family: var(--font-display); font-size: 2rem; font-weight: 700; color: var(--sage); }
.stat-label { font-size: 0.85rem; color: rgba(242,237,228,0.5); margin-top: 0.25rem; }

/* Sections */
.section-inner { max-width: var(--max-width); margin: 0 auto; padding: 0 2rem; }
.trails-section { padding: 5rem 0; }
.section-title { font-family: var(--font-display); font-size: 2.5rem; margin-bottom: 0.75rem; }
.section-sub { color: rgba(242,237,228,0.6); font-size: 1.05rem; margin-bottom: 3rem; max-width: 600px; }

/* Trail Cards */
.trails-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 1.5rem; }
.trail-card { display: flex; flex-direction: column; background: rgba(141,184,122,0.04); border: 1px solid rgba(141,184,122,0.1); border-radius: var(--radius); padding: 1.75rem; text-decoration: none; color: var(--cream); transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition); }
.trail-card:hover { border-color: rgba(141,184,122,0.35); transform: translateY(-3px); box-shadow: 0 12px 40px rgba(0,0,0,0.3); color: var(--cream); }
.trail-card-icon { font-size: 2rem; margin-bottom: 0.75rem; }
.trail-card h3 { font-family: var(--font-display); font-size: 1.35rem; margin-bottom: 0.75rem; }
.trail-card-meta { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 1rem; }
.trail-card p { color: rgba(242,237,228,0.65); font-size: 0.95rem; line-height: 1.6; flex-grow: 1; }
.trail-card-link { color: var(--sage); font-weight: 600; font-size: 0.9rem; margin-top: 1rem; }

/* Badges */
.badge { display: inline-block; font-size: 0.78rem; font-weight: 600; padding: 0.2rem 0.65rem; border-radius: 20px; }
.badge-easy { background: rgba(141,184,122,0.2); color: var(--sage); }
.badge-moderate { background: rgba(201,169,110,0.2); color: var(--gold); }
.badge-hard { background: rgba(200,80,60,0.15); color: #E08060; }
.badge-yes { background: rgba(141,184,122,0.15); color: var(--sage); }
.badge-no { background: rgba(200,60,60,0.15); color: #E07070; }

/* Info Banner */
.info-banner { padding: 4rem 0; background: var(--bg-light); }
.info-banner h2 { font-family: var(--font-display); font-size: 2rem; margin-bottom: 2rem; text-align: center; }
.rules-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.25rem; }
.rule-item { display: flex; align-items: flex-start; gap: 0.75rem; background: rgba(141,184,122,0.05); border: 1px solid rgba(141,184,122,0.08); border-radius: 8px; padding: 1.25rem; }
.rule-icon { font-size: 1.5rem; flex-shrink: 0; }
.rule-item p { color: rgba(242,237,228,0.8); font-size: 0.95rem; line-height: 1.5; }

/* CTA Section */
.cta-section { padding: 5rem 0; }
.btn-primary { display: inline-block; background: var(--moss); color: var(--cream); padding: 0.9rem 2rem; border-radius: 8px; font-family: var(--font-body); font-weight: 700; font-size: 1rem; text-decoration: none; transition: background var(--transition); border: none; cursor: pointer; }
.btn-primary:hover { background: var(--sage); color: var(--bg); }

/* Trail Detail */
.trail-detail-inner { max-width: 780px; margin: 0 auto; padding: 2rem 1.5rem 4rem; }
.trail-hero-badge { font-size: 3.5rem; margin-bottom: 1rem; }
.trail-detail h1 { font-family: var(--font-display); font-size: clamp(2.2rem, 5vw, 3.2rem); margin-bottom: 1.5rem; }
.trail-meta-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 1rem; margin-bottom: 2rem; padding: 1.5rem; background: rgba(141,184,122,0.06); border: 1px solid rgba(141,184,122,0.15); border-radius: var(--radius); }
.meta-item { text-align: center; }
.meta-label { display: block; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.08em; color: rgba(242,237,228,0.5); margin-bottom: 0.25rem; }
.meta-value { display: block; font-size: 1.1rem; font-weight: 700; color: var(--sage); }
.trail-detail h2 { font-family: var(--font-display); font-size: 1.6rem; margin: 2.5rem 0 1rem; }
.trail-detail p { font-size: 1.05rem; color: rgba(242,237,228,0.85); line-height: 1.8; margin-bottom: 1.25rem; }
.trail-detail .highlights { background: rgba(141,184,122,0.06); padding: 1rem 1.25rem; border-radius: 8px; border-left: 3px solid var(--sage); }
.trail-cta { background: linear-gradient(135deg, rgba(76,112,52,0.3), rgba(141,184,122,0.15)); border: 1px solid rgba(141,184,122,0.3); border-radius: 16px; padding: 2rem; text-align: center; margin: 3rem 0 2rem; }
.trail-cta h3 { font-family: var(--font-display); font-size: 1.5rem; margin-bottom: 0.75rem; }
.trail-cta p { color: rgba(242,237,228,0.8); margin-bottom: 1.25rem; }

/* Shared Boxes */
.tip-box { background: rgba(76,112,52,0.15); border-left: 3px solid var(--moss); border-radius: 0 8px 8px 0; padding: 1.25rem; margin: 1.5rem 0; }
.tip-box p { margin: 0; color: rgba(242,237,228,0.9); font-size: 1.05rem; line-height: 1.7; }
.tip-box strong { color: var(--sage); }
.warning-box { background: rgba(200,60,60,0.1); border-left: 3px solid #C83C3C; border-radius: 0 8px 8px 0; padding: 1.25rem; margin: 1.5rem 0; }
.warning-box p { margin: 0; color: rgba(242,237,228,0.9); font-size: 1.05rem; line-height: 1.7; }
.warning-box strong { color: #E07070; }
.back-link { display: inline-block; color: var(--sage); font-size: 0.9rem; margin-bottom: 2rem; }
.back-link:hover { text-decoration: underline; }

/* Page Content */
.page-content { min-height: 80vh; }
.page-inner { max-width: 780px; margin: 0 auto; padding: 2rem 1.5rem 4rem; }
.page-inner h1 { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3rem); margin-bottom: 1.5rem; }
.page-inner h2 { font-family: var(--font-display); font-size: 1.5rem; margin: 2rem 0 0.75rem; }
.page-inner p { font-size: 1.05rem; color: rgba(242,237,228,0.85); line-height: 1.8; margin-bottom: 1.25rem; }
.page-inner.legal p, .page-inner.legal h2 { font-size: 0.95rem; }

/* Blog Grid */
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.25rem; }
.blog-card { display: block; background: rgba(141,184,122,0.04); border: 1px solid rgba(141,184,122,0.1); border-radius: var(--radius); padding: 1.5rem; text-decoration: none; color: var(--cream); transition: border-color var(--transition), transform var(--transition); }
.blog-card:hover { border-color: rgba(141,184,122,0.35); transform: translateY(-2px); color: var(--cream); }
.blog-card-tag { font-size: 0.78rem; font-weight: 600; color: var(--sage); text-transform: uppercase; letter-spacing: 0.08em; }
.blog-card h3 { font-family: var(--font-display); font-size: 1.2rem; margin: 0.5rem 0; }
.blog-card p { color: rgba(242,237,228,0.6); font-size: 0.9rem; line-height: 1.5; }

/* Contact Form */
.contact-form { max-width: 500px; }
.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; font-size: 0.9rem; font-weight: 500; color: var(--sage); margin-bottom: 0.4rem; }
.form-group input, .form-group textarea { width: 100%; padding: 0.75rem 1rem; background: rgba(141,184,122,0.06); border: 1px solid rgba(141,184,122,0.2); border-radius: 8px; color: var(--cream); font-family: var(--font-body); font-size: 1rem; transition: border-color var(--transition); }
.form-group input:focus, .form-group textarea:focus { outline: none; border-color: var(--sage); }

/* Footer */
.site-footer { padding: 4rem 0 2rem; border-top: 1px solid rgba(141,184,122,0.1); background: var(--bg-light); }
.footer-inner { max-width: var(--max-width); margin: 0 auto; padding: 0 2rem; }
.footer-brand { margin-bottom: 2rem; }
.footer-brand .logo-text { font-size: 1.5rem; }
.footer-tagline { color: rgba(242,237,228,0.5); font-size: 0.9rem; margin-top: 0.5rem; }
.footer-links { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 2rem; margin-bottom: 3rem; }
.footer-col h4 { font-family: var(--font-body); font-size: 0.85rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--sage); margin-bottom: 0.75rem; }
.footer-col a { display: block; color: rgba(242,237,228,0.6); font-size: 0.9rem; padding: 0.25rem 0; }
.footer-col a:hover { color: var(--cream); }
.footer-bottom { padding-top: 2rem; border-top: 1px solid rgba(141,184,122,0.08); }
.footer-bottom p { font-size: 0.8rem; color: rgba(242,237,228,0.4); line-height: 1.6; }
.footer-bottom a { color: var(--sage); }

/* Animations */
@keyframes fadeUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

/* Mobile */
@media (max-width: 768px) {
    .nav-toggle { display: block; }
    .nav-links { position: fixed; top: 0; right: -100%; width: 280px; height: 100vh; background: var(--bg); flex-direction: column; padding: 5rem 2rem 2rem; gap: 1.5rem; transition: right var(--transition); box-shadow: -4px 0 20px rgba(0,0,0,0.5); }
    .nav-links.active { right: 0; }
    .nav-links a { font-size: 1.1rem; }
    .hero { padding: 5rem 1.25rem 3rem; }
    .hero-stats { gap: 1.5rem; }
    .trails-grid { grid-template-columns: 1fr; }
    .section-inner { padding: 0 1.25rem; }
    .trail-meta-grid { grid-template-columns: repeat(2, 1fr); }
    .rules-grid { grid-template-columns: 1fr; }
    .footer-links { grid-template-columns: 1fr 1fr; }
    .blog-grid { grid-template-columns: 1fr; }
}


/* v2 additions */
.hero-ctas { display: flex; gap: 1rem; margin-top: 2rem; flex-wrap: wrap; opacity: 0; animation: fadeUp 0.6s ease forwards 1s; }
.btn-secondary { display: inline-block; border: 1px solid var(--sage, #8DB87A); color: var(--sage, #8DB87A); padding: 0.9rem 2rem; border-radius: 8px; font-family: var(--font-body); font-weight: 700; font-size: 1rem; text-decoration: none; transition: all 0.3s; background: transparent; }
.btn-secondary:hover { background: var(--sage, #8DB87A); color: var(--bg, #080C06); }
.trail-intro { font-size: 1.15rem; color: rgba(242,237,228,0.8); line-height: 1.7; margin-bottom: 2rem; font-style: italic; }

/* Beyond cards */
.beyond-preview { padding: 5rem 0; }
.beyond-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.25rem; }
.beyond-card { background: rgba(141,184,122,0.04); border: 1px solid rgba(141,184,122,0.1); border-radius: 12px; padding: 1.5rem; transition: border-color 0.3s, transform 0.3s; }
.beyond-card:hover { border-color: rgba(141,184,122,0.3); transform: translateY(-2px); }
.beyond-icon { font-size: 1.5rem; }
.beyond-card h3 { font-family: var(--font-display); font-size: 1.15rem; margin: 0.5rem 0 0.25rem; }
.beyond-stat { color: var(--sage, #8DB87A); font-size: 0.9rem; font-weight: 600; margin-bottom: 0.75rem; }
.beyond-card p { color: rgba(242,237,228,0.65); font-size: 0.9rem; line-height: 1.5; }
.card-link { color: var(--sage, #8DB87A); font-weight: 600; font-size: 0.85rem; display: inline-block; margin-top: 0.5rem; }

/* Beyond detail page */
.beyond-detail-card { background: rgba(141,184,122,0.04); border: 1px solid rgba(141,184,122,0.1); border-radius: 12px; padding: 1.75rem; margin-bottom: 1.5rem; }
.beyond-detail-header { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1rem; }
.beyond-icon-lg { font-size: 2.5rem; flex-shrink: 0; }
.beyond-detail-header h3 { font-family: var(--font-display); font-size: 1.35rem; margin-bottom: 0.25rem; }
.beyond-stats { color: var(--sage, #8DB87A); font-size: 0.9rem; font-weight: 500; }
.beyond-highlights { background: rgba(141,184,122,0.06); padding: 0.75rem 1rem; border-radius: 8px; border-left: 3px solid var(--sage, #8DB87A); margin-bottom: 1rem; font-size: 0.95rem; }

/* Season cards */
.seasons-preview { padding: 5rem 0; }
.season-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.25rem; }
.season-card { display: block; padding: 2rem 1.5rem; border-radius: 12px; text-decoration: none; color: var(--cream, #F2EDE4); transition: transform 0.3s, box-shadow 0.3s; text-align: center; }
.season-card:hover { transform: translateY(-3px); box-shadow: 0 12px 40px rgba(0,0,0,0.3); color: var(--cream, #F2EDE4); }
.season-fall { background: linear-gradient(135deg, rgba(200,120,50,0.15), rgba(180,80,30,0.08)); border: 1px solid rgba(200,120,50,0.2); }
.season-winter { background: linear-gradient(135deg, rgba(100,160,220,0.12), rgba(60,120,180,0.06)); border: 1px solid rgba(100,160,220,0.2); }
.season-spring { background: linear-gradient(135deg, rgba(180,200,100,0.12), rgba(140,180,60,0.06)); border: 1px solid rgba(180,200,100,0.2); }
.season-emoji { font-size: 2.5rem; display: block; margin-bottom: 0.75rem; }
.season-card h3 { font-family: var(--font-display); font-size: 1.3rem; margin-bottom: 0.5rem; }
.season-card p { color: rgba(242,237,228,0.65); font-size: 0.9rem; line-height: 1.5; }

/* Geology section */
.geology-section { padding: 5rem 0; background: var(--bg-light, #0E1409); }
.geology-section h2 { font-family: var(--font-display); font-size: 2rem; margin-bottom: 1.5rem; }
.geology-section p { font-size: 1.05rem; color: rgba(242,237,228,0.8); line-height: 1.8; margin-bottom: 1.25rem; max-width: 780px; }
.geology-section strong { color: var(--sage, #8DB87A); }

/* CTA box */
.cta-box { background: linear-gradient(135deg, rgba(76,112,52,0.3), rgba(141,184,122,0.15)); border: 1px solid rgba(141,184,122,0.3); border-radius: 16px; padding: 2.5rem; text-align: center; margin: 3rem 0 2rem; }
.cta-box h3 { color: var(--cream, #F2EDE4); font-family: var(--font-display); font-size: 1.5rem; margin: 0 0 0.75rem; }
.cta-box p { color: rgba(242,237,228,0.8); margin-bottom: 1.25rem; font-size: 1.05rem; }

@media (max-width: 768px) {
    .beyond-grid { grid-template-columns: 1fr; }
    .season-cards { grid-template-columns: 1fr; }
    .beyond-detail-header { flex-direction: column; }
    .hero-ctas { flex-direction: column; }
    .hero-ctas a { text-align: center; }
}
