/* ══════════════════════════════════════════════════════
   CAMPING HIGHWAY THEME — Mobile Meadows
   Dark asphalt roads, pine forests, campfire warmth
   ══════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cabin:wght@400;600;700&family=Oswald:wght@400;600;700&display=swap');

:root {
  --primary: #1a472a;
  --primary-dark: #0d2818;
  --primary-light: #2d8a4e;
  --accent: #e8722a;
  --accent-glow: #ff9149;
  --bg: #1c1c1e;
  --bg-card: #2a2a2e;
  --text: #e8e4df;
  --text-light: #9e9a94;
  --border: #3a3a3e;
  --radius: 6px;
  --shadow: 0 4px 16px rgba(0,0,0,0.35);

  /* Camping Highway specials */
  --asphalt: #2c2c30;
  --road-stripe: #e8c840;
  --pine: #1a472a;
  --campfire: #e8722a;
  --night-sky: #0f1420;
  --starlight: #f0e6d2;
  --lantern: #f5c242;
}

/* ── Typography ── */
html { font-size: 16px; }
body {
  font-family: 'Cabin', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--bg);
  color: var(--text);
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Oswald', 'Impact', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

a { color: var(--accent); }
a:hover { color: var(--accent-glow); }

/* ── Buttons ── */
.btn {
  border-radius: 4px;
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  transition: all 0.25s ease;
}
.btn-primary {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 2px 12px rgba(232, 114, 42, 0.3);
}
.btn-primary:hover {
  background: var(--accent-glow);
  color: #fff;
  box-shadow: 0 4px 20px rgba(232, 114, 42, 0.5);
  transform: translateY(-2px);
}
.btn-secondary {
  background: transparent;
  color: var(--accent);
  border: 2px solid var(--accent);
}
.btn-secondary:hover {
  background: var(--accent);
  color: #fff;
}

/* ── Nav — Highway Top Bar ── */
.nav {
  background: var(--night-sky);
  border-bottom: 3px solid var(--road-stripe);
  position: sticky;
  top: 0;
  z-index: 100;
}
.nav-inner {
  height: 64px;
}
.nav-brand {
  color: var(--starlight) !important;
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 1.4rem;
}
.nav-brand:hover { color: var(--accent) !important; }
.nav-links a { color: var(--starlight) !important; font-family: 'Cabin', sans-serif; }
.nav-links a:hover { color: var(--accent) !important; }
.nav-toggle { color: var(--starlight) !important; }

@media (max-width: 768px) {
  .nav-links {
    background: var(--night-sky) !important;
    border-top: 2px solid var(--road-stripe);
  }
}

/* ── Hero — Highway at Dusk ── */
.hero {
  background:
    /* Sky gradient — dusk over pines */
    linear-gradient(
      180deg,
      #0f1420 0%,
      #1a2744 25%,
      #2d4a3a 50%,
      #1a472a 70%,
      #0d2818 100%
    );
  color: var(--starlight);
  padding: 5rem 1.5rem;
  min-height: 60vh;
  position: relative;
  overflow: hidden;
  text-align: center;
}

/* Pine tree silhouettes */
.hero::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 180px;
  background:
    /* Tree 1 */
    conic-gradient(from 210deg at 8% 100%, #0a1f12 0deg, #0a1f12 60deg, transparent 60deg) no-repeat,
    conic-gradient(from 210deg at 15% 100%, #0d2818 0deg, #0d2818 60deg, transparent 60deg) no-repeat,
    /* Tree 2 */
    conic-gradient(from 210deg at 25% 100%, #0a1f12 0deg, #0a1f12 60deg, transparent 60deg) no-repeat,
    /* Tree 3 */
    conic-gradient(from 210deg at 40% 100%, #0d2818 0deg, #0d2818 60deg, transparent 60deg) no-repeat,
    conic-gradient(from 210deg at 45% 100%, #0a1f12 0deg, #0a1f12 60deg, transparent 60deg) no-repeat,
    /* Tree 4 */
    conic-gradient(from 210deg at 60% 100%, #0a1f12 0deg, #0a1f12 60deg, transparent 60deg) no-repeat,
    /* Tree 5 */
    conic-gradient(from 210deg at 75% 100%, #0d2818 0deg, #0d2818 60deg, transparent 60deg) no-repeat,
    conic-gradient(from 210deg at 82% 100%, #0a1f12 0deg, #0a1f12 60deg, transparent 60deg) no-repeat,
    /* Tree 6 */
    conic-gradient(from 210deg at 92% 100%, #0d2818 0deg, #0d2818 60deg, transparent 60deg) no-repeat;
  background-size:
    120px 160px, 100px 130px,
    110px 150px,
    90px 120px, 130px 170px,
    100px 140px,
    120px 160px, 80px 110px,
    110px 145px;
  z-index: 1;
  pointer-events: none;
}

/* Stars */
.hero::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 50%;
  background-image:
    radial-gradient(1px 1px at 10% 15%, #fff 50%, transparent 100%),
    radial-gradient(1px 1px at 30% 8%, #fff 50%, transparent 100%),
    radial-gradient(2px 2px at 50% 20%, #ffe 50%, transparent 100%),
    radial-gradient(1px 1px at 70% 12%, #fff 50%, transparent 100%),
    radial-gradient(1px 1px at 85% 25%, #fff 50%, transparent 100%),
    radial-gradient(2px 2px at 20% 30%, #ffe 50%, transparent 100%),
    radial-gradient(1px 1px at 60% 5%, #fff 50%, transparent 100%),
    radial-gradient(1px 1px at 90% 18%, #fff 50%, transparent 100%),
    radial-gradient(1px 1px at 45% 28%, #fff 50%, transparent 100%),
    radial-gradient(2px 2px at 75% 35%, #ffe 50%, transparent 100%);
  z-index: 0;
  pointer-events: none;
  animation: twinkle 4s ease-in-out infinite alternate;
}

@keyframes twinkle {
  0% { opacity: 0.6; }
  100% { opacity: 1; }
}

.hero-content {
  position: relative;
  z-index: 2;
}
.hero-content h1 {
  font-size: 3rem;
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  text-shadow: 0 2px 20px rgba(0,0,0,0.6), 0 0 40px rgba(232, 114, 42, 0.15);
  margin-bottom: 0.6rem;
}
.hero-sub {
  font-size: 1.25rem;
  color: var(--starlight);
  opacity: 0.85;
  text-shadow: 0 1px 8px rgba(0,0,0,0.5);
}

/* Road divider accent under hero */
.hero + .services::before,
.hero + section::before {
  content: '';
  display: block;
  height: 6px;
  background: repeating-linear-gradient(
    90deg,
    var(--road-stripe) 0px,
    var(--road-stripe) 40px,
    transparent 40px,
    transparent 60px
  );
}

@media (max-width: 768px) {
  .hero { padding: 3.5rem 1rem; min-height: 45vh; }
  .hero-content h1 { font-size: 2rem; }
  .hero::before { height: 100px; }
}

/* ── Services (Dual Boxes) — Campsite Cards ── */
.services {
  background: var(--asphalt);
}
.service-box {

  border: 1px solid var(--border);
  padding: 3rem 2rem;
  position: relative;
  overflow: hidden;
  transition: all 0.35s ease;
}
.service-box::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--pine), var(--accent), var(--pine));
  opacity: 0;
  transition: opacity 0.35s;
}
.service-box:hover {
  background: #333338;
  transform: translateY(-4px);
  box-shadow: 0 8px 30px rgba(0,0,0,0.4);
}
.service-box:hover::before { opacity: 1; }
.service-box:first-child { border-right: 1px solid var(--border); }

.service-icon { font-size: 3.5rem; filter: drop-shadow(0 2px 6px rgba(232,114,42,0.3)); }
.service-box h2 {
  color: var(--starlight);
  font-family: 'Oswald', sans-serif;
}
.service-box p { color: var(--text-light); }

@media (max-width: 768px) {
  .service-box:first-child { border-right: 1px solid var(--border); border-bottom: none; }
}

/* ── About — Fireside Story ── */
.about {
  background: var(--bg);
  padding: 3rem 1.5rem;
  position: relative;
}
.about::before {
  content: '';
  display: block;
  width: 60px;
  height: 4px;
  background: var(--accent);
  margin: 0 auto 1.5rem;
  border-radius: 2px;
}
.about h2 {
  color: var(--starlight);
  font-family: 'Oswald', sans-serif;
}
.about p { color: var(--text-light); }

/* ── Calendar Page ── */
.calendar-page h1 { color: var(--starlight); }
.calendar-subtitle { color: var(--text-light); }

.filter-btn {
  border-color: var(--accent);
  color: var(--accent);
  background: transparent;
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.filter-btn.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.filter-btn:hover {
  background: rgba(232, 114, 42, 0.15);
}

.cal-day {
  background: var(--bg-card);
  border-color: var(--border);
  color: var(--text);
}
.cal-day.empty { background: transparent; }
.cal-day.has-slots { border-color: var(--accent); }
.cal-day.has-slots:hover { background: rgba(232, 114, 42, 0.1); }
.cal-header { color: var(--text-light); }

.slot-panel {
  background: var(--bg-card);
  border-color: var(--border);
}
.slot-type { color: var(--starlight); }
.slot-time { color: var(--text-light); }
.slot-location { color: var(--accent); }

/* ── Booking Form ── */
.booking-slot-info {
  background: var(--bg-card);
  border-color: var(--border);
}
.booking-form h3 { color: var(--accent); }

.form-group label { color: var(--text); }
.form-group input,
.form-group textarea,
.form-group select {
  background: var(--asphalt);
  border-color: var(--border);
  color: var(--text);
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(232, 114, 42, 0.2);
}

/* ── Confirmation ── */
.confirmation-card {
  background: var(--bg-card);
  color: var(--text);
}

/* ── Error Pages ── */
.error-page h1 { color: var(--accent); }

/* ── Footer — Night Road ── */
.site-footer {
  background: var(--night-sky);
  border-top: 3px solid var(--road-stripe);
  color: var(--text-light);
  position: relative;
}
.site-footer::before {
  content: '';
  display: block;
  height: 4px;
  background: repeating-linear-gradient(
    90deg,
    var(--road-stripe) 0px,
    var(--road-stripe) 40px,
    transparent 40px,
    transparent 60px
  );
  margin-bottom: 0;
}

/* ── Tables ── */
th { background: var(--night-sky); color: var(--starlight); }
td { border-color: var(--border); color: var(--text); }
table { color: var(--text); }

/* ── Badges ── */
.badge-pending { background: var(--lantern); color: #1c1c1e; }
.badge-confirmed { background: var(--primary-light); color: #fff; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent); }

/* ── Selection ── */
::selection { background: var(--accent); color: #fff; }

/* ── Campfire glow animation for special elements ── */
@keyframes campfireGlow {
  0%, 100% { box-shadow: 0 0 15px rgba(232, 114, 42, 0.15); }
  50% { box-shadow: 0 0 25px rgba(232, 114, 42, 0.3); }
}

.service-box:hover {
  animation: campfireGlow 2s ease-in-out infinite;
}

/* ── Road stripe divider utility ── */
.road-divider {
  height: 6px;
  background: repeating-linear-gradient(
    90deg,
    var(--road-stripe) 0px,
    var(--road-stripe) 40px,
    transparent 40px,
    transparent 60px
  );
  margin: 0;
}
