html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  background:
    radial-gradient(circle at 50% 0%, rgba(142, 0, 0, .12), transparent 360px),
    url("/wp-content/themes/that-music-theme/img/body_bck.jpg") repeat;
  color: #2b2420;
}

a {
  text-underline-offset: 2px;
}

a:focus-visible,
input:focus-visible {
  outline: 2px solid #d8cfb7;
  outline-offset: 2px;
}

.skip-link {
  position: absolute;
  left: 12px;
  top: -80px;
  z-index: 1000;
  padding: 8px 12px;
  background: #210f0d;
  color: #fff;
  border: 1px solid #d8cfb7;
  text-decoration: none;
}

.skip-link:focus {
  top: 12px;
}

.container_16 {
  max-width: 940px;
  width: calc(100% - 24px);
  filter: drop-shadow(0 22px 48px rgba(32, 12, 10, .22));
}

.blog_title {
  position: relative;
  overflow: hidden;
}

.blog_title:after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(115deg, transparent 0%, rgba(255,255,255,.15) 42%, transparent 58%),
    radial-gradient(circle at 88% 25%, rgba(216,207,183,.16), transparent 180px);
  mix-blend-mode: screen;
  opacity: .55;
}

.blog_title h1,
.blog_title h4 {
  position: relative;
  z-index: 1;
}

.navigation {
  position: relative;
  z-index: 2;
}

.navigation ul {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

.navigation li a {
  transition: background-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.navigation li a:hover,
.navigation li a:focus-visible {
  transform: translateY(-1px);
}

.search_box,
.widget_search {
  display: none;
}

.content_wrapper {
  backdrop-filter: blur(2px);
}

.entry,
.post,
.widget {
  overflow-wrap: anywhere;
}

.post img,
.textwidget img,
.ngg-gallery-thumbnail img,
.memorial-gallery img {
  max-width: 100%;
  height: auto;
}

.post h2 a,
.sectionhead,
.widgettitle {
  text-wrap: balance;
}

.postinfo {
  letter-spacing: 0;
}

.memorial-gallery {
  border-top: 1px solid rgba(93, 29, 25, .2);
  padding-top: 14px;
}

.memorial-gallery__item {
  transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}

.memorial-gallery__item:hover,
.memorial-gallery__item:focus-visible {
  transform: translateY(-2px);
  filter: saturate(1.05);
  box-shadow: 0 8px 20px rgba(35, 18, 12, .25);
}

.footer {
  text-align: center;
}

.footer p {
  margin: 0;
}

.static-error {
  max-width: 680px;
  margin: 0 auto;
  padding: 28px 24px 34px;
  text-align: center;
}

.static-error h2 {
  margin-top: 0;
  color: #5d1d19;
}

.static-error__links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.static-error__links a {
  display: inline-block;
  padding: 8px 12px;
  background: #5d1d19;
  color: #fff;
  border: 1px solid #2c1110;
  text-decoration: none;
}

.static-error__links a:hover,
.static-error__links a:focus-visible {
  background: #8e0000;
}

@media (max-width: 760px) {
  .container_16 {
    width: calc(100% - 16px);
  }

  .grid_16,
  .grid_9,
  .grid_7,
  .grid_4,
  .grid_3,
  #left,
  .right,
  .sleft,
  .sright {
    display: block;
    float: none !important;
    width: auto !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .blog_title {
    min-height: 118px;
    padding: 18px 14px;
    box-sizing: border-box;
  }

  .blog_title h1 {
    font-size: 30px;
    line-height: 1.05;
  }

  .blog_title h4 {
    font-size: 14px;
    line-height: 1.35;
  }

  .navigation {
    min-height: 0;
    padding: 6px;
  }

  .navigation ul {
    gap: 6px;
  }

  .navigation li {
    float: none;
    width: auto;
  }

  .navigation li a {
    display: block;
    padding: 8px 9px;
    line-height: 1.2;
  }

  .main_image {
    min-height: 92px;
    background-size: cover;
    background-position: center;
  }

  .content_wrapper {
    padding: 10px;
    box-sizing: border-box;
  }

  .post h2 {
    font-size: 22px;
    line-height: 1.15;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *:before,
  *:after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
  }
}

.media-page .post {
  color: #2b2420;
}

.media-hub {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 16px 0 6px;
}

.media-panel {
  border: 1px solid rgba(93, 29, 25, .26);
  background: rgba(255, 250, 238, .72);
  padding: 14px;
  box-sizing: border-box;
}

.media-panel--feature {
  grid-column: span 2;
}

.media-panel h3 {
  margin: 0 0 10px;
  color: #5d1d19;
  font-size: 18px;
  line-height: 1.25;
}

.media-embed {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #1f1110;
  overflow: hidden;
  border: 1px solid rgba(44, 17, 16, .45);
}

.media-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.media-link-list,
.media-downloads {
  margin: 0 0 10px;
}

.media-link-list li {
  margin: 0 0 6px 18px;
}

.media-downloads {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.media-downloads a,
.media-panel p a {
  font-weight: bold;
}

@media (max-width: 760px) {
  .media-hub {
    grid-template-columns: 1fr;
  }

  .media-panel--feature {
    grid-column: span 1;
  }
}

/* Readability and contrast audit - 2026-06-04 */
body {
  font-family: Verdana, Arial, Helvetica, sans-serif;
  font-size: 16px;
  line-height: 1.55;
}

a {
  color: #f5d36a;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

a:visited {
  color: #e7b8a6;
}

a:hover,
a:focus-visible {
  color: #fff7d8;
}

a:focus-visible,
input:focus-visible {
  outline: 3px solid #f5d36a;
  outline-offset: 3px;
}

.navigation li a {
  min-height: 17px;
  font-size: 14px;
  line-height: 1.25;
}

.navigation li a:hover,
.navigation li a:focus-visible {
  background-color: rgba(142, 0, 0, .68);
  color: #fff7d8;
}

.entry {
  background-color: rgba(32, 24, 21, .88) !important;
}

.entry p,
html>body .entry li,
.entry td,
.entry dd,
.entry blockquote,
.tabbertab,
.tabbertab p,
.tabbertab ul li,
.sleft ul li ul li,
.sright ul li ul li {
  color: #fff8e7;
  font-size: 15px;
  line-height: 1.65;
}

.entry p {
  padding-bottom: 14px;
}

.entry p a,
.entry li a,
.entry blockquote a,
.tabbertab a,
.sleft ul li a,
.sright ul li a,
.post a {
  color: #f5d36a;
  font-weight: 600;
}

.entry p a:visited,
.entry li a:visited,
.entry blockquote a:visited,
.tabbertab a:visited,
.sleft ul li a:visited,
.sright ul li a:visited,
.post a:visited {
  color: #e7b8a6;
}

.entry p a:hover,
.entry p a:focus-visible,
.entry li a:hover,
.entry li a:focus-visible,
.tabbertab a:hover,
.tabbertab a:focus-visible,
.sleft ul li a:hover,
.sleft ul li a:focus-visible,
.sright ul li a:hover,
.sright ul li a:focus-visible,
.post a:hover,
.post a:focus-visible {
  color: #fff7d8;
  background: rgba(93, 29, 25, .72);
  text-decoration: none;
}

.entry h2 {
  font-size: 20px;
  line-height: 1.25;
}

.entry h2.sectionhead {
  color: #fff8e7;
  font-size: 12px;
  line-height: 1.35;
}

.entry p.postinfo,
.entry p.postinfo a,
.entry p.postinfo span.category,
.entry p.postinfo span.comment {
  color: #fff0c3;
  font-size: 12px;
  line-height: 1.45;
}

blockquote {
  color: #fff8e7;
  font-size: 15px;
  line-height: 1.6;
}

h2.widgettitle {
  font-size: 15px;
  line-height: 1.35;
  color: #fff8e7;
}

ul.tabbernav li a:link,
ul.tabbernav li a:visited {
  color: #fff8e7;
  font-size: 13px;
}

ul.tabbernav li a:hover,
ul.tabbernav li a:focus-visible,
ul.tabbernav li.tabberactive a {
  color: #210f0d;
  background: #d8cfb7;
}

.footer {
  color: #fff8e7;
  font-size: 14px;
  line-height: 1.5;
}

.footer a,
.footer a:visited {
  color: #f5d36a;
}

@media (max-width: 760px) {
  .navigation li a {
    padding: 10px 11px;
    font-size: 14px;
    line-height: 1.25;
  }

  .entry {
    padding: 16px;
    margin-left: 0;
    margin-right: 0;
  }

  .entry p,
  html>body .entry li,
  .entry td,
  .entry dd,
  .entry blockquote,
  .tabbertab,
  .tabbertab p,
  .tabbertab ul li,
  .sleft ul li ul li,
  .sright ul li ul li {
    font-size: 16px;
    line-height: 1.65;
  }
}

/* Mobile header/navigation readability fix - 2026-06-04 */
@media (max-width: 760px) {
  .blog_title {
    height: auto !important;
    min-height: 0;
    padding: 0;
    overflow: visible;
  }

  .blog_title h1 {
    width: auto !important;
    height: auto !important;
    min-height: 42px;
    margin: 0 0 4px;
    padding: 12px 12px 10px 16px;
    font-size: 24px;
    line-height: 1.15;
    box-sizing: border-box;
  }

  .blog_title h1 a {
    display: block;
    min-height: 30px;
    padding: 6px 0 4px 42px;
    line-height: 1.15;
  }

  .blog_title h4 {
    padding: 0 14px 12px 58px;
    font-size: 15px;
    line-height: 1.35;
    color: #2b2420;
  }

  .navigation {
    height: auto !important;
    min-height: 0;
    overflow: visible;
    background-color: #2b2b30;
    background-repeat: repeat;
  }

  .navigation ul {
    float: none;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 0;
    margin: 0;
  }

  .navigation ul li {
    float: none;
    display: block;
  }

  .navigation ul li a {
    float: none;
    height: auto;
    min-height: 0;
    padding: 10px 11px;
    background-color: rgba(0, 0, 0, .18);
    background-position: top right;
    box-sizing: border-box;
  }
}

/* Web3 button menu and surface polish - 2026-06-04 */
.container_16 {
  position: relative;
  overflow: visible;
}

.blog_title {
  background:
    linear-gradient(135deg, rgba(142, 0, 0, .94), rgba(64, 20, 18, .98) 52%, rgba(25, 13, 11, .96)),
    url("/wp-content/themes/that-music-theme/img/site_title_bck.gif") top right no-repeat;
  border: 1px solid rgba(255, 248, 231, .22);
  border-bottom: 0;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .18),
    0 12px 30px rgba(32, 12, 10, .22);
  box-sizing: border-box;
}

.blog_title h1 {
  width: auto;
  max-width: none;
  box-sizing: border-box;
  background: transparent;
  text-shadow: 0 2px 0 rgba(0, 0, 0, .35), 0 0 22px rgba(245, 211, 106, .22);
}

.blog_title h1 a {
  display: inline-block;
  max-width: calc(100% - 24px);
}

.blog_title h4 {
  color: #fff0c3;
  text-shadow: 0 1px 0 rgba(0, 0, 0, .28);
}

.navigation {
  height: auto !important;
  min-height: 0;
  padding: 10px;
  overflow: visible;
  box-sizing: border-box;
  background:
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,0) 45%),
    linear-gradient(135deg, rgba(37,31,31,.98), rgba(25,19,18,.96));
  border: 1px solid rgba(216, 207, 183, .22);
  border-top: 0;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.10),
    0 14px 30px rgba(31, 14, 12, .20);
}

.navigation ul {
  float: none;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
}

.navigation ul li {
  float: none;
  display: block;
  min-width: 0;
}

.navigation ul li a {
  float: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  height: auto;
  max-width: 100%;
  padding: 10px 14px;
  box-sizing: border-box;
  color: #fff8e7;
  background:
    linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.04)),
    rgba(93, 29, 25, .34);
  border: 1px solid rgba(245, 211, 106, .20);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.14),
    0 6px 16px rgba(0,0,0,.16);
  font-size: 14px;
  line-height: 1.25;
  text-align: center;
  text-decoration: none;
  white-space: normal;
  overflow-wrap: normal;
  word-break: normal;
}

.navigation ul li a.current,
.navigation ul li.current_page_item a,
.navigation ul li a:hover,
.navigation ul li a:focus-visible {
  color: #210f0d;
  background:
    linear-gradient(180deg, #fff7d8, #f5d36a);
  border-color: rgba(255, 248, 231, .78);
  box-shadow:
    0 0 0 1px rgba(142, 0, 0, .28),
    0 10px 26px rgba(142, 0, 0, .28);
  transform: translateY(-1px);
}

.navigation ul li a:visited {
  color: #fff8e7;
}

.navigation ul li a.current:visited,
.navigation ul li.current_page_item a:visited,
.navigation ul li a:hover:visited,
.navigation ul li a:focus-visible:visited {
  color: #210f0d;
}

.main_image {
  clear: both;
  position: relative;
  overflow: hidden;
  border-left: 1px solid rgba(216, 207, 183, .22);
  border-right: 1px solid rgba(216, 207, 183, .22);
  box-sizing: border-box;
}

.main_image:after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(25,13,11,.04), transparent 35%, rgba(25,13,11,.18)),
    linear-gradient(90deg, rgba(142,0,0,.20), transparent 28%, transparent 72%, rgba(142,0,0,.16));
}

.content_wrapper {
  border: 1px solid rgba(216, 207, 183, .24);
  border-top: 0;
  box-shadow: 0 18px 38px rgba(31, 14, 12, .22);
}

.entry {
  border: 1px solid rgba(216, 207, 183, .22);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 12px 28px rgba(31, 14, 12, .18);
}

.post h2,
.entry h2:not(.sectionhead) {
  background:
    linear-gradient(90deg, rgba(142,0,0,.98), rgba(93,29,25,.88)),
    url("/wp-content/themes/that-music-theme/img/site_title_bck.gif") top right no-repeat;
  border-color: rgba(245, 211, 106, .28);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.14);
}

.post h2 a:hover,
.post h2 a:focus-visible {
  background: transparent;
  color: #fff7d8;
  text-decoration: underline;
}

@media (min-width: 761px) {
  .navigation ul li a[href="/depression-and-teenage-suicide-in-utah/"],
  .navigation ul li a[href="/justin-jared-thompson-1986-2002-obituary/"] {
    max-width: 260px;
  }
}

@media (max-width: 760px) {
  .blog_title h1 {
    font-size: 25px;
    padding-right: 14px;
  }

  .blog_title h1 a {
    max-width: 100%;
  }

  .navigation {
    padding: 9px;
  }

  .navigation ul {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .navigation ul li,
  .navigation ul li a {
    width: 100%;
  }

  .navigation ul li a {
    min-height: 44px;
    padding: 10px 8px;
    font-size: 14px;
    line-height: 1.18;
  }

  .navigation ul li a[href="/depression-and-teenage-suicide-in-utah/"],
  .navigation ul li a[href="/justin-jared-thompson-1986-2002-obituary/"] {
    grid-column: 1 / -1;
  }

  .main_image {
    clear: both;
  }
}

@media (max-width: 420px) {
  .navigation ul {
    grid-template-columns: 1fr;
  }
}

