/* css/style.css
   Shared responsive styles for HuntersGo
   Mobile-first, with breakpoints and hamburger nav
*/

/* ====== Fonts ====== */
@import url('https://fonts.googleapis.com/css2?family=Merriweather:wght@400;700&family=Source+Sans+Pro:wght@300;400;600&display=swap');

:root{
  --bg:#f7f1e3;
  --cream:#fdfaf3;
  --olive:#4c5b47;
  --accent:#c89a2f;
  --terracotta:#a65a3e;
  --text:#2f3e2f;
  --muted:#6e655b;
  --shadow: rgba(46,61,50,0.10);
  --header-height:64px;
  --max-width:1100px;
}

/* dark theme overrides */
[data-theme="dark"]{
  --bg:#1a1a18;
  --cream:#22211f;
  --olive:#c7d0b6;
  --accent:#d4ac2e;
  --text:#efece3;
  --muted:#9b9286;
  --shadow: rgba(0,0,0,0.6);
}

/* ====== Base ====== */
*{box-sizing:border-box}
html,body{height:100%;margin:0;background:var(--bg);color:var(--text);font-family:'Source Sans Pro',sans-serif;line-height:1.6}
a{color:var(--olive);text-decoration:none}
img{max-width:100%;height:auto;display:block}

/* ====== Header & Nav ====== */
.header {
  position:sticky;
  top:0;
  z-index:40;
  background:var(--cream);
  box-shadow:0 2px 8px var(--shadow);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:0.6rem 1rem;
  height:var(--header-height);
}

.logo {display:flex;align-items:center;gap:.6rem}
.logo img{width:40px;height:40px}
.site-title{font-family:'Merriweather',serif;font-weight:700;color:var(--olive);letter-spacing:1px}

/* nav */
.nav {
  display:flex;
  align-items:center;
  gap:1rem;
}
.nav ul{display:flex;gap:1rem;list-style:none;margin:0;padding:0;align-items:center}
.nav a{font-weight:600}
.menu-toggle {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:0;
  background:transparent;
  font-size:1.35rem;
  cursor:pointer;
  padding:.35rem;
}

/* mobile nav (hidden by default) */
.mobile-nav {
  display:none;
  position: absolute;
  right: 0;
  top: var(--header-height);
  background: var(--cream);
  width:100%;
  max-width:320px;
  box-shadow:0 6px 18px var(--shadow);
  border-left: 1px solid rgba(0,0,0,0.02);
  padding:1rem;
}
.mobile-nav ul{flex-direction:column;display:flex;gap:.75rem}
.mobile-nav a{display:block;padding:.6rem .8rem;border-radius:8px}

/* container helper */
.container{max-width:var(--max-width);margin:1.2rem auto;padding:0 1rem}

/* ====== Hero (keeps full, crops as needed) ====== */
.hero {
  min-height:70vh;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  color:#fff;
  text-align:center;
  padding:3rem 1rem;
  background-position:center;
  background-repeat:no-repeat;
  background-size:cover; /* important: keeps hero full and crops */
}
.hero .overlay {
  position:absolute;inset:0;background:rgba(47,62,47,0.45);backdrop-filter:blur(1px)
}
.hero-content{position:relative;z-index:2;max-width:680px;animation:fadeIn 700ms ease}

/* Buttons */
.btn {display:inline-block;padding:.75rem 1.2rem;border-radius:8px;font-weight:700}
.btn-primary{background:var(--accent);color:#fff}
.btn-outline{background:transparent;border:2px solid var(--accent);color:var(--olive)}

/* utility grid */
.directory{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;padding:1rem 0}
.dir-item{background:var(--cream);padding:1.2rem;border-radius:10px;box-shadow:0 4px 12px var(--shadow);text-align:center}

/* stories grid */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}
.card{background:var(--cream);border-radius:12px;overflow:hidden;box-shadow:0 6px 18px var(--shadow);display:flex;flex-direction:column}
.card .card-body{padding:1rem;flex:1;display:flex;flex-direction:column}

/* tiles that used background images */
.tile {
  position:relative;height:260px;border-radius:12px;overflow:hidden;background-size:cover;background-position:center;
  display:flex;align-items:flex-end;
}
.tile .tile-text{padding:1rem;color:var(--cream);background:linear-gradient(180deg,transparent,rgba(0,0,0,0.5));width:100%}

/* footer */
footer{background:var(--cream);color:var(--olive);text-align:center;padding:1.25rem;border-top:2px solid var(--accent);margin-top:2rem}

/* small helpers */
.meta{color:var(--muted);font-size:.95rem}
.center{text-align:center}

/* slideshow small */
.slideshow{position:relative;border-radius:10px;overflow:hidden}
.slide{display:none}
.slide.active{display:block}
.slideshow img{width:100%;height:auto;display:block;object-fit:cover}

/* ====== Accessibility focus states ====== */
a:focus,button:focus{outline:3px solid rgba(200,154,47,0.25);outline-offset:3px}

/* ====== Animations ====== */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ====== Responsive breakpoints ====== */
@media(min-width:768px){
  .menu-toggle{display:none}
  .mobile-nav{display:none !important}
  .desktop-only{display:block}
  .nav ul{display:flex}
}
@media(max-width:767px){
  .nav ul{display:none}
  .menu-toggle{display:inline-flex}
  .mobile-nav{display:none}
  .mobile-nav.open{display:block}
  .hero{min-height:56vh;padding:2.25rem 1rem}
  header .site-title{font-size:1rem}
  .container{margin:0.8rem auto}
  .directory{gap:.65rem}
  .tile{height:180px}
}

/* larger desktop */
@media(min-width:1200px){
  .hero{min-height:85vh}
}
