/*
Theme Name: Solina Pilates
Theme URI: https://solina-pilates.com
Author: Your Name
Description: Custom WordPress theme inspired by TCD demo site
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/

/* =======================================
   0) Tokens / Variables
======================================= */
:root{
  /* Colors */
  --text:#333; --text-invert:#fff; --line:#eee;
  --overlay:rgba(0,0,0,.36); --backdrop:rgba(0,0,0,.32);
 --brand:#CC7F91;        /* ピンク（主役） */
	--brand-soft:#FDECEE;   /* 薄ピンク背景 */
	
  --line-btn:#06C755;     /* LINEは公式緑 or くすみ緑 */
  --accent:#111;

  /* Header */
  /*--header-h:64px; --header-h-small:44px;*/
  --header-gap:24px; --header-gap-small:14px;
	
--logo-w:350px;
  --logo-w-small:280px; 
  --logo-w-sp:120px;       /* SP通常 */
  --logo-w-sp-small:110px; /* SPスクロール後 */
  --nav-pad-y:10px; --nav-pad-y-small:6px;

  /* Layout */
  --max-w:1100px; --max-w-narrow:860px;
	--radius-lg:20px; --shadow-sm:0 6px 24px rgba(0,0,0,.06);
	
	
  --ico-line: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Crect x='6' y='6' width='52' height='52' rx='12' fill='%23ffffff'/%3E%3Cpath fill='%23ffffff' d=''/%3E%3Cpath fill='%23000000' opacity='0' d=''/%3E%3Cpath fill='%23ffffff' d=''/%3E%3Cpath fill='%23ffffff' d=''/%3E%3Cpath fill='%23ffffff' d=''/%3E%3Cpath fill='%23ffffff' d=''/%3E%3Cpath fill='%23ffffff' d=''/%3E%3Cpath fill='%23ffffff' d=''/%3E%3Crect x='6' y='6' width='52' height='52' rx='12' fill='%2306C755'/%3E%3Cpath d='M19 24c0-6 6-11 13-11s13 5 13 11-6 11-13 11c-1 0-2 0-3-.2l-6.2 3.6.8-4.6C21 31.8 19 28.1 19 24z' fill='%23ffffff'/%3E%3Ctext x='32' y='28.5' text-anchor='middle' font-size='11' font-weight='800' font-family='Arial, sans-serif' fill='%2306C755'%3ELINE%3C/text%3E%3C/svg%3E");


	
	
}

/* ユーザーの省モーション設定に追従 */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
}



/* =======================================
   1) Base
======================================= */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;overflow-x:hidden;}
html,body{
  font-family:"Noto Sans JP",system-ui,-apple-system,"Segoe UI","Hiragino Kaku Gothic ProN","Hiragino Sans","Noto Sans CJK JP",Meiryo,sans-serif;
  font-weight:400;line-height:1.8;color:var(--text);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;height:auto;display:block;}
.container{max-width:var(--max-w);width:100%;margin-inline:auto;padding-inline:clamp(16px,4vw,24px);}
.container--narrow{max-width:var(--max-w-narrow);width:100%;margin-inline:auto;padding-inline:clamp(16px,4vw,24px);}
.container--wide{width:min(1100px,94vw);margin-inline:auto;padding-inline:clamp(8px,2vw,16px);}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* 改行ユーティリティ */
.pc-br{display:none;}
.sp-br{display:inline;}
@media (min-width:961px){.pc-br{display:inline;}.sp-br{display:none;}}

/* 表示切替ユーティリティ */
.pc-only{display:none;}
.sp-only{display:block;}
@media (min-width:961px){.pc-only{display:block;}.sp-only{display:none;}}

/* =======================================
   2) Header（PC=横並び / SP=オーバーレイ）
======================================= */
.site-header{
  position:fixed; inset:0 0 auto 0; width:100%;
  background:transparent; border-bottom:1px solid transparent;
  transition:background .3s, border-color .3s, box-shadow .3s, opacity .35s;
  z-index:1000; opacity:1; pointer-events:auto;
}
.header-inner{
  position:relative; display:flex; align-items:center; gap:var(--header-gap);
  min-height:var(--header-h); padding-block:12px;
  transition:min-height .28s, gap .28s, padding .28s;
}
.site-header.scrolled{
  background:#fff; border-bottom-color:var(--line); box-shadow:0 1px 8px rgba(0,0,0,.04);
}
.site-header.scrolled .header-inner{ padding-block:8px; }


.site-header .logo{ display:flex; align-items:center; line-height:0; }
.site-header .logo a{
  display:flex; align-items:center; padding:4px 0; color:var(--text-invert); transition:color .25s;
}
.site-header.scrolled .logo a{ color:var(--text); }
.site-header .logo svg{
  width:var(--logo-w); height:auto; display:block; color:#fff;
  transition:width .28s ease, color .28s ease;
}
.site-header.scrolled .logo svg{ width:var(--logo-w-small); color:var(--brand); }


/* ヒーロー上でもヘッダーが読める“上部scrim” */
.site-header:not(.scrolled)::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,.42) 0%,
    rgba(0,0,0,.20) 45%,
    rgba(0,0,0,0) 100%
  );
  pointer-events:none;
  z-index:-1; /* header-innerより背面 */
}

/* 念のためヘッダー自体を stacking させる */
.site-header{ position:fixed; }
.header-inner{ position:relative; z-index:1; }




/* PCナビ */
#global-nav{ margin-left:auto; }
#global-nav .menu{ list-style:none; display:flex; gap:24px; margin:0; padding:0; }
#global-nav .menu>li>a{
  display:block; padding-block:var(--nav-pad-y); color:var(--text-invert); font-weight:bold;
  transition:padding .28s, color .25s, opacity .25s;
}
.site-header.scrolled #global-nav .menu>li>a{ color:var(--text); }
#global-nav .menu>li>a:hover{ opacity:.7; }

@media (min-width:961px){
  #global-nav{ display:flex !important; align-items:center !important; gap:16px !important; margin-left:auto; }
  #global-nav .menu{ display:flex !important; flex-direction:row !important; align-items:center !important; gap:24px !important; margin:0 !important; padding:0 !important; }
}

/* CTAボタン（共通ベース） */
.btn-cta{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:6px; border:1px solid transparent;
  font-weight:700; line-height:1; text-decoration:none;
  transition:transform .18s, opacity .18s, filter .18s, background .18s, color .18s, border-color .18s;
}
.btn-cta:hover{ transform:translateY(-1px); opacity:.96; }
.btn-cta:focus-visible{ outline:2px solid #000; outline-offset:2px; }

/* ── PC専用 nav-cta（右端の目立つボタン） ── */
.nav-cta{ display:none; }
@media (min-width:961px){
  .nav-cta{ display:flex; align-items:center; gap:12px; margin-left:10px; flex:0 0 auto; }
  /* 配色（PC） */
  #global-nav .nav-cta .btn-cta--trial{
    background:#CC7F91 !important; border-color:#CC7F91 !important; color:#fff !important;
  }
  #global-nav .nav-cta .btn-cta--line{
    background:var(--line-btn, #5A8FAF); border-color:var(--line-btn, #5A8FAF) !important; color:#fff !important;
	}
	
  .nav-cta .btn-cta--trial:hover,
  .nav-cta .btn-cta--line:hover{ filter:brightness(.95); }
}

/* ── SP用：ドロワー内CTA ── */
.menu-cta-wrap{ display:none; }






.btn-cta--line{
  display:inline-flex;
  align-items:center;
  gap:6px; /* 少し詰める */
}

/* 公式LINEアイコン */
.btn-cta--line::before{
  content:"";
  width:20px;
  height:20px;
  background-image:url("./assets/img/line.png");
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
  flex-shrink:0;
}








@media (max-width:960px){
  .menu-cta-wrap{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:16px; }
  /* 配色（SPドロワー） */
  #global-nav .menu-cta-wrap .btn-cta--brand{
    background:#CC7F91 !important; border-color:#CC7F91 !important; color:#fff !important;
  }
  #global-nav .menu-cta-wrap .btn-cta--line{
    background:#5FAF8F !important; border-color:#5FAF8F !important; color:#fff !important;
  }
}

/* SPメニューボタン（右上テキスト） */
.menu-btn.menu-btn--text{
  display:none; position:absolute; right:16px; top:10px; padding:8px 14px; background:transparent; border:0; cursor:pointer; z-index:1100;
  font-family:"Noto Serif JP",serif; font-style:italic; font-size:20px; font-weight:700; color:var(--text-invert); transition:color .25s;
}
.site-header.scrolled .menu-btn.menu-btn--text{ color:var(--text); }
.menu-btn__label{ position:relative; display:inline-block; padding-bottom:2px; }
.menu-btn__label::after{
  content:""; position:absolute; left:0; bottom:0; width:100%; height:1px;
  background:currentColor; transform:scaleX(1); transform-origin:left; transition:transform .25s;
}
.menu-btn.is-open .menu-btn__label::after{ transform:scaleX(0); }
.menu-btn__label::before{ content:attr(data-open); }
.menu-btn.is-open .menu-btn__label::before{ content:attr(data-close); }

/* ── SPドロワー本体 ── */
@media (max-width:960px){
  .menu-btn.menu-btn--text{ display:inline-block; }
  .site-header .logo svg{ width:var(--logo-w-sp); }
  .site-header.scrolled .logo svg{ width:var(--logo-w-sp-small); }

  #global-nav{
    position:fixed; inset:0; display:flex; flex-direction:column; justify-content:center; align-items:center;
    background:#fff; opacity:0; pointer-events:none; transform:scale(1.02);
    transition:opacity .32s, transform .32s; z-index:1090;
  }
  #global-nav.open{ opacity:1; pointer-events:auto; transform:none; }
  #global-nav .nav-backdrop{ position:fixed; inset:0; background:var(--backdrop); opacity:0; pointer-events:none; transition:opacity .28s; z-index:-1; }
  #global-nav.open .nav-backdrop{ opacity:1; pointer-events:auto; }

  #global-nav .menu{ flex-direction:column; gap:18px; width:min(92%,720px); }
  #global-nav .menu>li>a{
    color:var(--text) !important; border-bottom:1px solid transparent; padding:16px 20px; line-height:1.4;
  }
}

/* ── PC固定（ドロワー無効化） ── */
@media (min-width:961px){
  .menu-btn.menu-btn--text{ display:none !important; }
  #global-nav, #global-nav.open{
    position:static !important; inset:auto !important; transform:none !important; opacity:1 !important;
    pointer-events:auto !important; background:transparent !important; width:auto !important; border-left:0 !important; box-shadow:none !important;
  }
  #global-nav .nav-backdrop{ display:none !important; }
  #global-nav .menu{ flex-direction:row !important; gap:24px !important; margin:0 !important; padding:0 !important; }
  .site-header.scrolled #global-nav .menu>li>a{ padding-block:var(--nav-pad-y-small); }
}

/* ドロワーOPEN時の背景スクロール抑止 */
body.no-scroll, body.drawer-open{ overflow:hidden; touch-action:none; }
.site-header:not(.scrolled){
  background:transparent !important; border-bottom-color:transparent !important; box-shadow:none !important;
}

/* =======================================
   3) SP固定バー（LINE予約／無料体験）
======================================= */
.fixed-reserve{
  position:fixed; left:0; right:0; bottom:0; display:flex; align-items:stretch; height:clamp(52px,7.2vh,64px);
  z-index:1200; background:#fff; box-shadow:0 -6px 22px rgba(0,0,0,.08);
  padding-bottom:env(safe-area-inset-bottom,0); transition:transform .28s ease, opacity .28s ease, visibility .28s ease;
}
.drawer-open .fixed-reserve{ transform:translateY(100%); opacity:0; visibility:hidden; pointer-events:none; }
.fixed-btn{
  flex:0 0 50% !important; display:flex; align-items:center; justify-content:center; gap:10px;
  padding:0 clamp(12px,3vw,18px); font-weight:700; letter-spacing:.02em; font-size:15px; line-height:1;
  -webkit-tap-highlight-color:transparent; min-height:48px;
  border-radius:0; /* ← スマ下部はフラット */
}
.fixed-btn--primary{ background:#90B8E0; color:#fff; border:0; }
.fixed-btn--ghost  { background:#CC7F91; color:#fff; border:0; }
.fixed-btn::before{
  -webkit-mask:none !important; mask:none !important; content:""; width:1.15em; height:1.15em; display:inline-block; background-repeat:no-repeat; background-position:center; background-size:100% 100%;
}
.fixed-btn--primary::before{
  background-image:url(data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M2 3h20v14H7l-5 5V3z'/%3E%3C/svg%3E);
}
.fixed-btn--ghost::before{
  background-image:url(data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M12 17.27 18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z'/%3E%3C/svg%3E);
}

		/* SP固定バー：LINE予約（強制） */
.fixed-reserve .fixed-btn--line{
  background: var(--line-btn, #5A8FAF);
  color:#fff;
  border:0;
}

/* LINEアイコン（ヘッダーと同じpng） */
.fixed-reserve .fixed-btn--line::before{
  content:"";
  width: 1.15em;
  height: 1.15em;
  display:inline-block;
  background-image:url("/wp-content/themes/solina_pilates_theme/assets/img/line.png");
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
}


.fixed-btn--line:hover{ filter: brightness(.96); }

@media (min-width:961px){ .fixed-reserve{ display:none; } }




/* =====================================================
   HOTFIX: HERO整理（重複セレクタを最後で統一）
   - hero-copy の二重定義/競合を解消
   - overlay はPC基準 + SP上書き
   - 未使用の hero-kicker/headline/sub は使わない前提
===================================================== */

/* ===== HERO / Swiper ===== */
.hero--swiper{ position:relative; height:100dvh; overflow:hidden; background:#111; }

.hero-swiper,
.hero-swiper .swiper-wrapper,
.hero-swiper .swiper-slide{ width:100%; height:100dvh; }

.hero-swiper{ position:relative; overflow:hidden; }
.hero-swiper .swiper-slide img{
  width:100%;
  height:100%;
  object-fit:cover;
  will-change: transform, opacity;
  transform: translateZ(0);
}

/* overlay（PC基準） */
.hero-swiper::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 520px at 18% 50%,
      rgba(204,127,145,.55) 0%,
      rgba(204,127,145,.22) 40%,
      rgba(0,0,0,0) 70%),
    linear-gradient(to right,
      rgba(0,0,0,.28) 0%,
      rgba(0,0,0,.10) 45%,
      rgba(0,0,0,0) 70%);
  pointer-events:none;
  z-index:1;
}

/* SPはoverlayを上書き（読みやすさ優先） */
@media (max-width:960px){
  .hero-swiper::after{
    background:
      radial-gradient(900px 520px at 50% 35%,
        rgba(204,127,145,.34) 0%,
        rgba(204,127,145,.18) 48%,
        rgba(204,127,145,.06) 72%,
        rgba(204,127,145,0) 100%),
      linear-gradient(to bottom,
        rgba(0,0,0,.08) 0%,
        rgba(0,0,0,.16) 60%,
        rgba(0,0,0,.30) 100%);
  }
}

/* fade想定 */
.hero-swiper.swiper-fade .swiper-slide{
  pointer-events:none;
  transition:opacity 1.4s ease !important;
  z-index:0;
}
.hero-swiper.swiper-fade .swiper-slide-active{ pointer-events:auto; }

/* zoom（任意） */
@keyframes heroZoom{ from{ transform:scale(1); } to{ transform:scale(1.06); } }
.hero-swiper .swiper-slide.swiper-slide-active img{
  animation: heroZoom 6.8s linear forwards;
}
@media (prefers-reduced-motion: reduce){
  .hero-swiper .swiper-slide.swiper-slide-active img{ animation:none !important; }
}

/* ===== HERO Copy（front-page.php準拠） ===== */
.hero-copy{
  position:absolute;
  inset:0;
  z-index:5;            /* overlay(1)より上 */
  pointer-events:none;  /* 全体はクリックさせない */
}

/* 箱：位置とサイズ */
/* 箱：位置とサイズ（FIX：文字が上に上がるのを防止） */
.hero-copy--h{
  position:absolute;
  left: clamp(18px, 4.5vw, 72px);
  max-width: min(640px, 92vw);
  color:#fff;
  text-shadow: 0 2px 14px rgba(0,0,0,.28);
}

/* PC：縦センターより少し下に固定 */
@media (min-width: 961px){
  .hero-copy--h{
    top: 58%;
    bottom: auto;
    transform: translateY(-50%);
  }
  /* 余計な上の逃げで位置がズレるのを防ぐ */
  .hero-copy--h .hero-copy__inner{
    padding-top: 0;
  }
}

/* SP：従来通り下寄せ（固定バー分も考慮） */
@media (max-width: 960px){
  .hero-copy--h{
    top: auto;
    bottom: clamp(84px, 12vh, 140px);
    transform: none;
  }
  .hero-copy--h .hero-copy__inner{
    padding-top: 0;
    padding-bottom: calc(72px + env(safe-area-inset-bottom,0) + 64px);
  }
}

/* 中：ヘッダー/固定バーの逃げ */
.hero-copy--h .hero-copy__inner{
  padding-top: calc(var(--header-h, 64px) + 24px);
}
@media (max-width:960px){
  .hero-copy--h .hero-copy__inner{
    padding-bottom: calc(72px + env(safe-area-inset-bottom,0) + 64px);
  }
}

/* text */
.hero-copy--h .hero-copy__eyebrow{
  margin:0 0 10px;
  letter-spacing:.16em;
  font-weight:700;
  opacity:.92;
}
.hero-copy--h .hero-copy__title{
  margin:0 0 12px;
  font-family:"Klee One","Noto Serif JP",serif;
  font-weight:700;
  letter-spacing:.06em;
  line-height:1.25;
  font-size: clamp(34px, 4.2vw, 56px);
}
.hero-copy--h .hero-copy__lead{
  margin:0 0 22px;
  font-size: clamp(14px, 1.55vw, 18px);
  line-height:1.9;
  opacity:.95;
}

/* CTA：ボタンだけクリック可能に */
.hero-copy--h .hero-copy__cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  pointer-events:auto;
}
.hero-copy--h .hero-copy__cta a{ pointer-events:auto; }

/* buttons */
.btn-hero{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55em;
  padding: 14px 22px;
  border-radius: 999px;
  font-weight:800;
  letter-spacing:.04em;
  border:1px solid transparent;
  transition: transform .18s, filter .18s, opacity .18s;
}
.btn-hero:hover{ transform: translateY(-1px); filter: brightness(.97); opacity:.98; }

.btn-hero--trial{
  color:#fff;
  background: linear-gradient(90deg,
    color-mix(in oklab, var(--brand) 92%, #fff) 0%,
    color-mix(in oklab, var(--brand) 72%, #fff) 55%,
    color-mix(in oklab, var(--brand) 55%, #fff) 100%);
  box-shadow: 0 10px 26px rgba(204,127,145,.28);
}

.btn-hero--line{
  color:#fff;
  background: var(--line-btn, #06C755);
  box-shadow: 0 10px 26px rgba(6,199,85,.18);
}
.btn-hero--line::before{
  content:"";
  width: 1.2em;
  height: 1.2em;
  display:inline-block;
  background-image:url("/wp-content/themes/solina_pilates_theme/assets/img/line.png");
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
}




.page-content{padding:clamp(36px,6vw,72px) 0;}
.prose :where(p,ul,ol){line-height:1.9;}
.prose h2{font-size:clamp(22px,3vw,28px);margin:1.8em 0 .6em;}
.prose h3{font-size:clamp(18px,2.3vw,22px);margin:1.6em 0 .5em;}
.prose img{max-width:100%;height:auto;border-radius:14px;}

.section{padding:clamp(48px,8vw,96px) 0;}
.section-title{font-size:clamp(22px,3vw,32px);font-weight:700;text-align:center;margin-bottom:1em;}
.section-lead{text-align:center;font-size:1.1rem;opacity:.85;}

.feature-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;list-style:none;padding:0;margin:0;text-align:center;}
.feature-list img{border-radius:12px;margin-bottom:12px;}
.visual-grid{display:grid;gap:40px;align-items:center;}
@media (min-width:960px){.visual-grid{grid-template-columns:1fr 1fr;}}
.visual-text p{line-height:1.9;}
.cta{background:#fafafa;text-align:center;}
.cta-buttons{margin-top:20px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.blog-list{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}
.blog-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.06);}
.blog-card img{width:100%;height:auto;display:block;}
.blog-card h3{margin:12px;font-size:1rem;}
.access .map{margin-top:20px;border-radius:12px;overflow:hidden;}

/* 共通ボタン（再掲・他所でも利用） */
.btn,.btn-cta{
  display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:9999px;border:1px solid currentColor;
  text-decoration:none;font-weight:700;letter-spacing:.02em;line-height:1;transition:transform .18s,opacity .18s,background .18s,color .18s,border-color .18s;
}
.btn:hover,.btn-cta:hover{transform:translateY(-1px);opacity:.95;}
.btn-cta .i-line{display:inline-block;vertical-align:-1px;}
.btn--primary{background:#111;color:#fff;border-color:#111;}
.btn-cta--brand{background:var(--brand);border-color:var(--brand);color:#fff;}
.btn-cta--line{background: var(--line-btn, #06C755);
  border-color: var(--line-btn, #06C755);
  color:#fff;}

/* Hero右側CTA（PCのみ） */
.hero-cta{position:absolute;right:clamp(16px,4vw,56px);top:50%;transform:translateY(-50%);display:grid;gap:12px;z-index:3;pointer-events:auto;}
@media (max-width:960px){.hero-cta{display:none;}}

/* =======================================
   Footer（Light / Clean）
======================================= */
.site-footer{
  background:#f8f9fb; /* 清潔感のある薄グレー */
  color:#333;
  padding:60px 0 40px;
  overflow:hidden;
  border-top:1px solid #e6e8eb;
}
.footer-inner{width:min(92%,1200px);margin:0 auto;}
.footer-heading{
  font-size:1.4rem;font-weight:700;letter-spacing:.06em;margin-bottom:24px;
  text-align:center;color:#2b3137;
}

/* layout */
.footer-access-body{display:grid;gap:24px;}
@media (min-width:961px){
  .footer-access-body{grid-template-columns:1.1fr .9fr;gap:40px;align-items:start;}
}

/* map card */
.card{
  background:#fff;border-radius:var(--radius,12px);
  box-shadow:var(--shadow-sm,0 8px 24px rgba(0,0,0,.06));
  overflow:hidden;
}
.footer-map{position:relative;width:100%;aspect-ratio:16/9;min-height:280px;}
@supports not (aspect-ratio:1/1){
  .footer-map{padding-top:56.25%;}
  .footer-map iframe{position:absolute;inset:0;}
}
.footer-map iframe{width:100%;height:100%;border:0;display:block;}

/* text & info */
.footer-access-text{font-size:.95rem;line-height:1.9;word-break:keep-all;}
.footer-address{margin:0 0 10px;}
.footer-hours{margin:0 0 10px;color:#4b5563;}
.footer-contacts{list-style:none;padding:0;margin:10px 0 18px;display:flex;flex-wrap:wrap;gap:14px;}
.footer-contacts a{color:#1f2937;text-decoration:underline;text-decoration-color:#cbd5e1;text-underline-offset:3px;}
.footer-contacts a:hover{opacity:.85}

/* CTAs */
.footer-ctas{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 10px;}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45em;
  padding:.75em 1.05em;border-radius:999px;font-weight:700;font-size:.95rem;
  border:1px solid transparent;text-decoration:none;transition:.2s ease;
}
	.btn.line{
  background: var(--line-btn, #5A8FAF);
  color:#fff;
  display:inline-flex;
  align-items:center;
  gap:.45em; /* 文字との余白 */
}

/* LINEアイコン */
.btn.line::before{
  content:"";
  width:1.1em;
  height:1.1em;
  display:inline-block;
  background-image:url("/wp-content/themes/linoe_pilates_theme/assets/img/line.png");
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
  flex-shrink:0;
}
	
.btn.line:hover{filter:brightness(.95);}
.btn.trial{background:#CC7F91;color:#fff;}
.btn.trial:hover{filter:brightness(.96);}
.btn.ghost{background:#fff;border-color:#d1d5db;color:#374151;}
.btn.ghost:hover{border-color:#c5cad3;background:#f9fafb}
		.btn.pri{background:#90B8E0;color:#fff;}		
		
		
		
		.footer-directions {
  margin-top: 1em;
  font-size: 0.9rem;
  line-height: 1.6;
}
.footer-directions h3 {
  font-weight: 600;
  margin-bottom: 0.3em;
}
.footer-directions ul {
  list-style: none;

}
		
		
/* =========================
   Campaign（Footer直前/独立カード）
========================= */
.site-campaign-wrap{
  padding: clamp(18px, 3vw, 28px) 0 0;
  background: transparent;
}
.site-campaign__inner{
  width: min(92%, 1200px);
  margin-inline: auto;
}

/* Card */
.campaign.card{
  background:#fff;
  border:1px solid #e6e8eb;
  border-radius: var(--radius, 12px);
  box-shadow: var(--shadow-sm, 0 10px 28px rgba(0,0,0,.08));
  padding: clamp(18px, 3.6vw, 28px);
}

/* Header */
.campaign__head{ text-align:center; margin-bottom: 14px; }
.campaign__label{
  display:inline-block;
  font-size:.86rem;
  letter-spacing:.12em;
  font-weight:800;
  color:#1f2937;
  background: #f3f4f6;
  border: 1px solid #e5e7eb;
  border-radius:999px;
  padding: 7px 12px;
}
.campaign--january .campaign__label{
  background: #fff7ed;
  border-color: #fed7aa;
  color: #9a3412;
}
.campaign__title{
  font-family:"Klee One","Noto Serif JP",serif;
  font-weight:700;
  color: var(--brand, #90B8E0);
  font-size: clamp(20px, 3.2vw, 30px);
  margin: 10px 0 6px;
}
.campaign__lead{
  margin: 0 auto;
  max-width: 52rem;
  font-size: 1rem;
  line-height: 1.9;
  color: #374151;
}

/* =========================
   通常月：3カード（少し強め）
========================= */
.campaign-grid{
  list-style:none;
  padding:0;
  margin: 18px 0 10px;
  display:grid;
  gap:12px;
}
@media (min-width:801px){
  .campaign-grid{ grid-template-columns: repeat(3, 1fr); gap: 14px; }
}
.campaign-card{
  border: 1px solid #eee;
  border-radius: 14px;
  padding: 14px 14px 16px;
  background:#fff;
}
.campaign-card__title{
  margin: 0 0 .45em;
  font-weight: 800;
  color:#111827;
}
.campaign-card__desc{
  margin: 0 0 .35em;
  color:#4b5563;
  font-size:.95rem;
}
.campaign-card__price{ margin:0; font-size:1rem; }
.campaign-card__price del{ color:#9ca3af; margin-right:.4em; }
.campaign-card__price .now{ display:inline-flex; gap:.35em; font-weight:900; }
.campaign-card__price .now strong{ font-size:1.25rem; color:#111; }
.campaign-card__note{
  margin-top:.55em;
  color:#374151;
}
.campaign-card__note strong{
  font-weight:900;
}

/* =========================
   1月：縦（トリプル）スタック
========================= */
.campaign-stack{
  list-style:none;
  padding:0;
  margin: 18px 0 12px;
  display:grid;
  gap: 12px;
}
.campaign-item{
  border: 1px solid #eee;
  border-radius: 14px;
  padding: 14px 14px 16px;
  background:#fff;
}
.campaign-item__head{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin-bottom: 6px;
}
.campaign-item__head .num{
  display:inline-grid;
  place-items:center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  font-weight: 900;
  background: #111827;
  color:#fff;
  flex: 0 0 auto;
}
.campaign-item__title{
  margin:0;
  font-weight: 900;
  color:#111827;
  line-height: 1.35;
}
.campaign-item__desc{
  margin: 0;
  color:#4b5563;
  line-height: 1.8;
}
.campaign-sublist{
  margin: 8px 0 0;
  padding-left: 1.2em;
  color:#374151;
  line-height: 1.9;
}
.campaign-sublist strong{ font-weight: 900; }

.tag{
  display:inline-block;
  margin-left: .4em;
  padding: .2em .55em;
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 900;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  color: #9a3412;
  vertical-align: middle;
}
.tag--soft{
  background:#eff6ff;
  border-color:#bfdbfe;
  color:#1d4ed8;
}

/* CTA */
.campaign-ctas{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
  margin-top: 14px;
}
.campaign-ctas--primary .btn.line{
  /* 主CTA感をちょい強め */
  transform: translateY(0);
}

/* Notes */
.campaign-notes{
  margin: 12px 0 0;
  padding-left: 1.1em;
  color:#6b7280;
  line-height: 1.8;
}
.campaign-note{
  margin: 10px 0 0;
  color:#6b7280;
  line-height: 1.7;
}

/* Banner */
.campaign-banner.card{
  display:block;
  overflow:hidden;
  border-radius: var(--radius, 12px);
  border:1px solid #e6e8eb;
  box-shadow: var(--shadow-sm, 0 10px 28px rgba(0,0,0,.08));
}
.campaign-banner img{ width:100%; height:auto; display:block; }
.banner-badge{
  position:absolute;
  top:12px; left:12px;
  display:inline-block;
  padding:6px 10px;
  border-radius: 999px;
  font-size:.85rem;
  font-weight:900;
  background: rgba(255,255,255,.92);
  border:1px solid rgba(229,231,235,.9);
  color:#111827;
}


/* 既存の .btn, .btn.line, .btn.trial を流用（定義済） */
/* PCで少し見栄えを強めたい場合は以下を任意で追加
.campaign-ctas .btn{ min-width: 200px; }
*/
					
					
/* =======================================
   9) Page Hero (TCD-ish) 共通
======================================= */
.page-hero.tcd-ish{
  position:relative;color:#111;background:#f5f5f5;
  padding:clamp(84px,14vw,220px) 0 clamp(34px,5vw,56px);
}
.page-hero.tcd-ish .page-hero__inner{
  position:relative;z-index:1;display:grid;grid-template-rows:1fr auto; /* 本文 + パンくず帯 */
  min-height:clamp(60vh,70vh,72vh);
}
.page-hero.tcd-ish .page-hero__container{
  align-self:center;justify-self:center;width:min(92vw,1000px);text-align:center;padding-inline:16px;
}
.page-hero.tcd-ish .page-hero__title{
  margin:0 0 .4em;font-size:clamp(28px,5.2vw,56px);font-weight:700;letter-spacing:.02em;text-shadow:0 2px 14px rgba(0,0,0,.3);color:currentColor;
}
.page-hero.tcd-ish .page-hero__subtitle{margin:0;font-size:clamp(14px,1.8vw,18px);opacity:.95;text-shadow:0 2px 10px rgba(0,0,0,.28);color:currentColor;}
.page-hero.tcd-ish .page-hero__crumbs{align-self:end;}
.page-hero.tcd-ish .page-hero__crumbs-inner{
  display:flex;align-items:center;min-height:46px;padding:10px clamp(16px,4vw,28px);
  background:rgba(0,0,0,.3);backdrop-filter:saturate(1.1) blur(2px);
}
.page-hero.tcd-ish:not(.has-image) .page-hero__crumbs-inner{background:rgba(0,0,0,.06);}
.page-hero.tcd-ish .breadcrumbs{width:100%;color:#fff;font-size:13px;white-space:nowrap;overflow:auto;}
.page-hero.tcd-ish:not(.has-image) .breadcrumbs{color:#333;}
.page-hero.tcd-ish .breadcrumbs a{color:inherit;opacity:.9;text-decoration:none;}
.page-hero.tcd-ish .breadcrumbs a:hover{opacity:1;text-decoration:underline;}
.page-hero.tcd-ish .breadcrumbs span{opacity:.75;}
.page-hero.tcd-ish.is-compact{padding:clamp(56px,9vw,120px) 0 clamp(26px,4vw,40px);}
.page-hero.tcd-ish.is-compact .page-hero__inner{min-height:42vh;}
@media (max-width:960px){.page-hero.tcd-ish .page-hero__inner{min-height:56vh;}}

/* 画像あり時のオーバーレイ */
.page-hero.tcd-ish.has-image{color:#fff;background-image:var(--hero);background-size:cover;background-position:center;}
.page-hero.tcd-ish .page-hero__overlay{
  position:absolute;inset:0;background:linear-gradient(to bottom, rgba(0,0,0,.20) 0%, rgba(0,0,0,.20) 35%, rgba(0,0,0,.35) 70%, rgba(0,0,0,.55) 100%);
  opacity:0;pointer-events:none;transition:opacity .35s ease;
}
.page-hero.tcd-ish.has-image .page-hero__overlay{opacity:1;}

/* =======================================
   Concept page
======================================= */

/* 共通タイトル */
.concept .section-title,
.concept h3,
.concept-features__head .section-title {
  font-family: "Klee One","Noto Serif JP",serif;
  font-weight: 600;
  color: var(--brand);
  letter-spacing: .05em;
  line-height: 1.4;
  text-align: center;
  margin-bottom: 1em;
}
.concept .section-title { font-size: clamp(22px,3vw,32px); }
.concept h3,
.concept h3.section-title,
.concept-features__head .section-title { font-size: clamp(22px,3.2vw,30px); }
.concept .section-lead { font-size: 1.05rem; opacity: .9; }
.concept .visual-text p { margin: .5em 0; }
.concept .visual-image img {
  display: block; width: 100%; height: auto;
  border-radius: 12px; object-fit: cover;
}
@media (min-width:960px) {
  .visual-grid { display:grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 40px; }
}

/* ======================
   Features セクション（3カード）
====================== */
.concept-features__head {
  text-align: center;
  max-width: 56rem;
  margin: 0 auto 18px;
}
.concept-features__head p {
  max-width: 48rem;
  margin: .6em auto 0;
  line-height: 1.9;
  font-size: 1rem;
  opacity: .95;
}

.feature-grid {
  display: grid;
  gap: 16px;
  margin-top: 22px;
  list-style: none;
  padding: 0;
}
@media (min-width:961px) {
  .feature-grid { grid-template-columns: repeat(3,1fr); }
}
@media (max-width:960px) and (min-width:561px) {
  .feature-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width:560px) {
  .feature-grid { grid-template-columns: 1fr; }
}

.feature-card {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  padding: 16px;
  border: 1px solid #eee;
  border-radius: 12px;
  background: #fff;
  box-shadow: var(--shadow-sm);
  text-align: left;
}
.feature-card__media {
  flex: 0 0 200px;
  max-width: 200px;
}
.feature-card__media img {
  display: block;
  width: 100%; height: auto;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 10px;
}
.feature-card__body {
  flex: 1;
  min-width: 0;   /* ← これがないと一文字折り返しになる */
}
.feature-card__title {
  margin: 0 0 .4em;
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1.5;
  color: #111;
}
.feature-card__text {
  margin: 0;
  line-height: 1.8;
  font-size: 1rem;
  opacity: .95;
}
.feature-card__text + .feature-card__text { margin-top: .6em; }

@media (max-width:680px) {
  .feature-card { flex-direction: column; }
  .feature-card__media { flex: none; width: 100%; max-width: 100%; }
}

/* ======================
   Method セクション（タイムライン）
====================== */
.concept-method .method-steps {
  position: relative;
  display: grid;
  gap: 28px;
  margin: 32px 0;
  padding-left: 48px; /* 番号分の余白 */
  list-style: none;
}
.concept-method .method-steps::before {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  left: 22px;
  width: 2px;
  background: #e5e7eb;
}
.concept-method .method-step {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.concept-method .method-num {
  position: absolute;
  left: -48px;
  top: 0;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--brand,#90B8E0);
  color: #fff;
  font-weight: 800;
  font-size: 1rem;
  line-height: 44px;
  text-align: center;
  box-shadow: 0 2px 6px rgba(0,0,0,.08);
}
.concept-method .method-body h4 {
  margin: 0 0 .25em;
  font-size: 1.1rem;
  font-weight: 700;
  color: #111;
}
.concept-method .method-body p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.8;
  opacity: .95;
}
.concept-method .method-visual { margin-top: 32px; }
.concept-method .method-visual img {
  width: 100%; height: auto;
  border-radius: 14px; object-fit: cover;
}

/* ======================
   横長ビジュアル帯
====================== */
.concept-visual-band { padding: clamp(16px,3vw,24px) 0; }
.concept-visual-band .band-figure {
  position: relative; width: 100%; aspect-ratio: 21/9;
  border-radius: 14px; overflow: hidden;
  background: #eaeaea; box-shadow: 0 6px 24px rgba(0,0,0,.06);
}
.concept-visual-band .band-figure img {
  display: block; width: 100%; height: 100%;
  object-fit: cover; transform: translateZ(0);
}
@media (max-height:680px) {
  .concept-visual-band .band-figure { max-height: 46vh; }
}

/* ===== HOTFIX: Concept Features を強制レイアウト（最下部に貼る） ===== */
.concept-features .feature-grid{
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
  margin-top: 22px;
  list-style: none; padding: 0;
}
@media (min-width: 961px){
  .concept-features .feature-grid{
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

.concept-features .feature-card{
  display: flex !important;
  align-items: flex-start !important;
  gap: 18px !important;
  padding: 16px !important;
  border: 1px solid #eee;
  border-radius: 12px;
  background: #fff;
  box-shadow: var(--shadow-sm, 0 4px 12px rgba(0,0,0,.06));
  text-align: left !important;
}

/* 左：画像 */
.concept-features .feature-card__media{
  flex: 0 0 200px !important;
  max-width: 200px !important;
  margin: 0 !important;
}
.concept-features .feature-card__media img{
  display: block; width: 100%; height: auto;
  aspect-ratio: 4 / 3; object-fit: cover;
  border-radius: 10px;
}

/* 右：本文（潰れ防止が本命） */
.concept-features .feature-card__body{
  flex: 1 1 auto !important;
  min-width: 0 !important;   /* ← これが無いと1文字折りになる */
  width: auto !important;
  overflow: visible;
  writing-mode: horizontal-tb !important; /* 念のため横書きを強制 */
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: anywhere;
}
.concept-features .feature-card__title{
  margin: 0 0 .4em !important;
  font-size: 1.1rem; font-weight: 700; line-height: 1.5; color: #111;
}
.concept-features .feature-card__text{ margin: 0; line-height: 1.8; font-size: 1rem; opacity: .95; }
.concept-features .feature-card__text + .feature-card__text{ margin-top: .6em; }

/* SPでは縦積み */
@media (max-width: 680px){
  .concept-features .feature-card{ flex-direction: column !important; }
  .concept-features .feature-card__media{
    flex: none !important; width: 100% !important; max-width: 100% !important;
  }
}

/* 他セクションの .feature-card 既存指定を無効化（影響範囲をConcept内に限定） */
.concept-features .feature-card img{ margin-bottom: 0 !important; }
		
		
/* ===== Concept (scoped & conflict-free) ===== */

/* 共通 */
.cpt-concept .cpt-section-title,
.cpt-concept h3.cpt-h3 {
  font-family: "Klee One","Noto Serif JP",serif;
  font-weight: 600;
  color: var(--brand, #90B8E0);
  letter-spacing: .05em;
  line-height: 1.4;
  text-align: center;
  margin: 0 0 1em;
}
.cpt-concept .cpt-section-title { font-size: clamp(22px,3vw,32px); }
.cpt-concept h3.cpt-h3 { font-size: clamp(22px,3.2vw,30px); }
.cpt-concept .cpt-lead { font-size: 1.05rem; opacity: .9; text-align: center; }
.cpt-concept .cpt-container { max-width: var(--max-w, 1100px); width: 100%; margin: 0 auto; padding-inline: clamp(16px,4vw,24px); }

/* 1) イントロ */
.cpt-intro { padding: clamp(48px,8vw,96px) 0; }
.cpt-visual-band { padding: clamp(16px,3vw,24px) 0; }
.cpt-visual-band .cpt-band-figure {
  position: relative; width: 100%; aspect-ratio: 21/9;
  border-radius: 14px; overflow: hidden; background: #eaeaea;
  box-shadow: 0 6px 24px rgba(0,0,0,.06);
}
.cpt-visual-band .cpt-band-figure img {
  display:block; width:100%; height:100%; object-fit:cover; transform: translateZ(0);
}

/* 2) Features（画像 左 / テキスト 右、上揃え、スマホ縦積み） */
.cpt-features { padding: clamp(48px,8vw,96px) 0; }
.cpt-features-head { text-align:center; max-width:56rem; margin:0 auto 18px; }
.cpt-features-head p {
  max-width:48rem; margin:.6em auto 0; line-height:1.9; font-size:1rem; opacity:.95;
}

/* リスト（縦積み） */
.cpt-feature-list {
  list-style: none; padding: 0; margin: 22px 0 0;
  display: grid; gap: 16px;
}

/* カード本体（横並びレイアウト） */
.cpt-card {
  display: flex; align-items: flex-start;
  gap: 18px; padding: 16px;
  border: 1px solid #eee; border-radius: 12px;
  background: #fff; box-shadow: var(--shadow-sm, 0 4px 12px rgba(0,0,0,.06));
  text-align: left;
}

/* 左：画像 */
.cpt-card-media {
  --thumb: clamp(120px, 32vw, 200px);
  flex: 0 0 var(--thumb); max-width: var(--thumb); margin: 0;
}
@media (min-width: 801px){ .cpt-card-media{ --thumb: 200px; } }
.cpt-card-media img {
  display:block; width:100%; height:auto; aspect-ratio:4/3;
  object-fit:cover; border-radius:10px;
}

/* 右：本文（潰れ防止がカギ） */
.cpt-card-body {
  flex: 1 1 auto; min-width: 0; width: auto;
  writing-mode: horizontal-tb; white-space: normal;
  word-break: break-word; overflow-wrap: anywhere;
}
.cpt-card-title {
  margin: 0 0 .4em; font-size: 1.1rem; font-weight: 700; line-height: 1.5; color: #111;
}
.cpt-card-text { margin: 0; line-height: 1.8; font-size: 1rem; opacity: .95; }
.cpt-card-text + .cpt-card-text { margin-top: .6em; }

/* スマホでは縦積み */
@media (max-width: 680px){
  .cpt-card { flex-direction: column; }
  .cpt-card-media { flex: none; width: 100%; max-width: 100%; }
}

/* 3) Two-col（テキスト＆画像） */
.cpt-two-col { padding: clamp(48px,8vw,96px) 0; }
.cpt-two-col-grid {
  display: grid; gap: 40px; align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width:960px){
  .cpt-two-col-grid { grid-template-columns: 1fr 1fr; }
}
.cpt-two-col .cpt-visual-text p { margin:.5em 0; line-height:1.9; }
.cpt-two-col .cpt-visual-image img {
  display:block; width:100%; height:auto; border-radius:12px; object-fit:cover;
}

/* 4) Method（年表風：左丸数字＋縦線） */
.cpt-method { padding: clamp(48px,8vw,96px) 0; }
.cpt-steps {
  position: relative; display: block;
  max-width: 56rem; margin: 24px auto 10px;
}
.cpt-steps::before {
  content:""; position:absolute; left:30px; top:0; bottom:0; width:2px; background:#eee;
}
.cpt-step {
  position: relative;
  display: grid; grid-template-columns: 60px 1fr; gap: 16px;
  padding: 18px 12px 18px 0; margin: 0;
  background: transparent; border: 0; box-shadow: none;
}
.cpt-step + .cpt-step { margin-top: 8px; }
.cpt-num {
  position: relative; z-index: 1;
  width: 40px; height: 40px; margin-left: 10px; border-radius: 50%;
  display: grid; place-items: center;
  font-weight: 800; letter-spacing: .06em;
  background: var(--brand, #90B8E0); color: #fff; font-size: .95rem;
  box-shadow: 0 4px 12px rgba(0,0,0,.06);
}
.cpt-step h4 { margin: .1em 0 .4em; font-size: 1.1rem; line-height: 1.5; }
.cpt-step p  { margin: 0; line-height: 1.9; font-size: 1rem; opacity: .96; }

/* 年表下の横長画像 */
.cpt-method-visual {
  margin: 20px auto 0; max-width: 1100px;
  padding-inline: clamp(16px,4vw,24px);
}
.cpt-method-visual img {
  display:block; width:100%; height:auto;
  aspect-ratio: 21/9; object-fit:cover;
  border-radius:14px; box-shadow:0 6px 24px rgba(0,0,0,.06);
}
		
		/* ======================
   Concept: Approach（1カラム + 下に画像）
====================== */
.cpt-two-col {
  padding: clamp(48px,8vw,96px) 0;
}

.cpt-two-col-grid {
  display: block; /* ← グリッド解除 */
  max-width: 56rem;
  margin: 0 auto;
  padding-inline: clamp(16px,4vw,24px);
}

.cpt-two-col .cpt-visual-text {
  margin-bottom: 18px;
  text-align: left;
}

.cpt-two-col .cpt-visual-text p {
  margin: .5em 0;
  line-height: 1.9;
}

.cpt-two-col .cpt-visual-image {
  margin: 0;
}

.cpt-two-col .cpt-visual-image img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 21/9; /* 横長に安定 */
  object-fit: cover;
  border-radius: 14px;
  box-shadow: 0 6px 24px rgba(0,0,0,.06);
}
		
		
		
		
/* =======================================
   11) MENU
======================================= */
.menu-strengths__grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));list-style:none;padding:0;margin:0;}
.menu-card{
  position:relative;background:#fff;border:1px solid #eee;border-radius:12px;padding:16px;text-align:center;box-shadow:var(--shadow-sm);
}
.menu-card__num{
  position:absolute;left:12px;top:12px;width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:#111;color:#fff;font-weight:800;font-size:.95rem;letter-spacing:.06em;
}
.menu-card__thumb{margin:0 0 12px 0;}
.menu-card__thumb img{border-radius:10px;display:block;width:100%;height:auto;object-fit:cover;}
.menu-card__title{margin:.4em 0 .2em;font-size:1.05rem;font-weight:700;}
.menu-card__text{margin:0;font-size:.95rem;opacity:.92;}
.menu-details .visual-grid{gap:28px;}
.menu-detail__text h3{margin-top:0;}
.menu-detail__image img{width:100%;height:auto;border-radius:12px;object-fit:cover;}
@media (min-width:960px){
  .menu-details .visual-grid{grid-template-columns:1fr 1fr;align-items:center;}
  .menu-details .menu-detail__text:nth-of-type(2){order:2;}
}
.u-center{text-align:center;}
.u-strong{font-weight:700;}
		
		/* ===== MENU add-ons ===== */

/* ヒーローは共通 .page-hero.tcd-ish を流用（追記なし） */

/* サムネ比率を安定化（3カード） */
.menu-card__thumb { position: relative; aspect-ratio: 4 / 3; overflow: hidden; }
.menu-card__thumb img {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transform:scale(1.02); transition:transform .5s ease;
}
.menu-card:hover .menu-card__thumb img { transform:scale(1.06); }

/* レッスン詳細セクション */
.menu-details .visual-grid { gap: 28px; align-items: center; }
.menu-detail__text p { margin:.5em 0; line-height:1.9; }
.menu-ctas { margin-top:12px; display:flex; flex-wrap:wrap; gap:10px; }

/* 設備帯 */
.menu-equip .equip-band {
  border:1px solid #eee; border-radius:14px; background:#fff;
  box-shadow:var(--shadow-sm); padding:clamp(16px,3vw,22px);
}
.menu-equip .equip-title { text-align:center; margin:0 0 12px; }
.equip-grid {
  list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap;
  gap:10px; justify-content:center;
}
.equip-item {
  border:1px solid #e6e8eb; border-radius:999px; padding:8px 12px;
  background:#f9fafb; font-weight:700; font-size:.92rem; color:#374151;
}
		
		
		/* ===== MENU (scoped & conflict-free) ===== */
.menu-page .mnu-container{max-width:var(--max-w,1100px);width:100%;margin:0 auto;padding-inline:clamp(16px,4vw,24px);}
.menu-page .mnu-section-title,
.menu-page h3.mnu-h3{
  font-family:"Klee One","Noto Serif JP",serif;font-weight:600;color:var(--brand,#90B8E0);
  letter-spacing:.05em;line-height:1.4;text-align:center;margin:0 0 1em;
}
.menu-page .mnu-section-title{font-size:clamp(22px,3vw,32px);}
.menu-page h3.mnu-h3{font-size:clamp(22px,3.2vw,30px);}
.menu-page .mnu-lead{font-size:1.05rem;opacity:.9;text-align:center;margin:0 auto;max-width:48rem;}

/* spacing */
.menu-page .mnu-intro,
.menu-page .mnu-offers,
.menu-page .mnu-equip{padding:clamp(48px,8vw,96px) 0;}
.menu-page .mnu-cta{padding:clamp(36px,6vw,72px) 0;}

/* visual band */
.menu-page .mnu-visual-band{padding:clamp(16px,3vw,24px) 0;}
.menu-page .mnu-band-figure{position:relative;width:100%;aspect-ratio:21/9;border-radius:14px;overflow:hidden;background:#eaeaea;box-shadow:0 6px 24px rgba(0,0,0,.06);}
.menu-page .mnu-band-figure img{display:block;width:100%;height:100%;object-fit:cover;transform:translateZ(0);}

/* offers（Conceptのカード設計を踏襲） */
.menu-page .mnu-offers-head{text-align:center;max-width:56rem;margin:0 auto 18px;}
.menu-page .mnu-offers-head p{max-width:48rem;margin:.6em auto 0;line-height:1.9;font-size:1rem;opacity:.95;}
.menu-page .mnu-offer-list{list-style:none;padding:0;margin:22px 0 0;display:grid;gap:16px;}
.menu-page .mnu-card{
  display:flex;align-items:flex-start;gap:18px;padding:16px;border:1px solid #eee;border-radius:12px;background:#fff;
  box-shadow:var(--shadow-sm,0 4px 12px rgba(0,0,0,.06));text-align:left;
}
.menu-page .mnu-card-media{--thumb:clamp(120px,32vw,200px);flex:0 0 var(--thumb);max-width:var(--thumb);margin:0;}
@media (min-width:801px){.menu-page .mnu-card-media{--thumb:200px;}}
.menu-page .mnu-card-media img{display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;border-radius:10px;}
.menu-page .mnu-card-body{flex:1 1 auto;min-width:0;width:auto;writing-mode:horizontal-tb;white-space:normal;word-break:break-word;overflow-wrap:anywhere;}
.menu-page .mnu-card-title{margin:0 0 .4em;font-size:1.1rem;font-weight:700;line-height:1.5;color:#111;}
.menu-page .mnu-card-text{margin:0;line-height:1.9;font-size:1rem;opacity:.95;}
.menu-page .mnu-bullets{list-style:disc;margin:.6em 0 0 1.2em;padding:0;opacity:.92;}
.menu-page .mnu-ctas{margin-top:10px;display:flex;flex-wrap:wrap;gap:10px;}
@media (max-width:680px){
  .menu-page .mnu-card{flex-direction:column;}
  .menu-page .mnu-card-media{flex:none;width:100%;max-width:100%;}
}

/* equipment（タグ表示） */
.menu-page .mnu-equip-list{
  list-style:none;padding:0;margin:10px 0 0;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;
}
.menu-page .mnu-equip-list li{
  border:1px solid #e6e8eb;border-radius:999px;padding:8px 12px;background:#f9fafb;font-weight:700;font-size:.92rem;color:#374151;
}

/* CTA（共通ボタン流用） */
.menu-page .mnu-cta-inner{
  border:1px solid #eee;border-radius:14px;background:#fff;box-shadow:var(--shadow-sm,0 6px 24px rgba(0,0,0,.06));
  display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;
}
.menu-page .mnu-cta-title{margin:0 0 4px;font-size:clamp(20px,3vw,26px);font-weight:800;}
.menu-page .mnu-cta-note{margin:0;opacity:.85;}
.menu-page .mnu-cta-action{flex:0 0 auto;}
@media (max-width:720px){
  .menu-page .mnu-cta-inner{flex-direction:column;align-items:flex-start;}
}
		
		
/* =======================================
   12) PRICE
======================================= */
.price-kv{list-style:none;padding:0;margin:0;display:grid;gap:10px;}
.price-kv li{
  display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #eee;border-radius:12px;
  padding:12px 16px;box-shadow:var(--shadow-sm);
}
.price-kv li span{opacity:.9;}
.price-kv li strong{font-size:1.1rem;}

.price-grid{list-style:none;padding:0;margin:0;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}
.price-card{background:#fff;border:1px solid #eee;border-radius:14px;box-shadow:var(--shadow-sm);padding:16px;text-align:center;position:relative;}
.price-card.is-popular{border-color:var(--brand);box-shadow:0 6px 24px rgba(0,0,0,.08);}
.price-card__head{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:8px;}
.price-card__head .tag{display:inline-block;font-weight:700;font-size:.85rem;letter-spacing:.02em;padding:4px 8px;border-radius:999px;background:#f4f6fb;color:#3a4c6b;}
.price-card__head .badge{display:inline-block;font-size:.78rem;padding:2px 6px;border-radius:6px;background:var(--brand);color:#fff;font-weight:700;}
.price-card__price span{display:inline-block;font-size:1.6rem;font-weight:800;letter-spacing:.02em;}
.price-card__note{margin:.3em 0 0;font-size:.9rem;opacity:.8;}

.combo-list{list-style:none;padding:0;margin:0;display:grid;gap:12px;}
.combo-item{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff;border:1px solid #eee;border-radius:12px;padding:12px 16px;box-shadow:var(--shadow-sm);}
.combo-item__head{font-weight:600;}
.combo-item__price{font-weight:800;}

.notes{list-style:disc inside;padding:0;margin:0;display:grid;gap:.4em;font-size:.95rem;}
.notes li{opacity:.92;}

.price-group.section,.price-personal.section,.price-combo.section{
  padding-top:clamp(28px,4vw,44px);padding-bottom:clamp(28px,4vw,44px);
}
		
		
		/* ===== Price page: heading tweak ===== */
.price-intro .section-title.u-klee.u-brand,
.price-menu .section-title.u-klee.u-brand,
.price-group .section-title.u-klee.u-brand,
.price-personal .section-title.u-klee.u-brand,
.price-combo .section-title.u-klee.u-brand {
  color: var(--brand, #90B8E0);
  position: relative;
  text-align: center;
}

/* 日本語サブ見出し（英字の下に小さく） */
.section-title .jp-sub{
  display:block;
  margin-top:.2em;
  font-size:.9rem;
  font-weight:700;
  letter-spacing:.12em;
  color:#374151;
  opacity:.85;
}

/* アクセントの下線バー（見出しの下に細いライン） */
.price-intro .section-title.u-klee.u-brand::after,
.price-menu .section-title.u-klee.u-brand::after,
.price-group .section-title.u-klee.u-brand::after,
.price-personal .section-title.u-klee.u-brand::after,
.price-combo .section-title.u-klee.u-brand::after{
  content:"";
  display:block;
  width:64px;
  height:3px;
  margin:.55em auto 0;
  background: var(--brand, #90B8E0);
  border-radius:999px;
  opacity:.9;
}

/* アンカー位置のズレ対策（固定ヘッダー分ずらす） */
#group, #personal { scroll-margin-top: calc(var(--header-h, 64px) + 12px); }

/* （任意）“まずは無料体験”ボタンを軽く：既存のブランドCTA色を使用 */
		
		
		
		
/* =======================================
   13) FAQ / Accordion
======================================= */
#faq.section{padding:clamp(36px,6vw,72px) 0;}
.faq .ttl{
  margin:0 0 .4em;text-align:center;font-family:"Klee One","Noto Serif JP",serif;font-weight:600;color:var(--brand);
  font-size:clamp(22px,3vw,32px);letter-spacing:.05em;
}
.faq .ttl2{margin:0 0 1.2em;text-align:center;opacity:.9;font-size:clamp(15px,1.6vw,18px);}
.faq .box{margin:10px 0;}
.faq .box + .box{margin-top:12px;}
.faq .box dl{margin:0;}
.faq .box dt,.faq .box dd{margin:0;}

.faq .faq-toggle{
  display:flex;align-items:flex-start;gap:12px;width:100%;
  background:#fff;border:1px solid #eee;border-radius:12px;padding:14px 18px;text-align:left;cursor:pointer;
  font:inherit;color:inherit;box-shadow:var(--shadow-sm);
  transition:background .2s,border-color .2s,box-shadow .2s;
}
.faq .faq-toggle:hover{border-color:#ddd;box-shadow:0 8px 28px rgba(0,0,0,.08);}
.faq .faq-toggle:focus-visible{outline:2px solid transparent;box-shadow:0 0 0 3px color-mix(in oklab, var(--brand) 60%, #fff);border-color:var(--brand);}
.faq .faq-item.is-open .faq-toggle{border-color:var(--brand);}
.faq .faq-toggle>span:last-child{flex:1 1 auto;font-weight:700;line-height:1.7;}
.faq .faq-toggle::after{
  content:"";flex:0 0 auto;width:12px;height:12px;margin-left:10px;margin-top:4px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);transition:transform .2s ease;opacity:.8;
}
.faq .faq-item.is-open .faq-toggle::after{transform:rotate(-135deg);}
.faq .faq-panel{
  overflow:hidden;max-height:0;opacity:0;transition:max-height .28s ease,opacity .18s ease;
  background:#fff;border:1px solid #eee;border-top:0;border-radius:0 0 12px 12px;padding:0 18px;
}
.faq .faq-item.is-open .faq-panel{opacity:1;}
.faq .faq-panel-inner{display:flex;gap:12px;padding:14px 0 16px;}
.faq .faq-panel-inner span:last-child{line-height:1.9;}
.faq-ico{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;background:#111;color:#fff;font-weight:700;font-size:.8rem;margin-top:2px;}
.faq-ico--q::before{content:"Q";}
.faq-ico--a::before{content:"A";}
@media (prefers-reduced-motion: reduce){.faq .faq-toggle,.faq .faq-panel{transition-duration:.001ms !important;}}

/* =======================================
   14) Instructors
======================================= */
.instructors-about p + p{margin-top:.8em;}
.instructors-note{margin:.2em 0 1.6em;opacity:.9;}

.inst-name{
  margin:.1em 0 .4em;font-family:"Klee One","Noto Serif JP",serif;font-weight:600;
  font-size:clamp(20px,2.2vw,26px);color:var(--brand);
}
.inst-photo img{display:block;width:100%;height:auto;object-fit:cover;border-radius:12px;}

.inst-meta{list-style:none;padding:0;margin:0 0 .6em;display:flex;flex-wrap:wrap;gap:10px 16px;font-size:.95rem;}
.inst-meta li strong{font-weight:700;}

.inst-quals{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:.8em;}
.inst-qual{display:inline-block;padding:6px 10px;border-radius:999px;background:#f4f6fb;color:#3a4c6b;font-size:.85rem;font-weight:700;letter-spacing:.02em;}

.instructor-profile.visual-grid{gap:22px;align-items:start;}
@media (min-width:960px){
  .instructor-profile.visual-grid{grid-template-columns:1fr 1.2fr;}
  .instructor-profile.inst--reverse.visual-grid{grid-template-columns:1.2fr 1fr;}
  .instructor-profile.inst--reverse .visual-image{order:2;}
  .instructor-profile.inst--reverse .visual-text{order:1;}
}
.inst-bio p{margin:.5em 0;line-height:1.9;}


/* ===== Contact Form ===== */
.contact-form .wpcf7 form { margin: 0; }
.form-grid{
  display: grid; gap: 16px;
  grid-template-columns: 1fr 1fr;
}
.form-row{ display:flex; flex-direction:column; gap:8px; }
.form-row--full{ grid-column: 1 / -1; }

/* ラベル */
.form-row > label{
  font-weight:700; letter-spacing:.02em;
  display:flex; align-items:center; gap:8px;
}
.req{
  display:inline-block; font-size:.75rem; line-height:1;
  padding:2px 6px; border-radius:999px;
  background:#f4f6fb; color:#3a4c6b; font-weight:700;
}

/* 入力 */
.input-text,
.input-select,
.input-textarea,
input[type="text"], input[type="email"], input[type="tel"],
select, textarea{
  appearance:none; width:100%;
  border:1px solid #e5e7eb; border-radius:12px;
  padding:12px 14px; background:#fff; color:var(--text);
  transition:border-color .18s, box-shadow .18s, background .18s;
  font: inherit; line-height:1.6;
}
.input-textarea, textarea{ min-height: 160px; resize: vertical; }
.input-file{ display:block; }

/* フォーカス */
.input-text:focus, .input-select:focus, .input-textarea:focus,
input:focus, select:focus, textarea:focus{
  outline: 2px solid transparent;
  border-color: color-mix(in oklab, var(--brand) 55%, #ddd);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand) 35%, #fff);
}

/* エラー・メッセージ */
.wpcf7 form .wpcf7-not-valid{
  border-color:#e96363 !important;
  box-shadow: 0 0 0 3px rgba(233,99,99,.12);
}
.wpcf7 form .wpcf7-not-valid-tip{
  font-size:.85rem; color:#b42318; margin-top:6px;
}
.wpcf7 form .wpcf7-response-output{
  margin-top:12px; border-radius:12px; padding:12px 14px; border:1px solid #eee; background:#fff;
}

/* 送信ボタン（既存ボタンを流用） */
.form-actions .btn{ padding:14px 26px; }

/* SPレイアウト */
@media (max-width: 960px){
  .form-grid{ grid-template-columns: 1fr; }
}
/* Trial Flow */
.trial-flow .flow-step {
  margin-bottom:64px;
}
.trial-flow .flow-step h4 {
  font-family:"Klee One", serif;
  font-size:1.25rem;
  color:var(--brand);
  margin-bottom:.5em;
  display:flex;
  align-items:center;
  gap:.4em;
}
.trial-flow .step-num {
  display:inline-block;
  width:2em; height:2em;
  border-radius:50%;
  background:var(--brand);
  color:#fff; font-weight:700;
  line-height:2em; text-align:center;
  font-size:.9rem;
}
.trial-flow figure {
  margin-top:16px;
}
.trial-flow figure img {
  width:100%; height:auto;
  border-radius:12px; object-fit:cover;
}
					
					
/* =========================
   Home CONCEPT（寄せバランス）
========================= */
.home-concept{
  background:#fff;
  padding-block:80px;
}
@media (min-width:961px){ .home-concept{ padding-block:100px; } }

.home-concept__head{
  text-align:center;
  margin-bottom:28px;
}
.home-concept__label{
  display:block;
  font-size:.95rem;
  letter-spacing:.15em;
  color: var(--brand, #90B8E0);
  font-weight:600;
  margin-bottom:6px;
}
.home-concept__title{
  font-size:2rem;
  font-weight:700;
  letter-spacing:.12em;
  color: var(--brand, #90B8E0);
}
@media (min-width:961px){
  .home-concept__title{ font-size:2.4rem; }
}

/* リード文（スプラッシュフォントで太く） */
.home-concept__lead{
  text-align:center;
  font-family: var(--splash-font, "Klee One", "Noto Serif JP", serif);
  font-size:1.6rem;
  font-weight:600;   /* ← 太めに */
  line-height:1.55;  /* 詰めて力強く */
  color:#222;
  margin:22px auto 28px;
  max-width:42rem;
}
@media (min-width:961px){
  .home-concept__lead{
    font-size:1.9rem;
    line-height:1.55;
  }
}

/* 本文（ゆったり行間） */
.home-concept__body{
  max-width:46rem;
  margin:0 auto;
  color:#444;
  line-height:2;     /* ←広めにして読みやすさ重視 */
  font-size:1rem;
  text-align:center;
}

.home-concept__cta{
  text-align:center;
  margin-top:40px;
}
.btn.btn--brand-lg{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:1.2em 3.2em;
  border-radius:999px;
  font-weight:700;
  font-size:1.2rem;
  background: var(--brand, #90B8E0);
  color:#fff;
  border:1px solid transparent;
  text-decoration:none;
  transition:filter .2s ease, transform .08s ease;
}
.btn.btn--brand-lg:hover{ filter:brightness(.95); }
.btn.btn--brand-lg:active{ transform:translateY(1px); }


					
					
/* =========================
   Gate Split (MENU / PRICE)
========================= */
.home-visual-split{ margin:0; padding:0; }
.gate-split{
  display:grid; grid-template-columns:1fr 1fr; width:100%;
}
@media (max-width:960px){
  .gate-split{ grid-template-columns:1fr; }
}

.gate-split__card{
  position:relative; display:block; overflow:hidden;
  isolation:isolate; text-decoration:none; color:#fff;
  /* 高さバランス：画像が未ロードでも見栄えを維持 */
  aspect-ratio:16/9; /* 好みで16/10や3/2でもOK */
}
@supports not (aspect-ratio:1/1){
  .gate-split__card::before{ content:""; display:block; padding-top:56.25%; }
}

.gate-split__card img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; transform:scale(1.02);
  transition:transform .5s ease, filter .5s ease;
  filter:saturate(1) contrast(1.02);
}

/* 下部グラデーションで白文字をくっきり */
.gate-split__card::after{
  content:""; position:absolute; inset:auto 0 0 0; height:62%;
  background: linear-gradient(to top, rgba(0,0,0,.52), rgba(0,0,0,.22) 45%, transparent 70%);
  z-index:1; pointer-events:none;
}

/* オーバーレイ内側 */
.gate-split__overlay{
  position:absolute; inset:0; display:flex; align-items:flex-end;
  justify-content:space-between; padding:18px 16px; z-index:2;
}
@media (min-width:961px){
  .gate-split__overlay{ padding:22px 22px; }
}

.gate-split__text{ max-width:70%; }
.gate-split__label{
  display:inline-block; font-size:.85rem; letter-spacing:.14em;
  color:#e5e7eb; opacity:.95; margin-bottom:6px;
}
.gate-split__title{
  margin:0 0 6px; font-family: var(--heading-font, "Klee One", "Noto Sans JP", system-ui, -apple-system, sans-serif);
  font-weight:800; letter-spacing:.08em; font-size:2rem; line-height:1;
  text-shadow:0 2px 10px rgba(0,0,0,.25); color:#fff;
}
@media (min-width:961px){
  .gate-split__title{ font-size:2.2rem; }
}
.gate-split__desc{
  margin:0; font-size:.95rem; line-height:1.6; opacity:.95;
}

/* 矢印ボタン風 */
.gate-split__arrow{
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px; border-radius:999px;
  background:rgba(255,255,255,.92); color: var(--brand, #90B8E0);
  box-shadow:0 6px 16px rgba(0,0,0,.18);
  transform:translate3d(0,0,0);
  transition:transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}

/* ホバー演出：自然なズーム＋矢印ちょいスライド */
.gate-split__card:hover img{ transform:scale(1.06); filter:saturate(1.05); }
.gate-split__card:hover .gate-split__arrow{ transform:translateX(2px); background:#fff; color:#1f293b; }

/* 省エネ＆タッチ端末配慮 */
@media (hover:none){
  .gate-split__card:hover img{ transform:scale(1.02); }
  .gate-split__card:hover .gate-split__arrow{ transform:none; }
}
@media (prefers-reduced-motion: reduce){
  .gate-split__card img{ transition:none; }
  .gate-split__card:hover img{ transform:none; }
  .gate-split__arrow{ transition:none; }
}
					
					/* =========================
   NEWS（お知らせ）
========================= */
.home-news{ padding-block:70px; background:#fff; }
@media (min-width:961px){ .home-news{ padding-block:90px; } }

.home-news__head{
  text-align:center; margin-bottom:26px;
}
.home-news__label,
.home-news__title{
  display:block; letter-spacing:.15em; color: var(--brand, #90B8E0); font-weight:600;
}
.home-news__label{ font-size:.95rem; margin-bottom:6px; }
.home-news__title{ font-size:2rem; }
@media (min-width:961px){ .home-news__title{ font-size:2.4rem; } }

/* grid */
.news-grid{
  display:grid; gap:16px;
}
@media (min-width:801px){
  .news-grid{ grid-template-columns:repeat(3, 1fr); gap:20px; }
}

/* card */
.news-card{
  background:#fff; border:1px solid #e6e8eb; border-radius:12px; overflow:hidden;
  transition: box-shadow .18s ease, transform .18s ease, border-color .18s ease;
}
.news-card:hover{
  box-shadow:0 10px 28px rgba(0,0,0,.08);
  transform: translateY(-2px);
  border-color:#d9dce1;
}
.news-card__link{ display:block; color:inherit; text-decoration:none; }

/* thumb with fixed ratio */
.news-card__thumb{ position:relative; aspect-ratio:16/9; background:#f3f4f6; overflow:hidden; }
@supports not (aspect-ratio:1/1){
  .news-card__thumb::before{ content:""; display:block; padding-top:56.25%; }
}
.news-card__thumb img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transform: scale(1.02); transition: transform .5s ease;
}
.news-card:hover .news-card__thumb img{ transform: scale(1.06); }

/* body */
.news-card__body{ padding:12px 14px 14px; }
.news-card__title{
  font-size:1.02rem; line-height:1.5; color:#1f2937; margin:4px 0 8px; font-weight:700;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.news-card__meta{
  font-size:.85rem; color:#6b7280;
}
					
		
/* ===== Campaign 強化 & 余白 ===== */
.site-campaign-wrap.site-campaign--separate{
  margin-bottom: clamp(22px, 4vw, 40px);   /* ← フッターと“くっつく”のを回避 */
}
.campaign.card.campaign--push{
  position: relative;
  overflow: hidden;
  border: 1px solid #e6e8eb;
  background:
    radial-gradient(1200px 400px at 90% -10%, color-mix(in oklab, var(--brand) 28%, #fff), transparent 60%),
    #fff;
}
.campaign--push .campaign__head{ margin-bottom: 12px; }
.campaign--push .campaign__title{ letter-spacing: .03em; }
.campaign--push .campaign-grid{ margin-top: 10px; }
.campaign--push .campaign-ctas{ margin-top: 14px; }

/* 画像バナー */
.campaign-banner{
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--radius, 12px);
  box-shadow: var(--shadow-sm, 0 8px 24px rgba(0,0,0,.08));
}
.campaign-banner img{
  display:block; width:100%; height:auto; object-fit:cover; transform:scale(1.01);
  transition: transform .45s ease, filter .45s ease;
}
.campaign-banner:hover img{ transform:scale(1.04); filter:saturate(1.05) contrast(1.02); }
.campaign-banner .banner-badge{
  position:absolute; left:12px; top:12px;
  display:inline-block; padding:6px 10px; border-radius:999px;
  background: var(--brand, #90B8E0); color:#fff; font-weight:800; font-size:.82rem; letter-spacing:.06em;
  box-shadow: 0 6px 16px rgba(0,0,0,.18);
}

/* 押したくなる“鼓動” */
.btn-cta--pulse{
  position:relative;
  box-shadow: 0 8px 22px rgba(144,184,224,.35);
  animation: pulseGlow 1.8s ease-in-out infinite;
}
@keyframes pulseGlow{
  0%,100%{ box-shadow: 0 8px 22px rgba(144,184,224,.36); transform: translateY(0); }
  50%{    box-shadow: 0 10px 26px rgba(144,184,224,.5);  transform: translateY(-1px); }
}

/* ===== Footer Contacts: アイコン & 並び ===== */
.footer-contacts{
  display:flex; flex-wrap:wrap; gap: 10px 16px;
}
.footer-contacts .ico{
  margin-right: 6px; vertical-align: -3px; opacity: .9;
}
.footer-contacts li a{
  display:inline-flex; align-items:center; gap:6px;
  text-decoration: underline; text-decoration-color:#cbd5e1; text-underline-offset: 3px;
}
.footer-contacts li.insta a{
  text-decoration: none;          /* インスタだけはボタン的に */
  background:#fff;
  border:1px solid #e5e7eb;
  padding:6px 10px; border-radius:999px;
  box-shadow: 0 4px 12px rgba(0,0,0,.04);
}
.footer-contacts li.insta a:hover{ box-shadow: 0 8px 18px rgba(0,0,0,.08); }

/* ちょいアクセント */
.footer-heading{ margin-bottom: 18px; }
		
		
		
		
		
/* reCAPTCHA バッジ非表示 */
.grecaptcha-badge {
  visibility: hidden !important;
		}
		
		
/* ===== Overlay tune: darker blue for readability ===== */

/* 1) ページヒーローのグラデを“濃いめ青”に */
.page-hero.tcd-ish .page-hero__overlay{
  /* 以前より暗く・深く */
  background: linear-gradient(
    to bottom,
    rgba(60,110,180, .32) 0%,    /* ← 濃く */
    rgba(60,110,180, .42) 35%,
    rgba(60,110,180, .48) 70%,
    rgba(60,110,180, .52) 100%   /* ← 最下部ほど強く */
  );
}

/* 2) パンくず帯（下部の半透明帯）も少し暗めに */
.page-hero.tcd-ish .page-hero__crumbs-inner{
  background: rgba(60,110,180, .36);
  backdrop-filter: saturate(1.05) blur(2px);
}

/* 3) Gate Split（HOMEの2枚カード）の下部グラデも濃いめに */
.gate-split__card::after{
  background: linear-gradient(
    to top,
    rgba(60,110,180, .60),
    rgba(60,110,180, .28) 45%,
    transparent 70%
  );
}

/* 4) ヒーローの見出しを読みやすく（白文字のエッジ強化） */
.hero-title, .hero-subtitle,
.page-hero.tcd-ish .page-hero__title,
.page-hero.tcd-ish .page-hero__subtitle{
  text-shadow:
    0 2px 12px rgba(0,0,0,.35),
    0 1px 0 rgba(0,0,0,.08);
}


/* ===== Trial Flow Layout ===== */
.trial-flow .flow-step {
  margin-bottom: 48px;
}
.trial-flow .flow-grid {
  display: grid;
  gap: 24px;
  align-items: center;
}
@media (min-width: 960px) {
  .trial-flow .flow-grid {
    grid-template-columns: 1fr 1fr; /* 左テキスト / 右画像 */
  }
}
.trial-flow .flow-text p {
  line-height: 1.9;
}
.trial-flow .flow-image img {
  width: 100%;
  height: auto;
  border-radius: 12px;
  object-fit: cover;
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}
		
		
		
		
		
		
/* ==== もやっと浮遊する円背景（全ページ・少し濃い） ==== */
.bg-animation{
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.site{
  position: relative;
  z-index: 1;
}

/* 共通：ブロブ */
.bg-animation .blob{
  position: absolute;
  width: 34vmin;
  height: 34vmin;
  border-radius: 9999px;
  filter: blur(44px);   /* ぼかし少し弱め */
  opacity: 0.26;        /* 前より濃いめ（0.18 → 0.26） */
  will-change: transform;
  mix-blend-mode: soft-light;
}

/* 色味 */
.bg-animation .blob--pink{ background:#f8d7e1; }
.bg-animation .blob--blue{ background:#cfe3f6; }
.bg-animation .blob--mix { background:#f1e8ff; }

/* ゆったり動き */
@keyframes blobA{
  0%   { transform: translate(10vw, 20vh) scale(1.0); }
  50%  { transform: translate(18vw, 14vh) scale(1.1); }
  100% { transform: translate(10vw, 20vh) scale(1.0); }
}
@keyframes blobB{
  0%   { transform: translate(65vw, 65vh) scale(0.9); }
  50%  { transform: translate(58vw, 58vh) scale(1.05); }
  100% { transform: translate(65vw, 65vh) scale(0.9); }
}
@keyframes blobC{
  0%   { transform: translate(45vw, 10vh) scale(0.95); }
  50%  { transform: translate(52vw, 18vh) scale(1.05); }
  100% { transform: translate(45vw, 10vh) scale(0.95); }
}

.bg-animation .blob--pink{ animation: blobA 36s ease-in-out infinite; }
.bg-animation .blob--blue{ animation: blobB 44s ease-in-out infinite; }
.bg-animation .blob--mix { animation: blobC 52s ease-in-out infinite; }

/* スマホ調整 */
@media (max-width: 768px){
  .bg-animation .blob{
    width: 40vmin; height: 40vmin;
    opacity: 0.22;
    filter: blur(48px);
  }
}

@media (prefers-reduced-motion: reduce){
  .bg-animation .blob{ animation: none; }
}


		
/* Contact lead */
.contact-lead{
  text-align:center;
  max-width: 52rem;
  margin: 0 auto 18px;
  line-height: 1.9;
}
.contact-lead a{ text-decoration: underline; text-underline-offset: 3px; }

/* CF7 layout */
.cf7-grid{
  display:grid;
  gap: 14px;
  max-width: 720px;
  margin: 0 auto;
}
@media (min-width: 720px){
  .cf7-grid{ grid-template-columns: 1fr 1fr; }
  .cf7-row--full{ grid-column: 1 / -1; }
}
.cf7-row label{ font-weight:700; display:block; }
.cf7-grid input[type="text"],
.cf7-grid input[type="email"],
.cf7-grid textarea{
  width:100%;
  border:1px solid #e5e7eb;
  border-radius:12px;
  padding:12px 14px;
  font: inherit;
  line-height:1.6;
}
.cf7-grid textarea{ min-height: 180px; resize: vertical; }

.req{
  display:inline-block;
  margin-left:.4em;
  font-size:.75rem;
  padding:2px 6px;
  border-radius:999px;
  background:#f4f6fb;
  color:#3a4c6b;
  font-weight:800;
}
		.cf7-actions{ text-align:center; }
		
		
		
		
		/* =======================================
   About Page (scoped)
======================================= */
.about-hero{
  position:relative;
  min-height: clamp(58vh, 70vh, 84vh);
  display:grid;
  place-items:center;
  padding: clamp(84px, 12vw, 140px) 0 56px;
  color:#fff;
  background:
    radial-gradient(900px 520px at 12% 70%, rgba(204,127,145,.35), transparent 55%),
    linear-gradient(to bottom, rgba(0,0,0,.18), rgba(0,0,0,.35)),
    url("/wp-content/themes/solina/assets/img/about-hero.jpg");
  background-size: cover;
  background-position: center;
}

.about-hero__inner{
  width:min(1100px, 92vw);
  padding: clamp(18px, 3vw, 28px);
}

.about-hero__eyebrow{
  margin:0 0 8px;
  letter-spacing:.16em;
  font-weight:800;
  opacity:.9;
}

.about-hero__title{
  margin:0 0 10px;
  font-family:"Klee One","Noto Serif JP",serif;
  font-weight:700;
  font-size: clamp(30px, 5vw, 56px);
  line-height:1.18;
  text-shadow: 0 2px 16px rgba(0,0,0,.28);
}

.about-hero__lead{
  margin:0;
  font-size: clamp(14px, 2vw, 18px);
  opacity:.95;
  text-shadow: 0 2px 12px rgba(0,0,0,.22);
}

.about-hero__cta{
  margin-top: 18px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.about-section{ padding: clamp(52px, 8vw, 92px) 0; }
.about-lead{ text-align:center; line-height:2; margin: 0 auto; max-width: 56rem; }

.about-kv{
  margin-top: 22px;
  display:grid;
  gap:16px;
}
@media (min-width:960px){
  .about-kv{ grid-template-columns: 1fr 1fr; }
}
.about-kv__item{
  border:1px solid #eee;
  background:#fff;
  border-radius:14px;
  padding: 18px 18px 16px;
  box-shadow: var(--shadow-sm);
}
.about-kv__label{
  margin:0 0 6px;
  font-weight:900;
  letter-spacing:.1em;
  color: var(--brand);
}
.about-kv__title{ margin:0 0 6px; font-weight:900; }
.about-kv__text{ margin:0; opacity:.95; }

.about-cards{
  list-style:none;
  padding:0;
  margin: 18px 0 0;
  display:grid;
  gap:14px;
}
@media (min-width:960px){
  .about-cards{ grid-template-columns: repeat(3, 1fr); }
}
.about-card{
  border:1px solid #eee;
  background:#fff;
  border-radius:14px;
  padding: 16px;
  box-shadow: var(--shadow-sm);
}
.about-card__title{
  margin:0 0 .45em;
  font-weight:900;
}
.about-card__text{ margin:0; opacity:.95; line-height:1.9; }

.about-profile{
  display:grid;
  gap:18px;
  align-items:center;
}
@media (min-width:960px){
  .about-profile{ grid-template-columns: 1.2fr .8fr; gap:28px; }
}
.about-profile__name{
  margin:0 0 10px;
  font-family:"Klee One","Noto Serif JP",serif;
  font-weight:700;
  font-size: clamp(22px, 2.8vw, 32px);
  color: var(--brand);
}
.about-profile__text{ margin:0 0 14px; line-height:2; }

.about-quals{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin: 0 0 14px;
}
.about-qual{
  display:inline-block;
  padding: 6px 10px;
  border-radius:999px;
  background:#f4f6fb;
  color:#3a4c6b;
  font-weight:800;
  font-size:.86rem;
}

.about-profile__cta{ display:flex; gap:12px; flex-wrap:wrap; }
.about-profile__media img{
  width:100%;
  height:auto;
  border-radius:14px;
  object-fit:cover;
  box-shadow: var(--shadow-sm);
}

.about-access__grid{
  display:grid;
  gap:16px;
  align-items:stretch;
}
@media (min-width:960px){
  .about-access__grid{ grid-template-columns: .9fr 1.1fr; gap:22px; }
}
.about-access__lead{ font-weight:900; margin:0 0 12px; }
.about-access__ctas{ display:flex; gap:10px; flex-wrap:wrap; margin: 10px 0 8px; }
.about-access__note{ margin: 10px 0 0; color:#6b7280; }

.about-map__dummy{
  display:grid;
  place-items:center;
  min-height: 320px;
  background:#f3f4f6;
  color:#6b7280;
}

.about-last__box{
  padding: clamp(18px, 3.6vw, 28px);
  border:1px solid #eee;
  border-radius:14px;
  background:#fff;
}
.about-last__title{
  margin:0 0 10px;
  font-family:"Klee One","Noto Serif JP",serif;
  font-weight:700;
  color: var(--brand);
  font-size: clamp(20px, 3vw, 28px);
}
.about-last__text{ margin:0; line-height:2; }

.about-last__cta{
  margin-top: 16px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.btn-cta--ghost{
  background:#fff;
  border:1px solid #e5e7eb;
  color:#111;
}
.btn-cta--ghost:hover{ filter:brightness(.98); }

.about-mail{
  margin: 14px 0 0;
  text-align:center;
  color:#4b5563;
}
.about-mail a{ text-decoration:underline; text-underline-offset:3px; }