@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@700&family=Merriweather:ital,wght@0,400;0,700;1,400&display=swap');
*, *::before, *::after { box-sizing: border-box; }
html { overflow-x: hidden; }
body {
  font-family: 'Merriweather', Georgia, serif;
  background: #0d0d0d;
  color: #d4cfc8;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}
img, video, iframe, embed { max-width: 100%; height: auto; }
header {
  background: #111;
  border-bottom: 3px solid #c0392b;
  padding: 1.8rem 2rem 0;
  text-align: center;
}
header h1 {
  margin: 0;
  font-family: 'Oswald', Impact, sans-serif;
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}
header h1 a { color: #fff; text-decoration: none; }
header h1 a:hover { color: #e74c3c; }
.header-banner { display: block; width: 100%; max-width: 940px; height: auto; margin: 0 auto; }
.banner-wrap {
  position: relative; max-width: 940px; margin: 0 auto; display: block; overflow: hidden;
}
.banner-wrap::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(to right,  #111 0%, transparent 10%, transparent 90%, #111 100%),
    linear-gradient(to bottom, transparent 50%, #111 100%);
  z-index: 1;
}
nav.breadcrumb {
  max-width: 1100px; margin: 0 auto; padding: .6rem 1.5rem;
  font-size: .8rem; color: #555; background: #181818;
  border-bottom: 1px solid #222;
}
nav.breadcrumb a { color: #e74c3c; text-decoration: none; }
nav.breadcrumb a:hover { text-decoration: underline; }
.page-wrap { max-width: 1100px; margin: 2.5rem auto; padding: 0 1.5rem 4rem; display: flex; gap: 3rem; align-items: flex-start; }
aside.date-nav {
  width: 175px; flex-shrink: 0; position: sticky; top: 1.5rem;
  border-left: 2px solid #c0392b; padding-left: 1rem;
}
aside.date-nav h3 {
  font-family: 'Oswald', Impact, sans-serif;
  font-size: .75rem; text-transform: uppercase; letter-spacing: .12em;
  color: #c0392b; margin: 0 0 .7rem;
}
.year-group { margin-bottom: .15rem; }
.year-btn {
  display: flex; justify-content: space-between; align-items: center;
  width: 100%; background: none; border: none; padding: .4rem .3rem;
  font-family: 'Oswald', Impact, sans-serif; font-size: 1rem;
  font-weight: 700; color: #ccc; letter-spacing: .04em;
  cursor: pointer; text-align: left;
}
.year-btn:hover { color: #fff; }
.year-btn.active { color: #e74c3c; }
.year-btn .arrow { font-size: .6rem; transition: transform .15s; color: #555; }
.year-btn.open .arrow { transform: rotate(90deg); }
.month-list { display: none; padding: 0 0 .4rem .6rem; border-left: 1px solid #2a2a2a; margin-left: .3rem; }
.month-list.open { display: block; }
.month-btn {
  display: block; width: 100%; background: none; border: none;
  padding: .2rem .3rem; font-family: 'Merriweather', Georgia, serif;
  font-size: .78rem; color: #777; cursor: pointer; text-align: left;
}
.month-btn:hover { color: #d4cfc8; }
.month-btn.active { color: #e74c3c; font-weight: 700; }
.all-btn {
  display: block; width: 100%; background: none; border: none;
  padding: .3rem .3rem .6rem; font-family: 'Merriweather', Georgia, serif;
  font-size: .78rem; color: #666; cursor: pointer; text-align: left;
  font-style: italic; border-bottom: 1px solid #222; margin-bottom: .6rem;
  text-decoration: none;
}
.all-btn:hover { color: #e74c3c; }
a.year-btn { text-decoration: none; }
a.month-btn { text-decoration: none; }
main.post-list { display: block; }
.post-area { flex: 1; min-width: 0; max-width: 100%; overflow: hidden; }
article.post.single { max-width: 720px; }
.search-bar { margin-bottom: 2.5rem; }
.search-bar input {
  width: 100%; padding: .7rem 1rem;
  font-size: .95rem; font-family: 'Merriweather', Georgia, serif;
  border: none; border-bottom: 2px solid #333;
  background: #181818; color: #d4cfc8; outline: none;
}
.search-bar input::placeholder { color: #444; }
.search-bar input:focus { border-bottom-color: #e74c3c; }
.search-count { font-size: .75rem; color: #555; margin-top: .4rem; }
article.post { margin-bottom: 3rem; padding-bottom: 2.5rem; border-bottom: 1px solid #222; min-width: 0; }
article.post:last-child { border-bottom: none; }
article.post.hidden { display: none; }
h2.post-title {
  font-family: 'Oswald', Impact, sans-serif;
  font-size: 1.6rem; font-weight: 700; letter-spacing: .03em;
  text-transform: uppercase; margin: 0 0 .3rem;
}
h2.post-title a { color: #fff; text-decoration: none; }
h2.post-title a:hover { color: #e74c3c; }
h1.post-title {
  font-family: 'Oswald', Impact, sans-serif;
  font-size: 2.2rem; font-weight: 700; letter-spacing: .03em;
  text-transform: uppercase; margin: 0 0 .4rem; color: #fff;
}
.post-meta { font-size: .75rem; color: #555; margin-bottom: 1.1rem; letter-spacing: .03em; text-transform: uppercase; }
.post-content { font-size: .97rem; line-height: 1.85; color: #bbb; overflow-wrap: break-word; word-break: break-word; }
.post-content p { margin: 0 0 1.1em; }
.post-content a { color: #e74c3c; }
.post-content a:hover { color: #ff6b5b; }
.post-content img { max-width: 100%; width: auto; height: auto; margin: 1rem 0; }
.read-more {
  display: inline-block; margin-top: .6rem;
  font-family: 'Oswald', Impact, sans-serif;
  font-size: .8rem; letter-spacing: .1em; text-transform: uppercase;
  color: #555; text-decoration: none; border-bottom: 1px solid #333;
  padding-bottom: 1px;
}
.read-more:hover { color: #e74c3c; border-bottom-color: #e74c3c; }
footer {
  background: #111; color: #444; text-align: center;
  padding: 1.5rem; font-size: .75rem; letter-spacing: .05em;
  text-transform: uppercase; border-top: 1px solid #1e1e1e;
}
footer a { color: #666; text-decoration: none; }
footer a:hover { color: #e74c3c; }
.back-link {
  display: inline-block; margin-top: 2rem;
  font-family: 'Oswald', Impact, sans-serif;
  font-size: .8rem; letter-spacing: .1em; text-transform: uppercase;
  color: #555; text-decoration: none; border-bottom: 1px solid #333;
  padding-bottom: 1px;
}
.back-link:hover { color: #e74c3c; border-bottom-color: #e74c3c; }
#no-results { display: none; color: #555; font-style: italic; padding: 1rem 0; }
@media (max-width: 900px) and (min-width: 701px) {
  header h1 { font-size: 2.2rem; }
  .page-wrap { gap: 1.8rem; padding: 0 1.2rem 3rem; }
  aside.date-nav { width: 150px; }
  aside.date-nav h3 { font-size: .7rem; }
  .year-btn { font-size: .9rem; }
  .month-btn { font-size: .75rem; }
}
@media (max-width: 700px) {
  header { padding: 1.2rem 1rem 0; }
  header h1 { font-size: 1.7rem; }
  .page-wrap { flex-direction: column; gap: 0; padding: 0 1rem 3rem; margin-top: 1.5rem; }
  aside.date-nav {
    width: 100%; position: static;
    border-left: none; border-top: 2px solid #c0392b;
    padding: 0; margin-bottom: 1.5rem;
  }
  aside.date-nav h3 {
    cursor: pointer; padding: .7rem 0;
    margin: 0; display: flex; justify-content: space-between; align-items: center;
  }
  aside.date-nav h3::after { content: '\25BC'; font-size: .6rem; color: #c0392b; }
  aside.date-nav.nav-open h3::after { content: '\25B2'; }
  .nav-body { display: none; padding-bottom: .5rem; }
  aside.date-nav.nav-open .nav-body { display: block; }
  h1.post-title { font-size: 1.6rem; }
  h2.post-title { font-size: 1.3rem; }
  main.post-page { padding: 0 1rem 3rem; margin-top: 1.5rem; }
  .post-content { font-size: .93rem; }
  nav.breadcrumb { padding: .5rem 1rem; }
}
@media (max-width: 400px) {
  header h1 { font-size: 1.4rem; letter-spacing: .03em; }
}
