/* WhereToFish.net — base stylesheet.
 * Palette mirrors fish-database: navy / ocean / teal / seafoam / sand.
 * SCSS sources in ../../scss/ (no build pipeline; edit this file directly). */

:root {
  --navy:    #0f3d5c;
  --ocean:   #1e5f8f;
  --teal:    #1a6b6b;
  --seafoam: #3eb5a0;
  --sand:    #e8ddc6;
  --muted:   #6b7f8e;
  --bg:      #ffffff;
  --text:    #0d2033;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: 'DM Sans', system-ui, sans-serif;
  color: var(--text);
  background: var(--bg);
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  color: var(--navy);
  font-weight: 600;
  letter-spacing: -0.01em;
}

a { color: var(--ocean); text-decoration: none; }
a:hover { text-decoration: underline; }

header { background: var(--navy); color: #fff; padding: 14px 20px; }
header .site-title { color: #fff; font-weight: 700; font-size: 20px; }
header nav { display: flex; align-items: center; gap: 24px; max-width: 1200px; margin: 0 auto; }
header ul.main-nav { list-style: none; padding: 0; margin: 0; display: flex; gap: 18px; }
header ul.main-nav a { color: rgba(255,255,255,0.9); font-size: 14px; font-weight: 500; }

/* Nav search bar — pill-style match to fish-database header search */
header .nav-search { display: flex; align-items: center; margin-left: auto; }
header .nav-search input[type="search"] {
  -webkit-appearance: none;
  appearance: none;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.22);
  border-right: none;
  color: #fff;
  font-family: inherit;
  font-size: 0.875rem;
  padding: 7px 15px;
  border-radius: 20px 0 0 20px;
  outline: none;
  width: 190px;
  height: 34px;
  box-sizing: border-box;
  transition: background 0.2s, width 0.3s;
}
header .nav-search input[type="search"]::placeholder { color: rgba(255,255,255,0.5); }
header .nav-search input[type="search"]:focus {
  background: rgba(255,255,255,0.18);
  width: 240px;
}
header .nav-search button {
  background: var(--seafoam);
  border: 1px solid var(--seafoam);
  color: #fff;
  padding: 7px 13px;
  border-radius: 0 20px 20px 0;
  cursor: pointer;
  font-size: 0.85rem;
  line-height: 1;
  height: 34px;
  box-sizing: border-box;
  transition: background 0.2s, border-color 0.2s;
}
header .nav-search button:hover {
  background: var(--teal);
  border-color: var(--teal);
}
@media (max-width: 720px) {
  header .nav-search { display: none; }
}

main { max-width: 1200px; margin: 0 auto; padding: 0 20px; min-height: 60vh; }

footer { background: var(--navy); color: rgba(255,255,255,0.8); padding: 30px 20px; margin-top: 60px; }
footer .footer-inner { max-width: 1200px; margin: 0 auto; }
