/* ========== Hero carousel + vibrancy refresh ========== */

/* HERO v2: full-bleed carousel with overlay title card */
.hero-v2 {
  position: relative;
  padding: 0;
  min-height: clamp(640px, 84vh, 860px);
  overflow: hidden;
  background: var(--ink);
  isolation: isolate;
}
.hero-carousel {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.hero-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transform: scale(1.06);
  transition: opacity 1.6s ease, transform 7s ease;
  will-change: opacity, transform;
}
.hero-slide.active {
  opacity: 1;
  transform: scale(1.0);
}
.hero-scrim {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(100deg, rgba(12,20,16,.9) 0%, rgba(12,20,16,.68) 36%, rgba(12,20,16,.25) 66%, rgba(12,20,16,.04) 100%),
    linear-gradient(180deg, rgba(12,20,16,.35) 0%, rgba(12,20,16,.05) 22%, rgba(12,20,16,.08) 62%, rgba(12,20,16,.68) 100%);
  pointer-events: none;
}
.hero-backdrop-v2 {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 220px;
  pointer-events: none;
  mix-blend-mode: multiply;
  opacity: .75;
}
.hero-app {
  position: relative;
  z-index: 1;
  padding-top: 56px;
  padding-bottom: 96px;
}

/* light variants of chrome elements atop dark carousel */
.kicker-light {
  color: #f7e9c7 !important;
}
.kicker-light .dot {
  color: var(--accent) !important;
  text-shadow: 0 0 10px rgba(107,168,78,.6);
}
.landmark-light {
  color: #ead9b8 !important;
  border-color: rgba(240,224,186,.35) !important;
  background: rgba(22,20,18,.28) !important;
  backdrop-filter: blur(6px);
}
.coord-plate-light {
  background: rgba(22,20,18,.35) !important;
  color: #f3e4be !important;
  border: 1px solid rgba(240,224,186,.25) !important;
  backdrop-filter: blur(6px);
}

.hero-grid-v2 {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(300px, .8fr);
  gap: 46px;
  align-items: end;
  margin-top: clamp(72px, 10vh, 130px);
}
.hero-text-card {
  max-width: 760px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  position: relative;
  animation: hero-text-in .8s cubic-bezier(.2,.8,.2,1) both;
}
.hero-text-card::before {
  content: none;
}
@keyframes hero-text-in {
  from { transform: translateY(14px) scale(.985); }
  to { transform: translateY(0) scale(1); }
}
.hero-title-v2 {
  color: #f6f7f2 !important;
  text-shadow: 0 3px 24px rgba(0,0,0,.42);
  font-size: clamp(48px, 5.8vw, 78px) !important;
  line-height: 1.08 !important;
  letter-spacing: 0 !important;
}
.hero-title-v2 .underline {
  background-image: linear-gradient(transparent 68%, rgba(116, 176, 103, .78) 68%);
  padding: 0 2px;
}
.hero-quote-v2 {
  margin-top: 22px !important;
  max-width: 660px;
  font-size: 15px !important;
  line-height: 1.75 !important;
  color: rgba(246,247,242,.84) !important;
  text-shadow: 0 2px 12px rgba(0,0,0,.25);
}
.hero-quote-v2 strong { color: #fff7df !important; }
.hero-quote-v2 .hero-quote-author { color: rgba(246,247,242,.62); }
.hero-text-card .btn-ghost {
  color: #f6f7f2;
  border-color: rgba(246,247,242,.72);
  background: rgba(8, 16, 12, .18);
}
.hero-text-card .btn-ghost:hover {
  color: #ffffff;
  border-color: #ffffff;
  background: rgba(8, 16, 12, .32);
}

/* Right column card over carousel */
.hero-right-col {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 16px;
  animation: hero-right-in .9s .15s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes hero-right-in {
  from { transform: translateX(18px); }
  to { transform: translateX(0); }
}
.hero-slide-card {
  width: 100%;
  max-width: 360px;
  padding: 18px 20px 16px;
  background: rgba(10, 19, 15, 0.62);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(240, 224, 186, 0.28);
  color: #f3e4be;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: transform .35s ease, background .35s ease;
}
.hero-slide-card:hover {
  background: rgba(22,20,18,.68);
  transform: translateY(-2px);
}
.hero-slide-card-id {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: .12em;
  color: #ead9b8;
  display: flex;
  align-items: center;
  gap: 6px;
}
.hero-slide-card-id .dot {
  color: var(--accent);
  text-shadow: 0 0 8px rgba(107,168,78,.7);
}
.hero-slide-card-caption {
  display: flex;
  justify-content: space-between;
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px;
  letter-spacing: .08em;
  color: rgba(243,228,190,.7);
  padding-top: 8px;
  border-top: 1px dashed rgba(240, 224, 186, 0.25);
}

/* Dots + counter */
.hero-dots {
  display: flex;
  gap: 8px;
  align-items: center;
}
.hero-dot {
  width: 22px;
  height: 3px;
  border-radius: 2px;
  background: rgba(240,224,186,.3);
  border: none;
  cursor: pointer;
  transition: background .35s ease, width .35s ease;
  padding: 0;
}
.hero-dot.active {
  background: var(--accent);
  width: 44px;
  box-shadow: 0 0 14px rgba(107,168,78,.5);
}
.hero-counter {
  color: rgba(243,228,190,.6);
  font-size: 10.5px;
  letter-spacing: .14em;
}

/* Button glow for CTA */
.btn-glow {
  position: relative;
  box-shadow: 0 10px 28px rgba(107,168,78,.35), 0 2px 0 rgba(40,80,30,.25);
  transition: transform .25s ease, box-shadow .25s ease;
}
.btn-glow::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.35) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform .6s ease;
}
.btn-glow:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(107,168,78,.45), 0 3px 0 rgba(40,80,30,.3);
}
.btn-glow:hover::after {
  transform: translateX(100%);
}

/* Vibrancy upgrades for existing components */
.deer-card {
  transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease;
}
.deer-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 22px 40px rgba(22,20,18,.18);
}
.deer-card::after {
  content: "";
  position: absolute;
  top: 0; right: 0;
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, transparent 48%, var(--accent) 48%, var(--accent) 52%, transparent 52%);
  opacity: 0;
  transition: opacity .35s ease;
  pointer-events: none;
}
.deer-card:hover::after { opacity: .9; }

/* Stat numbers get a subtle pop on mount */
.stat-n {
  animation: stat-in .9s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes stat-in {
  from { transform: translateY(8px); }
  to { transform: translateY(0); }
}

/* Section headings: lively serif + accent bar */
.section-head h2 {
  position: relative;
  padding-left: 22px;
}
.section-head h2::before {
  content: "";
  position: absolute;
  left: 0; top: 10px; bottom: 14px;
  width: 6px;
  background: var(--accent);
  box-shadow: 4px 0 0 -1px rgba(107,168,78,.18);
}

/* Dashed wave divider between sections */
.wave-divider {
  height: 24px;
  overflow: hidden;
  margin: 0 auto;
  max-width: 1280px;
  padding: 0 40px;
  color: var(--accent);
  opacity: .45;
}
.wave-divider svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* Kicker + accent tweak: stronger accent saturation */
.kicker .dot { color: var(--accent); }

/* Responsive */
@media (max-width: 1000px) {
  .hero-v2 { min-height: auto; }
  .hero-app { padding-top: 34px; padding-bottom: 64px; }
  .hero-grid-v2 { grid-template-columns: 1fr; gap: 30px; margin-top: 50px; }
  .hero-right-col { align-items: flex-start; }
  .hero-title-v2 { font-size: clamp(40px, 9vw, 58px) !important; }
  .hero-slide-card { max-width: 100%; }
}

@media (max-width: 560px) {
  .hero-app { padding-top: 28px; padding-bottom: 52px; }
  .hero-grid-v2 { margin-top: 36px; }
  .hero-title-v2 { font-size: 38px !important; }
  .hero-quote-v2 {
    font-size: 13.5px !important;
    line-height: 1.68 !important;
    padding-left: 14px !important;
    margin-bottom: 22px !important;
  }
  .hero-slide-card-caption { display: grid; gap: 4px; }
  .hero-backdrop-v2 { height: 150px; }
}

/* ADMIN: login gate */
.admin-login {
  min-height: 100vh;
  display: grid;
  place-items: center;
  background:
    radial-gradient(ellipse at 20% 20%, rgba(107,168,78,.14), transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(60,90,70,.14), transparent 50%),
    var(--paper-2);
  padding: 40px;
}
.admin-login-card {
  width: 100%;
  max-width: 440px;
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 38px 40px 32px;
  box-shadow: 0 24px 60px rgba(22,20,18,.14);
  position: relative;
}
.admin-login-card::before {
  content: "";
  position: absolute;
  top: -1px; left: -1px;
  width: 90px;
  height: 6px;
  background: var(--accent);
}
.admin-login h2 {
  font-family: "Noto Serif SC", serif;
  font-size: 24px;
  color: var(--ink);
  margin-bottom: 6px;
}
.admin-login .admin-login-sub {
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px;
  color: var(--muted);
  letter-spacing: .15em;
  margin-bottom: 28px;
}
.admin-login label {
  display: block;
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px;
  color: var(--muted);
  letter-spacing: .12em;
  margin: 16px 0 6px;
}
.admin-login input {
  width: 100%;
  padding: 10px 12px;
  font: inherit;
  background: var(--paper-2);
  border: 1px solid var(--rule);
  color: var(--ink);
  transition: border .2s ease;
}
.admin-login input:focus {
  border-color: var(--accent);
  outline: none;
}
.admin-login-err {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: #b83a2a;
  margin-top: 10px;
}
.admin-login-hint {
  margin-top: 22px;
  padding: 12px 14px;
  background: var(--paper-2);
  border-left: 3px solid var(--accent);
  font-size: 11.5px;
  color: var(--ink-soft);
  line-height: 1.55;
}
.admin-login-hint .mono { color: var(--ink); font-weight: 600; }

/* Admin: hero carousel section */
.hero-slot {
  display: grid;
  grid-template-columns: 80px 1fr 40px;
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--rule);
  background: var(--paper);
  align-items: center;
  margin-bottom: 10px;
  transition: box-shadow .2s ease;
}
.hero-slot:hover { box-shadow: 0 4px 12px rgba(22,20,18,.08); }
.hero-slot-thumb {
  width: 80px; height: 100px;
  background-size: cover;
  background-position: center;
  border: 1px solid var(--rule);
}
.hero-slot-meta {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 8px 14px;
  font-size: 12px;
}
.hero-slot-meta .k {
  color: var(--muted);
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px;
  letter-spacing: .12em;
  align-self: center;
}
.hero-slot-actions {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
}
