/* Colors */
:root {
  --lightgray: #e0e0e0;
  --gray: #c0c0c0;
  --darkgray: #2c3e50;
  --navy: #5ba386;
  --blue: #082840;
  --white: #fff;
  --lightblue: #f3f5f7;

  --space-xxs: 4px;
  --space-xs: 8px;
  --space-s: 16px;
  --space-m: 24px;
  --space-l: 32px;
  --space-xl: 48px;
  --space-xxl: 64px;
}

/* Global stylesheet */
* {
  box-sizing: border-box;
}

html,
body {
  padding: 0;
  /* margin: 0; */
  font-family: -apple-system, system-ui, sans-serif;
  color: var(--darkgray);
  background-color: var(--white);
  max-width: 1024px;
  margin: 0 auto;
}
p:last-child {
  margin-bottom: 0;
}
p,
.tmpl-post li,
img {
  /* max-width: 37.5em; 600px /16 */
}
p,
.tmpl-post li {
  line-height: 1.45;
}
a[href] {
  color: var(--blue);
}
/* a[href]:visited {
  color: var(--gray);
} */
main {
  padding: var(--space-s);
}
main :first-child {
  margin-top: 0;
}

/* Header */
header {
  border-bottom: 1px dashed var(--lightgray);
  display: flex;
  padding: var(--space-s);
  /* justify-content: center; */
}
header:after {
  content: "";
  display: table;
  clear: both;
}
table {
  margin: 1em 0;
}
table td,
table th {
  padding-right: 1em;
}

blockquote {
  /* background: #f6f6f6; */
  background-color: var(--lightblue);
  margin: 0;
  padding: 1em;
  font-style: italic;
}

pre,
code {
  font-family: Consolas, Menlo, Monaco, "Andale Mono WT", "Andale Mono",
    "Lucida Console", "Lucida Sans Typewriter", "DejaVu Sans Mono",
    "Bitstream Vera Sans Mono", "Liberation Mono", "Nimbus Mono L",
    "Courier New", Courier, monospace;
  line-height: 1.5;
}
pre {
  font-size: 14px;
  line-height: 1.375;
  direction: ltr;
  text-align: left;
  white-space: pre;
  word-spacing: normal;
  word-break: normal;
  -moz-tab-size: 2;
  -o-tab-size: 2;
  tab-size: 2;
  -webkit-hyphens: none;
  -moz-hyphens: none;
  -ms-hyphens: none;
  hyphens: none;
  padding: 1em;
  margin: 0.5em 0;
  background-color: #f6f6f6;
}
code {
  word-break: break-all;
}
.highlight-line {
  display: block;
  padding: 0.125em 1em;
  text-decoration: none; /* override del, ins, mark defaults */
  color: inherit; /* override del, ins, mark defaults */
}

/* allow highlighting empty lines */
.highlight-line:empty:before {
  content: " ";
}
/* avoid double line breaks when using display: block; */
.highlight-line + br {
  display: none;
}

.highlight-line-isdir {
  color: #b0b0b0;
  background-color: #222;
}
.highlight-line-active {
  background-color: #444;
  background-color: hsla(0, 0%, 27%, 0.8);
}
.highlight-line-add {
  background-color: #45844b;
}
.highlight-line-remove {
  background-color: #902f2f;
}

/* Header */
.home {
  padding: 0 1rem;
  float: left;
  margin: 1rem 0; /* 16px /16 */
  font-size: 1em; /* 16px /16 */
}
.home :link:not(:hover) {
  text-decoration: none;
}

/* Nav */
.nav {
  padding: 0;
  list-style: none;
  float: left;
  margin-left: 1em;
}
.nav-item {
  display: inline-block;
  margin-right: 1em;
}
.nav-item a[href]:not(:hover) {
  text-decoration: none;
}
.nav-item-active {
  font-weight: 700;
  text-decoration: underline;
}

.nav-item-active a[href] {
  color: var(--navy) !important;
}

/* Posts list */
.postlist {
  list-style: none;
  padding: 0;
}
.postlist-item {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  counter-increment: start-from -1;
  line-height: 1.8;
}
.postlist-item:before {
  display: inline-block;
  pointer-events: none;
  content: "" counter(start-from, decimal-leading-zero) ". ";
  line-height: 100%;
  text-align: right;
}
.postlist-date,
.postlist-item:before {
  font-size: 0.8125em; /* 13px /16 */
  color: var(--darkgray);
}
.postlist-date {
  word-spacing: -0.5px;
}
.postlist-link {
  padding-left: 0.25em;
  padding-right: 0.25em;
  text-underline-position: from-font;
  text-underline-offset: 0;
  text-decoration-thickness: 1px;
}
.postlist-item-active .postlist-link {
  font-weight: bold;
}
.tmpl-home .postlist-link {
  font-size: 1.1875em; /* 19px /16 */
  font-weight: 700;
}

/* Tags */
.post-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-transform: uppercase;
  font-size: 0.75em; /* 12px /16 */
  padding: 0.08333333333333em 0.3333333333333em; /* 1px 4px /12 */
  margin-left: 0.6666666666667em; /* 8px /12 */
  margin-top: 0.5em; /* 6px /12 */
  margin-bottom: 0.5em; /* 6px /12 */
  color: var(--darkgray);
  border: 1px solid var(--gray);
  border-radius: 0.25em; /* 3px /12 */
  text-decoration: none;
  line-height: 1.8;
}
a[href].post-tag,
a[href].post-tag:visited {
  color: inherit;
}
a[href].post-tag:hover,
a[href].post-tag:focus {
  background-color: var(--lightgray);
}
.postlist-item > .post-tag {
  align-self: center;
}

/* Warning */
.warning {
  background-color: #ffc;
  padding: 1em 0.625em; /* 16px 10px /16 */
}
.warning ol:only-child {
  margin: 0;
}

/* Direct Links / Markdown Headers */
.direct-link {
  font-family: sans-serif;
  text-decoration: none;
  font-style: normal;
  margin-left: 0.1em;
}
a[href].direct-link,
a[href].direct-link:visited {
  color: transparent;
}
a[href].direct-link:focus,
a[href].direct-link:focus:visited,
:hover > a[href].direct-link,
:hover > a[href].direct-link:visited {
  color: #aaa;
}

/* Carousel */
.embla {
  overflow: hidden;
}
.embla__container {
  display: flex;
}
.embla__slide {
  position: relative;
  flex: 0 0 100%;
}

/* Audio player */
audio {
  width: 100%;
  /* max-width: 800px; */
}

/* Header */
.header-container {
  display: flex;
  justify-content: center;
}

/* Kinh */
.kinh > p {
  text-indent: var(--space-s);
  line-height: 1.6;
}

.kinh div.tip {
  /* background-color: #f6f6f6; */
  text-align: center;
  background-color: var(--lightblue);
  padding: var(--space-s) var(--space-m);
  font-size: 1.1em;
  font-style: italic;
}

.kinh h3 {
  margin-bottom: 0;
}

div.tip > p:first-child::before {
  /* content: "❝ "; */
  content: "〝 ";
}

div.tip > p:last-child::after {
  /* content: " ❞"; */
  content: " 〞";
}

.kinh div.tip p,
ol,
ul {
  line-height: 1.6;
}

.playlist {
  max-height: 250px;
  overflow: scroll;
  border-style: solid;
}

.playlist .chapter {
  /* display: inline-block; */
  /* margin: 0 var(--space-s) var(--space-s) 0; */
  /* padding: var(--space-xs) var(--space-s); */
  /* width: 80px; */
  padding: var(--space-xs) var(--space-s);
  text-decoration: underline;
  /* text-align: center; */
}
.playlist .chapter span {
  cursor: pointer;
}
.playlist .chapter:nth-of-type(even) {
  background-color: var(--lightblue);
  /* background: var */
}

/* Sach noi */
.sachnoi .infos,
.kinh .infos {
  padding: var(--space-s);
  font-size: 0.85em;
  /* max-width: fit-content; */
  border-style: solid;
  /* border-width: 1px; */
  border-color: var(--darkgray);
}

.audio-player {
  background: var(--lightblue);
  border-radius: 30px;
  /* width: 300px; */
  padding: var(--space-xs) var(--space-s);
  margin: var(--space-s) 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.audio-player .audio-controls {
  display: flex;
  justify-content: center;
  align-items: center;
}

.audio-player .audio-playing {
  height: 2px;
  background-color: var(--darkgray);
  flex: 1;
}

.audio-player ion-icon {
  color: var(--darkgray);
}

.audio-player label {
  font-size: 0.85em;
}

.audio-player .audio-playing {
  -webkit-appearance: none;
  background-color: var(--darkgray);
  margin: 0 var(--space-xs);
}

.audio-player :first-child,
.audio-player :last-child {
  /* margin: 0 var(--space-xs); */
}

.audio-player .audio-controls ion-icon {
  margin: 0 var(--space-xxs);
}

.audio-player ion-icon.disabled {
  opacity: 0.5;
}

.audio-player ion-icon.loading {
  animation-name: rotate-s-loader;
  animation-iteration-count: infinite;
  animation-duration: 1s;
  animation-timing-function: linear;
}

@keyframes rotate-s-loader {
  from {
    transform: rotate(0);
  }
  to {
    transform: rotate(360deg);
  }
}

/* Home */
.hero-image {
  /* width: 100%; */
  margin: var(--space-m) auto;
  text-align: center;
}
.hero-image img {
  max-width: 600px;
}
.tmpl-home .tip {
  text-align: center;
  /* font-size: 1.15em; */
  /* font-style: italic; */
}

@media screen and (max-width: 600px) {
  .hero-image img {
    max-width: 100%;
  }
}

.go-to-top {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
  padding: 20px;
  cursor: pointer;
  /* background-color: #e0e0e0; */
  border-width: 2px;
  border-style: solid;
  z-index: 112;
  background-color: white;
}
