@charset "utf-8";
:root {
  --key: linear-gradient(90deg, #134987 0%, #1a569b 100%); /* キーカラーグラデ */
  --key-2: #1a569b; /* ロゴの青 */
  --accent: #eca22a; /* 差し色（ロゴのオレンジ） */
  --text: #111;
  --bg: #fff;
  --muted: #eef2f6; /* 薄い背景 */
}
* {
  margin: 0;
  padding: 0;
}
body {
  /*font-family: "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;*/
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
html {
  scroll-behavior: smooth;
}
.brcl {
  clear: both;
}
a {
  text-decoration: underline;
}
.decoration_none a {
  text-decoration: none !important;
}
a:link {
  text-decoration: underline;
  font-weight: bold;
}
a:visited {}
a:hover {
  text-decoration: underline;
}
a img {
  border: none;
  margin: 0;
  padding: 0;
  vertical-align: bottom;
}
a:hover, a:hover img, a:hover:after {
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
/* =============================================================================================== */
/* ===== 基本設定 ===== */
/* =============================================================================================== */
section {
  padding: 20px;
}
.lightning_swiper {
  background-image:
    linear-gradient(rgba(0, 0, 0, 0.45), rgba(0, 0, 0, 0.65));
}
.wrap {
  max-width: 1180px;
  margin: 0 auto;
  padding: 24px;
}
.section {
  margin: 32px 0;
}
.pill {
  background: #f3f3f3;
  padding: 10px 12px;
  border-radius: 10px;
}
section h2 {
  font-size: 2.4rem;
  font-weight: 700;
  margin: 20px 0;
  line-height: 2.0;
  text-align: center;
}
section h3 {
  font-size: 1.8rem;
  margin: 10px 0;
  line-height: 1.6
}
h1.entry-title {
  font-size: 1.8rem;
  margin: 20px 0;
  line-height: 1.6;
}
/* =============================================================================================== */
/* ===== 装飾共通 ===== */
/* =============================================================================================== */
.no_deco a, span.no_deco a {
  text-decoration: none;
}
.border_none {
  border: none !important
}
.border_btm_333 {
  border-bottom: 1px solid #333;
}
.kado5 {
  border-radius: 5px;
}
.kado10 {
  border-radius: 10px;
}
.tag {
  display: inline-block;
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  background: #eee;
  margin: 0 6px 6px 0;
}
.card {
  background: none;
  border-radius: 12px;
  box-shadow: 0 5px 10px rgba(0, 0, 0, .05);
  overflow: hidden;
}
.card__maintitle {
  font-weight: 700;
  padding: 10px 0 0 0;
  text-align: center;
  background: var(--key);
  color: #fff;
  border-bottom: 1px solid #999;
}
.card__body {
  padding: 16px;
}
.card__title {
  font-weight: 700;
  margin: 0 0 8px;
}
.card img {
  object-fit: cover; /* 伸びてもトリミングで埋める */
  display: block;
  line-height: 0;
}
.iconbox {
  background: #fff;
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 5px 10px rgba(0, 0, 0, .05);
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.iconbox i {
  font-size: 22px;
  width: 32px;
  text-align: center;
  margin-top: 2px;
}
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 20px;
  padding: 10px 14px;
  border-radius: 10px;
  background: var(--key);
  color: #fff;
  color: #fff;
  text-decoration: none;
  font-weight: 700;
}
a.btn {
  color: #fff !important;
  text-decoration: none;
}
.btn--ghost {
  background: #fff;
  color: #111;
  border: 1px solid #ddd;
}
.hr {
  height: 1px;
  background: #e5e5e5;
  margin: 18px 0;
}
th.price_top {
  background: #444;
  color: #fff;
}
td.price_01 {
  background: #dcdcdc;
  text-align: center;
}
td.price_02,td.price_02_center {
  text-align: center;
}
td.price_mid {
  background: #666;
  color: #fff;
}
td.price_mid_size {
  background: #666;
  color: #fff;
  text-align: center;
}
td.price02_uru {
  background: linear-gradient(135deg, #f2f2f2, #d9d9d9, #ffffff);
  text-align: center;
}
td.price02_pre {
  background: linear-gradient(135deg, #f5e6b3, #d4af37, #fff2cc);
  text-align: center;
}
/* =============================================================================================== */
/* ===== Gap ===== */
/* =============================================================================================== */
.grid {
  display: grid;
  margin-bottom: 40px;
}
.grid_item {
  border-radius: 10px;
}
.gap_0 {
  gap: 0;
}
.gap_10 {
  gap: 10px;
}
.gap_20 {
  gap: 20px;
}
.gap_30 {
  gap: 30px;
}
.gap_40 {
  gap: 40px;
}
@media screen and (min-width:781px) {
  /* ===== PC Grid Columns ===== */
  .pc_col_1 {
    grid-template-columns: 1fr;
  }
  .pc_col_2 {
    grid-template-columns: repeat(2, 1fr);
  }
  .pc_col_3 {
    grid-template-columns: repeat(3, 1fr);
  }
  .pc_col_4 {
    grid-template-columns: repeat(4, 1fr);
  }
  .pc_col_5 {
    grid-template-columns: repeat(5, 1fr);
  }
}
@media screen and (min-width:240px) and (max-width:780px) {
  .sp_col_1 {
    grid-template-columns: 1fr;
  }
  .sp_col_2 {
    grid-template-columns: repeat(2, 1fr);
  }
  .sp_col_3 {
    grid-template-columns: repeat(3, 1fr);
  }
}
/* =============================================================================================== */
/* ===== 画像  ===== */
/* =============================================================================================== */
img {
  max-width: 100%;
  height: auto;
}
.img_w100 {
  width: 100%;
  height: auto;
}
.img_w100_only {
  width: 100%;
}
.thumb {
  width: 100%;
  object-fit: cover;
  display: block;
}
.thumb_16_9 {
  aspect-ratio: 16/9;
}
.thumb_sq {
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
  display: block;
}
/* =============================================================================================== */
/* ===== margin  padding ===== */
/* =============================================================================================== */
@media screen and (min-width:781px) {
  .m_top_0 {
    margin-top: 0 !important;
  }
  .m_bottom_0 {
    margin-bottom: 0 !important;
  }
  .p_all_0 {
    padding: 0px !important;
  }
  .p_top_0 {
    padding-top: 0px !important;
  }
  .p_bottom_0 {
    padding-bottom: 0px !important;
  }
  .m_left_5 {
    margin-left: 5px !important;
  }
  .m_right_5 {
    margin-right: 5px !important;
  }
  .m_top_5 {
    margin-top: 5px !important;
  }
  .m_top_-5 {
    margin-top: -5px !important;
  }
  .m_bottom_5 {
    margin-bottom: 5px !important;
  }
  .m_bottom_-5 {
    margin-bottom: -5px !important;
  }
  .p_top_5 {
    padding-top: 5px !important;
  }
  .p_bottom_5 {
    padding-bottom: 5px !important;
  }
  .p_bottom_-5 {
    padding-bottom: -5px !important;
  }
  .m_top_10 {
    margin-top: 10px !important;
  }
  .m_bottom_10 {
    margin-bottom: 10px !important;
  }
  .m_left_10 {
    margin-left: 10px !important;
  }
  .m_right_10 {
    margin-right: 10px !important;
  }
  .p_top_10 {
    padding-top: 10px !important;
  }
  .p_bottom_10 {
    padding-bottom: 10px !important;
  }
  .p_all_5 {
    padding: 5px !important;
  }
  .p_all_10 {
    padding: 10px !important;
  }
  .m_top_15 {
    margin-top: 15px !important;
  }
  .m_top_20 {
    margin-top: 20px !important;
  }
  .m_top_-20 {
    margin-top: -20px !important;
  }
  .m_bottom_20 {
    margin-bottom: 20px !important;
  }
  .m_bottom_-20 {
    margin-bottom: -20px !important;
  }
  .m_left_20 {
    margin-left: 20px !important;
  }
  .m_right_20 {
    margin-right: 20px !important;
  }
  .p_top_20 {
    padding-top: 20px !important;
  }
  .p_bottom_20 {
    padding-bottom: 20px !important;
  }
  .p_left_20 {
    padding-left: 20px !important;
  }
  .p_right_20 {
    padding-right: 20px !important;
  }
  .p_all_20 {
    padding: 20px !important;
  }
  .m_top_30 {
    margin-top: 30px !important;
  }
  .m_bottom_30 {
    margin-bottom: 30px !important;
  }
  .m_left_30 {
    margin-left: 30px !important;
  }
  .m_right_30 {
    margin-right: 30px !important;
  }
  .m_top_40 {
    margin-top: 40px !important;
  }
  .m_top_-40 {
    margin-top: -40px !important;
  }
  .m_bottom_40 {
    margin-bottom: 40px !important;
  }
  .m_left_40 {
    margin-left: 40px !important;
  }
  .m_right_40 {
    margin-right: 40px !important;
  }
  .p_top_40 {
    padding-top: 40px !important;
  }
  .p_bottom_40 {
    padding-bottom: 40px !important;
  }
  .p_left_40 {
    padding-left: 40px !important;
  }
  .p_right_40 {
    padding-right: 40px !important;
  }
  .p_all_40 {
    padding: 40px !important;
  }
  .m_top_60 {
    margin-top: 60px !important;
  }
  .m_bottom_60 {
    margin-bottom: 60px !important;
  }
  .m_left_60 {
    margin-left: 60px !important;
  }
  .m_right_60 {
    margin-right: 60px !important;
  }
  .p_top_60 {
    padding-top: 60px !important;
  }
  .p_bottom_60 {
    padding-bottom: 60px !important;
  }
  .m_top_80 {
    margin-top: 80px !important;
  }
  .m_bottom_80 {
    margin-bottom: 80px !important;
  }
  .m_top_100 {
    margin-top: 100px !important;
  }
  .m_top_-100 {
    margin-top: -100px !important;
  }
  .m_bottom_100 {
    margin-bottom: 100px !important;
  }
  .m_left_100 {
    margin-left: 100px !important;
  }
  .m_right_100 {
    margin-right: 100px !important;
  }
  .p_top_100 {
    padding-top: 100px !important;
  }
  .p_bottom_100 {
    padding-bottom: 100px !important;
  }
  .m_top_200 {
    margin-top: 200px !important;
  }
  .m_bottom_200 {
    margin-bottom: 200px !important;
  }
  .p_bottom_200 {
    padding-bottom: 200px !important;
  }
  .m_top_400 {
    margin-top: 400px !important;
  }
  .p_top_400 {
    padding-top: 400px !important;
  }
  .m_top_500 {
    margin-top: 500px !important;
  }
  .m_top_600 {
    margin-top: 600px !important;
  }
  .p_bottom_600 {
    padding-bottom: 600px !important;
  }
  .m_top_700 {
    margin-top: 700px !important;
  }
  .m_top_800 {
    margin-top: 800px !important;
  }
}
@media screen and (min-width:240px) and (max-width:780px) {
  .sp_m_all_0 {
    margin: 0 !important
  }
  .sp_p_all_0 {
    padding: 0 !important
  }
  .sp_m_top_0 {
    margin-top: 0 !important
  }
  .sp_m_bottom_0 {
    margin-bottom: 0 !important
  }
  .sp_p_all_5 {
    padding: 5px !important
  }
  .sp_p_top_5 {
    padding-top: 5px !important
  }
  .sp_p_bottom_5 {
    padding-bottom: 5px !important
  }
  .sp_m_top_10 {
    margin-top: 10px !important
  }
  .sp_m_bottom_10 {
    margin-bottom: 10px !important
  }
  .sp_m_left_10 {
    margin-left: 10px !important
  }
  .sp_p_all_10 {
    padding: 10px
  }
  .sp_p_top_10 {
    padding-top: 10px !important
  }
  .sp_p_left_10 {
    padding-left: 10px !important
  }
  .sp_p_all_20 {
    padding: 20px
  }
  .sp_m_top_20 {
    margin-top: 20px !important
  }
  .sp_m_bottom_20 {
    margin-bottom: 20px !important
  }
  .sp_p_top_20 {
    padding-top: 20px !important
  }
  .sp_p_bottom_20 {
    padding-bottom: 20px !important
  }
  .sp_p_all_20 {
    padding: 20px !important
  }
  .sp_m_top_-30 {
    margin-top: -30px !important
  }
  .sp_m_top_40 {
    margin-top: 40px !important
  }
  .sp_m_bottom_40 {
    margin-bottom: 40px !important
  }
  .sp_m_top_-50 {
    margin-top: -50px !important
  }
  .sp_p_top_50 {
    padding-top: 50px !important
  }
  .sp_m_top_60 {
    margin-top: 60px !important
  }
  .sp_m_bottom_60 {
    margin-bottom: 60px !important
  }
  .sp_m_left_60 {
    margin-left: 60px !important
  }
  .sp_p_top_60 {
    padding-top: 60px !important;
  }
  .sp_p_bottom_60 {
    padding-bottom: 60px !important;
  }
  .sp_m_top_80 {
    margin-top: 5pc !important
  }
  .sp_m_bottom_80 {
    margin-bottom: 5pc !important
  }
  .sp_m_left_80 {
    margin-left: 5pc !important
  }
  .sp_m_top_100 {
    margin-top: 75pt !important
  }
  .sp_m_bottom_100 {
    margin-bottom: 75pt !important
  }
  .sp_m_left_100 {
    margin-left: 75pt !important
  }
  .sp_p_top_100 {
    padding-top: 75pt !important
  }
  .sp_p_bottom_100 {
    padding-bottom: 75pt !important
  }
  .sp_p_top_200 {
    padding-top: 200px !important
  }
  .sp_p_bottom_200 {
    padding-bottom: 200px !important
  }
}
/* =============================================================================================== */
/* ===== フォントサイズ  ===== */
/* =============================================================================================== */
@media screen and (min-width:781px) {
  .l-h10 {
    line-height: 1.0 !important;
  }
  .l-h12 {
    line-height: 1.2 !important;
  }
  .l-h20 {
    line-height: 2.0 !important;
  }
  .l-h30 {
    line-height: 3.0 !important;
  }
  .l-h20px {
    line-height: 20px !important;
  }
  .l-h30px {
    line-height: 30px !important;
  }
  .f10 {
    font-size: 10px !important;
  }
  .f12 {
    font-size: 12px !important;
  }
  .f13 {
    font-size: 13px !important;
  }
  .f14 {
    font-size: 14px !important;
  }
  .f15 {
    font-size: 15px !important;
  }
  .f16 {
    font-size: 16px !important;
  }
  .f18 {
    font-size: 18px !important;
  }
  .f20 {
    font-size: 20px !important;
  }
  .f24 {
    font-size: 24px !important;
  }
  .f28 {
    font-size: 28px !important;
  }
  .f36 {
    font-size: 36px !important;
  }
  .f48 {
    font-size: 48px !important;
  }
  .f60 {
    font-size: 60px !important;
  }
  .f72 {
    font-size: 72px !important;
  }
  .f108 {
    font-size: 108px !important;
  }
}
@media screen and (min-width:240px) and (max-width:780px) {
  .sp_l-h12 {
    line-height: 1.2 !important
  }
  .sp_l-h20 {
    line-height: 2 !important
  }
  .sp_f10 {
    font-size: 10px !important
  }
  .sp_f12 {
    font-size: 12pt !important
  }
  .sp_f13 {
    font-size: 13px !important
  }
  .sp_f14 {
    font-size: 14px !important
  }
  .sp_f15 {
    font-size: 15px !important
  }
  .sp_f16 {
    font-size: 1pc !important
  }
  .sp_f18 {
    font-size: 18px !important
  }
  .sp_f20 {
    font-size: 20px !important
  }
  .sp_f24 {
    font-size: 24px !important
  }
  .sp_f30 {
    font-size: 30px !important
  }
  .sp_f36 {
    font-size: 36px !important
  }
}
/* =============================================================================================== */
/* ===== フォント 装飾  ===== */
/* =============================================================================================== */
.mincho {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif !important;
}
.michroma {
  font-family: 'Michroma', sans-serif;
}


.p_bold {
  font-weight: bold !important;
}
.p_center {
  text-align: center !important;
}
.p_left {
  text-align: left !important;
}
.p_right {
  text-align: right !important;
}
.p_gold {
  color: #ba9953 !important;
}
.p_white {
  color: #FFFFFF !important;
}
.a_white a {
  color: #FFFFFF !important;
}
@media screen and (min-width:781px) {}
@media screen and (min-width:240px) and (max-width:780px) {
  .sp_p_center {
    text-align: center !important
  }
}
/* =============================================================================================== */
/* ===== 背景  ===== */
/* =============================================================================================== */
.bgfff, .bgfff:hover {
  background-color: #fff !important;
}
.bg000, .bg000:hover {
  background-color: #000 !important;
}
.bg111, .bg111:hover {
  background-color: #111 !important;
}
.bg222, .bg222:hover {
  background-color: #222 !important;
}
.bg333, .bg333:hover {
  background-color: #333 !important;
}
.bg666, .bg666:hover {
  background-color: #666 !important;
}
.bgccc, .bgccc:hover {
  background-color: #ccc !important;
}
.bgddd, .bgddd:hover {
  background-color: #ddd !important;
}
.bgdedede, .bgdedede:hover {
  background-color: #dedede !important;
}
.bgeee, .bgeee:hover {
  background-color: #eee !important;
}
.bggold {
  background-color: #ad8c47 !important;
}
.bgred {
  background-color: #c22929 !important;
}
@media screen and (min-width:781px) {}
@media screen and (min-width:240px) and (max-width:780px) {}
/* =============================================================================================== */
/* ===== 画面横幅MAX  ===== */
/* =============================================================================================== */
.max-w_240 {
  max-width: 240px !important;
  margin: 0 auto;
}
.max-w_300 {
  max-width: 300px !important;
  margin: 0 auto;
}
.max-w_320 {
  max-width: 320px !important;
  margin: 0 auto;
}
.max-w_400 {
  max-width: 400px !important;
  margin: 0 auto;
}
.max-w_480 {
  max-width: 480px !important;
  margin: 0 auto;
}
.max-w_500 {
  max-width: 500px !important;
  margin: 0 auto;
}
.max-w_540 {
  max-width: 540px !important;
  margin: 0 auto;
}
.max-w_640 {
  max-width: 640px !important;
  margin: 0 auto;
}
.max-w_760 {
  max-width: 760px !important;
  margin: 0 auto;
}
.max-w_800 {
  max-width: 800px !important;
  margin: 0 auto;
}
.max-w_960 {
  max-width: 960px !important;
  margin: 0 auto;
}
.max-w_1200 {
  max-width: 1200px !important;
  margin: 0 auto;
}
.max-w_1280 {
  max-width: 1280px !important;
  margin: 0 auto;
}
.max-w_1400 {
  max-width: 1400px !important;
  margin: 0 auto;
}
.max-w_1600 {
  max-width: 1600px !important;
  margin: 0 auto;
}
@media screen and (min-width:781px) {}
@media screen and (min-width:240px) and (max-width:780px) {}
/* =============================================================================================== */
/* ===== お問い合わせフォーム  ===== */
/* =============================================================================================== */
.infobox {
  display: table;
}
.infobox_left {
  width: 280px;
  padding: 3px 20px;
  display: table-cell;
  vertical-align: middle;
  border-bottom: 1px dotted #333;
  font-size: 18px;
  font-weight: bold;
  background-color: #f7f7f7;
}
.infobox_right {
  width: 440px;
  padding: 20px;
  display: table-cell;
  vertical-align: middle;
  border-bottom: 1px dotted #333;
  line-height: 2em;
  font-size: 18px;
  float: none;
  padding-bottom: 10px;
  background: #fff;
}
.infobox_left img {
  vertical-align: middle;
}
.infotopbb {
  border-top: 1px dotted #333;
}
.infopp {
  margin: 5%;
  padding: 4%;
  width: 80%;
  height: 150px;
  border: solid 1px #666666;
  background-color: #f7f7f7;
  overflow: scroll;
}
.infobtn_pc {
  margin-left: 120px;
}
.infobtn_pc_02 {
  margin-left: 50px;
}
span.nini {
  background-color: #3366FF;
  color: #FFFFFF;
  padding: 2px 5px;
  margin-right: 10px;
  vertical-align: middle;
  font-size: 12px;
}
span.hissu {
  background-color: #FF3300;
  color: #FFFFFF;
  padding: 2px 5px;
  margin-right: 10px;
  vertical-align: middle;
  font-size: 12px;
}
span.infotitle {
  margin: 10px 0 5px 0;
  padding: 0;
  font-size: 18px;
  color: #666;
  border-bottom: none;
  border-top: none;
  line-height: 2.0;
  font-family: "ＭＳ Ｐ明朝", "細明朝体", "ヒラギノ明朝 Pro W3";
  vertical-align: middle;
  font-weight: bold;
}
textarea {
  width: 98%;
  padding: 1%;
  font-size: 16px;
}
input {
  padding: 10px;
}
input[type="button"] {
  background-color: #ccc;
  color: #333;
  margin-top: 40px;
  margin-right: 20px;
  padding: 14px 30px;
  border: 1px solid #c22929;
}
input[type="button"]:hover {
  background-color: #fff;
}
input[type="submit"] {
  background-color: #111;
  color: #fff;
  margin-top: 40px;
  margin-right: 20px;
  padding: 14px 30px;
  border: 1px solid #c22929;
  border-bottom: 3px solid #c22929;
}
input[type="submit"]:hover {
  background-color: #444;
}
input[type=text] {
  border-radius: 5px;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  -o-border-radius: 5px;
  -ms-border-radius: 5px;
  border: #a9a9a9 1px solid;
  -moz-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2), 0 0 2px rgba(0, 0, 0, 0.3);
  -webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2), 0 0 2px rgba(0, 0, 0, 0.3);
  box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2), 0 0 2px rgba(0, 0, 0, 0.3);
  width: 100%;
  height: 2em;
  padding: 0;
  font-size: 16px;
  resize: none;
}
input[type=text]:focus {
  border: solid 1px #20b2aa;
}
input[type=text], select {
  outline: none;
}
input.history_back {
  padding: 15px 50px;
}
iframe {
  border: none;
}
@media screen and (min-width:781px) {}
@media screen and (min-width:240px) and (max-width:780px) {
  .infobox {
    display: block
  }
  .infobox_left {
    padding: 0;
    border-bottom: 0;
    padding-top: 10px;
    font-size: 18px;
    font-weight: 700
  }
  .infobox_left, .infobox_right {
    width: 100%;
    display: block;
    vertical-align: center
  }
  .infobox_right {
    padding: 3px 0 10px;
  }
  .infobox_left img {
    vertical-align: center
  }
  span.infotitle {
    font-size: 24px;
  }
  select {
    width: 60%;
    margin: 0 20%;
    font-size: 1pc
  }
  textarea {
    font-size: 1pc;
    resize: none
  }
}
/* =============================================================================================== */
/* =====  youtube  ===== */
/* =============================================================================================== */
.youtube {
  display: inline-block;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: auto;
}
.youtube::before {
  position: absolute;
  content: "動画を再生する";
  color: #fff;
  text-align: center;
  font-size: 22px;
  font-weight: bold;
  line-height: 260px;
  background: rgba(0, 0, 0, 0.6);
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  transition: all 0.3s;
}
.youtube:hover::before {
  background: rgba(0, 0, 0, 0.7);
  cursor: pointer;
  transition: all 0.3s;
}
/* =============================================================================================== */
/* ===== Googleマップ  ===== */
/* =============================================================================================== */
.gmap_pc iframe {
  width: 100%
}
.gmap {
  height: 0;
  overflow: hidden;
  padding-bottom: 56.25%;
  position: relative;
}
.gmap iframe {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
}
/* =============================================================================================== */
/* ===== スマホ スクロール  ===== */
/* =============================================================================================== */
@media screen and (min-width:240px) and (max-width:780px) {
  .sp_scroll table {
    width: 100%;
  }
  .sp_scroll {
    overflow: auto; /*tableをスクロールさせる*/
    white-space: nowrap; /*tableのセル内にある文字の折り返しを禁止*/
  }
  .sp_scroll::-webkit-scrollbar { /*tableにスクロールバーを追加*/
    height: 5px;
  }
  .sp_scroll::-webkit-scrollbar-track { /*tableにスクロールバーを追加*/
    background: #F1F1F1;
  }
  .sp_scroll::-webkit-scrollbar-thumb { /*tableにスクロールバーを追加*/
    background: #BCBCBC;
  }
}
/* =============================================================================================== */
/* ===== クリック領域  ===== */
/* =============================================================================================== */
.ac-child {
  display: none;
}
.ac-parent {
  position: relative; /* 追加 */
  border-bottom: 5px solid #fff;
  background: var(--key);
  color: #fff;
  text-align: left;
  line-height: 50px;
  cursor: pointer;
  padding: 10px 0 10px 21px; /*上、右、下、左*/
}
.ac-parent p {
  padding: 10px 50px 10px 0 !important; /*上、右、下、左*/
}
/* ①プラスの横線 */
.ac-parent:before {
  content: "";
  position: absolute;
  top: 50%;
  right: 8px;
  width: 24px;
  height: 2px;
  background: #fff;
  transform: translateY(-50%);
  margin: 0px 21px 0px 21px; /*上、右、下、左*/
}
/* ②プラスの縦線 */
.ac-parent:after {
  content: "";
  position: absolute;
  top: 50%;
  /* 8px+12px-1px(幅2pxの半分) */
  right: 19px;
  width: 2px;
  height: 24px;
  background: #fff;
  transform: translateY(-50%);
  transition: .3s;
  margin: 0px 21px 0px 21px; /*上、右、下、左*/
}
/* ③オープン時にopenクラスを付与（縦線を回転させて非表示に） */
.ac-parent.open:after {
  top: 25%;
  opacity: 0;
  transform: rotate(90deg);
}
.area li {
  float: left;
  width: 23%;
  margin: 1%;
  font-size: 13px;
  border: 1px solid var(--key);
  ;
  text-align: center;
}
.area li a {
  display: block;
  line-height: 28px;
  text-decoration: none;
  background-color: #eee;
  border-radius: 5px;
}
.area li a:hover {
  display: block;
  text-decoration: none;
  background-color: #ddd;
  border-radius: 5px;
}
.area li.maker {
  float: left;
  width: 8%;
  margin: 1%;
  font-size: 13px;
}
.area li.maker a {
  display: block;
  line-height: 28px;
  text-decoration: none;
  background-color: #fff;
}
.area li.maker a:hover {
  display: block;
  text-decoration: none;
  background-color: #4c5e6e;
}

/* =============================================================================================== */
/* =====　口コミ（PC：4列 / SP：横スワイプ） ===== */
/* =============================================================================================== */

.voice {
  background: linear-gradient(135deg, #F8F9FA 0%, #E9ECEF 100%);
  position: relative;
  padding: 60px 0;
  overflow: hidden;
}
.voice::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 30% 40%, rgba(255, 140, 66, 0.03) 0%, transparent 50%);
  z-index: 0;
}
.voice .max-w_1200 {
  position: relative;
  z-index: 1;
}
.accent {
  color: #FF8C42;
}

/* PC：4枚横並び（必要なら折り返し） */
.voice-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

/* 各カード */
.voice-card {
  background: #fff;
  padding: 24px;
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
  transition: all 0.3s ease;
}
.voice-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}

/* アバター＋写真 */
.voice-content-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-bottom: 16px;
}
.avatar-placeholder {
  width: 56px;
  height: 56px;
  background: linear-gradient(135deg, #FF8C42 0%, #E67E22 100%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 22px;
  font-weight: 600;
  box-shadow: 0 4px 12px rgba(255,140,66,0.3);
  flex-shrink: 0;
}
.voice-photo {
  width: 140px;
  height: 80px;
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  margin-left: auto;
}
.voice-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* テキスト */
.voice-info h4 {
  font-size: 16px;
  font-weight: 600;
  color: #343A40;
  margin: 0 0 4px;
}
.voice-info span {
  font-size: 13px;
  color: #6C757D;
}
.voice-comment {
  margin: 16px 0;
  color: #343A40;
  line-height: 1.8;
  font-style: italic;
  position: relative;
  padding-left: 18px;
}
.voice-comment::before {
  content: '"';
  position: absolute;
  left: 0;
  top: -6px;
  font-size: 30px;
  color: #FF8C42;
  font-family: serif;
}
.voice-rating .stars {
  color: #FFD700;
  font-size: 18px;
}

/* 画面幅で列数調整（任意だけど実用的） */
@media screen and (max-width: 1024px) {
  .voice-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media screen and (max-width: 768px) {
  .voice-list { grid-template-columns: 1fr; }
}

/* SP：横スワイプ（スライダー風） */
@media screen and (max-width: 480px) {
  .voice-list {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 0 16px;
  }

  .voice-card {
    flex: 0 0 80%;
    scroll-snap-align: start;
  }

  /* スクロールバーを目立たせない（任意） */
  .voice-list::-webkit-scrollbar { height: 6px; }
  .voice-list::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.15); border-radius: 999px; }

  .avatar-placeholder { width: 60px; height: 60px; font-size: 22px; }
  .voice-photo { width: 120px; height: 120px; }
  .voice-rating .stars { font-size: 20px; }
}


/* =============================================================================================== */
/* =====   ===== */
/* =============================================================================================== */
@media screen and (min-width:781px) {
  .pc_none {
    display: none;
  }
}
@media screen and (min-width:240px) and (max-width:780px) {
  .sp_none {
    display: none;
  }
}
/* =============================================================================================== */
/* =====   ===== */
/* =============================================================================================== */
@media screen and (min-width:781px) {}
@media screen and (min-width:240px) and (max-width:780px) {}