@charset "UTF-8";
/*
Theme Name: ファービーサイトテンプレート
Description: ファービーのファンサイト用のテンプレートです
Version: 1.0
Author: inu/点P空間
*/

:root {
  --blue-color: #a1f6ff;
  --green-color: #62cde0;
  --green2-color: #55c79f;
  --purple-color: #dfc6ff;
  --purple2-color: #7441b5;
  --yellow-color: #f8ed8f;
  --red-color: #ff2024;
  --main-font: "Titan One", "メイリオ", sans-serif;
  --text-font: "Arial", "メイリオ", sans-serif;
}

.home-body {
  font-family: var(--main-font);
  font-size: 1rem;
  overflow-x: hidden;
  width: 100%;
  position: relative;
  height: auto;
}
html {
  height: auto;
  position: relative;
}
html.no-scroll {
  width: 100%;
  height: 100%;
  position: fixed;
}
.home-body.no-scroll {
  width: 100%;
  height: 100%;
  position: fixed;
}

.grecaptcha-badge {
  visibility: hidden;
}
a {
  color: inherit;
  text-decoration: none;
}
li {
  list-style: none;
}

#is-loading {
  position: fixed;
  width: 100%;
  height: 100vh;
  height: calc(var(--vh) * 100);
  top: 0px;
  left: 0px;
  background: #d1d1d1;
  z-index: 800;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
#is-loading p {
  display: inline-block;
}
#loading {
  display: none;
  width: 100px;
  height: 100px;
}
#loading img {
  object-fit: contain;
  width: 100%;
  height: auto;
  display: block;
}
.fade-out {
  opacity: 0;
  transition: opacity 1s ease-out;
}

/* frame---------------------- */
.frameback {
  width: 100%;
  height: calc(var(--vh) * 100);
  z-index: 100;
  position: fixed;
  border: 2vw solid var(--blue-color);
  border-width: clamp(20px, 5vw, 60px);
  user-select: none;
  pointer-events: none;
}
.frame {
  width: 100%;
  height: calc(var(--vh) * 100);
  z-index: 100;
  position: fixed;
  border-radius: clamp(50px, 8vw, 100px);
  border: 2vw solid var(--blue-color);
  border-width: clamp(20px, 5vw, 60px);
  user-select: none;
  pointer-events: none;
}
.frame-movie {
  position: fixed;
  z-index: 210;
  bottom: 0;
  left: 0;
  width: 200px;
  height: auto;
  transition: left 0.2s ease-out;
}
@media screen and (max-width: 768px) {
  .frame-movie {
    width: 100px;
  }
}
.site-id {
  position: fixed;
  z-index: 210;
  top: clamp(10px, 2.5vw, 30px);
  left: 0;
  width: clamp(200px, 20vw, 400px);
  height: 80px;
  background: var(--blue-color);
  border-radius: clamp(50px, 8vw, 100px);
  display: flex;
  justify-content: center;
  align-items: center;
}
.site-id p {
  text-align: center;
  color: #fff;
  font-family: var(--main-font);
  font-size: 20px;
  line-height: 1.2;
  -webkit-text-stroke: 1px #000000;
}
.site-id p span {
  white-space: nowrap;
}

.sideScAnim {
  position: absolute;
  top: 50%;
  left: 0;
  z-index: inherit;
  width: clamp(20px, 5vw, 60px);
  transform: translate(-100%, -50%);
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
.sideScAnim p {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  display: flex;
  flex-direction: column;
  white-space: nowrap;
  color: #fff;
  font-size: 20px;
  margin-bottom: 20px;
}

.arrow {
  position: relative;
  display: inline-block;
  width: 2px;
  height: 80px;
  transform: scale(1, 1);
  transform-origin: top center;
  background-color: #fff;
  animation: 3s ease-out infinite forwards arrow;
}
.arrow::before {
  content: "";
  position: absolute;
  /* top: calc(50% - 2px); */
  bottom: 0;
  left: 2px;
  width: 10px;
  height: 2px;
  /* border-radius: 9999px; */
  background-color: #fff;
  transform: rotate(-45deg);
  transform-origin: top left;
}

@keyframes arrow {
  0% {
    transform: scale(1, 1);
  }
  90% {
    transform: scale(1, 1.7);
  }
  100% {
    transform: scale(1, 1);
  }
}
.sideR {
  position: absolute;
  top: 50%;
  right: 0;
  z-index: inherit;
  width: clamp(20px, 5vw, 60px);
  transform: translate(100%, -50%);
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
.sideR p {
  font-family: var(--text-font);
  font-weight: 500;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  white-space: nowrap;
  color: var(--purple2-color);
  font-size: 12px;
  margin-bottom: 20px;
}
/* hamburger menu */
.hamburger {
  width: 0;
  height: 0;
}
/* 表示された時用のCSS */
.nav-open .hamburger_border_top {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 25px;
}
.nav-open .hamburger_border_center {
  width: 0;
  left: 50%;
}
.nav-open .hamburger_border_bottom {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 25px;
}
/* headersp-------------------- */
.headersp {
  display: none;
  position: fixed;
  overflow-y: hidden;
  right: -100%;
  top: 0;
  width: 100%;
  height: 100%;
  min-height: 100vh;
  min-height: calc(var(--vh) * 100);
  overflow-y: auto;
  background: var(--blue-color);
  z-index: 50;
}

.nav_headersp {
  width: 80%;
  margin: 150px auto;
}
@media screen and (max-width: 1200px) {
  .headersp {
    display: block;
    right: -100%;
    transition: right 0.2s ease-out;
  }
  .headersp.nav-open {
    right: 0;
  }

  .hamburger {
    position: fixed;
    right: 15px;
    top: 13px;
    width: 50px;
    height: 50px;
    cursor: pointer;
    z-index: 300;
    border-radius: 5px;
    background: var(--blue-color);
  }
  .hamburger_border {
    position: absolute;
    left: 12px;
    width: 26px;
    height: 3px;
    background-color: var(--purple2-color);
    -webkit-transition: all 0.4s;
    -o-transition: all 0.4s;
    transition: all 0.4s;
  }
  .hamburger_border_top {
    top: 17px;
  }
  .hamburger_border_center {
    top: 25px;
  }
  .hamburger_border_bottom {
    top: 33px;
  }
}
.nav_headersp a {
  display: block;
  margin: 0 auto 1em;
  padding: 15px 0px;
  width: 100%;
  max-width: 300px;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.5;
  text-align: center;
  color: var(--purple2-color);
  transition: color 0.2s ease-out;
}
.nav_headersp a:hover {
  color: var(--purple-color);
}

.header-nav-wrapper {
  position: fixed;
  z-index: 200;
  width: 70%;
  max-width: 900px;
  height: 70px;
  right: 10px;
  top: 31px;
}
.gnav {
  border: 5px solid #7441b5;
  backdrop-filter: blur(25px);
  /* Note: backdrop-filter has minimal browser support */
  border-radius: 50px;
  background: rgba(255, 255, 255, 0.3);
  z-index: 3;
  height: 70px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  /* transition: all .3s ease-in-out; */
}
.gnav-list {
  padding: 0 10px;
  width: 100%;
  display: flex;
  justify-content: space-evenly;
  align-items: center;
}
.gnav-list li a {
  font-family: var(--main-font);
  font-style: normal;
  font-weight: 400;
  font-size: 25px;
  text-transform: uppercase;
  color: #fff;
  -webkit-text-stroke: 1px #000;
  transition: 0.2s color ease-out;
}
.gnav-list li a.current {
  color: var(--purple-color);
}
.gnav-list li a:hover {
  color: var(--purple-color);
}
@media screen and (max-width: 1200px) {
  .header-nav-wrapper {
    display: none;
  }
}

.topview {
  width: 100%;
  height: calc(var(--vh) * 100);
  position: relative;
}
.topview h1 {
  font-size: 80px;
  font-size: clamp(24px, 6.96px + 6.09vw, 80px);
  display: block;
  position: absolute;
  top: 150px;
  left: 50%;
  width: 9em;
  z-index: 30;
  transform: translateX(-50%);
}
.topview h1 p {
  color: #fff;
  font-weight: 400;
  font-family: var(--main-font);
  font-size: 1em;
  text-align: center;
  -webkit-text-stroke: 1px #000;
}
.topview h1 div {
  display: flex;
  justify-content: center;
  width: 100%;
}
.topview h1 img {
  display: block;
  width: 8em;
  height: auto;
}

.topimg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.topimg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center bottom;
}
.top-white-dot {
  position: absolute;
  width: 100%;
  height: 100px;
  bottom: 0;
  left: 0;
  background-image: url("./img/white-dot.png");
  background-repeat: repeat-x;
  background-position: bottom left;
  background-size: contain;
}

/* about section-------------------------- */

.section-container {
  width: 100%;
  padding-top: 86px;
  padding-bottom: 86px;
}
.about {
  background: #fffef0;
  position: relative;
}
.inner {
  width: 80%;
  /* max-width: ; */
  margin: 0 auto;
  position: relative;
}
.content-title {
  font-size: clamp(32px, 26.52px + 1.96vw, 50px);
  font-weight: 500;
  letter-spacing: 0;
  color: var(--purple-color);
  -webkit-text-stroke: 1px #000;
  text-transform: uppercase;
  margin-bottom: 1.2em;
  margin-left: clamp(150px, 15vw, 300px);
}
.about-flex-box {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}
.about-left {
  width: 40%;
  position: relative;
  z-index: 2;
}
.about-left p {
  font-size: clamp(13px, 1.5vw, 18px);
  font-family: var(--text-font);
  color: var(--purple2-color);
}
.about-right {
  width: 60%;
}
.about-right > div {
  width: 100%;
  transform: translateY(-5vw);
}
.about-right img {
  width: 100%;
  height: auto;
  display: block;
}
@media screen and (max-width: 768px) {
  .section-container {
    padding-top: 48px;
    padding-bottom: 48px;
  }
  .about-flex-box {
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
  }
  .about-left {
    width: 100%;
  }
  .about-right {
    width: 100%;
  }
  .about-right > div {
    width: 100%;
    transform: translateY(0);
  }
  .content-title {
    margin-left: 0;
  }
}
.about-scroll {
  display: flex;
  flex-wrap: nowrap;
  position: absolute;
  bottom: 86px;
  left: 0;
  z-index: 500;
}
.about-scroll p {
  white-space: nowrap;
  font-family: var(--main-font);
  font-weight: 400;
  padding-right: 0.5em;
  color: transparent;
  -webkit-text-stroke: 1px var(--purple2-color);
  font-size: clamp(30px, 10.5vw, 200px);
  animation: aboutSc 15s linear infinite forwards;
}

@keyframes aboutSc {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
/* fix&fun section---------------------------------------------- */
.section-container.fixfun {
  background: #8a8a8a;
  overflow: hidden;
}
.content-title.fixfun {
  color: var(--yellow-color);
}
.inner > p {
  font-size: clamp(13px, 1.5vw, 18px);
  font-family: var(--text-font);
  color: #fff;
}
.top-article-link-box {
  display: flex;
  width: 100%;
  justify-content: flex-end;
  margin-bottom: 1.5em;
}
.top-article-link {
  margin-left: auto;
  display: inline-block;
  border-radius: 2em;
  padding: 0.7em;
  border: 1px solid #000;
  font-family: var(--main-font);
  font-style: normal;
  font-weight: 900;
  font-size: 24px;
  font-size: clamp(14px, 10.96px + 1.09vw, 24px);
  line-height: 1em;
  color: #fff;
  -webkit-text-stroke: 0.5px #000000;
}
.ff-list-wrapper {
  margin: 0 auto;
  width: 100%;
  max-width: 1200px;
  position: relative;
}

.ff-list li a {
  position: relative;
  width: 80%;
  aspect-ratio: 1/1;
  /* height: 300px; */
  border-radius: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-left: 10%;
  margin-right: 10%;
  margin-bottom: 30px;
  margin-top: 50px;
  cursor: pointer;
  background: linear-gradient(130.66deg, #ffabf4 19.49%, #49e4ff 84.31%);
  border: 1px solid #000000;
}
.list-cat {
  position: absolute;
  display: flex;
  justify-content: center;
  width: 100%;
  height: 2em;
  top: -2.5em;
  left: 0;
}
.list-cat span {
  font-size: 13px;
  color: var(--purple2-color);
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 2em;
  line-height: 1em;
  padding: 0.5em 1em;
  text-align: center;
  border: 1px solid #000;
}
.thumb-img {
  width: 80%;
  height: 80%;
  border: 1px solid #000;
  border-radius: 100%;
  overflow: hidden;
}
.thumb-img img {
  width: 100%;
  /* aspect-ratioがきくのは一方のサイズがautoのとき */
  height: auto;
  aspect-ratio: 1/1;
  object-fit: cover;
  display: block;
  /* border-radius: 100%; */
}
.ff-list li a .date {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  font-size: 10.5px;
  font-size: max(10.5px, 0.87vw);
  letter-spacing: 0.1em;
  line-height: 2.5em;
}
.ff-list li a p {
  text-align: center;
  position: absolute;
  width: 100%;
  top: 1.3em;
  left: 50%;
  transform: translateX(-50%);
  font-size: 24px;
  font-size: clamp(18px, 16.17px + 0.65vw, 24px);
  font-family: var(--main-font);
  font-weight: 900;
  color: #fff;
  -webkit-text-stroke: 0.5px #000;
  line-height: 1.4;
}
.tri-left,
.tri-right {
  position: absolute;
  top: 50%;
  left: 20px;
  transform: translate(-50%, -50%);
  z-index: 10;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  cursor: pointer;
}
.tri-right {
  left: auto;
  right: -20px;
}
.tri-left span,
.tri-right span {
  display: block;
  width: 30px;
  height: 26px;
  clip-path: polygon(
    50% 0,
    0% 100%,
    15% 90%,
    50% 20%,
    85% 90%,
    15% 90%,
    0 100%,
    100% 100%
  );
  background-color: var(--purple2-color);
}
.tri-left span {
  transform: rotate(-90deg);
}
.tri-right span {
  transform: rotate(90deg);
}
/* @media screen and (max-width: 1100px) {
  .content-title::before {
    font-size: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .content-title::before {
    font-size: 2rem;
  }
} */
/* doodle section------------------ */
.section-container.doodle {
  background: #7138b9;
}
.top-article-link.doodle {
  color: var(--green-color);
}
.dd-list-wrapper {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.dd-list {
  width: 100%;
  max-width: 900px;
  display: flex;
  align-items: center;
  justify-content: space-around;
}
.dd-list li {
  width: 20%;
}
@media screen and (max-width: 1200px) {
  .dd-list li {
    width: 150px;
  }
}
@media screen and (max-width: 768px) {
  .dd-list li {
    margin-left: 1em;
    margin-right: 1em;
  }
  .dd-list {
    justify-content: center;
    flex-wrap: wrap;
  }
}
.dd-list li a {
  position: relative;
  width: 100%;
  height: 300px;
  border-radius: 80px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 30px;
  margin-top: 30px;
  cursor: pointer;
  background: #000;
}
.dd-list .list-cat {
  position: absolute;
  display: flex;
  justify-content: start;
  width: 100%;
  height: 2em;
  top: -1em;
  left: 0;
}

.dd-list .list-cat span {
  font-size: 13px;
  color: #fff;
  background: var(--red-color);
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 2em;
  line-height: 1em;
  padding: 1em;
  text-align: center;
  border: 1px solid #000;
}

.thumb-img.dd {
  width: 100%;
  height: 100%;
  border-radius: 80px;
}
.thumb-img.dd img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 75px;
  border: 5px solid #000;
}
.dd-list li a .date {
  position: absolute;
  top: 1em;
  left: 50%;
  transform: translateX(-50%);
  font-size: 10.5px;
  font-size: max(10.5px, 0.87vw);
  letter-spacing: 0.1em;
  line-height: 2.5em;
}
.dd-list li a p {
  position: absolute;
  padding: 1em 2em;
  transform: rotate(-10deg);
  width: 100%;
  bottom: 2em;
  right: -2em;
  background: var(--green2-color);
  font-size: 14px;
  font-family: var(--main-font);
  font-weight: 900;
  color: var(--purple2-color);
  line-height: 1.4;
}
/* footer------------------------------------ */
.footer {
  width: 100%;
  background: var(--blue-color);
  position: relative;
  padding-top: 50px;
  padding-bottom: 100px;
  z-index: 0;
}
.footer-back-dot {
  position: absolute;
  z-index: 1;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background-image: url("./img/pink-dot.png");
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: contain;
}

.footer-text {
  position: relative;
  z-index: 3;
  width: 80%;
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
}
.footer-text img {
  width: 100%;
  height: auto;
  display: block;
}
.footer-back {
  z-index: 2;
  width: 80%;
  max-width: 800px;
  margin: 0 auto;
  margin-top: max(-100px, -10%);
}
.footer-back img {
  width: 100%;
  height: auto;
  display: block;
}
.footer-title {
  position: relative;
  z-index: 3;
  margin-top: -1em;
  color: #fff;
  font-weight: 400;
  font-family: var(--main-font);
  font-size: 80px;
  font-size: clamp(24px, 6.96px + 6.09vw, 80px);
  text-align: center;
  -webkit-text-stroke: 1px #000;
}
.footer-text02 {
  position: relative;
  z-index: 3;
  width: 80%;
  max-width: 600px;
  margin: 0.5em auto 0;
}
.footer-text02 img {
  width: 100%;
  height: auto;
  display: block;
}
.copyright {
  position: relative;
  z-index: 3;
  display: block;
  width: 100%;
  margin-top: 2em;
  font-size: 14px;
  color: var(--purple2-color);
  text-align: center;
  margin-bottom: 2em;
}
/* 404-section-------------- */
.c-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  font-size: 0.875rem;
  color: #fff;
  line-height: 3.2;
  justify-content: flex-start;
  align-items: center;
}
.c-breadcrumbs li {
  -webkit-text-stroke: 0.5px #000;
  font-weight: bold;
  text-transform: uppercase;
}
.c-breadcrumbs a {
  -webkit-text-stroke: 0.5px #000;
  font-weight: bold;
  text-transform: uppercase;
}

.c-breadcrumbs .bc-arrow {
  display: inline-block;
  content: "";
  width: 6px;
  height: 6px;
  border-top: solid 1.5px #aaa;
  border-right: solid 1.5px #aaa;
  margin-right: 10px;
  margin-left: 10px;
  transform: rotate(45deg);
}
.not-found-section {
  width: 100%;
  padding-top: 150px;
  padding-bottom: 150px;
  background: var(--blue-color);
  height: 100vh;
  height: calc(var(--vh) * 100);
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
  overflow-y: auto;
}
.not-found-title {
  font-size: 32px;
  color: #fff;
}
.nf-container {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
.nf-img {
  display: block;
  height: 30vh;
  width: 80%;
}
.nf-img img {
  object-position: 50% 50%;
  object-fit: contain;
  height: 100%;
  width: 100%;
  display: block;
}
.nf-text-box h2 {
  font-size: 16px;
  margin-top: 1em;
}
/* contact section----------------------- */
.contact-section {
  padding-top: 150px;
  padding-bottom: 1em;
  width: 100%;
  background: #4e709d;
}
.page-title {
  display: inline-block;
  font-size: clamp(24px, 17.5px + 2.71vw, 50px);
  font-weight: 500;
  letter-spacing: 0;
  color: var(--purple2-color);
  -webkit-text-stroke: 1px #000;
  text-transform: uppercase;
  margin-bottom: 1.2em;
  background: var(--yellow-color);
  border-radius: 2em;
  padding: 0.2em 0.4em;
  border: 1px solid #000;
  margin-top: 0.2em;
}
.page-content-box.contact {
  width: 100%;
  max-width: 800px;
  margin-left: auto;
  color: #fff;
}
.contact-text a {
  color: var(--purple-color);
}
.form-box dl {
  display: block;
  margin-top: 1.5em;
}
.form-box dl dd input {
  color: #000;
  margin-top: 0.5em;
  width: 100%;
  background: #fff;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  padding: 16px;
  box-sizing: border-box;
  display: block;
  border-style: none;
  border-radius: 5px;
  border: 1px solid #000;
}

.form-box dl dd textarea {
  color: #000;
  margin-top: 0.5em;
  border-style: none;
  background: #fff;
  width: 100%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  padding: 16px;
  box-sizing: border-box;
  display: block;
  border-radius: 5px;
  border: 1px solid #b9b9b9;
}
.submitBtn {
  display: flex;
  justify-content: center;
  width: 100%;
  padding-bottom: 2em;
}
.submitBtn input {
  margin: 1em auto;
  padding: 0.5em 2em;
  border: 1px solid #000;
  border-radius: 0.5em;
  display: inline-block;
  background-color: var(--purple2-color);
  color: #fff;
  font-weight: bold;
  transition: background-color 0.2s ease-out;
}
.submitBtn input:hover {
  background-color: var(--purple-color);
}

/* ff archive-section------------------------ */
.archive-section {
  width: 100%;
  padding-top: 150px;
  padding-bottom: 150px;
  background-image: url("./img/top-min.png");
  background-position: top center;
  background-repeat: repeat;
  background-size: contain;
}
@media screen and (max-width: 1200px) {
  .archive-section {
    background-image: url("./img/topsp-min.png");
  }
}
.page-title.ff {
  background: #fff;
  color: var(--yellow-color);
}
.page-content-box.archive {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
}

.article-container {
  width: 67%;
  background: rgba(255, 255, 255, 0.72);
  border-radius: 50px;
}
.article-wrapper {
  padding: 5%;
}
.article-list {
  margin-top: 2em;
}
@media screen and (max-width: 1200px) {
  .page-content-box.archive {
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
  }
  .article-container {
    width: 100%;
  }
}
.article-list a {
  padding: 1em 0;
  width: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  border-bottom: 2px solid #ebdd48;
}

.thumbnail {
  width: 30%;
  height: 100px;
  background: grey;
  border-radius: 20px;
  margin-right: 1em;
}
.thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  background: grey;
  border-radius: 20px;
}
.archive-text-box {
  width: calc(70% - 1em);
}
@media screen and (max-width: 768px) {
  .article-container {
    border-radius: 20px;
  }
  .article-list a {
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
  }
  .thumbnail {
    width: 100%;
    height: 40vw;
    margin-right: 0;
    margin-bottom: 1em;
  }
  .archive-text-box {
    width: 100%;
  }
}
.archive-text-box .cat-list {
  display: flex;
}
.archive-text-box .cat-list li {
  background: var(--yellow-color);
  color: #000;
  font-weight: bold;
  font-size: 12px;
  font-family: var(--text-font);
  padding: 0.2em 1.5em;
  margin-right: 0.3em;
  border-radius: 1em;
  display: flex;
  justify-content: center;
  align-items: center;
}
.archive-text-box .date {
  color: grey;
  font-family: var(--text-font);
  font-size: 14px;
}
.archive-text-box .title {
  margin-top: 1em;
  font-family: var(--text-font);
  font-size: 16px;
  font-weight: bold;
}
.archive-text-box .excerpt {
  font-family: var(--text-font);
  font-size: 14px;
}

.nav-links {
  display: flex;
  justify-content: flex-end;
  margin-top: 1em;
}
.nav-links span,
.nav-links a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  border: 1px solid #000;
  font-size: 0.9375rem;
  font-weight: 500;
  transition: 0.3s ease-in;
}
.nav-links span:not(:last-child),
.nav-links a:not(:last-child) {
  margin-right: 1%;
}
@media screen and (max-width: 768px) {
  .nav-links span,
  .nav-links a {
    font-size: 0.875rem;
  }
}
.nav-links span:hover,
.nav-links a:hover {
  background-color: var(--purple2-color);
  color: #ffffff;
}
.nav-links span.current {
  background-color: var(--purple2-color);
  color: #ffffff;
}
.nav-links a {
  color: #666666;
}
.nav-links a.next,
.nav-links a.prev {
  width: auto;
  padding: 5px 1.2em;
}
/* sidebar------------------------ */
.sidebar {
  width: 30%;
  height: auto;
}

.side-container {
  background: rgba(255, 255, 255, 0.72);
  border-radius: 50px;
  padding: 10%;
  display: flex;
  flex-direction: column;
  align-items: center;
  height: auto;
  margin-bottom: 1em;
}
@media screen and (max-width: 1200px) {
  .sidebar {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-top: 1em;
  }
  .side-container {
    padding: 5%;
    width: calc(50% - 1em);
  }
}
@media screen and (max-width: 768px) {
  .sidebar {
    flex-direction: column;
    align-items: flex-start;
    margin-top: 1em;
  }
  .side-container {
    padding: 5%;
    width: 100%;
    border-radius: 20px;
  }
}
.side-title {
  display: inline-block;
  font-size: 32px;
  font-size: clamp(24px, 20.36px + 1.52vw, 32px);
  font-weight: 500;
  letter-spacing: 0;
  color: var(--yellow-color);
  -webkit-text-stroke: 1px #000;
  text-transform: uppercase;
  background: #fff;
  border-radius: 2em;
  padding: 0.2em 1em;
  border: 1px solid #000;
  margin-bottom: 1em;
}
.side-item {
  width: 100%;
  margin-bottom: 2em;
}
.side-archive-title {
  font-size: 16px;
  font-weight: normal;
  margin-bottom: 0.5em;
}
.side-container.search {
  background: var(--purple-color);
}
.search-form {
  width: 100%;
}
.search-wrap {
  display: flex;
  margin: 0 auto;
  width: 100%;
  padding: 0.5em 1em;
  background-color: #fff;
  border-radius: 20px;
}
.search-wrap input[type="text"] {
  padding: 0;
  border: none;
  outline: none;
}

.btn-search {
  margin-right: 26px;
  line-height: 1;
}
/* single page ff---------------------------- */
.article-container.single {
  width: 67%;
  background: #b8b8b8;
  border-radius: 50px;
}
@media screen and (max-width: 1200px) {
  .article-container.single {
    width: 100%;
  }
}
.article-tt-upper {
  display: flex;
}
.article-tt-upper .cat-list {
  display: flex;
  margin-right: 0.3em;
}
.article-tt-upper .cat-list li {
  background: var(--yellow-color);
  color: #000;
  font-weight: bold;
  font-size: 12px;
  font-family: var(--text-font);
  padding: 0.2em 1.5em;
  margin-right: 0.3em;
  border-radius: 1em;
  display: flex;
  justify-content: center;
  align-items: center;
}
.article-tt-upper .date {
  color: #fff;
  font-family: var(--text-font);
  font-size: 14px;
}

.article-container.single .title {
  margin-top: 1em;
  color: #000;
  font-family: var(--text-font);
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 1em;
  border-bottom: 1px solid #ebdd48;
}
.thumbnail.single {
  width: 100%;
  height: auto;
  margin-right: 0;
  margin-bottom: 1em;
}
.article-text {
  color: #000;
  margin-bottom: 3em;
}

.page-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1em;
  width: 100%;
}

.page-nav a {
  background-color: #fff;
  color: var(--purple2-color);
  padding: 0.2em 1em;
  border-radius: 1em;
  display: inline-block;
  font-size: 14px;
  font-weight: bold;
  margin: 0 0.3em;
  transition: background-color 0.2s ease-out;
}
.page-nav a:hover {
  background-color: var(--purple-color);
}

/* archive-section dd---------------- */
.page-title.dd {
  background: var(--purple2-color);
  color: var(--yellow-color);
}
.article-container.dd {
  background: transparent;
}

.dd-list.archive {
  flex-wrap: wrap;
  width: 100%;
  max-width: 100%;
  align-items: center;
  justify-content: center;
}
.dd-list.archive li {
  width: 150px;
  margin: 0.3em 2em;
}
.dd-list.archive a {
  width: 100%;
}
@media screen and (max-width: 1200px) {
  .article-container.dd {
    width: 100%;
  }
  .dd-list.archive li {
    margin: 0.3em 1em;
  }
}
@media screen and (max-width: 768px) {
  .article-container.dd {
    border-radius: 20px;
  }
}
.side-title.dd {
  background: var(--purple2-color);
  color: var(--yellow-color);
}

/* article-single-dd------------- */
.archive-section.singledd {
  background: #000;
}
.article-container.singledd {
  width: 100%;
  background: transparent;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.thumbnail.singledd {
  width: 58%;
  height: auto;
  background: grey;
  border-radius: 20px;
}
.thumbnail.singledd > img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}
.article-wrapper.singledd {
  width: 40%;
  padding: 0;
}

.cat-list.singledd li {
  background: rgb(219, 0, 0);
  color: #fff;
}
.title.singledd {
  font-weight: bold;
  color: #24ffb2;
  margin-top: 1em;
  font-size: 24px;
  margin-bottom: 0.5em;
}
.article-text.singledd {
  color: #fff;
}
@media screen and (max-width: 1200px) {
  .article-container.singledd {
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
  }
  .thumbnail.singledd {
    width: 100%;
    height: auto;
  }
  .article-wrapper.singledd {
    width: 100%;
    margin-top: 2em;
  }
}
/* search-------------------- */
.page-title.search {
  background: var(--blue-color);
  color: var(--red-color);
}
.article-container.search {
  width: 100%;
}
