/* ===================================
    Crafto - Consulting
====================================== */
/* font */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Kumbh+Sans:wght@100;200;300;400;500;600;700;800;900&display=swap');
/* variable */
:root {     
    --base-color: #25856f;
    --dark-gray: #292d36;
    --medium-gray: #808291;
    --primary-font: "Zen Maru Gothic", serif;
    --alt-font: "Zen Maru Gothic", serif;
}
/* reset */
body {
    font-size: 17px;
    line-height: 30px; 
}
a {
    color: #808291;
}
/* bg gradient color */
.bg-gradient-black-dark-orange {
    background-image: linear-gradient(to right top, #353332, #312b28, #15110f, #4a3229, #5a2611);
}
.bg-gradient-dark-orange-transparent { 
    background-image: linear-gradient(to right top, rgba(212, 110, 66,.8), rgba(197, 105, 66,.8), rgba(184, 101, 66,.8), rgba(158, 93, 67,.8), rgba(111, 80, 70,.8));
}
/* header */
.header-icon .icon > a {
    font-size: 20px;
}
.navbar .navbar-nav .nav-link {
    font-weight: 400;
    font-size: 18px;
    letter-spacing: .5px;
}
.navbar .navbar-nav .dropdown .dropdown-menu a {
    font-size: 16px;
    line-height: 28px;
}
.push-menu {
    width: 400px;
}
header .navbar-brand img {
    max-height: 35px;
}
.navbar .navbar-nav .simple-dropdown .dropdown-menu {
    border-radius: 5px;
}
.navbar .navbar-nav .simple-dropdown .dropdown-menu li a {
    padding: 9px 0 11px;
    border-bottom: 1px solid var(--light-medium-gray);
}
.navbar .navbar-nav .simple-dropdown .dropdown-menu li:first-child a {
    padding-top: 0;
}
.navbar .navbar-nav .simple-dropdown .dropdown-menu li:last-child a {
    border: 0;
    padding-bottom: 0;
}
.push-menu .close-menu {
    right: 30px;
    top: 30px;
}
/* typography */
h1 {
    line-height: 4.5rem;
}
/* subcribe style 02 */
.newsletter-style-02 .btn {
    padding: 7px 18px 9px 18px;
}
/* footer */
footer .input-small, footer .textarea-small {
    font-size: 15px;
    padding-left: 20px;
}
footer .footer-logo img {
    max-height: 35px;
}
/* page title */
.page-title-extra-small h1 {
    font-size: 22px;
    line-height: 32px;
}
/* subcribe style 02 */
.newsletter-style-02 input {
    padding-right: 65px;
}
/* media query responsive */
@media (max-width: 1199px) {
    .newsletter-style-02 input {
        padding-left: 15px;
    }
}
@media (max-width: 991px) {
    .navbar .navbar-nav .simple-dropdown .dropdown-menu {
        margin-top: 15px;
    }
}
@media (max-width: 767px) {
    .page-title-extra-small h1 {
        font-size: 20px;
        line-height: 28px;
    }
    .process-step-style-02 .progress-step-separator {
        display: block;
    }
}
@media (max-width: 575px) {
    .process-step-style-02 .progress-step-separator {
        display: none;
    }
}



            .recruitment-table {
                width: 100%;
                border-collapse: collapse;
                margin-bottom: 30px;
            }
            .recruitment-table th, .recruitment-table td {
                border: 1px solid #e0e0e0;
                padding: 15px;
                text-align: left;
                vertical-align: top;
            }
            .recruitment-table th {
                background-color: #f9f9f9;
                width: 25%;
                font-weight: 600;
                font-size: 18px;
            }
            .recruitment-table td {
                font-size: 16px;
            }
            @media (max-width: 767px) {
                .recruitment-table, .recruitment-table tbody, .recruitment-table tr, .recruitment-table td, .recruitment-table th {
                    display: block;
                    width: 100%;
                }
                .recruitment-table th {
                    background-color: transparent;
                    padding-top: 20px;
                }
                .recruitment-table th:first-child {
                    padding-top: 0;
                }
                .recruitment-table td {
                    padding-bottom: 20px;
                }
            }

.white-txt {
    color: #ffffff;
}



.company-table {
 width: 100%;
 text-align: center;
 border-collapse: collapse;
 border-spacing: 0;
}
.company-table th {
 padding: 10px;
 border-bottom: solid 4px #778ca3;
 color: #778ca3
}
.company-table td {
 padding: 10px;
 border-bottom: solid 1px #778ca3;
}




/* 全て .my-history-section 内に限定する */
.my-history-section {
  /* 必要であればセクション全体のスタイルをここで */
}

.my-history-section .my-history-container {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 40px 20px;
  box-sizing: border-box;
}

.my-history-section .section-title {
  font-size: 1.8rem;
  margin-bottom: 30px;
  font-weight: 700;
  position: relative;
  color: #333;
  text-align: center;
}

.my-history-section .section-title::after {
  content: "";
  display: block;
  width: 60px;
  height: 3px;
  background: #26856F;
  margin: 10px auto 0 auto;
}

.my-history-section .timeline {
  position: relative;
  padding: 40px 0;
}

.my-history-section .timeline::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 2px;
  background: #e0e0e0;
  transform: translateX(-50%);
}

.my-history-section .timeline-item {
  display: flex;
  margin-bottom: 50px;
  position: relative;
  align-items: flex-start;
}

.my-history-section .timeline-item.reverse {
  flex-direction: row-reverse;
}

.my-history-section .timeline-icon {
  width: 20px;
  height: 20px;
  background: #26856F;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

.my-history-section .timeline-content {
  background: #fff;
  padding: 20px;
  border-radius: 8px;
  width: 45%;
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
  position: relative;
}

.my-history-section .timeline-item:not(.reverse) .timeline-content {
  margin-right: auto;
  margin-left: calc(50% + 30px);
}

.my-history-section .timeline-item.reverse .timeline-content {
  margin-left: auto;
  margin-right: calc(50% + 30px);
}

.my-history-section .timeline-date {
  display: inline-block;
  background: #26856F;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 999px;
  margin-bottom: 10px;
}

.my-history-section .timeline-content h3 {
  font-size: 1.4rem;
  margin-top: 0;
  margin-bottom: 15px;
  color: #333;
  font-weight: 700;
}

.my-history-section .timeline-content p,
.my-history-section .timeline-content ul {
  margin-bottom: 0;
  line-height: 1.7;
  font-size: 1rem;
}

.my-history-section .timeline-content ul {
  padding-left: 20px;
  list-style: disc;
  margin-top: 15px;
}

.my-history-section .history {
  margin-top: 80px;
}

.my-history-section .history-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.my-history-section .history-list li {
  background: #fff;
  border-left: 4px solid #26856F;
  padding: 10px 15px;
  margin-bottom: 15px;
  border-radius: 4px;
  position: relative;
}

.my-history-section .year {
  display: inline-block;
  font-weight: 700;
  margin-right: 10px;
  color: #26856F;
}

.my-history-section .tradition {
  margin-top: 80px;
  background: #fff;
  border-radius: 8px;
  padding: 40px;
  box-sizing: border-box;
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}

.my-history-section .tradition p {
  font-size: 1rem;
  margin-bottom: 20px;
}

/* スマートフォン表示対応 */
@media screen and (max-width: 768px) {
  .my-history-section .timeline::before {
    content: none; /* スマホでは中央線削除 */
  }

  .my-history-section .timeline-item {
    flex-direction: column;
    margin-bottom: 40px;
    align-items: flex-start; 
    position: relative;
  }

  .my-history-section .timeline-item.reverse {
    flex-direction: column; 
  }

  .my-history-section .timeline-icon {
    position: static;
    transform: none;
    margin-bottom: 10px;
    left: auto;
  }

  .my-history-section .timeline-content {
    width: 100%;
    margin: 0;
  }

  .my-history-section .timeline-item:not(.reverse) .timeline-content,
  .my-history-section .timeline-item.reverse .timeline-content {
    margin: 0; /* スマホ時は左右マージンなし */
  }

  .my-history-section .timeline-date {
    margin-bottom: 10px;
  }
}



/*
.infomation-list li a:hover {
  filter: alpha(opacity=50);
  opacity: 0.50;
}
@media (max-width: 540px) {
.infomation-list li a span {
  display: block;
}
}

*/



.infomation-list {
  background: #f8fafc; /* 淡い背景で清潔感を */
  border-radius: 8px;
  padding: 20px;
/*  font-family: "Helvetica Neue", Arial, sans-serif;*/
  max-width: 600px; 
  margin: 0 auto; /* コンテンツ幅を整え中央揃え */
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05); /* 柔らかなシャドウ */
}

.infomation-list ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.infomation-list li {
  padding: 12px 0;
  border-bottom: 1px solid #e2e8f0; /* 淡いグレーの下線で整列感 */
}

.infomation-list li:last-child {
  border-bottom: none;
}

.infomation-list li a {
  display: inline-block;
  text-decoration: none;
  color: #333;
  transition: color 0.3s ease, transform 0.3s ease;
  font-weight: 400;
  line-height: 1.5;
}

.infomation-list li a span {
  font-size: 0.85em;
  color: #666;
  margin-right: 8px;
  display: inline-block;
  font-weight: 500;
}

/* ホバー時は軽やかなアニメーションとカラー変化 */
.infomation-list li a:hover {
  color: #007acc;
  transform: translateX(4px);
  text-decoration: underline;
}

/* モバイル対応：日付をブロック表示して整列 */
@media (max-width: 540px) {
  .infomation-list li a span {
    display: block;
    margin-bottom: 4px;
  }
  
  /* モバイルではホバーアニメーション簡略化（タップ操作想定） */
  .infomation-list li a:hover {
    transform: none;
  }
}



.cleaning-info {
  color: #333;
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 20px;
  box-sizing: border-box;
}

.cleaning-info-title {
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  position: relative;
  margin-bottom: 50px;
  color: #333;
}

.cleaning-info-title::after {
  content: "";
  display: block;
  width: 80px;
  height: 3px;
  background: #26856F;
  margin: 10px auto 0;
}

.cleaning-info-cards {
  display: flex;
  justify-content: space-between;
  gap: 30px;
  flex-wrap: wrap;
}

.cleaning-info-card {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  padding: 30px;
  flex: 1 1 calc(33% - 30px);
  min-width: 280px;
  box-sizing: border-box;
  border-top: 6px solid #26856F;
}

.cleaning-info-card h3 {
  font-size: 1.4rem;
  margin-top: 0;
  margin-bottom: 20px;
  color: #26856F;
  font-weight: bold;
}

.cleaning-info-card p {
  line-height: 1.8;
  font-size: 1rem;
  margin-bottom: 20px;
}

.cleaning-info-card .highlight {
  color: #26856F;
  font-weight: bold;
}

@media screen and (max-width: 768px) {
  .cleaning-info-cards {
    flex-direction: column;
  }
  
  .cleaning-info-card {
    flex: 1 1 100%;
    margin-bottom: 20px;
  }

  .cleaning-info-card:last-child {
    margin-bottom: 0;
  }
}


.pickup-info {
  color: #333;
  max-width: 1000px;
  margin: 0 auto;
  padding: 40px 20px;
  box-sizing: border-box;
}

.pickup-info-title {
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  position: relative;
  margin-bottom: 50px;
  color: #333;
}

.pickup-info-title::after {
  content: "";
  display: block;
  width: 80px;
  height: 3px;
  background: #26856F;
  margin: 10px auto 0;
}

.pickup-info-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  justify-content: space-between;
}

.pickup-info-box {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  padding: 30px;
  flex: 1 1 calc(50% - 30px);
  min-width: 280px;
  box-sizing: border-box;
  border-top: 6px solid #26856F;
}

.pickup-info-box h3 {
  font-size: 1.4rem;
  margin-top: 0;
  margin-bottom: 20px;
  color: #26856F;
  font-weight: bold;
}

.pickup-info-box p {
  line-height: 1.8;
  font-size: 1rem;
  margin-bottom: 20px;
}

.pickup-info-box .highlight {
  color: #26856F;
  font-weight: bold;
}

@media screen and (max-width: 768px) {
  .pickup-info-wrapper {
    flex-direction: column;
  }

  .pickup-info-box {
    flex: 1 1 100%;
    margin-bottom: 20px;
  }

  .pickup-info-box:last-child {
    margin-bottom: 0;
  }
}



.customer-request {
  color: #333;
  max-width: 1000px;
  margin: 0 auto;
  padding: 40px 20px;
  box-sizing: border-box;
}

.customer-request-title {
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 50px;
  position: relative;
  color: #333;
}

.customer-request-title::after {
  content: "";
  display: block;
  width: 80px;
  height: 3px;
  background: #26856F;
  margin: 10px auto 0;
}

.customer-request-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 30px;
}

.customer-request-item {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  padding: 30px;
  border-top: 6px solid #26856F;
  box-sizing: border-box;
}

.customer-request-item h3 {
  font-size: 1.2rem;
  margin-top: 0;
  margin-bottom: 20px;
  color: #26856F;
  font-weight: bold;
  line-height: 1.4;
}

.customer-request-item p {
  line-height: 1.8;
  font-size: 1rem;
  margin: 0;
}

@media screen and (max-width: 768px) {
  .customer-request {
    padding: 20px;
  }

  .customer-request-title {
    font-size: 1.5rem;
  }

  .customer-request-grid {
    grid-template-columns: 1fr;
  }

  .customer-request-item {
    padding: 20px;
  }

  .customer-request-item h3 {
    font-size: 1.2rem;
  }

  .customer-request-item p {
    font-size: 0.95rem;
  }
}



.membership-offer {
  color: #333;
  background: #f7f7f7;
  padding: 40px 20px;
  max-width: 800px;
  margin: 0 auto;
  box-sizing: border-box;
  border-radius: 8px;
}

.membership-offer-title {
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
  color: #26856F;
  margin: 0;
  margin-bottom: 10px;
  position: relative;
}

.membership-offer-sub {
  text-align: center;
  font-size: 1rem;
  color: #555;
  margin-bottom: 40px;
}

.membership-offer-content {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  justify-content: center;
}

.membership-offer-box {
  background: #fff;
  border: 1px solid #eaeaea;
  border-radius: 8px;
  padding: 30px;
  box-sizing: border-box;
  width: 300px;
  text-align: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

.membership-offer-box h3 {
  font-size: 1.3rem;
  margin-top: 0;
  margin-bottom: 20px;
  font-weight: 700;
  color: #26856F;
}

.membership-offer-box p {
  margin: 10px 0;
  line-height: 1.8;
  font-size: 1rem;
}

.highlight {
  color: #26856F;
  font-weight: bold;
}

.big-discount {
  color: #26856F;
  font-weight: 700;
  font-size: 1.2rem;
}

@media screen and (max-width: 600px) {
  .membership-offer-content {
    flex-direction: column;
    align-items: center;
  }

  .membership-offer-box {
    width: 100%;
    max-width: 300px;
  }
}



.rainbow {
  height: 100vh;
  width: 0;
  top: 0;
  position: absolute;
  transform: rotate(10deg);
  transform-origin: top right;
}
.rainbow:nth-child(1) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #5eead4, 0 0 50px 25px #e879f9, 50px 0 50px 25px #60a5fa, 130px 0 80px 40px white;
  animation: 44.1s linear infinite slide;
  animation-delay: -1.8s;
}
.rainbow:nth-child(2) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #5eead4, 0 0 50px 25px #60a5fa, 50px 0 50px 25px #e879f9, 130px 0 80px 40px white;
  animation: 43.2s linear infinite slide;
  animation-delay: -3.6s;
}
.rainbow:nth-child(3) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #60a5fa, 0 0 50px 25px #e879f9, 50px 0 50px 25px #5eead4, 130px 0 80px 40px white;
  animation: 42.3s linear infinite slide;
  animation-delay: -5.4s;
}
.rainbow:nth-child(4) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #60a5fa, 0 0 50px 25px #5eead4, 50px 0 50px 25px #e879f9, 130px 0 80px 40px white;
  animation: 41.4s linear infinite slide;
  animation-delay: -7.2s;
}
.rainbow:nth-child(5) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #60a5fa, 0 0 50px 25px #e879f9, 50px 0 50px 25px #5eead4, 130px 0 80px 40px white;
  animation: 40.5s linear infinite slide;
  animation-delay: -9s;
}
.rainbow:nth-child(6) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #5eead4, 0 0 50px 25px #e879f9, 50px 0 50px 25px #60a5fa, 130px 0 80px 40px white;
  animation: 39.6s linear infinite slide;
  animation-delay: -10.8s;
}
.rainbow:nth-child(7) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #e879f9, 0 0 50px 25px #5eead4, 50px 0 50px 25px #60a5fa, 130px 0 80px 40px white;
  animation: 38.7s linear infinite slide;
  animation-delay: -12.6s;
}
.rainbow:nth-child(8) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #5eead4, 0 0 50px 25px #e879f9, 50px 0 50px 25px #60a5fa, 130px 0 80px 40px white;
  animation: 37.8s linear infinite slide;
  animation-delay: -14.4s;
}
.rainbow:nth-child(9) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #e879f9, 0 0 50px 25px #5eead4, 50px 0 50px 25px #60a5fa, 130px 0 80px 40px white;
  animation: 36.9s linear infinite slide;
  animation-delay: -16.2s;
}
.rainbow:nth-child(10) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #e879f9, 0 0 50px 25px #5eead4, 50px 0 50px 25px #60a5fa, 130px 0 80px 40px white;
  animation: 36s linear infinite slide;
  animation-delay: -18s;
}
.rainbow:nth-child(11) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #5eead4, 0 0 50px 25px #e879f9, 50px 0 50px 25px #60a5fa, 130px 0 80px 40px white;
  animation: 35.1s linear infinite slide;
  animation-delay: -19.8s;
}
.rainbow:nth-child(12) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #5eead4, 0 0 50px 25px #60a5fa, 50px 0 50px 25px #e879f9, 130px 0 80px 40px white;
  animation: 34.2s linear infinite slide;
  animation-delay: -21.6s;
}
.rainbow:nth-child(13) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #60a5fa, 0 0 50px 25px #5eead4, 50px 0 50px 25px #e879f9, 130px 0 80px 40px white;
  animation: 33.3s linear infinite slide;
  animation-delay: -23.4s;
}
.rainbow:nth-child(14) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #60a5fa, 0 0 50px 25px #e879f9, 50px 0 50px 25px #5eead4, 130px 0 80px 40px white;
  animation: 32.4s linear infinite slide;
  animation-delay: -25.2s;
}
.rainbow:nth-child(15) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #e879f9, 0 0 50px 25px #60a5fa, 50px 0 50px 25px #5eead4, 130px 0 80px 40px white;
  animation: 31.5s linear infinite slide;
  animation-delay: -27s;
}
.rainbow:nth-child(16) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #e879f9, 0 0 50px 25px #5eead4, 50px 0 50px 25px #60a5fa, 130px 0 80px 40px white;
  animation: 30.6s linear infinite slide;
  animation-delay: -28.8s;
}
.rainbow:nth-child(17) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #60a5fa, 0 0 50px 25px #e879f9, 50px 0 50px 25px #5eead4, 130px 0 80px 40px white;
  animation: 29.7s linear infinite slide;
  animation-delay: -30.6s;
}
.rainbow:nth-child(18) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #e879f9, 0 0 50px 25px #60a5fa, 50px 0 50px 25px #5eead4, 130px 0 80px 40px white;
  animation: 28.8s linear infinite slide;
  animation-delay: -32.4s;
}
.rainbow:nth-child(19) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #60a5fa, 0 0 50px 25px #e879f9, 50px 0 50px 25px #5eead4, 130px 0 80px 40px white;
  animation: 27.9s linear infinite slide;
  animation-delay: -34.2s;
}
.rainbow:nth-child(20) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #60a5fa, 0 0 50px 25px #e879f9, 50px 0 50px 25px #5eead4, 130px 0 80px 40px white;
  animation: 27s linear infinite slide;
  animation-delay: -36s;
}
.rainbow:nth-child(21) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #5eead4, 0 0 50px 25px #e879f9, 50px 0 50px 25px #60a5fa, 130px 0 80px 40px white;
  animation: 26.1s linear infinite slide;
  animation-delay: -37.8s;
}
.rainbow:nth-child(22) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #5eead4, 0 0 50px 25px #e879f9, 50px 0 50px 25px #60a5fa, 130px 0 80px 40px white;
  animation: 25.2s linear infinite slide;
  animation-delay: -39.6s;
}
.rainbow:nth-child(23) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #60a5fa, 0 0 50px 25px #e879f9, 50px 0 50px 25px #5eead4, 130px 0 80px 40px white;
  animation: 24.3s linear infinite slide;
  animation-delay: -41.4s;
}
.rainbow:nth-child(24) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #5eead4, 0 0 50px 25px #60a5fa, 50px 0 50px 25px #e879f9, 130px 0 80px 40px white;
  animation: 23.4s linear infinite slide;
  animation-delay: -43.2s;
}
.rainbow:nth-child(25) {
  box-shadow: -130px 0 80px 40px white, -50px 0 50px 25px #e879f9, 0 0 50px 25px #5eead4, 50px 0 50px 25px #60a5fa, 130px 0 80px 40px white;
  animation: 22.5s linear infinite slide;
  animation-delay: -45s;
}

@keyframes slide {
  from {
    right: -25vw;
  }
  to {
    right: 125vw;
  }
}
.h {
  box-shadow: 0 0 50vh 40vh white;
  width: 100vw;
  height: 0;
  bottom: 0;
  left: 0;
  position: absolute;
}

.v {
  box-shadow: 0 0 35vw 25vw white;
  width: 0;
  height: 100vh;
  bottom: 0;
  left: 0;
  position: absolute;
}

.description-container {
  position: absolute;
  bottom: 32px;
  left: 32px;
  text-align: left;
  letter-spacing: 3px;
}
.description-container .title {
  font-size: 19px;
  font-weight: 500;
  color: black;
  text-transform: uppercase;
}
.description-container .subtitle {
  margin-top: 6px;
  font-size: 26px;
  font-weight: 500;
  color: black;
  text-transform: uppercase;
}

.author-container {
  position: absolute;
  width: 50%;
  right: 21px;
  bottom: 21px;
  text-align: right;
}
.author-container .picture {
  position: absolute;
  right: 0;
  top: -42px;
  margin-top: -12px;
  width: 42px;
  height: 42px;
  background-size: 42px;
  background-position: center;
  background-repeat-style: "no-repeat";
  background-image: url(https://assets.codepen.io/595576/internal/avatars/users/default.png?format=auto&version=1689877807&width=80&height=80);
}
.author-container .title {
  font-size: 16px;
  letter-spacing: 2px;
  color: black;
}



.bubbles {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: hidden;
  z-index: 1; /* 背面に配置 */
}

.bubble {
  position: absolute;
  left: var(--bubble-left-offset);
  bottom: -75%;
  display: block;
  width: var(--bubble-radius);
  height: var(--bubble-radius);
  border-radius: 50%;
  animation: float-up var(--bubble-float-duration) var(--bubble-float-delay) ease-in infinite;
}

.bubble::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--bubble-color);
  border-radius: inherit;
  animation: var(--bubble-sway-type) var(--bubble-sway-duration) var(--bubble-sway-delay) ease-in-out alternate infinite;
}

/* 以下、10個のバブルをパステルカラーで設定例(色やパラメータは好みで調整可能) */
.bubble:nth-child(1) {
  --bubble-left-offset: 5vw;
  --bubble-radius: 8vw;
  --bubble-float-duration: 10s;
  --bubble-sway-duration: 6s;
  --bubble-float-delay: 0s;
  --bubble-sway-delay: 0s;
  --bubble-sway-type: sway-left-to-right;
  --bubble-color: rgba(255, 183, 197, 0.3); /* パステルピンク */
}
.bubble:nth-child(2) {
  --bubble-left-offset: 20vw;
  --bubble-radius: 6vw;
  --bubble-float-duration: 12s;
  --bubble-sway-duration: 5s;
  --bubble-float-delay: 1s;
  --bubble-sway-delay: 2s;
  --bubble-sway-type: sway-right-to-left;
  --bubble-color: rgba(255, 223, 186, 0.3); /* パステルオレンジ */
}
.bubble:nth-child(3) {
  --bubble-left-offset: 40vw;
  --bubble-radius: 10vw;
  --bubble-float-duration: 11s;
  --bubble-sway-duration: 6s;
  --bubble-float-delay: 2s;
  --bubble-sway-delay: 1s;
  --bubble-sway-type: sway-left-to-right;
  --bubble-color: rgba(255, 243, 191, 0.3); /* パステルイエロー */
}
.bubble:nth-child(4) {
  --bubble-left-offset: 60vw;
  --bubble-radius: 4vw;
  --bubble-float-duration: 9s;
  --bubble-sway-duration: 5s;
  --bubble-float-delay: 1s;
  --bubble-sway-delay: 3s;
  --bubble-sway-type: sway-right-to-left;
  --bubble-color: rgba(186, 255, 201, 0.3); /* パステルグリーン */
}
.bubble:nth-child(5) {
  --bubble-left-offset: 80vw;
  --bubble-radius: 7vw;
  --bubble-float-duration: 10s;
  --bubble-sway-duration: 6s;
  --bubble-float-delay: 0s;
  --bubble-sway-delay: 0s;
  --bubble-sway-type: sway-left-to-right;
  --bubble-color: rgba(183, 255, 234, 0.3); /* パステルアクア */
}
.bubble:nth-child(6) {
  --bubble-left-offset: 15vw;
  --bubble-radius: 9vw;
  --bubble-float-duration: 8s;
  --bubble-sway-duration: 4s;
  --bubble-float-delay: 3s;
  --bubble-sway-delay: 2s;
  --bubble-sway-type: sway-left-to-right;
  --bubble-color: rgba(201, 186, 255, 0.3); /* パステルパープル */
}
.bubble:nth-child(7) {
  --bubble-left-offset: 35vw;
  --bubble-radius: 5vw;
  --bubble-float-duration: 12s;
  --bubble-sway-duration: 5s;
  --bubble-float-delay: 1s;
  --bubble-sway-delay: 4s;
  --bubble-sway-type: sway-right-to-left;
  --bubble-color: rgba(255, 201, 255, 0.3); /* パステルピンク(薄め) */
}
.bubble:nth-child(8) {
  --bubble-left-offset: 55vw;
  --bubble-radius: 3vw;
  --bubble-float-duration: 9s;
  --bubble-sway-duration: 6s;
  --bubble-float-delay: 2s;
  --bubble-sway-delay: 1s;
  --bubble-sway-type: sway-left-to-right;
  --bubble-color: rgba(210, 230, 255, 0.3); /* パステルブルー */
}
.bubble:nth-child(9) {
  --bubble-left-offset: 75vw;
  --bubble-radius: 8vw;
  --bubble-float-duration: 11s;
  --bubble-sway-duration: 4s;
  --bubble-float-delay: 4s;
  --bubble-sway-delay: 1s;
  --bubble-sway-type: sway-right-to-left;
  --bubble-color: rgba(230, 255, 210, 0.3); /* パステルグリーン(薄) */
}
.bubble:nth-child(10) {
  --bubble-left-offset: 90vw;
  --bubble-radius: 5vw;
  --bubble-float-duration: 10s;
  --bubble-sway-duration: 5s;
  --bubble-float-delay: 3s;
  --bubble-sway-delay: 0s;
  --bubble-sway-type: sway-left-to-right;
  --bubble-color: rgba(255, 210, 230, 0.3); /* パステルピンクより赤み有 */
}

/* アニメーションはそのまま */
@keyframes float-up {
  to {
    transform: translateY(-175vh);
  }
}
@keyframes sway-left-to-right {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(100%);
  }
}
@keyframes sway-right-to-left {
  from {
    transform: translateX(100%);
  }
  to {
    transform: translateX(-100%);
  }
}


  .main-visual {
    display: flex;
    align-items: center;
    justify-content: center;
    
    
    text-align: center;
    flex-direction: column;
  }

  .main-visual .top-text {
/*    font-family: 'Arial', sans-serif;*/
    font-size: 3rem;
    font-weight: 700;
    color: #4caefd; /* 青よりの色 */
    position: relative;
    -webkit-text-stroke: 1px #fff;
    text-shadow:
      -1px -1px 0 #fff,
       1px -1px 0 #fff,
      -1px  1px 0 #fff,
       1px  1px 0 #fff;
    letter-spacing: 0.15em;
    margin: 0;
  }

  .main-visual .taguchi {
font-family: "Mochiy Pop P One", sans-serif;
    font-size: 6rem;
    font-weight: 900;
    color: #ff4f58; /* 赤色 */
    line-height: 1;
    margin: 0.2em 0 0;
    /* 白縁取り */
    -webkit-text-stroke: 2px #fff;
    text-shadow:
      -2px -2px 0 #fff,
       2px -2px 0 #fff,
      -2px  2px 0 #fff,
       2px  2px 0 #fff;
  }



.mochiy-pop-p-one-regular {
  font-family: "Mochiy Pop P One", sans-serif;
  font-weight: 400;
  font-style: normal;
}



/* h2 タイトル部分のスタイリング変更例 */
h2.text-dark-gray {
  /* ベースとなるフォントは元々指定済み */
  font-weight: 600;
  font-family: var(--alt-font, sans-serif);

  /* テキストカラーをグラデーションで表現 */
  background: linear-gradient(to right, #a5e8d3, #26856F, #c1eddb);
  -webkit-background-clip: text;
  color: transparent;

  /* わずかなシャドウで白背景でも視認性アップ */
  text-shadow: 0 1px 1px rgba(0,0,0,0.1);

  /* 文字のラインハイトや余白は既存調整 */
  line-height: 1.3;
  margin-bottom: 25px;
}

/* 必要なら微調整（例：全体的なフォントサイズ調整など）
h2.alt-font.fw-600.text-dark-gray.ls-minus-2px.mb-25px {
  font-size: 2rem;
  letter-spacing: -0.5px;
}
*/



.cover-background2 {
  position: relative;
  /* パステル調かつブランド感を残したグラデーション */
  background: linear-gradient(135deg, #c8e6db, #a4d6c8, #72c7ad, #26856F);
  background-size: 200% 200%;
  animation: pastelGradient 12s ease-in-out infinite alternate;
  overflow: hidden;
  z-index: 0;
}

/* ゆっくりと背景グラデーションを動かす */
@keyframes pastelGradient {
  0% { background-position: 0% 50%; }
  100% { background-position: 100% 50%; }
}

/* 波のレイヤー：白いグラデーションをマスクで波形に切り抜き、水平移動 */
.cover-background2::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 200%; height: 200%;
  /* 下記SVGは白→透明のグラデーションをマスクするためのwave形状。
     色はマスクには影響しないが、URLエンコード済みSVGでwaveパスを定義。
     mask-imageでこの波形を適用し、背景のグラデを波形でくり抜く感じ。 */
  background: linear-gradient(to bottom, rgba(255,255,255,0.6), rgba(255,255,255,0));
  mask-image: url("data:image/svg+xml,%3Csvg width='1600' height='900' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0,300 C300,400 1300,100 1600,300 L1600,900 L0,900 Z' fill='black'/%3E%3C/svg%3E");
  mask-repeat: no-repeat;
  mask-size: cover;
  mask-position: center;
  
  /* 軽くブレンドモードで背景となじませる */
  mix-blend-mode: lighten;
  
  /* ゆるやかな波の動きを横方向のトランスフォームで表現 */
  animation: waveMotion 15s linear infinite alternate;
  opacity: 0.5; /* 透明度で上品さとテキスト可読性確保 */
}

@keyframes waveMotion {
  0% { transform: translateX(0%) translateY(0%); }
  100% { transform: translateX(-10%) translateY(2%); }
}






/* ========== 受付時間セクションの追加CSS ========== */

/* セクション全体：背景色や余白はお好みで */
.section-schedule-announcement {
  background-color: #f9fafc; /* 必要に応じて変更 */
}

/* カード */
.schedule-card {
  background-color: #fff;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
}

/* テーブル */
.schedule-table {
  width: 100%;
  min-width: 600px; /* 横幅600px以上で表全体を表示（スマホ時のスクロール許可） */
  border-collapse: collapse;
  margin-bottom: 15px;
}
.schedule-table th,
.schedule-table td {
  border: 1px solid #eaeaea;
  text-align: center;
  vertical-align: middle;
  padding: 12px;
  font-size: 15px;
}
.schedule-table thead th {
  background-color: #f2f2f2;
  font-weight: 600;
  color: #555;
}
.schedule-table tbody th.text-start {
  background-color: #fff;
  text-align: left !important;
  font-weight: 600;
}

/* リスト */
.schedule-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.schedule-list li {
  margin-bottom: 10px;
  position: relative;
  padding-left: 30px;
  line-height: 1.7;
}
.schedule-list li i {
  position: absolute;
  left: 0;
  top: 2px;
  font-size: 16px;
}

/* 見出しに左線をつけたい場合の例 */
/*
.schedule-card h3,
.schedule-card h4 {
  border-left: 4px solid var(--base-color);
  padding-left: 10px;
}
*/

/* Bootstrapの .table-responsive クラス が適用される想定で、overflow-xを確実にする */
.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch; /* iOS 端末でのスムーススクロール */
}