@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
*/

html {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

*, *::before, *::after {
  box-sizing: inherit;
}

body {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  color: #333;
  font-size: 16px;
  font-family: YuGothic, '游ゴシック',"Noto Sans JP", Meiryo, sans-serif;
}

/* ========== 共通 ========== */
/* ========== ここから共通 SWELL========== */
p {
  margin-top: 16px;
  margin-bottom: 16px;
}

.l-content {
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-top: 0 !important;
}

/* navigation contact btn */
.mail, .telephone {
  white-space : nowrap;
}

.telephone p {
  margin: 0;
  color: #09491a;
}

.telephone01 {
  padding-top: 10px;
}

.telephone02 {
  padding-bottom: 10px;
}

.nav-cta {
  display: flex;
  flex-direction: row;
  align-items: center;
}
/* ========== ここまで共通 SWELL========== */
.section {
  display: flex;
  justify-content: center;
  padding: 80px 0;
}

.inner {
  width: 90%;
  max-width: 1100px;
}

.section-title {
  text-align: center;
}

.section-title h2 {
  letter-spacing: 0.1rem;
  font-size: 2rem;
  font-weight: 500;
  margin-top: 10px;
  margin-bottom: 100px;
  /* font-family: "Zen Kaku Gothic New", sans-serif; */
  font-family: "游明朝", YuMincho;
  position: relative;
}

.section-title-eng {
  letter-spacing: 0.1rem;
  font-size: 1.1rem;
  position: relative;
  display: none;
}

.section-title h2::after {
  content: "";
  background-color: green;
  width: 60px;
  height: 3px;
  position: absolute;
  bottom: -8px;
  left: 50%;
  transform: translateX(-50%); 
}

/* ========== main visual ========== */
.main-visual-original {
  display: flex;
  position: relative;
}

.main-visual-left-logo {
  margin-left: 50px;
}

.main-visual-img {
  height: 100vh;
  width: 70%;
  position: relative;   /* Vegas */
  overflow: hidden;     /* スライドのはみ出し防止 */
}

.main-visual-left-logo {
  width: 30%;
}

.main-visual-left-text {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: clamp(20px, 15vw, 150px);
  color: #09491a;
  writing-mode: vertical-rl;
}

.main-visual-left-text h2 {
  white-space: nowrap;
  font-size: 1.5rem;
  line-height: 3.5rem;
  font-weight: 900;
  font-family: "游明朝", YuMincho, "Midashi Go MB31", "YuGothic";
}

.main-visual-left-text h2::after {
  content: none;
}

.mv-line-bold {
  font-size: 2.5rem;
}

.mv-line {
  background-color: rgba(255, 255, 255, 0.95); /* 白背景（透明80%） */
  display: inline-block;
  padding: 10px 5px;
  margin: 5px;
}

/* ========== greeting-section ========== */
.greetings-section {
  background-color: #ECF8EC;
}

/* 画像＋テキストの2カラム */
.greetings-wrap {
  display: flex;
  gap: 40px;
  align-items: flex-start;
}

.greetings-img,
.greetings-content {
  width: 50%;
}

/* 画像エリア */
.greetings-img {
  position: relative;
}

.img-main-l {
  height: 450px;
}

.img-main,
.img-sub {
  border-radius: 5%;
  object-fit: cover;  
}

.img-main {
  width: 80%;
  height: 100%;
  object-fit: cover;
  object-position: right;
}

.img-sub {
  position: absolute;
  top: 350px;
  right: 20px;
  width: 250px;
  height: 150px;
  opacity: 0.95;
  object-position: center;
  overflow: hidden;  
}

/* テキストエリア */
.greetings-content {
  padding: 0 40px 0 40px;
}

.greetings-lead {
  font-size: 1.4rem;
  letter-spacing: 0.25rem;
  font-weight: 550;
  margin: 40px 0 24px;
  font-family: "游明朝", YuMincho;
}

.greetings-description {
  letter-spacing: 0.1rem;
  font-size: 0.95rem;
  line-height: 1.9;
}

/* 署名部分 */
.greetings-signature {
  margin-top: 24px;
  text-align: right;
}

.name {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  font-size: 1.5rem;
  letter-spacing: 0.1rem;
  gap: 8px;
}




/* ========== service section ========== */
.service-section {
  background-color: #faf7d7;
  /* background: linear-gradient(to bottom, #FAF7D7 0%, #FAF7D7 10%, white 30%, #FAF7D7 50%); */
}

.service-section-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.service-subtext {
  width: 75%;
  margin-bottom: 50px;
  line-height: 1.5rem;
  text-align: center;
}

.service-subtext span {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 2.2rem;
  color: #09491a;
  font-family: "Zen Kaku Gothic New", sans-serif;
}

.service-wrap {
  box-sizing: border-box;
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  justify-content: center;
  margin: 0 20px;
}

.service-container-link {
  width: 100%;
  display: block;
  text-decoration: none;
  color: #333;
  background-color: #f1ea9a;
}

.service-container {
  width: calc((100% - 30px) / 2);
  min-width: 330px;
  /* position: relative; */
  overflow: hidden;

}

.service-container h3 {
  font-family: "游明朝", "Zen Kaku Gothic New", sans-serif;
  letter-spacing: 0.1rem;
  font-size: 1.5rem;
  padding-left: 1rem;
  margin-bottom: 1rem;
  margin-top: 1rem;
}

.service-container span {
  font-size: 1.8rem;
  color: #508631;
}

.service-container-text {
  /* position: absolute;
  bottom: 0; */
  background-color: rgba(255, 255, 255, 0.94);
}

.service-container-text ul {
  margin: 0;
  padding: 0 1rem 2rem 1rem;
  /* column-count: 2;    */
  column-gap: 10px;       /* ← 列間の余白 */
  list-style-position: inside; /* 丸ポチ位置の調整（任意） */
}

.service-container-text h3 {
  padding-top: 1rem;
  margin-top: 0;
}

.service-container-text li {
  line-height: 2rem;
}

.service-container-link img {
  width: 100%;
  object-fit: cover;
  padding: 10px;
}

.one img {
  width: 100%;
  border-top-left-radius: 80px;
  /* border-bottom-left-radius: 50px; */
  object-fit: contain;
  /* object-position: 80%;  */
  /* transform: scale(1.6); */
  /* transform-origin: 0% 20%;  */
}

.one {
  border-bottom-left-radius: 50px;
  border-top-left-radius: 80px;
}

.two img {
  width: 100%;
  border-top-right-radius: 80px;
  /* border-bottom-right-radius: 50px; */
  object-fit: contain;
  /* object-position: 100% 20%; */
  /* transform: scale(1.6);
  transform-origin: 100% 20%; */
}

.two {
  border-top-right-radius: 80px;
  border-bottom-right-radius: 50px;
}

/* ========== feature section ========== */
.feature-section {
  background: linear-gradient(to bottom, #ECF8EC 0%, #ECF8EC 80%, #F2F0EE 100%);

}
.feature-wrap {
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 30px;
}

.feature-container {
  box-sizing: border-box;
  width: calc((100% - 60px) / 3);
  border-radius: 5%;
  padding: 1rem;
  background-color: white;
  position: relative;
  margin-bottom: 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.colored-box {
  position: absolute;
  left: -16px;
  top: -16px;
  height: 80px;
  width: 80px;
  background-color: #8DC031;
  border-radius: 5%;  
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: white;
}

.colored-box p {
  text-align: center;
  line-height: 1.5rem;
  font-weight: bold;
}

.colored-box span {
  font-size: 1.5rem;
}

.feature-container img {
  width: 90%;
  border-radius: 5%;
  min-height: 100px;
  object-fit: contain;
}

.feature-container h3 {
  text-align: center;
  margin: 1.5rem 0;
  letter-spacing: 0.07rem;
  font-size: 1.2rem;
  font-family: "游明朝", "Zen Kaku Gothic New", sans-serif;
  font-weight: bold;

}

.feature-container p {
  letter-spacing: 0.05rem;
  margin-top: 0;
}


/* ========== contact section ========== */
.contact-section {
  position: relative;
  text-align: center;
  background-image: url(img/meeting.jpeg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: 50%;
  height: auto;
  /* background: linear-gradient(to bottom, #e5f4e5, #f8fff8); */
}

.contact-section::before {
  content: "";
  position: absolute;
  inset: 0;
  /* background-color: rgba(76, 151, 198, 0.8);  */
  z-index: 0; /* 背景画像の上 */
  background: linear-gradient(
    to right,
    rgba(76, 151, 198, 1) 0%,
    rgba(76, 151, 198, 0.8) 30%,
    rgba(76, 151, 198, 0.4) 100%
  );
}

.contact-section > * {
  position: relative;
  z-index: 1;
}


.contact-lead {
  max-width: 700px;
  margin: 0 auto 40px;
  color: white;
  font-size: 2.2rem;
  font-weight: bold;
}

.contact-lead span {
  font-size: 1.1rem;
}

.contact-wrap {
  width: 100%;
  display: flex;
  gap: 2rem;
  justify-items: center;
}

.contact-card {
  width: calc((100% - 2rem) / 2);
  white-space: nowrap;
}

.contact-card a {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  border-radius: 12px;
  padding: 24px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.1);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.contact-card a:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}

/* 電話カード */
.contact-card--tel a {
  background-color: #fff;
  color: #2a2a2a;
}

.contact-card--tel i {
  color: #48a867;
  font-size: 2rem;
  margin-bottom: 8px;
}

/* メールカード */
.contact-card--mail a {
  background: linear-gradient(135deg, #48a867, #3d945a);
  color: #fff;
}

.contact-card--mail i {
  font-size: 2rem;
  margin-bottom: 8px;
}

.contact-main {
  font-size: clamp(20px, 4vw, 24px);
  font-weight: 700;
  margin-bottom: 6px;
}

.contact-note {
  font-size: 0.9rem;
  opacity: 0.9;
}



/* ========== news Section ========== */
.news-section {
  background-color: white;
}


/* ========== Profile Section ========== */

.profile-section {
  position: relative;
  padding: 80px 0;
  background-color: #F2F0EE;
  z-index: -2;
}

/* 背景の白い箱（PC） */
.profile-section::after {
  content: "";
  position: absolute;
  top: 0;
  right: calc(600px - 10vw);
  width: 65vw;
  height: 750px;
  background-color: #fff;
  z-index: -1;
}


/* レイアウト本体：テキスト左／画像右 */
.profile-wrap {
  display: flex;
  justify-content: space-between;
  gap: 40px;
}

/* テキスト側（左） */
.profile-container {
  width: 50%;
}

.profile-textbox02 h3 {
  margin: 0 0 0.2rem;
  font-size: 1.4rem;
  font-weight: 500;
}

.profile-textbox02 > p {
  margin: 0 0 1.2rem;
  font-size: 0.95rem;
}

/* ラベル＋内容の行 */
.profile-textbox02-text {
  display: flex;
  margin-bottom: 0.6rem;
}

.profile-textbox02-text p:first-of-type {
  background-color: #F4F4F4;
  width: 25%;
  max-width: 120px;
  padding: 0.5rem;
  text-align: center;
  white-space: nowrap;
  font-size: 0.85rem;
}

.profile-textbox02-text p:nth-of-type(2) {
  font-size: 0.9rem;
  width: 70%;
  padding-left: 1rem;
  padding-top: 0.15rem;
  line-height: 1.7;
}

/* 画像側（右） */
.profile-img-container {
  width: 45%;
}

.profile-img-container img {
  width: 100%;
  height: auto;
  display: block;
  transform: scaleX(-1)
}

/* ===== Access Section ===== */

.access-section {
  padding: 80px 0;
  background-color: #F9FCF5; /* お好みで #fff でもOK */
}

.access-inner {
  width: 80%;
  max-width: 1100px;
  display: flex;
  flex-direction: column;
  align-items: center;
}


/* layout */
.access-wrap {
  width: 100%;
  display: flex;
  justify-content: center;
}

/* 左カラム：情報 */
.access-info {
  width: 40%;
  font-size: 0.95rem;
  line-height: 1.9;
}

.access-info h3 {
  margin-top: 0;
  margin-bottom: 1rem;
  font-size: 1.2rem;
  font-weight: 600;
}

.access-address {
  margin: 0 0 1.5rem;
}

.access-detail-row {
  display: flex;
  margin-bottom: 0.5rem;
}

.access-label {
  background-color: #F4F4F4;
  width: 28%;
  max-width: 140px;
  padding: 0.5rem;
  text-align: center;
  white-space: nowrap;
  font-size: 0.85rem;
}

.access-value {
  width: 70%;
  padding-left: 1rem;
  padding-top: 0.15rem;
  font-size: 0.9rem;
}

/* 右カラム：地図 */
.access-map {
  width: 50%;
}

/* 仮地図用のプレースホルダー */
.access-map-placeholder {
  width: 100%;
  height: 320px;
  background-color: #E0E4EB;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  color: #555;
}

/* 実際にGoogleマップを埋め込むときの例
.access-map iframe {
  width: 100%;
  height: 320px;
  border: 0;
  border-radius: 8px;
}
*/

/* ===== Responsive ===== */

@media screen and (max-width: 1024px) {
/* ========== main visual ========== */
.main-visual-original {
  justify-content: flex-end;
}

.main-visual-img {
  height: 80vh;
  width: 100%;
}

.main-visual-left-logo {
  display: none;
}

.main-visual-left-text {
  top: 10vw;
  transform: none;
  left: 10vw;
}

/* ========== greeting section ========== */
  .img-sub {
    display: none;
  }

  .img-main-l {
  height: 400px;
}

  .img-main {
    width: 100%;
    height: 400px;
  }

  .greetings-content {
    padding-right: 0;
  }

/* ========== service section ========== */
  .service-container-text ul {
  column-count: 1;     
}

/* ========== feature section ========== */
  .feature-inner {
  box-sizing: border-box;
  padding: 40px;
}

  .feature-container {
    width: calc((100% - 60px) / 2);
}

/* ========== profile section ========== */
  .profile-section::after {
    left: 0;
    width: 80vw;
  }

}


@media screen and (max-width: 767px) {

.inner {
  width: 85%;
}

/* ========== main visual section ========== */

.main-visual-img {
  margin-top: 80px;
}
.main-visual-left-logo {
  display: none;
}

.main-visual-left-text {
  left: 5vw;
  top: 10vw;
  transform: none;
}

.mv-line {
  padding: 10px 0px;
  margin: 2px;
  font-size: 1.2rem;
}

/* ========== greetings section ========== */
  .greetings-wrap {
    flex-direction: column;
    gap: 80px;
  }

  .greetings-img,
  .greetings-content {
    width: 100%;
    height: auto;
  }

  .img-main-l {
  height: 350px;
  width: 90%;
}

  .img-main {
    width: 100%;
    height: 350px;
  }

  .img-sub {
    display: block;
    top: 250px;
    right: 0;
    width: 150px;
    height: 150px;
  }

  .greetings-content {
    padding: 0;
  }

  .greetings-lead {
    font-size: 1.2rem;
    letter-spacing: 0.15rem;
    margin-top: 16px;
  }
/* ========== profile section ========== */
  .profile-section {
    background-color: #ffffff;
  }

  .profile-section::after {
    display: none;
  }

  .profile-wrap {
    flex-direction: column;
    align-items: center;
    width: 100%;
  }

  .profile-img-container,
  .profile-container {
    width: 100%;
  }

  .profile-container {
    padding: 0 1.5rem;
  }

  .profile-img-container {
    height: 420px;
  }

  .profile-img-container img {
    width: 100%;
    height: 420px;
    object-fit: cover;
    object-position: 50% 20%;
  }

/* ========== service section ========== */
  .service-container {
    width: 90%;
    position: relative;
    overflow: hidden;
  }

  .service-subtext span {
    font-size: 1rem;
  }

  .one, .one img, .two, .two img {
    border-radius: 5%;
  }

  .service-container-text h3 {
    text-align: center;
  }

  .service-container-text li {
    list-style: none;
    letter-spacing: 0.1rem;
  }


/* ========== feature section ========== */
  .feature-inner {
  box-sizing: border-box;
  padding: 0 20px;
}

  .feature-wrap {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
}

  .feature-container {
    width: 100%;
}

.feature-container img {
  width: 70%;
  border-radius: 5%;
  min-height: 100px;
  object-fit: contain;


}

/* ========== contact section ========== */
  .contact-wrap {
    flex-direction: column;
    gap: 2rem;
    justify-items: center;
    align-items: center;
  }

  .contact-card {
    width: 70%;
  }
  
/* ========== access section ========== */
  .access-wrap {
    flex-direction: column;
  }

  .access-info,
  .access-map {
    width: 100%;
  }

  .access-map {
    margin-top: 16px;
  }
}

/* ========== お問い合わせフォーム  ========== */
  .wpcf7-text, .wpcf7-textarea {
    width: 100%;
  }
table.CF7_table{
	width:80%;
	margin :0 auto;
	border: 3px solid #e5e5e5;
}

table.CF7_table tr{
	border-top: 1px solid #e5e5e5;
}

.single .entry-content table.CF7_table,
.page .entry-content table.CF7_table{
	display:table;
}

/*入力欄*/
.CF7_table input, .CF7_table textarea {
	border: 1px solid #d8d8d8;
}

.CF7_table ::placeholder {
	color:#797979;
}

/*「必須」文字*/
.CF7_req{
	font-size:.9rem;
	padding: 5px;
	background: #09491a;
	color: #fff;
	border-radius: 3px;
	margin-left:1rem;
}

/*「任意」文字*/
.CF7_unreq{
	font-size:.9em;
	padding: 5px;
	background: #bdbdbd;/*グレー*/
	color: #fff;
	border-radius: 3px;
	margin-right:1em;
}

/* タイトル列 */
@media screen and (min-width: 768px){
	.CF7_table th{
	width:30%;/*横幅*/
	background-color:#ECF8EC;
	}
}

/* レスポンシブ */
@media screen and (max-width: 768px){


	table.CF7_table{
	width:95%;
	}
	.CF7_table tr, .CF7_table td, .CF7_table th{
	display: block;
	width: 100%;
	line-height:2.5em;
	}
	.CF7_table th{
	background-color:#ebedf5;
	}
}

/* 「送信する」ボタン */
.wpcf7 input.wpcf7-submit {
	background-color:#09491a;
	border:0;
	color:#fff;
	font-size:1.2em;
	margin:0 auto;
}

.CF7_btn{
	text-align:center;
	margin-top:20px;
  margin-bottom: 60px;
}

.wpcf7-spinner{
	width:0;
	margin:0;
}

/* contactformここまで */
