@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
*/
.c-headLogo__img {
  height: 130% !important;
}
.title1,.p-postSlider__title{
    color: #0087cc;
    font-size: 2rem !important;
}
@media screen and (max-width:480px) {
	.title2{
		font-size:1.3rem !important;
	}
}
.p-postSlider__title{
    text-align: left !important;
    padding-left: 10px !important;
}
.title2{
    color: #fbfeff;
    font-size: 2rem !important;
}
.background{
    background-color: rgba(250, 249, 248, 0.897);
}

.text12 {
    position: relative;
    display: inline-block;
    font-weight:bold;
    background: linear-gradient(transparent 50%, #77bcff 50%);
    margin: 0 auto 50px;
    padding: 0 10px 0 10px;
}
/* サイドバーボタン */
.bold{
    font-weight: bold;
}
.cta_btn09 {
    font-weight: bold; /* 文字の太さ */
    text-align: center;
    letter-spacing: 0.1em;
    align-items: center;
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
  }
  
  .cta_btn09-contact , .cta_btn09-tel {
    color: #fff; /* 文字色 */
    position: relative;
    display: inline-block;
    text-decoration: none;
    padding: 1em 1em 1em 60px;
    border-radius: 100vh;
    width: 100%; /* ボタン幅 */
    max-width: 350px; /* 最低ボタン幅 */
    transition: 0.3s;
  }
  
  .cta_btn09-contact {
    background: #F88400; /* お問い合わせボタン色 */
  }
  
  .cta_btn09-tel {
    background: #4D9BC1; /* 電話ボタン色 */
  }
  
  .cta_btn09-contact::before,
  .cta_btn09-tel::before {
    content: '';
    position: absolute;
    left: 30px;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    background-repeat: no-repeat;
    background-size: cover;
  }
  .cta_btn09-contact::before {
    width: 50px;
    height: 41px;
    background-image: url(https://seotimes.jp/wp-content/uploads/mail.png); /* メールアイコン */
  }
  
  .cta_btn09-tel::before {
    width: 40px;
    height: 40px;
    background-image: url(https://seotimes.jp/wp-content/uploads/cta-phone.png); /* 電話アイコン */
  }
  
  .cta_btn09 .copy_txt {
    line-height: 1;
    display: inline-block;
    padding: 0.2em 1.5em;
    letter-spacing: 0;
    background: #fff; /* 下文字背景色 */
    font-size: 90%; /* 下文字サイズ */
    border-radius: 5px;
  }
  
  .cta_btn09-contact .copy_txt {
    color: #F88400; /* 下文字色 */
  }
  
  .cta_btn09-tel .copy_txt {
    color: #4D9BC1; /* 下文字色 */
  }
  
  .cta_btn09 img {
      width: 1em;
      margin-right: 0.5em;
  }
  
  /* マウスオーバーした際のデザイン */
  .cta_btn09-contact:hover,
  .cta_btn09-tel:hover {
    transform: scale(1.05);
  }
/* 問い合わせ */
  .cf7__list {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 60px;
  }
  
  .cf7__list dt:nth-of-type(n + 2),
  .cf7__list dd:nth-of-type(n + 2) {
    margin-top: 30px;
  }
  
  .cf7__list dt {
    width: 35%;
    padding-top: 15px;
  }
  
  .cf7__list dd {
    width: 65%;
  }
  
  /* 必須・任意 */
  .cf7__required,
  .cf7__optional {
    margin-right: 15px;
    padding: 6px 14px;
    color: #fff;
    font-size: 12px;
    vertical-align: 1px;
  }
  
  .cf7__required {
    background: #BE1D1D;
  }
  
  .cf7__optional {
    background: #878D8E;
  }
  
  /* input・textarea */
  .cf7__list dd input[type="text"],
  .cf7__list dd input[type="tel"],
  .cf7__list dd input[type="email"],
  .cf7__list dd textarea {
    width: 100%;
    padding: 15px 20px;
    background: #F4F4F4;
  }
  
  /* ドロップダウンメニュー */
  .cf7__select {
    position: relative;
  }
  
  .cf7__select:before {
    position: absolute;
    top: 50%;
    right: 20px;
    z-index: 10;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-top: 8px solid #000;
    border-right: 6px solid transparent;
    border-left: 6px solid transparent;
    pointer-events: none;
    content: '';
  }
  
  .cf7__select select {
    width: 100%;
    padding: 19px 20px;
    background: #F4F4F4;
    color: #a5a5a5;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
  }
  
  /* チェックボックス・ラジオボタン */
  .cf7__list dd .wpcf7-checkbox,
  .cf7__list dd .wpcf7-radio {
    display: block;
    padding: 15px 0 10px;
  }
  
  /* 縦並び（チェックボックス・ラジオボタン） */
  .cf7__list dd .wpcf7-list-item {
    display: block;
    margin: 0;
  }
  
  .cf7__list dd .wpcf7-list-item:nth-child(n + 2) {
    margin-top: 18px;
  }
  
  /* マウスカーソル（チェックボックス・ラジオボタン） */
  .cf7__list dd .wpcf7-list-item label {
    cursor: pointer;
  }
  
  /* チェックボックス・ラジオボタン */
  input[type="checkbox"],
  input[type="radio"] {
    position: relative;
    width: 18px;
    height: 18px;
    margin-right: 8px;
    border: 1px solid #bcbcbc;
    vertical-align: -3px;
    cursor: pointer;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
  }
  
  /* チェックボックス */
  input[type="checkbox"]:checked {
    border: 1px solid #000;
    background: #000;
  }
  
  input[type="checkbox"]:checked:before {
    position: absolute;
    top: 2px;
    left: 5px;
    transform: rotate(50deg);
    width: 6px;
    height: 10px;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    content: '';
  }
  
  /* ラジオボタン */
  input[type="radio"] {
    border-radius: 50%;
  }
  
  input[type="radio"]:checked:before {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #000;
    content: '';
  }
  
  /* プレースホルダー */
  /* Google Chrome / Safari / Mozilla Firefox / Opera */
  .cf7__list dd input[type="text"]::placeholder,
  .cf7__list dd input[type="tel"]::placeholder,
  .cf7__list dd input[type="email"]::placeholder,
  .cf7__list dd textarea::placeholder {
    color: #a5a5a5;
  }
  
  /* Microsoft Edge */
  .cf7__list dd input[type="text"]::-ms-input-placeholder,
  .cf7__list dd input[type="tel"]::-ms-input-placeholder,
  .cf7__list dd input[type="email"]::-ms-input-placeholder,
  .cf7__list dd textarea::-ms-input-placeholder {
    color: #a5a5a5;
  }
  
  /* Internet Explorer */
  .cf7__list dd input[type="text"]:-ms-input-placeholder,
  .cf7__list dd input[type="tel"]:-ms-input-placeholder,
  .cf7__list dd input[type="email"]:-ms-input-placeholder,
  .cf7__list dd textarea:-ms-input-placeholder {
    color: #a5a5a5;
  }
  
  /* 送信ボタン */
  .cf7__button {
    padding-left: 72px;
    text-align: center;
  }
  
  input[type="submit"] {
    width: 260px;
    height: 60px;
    background: #000;
    color: #fff;
    transition: opacity .6s;
  }
  
  input[type="submit"]:hover {
    opacity: .6;
  }
  
  /* ajax-loader */
  .wpcf7-spinner {
    vertical-align: middle;
  }
  
  @media screen and (max-width: 767px) {
  
    .cf7__list dt {
      width: 100%;
      margin-bottom: 15px;
      padding-top: 0;
    }
  
    .cf7__list dd {
      width: 100%;
    }
  
    .cf7__list dd:nth-of-type(n + 2) {
      margin-top: 0;
    }
  
    .cf7__list dd .wpcf7-checkbox,
    .cf7__list dd .wpcf7-radio {
      padding: 15px 0 0;
    }
  
    /* 送信ボタン */
    input[type="submit"] {
      width: 180px;
      height: 56px;
    }
  
  }
  /* jc今治タイトル */
  .ttl_line1 {
    font-weight: bold;
    border-left: 5px solid #4c9ac0;
    border-bottom: 2px dashed #B4B4B4;
    padding: 0.25em 0 0.3em 0.5em;
  }
.ttl-title{
  color:#0087cc;
  font-weight: bold;
}
.title12{
    color:#0087cc;
    font-weight: bold;
    font-size: 1.8rem;
}
/* 組織図 */
/* ラッパー（横スクロール対応） */
.jc-org-chart-container {
  width: 100%;
  overflow-x: auto;
  padding: 1em;
  box-sizing: border-box;
}

/* 内部チャート */
.jc-org-chart {
  display: block;
  min-width: 1000px;
}

/* 行共通 */
.jc-row {
  display: flex;
  gap: 60px;
  margin-bottom: 40px;
  align-items: flex-start;
}

/* 上段：中央揃え */
.jc-row.jc-top-row {
  justify-content: center;
}

/* 下段：左揃え */
.jc-row.jc-bottom-row {
  justify-content: flex-start;
}

/* 各列 */
.jc-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
  width: 320px; /* 明示的に各列の幅を統一 */
}

/* 「魅力ある郷土継承委員会」ボックスだけ下げる */
.jc-right-col .jc-committee {
  margin-top: 55px; /* 必要に応じて数値調整 */
}
.jc-center-col {
  width: 320px;
  align-items: center;
}
.jc-top-row .jc-right-col {
  margin-top: 280px; /* 数値はお好みで調整 */
}

/* 通常ボックス */
.jc-box {
  background: #fff;
  border: 2px solid #007acc;
  border-radius: 6px;
  padding: 12px;
  margin: 8px 0;
  text-align: center;
  width: 260px;
  box-sizing: border-box;
  font-size: 14px;
  line-height: 1.4;
}

/* 会社名 */
.jc-company {
  display: block;
  font-size: 12px;
  color: #666;
  margin-top: 4px;
}

/* 縦線 */
.jc-line-vertical {
  width: 2px;
  height: 80px;
  background: #007acc;
  margin: 10px 0;
}
.jc-line-vertical1{
  width: 2px;
  height: 280px;
  background: #007acc;
  margin: 10px 0;
}
/* 横線 */
.jc-line-horizontal {
  height: 2px;           /* 線の太さ */
  width: 80px;           /* 線の長さ */
  background: #007acc;   /* 線の色 */
  margin: 0 10px;        /* 上下余白はなし、左右に余白 */
}

/* 委員会ボックス */
.jc-committee {
  text-align: left;
  padding: 16px;
  width: 300px;
  min-height: 330px;
  box-sizing: border-box;
}

/* 委員会内リスト */
.jc-committee ul {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  white-space: nowrap;
  text-align: left;
}

/* リスト項目 */
.jc-committee li {
  display: flex;
  align-items: baseline;
}

/* 記号 (◎○△※) */
.jc-role {
  display: inline-block;
  width: 1.5em;
  text-align: right;
  margin-right: 6px;
  font-weight: bold;
}

/* 記号なし用空白 */
.jc-role.empty {
  visibility: hidden;
}

/* 強調タイトル */
.jc-box strong {
  display: block;
  margin-bottom: 8px;
  font-weight: bold;
}

/* スマホ対応 */
@media (max-width: 768px) {
  .jc-org-chart {
    min-width: 800px;
  }
  .jc-box {
    width: 200px;
    padding: 8px;
  }
  .jc-committee {
    width: 280px;
  }
  .jc-row {
    justify-content: center !important;
  }
  .jc-col {
    width: 280px; /* または同じ幅を維持 */
  }
}
/* 区切り線 */
hr {
  border: none;
  padding: 0;
}

.hr3 {
  border-top: 1px solid #129df3 !important;
}
.post_content hr {
  margin: 0.5em 0;
}
