@import url("https://fonts.googleapis.com/css?family=Shippori+Mincho:400,700");
body { max-width: 1920px; width: 100%; margin: 0 auto; padding: 20px; box-sizing: border-box; background-color: rgb(212, 245, 241); color: rgb(0, 0, 0); font-family: "Shippori Mincho", sans-serif; font-size: 19px; }
body a { text-decoration: none; color: rgb(0, 0, 0); }
body a:visited { color: rgb(0, 0, 0); }
.header { padding: 10px; text-align: center; margin-bottom: 10px; position: relative; overflow: hidden; border-radius: 8px; background-color: rgb(212, 216, 245); }
.header::after { height: 69%; }
.review { margin-top: 10px; text-align: left; padding: 30px; overflow: auto; border-radius: 8px; background-color: rgb(212, 216, 245); line-height: 24px; }
.review::after { height: 69%; }
h3 { margin: 0; padding: 0; font-size: inherit; font-weight: bold; }
.navigation { font-weight: bold; margin-bottom: 15px; }
.spacer { height: 2px; }
.category-grid { column-width: 250px; column-gap: 10px; }
.category-container { break-inside: avoid-column; margin-bottom: 10px; overflow: hidden; border-radius: 8px; }
.category-name { padding: 10px; text-align: center; background-color: rgb(224, 212, 245); }
.site-list { display: flex; flex-direction: column; padding: 15px; gap: 10px; background-color: rgb(212, 232, 245); }
.site-list::after { height: 69%; }
.site-link-container { display: flex; gap: 10px; align-items: center; max-width: 190px; }
.site { display: grid; grid-template-columns: auto max-content; z-index: 1; }
.site-description-info { max-height: 0; overflow: hidden; visibility: hidden; opacity: 0; text-align: center; border-radius: 6px; box-sizing: border-box; padding: 0; background-color: rgb(212, 245, 241); color: rgb(0, 0, 0); }
.site-description-info a { color: rgb(0, 0, 0); }
.site-description-info a:visited { color: rgb(0, 0, 0); }
.review-link:hover + .site-description-info { margin-top: 5px; padding: 5px; max-height: 300px; visibility: visible; opacity: 1; transition-delay: 2s; }
.review-link { display: flex; opacity: 0.2; }
.site-link { overflow-x: hidden; white-space: nowrap; text-overflow: ellipsis; }
.site-icon { width: 23px; height: 23px; }
.review-icon { filter: invert(0%); width: 23px; height: 23px; }
.site-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 10px; }
.thumb-wrapper { display: flex; flex-direction: column; }
.site-container { overflow: hidden; border-radius: 8px; }
.site-name { padding: 10px; text-align: center; background-color: rgb(224, 212, 245); }
.site-thumb-container { position: relative; display: flex; }
.site-thumb-container:hover .site-thumb { filter: brightness(50%); }
.site-thumb-container:hover .site-buttons-container { visibility: visible; opacity: 1; pointer-events: auto; }
.site-thumb { transition: filter 0.3s ease 0s; max-width: 100%; }
.site-buttons-container { position: absolute; top: 50%; left: 50%; width: 60%; display: flex; flex-direction: column; justify-content: center; gap: 20px; visibility: hidden; opacity: 0; transform: translate(-50%, -50%); transition: opacity 0.4s ease 0s; }
.site-button { text-align: center; padding: 10px 5px; cursor: pointer; transition: background-color 0.3s ease 0s, color 0.3s ease 0s; border-radius: 8px; background-color: rgb(212, 232, 245); }
.site-button:hover { background-color: rgb(224, 212, 245); }
.site-description { padding: 10px; overflow: auto; overflow-wrap: break-word; height: 94px; background-color: rgb(212, 232, 245); line-height: 24px; scrollbar-width: thin;  }
.site-description::-webkit-scrollbar { width: 5px; }
.site-description-wrapper {  }
.site-description-wrapper::after { height: 69%; }
.site-image-container { display: flex; gap: 10px; overflow: hidden; margin-bottom: 10px; border-radius: 8px; }
.site-image-wrapper { display: flex; flex-direction: column; position: relative; }
.site-image-wrapper.side-image { width: 100%; overflow: hidden; }
.site-image-wrapper.side-image img { width: auto; height: 100%; position: absolute; left: 0; }
.site-image-wrapper.center-image { max-width: 50%; }
.site-buttons-container-big { display: flex; gap: 10px; }
.site-button-big { padding: 10px 20px; text-align: center; cursor: pointer; box-sizing: border-box; display: flex; align-items: center; justify-content: center; border-radius: 8px; background-color: rgb(212, 232, 245); }
.site-button-big:hover { background-color: rgb(224, 212, 245); }
.side-button { flex: 1 1 0; }
.center-button { flex: 0 0 50%; max-width: 620px; }
.more-sites { text-align: center; margin: 20px 0; }
.footer { margin-top: 30px; padding: 10px 0; text-align: center; border-top: 1px solid rgb(212, 232, 245); }
.site-description-container {  }
.site-description-container::after { height: 69%; }
@media (max-width: 768px) {
  body { padding: 10px; }
  .big-desc { padding: 0 30px; font-size: 1em; }
  .site-button-big { padding: 10px 15px; }
  .site-image-container { justify-content: center; }
  .site-image-wrapper.center-image { max-width: 100%; }
  .site-image-wrapper.side-image { display: none; }
  .side-button { font-size: smaller; }
  .center-button { font-size: smaller; min-width: fit-content; flex: 0 1 0; }
}