@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

.p-fixBtnWrap{
bottom: 7.25em;}

/* 法務CTA*/
.houmu-ipo{
margin-bottom: 30px;}
.p-blogParts post_content{
padding: 0 !important;}
.houmu-ipo .heading{
text-align: center;
font-weight: 600;
color: #FFF;
height: auto;
border-radius: 10px 10px 0 0;
background-color: #02747b;
padding: 10px 0 10px;}


.p-mainVisual__slideTitle {
font-size: 3rem;
font-family: system-ui;}

	
/* コンテナスタイル */
  .p-mainVisual__textLayer {
    font-size: 2em;
    font-family: monospace; /* タイプライター風のフォント */
    text-align: center;
  }

  /* 各<span>に適用する共通スタイル */
  .p-mainVisual__textLayer span {
    opacity: 0;
    display: inline-block;
    animation: typewriter 0.5s forwards;
  }

  /* 各文字に遅延を設定 */
  .p-mainVisual__textLayer span:nth-child(1) { animation-delay: 0.1s; }
  .p-mainVisual__textLayer span:nth-child(2) { animation-delay: 0.2s; }
  .p-mainVisual__textLayer span:nth-child(3) { animation-delay: 0.3s; }
  .p-mainVisual__textLayer span:nth-child(4) { animation-delay: 0.4s; }
  .p-mainVisual__textLayer span:nth-child(5) { animation-delay: 0.5s; }
  .p-mainVisual__textLayer span:nth-child(6) { animation-delay: 0.6s; }
  .p-mainVisual__textLayer span:nth-child(7) { animation-delay: 0.7s; }
  .p-mainVisual__textLayer span:nth-child(8) { animation-delay: 0.8s; }
  .p-mainVisual__textLayer span:nth-child(9) { animation-delay: 0.9s; }
  .p-mainVisual__textLayer span:nth-child(10) { animation-delay: 1.0s; }
  .p-mainVisual__textLayer span:nth-child(11) { animation-delay: 1.1s; }
  .p-mainVisual__textLayer span:nth-child(12) { animation-delay: 1.2s; }
  .p-mainVisual__textLayer span:nth-child(13) { animation-delay: 1.3s; }
  .p-mainVisual__textLayer span:nth-child(14) { animation-delay: 1.4s; }
  .p-mainVisual__textLayer span:nth-child(15) { animation-delay: 1.5s; }
  .p-mainVisual__textLayer span:nth-child(16) { animation-delay: 1.6s; }
  .p-mainVisual__textLayer span:nth-child(17) { animation-delay: 1.7s; }
  .p-mainVisual__textLayer span:nth-child(18) { animation-delay: 1.8s; }
  .p-mainVisual__textLayer span:nth-child(19) { animation-delay: 1.9s; }
  .p-mainVisual__textLayer span:nth-child(20) { animation-delay: 2.0s; }
  .p-mainVisual__textLayer span:nth-child(21) { animation-delay: 2.1s; }
  .p-mainVisual__textLayer span:nth-child(22) { animation-delay: 2.2s; }
  .p-mainVisual__textLayer span:nth-child(23) { animation-delay: 2.3s; }

  /* タイプライター風のアニメーション効果 */
  @keyframes typewriter {
    from { opacity: 0; transform: translateX(-10px); }
    to { opacity: 1; transform: translateX(0); }
  }

/*検索フォーム内*/
.p-searchModal__inner p{
padding: 5px;
color: #fff;}

.p-searchModal__inner a{
color: #fff;
font-size: 14px;}


/*ブログパーツ_CTA*/
        .card {
            background: white;
            border-radius: 12px;
            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
            overflow: hidden;
            width: 100%;
            max-width: 900px;
            display: flex;
            flex-direction: row;
            position: relative;
        }

        .card-image-container {
            flex: 0 0 45%;
            position: relative;
            overflow: hidden;
        }

        .card-image {
            width: 100%;
            height: 100%;
            min-height: 400px;
            object-fit: cover;
            object-position: center;
        }

        .card-content {
            flex: 1;
            padding: 40px;
            display: flex;
            flex-direction: column;
            justify-content: center;
            background: white;
        }

        .card-label {
            font-size: 15px;
            color: #555;
            margin-bottom: 20px;
            font-weight: 500;
        }

        .card-title {
            font-size: 2em;
            font-weight: bold;
            margin-bottom: 12px;
            line-height: 1.5;
            color: #222;
        }

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

        .card-description {
            font-size: 15px;
            color: #666;
            margin: 20px 0;
            padding-bottom: 24px;
            border-bottom: 1px solid #eee;
        }

        .download-button {
            background-color: #1a4789;
            color: white;
            text-decoration: none;
            padding: 18px 24px;
            border-radius: 6px;
            display: flex;
            justify-content: space-between;
            align-items: center;
            transition: all 0.3s ease;
            margin-top: 8px;
        }

        .download-button:hover {
            background-color: #0d2b54;
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(26, 71, 137, 0.2);
        }

        .button-text {
            font-weight: bold;
            font-size: 16px;
letter-spacing: 1.0px;
margin: 0 auto;
        }

        .arrow {
            font-size: 20px;
            margin-left: 12px;
        }

        @media (max-width: 768px) {
            .card {
                flex-direction: column;
                max-width: 480px;
            }

            .card-image-container {
                height: 240px;
            }

            .card-image {
                min-height: unset;
                height: 200px;
            }

            .card-content {
                padding: 32px 24px;
            }

            .card-title {
                font-size: 1.8em;
            }

            .card-description {
                margin: 16px 0;
                padding-bottom: 20px;
            }

            .download-button {
                padding: 16px 20px;
            }
        }

/*ランキングCSS*/
.food-ranking {
  width: 100%;
  max-width: 1024px;
  margin: 0 auto;
  padding: 24px;
  background-color: #FFB800;
  border-radius: 8px;
  font-family: Arial, sans-serif;
}

.header {
  margin-bottom: 32px;
}

.header p {
  font-size: 2.5rem;
  line-height: 1.3;
  font-weight: bold;
  color: white;
  letter-spacing: 0.05em;
  text-shadow: 2px 2px 4px rgba(0,0,0,0.1);
}

.subheader {
  position: relative;
}

.banner {
  background-color: #22C55E;
  color: white;
  padding: 4px 16px;
  border-radius: 9999px;
  display: inline-block;
  transform: rotate(-2deg);
}

.top-text {
  position: absolute;
  right: 0;
  color: white;
  font-size: 3.75rem;
  font-weight: bold;
  letter-spacing: 0.05em;
  text-shadow: 2px 2px 4px rgba(0,0,0,0.1);
}

.ranking-container {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 24px;
}

.top-items {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ranking-item {
  background-color: white;
  border-radius: 8px;
  padding: 16px;
  box-shadow: 0 4px 6px rgba(0,0,0,0.1);
  transition: transform 0.2s;
}

.ranking-item:hover {
  transform: scale(1.02);
}

.ranking-item.top-3 {
  border-left: 4px solid #FCD34D;
}

.item-header {
  display: grid;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}

.item-position {
  font-size: 1.5rem;
  font-weight: bold;
  color: #6B7280;
}

.item-title {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.3;
}

.item-title_mini{
  font-size: 12px;
}

.item-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 8px;
}

.star-rating {
  color: #FCD34D;
}

.website-link {
  background-color: #FFB800;
  color: white;
  padding: 4px 12px;
  border-radius: 4px;
  text-decoration: none;
  font-size: 0.875rem;
  transition: background-color 0.2s;
}

.website-link:hover {
  background-color: #FFA500;
}

.remaining-items a{
background-color: #FFF;
color: #000;
padding: 0;
font-size: 1.0rem;
border-radius: 0;
text-decoration: none;
}

.remaining-items {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.remaining-item {
  background-color: white;
  border-radius: 8px;
  padding: 12px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.1);
  display: flex;
  align-items: center;
  gap: 12px;
}

.remaining-item-position {
  font-size: 1.25rem;
  font-weight: bold;
  color: #6B7280;
}

.remaining-item-title {
  font-weight: 500;
}

@media (min-width: 600px) {
.c-postTitle__ttl {
font-size: 2.5rem;
letter-spacing: 1.5px;}

.-type-list2 .p-postList__title {
font-size: 22px;}
}

@media (max-width: 768px) {
.ranking-container {
grid-template-columns: 1fr;}
.c-postTitle__ttl {
font-size: 26px;
letter-spacing: 0.1rem;}
}

.grecaptcha-badge { visibility: hidden; }