.grecaptcha-badge {
	display:none!important;
}

.content .btn__link-primary {
    color: #ffffff;
    background-color: #c3ac80!important;
}

.still__content img {
    width: 40%;
}

.still__box {
    text-align: left;
}

.still {
    height: 80vh;
}

.l-wrapper {
    margin-top:0!important;
    margin-bottom:0!important;
}

.sub-page-wide-section {
    margin: 0 calc(50% - 50vw);
    padding: 5em 0;
    background-color: #f3f3f3;
    background-image: url('https://seoteas-test.work/akiiro/wp-content/uploads/2025/08/sub-page-title-bg-scaled.jpg');
    background-size: cover;
}

.nomal-wide-section {
    margin: 0 calc(50% - 50vw);
    padding: 5em 0;
}

.custom {
    padding: 5em 0;
}

.divider, .dividerBottom, .l-main, .pageContents {
    margin-bottom:0;
}


.u-bg--wh {
    background: #fff!important;
}

.u-tc--yw {
    color:#C3AC80!important;
}

.u-fw--b {
    font-weight: bold;
}

.u-ta--c {
    text-align: center;
}

.u-img--c {
    display: block;
    margin:0 auto;
}

.u-ta--PCc-SPl {
    text-align: center;
}

.u-fw--n {
    font-weight: normal;
}

.pageContents .container {
    max-width:900px;
}


.sub-page-wide-section h1,
.page-about-wide-section h1,
.page-service-wide-section h1 {
    font-weight: bold;
    margin: 0;
    font-size: 4em;
}

.c-title--c {
    text-align: center;
    position: relative;
    margin-bottom: 3em;
}

#price .c-title--c {
    margin-bottom: 1em;
}

.c-title--l {
    text-align: left;
    position: relative;
    margin-bottom: 3em;
}

.sub-page-wide-section h1:after {
    content: '';
    width: 40px;
    height: 4px;
    display: inline-block;
    background-color: #C3AC80;
    position: absolute;
    bottom: -10px;
    left: 0;
}

.c-title--c:after {
    content: '';
    width: 40px;
    height: 4px;
    display: inline-block;
    background-color: #C3AC80;
    position: absolute;
    bottom: -10px;
    left: calc(50% - 20px);
}

.c-title--l:after {
    content: '';
    width: 40px;
    height: 4px;
    display: inline-block;
    background-color: #C3AC80;
    position: absolute;
    bottom: -10px;
    left: 0;
}

.page-about-wide-section,
.page-service-wide-section {
    margin-top: 9em;
}

.page-about-wide-section h1:after,
.page-service-wide-section h1:after {
    content: '';
    width: 40px;
    height: 4px;
    display: inline-block;
    background-color: #C3AC80;
    position: absolute;
    top: 93px;
    left: 0;
}

.archiveHead .heading {
    border: none;
}

.bottomFooter {
    background: #303030;
}

.bottomFooter img {
    width: 100px;
    display: block;
    margin: 0 auto 2em;
}

.page-service-wide-section .hero {
    width: 100%;
    margin: 0 auto;
    display: block;
}

/* page-service */
.c-title--saikou {
    margin-bottom: 3em;
}
.c-title--saikou span {
    font-size: 0.7em;
}

#concept img {
    width:100%;
    max-width: 530px;
}

#service h3 {
    margin-top: 3em;
}
#service h3:nth-child(1) {
    margin-top:0;
}

#target .c-title--sub {
    display: block;
    text-align: center;
    font-weight: normal;
    font-size: 1em;
    margin-top: -3em;
}

#target .u-mt--m {
    margin-top: 5em!important;
}

#target img {
    width:100%;
}
@media screen and (max-width: 480px) {
#target img {
    width: 60%;
    margin: 0 auto;
    display: block;}
}

/* page-service-end */

@media screen and (min-width: 481px){
    .pc_none {
        display: none!important;
    }
    .pageContents {
        margin: 6em 0 0;
    }

  
}

@media screen and (max-width: 480px) {
    .sp_none,
    .br-sp {
    display: none!important;
    }
    .pageContents {
        margin: 4em 0 0;
    }
    .sub-page-wide-section h1,
    .page-about-wide-section h1,
    .page-service-wide-section h1 {
    font-weight: bold;
    margin: 0;
    font-size: 3em;
    text-align: center;
    }

.sub-page-wide-section h1:after,
.page-about-wide-section h1:after,
.page-service-wide-section h1:after,
.c-title--l:after {
    left: calc(50% - 20px);
}

.page-about-wide-section h1:after,
.page-service-wide-section h1:after {
    top: 70px;
}

    .page-about-wide-section,
    .page-service-wide-section {
        margin-top: 4em;
    }
    .hero {
        margin-top: 4em!important;
    }
    .company-data {
        margin-top: 0!important;
    }
    .company-title {
        margin-top: 2em;
    }
    .company-title:nth-child(1) {
        margin-top: 0em;
    }
    .c-title--l {
        text-align: center;
    }
    .u-ta--PCc-SPl {
        text-align: left;
    }
    #concept h2 {
        font-size: 4.5vw;
    }
}

@media (481px <= width < 768px) {
    .hero {
        margin-top: 4em!important;
    }    
}





/* ===== 2カラムの基本 ===== */
.column.column-2pc {
  display: grid;
  grid-template-columns: 1fr 1fr;   /* PC: 2列 */
  gap: 36px 56px;
  align-items: center;
  margin: 48px 0;                   /* セクション間余白 */
}

/* 画像をきれいに */
.column__item img {
  display: block;
  width: 100%;
  height: auto;
}

/* 見出し・本文の雰囲気（必要なら調整） */
.column__item h3 {
  font-size: 18px;
  margin: 0 0 8px;
  line-height: 1.6;
}
.u-tc--yw { color: #c8b07a; }       /* ゴールド系 */
.column__item .u-p {
  line-height: 2;
  margin: 0;
}

/* 最下のセンター文 */
.u-ta--c { text-align: center; }
.br-sp { display: none; }

/* ===== SP（～768px）: 1列 & 必ず「テキスト→画像」順 ===== */
@media (max-width: 768px) {
  .column.column-2pc {
    grid-template-columns: 1fr;     /* 1列 */
    gap: 16px;
    margin: 28px 0;
  }

  /* まず全要素を2番めに（=後ろへ） */
  .column.column-2pc .column__item { order: 2; }

  /* 画像を含まない=テキスト側は1番め（=前へ） */
  .column.column-2pc .column__item:not(:has(img)) { order: 1; }

  .column__item h3 { font-size: 16px; }
  .column__item .u-p { line-height: 1.9; }
  .br-sp { display: inline; }       /* 最下文の改行をSPだけ有効に */
}




















/* ルート */
.member-board { --gap: 28px; --heading-bg: #555; --heading-color: #fff; }

/* 見出しバー */
.member-board__heading {
  background: var(--heading-bg);
  color: var(--heading-color);
  padding: 12px 16px;
  margin: 28px 0 16px;
  font-weight: 600;
  letter-spacing: .3px;
}
.member-board__heading span { display: inline-block; }

/* グリッド（PC: 4列想定 / 画像に近い間隔） */
.member-board__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(180px, 1fr));
  gap: var(--gap);
}

/* カード（シンプル・余白中心） */
.member-board__card { text-align: center; }
.member-board__card-inner { padding: 10px 6px; }

/* 役職（1行目/小さめ） */
.member-board__role {
  font-size: 12px;
  color: #333;
  margin-bottom: 8px;
  line-height: 1.2;
}

/* 氏名（日本語/強調） */
.member-board__jname {
  font-size: 18px!important;
  font-weight: normal;
  margin: 2px 0 4px!important;
  line-height: 1.1;
}

/* 英語名（下/細め） */
.member-board__ename {
  font-size: 13px;
  color: #444;
  letter-spacing: .2px;
  margin:0!important;
}

/* セクションごとの余白調整 */
.member-board__section + .member-board__section { margin-top: 36px; }

/* レスポンシブ */
@media (max-width: 1024px) {
  .member-board__grid { grid-template-columns: repeat(3, minmax(160px, 1fr)); }
}
@media (max-width: 640px) {
  .member-board__grid { grid-template-columns: repeat(2, minmax(140px, 1fr)); gap: 18px; }
  .member-board__jname { font-size: 16px; }
}

/* 役職の高さを常に確保（1行ぶん） */
.member-board__role {
  font-size: 12px;
  color: #333;
  line-height: 1.2;
  margin-bottom: 8px;
  /* 1行分の最小高さを確保（行高×1行） */
  min-height: 1.2em;
}

/* 中身が空のときもブロック高を維持 */
.member-board__role.is-empty::before {
  content: '\00a0'; /* ノーブレークスペース */
  display: inline-block;
  height: 1em;
  line-height: 1;
}

/* もしSPで文字サイズを変えるなら、同様にmin-heightはemで追従します */
@media (max-width: 640px) {
  .member-board__role { font-size: 12px; } /* 必要に応じて */
}

.member-board__card-inner {
  display: grid;
  grid-template-rows: auto auto auto; /* 役職 / 氏名 / 英名 */
  row-gap: 0;
}



/* FAQ */

/* ルート */
.faq-board { --gap: 16px; --heading-bg:#555; --heading-color:#fff; --box-bg:#fff; --box-bd:#e5e5e5; }

/* 見出しバー（カテゴリ） */
.faq-board__heading {
  background: var(--heading-bg);
  color: var(--heading-color);
  padding: 12px 16px;
  margin: 28px 0 16px;
  border-radius: 0; /* 画像に合わせてフラット */
  font-weight: 600;
  letter-spacing: .3px;
}
.faq-board__heading span { display:inline-block; }

/* FAQリスト */
.faq-board__list { display: grid; gap: var(--gap); }

/* Q行（白地＋薄枠のボックス） */
.faq-item__q {
  background: var(--box-bg);
  border: 1px solid var(--box-bd);
  padding: 14px 16px;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  border-radius: 4px;
}
.faq-item__qmark { font-weight: 700; }
.faq-item__qtext { line-height: 1.6; }

/* A行（下の白ボックス。上と同じ幅で続く） */
.faq-item__a {
  background: var(--box-bg);
  border: 1px solid var(--box-bd);
  border-top: none;               /* Qと一体化して見せる */
  padding: 14px 16px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  border-radius: 0 0 4px 4px;     /* 下だけ角丸 */
  margin-top: -8px;               /* Qボックスとの間隔を詰める（画像の雰囲気） */
}
.faq-item__amark { font-weight: 700; }
.faq-item__atext { line-height: 1.9; }

/* Qボックスの角丸（上だけ） */
.faq-item__q { border-radius: 4px 4px 0 0; }

/* カテゴリ間の余白 */
.faq-board__section + .faq-board__section { margin-top: 36px; }

/* レスポンシブ：スマホは余白だけ少し詰める */
@media (max-width: 640px) {
  .faq-item__q, .faq-item__a { padding: 12px; }
  .faq-board__heading { margin: 24px 0 12px; }
}





/* 実績 */
/* ルート */
.works-board__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr); /* 2列 */
  gap: 60px 40px;
}
/* スマホ: 1列 */
@media (max-width: 640px) {
  .works-board__grid {
    grid-template-columns: 1fr; /* 1列 */
    gap: 50px; /* 余白も少し詰めても良い */
  }
}

/* サムネ */
.works-item__thumb img {
  width: 100%;
  height: auto;
  border-radius: 4px;
  display: block;
  transition: opacity .3s;
}
.works-item__thumb:hover img { opacity: 0.85; }

/* タイトル */
.works-item__title {
  font-size: 15px;
  font-weight: 600;
  margin: 8px 0 4px;
  line-height: 1.4;
}

/* スタッフ表記 */
.works-item__staff {
  font-size: 13px;
  color: #c3ac80;
  line-height: 1.6;
}
.works-item__staff-role {
  color: #c3ac80;
}


/* ================================
   CF7 お問い合わせフォーム（添付デザイン準拠）
   使用方法: ショートコードに html_class="contact-form"
   ================================ */

/* 共通行レイアウト */
.contact-form .form-row {
  display: grid;
  grid-template-columns: 220px 1fr; /* 左:ラベル / 右:入力 */
  gap: 10px 20px;
  align-items: start;
  padding: 14px 0;
}


/* ラベル部分 */
.contact-form .form-label {
  font-weight: 600;
  line-height: 1.6;
  color: #222;
}

/* 入力部分 */
.contact-form .form-field input[type="text"],
.contact-form .form-field input[type="email"],
.contact-form .form-field input[type="tel"],
.contact-form .form-field textarea {
  width: 100%;
  border: 1px solid #e6e1d7;
  border-radius: 6px;
  padding: 10px 12px;
  font-size: 15px;
  color: #222;
  background: #fff;
}

/* チェックボックス 2列レイアウト */
.contact-form .form-field .wpcf7-checkbox{
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 1fr)); /* 2列。幅はお好みで */
  column-gap: 36px;
  row-gap: 12px;
}




.form-field {
    margin-top:0!important;
}

.contact-form .form-field textarea { min-height: 160px; }

/* チェックボックス */
.contact-form .form-field .wpcf7-checkbox {
  display: grid;
  grid-template-columns: repeat(2, minmax(160px,1fr));
  gap: 10px 18px;
}
.contact-form .wpcf7-list-item { margin: 0; }

/* 受諾 */
.contact-form .form-accept {
  display: table;
  padding: 14px 0;
  margin: 0 auto;
}

/* 送信 */
.contact-form .form-submit {
  text-align: center;
  padding: 20px 0;
}
.contact-form .form-submit input[type="submit"] {
  background: #c8b07a;
  color: #fff;
  border: none;
  padding: 12px 24px;
  border-radius: 8px;
  font-weight: 700;
  cursor: pointer;
}
.contact-form .form-submit input[type="submit"]:hover {
  filter: brightness(0.95);
}



/* SP（1列に） */
@media (max-width: 640px) {
  .contact-form .form-row {
    grid-template-columns: 1fr;
    gap: 8px;
    padding:0;
  }
  .contact-form .form-field .wpcf7-checkbox {
    grid-template-columns: 1fr;
  }
}


.wpcf7-spinner {
    display: block!important;
    margin: 0 auto!important;
}





















/* ========= base ========= */
:root{
  --bg: #f7f2e7;          /* 背景ベージュ */
  --ink: #111;            /* 文字色 */
  --gold: #c8b07a;        /* ゴールドライン */
  --cardShadow: 0 10px 25px rgba(0,0,0,.08);
  --panelGrad: linear-gradient(#fff, #f2f2f2 55%, #d9d9d9 100%);
  --panelGradBottom: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.06) 90%, rgba(0,0,0,.12) 100%);
}






/* 横2カラム化：左=見出し/右=説明 */
body .sect.-about .sect__head,
body .sect.-service .sect__head{
  display: grid !important;
  grid-template-columns: 220px 1fr !important;  /* 見出し幅はお好みで */
  column-gap: 32px !important;
  align-items: start !important;
  position: relative !important;
  padding: 18px 0 24px !important;
}

/* 見出し */
body .sect.-about .sect__ttl,
body .sect.-service .sect__ttl,
.sect.-news .sect__ttl{
  margin: 0 0 8px !important;
  font-size: clamp(28px, 4vw, 42px) !important;
  line-height: 1.1 !important;
  letter-spacing: .02em !important;
  position: relative !important;
  z-index: 1 !important;
}

/* 見出し下のライン */
body .sect.-about .sect__ttl::after,
body .sect.-service .sect__ttl::after,
body .sect.-news .sect__ttl::after{
  content: "" !important;
  display: block !important;
  width: 46px !important; height: 4px !important;
  border-radius: 2px !important;
  background: #c8b07a !important;
  margin-top: 12px !important;
}

/* 説明文・CTA を右カラムに */
body .sect.-about .sect__lead,
body .sect.-service .sect__lead,
body .sect.-about .sect__cta,
body .sect.-service .sect__cta{
  grid-column: 2 !important;
  margin: 0 0 0 !important;
  line-height: 1.9 !important;
  position: relative !important;
  z-index: 1 !important;
}
body .sect.-about .sect__cta,
body .sect.-service .sect__cta{ margin-top: 14px !important; }

/* 背景の巨大な薄字（右寄せ・中央寄せ） */
body .sect.-about .sect__head::after,
body .sect.-service .sect__head::after{
  content: attr(data-watermark) !important; /* まずダミー */
  position: absolute !important;
  right: 0 !important;
  top: 50% !important;
  transform: translateY(-55%) !important;
  font-size: 9vw !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  color: rgba(0,0,0,.06) !important;
  letter-spacing: .04em !important;
  pointer-events: none !important;
  z-index: 0 !important;
}
/* 具体的な文字を差し込む */
body .sect.-about .sect__head::after{ content: "ABOUT" !important; }
body .sect.-service .sect__head::after{ content: "SERVICE" !important; }

/* ===== SP：縦積み（～768px） ===== */
@media (max-width: 768px){
  body .sect.-about .sect__head,
  body .sect.-service .sect__head{
    grid-template-columns: 1fr !important;
    row-gap: 8px !important;
    align-items: start !important;
  }
  body .sect.-about .sect__lead,
  body .sect.-service .sect__lead,
  body .sect.-about .sect__cta,
  body .sect.-service .sect__cta{
    grid-column: 1 !important;
  }
  body .sect.-about .sect__head::after,
  body .sect.-service .sect__head::after{
    right: 6px !important;
    font-size: clamp(60px, 26vw, 120px) !important;
    transform: translateY(-45%) !important;
  }
}


/* PC=2列 / SP=1列。余白は最小（必要なら微調整） */
body .svcGrid{
  display:grid !important;
  grid-template-columns:repeat(2,1fr) !important;
  gap:12px !important;
  margin:0 !important;
  padding:0 !important;
}

/* 画像リンクのリセット＆サイズ */
body .svcGrid__item{
  display:block !important;
  margin:0 !important;
}
body .svcGrid__item img{
  display:block !important;
  width:100% !important;
  height:auto !important;
  margin:0 !important;  /* WPのalign余白を殺す */
  border-radius:6px;    /* お好みで */
}

/* 端末別の表示切替 */
body .svcGrid__item img.pc_none{ display:none !important; }
@media (max-width: 768px){
  body .svcGrid{ grid-template-columns:1fr !important; gap:10px !important; }
  body .svcGrid__item img.sp_none{ display:none !important; }
  body .svcGrid__item img.pc_none{ display:block !important; }
}


body .top-btn {
    margin: 4em 0!important;
}


.top-bg-section {
    height:300px;
}
@media screen and (max-width: 480px) {
.top-bg-section {
    height:auto;
}
.still {
    height: 60vh;
}
.still__content img {
    width: 65%;
}
}


/* 初期状態（非表示） */
.fadein {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

/* 表示状態 */
.fadein.is-visible {
  opacity: 1;
  transform: translateY(0);
}