.page-fv-wrapper {
  position: relative;
}

.page-fv {
  height: 100px;
  position: relative;
}
@media (width >= 1440px) {
  .page-fv {
    max-width: 1600px;
    margin-inline: auto;
  }
}

.page-fv__list {
  display: none;
}
@media (width >= 1024px) {
  .page-fv__list {
    display: block;
    position: absolute;
    z-index: 5;
    top: 274px;
    right: 60px;
  }
}

.page-fv-box1,
.page-fv-box3,
.page-fv-box4,
.page-fv-box5,
.page-fv-box8 {
  position: absolute;
  z-index: 4;
  opacity: 0;
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
  will-change: opacity;
}
.page-fv-box1.is-no-animate,
.page-fv-box3.is-no-animate,
.page-fv-box4.is-no-animate,
.page-fv-box5.is-no-animate,
.page-fv-box8.is-no-animate {
  opacity: 1;
}

.page-fv-box1 stop,
.page-fv-box3 stop,
.page-fv-box4 stop,
.page-fv-box5 stop,
.page-fv-box8 stop {
  stop-color: currentColor;
}
.page-fv-box1 stop:nth-child(1),
.page-fv-box3 stop:nth-child(1),
.page-fv-box4 stop:nth-child(1),
.page-fv-box5 stop:nth-child(1),
.page-fv-box8 stop:nth-child(1) {
  stop-color: #ffa400;
}
.page-fv-box1 stop:nth-child(2),
.page-fv-box3 stop:nth-child(2),
.page-fv-box4 stop:nth-child(2),
.page-fv-box5 stop:nth-child(2),
.page-fv-box8 stop:nth-child(2) {
  stop-color: #ff9b00;
}
.page-fv-box1 stop:nth-child(3),
.page-fv-box3 stop:nth-child(3),
.page-fv-box4 stop:nth-child(3),
.page-fv-box5 stop:nth-child(3),
.page-fv-box8 stop:nth-child(3) {
  stop-color: #ff8200;
}
.page-fv-box1 stop:nth-child(4),
.page-fv-box3 stop:nth-child(4),
.page-fv-box4 stop:nth-child(4),
.page-fv-box5 stop:nth-child(4),
.page-fv-box8 stop:nth-child(4) {
  stop-color: #ff5a00;
}
.page-fv-box1 stop:nth-child(5),
.page-fv-box3 stop:nth-child(5),
.page-fv-box4 stop:nth-child(5),
.page-fv-box5 stop:nth-child(5),
.page-fv-box8 stop:nth-child(5) {
  stop-color: #ff2400;
}
.page-fv-box1 stop:nth-child(6),
.page-fv-box3 stop:nth-child(6),
.page-fv-box4 stop:nth-child(6),
.page-fv-box5 stop:nth-child(6),
.page-fv-box8 stop:nth-child(6) {
  stop-color: #ff0000;
}

.page-fv-box1 {
  display: none;
  top: 125px;
  left: clamp(333px, 5.381px + 87.365vw, 900px);
}
@media (width >= 1024px) {
  .page-fv-box1 {
    display: block;
    top: 234px;
    left: clamp(915px, -20.385px + 91.346vw, 1295px);
  }
}

.page-fv-box3 {
  top: 70px;
  left: clamp(108px, 0.529px + 28.659vw, 294px);
}
@media (width >= 1024px) {
  .page-fv-box3 {
    top: 92px;
    left: clamp(114px, 13.16vw, 214px);
  }
}

.page-fv-box4 {
  top: 65px;
  left: clamp(288px, -0.326px + 76.887vw, 787px);
}
@media (width >= 1024px) {
  .page-fv-box4 {
    top: 171px;
    left: clamp(590px, 76.78vw, 1107px);
  }
}

.page-fv-box5 {
  display: none;
  top: 16px;
  left: clamp(299px, -67.911px + 97.843vw, 934px);
}
@media (width >= 1024px) {
  .page-fv-box5 {
    display: block;
    top: 61px;
    left: clamp(934px, 45.711px + 86.747vw, 1149px);
  }
}

.page-fv-box8 {
  top: 125px;
  left: clamp(333px, 5.381px + 87.365vw, 900px);
}
@media (width >= 1024px) {
  .page-fv-box8 {
    top: 193px;
    left: clamp(221px, 18.55vw, 414px);
  }
}

.page-fv-exclamation2 {
  position: absolute;
  z-index: 4;
  opacity: 0;
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
  will-change: opacity;
}
.page-fv-exclamation2.is-no-animate {
  opacity: 1;
}

.page-fv-exclamation2 stop {
  stop-color: currentColor;
}
.page-fv-exclamation2 stop:nth-child(1) {
  stop-color: #ffb800;
}
.page-fv-exclamation2 stop:nth-child(2) {
  stop-color: #ffaf00;
}
.page-fv-exclamation2 stop:nth-child(3) {
  stop-color: #ff9600;
}
.page-fv-exclamation2 stop:nth-child(4) {
  stop-color: #ff9500;
}
.page-fv-exclamation2 stop:nth-child(5) {
  stop-color: #ff7a00;
}
.page-fv-exclamation2 stop:nth-child(6) {
  stop-color: #ff3700;
}
.page-fv-exclamation2 stop:nth-child(7) {
  stop-color: #ff0000;
}

.page-fv-exclamation2 {
  top: 111px;
  left: clamp(26px, 0.237px + 6.87vw, 53px);
}
@media (width >= 768px) {
  .page-fv-exclamation2 {
    top: 211px;
    left: clamp(53px, 4.34vw, 100px);
  }
}
.page-fv-exclamation2.--sp {
  display: block;
}
@media (width >= 1024px) {
  .page-fv-exclamation2.--sp {
    display: none;
  }
}
.page-fv-exclamation2.--pc {
  display: none;
}
@media (width >= 1024px) {
  .page-fv-exclamation2.--pc {
    display: block;
  }
}

/* Gradient background */

.gradient-bg-page {
  position: relative;
}

.gradient-bg-page__overlay {
  position: absolute;
  top: calc(20px + 27vw);
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(to right, #ffa505 0%, #ff1c01 100%);
  -webkit-mask-image: linear-gradient(
    to bottom,
    transparent 0%,
    #000 3%,
    #000 97%,
    transparent 100%
  );
  mask-image: linear-gradient(
    to bottom,
    transparent 0%,
    #000 3%,
    #000 97%,
    transparent 100%
  );
  z-index: -3;
  pointer-events: none;
}

.gradient-bg-page::before,
.gradient-bg-page::after {
  content: "";
  position: absolute;
  left: 50%;
  width: 150vw;
  min-width: 952px;
  height: auto;
  aspect-ratio: 952 / 341;
  overflow: hidden;
  background: url(../img/bg-sun-sp.webp) no-repeat center top / 100% auto;
  pointer-events: none;
  z-index: -5;
}

@media (width >= 1024px) {
  .gradient-bg-page::before,
  .gradient-bg-page::after {
    bottom: -15vw;
    width: 2114px;
    aspect-ratio: 2114 / 744;
    background: url(../img/bg-sun-pc.webp) no-repeat center top / 100% auto;
  }
}
@media (width >= 1600px) {
  .gradient-bg-page::before,
  .gradient-bg-page::after {
    width: 2914px;
    aspect-ratio: 2914 / 1025;
  }
}

.gradient-bg-page::before {
  transform: translateX(-50%);
}

.gradient-bg-page::after {
  transform: translateX(-50%) scaleY(-1);
}

/* ----------------------------------------
   Page: About
   ---------------------------------------- */
.gradient-bg-page--about::before {
  top: 0.5vw;
}
.gradient-bg-page--about::after {
  bottom: -40vw;
}

@media (width >= 480px) {
  .gradient-bg-page--about::after {
    bottom: -30vw;
  }
}

@media (width >= 768px) {
  .gradient-bg-page--about::after {
    bottom: -23vw;
  }
}
@media (width >= 1024px) {
  .gradient-bg-page--about::after {
    bottom: -16vw;
  }
}
@media (width >= 1600px) {
  .gradient-bg-page--about::after {
    bottom: -13vw;
  }
}

/* ----------------------------------------
   Page: Service
   ---------------------------------------- */
.gradient-bg-page--service::before {
  top: 2.5vw;
}
.gradient-bg-page--service::after {
  bottom: -21vw;
}
@media (width >= 1024px) {
  .gradient-bg-page--service::after {
    bottom: -24vw;
  }
}

/* ----------------------------------------
   Sidebar 共通（home.php / single.php）
   ---------------------------------------- */
.sidebar {
  width: 100%;
  max-width: 400px;
  margin-inline: auto;
}
@media (width >= 768px) {
  .sidebar--single {
    width: 25.8064516%;
    margin-left: 0;
    margin-right: 0;
    max-width: none;
  }
  .sidebar--home {
    width: 26.6666667%;
    margin-left: 0;
    margin-right: 0;
    max-width: none;
  }
}

.sidebar__list {
  display: flex;
  flex-direction: column;
}
@media (width >= 1024px) {
  .sidebar__list {
  }
}

.sidebar__title {
  position: relative;
  font-family: var(--ff-zen-kaku-gothic-new);
  font-weight: 700;
  font-size: 2rem;
  line-height: 1.5;
  letter-spacing: 0;
  color: var(--color-black);
  padding-left: 25px;
  text-align: left;
}
@media (width >= 1024px) {
  .sidebar__title {
    font-size: 2.4rem;
  }
}

.sidebar__title::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 11px;
  height: 11px;
  background: linear-gradient(
    to right,
    #ffa400 0%,
    #ff9b00 12%,
    #ff8200 31%,
    #ff5a00 55%,
    #ff2400 83%,
    #ff0000 100%
  );
}

.sidebar__item + .sidebar__item {
  margin-top: 30px;
}
@media (width >= 1024px) {
  .sidebar__item + .sidebar__item {
    margin-top: 55px;
  }
}

.sidebar__item-sns,
.sidebar__service-link {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity 0.3s ease;
  position: relative;
}

.sidebar__service-link {
  border-radius: 10px;
  border: 10px solid #ff2801;
}

.sidebar__service-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: max-content;
  max-width: calc(100% - 24px);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.sidebar__service-title {
  font-family: var(--ff-montserrat);
  font-weight: 700;
  font-size: 25px;
  line-height: 1.2;
  letter-spacing: 0.1em;
  color: #fff;
  position: relative;
  padding-right: 25px;
}

.sidebar__service-title::after {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  content: "";
  width: 18px;
  height: 18px;
  background-image: url(../img/icon_new_tab.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

.sidebar__service-description {
  font-family: var(--ff-zen-kaku-gothic-new);
  font-weight: 700;
  font-size: 16px;
  line-height: 1.5;
  color: #fff;
}

.sidebar__item-sns img,
.sidebar__service-link img {
  width: 100%;
  height: auto;
  display: block;
}

.sidebar__service-link img {
  aspect-ratio: 320 / 167;
  object-fit: cover;
}

.sidebar__item-sns:first-of-type {
  margin-top: 15px;
}
@media (width >= 1024px) {
  .sidebar__item-sns:first-of-type {
    margin-top: 22px;
  }
}

.sidebar__item-list {
  margin-top: 15px;
}
@media (width >= 1024px) {
  .sidebar__item-list {
    margin-top: 30px;
  }
}

.sidebar__item-service + .sidebar__item-service {
  margin-top: 15px;
}
@media (width >= 1024px) {
  .sidebar__item-service + .sidebar__item-service {
    margin-top: 24px;
  }
}

@media (any-hover: hover) {
  .sidebar__item-sns:hover,
  .sidebar__service-link:hover {
    cursor: pointer;
    opacity: 0.7;
  }
}

/* ----------------------------------------
   Sidebar: 関連ニュース（single.php のみ）
   ---------------------------------------- */
.sidebar__news-list {
  display: flex;
  flex-direction: column;
  margin-top: 20px;
}
@media (width >= 1024px) {
  .sidebar__news-list {
    margin-top: 28px;
  }
}
.sidebar__news-item + .sidebar__news-item {
  margin-top: 20px;
}
@media (width >= 1024px) {
  .sidebar__news-item + .sidebar__news-item {
    margin-top: 20px;
  }
}

.sidebar__news-link {
  display: block;
  transition: opacity 0.3s ease;
}
@media (any-hover: hover) {
  .sidebar__news-link:hover {
    opacity: 0.7;
  }
}

.sidebar__news-date {
  display: block;
  font-family: var(--ff-montserrat);
  font-weight: 600;
  font-size: 1.3rem;
  line-height: 1.5;
  color: var(--color-gray);
  font-feature-settings: "palt";
  letter-spacing: -0.04em;
}
@media (width >= 1024px) {
  .sidebar__news-date {
    font-size: 1.6rem;
  }
}

.sidebar__news-wrap {
  margin-top: 4px;
}
@media (width >= 1024px) {
  .sidebar__news-wrap {
    margin-top: 6px;
  }
}

.sidebar__news-category {
  width: auto;
  min-width: 80px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--color-red);
  font-family: var(--ff-zen-kaku-gothic-new);
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.1;
  white-space: nowrap;
  border: 1px solid var(--color-red);
  border-radius: 32px;
  padding: 1px 8px;
  background-color: var(--color-cream);
}
@media (width >= 1024px) {
  .sidebar__news-category {
    min-width: 94px;
    font-size: 1.4rem;
    padding: 2px 10px;
  }
}

.sidebar__news-category::before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 0 5px 8px;
  border-color: transparent transparent transparent var(--color-red);
}

.sidebar__news-body {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-top: 6px;
}
@media (width >= 1024px) {
  .sidebar__news-body {
    margin-top: 8px;
  }
}

.sidebar__news-thumb {
  flex-shrink: 0;
  width: 36.5625%;
}

.sidebar__news-thumb img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 2px;
}

.sidebar__news-title {
  width: 60.3125%;
  font-family: var(--ff-zen-kaku-gothic-new);
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.8;
  color: var(--color-black);
  margin-left: auto;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
@media (width >= 1024px) {
  .sidebar__news-title {
    font-size: 1.5rem;
  }
}