/* ============================================================
みゃーくずみ - メインスタイルシート
============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&family=Noto+Serif+JP:wght@400;700&display=swap');

/* ===== RESET & BASE ===== */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
   
:root {
  --ocean-mid:    #2a9fc0;
  --ocean-light:  #5ec8e0;
  --white:        #ffffff;
  --radius-card:  30px;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
}
   
body {
  font-family: 'Akshar', 'Noto Sans JP', sans-serif;
  color: #333333;
  overflow-x: hidden;
  line-height: 1.7;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}
   
a {
  text-decoration: none;
  color: inherit;
}

button {
  cursor: pointer;
}
   
/* ============================================================
ヘッダー
============================================================ */

header {
  padding: 30px;
}

.header-inner,
header nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* ===== サイトロゴ ===== */

.c-site-branding {
}

.c-site-branding__title {
}

.c-site-branding__title a {
}

.c-site-branding__title a.custom-logo-link {
}

.c-site-branding__title img.custom-logo {
}

/* ===== ナビゲーション ===== */
header .nav-pc {
  gap: 2vw;
  font-size: min(calc(1600vw / 1440),16px);
}
header .nav-pc .nav-has-menu,
header .nav-pc > a {
  position: relative;
}
header .nav-pc .nav-has-menu:after,
header .nav-pc > a:after {
  content: "";
  display: block;
  width: 9px;
  height: 6px;
  position: absolute;
  background: url(/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/header_menu_arrow.png);
  background-size: cover;
  bottom: -11px;
  left: 50%;
  transform: translateX(-50%);
}
header .nav-pc .nav-has-menu:hover:before {
  content: "";
  display: block;
  width: 100%;
  height: 42px;
  position: absolute;
  top: 100%;
}
header .nav-pc .nav-has-menu > .nav_children_menu {
  display: none;
  opacity: 0;
  align-items: center;
  justify-content: center;
  gap: 20px;
  min-width: 450px;
  padding: 20px 30px;
  background: #dce7ed;
  position: absolute;
  top: calc(100% + 41px);
  left: 0;
  transform: translateY(-10px);
  transition: all 0.2s ease;
}
header .nav-pc .nav-has-menu:hover > .nav_children_menu {
  display: flex;
  opacity: 1;
  transform: translateY(0);
}
header .nav-pc button {
  background: transparent;
  border: none;
}
.header-right {
  display: flex;
  align-items: center;
  gap: min(calc(5000vw / 2000),50px);
}

.header-right .language-dropdown.nav-lang {
  display: inline-flex;
  gap: 10px;
}
.dropdown-toggle {
  padding: 0;
  border: none;
}
.dropdown-toggle:after {
  content: none;
}
.language-dropdown #current-lang span {
  font-family: "Akshar", sans-serif;
  color: #007fb0;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0;
}
.header-right a.nav-search {
}
.language-dropdown img,
.header-right a img {
  width: 22px !important;
}

/* ===== CONTAINER ===== */

.d-container {
  /* max-width: 1200px;
  margin: 0 auto; */
}

.d-container section {
  padding: 120px 20px;
}
.mv,
.front__ad-container,
.secondSwiper,
.filter-search,
.swipernews-section,
.member-section,
.sns-section {
  background-color: #FFF;
}

.section-inner {
  max-width: 1200px;
  margin: 0 auto;
}

/* ===== SECTION TITLE ===== */
.section-title {
  text-align: center;
}
   
.section-title h2 {
  color: #333333;
  font-size: 40px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.1em;
}

.section-title p {
  font-size: 20px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0;
  text-transform: uppercase;
  margin-top: 20px;
  display: inline-block;
  background: linear-gradient(90deg, #007fb0, #c2ddeb 50%, #edde00);
  background: -webkit-linear-gradient(0deg, #007fb0, #c2ddeb 50%, #edde00);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  width: max-content;
  margin-left: auto;
  margin-right: auto;
}
   
.section-title + * {
  max-width: 1200px;
  margin: 50px auto 0;
}

/* ============================================================
MV（メインビジュアル）
============================================================ */
.mv {
  position: relative;
  width: 100%;
  min-height: 560px;
  padding-bottom: calc(37100vw / 2000);
  overflow: hidden;
}

/* Swiperラッパー */
.swiper.mv-swiper {
  position: relative;
  z-index: 2;
  mix-blend-mode: multiply;
}
   
.mv-swiper .swiper-wrapper,
.mv-swiper .swiper-slide {
  width: 100%;
  height: 100%;
}
   
.mv-swiper .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.swiper-pagination.mv-swiper-pagination {
  bottom: auto !important;
  top: calc(71000vw / 2000) !important;
}

/* コンテンツ */
.mv-content {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 13vw;
  width: calc(100% - 80px);
  margin: 0 auto;
}
.mv-logo {
  width: calc(76500vw / 2000);
}
.mv-logo img {
  /* height: 80px; */
  /* width: auto; */
  /* filter: drop-shadow(0 2px 12px rgba(0,0,0,0.25)); */
}
.mv-swiper-button-prev,
.mv-swiper-button-next {
  top: calc(13vw + 12750vw / 2000) !important;
  width: 23px !important;
  height: 35px !important;
}
.mv-swiper-button-prev:after,
.mv-swiper-button-next:after {
  content: none !important;
}
.mv-swiper-button-prev {
  left: 32px !important;
}
.mv-swiper-button-next {
  right: 32px !important;
  transform: rotate(180deg);
}
.mv-swiper-pagination .swiper-pagination-bullet,
.article-container .swiper-pagination-bullet,
.seasonal-container .swiper-pagination-bullet {
  background: #FFF !important;
}

/* お天気情報 */
.weather-box {
  font-family: "Akshar", sans-serif;
  color: #FFF;

  /* 背景をぼかす */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px); /* Safari用 */

  /* 透明な白や黒でガラス質を表現 */
  background-color: rgba(255, 255, 255, 0.3);

  /* 必要に応じてボーダーを追加 */
  border: 1px solid rgba(255, 255, 255, 0.2);
  padding: calc(1600vw / 2000) calc(1600vw / 2000) calc(200vw / 2000);
  line-height: 1;
  position: absolute;
  top: calc(50900vw / 2000);
  right: 14.8vw;
}
.weather-main,
.weather-date {
  margin-top: calc(2000vw / 2000);
}
.weather-city,
.weather-date {
  font-size: calc(3200vw / 2000);
  text-transform: uppercase;
}
.weather-main {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}
.weather-temp {
  font-size: calc(7200vw / 2000);
}
.weather-icon {
  width: calc(5600vw / 2000);
  display: flex;
  align-items: flex-end;
  padding-bottom: calc(1400vw / 2000);;
}
.weather-icon img {
  filter: brightness(0) invert(1);
}


/* MVメニューリスト（7アイコン横並び） */
.mv_menu_list {
  display: flex;
  gap: 25px;
  margin-top: calc(25000vw / 2000);
}

.mv_menu_item {
  flex: 1;
  min-width: 90px;
}

.mv_menu_item a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: calc(1400vw / 2000);
  position: relative;
  width: calc(16800vw / 2000);
  height: calc(16800vw / 2000);
  border-radius: calc(8400vw / 2000);
  background: #FFF;
}
.mv_menu_item .mv_menu_icon {
  width: auto !important;
  height: 40px;
}
   
.mv_menu_item span {
  color: #007fb0;
  font-size: 1vw;
  font-weight: 700;
  white-space: nowrap;
}

.mv_menu_item .mv_menu_arrow {
  width: 29px !important;
  height: 29px;
  position: absolute;
  bottom: -14.5px;
}

.mv_scroll {
  font-family: "Akshar", sans-serif;
  color: #FFF;
  font-size: 19px;
  line-height: 1;
  letter-spacing: 0.15em;
  position: relative;
  margin-top: 64px;
}
.mv_scroll:after {
  content: "";
  display: block;
  width: 1px;
  height: 72px;
  background: #FFF;
  position: absolute;
  bottom: -90px;
  left: 50%;
  transform: translateX(50%);
}

/* ウェーブ下部装飾（MVの下） */
.mv_wave {
  position: absolute;
  bottom: 0;
  z-index: 1;
  left: 0;
}
   
/* ============================================================
広告バナー
============================================================ */
/* .front__ad-container,
.front__main-ad-container,
.secondSwiper {
  margin: 48px auto 0;
  padding-bottom: 54px;
  overflow:visible;
} */

.front__main-ad-swiper.swiper,
.secondSwiper.swiper {
  padding: 40px 0 38px;
}

.front__ad-item.swiper-slide,
.secondSwiper .swiper-slide {
  width: auto;
  flex-shrink: 0;
}
.front__ad-item.swiper-slide > a,
.secondSwiper .swiper-slide > a {
  border-radius: 30px;
  overflow: hidden;
}
.front__ad-item.swiper-slide > a {
  display: block;
  width: 75vw;
  max-width: 1500px;
}
.front__ad-item img{
  width:100%;
  height:auto;
  display:block;
}
.ad-swiper-pagination.swiper-pagination,
.second-swiper-pagination.swiper-pagination {
  bottom: -8px !important;
}
.ad-swiper-pagination .swiper-pagination-bullet,
.second-swiper-pagination .swiper-pagination-bullet {
  background: #edde00 !important;;
}
.secondSwiper .swiper-slide > a {
  display: block;
  width: 25vw;
  max-width: 500px;
}
.secondSwiper .swiper-slide img {
  display: block;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 30px;
  max-height: 100%;
  aspect-ratio: 16 / 9;
}

/* ============================================================
新着記事セクション
============================================================ */
.new-articles-section {
  background: linear-gradient(to bottom, var(--white) 360px, #dce7ed 360px);
}

/* カードグリッド共通 */
.article-grid.swiper-wrapper {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-top: 30px;
}

/* 記事カード */
.article-card {
  background: #FFF;
  border-radius: 30px;
  overflow: hidden;
  transition: transform 0.3s ease;
}
.article-card:first-child {
  --category-color: #9f36e2;
}
.article-card:nth-child(2) {
  --category-color: #e66100;
}
.article-card:nth-child(3) {
  --category-color: #00358c;
}
.article-card:nth-child(4) {
  --category-color: #e26767;
}
.article-card:nth-child(5) {
  --category-color: #9ad67d;
}
.article-card:nth-child(6) {
  --category-color: #3298bf;
}
.article-card__img {
  height: 315px;
  overflow: hidden;
}
.article-card__img a {
  display: block;
  width: 100%;
  height: 100%;
}
.article-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.article-card:hover .article-card__img img {
  transform: scale(1.05);
}
.article-card__info {
  padding: 25px 20px 20px;
  letter-spacing: 0.1em;
} 
.article-card__top {
  display: flex;
  align-items: center;
  gap: 10px;
  line-height: 1;
}
.article-card__date {
  font-size: 16px;
}
.article-card__category {
  font-size: 14px;
  font-weight: 600;
  color: var(--category-color);
  text-align: center;
  display: inline-block;
  min-width: 100px;
  padding: 9px 20px;
  border-radius: 16px;
  border: 1px solid var(--category-color);
  letter-spacing: 0.5px;
}
.article-card__name {
  font-size: 16px;
  font-weight: 500;
  line-height: calc(30/16);
  margin-top: 12px;
  text-align: left;
}
.article-card__name a {
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.article-card__name a:hover {
  color: var(--ocean-mid);
}
.article-card__link {
  text-align: right;
  margin-top: 40px;
}
.article-card__link a {
  display: inline-block;
  width: 100px;
}

/* ============================================================
特集記事セクション（海の帯 + カテゴリリスト）
============================================================ */

.feature-section {
  background: url('/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/sec03_4dan_bg.jpg');
  background-size: cover;
  position: relative;
  overflow: hidden;
}
.feature-section .section-title h2 {
  color: var(--white);
}
.feature-section .section-title p {
  color: var(--white);
  -webkit-text-fill-color: unset;
}
.blue-btn-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.blue-btn {
  background: #cee3ed;
  background-image: url('/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/blue_btn_bg.png');
  background-size: cover;
  background-position: center center;
  border-radius: 20px;
  padding: 21.5px 10px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.blue-btn a {
  display: block;
  font-size: 22px;
  font-weight: 500;
  line-height: calc(36/22);
  text-align: center;
}

/* ============================================================
条件で探す（フィルター検索）
============================================================ */
.filter-search {
  background: #f2f5f5;
}

/* ジャンルタブ */
.filter-search_area {
  display: flex;
  gap: 8px;
  justify-content: center;
}
.filter-search_area button {
  flex: 1;
  padding: 26px 20px;
  border-radius: 20px 20px 0 0;
  border: 1px solid var(--search-color);
  background: var(--white);
  color: var(--search-color);
  font-size:24px;
  transition: all 0.2s;
}
.filter-search_area button.is-active {
  background: var(--search-color);
  border-color: var(--search-color);
  color: var(--white);
}

/* ジャンル別色分け */
.filter-search_area .tab-1 {
  --search-color: #d04515;
}
.filter-search_area .tab-2 {
  --search-color: #eb8133;
}
.filter-search_area .tab-3 {
  --search-color: #3399c0;
}
.filter-search_area .tab-4 {
  --search-color: #009160;
}
.filter-search_area .tab-5 {
  --search-color: #a45c98;
}
.filter-search_area .tab-6 {
  --search-color: #d01a6b;
}
 
/* エリア + マップ */
.search-tab-content {
  background: #FFF;
  border-radius: 0 0 30px 30px;
  padding: 50px 20px;
}
.filter-search-tab-content_wrapper {
  display: flex;
}
.filter-search-tab-content_wrapper > div {
  flex: 1;
  padding: 0 30px;
}

.search-tab-content h2 {
  font-size: 22px;
  font-weight: 600;
  text-align: center;
  letter-spacing: 0.1em;
  position: relative;
}
.search-tab-content h2:before,
.search-tab-content h2:after {
  content: "";
  display: block;
  width: calc(50% - 80px);
  height: 1px;
  background: #333;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.search-tab-content h2:before {
  left: 0;
}
.search-tab-content h2:after {
  right: 0;
}
.search-tab-content h2 + * {
  margin-top: 40px;
}
.tab-content h2:not(:first-child) {
  margin-top: 50px;
}
.search_map-area {
}
.search_map-area .map {
  position: relative;
}
.search_map-area .map button,
.tag-lineup button {
  padding: 15px 20px;
  border-radius: 22px;
  border: 1px solid #333;
  font-size: 14px;
  background: var(--white);
  transition: all 0.2s;
}
.search_map-area .map button:hover,
.search_map-area .map button.is-active {
  background: var(--ocean-light);
  border-color: var(--ocean-light);
  color: white;
}
.search_map-area .map button {
  position: absolute;
  min-width: 120px;;
}
.search_map-area .map button[data-area-slug="miyakojima"] {
  bottom: 148px;
  right: 89px;
}
.search_map-area .map button[data-area-slug="irabujima"] {
  top: 120px;
  /* left: 154px; */
  left: 90px;
}
.search_map-area .map button[data-area-slug="taramajima"] {
  bottom: 56px;
  left: 80px;
}
.search_map-area .map button[data-area-slug="o-gamijima"] {
  top: 100px;
  right: 54px;
}
.search_map-area .map button[data-area-slug="kurimajima"] {
  bottom: 56px;
  right: 146px;
}
.search_map-area .map button[data-area-slug="minnajima"] {
  bottom: 152px;
  left: 24px;
}
.search_map-area .map button[data-area-slug="ikemajima"] {
  top: 46px;
  right: 128px;
}
/* タグエリア */
.filter-search_tags {
  margin: 0 auto;
  background: #FFF;
  border-radius: 30px;
  padding: 24px 28px;
}
.tab-content {
  display: none;
}
.tab-content.is-show {
  display: block;
}
.tab-content h2:first-child {
  margin-top: 0;
}
.tag-lineup {
  display: flex;
  flex-wrap: wrap;
  column-gap: 10px;
  row-gap: 20px;
}
.tag-lineup button:hover {
  border-color: var(--ocean-mid);
  color: var(--ocean-mid);
}
.tag-lineup button.is-active {
  background: var(--ocean-mid);
  border-color: var(--ocean-mid);
  color: white;
}
.sbi_load_btn {
  font-family: "Akshar", sans-serif;
}
/* 検索ボタン */
.search-tab-content > button,
#sb_instagram #sbi_load .sbi_load_btn {
  color: white;
  font-size: 24px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.1em;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 330px;
  height: 85px;
  margin: 50px auto 0;
  background-image: url('/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/search_btn_bg.png') !important;
  background-size: cover !important;
  border: none;
  padding: 20px;
  border-radius: 42px;
  position: relative;
}
.search-tab-content > button:before {
  content: "";
  display: block;
  width: 33px;
  height: 36px;
  background-image: url('/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/btn_search_icon.png');
  background-size: cover;
  position: absolute;
  top: 50%;
  left: 50px;
  transform: translateY(-50%);
}
#js-search:disabled,
#js-search-island:disabled {
  box-shadow: none;
  cursor: not-allowed;
  opacity: 0.6;
}

/* ============================================================
みゃーくずみ編集部おすすめ
============================================================ */
.recommend-section {
  background: url('/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/sec05_bg.jpg');
  background-size: cover;
}
.recommend-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.rec-card {
  border-radius: 30px 30px 30px 0;
}
.rec-card a {
  display: block;
}
   
/* ============================================================
パララックスセクション
============================================================ */
.parallax_section {
  position: relative;
  height: 575px;
}
.parallax_section span {
  display: block;
  width: 100%;
  height: 100%;
  background-attachment: fixed;
  background-image: url(/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/bg_parallax_img.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  font-size: 0;
  color: transparent;

}
   
/* ============================================================
季節で楽しむ宮古島
============================================================ */
.seasonal-section {
  background: #dce7ed;
}

.seasonal-grid.swiper-wrapper {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
   
/* 季節カードは article-card スタイルを継承 */
.seasonal-grid .article-card {
  /* article-card のスタイルがそのまま適用される */
}
.seasonal-grid .article-card__img {
  height: 260px;
}
.article-card__season {
  color: var(--white);
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  background: var(--season-color);
  border-radius: 24px;
}
.seasonal-grid .article-card:first-child {
  --season-color: #f5a4c8;
}
.seasonal-grid .article-card:nth-child(2) {
  --season-color: #049d3a;
}
.seasonal-grid .article-card:nth-child(3) {
  --season-color: #ed5a01;
}
.seasonal-grid .article-card:nth-child(4) {
  --season-color: #40a4aa;
}
.seasonal-grid .article-card__name a {
  -webkit-line-clamp: 3;
}
.seasonal-grid .article-card__link {
  text-align: center;
}

/* ============================================================
宮古島ニュース
============================================================ */
.news-section {
  background: var(--white);
}
.news-item {
  display: flex;
  align-items: flex-start;
  padding: 20px 30px;
  border-bottom: 1px solid #09467c;
  cursor: pointer;
}
.news-item:first-child {
  border-top: 1px solid #09467c;
}
.news-thumb {
  width: 180px;
  height: 115px;
  border-radius: 30px;
  flex-shrink: 0;
  overflow: hidden;
}
.news-thumb a {
  display: block;
  width: 100%;
  height: auto;
}
.news-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.news-content {
  padding-left: 32px;
}
.news-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.news-date,
.news-title {
  font-size: 16px;
  line-height: 1;
}
.news-tag {
  font-size: 14px;
  line-height: 1;
  padding: 9px 10px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 100px;
}
.tag-new {
  color: var(--white);
  background: #ce0202;
}
.tag-news-category {
  border: 1px solid #333333;
}
.news-title {
  line-height: 1.5;
  margin-top: 17px;
}

/* ニュースカテゴリリスト */
.news_category_list {
  grid-template-columns: repeat(5, 1fr);
  margin-top: 32px;
}
.news_category_item a {
}
   
/* ============================================================
島の暮らしセクション
============================================================ */
.island-section {
  background: #f2f5f5;
  text-align: center;
}

.island-section .tab-content {
  display: block;
}

/* ============================================================
みゃーくずみとは？（about-section）
============================================================ */
.about-section {
  position: relative;
  height: 440px;
  overflow: hidden;
  background-image: url(/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/myakuzumi_bg.jpg);
  background-size: cover;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 20px;
}
.about-section a {
  display: block;
  max-width: 1200px;
}

/* ============================================================
会員限定セクション
============================================================ */
.member-section {
  background-image: url(/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/sec09_bg.jpg);
  background-size: cover;
  text-align: center;
}

.member-desc {
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 0.1em;
}

.member-section .article-grid {
  margin-top: 50px;
}

.member-register-link {
  margin-top: 50px;
  max-width: 570px;
  margin: 50px auto 0;
}

/* ============================================================
Instagram / SNS
============================================================ */
.sns-section {
}

.sns-title {
  font-family: 'Akshar', sans-serif;
  font-size: 48px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-align: center;
  background: linear-gradient(to left, #ff7a00, #ff0069 50%, #7638fa);
  background: -webkit-linear-gradient(to left, #ff7a00, #ff0069 50%, #7638fa);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  width: max-content;
  margin-left: auto;
  margin-right: auto;
}
.sb_instagram_header {
  display: none;
}
#sbi_images {
  font-size: 0;
}
/* .sbi_photo_wrap > a.sbi_photo:not(:last-child) {
  position: absolute;
} */

/* ============================================================
ロゴフッター（ページ最下部ロゴエリア）
============================================================ */
footer {
  background-image: url(/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/footer_bg.png);
  background-size: cover;
  background-color: #FFF;
  position: relative;
  overflow: visible;
}
.footer_main {
  padding-top: calc(21000vw / 2000);
}
.footer_logo img {
  height: 131px;
}
.footer-nav,
.footer_copyright {
  color: #FFF;
  font-size: 16px;
  font-weight: 300;
}
.footer-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  max-width: 760px;
  margin: 0 auto;
}
.footer-nav a {
  position: relative;
}
.footer-nav a:not(.footer_sns_icon) {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  line-height: 1;
}
.footer-nav a.footer_sns_icon {
  font-size: 0;
}
.footer-nav a:not(.footer_sns_icon):before {
  content: "";
  display: block;
  width: 7px;
  height: 10px;
  background-image: url(/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/footer-menu_arrow.png);
  background-size: cover;
}
.footer_sns_icon svg {
  height: 23px;
}
.footer_copyright {
  font-family: 'Noto Sans JP', sans-serif;
  line-height: 1;
  padding: 30px 0;
}
.footer_top_btn {
  width: 100px;
  height: 100px;
  background: #007fb0;
  position: absolute;
  bottom: 450px;
  right: 5px;
  z-index: 1;
  border-radius: 50px;
  border: 1px solid #FFF;
}
.footer_top_btn a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: 100%;
  height: 100%;
}
.footer_top_btn .totop_arrow {
  width: 15px;
}
.footer_top_btn span {
  color: #FFF;
  font-size: 22px;
  line-height: 1;
  letter-spacing: 0.15em;
  padding-left: 0.15em;
}

/* サイドバー */
.fixed_menu {
  display: flex;
  flex-direction: column;
  gap: 5px;
  position: fixed;
  bottom: 110px;
  right: 0;
  z-index: 3;
}
.fixed_menu a {
  width: 100px;
  height: 100px;
  display: block;
  overflow: hidden;
}

/* ============================================================
top_slide（library/top_slide）
============================================================ */
.top-slide-section {
  padding: 32px 20px 0;
  max-width: 1200px;
  margin: 0 auto;
}

/* ============================================================
ユーティリティ
============================================================ */

/* スマホ / タブレット向け表示切替 */
.content_pc { display: block; }
.content_sp { display: none; }
   
/* Swiper ドット */
.swiper-pagination-bullet {
  opacity: 0.8;
}
.swiper-pagination-bullet-active {
  opacity: 1 !important;
}
   
/* ============================================================
レスポンシブ
============================================================ */
@media (min-width: 1180px) {
  .nav-sp {
    display: none;
  }
}
@media (max-width: 1179px) {
  .nav-pc {
    display: none;
  }
  .header-right {
    margin-left: auto;
    margin-right: 25px;
  }
  .search_map-area .map button {
    padding: calc(1500vw / 1240) calc(2000vw / 1240);
    border-radius: 22px;
    border: 1px solid #333;
    font-size: calc(1400vw / 1240);
    min-width: 0;
  }
  .search_map-area .map button[data-area-slug="miyakojima"] {
    bottom: calc(14800% / 457);
    right: calc(8900% / 520);
  }
  .search_map-area .map button[data-area-slug="irabujima"] {
    top: calc(12000% / 457);
    left: calc(9000% / 520);
  }
  .search_map-area .map button[data-area-slug="taramajima"] {
    bottom: calc(5600% / 457);
    left: calc(8000% / 520);
  }
  .search_map-area .map button[data-area-slug="o-gamijima"] {
    top: calc(10000% / 457);
    right: calc(5400% / 520);
  }
  .search_map-area .map button[data-area-slug="kurimajima"] {
    bottom: calc(5600% / 457);
    right: calc(14600% / 520);
  }
  .search_map-area .map button[data-area-slug="minnajima"] {
    bottom: calc(15200% / 457);
    left: calc(2400% / 520);
  }
  .search_map-area .map button[data-area-slug="ikemajima"] {
    top: calc(4600% / 457);
    right: calc(12800% / 520);
  }
}

  #drawer-nav {
    background-color: #007fb0;
  }
  .drawer_content_202603 {
    height: 100%;
  }
  .drawer_content_202603 .c-site-branding__title {
    display: flex;
    justify-content: center;
    margin-top: 60px;
}
.drawer_content_202603 .nav-has-menu,
.drawer_content_202603 a,
.drawer_content_202603 a button {
  font-size: 16px;
  font-weight: 500;
  font-family: "Oswald", sans-serif;
  color: #fff;
  text-transform: uppercase;
  line-height: 1.2;
  -webkit-transition-duration: .3s;
  transition-duration: .3s;
}
.drawer_content_202603 .c-drawer__menu {
  margin-top: 20px;
}
.drawer_content_202603 ul {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.drawer_content_202603 a {
  display: block;
}
.drawer_content_202603 a button {
  background: transparent;
  border: none;
}
.drawer_content_202603 .nav-has-menu li {
  padding-left: 15px;
  position: relative;
}
  .custom-logo-link {}
  .custom-logo {}
  .drawer__menu {}
  .nav-has-menu {}
  .drawer_content_202603 .nav_children_menu {
    margin-top: 10px;
}
    #drawer-nav .c-hamburger-btn__bars > .c-hamburger-btn__bar:first-of-type, #drawer-nav .c-hamburger-btn__bars > .c-hamburger-btn__bar:nth-of-type(3) {
        background-color: #fff;
    }

  .drawer_content_202603 .c-hamburger-btn-area {
    top: 30px !important;
    right: 30px !important;
  }
  
/* @media (max-width: 999px) { */
/* } */

@media (max-width: 767px) {

  /* ============================================================
  ヘッダー
  ============================================================ */
  
  /* ===== ナビゲーション ===== */
  header {
    width: 100vw;
    position: fixed;
    padding: 0;
    background: transparent;
  }
  header:not(.is-scroll) {
    box-shadow: unset !important;
  }
  .header-inner {
    align-items: flex-start;
  }
  .c-site-branding {
    padding: 15px;
    background: #FFF;
    border-radius: 0 0 30px 0;
  }
  .header-right,
  .dropdown-toggle {
    align-items: flex-start;
  }
  .header-right,
  .c-hamburger-btn-area {
    margin-top: 15px;
  }
  .header-right {
    flex-direction: row-reverse;
    gap: 10px;
    margin-right: 12.5px;
  }
  .language-dropdown {
    margin: 0;
  }
  .language-dropdown #current-lang span {
    display: none;
  }
  .dropdown-toggle {
    background: transparent;
  }
  .language-dropdown img,
  .header-right a img {
    width: 13px !important;
    filter: brightness(0) invert(1);
  }
  .dropdown-list {
    width: 100px;
    left: 50%;
    transform: translateX(-50%);
  }
  .c-hamburger-btn-area {
    margin-right: 15px;
  }
  .c-hamburger-btn__bars {
    width: 27px;
    height: 20px;
  }
  .c-hamburger-btn__bar {
    filter: brightness(0) invert(1);
    border-radius: 3px;
    height: 3px;
  }
  header.is-scroll {
    background: #FFF;
  }
  header.is-scroll .header-inner,
  header.is-scroll .header-right {
    align-items: center;
  }
  header.is-scroll .header-right,
  header.is-scroll .c-hamburger-btn-area {
    margin-top: 0;
  }
  header.is-scroll .nav-lang {
    display: none !important;
  }
  header.is-scroll .header-right a img {
    width: 19px !important;
    align-items: center;
  }
  header.is-scroll .language-dropdown img,
  header.is-scroll .header-right a img,
  header.is-scroll .c-hamburger-btn__bar {
    filter: unset;
  }
  .drawer_content_202603 .c-hamburger-btn-area {
    top: 0 !important;
    right: 0 !important;
    margin-top: 15px !important;
  }



  /* ===== CONTAINER ===== */
  
  .d-container section {
    padding: 60px 16px;
  }
     
  .section-title h2 {
    font-size: 23px;
  }
  
  .section-title p {
    font-size: 16px;
    font-weight: 600;
    margin-top: 14px;
  }
     
  .section-title + * {
    margin: 25px auto 0;
  }
  
  /* ============================================================
  MV（メインビジュアル）
  ============================================================ */
  .mv {
    position: relative;
    width: 100%;
    min-height: 560px;
    padding-bottom: calc(43300vw / 750);
    overflow: hidden;
  }
  
  /* Swiperラッパー */
  .swiper.mv-swiper {
    mix-blend-mode: unset;
  }
     
  .mv-swiper .swiper-wrapper,
  .mv-swiper .swiper-slide {
    width: 100%;
    height: 100%;
  }
     
  .mv-swiper .swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  
  .swiper-pagination.mv-swiper-pagination {
    bottom: auto !important;
    top: calc(81500vw / 770) !important;
  }
  

  .mv-swiper-button-prev,
  .mv-swiper-button-next {
    top: calc(44500vw / 770) !important;
    width: calc(2100vw/770) !important;
    height: calc(3200vw/770) !important;
  }
  .mv-swiper-button-prev:after,
  .mv-swiper-button-next:after {
    content: none !important;
  }
  .mv-swiper-button-prev {
    left: calc(3200vw/770) !important;
  }
  .mv-swiper-button-next {
    right: calc(3200vw/770) !important;
    transform: rotate(180deg);
  }
  /* コンテンツ */
  .mv-content {
    padding-top: calc(14000vw / 770);
  }
  .mv-logo,
  .mv-sp-menu {
    width: calc(46400vw / 770);
  }
  .mv-sp-menu_grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    column-gap: calc(1000vw / 770);
    row-gap: calc(2000vw / 770);
    margin-top: calc(3000vw / 770);
  }
  .mv-sp-menu_grid a {
    font-size: 9px;
    width: calc(14800vw / 770);
    height: calc(6500vw / 770);
    background: #FFF;
    border-radius: 32px;
  }
  .mv-sp-menu_grid a {
    color: var(--mv-sp-color);
    font-size: calc(1800vw / 770);
    display: flex;
    align-items: center;
    justify-content: center;
    width: calc(14800vw / 770);
    height: calc(6500vw / 770);
    background: #FFF;
    border-radius: 32px;
    position: relative;
  }
  .mv-sp-menu_grid a:first-child {
    --mv-sp-color: #d04515;
  }
  .mv-sp-menu_grid a:nth-child(2) {
    --mv-sp-color: #e66100;
  }
  .mv-sp-menu_grid a:nth-child(3) {
    --mv-sp-color: #007fb0;
  }
  .mv-sp-menu_grid a:nth-child(4) {
    --mv-sp-color: #009160;
  }
  .mv-sp-menu_grid a:nth-child(5) {
    --mv-sp-color: #943f85;
  }
  .mv-sp-menu_grid a:nth-child(6) {
    --mv-sp-color: #d01a6b;
  }
  .mv-sp-menu_grid a:nth-child(7) {
    --mv-sp-color: #bb1f1f;
  }
  .mv-sp-menu_grid a:nth-child(8) {
    --mv-sp-color: #0c3889;
  }
  .mv-sp-menu_grid a:nth-child(9) {
    --mv-sp-color: #005520;
  }
  .mv-sp-menu_grid a:last-child {
    --mv-sp-color: #026c95;
    width: calc(24000vw / 770);
  }
  .mv-sp-menu_grid button {
    color: var(--mv-sp-color);
    background: transparent;
    width: 100%;
    height: 100%;
    border: none;
  }
  .mv-sp-menu_grid a:after {
    content: "";
    display: block;
    width: calc(700vw / 770);
    height: calc(700vw / 770);
    border-top: 1px solid var(--mv-sp-color);
    border-right: 1px solid var(--mv-sp-color);
    position: absolute;
    top: 50%;
    right: calc(1200vw / 770);
    transform: translateY(-50%) rotate(45deg);
  }

/* お天気情報 */
.weather-box {
  padding: calc(1600vw / 770) calc(1600vw / 770) calc(200vw / 770);
  top: calc(67200vw / 770);
  right: calc((100vw - 80px - 71000vw / 770) / 2);
}
.weather-main,
.weather-date {
  margin-top: calc(2000vw / 770);
}
.weather-city,
.weather-date {
  font-size: calc(3200vw / 770);
}
.weather-temp {
  font-size: calc(7200vw / 770);
}
.weather-icon {
  width: calc(5600vw / 770);
  padding-bottom: calc(1400vw / 770);
}

/* safari */
_::-webkit-full-page-media, _:future, :root .swiper-pagination.mv-swiper-pagination {
  top: calc(87500vw / 770) !important;
}
_::-webkit-full-page-media, _:future, :root .mv-content {
  padding-top: calc(19000vw / 770);
}
_::-webkit-full-page-media, _:future, :root .mv-sp-menu_grid {
  margin-top: calc(4000vw / 770);
}
_::-webkit-full-page-media, _:future, :root .weather-box {
  top: calc(73200vw / 770);
}



  /* MVメニューリスト（7アイコン横並び） */
  .mv_menu_list {
    width: calc(71000vw / 770);
    gap: calc(2500vw / 770);
    margin-top: calc(24000vw / 770);
    flex-wrap: wrap;
    justify-content: center;
  }
  
  .mv_menu_item {
    flex: none;
    min-width: 0;
    width: fit-content;
  }
  
  .mv_menu_item a {
    width: calc(15800vw / 770);
    height: calc(15800vw / 770);
    border-radius: calc(8400vw / 770);
    gap: calc(1500vw / 770);
  }
  .mv_menu_item .mv_menu_icon {
    width: auto !important;
    height: calc(5700vw / 770);
  }
  .mv_menu_item span {
    font-size: calc(2000vw / 770);
  }
  .mv_menu_item .mv_menu_arrow {
    width: calc(2900vw / 770) !important;
    height: calc(2900vw / 770);
    bottom: calc(-1450vw / 770);
  }
  .mv_scroll {
    font-size: calc(1900vw / 770);
    margin-top: calc(3800vw / 770);
  }
  .mv_scroll:after {
    height: calc(7200vw / 770);
    bottom: calc(-9000vw / 770);
  }

  /* ウェーブ下部装飾（MVの下） */
  .mv_wave {
    position: absolute;
    bottom: 0;
    z-index: 1;
    left: 0;
  }
     
  /* ============================================================
  広告バナー
  ============================================================ */


  .front__main-ad-swiper.swiper {
    padding: 40px 16px 26px;
  }
  .secondSwiper.swiper {
    padding: 20px 16px 26px;
  }
  .front__ad-item.swiper-slide {
    width:100%;
  }
  .secondSwiper .swiper-slide {
    width:100%;
  }
  .front__ad-item.swiper-slide > a,
  .secondSwiper .swiper-slide > a {
    width: 100%;
    max-width: none;
  }
  /* ============================================================
  新着記事セクション
  ============================================================ */
  .article-container,
  .seasonal-container {
    padding-bottom: 44px !important;
  }
  /* カードグリッド共通 */
  .article-grid.swiper-wrapper,
  .seasonal-grid.swiper-wrapper {
    display: flex;
    margin-top: 0;
    gap: 0;
  }

  /* 記事カード */     
  .article-card__img {
    height: calc(25700vw / 750);
    max-height: 257px;
  }
     
     .article-card__img a {
       display: block;
       width: 100%;
       height: 100%;
     }
     
     .article-card__info {
       padding: 14px 13px 19px;
     }
     
     .article-card__top {
       gap: 16px;
     }
     
     .article-card__date {
       font-size: 14px;
     }
     
     .article-card__category {
       font-size: 12px;
       min-width: 108px;
     }
     
     .article-card__name {
       font-size: 16px;
       line-height: calc(47/32);
       margin-top: 10px;
     }     
     .article-card__link {
       margin-top: 20px;
     }
     .article-card__link a {
       width: 97px;
     }
     
     
     /* ============================================================
        特集記事セクション（海の帯 + カテゴリリスト）
        ============================================================ */
     .blue-btn-list {
       grid-template-columns: repeat(2, 1fr);
       gap: 7px;
     }
     
     .blue-btn {
       background: #cee3ed;
       background-image: url('/manage/wp-content/themes/myakuzumi/assets/img/202603/pc/blue_btn_bg.png');
       background-size: cover;
       background-position: center center;
       border-radius: 20px;
       padding: 19px 10px;
       cursor: pointer;
       display: flex;
       align-items: center;
       justify-content: center;
      }
     
      .blue-btn a {
       font-size: 13px;
       line-height: calc(36/26);
     }
     
     /* ============================================================
        条件で探す（フィルター検索）
        ============================================================ */

     
     /* ジャンルタブ */
     .filter-search_area {
       gap: 1px;
     }
     
     .filter-search_area button {
       padding: 11px 6px;
       border-radius: 10px 10px 0 0;
       font-size: 10px;
     }
     .filter-search_area button.tab-1,
     .filter-search_area button.tab-2 {
      flex: 1.67;
     }
    /* エリア + マップ */
    .search-tab-content {
      background: #FFF;
      border-radius: 0 0 10px 10px;
      padding: 25px 22px;
    }
    .filter-search-tab-content_wrapper {
      flex-direction: column-reverse;
      gap: 25px;
     }
    .filter-search-tab-content_wrapper > div {
      padding: 0;
    }     
    .search-tab-content h2 {
      font-size: 14px;
    }
    .search-tab-content h2:before,
    .search-tab-content h2:after {
      width: calc(50% - 55px);
    }
    .search-tab-content h2 + * {
      margin-top: 20px;
    }
    .tab-content h2:not(:first-child) {
      margin-top: 25px;
    }
    .search_map-area .map {
      max-width: 310px;
      margin: 20px auto 0;
    }
    .search_map-area .map button,
    .tag-lineup button {
      padding: 9px 12px;
      font-size: 9px;
    }
    .search_map-area .map button {
      min-width: 60px;
    }
    .search_map-area .map button[data-area-slug="miyakojima"] {
      bottom: 87px;
      right: 58.5px;
    }
    .search_map-area .map button[data-area-slug="irabujima"] {
      top: 72px;
      left: 56px;
    }
    .search_map-area .map button[data-area-slug="taramajima"] {
      bottom: 16px;
      left: 37px;
    }
    .search_map-area .map button[data-area-slug="o-gamijima"] {
      top: 53px;
      right: 39px;
    }
    .search_map-area .map button[data-area-slug="kurimajima"] {
      bottom: 34px;
      right: 100px;
    }
    .search_map-area .map button[data-area-slug="minnajima"] {
      bottom: 101px;
      left: 6.5px;
    }
    .search_map-area .map button[data-area-slug="ikemajima"] {
      top: 20px;
      right: 120px;
    }
     /* タグエリア */
     .tag-lineup {
       column-gap: 6px;
       row-gap: 12px;
     }     
     
     /* 検索ボタン */
     .search-tab-content > button,
     #sb_instagram #sbi_load .sbi_load_btn {
        font-size: 14px;
        width: 165px;
        height: 42.5px;
        margin: 25px auto 0;
        padding: 20px;
      }
      .search-tab-content > button:before {
       width: 16.5px;
       height: 18px;
       left: 20px;
     }
     
     /* ============================================================
        みゃーくずみ編集部おすすめ
        ============================================================ */

        .recommend-grid {
          grid-template-columns: 1fr;
          gap: 17px;
        }
     
     
     /* ============================================================
        パララックスセクション
        ============================================================ */
     .parallax_section {
       height: 162px;
     }
     .parallax_section span {
       /* position: fixed;
       top: 0;
       left: 0;
       width: 100vw;
       height: 100vh; */
       background-attachment: scroll;
       background-image: url(/manage/wp-content/themes/myakuzumi/assets/img/202603/sp/sp_parallax_view.jpg);
       background-size: cover;
       z-index: -1;
      }
    
     /* ============================================================
        季節で楽しむ宮古島
        ============================================================ */
     .seasonal-section {
       background: #dce7ed;
     }
     
     /* 季節カードは article-card スタイルを継承 */
     .seasonal-grid .article-card {
       /* article-card のスタイルがそのまま適用される */
     }
     .seasonal-grid .article-card__img {
       height: 260px;
     }
     .article-card__season {
       color: var(--white);
       font-size: 18px;
       display: flex;
       align-items: center;
       justify-content: center;
       width: 48px;
       height: 48px;
       background: var(--season-color);
       border-radius: 24px;;
     }¥
     .seasonal-grid .article-card__link {
       text-align: center;
     }
     /* ============================================================
        宮古島ニュース
        ============================================================ */
     .news-item {
      padding: 10px 10px 10px 12px;
     }
          
     .news-thumb {
        width: 92.5px;
        height: 57.5px;
        border-radius: 13.5px;
     }
     .news-content {
      padding-left: 16px;
     }     
     .news-meta {
       gap: 6px;
     }
     .news-date,
     .news-title {
       font-size: 12px;
     }
     .news-tag {
       font-size: 7px;
       padding: 4.5px 5px;
       min-width: 50px;
     }
    .news-title {
      line-height: calc(30/24);
      margin-top: 8.5px;
    }
    
    /* ニュースカテゴリリスト */
    .news_category_list {
      grid-template-columns: repeat(2, 1fr);
      margin-top: 25px;
    }
     
    /* ============================================================
    みゃーくずみとは？（about-section）
    ============================================================ */
    .about-section {
      height: 204px;
      background-image: url(/manage/wp-content/themes/myakuzumi/assets/img/202603/sp/sp_myakuzumi_bg.jpg);
      background-size: cover;
      padding: 0 16px;
    }
     
    /* ============================================================
    会員限定セクション
    ============================================================ */
     .member-desc {
      font-size: 16px;
     }
     
     .member-section .article-grid {
       margin-top: 50px;
     }
     
     .member-register-link {
        margin-top: 25px;
        max-width: 285px;
     }
     
     /* ============================================================
        Instagram / SNS
        ============================================================ */
     .sns-section {
     }
     
     .sns-title {
       font-size: 48px;
       letter-spacing: 0.1em;
       text-align: center;
     }
     
     /* .sb_instagram_header {
       display: none;
     }
     #sbi_images {
       font-size: 0;
     }
     .sbi_photo_wrap > a.sbi_photo:not(:last-child) {
       position: absolute;
     } */

     /* サイドバー */
     .fixed_menu {
        flex-direction: row;
        gap: 1px;
        position: fixed;
        width: 100vw;
        height: auto;
        bottom: 0;
      }
      .fixed_menu a {
        flex: 1;
        width: auto;
        height: auto;
       }
     /* ============================================================
     ロゴフッター（ページ最下部ロゴエリア）
     ============================================================ */
     footer {
       background-image: url(/manage/wp-content/themes/myakuzumi/assets/img/202603/sp/footer_bg_sp.png);
       background-size: cover;
     }
     .footer_main {
       padding-top: calc(17000vw / 770);
     }
     .footer_logo img {
       height: calc(8300vw / 770);
     }
     .footer-nav,
     .footer_copyright {
       font-size: calc(2200vw / 770);
     }
     .footer-nav,
     .footer-nav a:not(.footer_sns_icon) {       
      gap: 5px;
    }
    .footer-nav {
      justify-content: center;
    }
    .footer-nav a:not(.footer_sns_icon) {
      flex-direction: row-reverse;
    }
     .footer-nav a:not(.footer_sns_icon):before {
       content: "|";
       display: block;
       width: auto;
       height: auto;
       background-image: none;
     }
     .footer_sns_icon svg {
       height: calc(2300vw / 770);
     }
     .footer_copyright {
       padding: calc(4000vw / 770) 0 calc(12000vw / 770);
     }
     .footer_top_btn {
       width: calc(10000vw / 770);
       height: calc(10000vw / 770);
       bottom: calc(70000vw / 770);
       right: 0;
     }
     .footer_top_btn a {
       gap: calc(1200vw / 770);
     }
     .footer_top_btn .totop_arrow {
       width: calc(1500vw / 770);
     }
     .footer_top_btn span {
       font-size: calc(2200vw / 770);
     }
     @supports (-webkit-touch-callout: none) {
      .footer-sticky {
        position: fixed;
      }
    }
   
     .nav-pc, .content_pc { display: none; }
     .content_sp { display: block; }
   }
   