@charset "UTF-8";
/* ===========================================================
   TRIGGER Personal Gym — 2026 Renewal Stylesheet
   Palette (kept from original):
     --primary:  #03989d  (ティール)
     --primaryD: #027074
     --bgBlue:   #c6e6f1  (ライトブルー)
     --bgBlue2:  #e8f5fa
     --accent:   #FFED00  (イエロー)
     --subBlue:  #2984BA
     --pink:     #f4c9d3  (ほんのり差す女性的なピンク)
     --ink:      #2b3441
   =========================================================== */

:root{ 
  --primary:#03989d;
  --primaryD:#027074;
  --primaryL:#5ec3c6;
  --bgBlue:#c6e6f1;
  --bgBlue2:#e8f5fa;
  --bgCream:#fbf7f2;
  --accent:#FFED00;
  --accentSoft:#fff5a0;
  --subBlue:#2984BA;
  --pink:#f4c9d3;
  --pinkSoft:#fde6eb;
  --ink:#2b3441;
  --muted:#6b7682;
  --line:#e5eef2;
  --shadow:0 20px 60px rgba(3,152,157,.12);
  --shadowSoft:0 8px 28px rgba(3,152,157,.08);
  --radius:22px;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
body,h1,h2,h3,h4,h5,p,ul,ol,li,a,dl,dt,dd,table,tr,th,td,figure,blockquote{
  margin:0;padding:0;color:var(--ink);
  text-decoration:none;list-style:none;line-height:1;outline:none;
}
button,input,select,textarea{background:unset;border:none;outline:none;-webkit-appearance:none;font:inherit;}
img{max-width:100%;height:auto;display:block;}
html,body{
  font-size:62.5%;
  letter-spacing:.04em;
  font-weight:500;
  color:var(--ink);
  font-family:"Noto Sans JP","游ゴシック体",YuGothic,"游ゴシック Medium","Yu Gothic Medium","Hiragino Sans",sans-serif;
  background:#fff;
  -webkit-font-smoothing:antialiased;
}
body{overflow-x:hidden;}
a{color:inherit;transition:all .3s ease;}
a:hover{opacity:.78;}

/* ---------- utilities ---------- */
.flx{display:flex;} .aic{align-items:center;} .aife{align-items:flex-end;}
.jcc{justify-content:center;} .jcsb{justify-content:space-between;} .jcfe{justify-content:flex-end;}
.fdrl{flex-direction:row-reverse;} .fdrc{flex-direction:column;} .fww{flex-wrap:wrap;}
.tal{text-align:left;} .tac{text-align:center;} .tar{text-align:right;}
.wsn{white-space:nowrap;}
.only_sp{display:none;}
.inner{margin:0 auto;width:min(120rem,92%);}

/* legacy class aliases kept for PHP compatibility */
.comCol{color:var(--primary);}
.comBg,.comBg01{background:var(--bgBlue);}
.comBg02{background:var(--bgBlue2);}
.acCol{color:var(--accent);}
.acBg{background:var(--accent);}
.bg01{color:var(--bgCream);}
.bgWhite{background:#fff;}

/* ---------- responsive font base ---------- */
@media screen and (min-width:768px) and (max-width:1920px){
  html,body{font-size:calc(10 * (100vw / 1920));}
}
@media screen and (max-width:767px){
  html,body{font-size:calc(10 * (100vw / 750));}
  .pc{display:none !important;}
  .sp{display:block;}
}
@media screen and (min-width:768px){
  .sp{display:none;}
}

/* =======================================================
   Typography — titles
   ======================================================= */
.jpTtl{
  font-size:1.8rem;
  letter-spacing:.3em;
  color:var(--primary);
  display:inline-block;
  margin-bottom:1.6rem;
  position:relative;
  padding:0 2.8rem;
  font-weight:600;
}
.jpTtl::before,.jpTtl::after{
  content:"";position:absolute;top:50%;width:2rem;height:1px;background:var(--primary);
}
.jpTtl::before{left:0;}
.jpTtl::after{right:0;}

.secTtl{
  font-family:"Cormorant Garamond","Playfair Display","Noto Serif JP",serif;
  font-size:6.4rem;
  letter-spacing:.12em;
  margin-bottom:10rem;
  position:relative;
  font-weight:500;
  line-height:1.1;
  background:linear-gradient(120deg,var(--primary) 0%,var(--subBlue) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.secTtl::after{
  content:"";width:5.6rem;height:.3rem;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  position:absolute;bottom:-3.6rem;left:50%;transform:translateX(-50%);
  border-radius:2px;
}

@media (max-width:767px){
  .secTtl{font-size:6.4rem;margin-bottom:10rem;}
  .jpTtl{font-size:2.6rem;}
}

main{overflow:hidden;}

/* =======================================================
   Animations
   ======================================================= */
.jsTop{opacity:0;transition:opacity 1.2s ease;}
.opacity{opacity:1;}
.jsUnder{transform:translateY(60px);opacity:0;transition:opacity .9s ease,transform .9s ease;}
.fadeIn{opacity:1;transform:translate(0);}
.jsFade{opacity:0;transform:translateY(24px);transition:opacity .9s ease,transform .9s ease;}
.jsFade.is-visible{opacity:1;transform:translateY(0);}

@media (prefers-reduced-motion: reduce){
  .jsFade{transition:none;transform:none;}
}

@keyframes floatY{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-12px);}
}
@keyframes blob{
  0%,100%{border-radius:42% 58% 62% 38% / 48% 42% 58% 52%;}
  50%{border-radius:58% 42% 38% 62% / 42% 58% 48% 52%;}
}
@keyframes shine{
  0%{background-position:-200% 0;}
  100%{background-position:200% 0;}
}
@keyframes marquee{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}

/* =======================================================
   HEADER
   ======================================================= */
/* =======================================================
   SITE HEADER
   ======================================================= */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1rem 0;
  background:rgba(255,255,255,.88);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(3,152,157,.12);
  transition:transform .3s ease;
}
.site-header.hide{transform:translateY(-100%);}

.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 3.2rem;
  max-width:140rem;margin:0 auto;
}

.header-logo{
  display:flex;align-items:center;gap:1.2rem;
  width:auto;height:auto;flex-shrink:0;
  text-decoration:none;
}
.header-logo img{width:8.8rem;height:8.8rem;flex-shrink:0;}
.header-logo-text{
  display:flex;flex-direction:column;gap:.3rem;
  line-height:1;
}
.header-logo-text span,
.header-logo-text{
  font-size:1.2rem;
  letter-spacing:.22em;
  color:var(--muted);
  font-weight:400;
  text-transform:uppercase;
  font-family:"Cormorant Garamond","Playfair Display","Noto Serif JP",serif;
}
.header-logo-text strong{
  display:block;
  font-size:2.4rem;
  font-weight:700;
  letter-spacing:.3em;
  font-family:"Cormorant Garamond","Playfair Display","Noto Serif JP",serif;
  background:linear-gradient(120deg,var(--primary) 0%,var(--subBlue) 80%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-top:.2rem;
  padding-top:.4rem;
  border-top:1px solid rgba(3,152,157,.18);
}

.header-nav{display:flex;align-items:center;gap:2.8rem;}
.header-nav-list{display:flex;align-items:center;gap:2.6rem;margin:0;padding:0;}
.header-nav-list a{
  font-size:1.8rem;font-weight:600;letter-spacing:.1em;color:var(--ink);
  position:relative;padding:.6rem 0;
}
.header-nav-list a::after{
  content:"";position:absolute;left:0;bottom:0;
  width:0;height:2px;background:var(--primary);transition:width .3s ease;
}
.header-nav-list a:hover{color:var(--primary);opacity:1;}
.header-nav-list a:hover::after{width:100%;}

.header-book-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:1rem 2.2rem;border-radius:999px;
  background:linear-gradient(135deg,var(--primary),var(--subBlue));
  color:#fff !important;font-size:1.3rem;font-weight:700;letter-spacing:.12em;
  box-shadow:0 8px 20px rgba(3,152,157,.32);white-space:nowrap;
}
.header-book-btn:hover{opacity:.9;transform:translateY(-2px);}

/* =======================================================
   HAMBURGER BUTTON
   ======================================================= */
.hamburger{
  display:none;flex-direction:column;justify-content:center;align-items:center;
  gap:.65rem;width:4.4rem;height:4.4rem;
  background:none;border:none;cursor:pointer;padding:0;flex-shrink:0;z-index:200;
}
.hamburger-bar{
  display:block;width:2.6rem;height:2px;
  background:var(--ink);border-radius:2px;
  transition:transform .35s ease,opacity .35s ease;transform-origin:center;
}
.hamburger.is-open .hamburger-bar:nth-child(1){transform:translateY(.67rem) rotate(45deg);}
.hamburger.is-open .hamburger-bar:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.is-open .hamburger-bar:nth-child(3){transform:translateY(-.67rem) rotate(-45deg);}

/* =======================================================
   DRAWER (SP)
   ======================================================= */
.drawer{
  position:fixed;top:0;right:-100%;
  width:min(80vw,32rem);height:100%;
  background:#fff;z-index:150;
  padding:8rem 3.6rem 5rem;
  display:flex;flex-direction:column;
  transition:right .38s cubic-bezier(.4,0,.2,1);
  box-shadow:-4px 0 32px rgba(0,0,0,.12);
  overflow-y:auto;
}
.drawer-close{
  position:absolute;top:1.8rem;right:1.8rem;
  width:4.4rem;height:4.4rem;border-radius:50%;
  border:1px solid rgba(3,152,157,.2);
  background:#fff;display:flex;align-items:center;justify-content:center;
  cursor:pointer;
}
.drawer-close span{
  position:absolute;width:2.2rem;height:2px;border-radius:2px;
  background:var(--ink);
}
.drawer-close span:nth-child(1){transform:rotate(45deg);}
.drawer-close span:nth-child(2){transform:rotate(-45deg);}
.drawer.is-open{right:0;}
.drawer-nav{display:flex;flex-direction:column;gap:3.2rem;height:100%;}
.drawer-list{margin:0;padding:0;}
.drawer-list li{border-bottom:1px solid rgba(3,152,157,.1);}
.drawer-list a{
  display:block;padding:1.8rem 0;
  font-size:3.2rem;font-weight:700;letter-spacing:.1em;color:var(--ink);
}
.drawer-list a:hover{color:var(--primary);opacity:1;}
.drawer-cta{
  display:block;text-align:center;
  padding:1.6rem 2rem;border-radius:999px;
  background:linear-gradient(135deg,var(--primary),var(--subBlue));
  color:#fff !important;font-size:1.6rem;font-weight:700;letter-spacing:.1em;
  box-shadow:0 8px 20px rgba(3,152,157,.32);margin-top:auto;
}
.drawer-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.48);z-index:140;
}
.drawer-overlay.is-open{display:block;}
body.drawer-open{overflow:hidden;}

@media(max-width:767px){
  .site-header{padding:.8rem 0;}
  .header-inner{padding:0 2rem;}
  .header-nav{display:none;}
  .hamburger{display:flex;}
}

/* =======================================================
   HERO / MV
   ======================================================= */
.mv{
  position:relative;z-index:5;overflow:hidden;
  min-height:95vh;
  padding-top:10.4rem;
  background:
    radial-gradient(1200px 600px at 90% 10%,rgba(198,230,241,.55),transparent 60%),
    radial-gradient(900px 600px at 0% 90%,rgba(244,201,211,.45),transparent 60%),
    linear-gradient(180deg,#ffffff 0%,#f6fbfd 100%);
}
.mvInner{
  position:relative;
  display:grid;grid-template-columns:1.05fr .95fr;gap:6rem;
  align-items:center;
  width:min(140rem,94%);margin:0 auto;padding:1rem 0 8rem;
}
.mvCopy{position:relative;z-index:3;}
.mvKicker{
  display:inline-flex;align-items:center;gap:1rem;
  padding:.8rem 1.6rem;border-radius:999px;
  background:#fff;border:1px solid rgba(3,152,157,.2);
  box-shadow:var(--shadowSoft);
  font-size:1.3rem;letter-spacing:.22em;color:var(--primary);font-weight:700;
  margin-bottom: 1.6rem;
}
.mvKicker::before{
  content:"";width:.8rem;height:.8rem;border-radius:50%;
  background:var(--primary);box-shadow:0 0 0 4px rgba(3,152,157,.18);
}
.mvHead{
  font-family:"Noto Serif JP","Cormorant Garamond",serif;
  font-size:4rem;line-height:1.35;letter-spacing:.04em;
  color:var(--ink);font-weight:500;margin-bottom:2.4rem;
}
.mvHead em{font-style:normal;position:relative;color:var(--primary);font-size: 7.2rem;margin: 00.8rem;}
.mvHead em::after{
  content:"";position:absolute;left:0;right:0;bottom:.1em;height:.28em;
  background:var(--accentSoft);z-index:-1;border-radius:4px;
}
.mvHead .thin{color:var(--muted);font-weight:400;font-size: 8rem; margin-left: 1rem;}
.mvHead-num{
  font-size:1.15em;letter-spacing:-.02em;
}
.mvLead{
  font-size:1.8rem;line-height:2;color:var(--muted);
  margin-bottom:4rem;max-width:52rem;
}
.mvActions{display:flex;gap:1.6rem;align-items:center;flex-wrap:wrap;}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:1rem;
  padding:1.8rem 3.2rem;border-radius:999px;font-weight:700;
  font-size:1.5rem;letter-spacing:.14em;cursor:pointer;
  transition:transform .3s ease,box-shadow .3s ease,opacity .3s ease;
}
.btn-primary{
  color:#fff !important;
  background:linear-gradient(135deg,var(--primary) 0%,var(--subBlue) 100%);
  box-shadow:0 14px 30px rgba(3,152,157,.35);
}
.btn-primary:hover{opacity:1;transform:translateY(-3px);box-shadow:0 20px 36px rgba(3,152,157,.45);}
.btn-ghost{
  color:var(--primary) !important;background:#fff;
  border:1px solid rgba(3,152,157,.3);
  box-shadow:var(--shadowSoft);
}
.btn-ghost:hover{opacity:1;border-color:var(--primary);transform:translateY(-3px);}
.btn svg,.btn .arr{transition:transform .3s ease;}
.btn:hover svg,.btn:hover .arr{transform:translateX(4px);}

.mvStats{
  margin-top:5.4rem;display:flex;gap:3rem;
  padding-top:3rem;border-top:1px solid rgba(3,152,157,.15);
}
.mvStats li{
  flex:1;
}
.mvStats .num{
  font-family:"Cormorant Garamond",serif;
  font-size:6.4rem;color:var(--primary);letter-spacing:.04em;display:block;line-height:1;
  margin-bottom:.8rem;font-weight:600;
}
.mvStats .lbl{font-size:1.2rem;color:var(--muted);letter-spacing:.14em;}

/* hero image stack */
.mvVisual{
  position:relative;height:74rem;
}
.mvImg{
  position:absolute;overflow:hidden;box-shadow:var(--shadow);
}
.mvImg img{width:100%;height:100%;object-fit:cover;}
.mvImg-main{
  inset: 0 -5rem -5rem 0;
  border-radius:46% 54% 48% 52% / 52% 46% 54% 48%;
  animation:blob 12s ease-in-out infinite;
}
.mvImg-sub{
  width:24rem;height:24rem;right:-2rem;bottom:0;
  border-radius:50%;
  border:6px solid #fff;
  animation:floatY 6s ease-in-out infinite;
}
.mvBadge{
  position:absolute;top:2rem;left:-3rem;
  width:14rem;height:14rem;border-radius:50%;
  background:var(--accent);color:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;font-weight:800;letter-spacing:.08em;
  box-shadow:0 12px 30px rgba(255,237,0,.55);
  animation:floatY 5s ease-in-out infinite;
  transform:rotate(-8deg);
}
.mvBadge b{font-size:3rem;display:block;font-family:"Cormorant Garamond",serif;}
.mvBadge span{font-size:1.1rem;margin-top:.4rem;}
.mvDots{
  position:absolute;top:-1rem;right:12rem;width:8rem;height:8rem;
  background-image:radial-gradient(var(--primaryL) 2px,transparent 2.5px);
  background-size:14px 14px;opacity:.5;
}

/* scrolling marquee under hero */
.mvMarquee{
  position:relative;z-index:4;
  background:var(--primary);
  color:#fff;overflow:hidden;
  height:5vh;
  display:flex;align-items:center;
}
.mvMarquee .track{
  display:flex;gap:4rem;animation:marquee 24s linear infinite;width:max-content;
}
.mvMarquee span{
  font-family:"Cormorant Garamond",serif;font-size:2.2rem;letter-spacing:.2em;white-space:nowrap;
  display:inline-flex;align-items:center;gap:4rem;
}
.mvMarquee span::after{
  content:"❋";font-size:1.6rem;color:var(--accent);
}

@media (max-width:767px){
  .mv{min-height:auto;padding-top:8.8rem;}
  .mvInner{grid-template-columns:1fr;gap:4rem;padding:4rem 0 6rem;}
  .mvHead{font-size:6.4rem;}
  .mvLead{font-size:2.6rem;}
  .mvStats{gap:1.6rem;}
  .mvStats .num{font-size:5.2rem;}
  .mvStats .lbl{font-size:1.8rem;}
  .mvVisual{height:60rem;}
  .mvImg-main{inset:0 2rem 2rem 0;}
  .btn{font-size:2.2rem;padding:2.2rem 3.6rem;}
  .mvMarquee span{font-size:3rem;}
}

/* =======================================================
   CONCEPT
   ======================================================= */
.consept{
  padding:14rem 0 10rem;
  position:relative;
  background:linear-gradient(180deg,#fff 0%,#fafdff 100%);
}
.consept::before{
  content:"CONCEPT";
  position:absolute;top:6rem;left:50%;transform:translateX(-50%);
  font-family:"Cormorant Garamond",serif;
  font-size:18rem;font-weight:600;
  color:rgba(3,152,157,.05);letter-spacing:.1em;
  pointer-events:none;
}
.consept h2{
  font-family:"Noto Serif JP",serif;
  font-size:4.4rem !important;line-height:1.7;letter-spacing:.08em;
  margin-bottom:6rem !important;
  color:var(--ink) !important;
  font-weight:500;
  position:relative;z-index:1;
  background:none !important;-webkit-text-fill-color:initial !important;
}
.consept h2 strong{color:var(--primary);font-weight:600;}
.conseptTxt{
  font-size:1.8rem;line-height:2.4;font-weight:500;
  color:var(--muted);
  max-width:68rem;margin:0 auto;
}
.conseptTxt strong{color:var(--primary);font-weight:700;}

@media (max-width:767px){
  .consept{padding:10rem 0 8rem;}
  .consept::before{font-size:12rem;top:4rem;}
  .consept h2{font-size:3.6rem !important;}
  .conseptTxt{font-size:2.6rem;width:calc(650 * (100vw / 750));}
}

/* =======================================================
   FEATURE / FUTURE (選ばれる理由)
   ======================================================= */
.future{
  padding:14rem 0 10rem;
  position:relative;
  background:
    radial-gradient(900px 500px at 100% 0,rgba(198,230,241,.35),transparent 60%),
    linear-gradient(180deg,#fafdff 0%,#fff 100%);
}
.future > .jpTtl,
.future > .secTtl{display:block;text-align:center;margin-left:auto;margin-right:auto;}

.futureBlock{
  display:grid;grid-template-columns:1fr 1fr;gap:6rem;
  align-items:center;
  width:min(132rem,92%);margin:0 auto 8rem;
  padding:5rem;background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  position:relative;overflow:hidden;
}
.futureBlock.comBg01{
  background:linear-gradient(120deg,#f3fafd 0%,#e6f4f9 100%);
}
.futureBlock::before{
  content:"";position:absolute;top:-6rem;right:-6rem;width:18rem;height:18rem;
  border-radius:50%;background:rgba(255,237,0,.25);filter:blur(30px);
}
.futureBlock.fdrl{direction:rtl;}
.futureBlock.fdrl > *{direction:ltr;}

.futureImg{
  width:100%;position:relative;aspect-ratio:4/3;
}
.futureImg img{
  width:100%;height:100%;object-fit:cover;
  border-radius:18px;
  box-shadow:0 18px 40px rgba(3,152,157,.18);
}
.futureImg::after{
  content:"";position:absolute;inset:1.5rem -1.5rem -1.5rem 1.5rem;
  border:2px solid var(--primary);border-radius:18px;z-index:-1;
}

.futureTxtBox{width:100%;text-align:left;}
.futureTxtBox h3{
  display:flex;align-items:center;gap:1.4rem;
  font-size:2.4rem;line-height:1.5;letter-spacing:.04em;
  padding:0 0 1.6rem;margin-bottom:2rem;
  background:none !important;
  color:var(--ink);font-weight:700;
  border-bottom:1px solid rgba(3,152,157,.2);
  font-family:"Noto Serif JP",serif;
}
.futureTxtBox h3::before{
  content:attr(data-num);
  flex:0 0 auto;width:5.2rem;height:5.2rem;
  display:flex;align-items:center;justify-content:center;
  font-family:"Cormorant Garamond",serif;font-size:2.4rem;font-weight:600;
  color:#fff;background:linear-gradient(135deg,var(--primary),var(--primaryL));
  border-radius:50%;letter-spacing:0;
  box-shadow:0 8px 18px rgba(3,152,157,.35);
}
.futureTxt{
  font-size:1.6rem;line-height:2;color:var(--muted);
  font-weight:500;
}

/* Old inline class acBg on h3 would conflict — neutralize */
.futureTxtBox h3.acBg{background:transparent !important;}

@media (max-width:767px){
  .future{padding:10rem 0 8rem;}
  .futureBlock{grid-template-columns:1fr;padding:4rem;gap:4rem;margin-bottom:6rem;}
  .futureBlock.fdrl{direction:ltr;}
  .futureTxtBox h3{font-size:3rem;}
  .futureTxtBox h3::before{width:6rem;height:6rem;font-size:2.8rem;}
  .futureTxt{font-size:2.6rem;}
}

/* =======================================================
   PROGRAM
   ======================================================= */
.program{
  padding:14rem 0 10rem;
  background:linear-gradient(180deg,#fff 0%,#fbf7f2 60%,#fff 100%);
  position:relative;
}
.program > .jpTtl,
.program > .secTtl{display:block;text-align:center;margin-left:auto;margin-right:auto;}

.programlist{
  display:grid;grid-template-columns:repeat(3,1fr);gap:3.2rem;
  width:min(132rem,92%);margin:0 auto 8rem;padding:0;
}
.programlist li{
  width:auto;position:relative;background:#fff;
  border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadowSoft);
  transition:transform .4s ease,box-shadow .4s ease;
}
.programlist li:hover{
  transform:translateY(-8px);box-shadow:var(--shadow);
}
.programlist li > a{display:block;}
.programImg{
  margin:0;overflow:hidden;position:relative;
  aspect-ratio:4/3;
}
.programImg img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease;}
.programlist li:hover .programImg img{transform:scale(1.08);}
.programImg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 45%,rgba(3,152,157,.55) 100%);
  pointer-events:none;
}
.programImgTxt{
  position:absolute;left:1.6rem;bottom:1.6rem;
  display:inline-flex;align-items:center;justify-content:center;
  padding:.8rem 1.6rem;font-size:1.2rem;letter-spacing:.18em;font-weight:700;
  background:#fff;color:var(--primary);border-radius:999px;
  width:auto;height:auto;
  box-shadow:0 6px 14px rgba(0,0,0,.18);z-index:2;
}
.programlist li h4{
  font-family:"Noto Serif JP",serif;
  font-size:2.2rem;font-weight:700;letter-spacing:.06em;
  margin:2.4rem 2.4rem 1.2rem;line-height:1.5;
  color:var(--ink) !important;
}
.programTxt{
  font-size:1.5rem;line-height:1.9;color:var(--muted);
  padding:0 2.4rem 2.8rem;text-align:left;
}

@media (max-width:767px){
  .program{padding:10rem 0 8rem;}
  .programlist{grid-template-columns:1fr;width:calc(650 * (100vw / 750));gap:4rem;}
  .programlist li h4{font-size:3.2rem;}
  .programlist li p.programTxt{font-size:2.4rem;line-height:1.8;}
}

/* =======================================================
   EXPERIENCE / RESERVE
   ======================================================= */
.experienceBox{
  width:min(100rem,92%);margin:0 auto;
  padding:8rem 6rem;
  background:linear-gradient(135deg,#e8f5fa 0%,#fde6eb 100%);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  text-align:center;position:relative;overflow:hidden;
}
.experienceBox::before{
  content:"";position:absolute;top:-6rem;left:-6rem;width:24rem;height:24rem;
  background:rgba(255,237,0,.35);border-radius:50%;filter:blur(30px);
}
.experienceBox::after{
  content:"";position:absolute;bottom:-8rem;right:-8rem;width:28rem;height:28rem;
  background:rgba(3,152,157,.15);border-radius:50%;filter:blur(40px);
}
.experienceBox > *{position:relative;z-index:1;}
.experienceBox h3{
  font-family:"Noto Serif JP",serif;font-size:3.6rem;line-height:1.5;
  margin-bottom:3rem;color:var(--ink);font-weight:700;letter-spacing:.06em;
}
.experienceImg{width:min(60rem,100%);margin:0 auto 3rem;border-radius:18px;overflow:hidden;box-shadow:var(--shadowSoft);}
.experienceTxt{
  width:min(72rem,100%);margin:3rem auto;
  font-size:1.6rem;line-height:2.2;color:var(--muted);
}
.experienceTxt a{color:var(--primary);font-weight:700;}
.experience_Line_btn,.linkBtn{
  margin:0 auto;display:flex;justify-content:center;
}
.linkBtn{
  width:36rem;height:auto;padding:0;
  border-radius:999px;overflow:visible;
}
.linkBtn.comBg{
  background:linear-gradient(135deg,var(--primary),var(--subBlue)) !important;
  color:#fff;
  padding:2rem 0;box-shadow:0 14px 30px rgba(3,152,157,.35);
  transition:transform .3s ease,box-shadow .3s ease;
}
.linkBtn.comBg:hover{transform:translateY(-3px);box-shadow:0 20px 36px rgba(3,152,157,.45);opacity:1;}
.linkBtn span{font-size:1.6rem;font-weight:700;letter-spacing:.14em;color:#fff !important;}

.banner_Line_btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.8rem;
  padding:1.6rem 3rem;border-radius:999px;
  background:linear-gradient(135deg,var(--primary),var(--subBlue));
  color:#fff;border:none;
  font-size:1.5rem;font-weight:700;letter-spacing:.1em;
  box-shadow:0 12px 24px rgba(3,152,157,.35);
  cursor:pointer;transition:transform .3s ease,opacity .3s ease;
  width:auto;
}
.banner_Line_btn:hover{transform:translateY(-3px);opacity:.95;}
.banner_Line_btn:focus{border:none;}
.banner_Line_btn:after,.banner_cp_btn:after,.banner_yoyaku_btn:after{display:none;}
.banner_cp_btn,.banner_yoyaku_btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:1.4rem 2.6rem;border-radius:999px;border:none;color:#fff;
  font-size:1.4rem;font-weight:700;letter-spacing:.1em;
}
.banner_cp_btn{background:#00b900;box-shadow:0 10px 20px rgba(0,185,0,.3);}
.banner_yoyaku_btn{background:#c42d48;box-shadow:0 10px 20px rgba(196,45,72,.3);}

@media (max-width:767px){
  .experienceBox{width:100vw;padding:8rem 4rem;border-radius:0;}
  .experienceBox h3{font-size:4.2rem;}
  .experienceTxt{font-size:2.4rem;line-height:2;width:100%;}
  .experienceImg{width:66rem;}
}

/* =======================================================
   PRICE
   ======================================================= */
.price{
  padding:14rem 0 10rem;
  background:
    radial-gradient(700px 400px at 0 0,rgba(244,201,211,.25),transparent 60%),
    #fff;
  position:relative;
}
.price > .jpTtl,
.price > .secTtl{display:block;text-align:center;margin-left:auto;margin-right:auto;}
.pricelist{
  width:min(110rem,92%);margin:0 auto;
  display:flex;justify-content:center;
}
.pricelist li{
  width:100%;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);background:#fff;
  border:1px solid var(--line);
  padding:2rem;
}
.pricelist li img{border-radius:14px;}



/* --- Price Single (coded) --- */
.price-single{
  max-width:90rem;
  text-align:left;
}

/* カード共通 */
.price-card{
  background:#fff;
  border-radius:28px;
  padding:5.6rem 6rem;
  box-shadow:0 2px 4px rgba(3,152,157,.04),0 20px 60px rgba(3,152,157,.1);
  border:1px solid rgba(3,152,157,.1);
  position:relative;overflow:hidden;
}
.price-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--subBlue),var(--primaryL));
}

/* 入会金 */
.price-entry{
  display:flex;align-items:center;gap:2.4rem;
  padding:2rem 2.8rem;
  background:rgba(3,152,157,.05);
  border-radius:16px;
  margin-bottom:3.6rem;
}
.price-entry-val{
  font-size:2.6rem;color:var(--primary);letter-spacing:.04em;
}
.price-entry-val strong{
  font-family:"Cormorant Garamond","Playfair Display",serif;
  font-size:3.8rem;font-weight:700;
  background:linear-gradient(120deg,var(--primary),var(--subBlue));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* バッジ */
.price-badge{
  display:inline-flex;align-items:center;
  font-size:1.4rem;font-weight:700;letter-spacing:.15em;
  color:var(--primary);
  border:1.5px solid rgba(3,152,157,.35);
  border-radius:999px;
  padding:.7rem 2rem;
  white-space:nowrap;background:#fff;
}
.price-badge--sm{
  font-size:1.3rem;padding:.6rem 1.6rem;
}

/* コースタグ */
.price-course-tag{
  display:inline-flex;
  font-size:1.4rem;font-weight:700;letter-spacing:.2em;
  color:#fff;
  background:linear-gradient(135deg,var(--primary),var(--subBlue));
  padding:.8rem 3rem;border-radius:999px;
  margin-bottom:1.8rem;
}

/* ヘッダー行 */
.price-col-head{
  display:flex;justify-content:space-between;
  padding:.8rem 2.4rem;
  font-size:1.3rem;color:var(--muted);letter-spacing:.14em;
  margin-bottom:.8rem;
}

/* 料金行 */
.price-rows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.8rem;}
.price-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.8rem 2.4rem;
  background:rgba(3,152,157,.04);
  border-radius:14px;
  border:1px solid transparent;
  transition:background .25s ease,border-color .25s ease,transform .25s ease;
}
.price-row:hover{
  background:rgba(3,152,157,.09);
  border-color:rgba(3,152,157,.18);
  transform:translateX(5px);
}
.price-row--accent{
  background:linear-gradient(135deg,rgba(3,152,157,.08),rgba(41,132,186,.06));
  border:1px solid rgba(3,152,157,.2);
}
.price-plan{
  font-size:1.7rem;font-weight:700;color:var(--ink);letter-spacing:.06em;
  display:flex;align-items:baseline;gap:.6rem;
}
.price-plan small{font-size:1.2rem;color:var(--muted);font-weight:400;}
.price-val{
  font-size:2rem;color:var(--ink);letter-spacing:.04em;
}
.price-val strong{
  font-family:"Cormorant Garamond","Playfair Display",serif;
  font-size:2.8rem;font-weight:700;color:var(--primary);
}
.price-val em{
  font-style:normal;font-size:1.4rem;color:var(--muted);
}

/* フッターノート */
.price-footer-notes{
  margin-top:3rem;display:flex;flex-direction:column;gap:1.2rem;
  padding-top:2.4rem;
  border-top:1px solid var(--line);
}
.price-note-row{
  display:flex;align-items:center;gap:1.6rem;
  font-size:1.5rem;color:var(--muted);
}

/* --- サイドカード --- */
.price-card--side{
  display:flex;flex-direction:column;justify-content:center;
  background:linear-gradient(145deg,rgba(3,152,157,.04) 0%,rgba(41,132,186,.06) 100%);
  border:1px solid rgba(3,152,157,.12);
}
.price-side-label{
  font-size:1.1rem;letter-spacing:.3em;color:var(--primary);
  font-weight:600;text-transform:uppercase;margin-bottom:1.2rem;
}
.price-side-ttl{
  font-family:"Cormorant Garamond","Playfair Display","Noto Serif JP",serif;
  font-size:4rem;font-weight:600;line-height:1.3;
  background:linear-gradient(120deg,var(--primary),var(--subBlue));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:3.2rem;letter-spacing:.08em;
}
.price-policy-list{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;gap:1.6rem;
  margin-bottom:3.6rem;
}
.price-policy-list li{
  display:flex;align-items:flex-start;gap:1.2rem;
  font-size:1.4rem;color:var(--ink);line-height:1.7;
}
.price-policy-icon{
  color:var(--primary);font-size:1rem;flex-shrink:0;margin-top:.3rem;
}
.price-side-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:1.4rem 3rem;border-radius:999px;
  background:linear-gradient(135deg,var(--primary),var(--subBlue));
  color:#fff;font-size:1.4rem;font-weight:700;letter-spacing:.12em;
  box-shadow:0 8px 24px rgba(3,152,157,.32);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease;
  align-self:flex-start;
}
.price-side-btn:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 32px rgba(3,152,157,.42);
  opacity:1;
}

@media (max-width:767px){
  .price-grid{grid-template-columns:1fr;gap:2.4rem;}
  .price-card{padding:2.8rem 2.4rem;}
  .price-side-ttl{font-size:3.2rem;}
}
@media (max-width:767px){
  .price{padding:8rem 0;}
  .pricelist{display:block;}
  .pricelist li{margin-bottom:3rem;}
  .price-entry-ttl{font-size:2.2rem;}
  .price-entry-val{font-size:3rem;}
  .price-entry-val strong{font-size:4.4rem;}
  .price-badge{font-size:2rem;}
  .price-course-tag{font-size:2.1rem;}
  .price-col-head{font-size:1.9rem;}
  .price-plan{font-size:2.4rem;}
  .price-plan small{font-size:1.8rem;}
  .price-val{font-size:2.4rem;}
  .price-val strong{font-size:3.4rem;}
  .price-val em{font-size:1.9rem;}
  .price-note-row{font-size:2.2rem;}
  .price-side-label{font-size:1.8rem;}
  .price-side-ttl{font-size:3.8rem;}
  .price-policy-list li{font-size:2.2rem;}
  .price-side-btn{font-size:2.1rem;}
}
/* =======================================================
   CUSTOMER VOICE (re-uses .program block)
   ======================================================= */
.YTvoice{
  width:min(92rem,92%);margin:0 auto 8rem;
  aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);
}
.YTvoice iframe{width:100%;height:100%;border:0;display:block;}

/* voice grid (uses .programlist) — we leave grid-template-columns at 3 cols;
   additional cards wrap to next row */
.voicemix{
  width:min(132rem,92%);margin:4rem auto 0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;
}
.voicemix li{
  background:#fff;border-radius:var(--radius);
  box-shadow:var(--shadowSoft);overflow:hidden;padding:1.6rem;
}
.voicemix li img{border-radius:14px;}

@media (max-width:767px){
  .voicemix{grid-template-columns:1fr;}
}

/* =======================================================
   MESSAGE
   ======================================================= */
.message{
  padding:14rem 0 10rem;
  background:linear-gradient(180deg,#fff 0%,#f6fbfd 100%);
  aspect-ratio:auto;
}
.message .experienceBox-ms{
  max-width:80rem;margin:0 auto;padding:0 2rem;
}
.message .experienceBox-ms .pricelist li{
  box-shadow:var(--shadow);border:none;background:#fff;padding:2rem;border-radius:var(--radius);
}

/* =======================================================
   FAQ (accordion)
   ======================================================= */
.faq{
  padding:14rem 0 10rem !important;
  background:#fbfdfe;
}
.faq > .jpTtl,
.faq > .secTtl{display:block;text-align:center;margin-left:auto;margin-right:auto;}
.qa-list{
  width:min(96rem,92%);margin:0 auto;
}
.qa-list.mts{display:block;}
.qa-list dl{
  position:relative;margin:0 0 1.4rem;cursor:pointer;
  border:none;border-radius:14px;background:#fff;
  box-shadow:var(--shadowSoft);overflow:hidden;
}
.qa-list dl::after{
  top:2.6rem;right:2.6rem;width:8px;height:8px;
  border-color:var(--primary);
}
.qa-list dl dt{
  padding:2.2rem 6rem 2.2rem 6.4rem;
  background:transparent !important;line-height:1.6;
  font-size:1.6rem;font-weight:700;color:var(--ink);
}
.qa-list dl dt::before{
  font-family:"Cormorant Garamond",serif;
  font-size:2.6rem;line-height:1;
  top:1.9rem;left:2.2rem;color:var(--primary);font-weight:600;
}
.qa-list dl dd{
  padding:0 6rem 2.2rem 6.4rem;line-height:1.8;
  color:var(--muted);
}
.qa-list dl dd::before{
  font-family:"Cormorant Garamond",serif;font-size:2.6rem;
  left:2.2rem;color:var(--accent);font-weight:700;
  -webkit-text-stroke:1px var(--primary);
}
.qa-list dl dd p{font-size:1.5rem;line-height:1.9;margin:0;}

@media (max-width:767px){
  .faq{padding:10rem 4rem !important;}
  .qa-list dl dt{font-size:2.6rem;padding:2.4rem 6rem 2.4rem 7rem;}
  .qa-list dl dd p{font-size:2.4rem;}
}

/* =======================================================
   ACCESS
   ======================================================= */
.accses{padding:14rem 0 6rem;background:#fff;}
.accses > .jpTtl,
.accses > .secTtl{display:block;text-align:center;margin-left:auto;margin-right:auto;}
.accses_map{
  width:min(132rem,94%);margin:0 auto 8rem;
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);
  overflow:hidden;padding:0;
}
.accses_info{
  width:100%;margin:0;padding:4rem;
  border-spacing:0;text-align:left;
}
.accses_info tr{border:none;}
.accses_info th{
  background:transparent !important;
  font-size:1.3rem;font-weight:700;letter-spacing:.14em;color:var(--primary);
  padding:1.6rem 1rem;border-bottom:1px dashed rgba(3,152,157,.2) !important;
  width:30%;vertical-align:middle;
  border-right:none !important;
}
.accses_info td{
  padding:1.6rem 1rem;border-bottom:1px dashed rgba(3,152,157,.2) !important;
  font-size:1.4rem;line-height:1.6;color:var(--ink);vertical-align:middle;
  width:70%;
}
.accses_info td a img{width:auto;max-height:3.6rem;display:inline-block;margin-right:.8rem;}
.accses_info img{width:auto;}

.google_map{
  width:100%;height:auto;min-height:40rem;margin:0;
}
.google_map iframe{width:100%;height:100%;min-height:40rem;border:0;display:block;}

@media (max-width:767px){
  .accses{padding:10rem 0 4rem;}
  .accses_map{grid-template-columns:1fr;gap:0;width:calc(100% - 4rem);}
  .accses_info{padding:3rem 2rem;width:100% !important;}
  .accses_info th{font-size:2rem;}
  .accses_info td{font-size:2.4rem;}
  .google_map{min-height:42rem;}
  .google_map iframe{min-height:42rem;}
}

/* =======================================================
   NEWS
   ======================================================= */
.news{
  padding:14rem 0 12rem;
  background:linear-gradient(180deg,var(--bgBlue2) 0%,#fff 40%);
  position:relative;
}
.news > .jpTtl,
.news > .secTtl{display:block;text-align:center;margin-left:auto;margin-right:auto;}

.newslist{
  width:min(120rem,92%);margin:0 auto 7rem;padding:0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:2.8rem;
}

/* カード */
.newsBox{
  width:auto;margin:0 !important;
  border:none !important;padding:0 !important;
  background:#fff;border-radius:20px;
  box-shadow:0 2px 8px rgba(3,152,157,.06),0 12px 32px rgba(3,152,157,.08);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .38s cubic-bezier(.34,1.56,.64,1),box-shadow .38s ease;
}
.newsBox a{
  display:flex;flex-direction:column;flex:1;padding:0;
  text-decoration:none;
}
.newsBox:hover{
  transform:translateY(-8px);
  box-shadow:0 4px 12px rgba(3,152,157,.1),0 24px 48px rgba(3,152,157,.14);
}

/* サムネイル */
.zoomWrap{overflow:hidden;flex-shrink:0;}
.newsimg{
  height:22rem;overflow:hidden;
}
.newsimg img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .7s ease;
}
.newsBox:hover .newsimg img{transform:scale(1.07);}

/* テキストエリア */
.newsBody{
  display:flex;flex-direction:column;flex:1;
  padding:2.4rem 2.8rem 2.8rem;
  position:relative;
}
.newsBody::before{
  content:'';position:absolute;top:0;left:2.8rem;right:2.8rem;height:1px;
  background:linear-gradient(90deg,var(--primary),transparent);
  opacity:.18;
}

.newsDay{
  font-size:1.15rem;font-weight:600;letter-spacing:.18em;
  color:var(--primary);margin:0 0 1rem;display:block;
}

.newsBox .newsTtl{
  font-size:1.55rem;font-weight:700;line-height:1.6;
  color:var(--ink) !important;margin:0 0 1.2rem;
  font-family:"Noto Sans JP",sans-serif;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

.newsTxt{
  font-size:1.35rem;line-height:1.8;color:var(--muted);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
  margin:0;
}

/* ニュース一覧ボタン */
.news .linkBtn{
  display:inline-flex;align-items:center;justify-content:center;gap:1rem;
  margin:0 auto;padding:1.4rem 4.8rem;
  border-radius:999px;
  background:linear-gradient(135deg,var(--primary),var(--subBlue));
  color:#fff !important;font-size:1.5rem;font-weight:700;letter-spacing:.14em;
  box-shadow:0 8px 24px rgba(3,152,157,.3);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease;
  width:auto;
}
.news .linkBtn:hover{
  transform:translateY(-3px);box-shadow:0 14px 32px rgba(3,152,157,.4);opacity:1;
}
.news .linkBtn span{color:#fff !important;}

@media (max-width:767px){
  .news{padding:12rem 0 10rem;}
  .newslist{grid-template-columns:1fr;gap:3.2rem;}
  .newsBox .newsTtl{font-size:2.6rem;}
  .newsDay{font-size:2rem;}
  .newsTxt{font-size:2.2rem;}
  .newsBody{padding:2.8rem 3.2rem 3.2rem;}
}

#index .newsBox{width:auto;border:none;padding:0;margin:0;}

#newsArchive .newslist{
  grid-template-columns:repeat(3,1fr);
}
#newsArchive .newsBox{width:auto;border:none;padding:0;margin:0;}
#newsArchive .newsimg{height:20rem;}

@media (max-width:767px){
  #newsArchive .newslist{grid-template-columns:1fr;}
}

/* =======================================================
   FLOATING / FOOTER
   ======================================================= */
.floating-banner{
  position:fixed;z-index:999;right:2.4rem;bottom:2.4rem;
  animation:floatCard 5s ease-in-out infinite;
}
@keyframes floatCard{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-7px)}
}
.floating-banner .banner{
  position:relative;overflow:hidden;
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(28px) saturate(200%);
  -webkit-backdrop-filter:blur(28px) saturate(200%);
  border-radius:26px;
  padding:1.8rem 2.2rem 1.6rem;
  box-shadow:
    0 2px 4px rgba(3,152,157,.04),
    0 8px 24px rgba(3,152,157,.1),
    0 28px 56px rgba(3,152,157,.15),
    inset 0 1px 0 rgba(255,255,255,.95);
  text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.2rem;
  border:1px solid rgba(255,255,255,.75);
  min-width:16rem;
}
.floating-banner .banner::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(3,152,157,.45),rgba(147,210,210,.6),rgba(3,152,157,.45),transparent);
  pointer-events:none;
}
.floating-banner .banner::after{
  content:'';position:absolute;top:-50%;left:50%;transform:translateX(-50%);
  width:130%;height:80%;
  background:radial-gradient(ellipse,rgba(3,152,157,.07) 0%,transparent 70%);
  pointer-events:none;
}
.floating-banner .banner_copy{
  font-size:1.05rem;margin:0;
  background:linear-gradient(135deg,var(--primary) 0%,var(--subBlue) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  font-weight:800;letter-spacing:.22em;
  position:relative;z-index:1;
}
.floating-banner .banner_Line_btn{
  padding:1.2rem 2.6rem;font-size:1.35rem;
  position:relative;overflow:hidden;z-index:1;
  background:linear-gradient(135deg,var(--primary) 0%,var(--subBlue) 100%);
  box-shadow:0 4px 16px rgba(3,152,157,.38),0 1px 3px rgba(3,152,157,.18);
  transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease;
}
.floating-banner .banner_Line_btn::after{
  content:'';display:block !important;
  position:absolute;top:0;left:-120%;
  width:70%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
  animation:btnShimmer 3.8s ease-in-out infinite;
  border:none;border-radius:0;
}
.floating-banner .banner_Line_btn:hover{
  transform:translateY(-3px) scale(1.03);
  box-shadow:0 12px 30px rgba(3,152,157,.48),0 4px 8px rgba(3,152,157,.2);
}
@keyframes btnShimmer{
  0%{left:-120%}
  45%{left:130%}
  100%{left:130%}
}
@media (max-width:767px){
  .floating-banner{
    right:2.8rem;bottom:2.8rem;
    left:auto;width:auto;
    animation:floatCard 5s ease-in-out infinite;
  }
  .floating-banner .banner{
    border-radius:26px;
    backdrop-filter:blur(28px) saturate(200%);
    -webkit-backdrop-filter:blur(28px) saturate(200%);
    background:rgba(255,255,255,.78);
    padding:2.2rem 2.6rem 2rem;
    flex-direction:column;
    justify-content:center;
    box-shadow:0 2px 4px rgba(3,152,157,.04),0 8px 24px rgba(3,152,157,.1),0 28px 56px rgba(3,152,157,.15);
    min-width:18rem;
  }
  .floating-banner .banner_copy{font-size:2rem;letter-spacing:.2em;}
  .floating-banner .banner_Line_btn{font-size:2rem;padding:1.4rem 2.8rem;}
}

footer{
  width:100%;margin-top:0;
  background:linear-gradient(135deg,#083d40 0%,#051f21 100%);
  color:#e5eef2;
  padding:6rem 0 2rem;
}
footer .footerLink{
  display:flex;justify-content:center;gap:3rem;margin-bottom:3rem;flex-wrap:wrap;
}
footer a{
  display:inline-block;padding:0;margin:0 1rem;
  color:#cfe1e6 !important;font-size:1.4rem;letter-spacing:.1em;
}
footer a:hover{color:#fff !important;opacity:1;}
.copy{
  text-align:center;font-size:1.2rem;padding:2rem 0 0;color:#7d8a95;letter-spacing:.12em;
  border-top:1px solid rgba(255,255,255,.08);
}
footer.comBg{background:linear-gradient(135deg,#083d40 0%,#051f21 100%) !important;}

@media (max-width:767px){
  footer{padding:6rem 0 3rem;}
  .copy{font-size:2rem;padding:3rem 0 0;}
  footer a{font-size:2rem;}
}

/* =======================================================
   Fixed link (hide placeholder by default)
   ======================================================= */
.fixedLink{display:none;}

/* =======================================================
   ADMIN
   ======================================================= */
#wpadminbar{display:none;}

/* form sanity (left mostly as-is) */
form{
  background:#fff;padding:2.4rem;border-radius:14px;
  box-shadow:var(--shadowSoft);max-width:60rem;margin:0 auto;
}
label{display:block;margin-bottom:.6rem;font-weight:700;font-size:1.3rem;color:var(--ink);}
input[type="text"],input[type="email"],input[type="tell"],textarea{
  width:100%;padding:1rem 1.2rem;margin-bottom:1.2rem;
  border:1px solid var(--line);border-radius:10px;background:#fbfdfe;
}
textarea{resize:vertical;min-height:12rem;}
input[type="submit"]{
  width:100%;background:linear-gradient(135deg,var(--primary),var(--subBlue));
  color:#fff;padding:1.4rem;border-radius:999px;cursor:pointer;
  font-size:1.5rem;font-weight:700;letter-spacing:.1em;
}
input[type="submit"]:hover{opacity:.9;}

/* =======================================================
   News detail page
   ======================================================= */
.news-detail{
  width:min(80rem,92%);margin:0 auto;
  padding:12rem 0 14rem;
}

/* ヘッダーエリア */
.news-detail-head{
  margin-bottom:5rem;
  padding-bottom:4rem;
  border-bottom:1px solid var(--line);
}
.news-detail-back{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:1.3rem;font-weight:600;letter-spacing:.1em;
  color:var(--primary);
  margin-bottom:3rem;
  transition:gap .25s ease,opacity .25s ease;
}
.news-detail-back:hover{gap:1rem;opacity:.75;}

.news-detail-date{
  font-size:1.2rem;font-weight:700;letter-spacing:.2em;
  color:var(--primary);margin-bottom:1.6rem;
}

.news-detail-title{
  font-family:"Noto Serif JP","Noto Sans JP",serif;
  font-size:3.2rem;font-weight:700;line-height:1.65;
  color:var(--ink);letter-spacing:.04em;
}

/* サムネイル */
.news-detail-thumb{
  border-radius:20px;overflow:hidden;
  margin-bottom:5.6rem;
  box-shadow:0 8px 32px rgba(3,152,157,.12);
  aspect-ratio:16/7;
}
.news-detail-thumb img{
  width:100%;height:100%;object-fit:cover;display:block;
}

/* 本文エリア */
.news-detail-body{
  font-size:1.65rem;line-height:2.0;color:var(--ink);
  letter-spacing:.04em;
}
.news-detail-body p{
  margin-bottom:2.4rem;
}
.news-detail-body h2,.news-detail-body h3,.news-detail-body h4{
  font-family:"Noto Serif JP",serif;
  font-weight:700;color:var(--primary);
  margin:4rem 0 1.6rem;line-height:1.5;
}
.news-detail-body h2{font-size:2.4rem;}
.news-detail-body h3{font-size:2rem;}
.news-detail-body h4{font-size:1.8rem;}
.news-detail-body img{
  border-radius:14px;margin:2.4rem 0;
  box-shadow:0 4px 16px rgba(3,152,157,.1);
}
.news-detail-body ul,.news-detail-body ol{
  padding-left:2em;margin-bottom:2.4rem;
}
.news-detail-body li{margin-bottom:.8rem;line-height:1.8;}
.news-detail-body a{
  color:var(--primary);text-decoration:underline;text-underline-offset:3px;
}

/* フッター */
.news-detail-footer{
  margin-top:7rem;padding-top:5rem;
  border-top:1px solid var(--line);
  text-align:center;
}
.news-detail-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:1.4rem 4.8rem;border-radius:999px;
  background:linear-gradient(135deg,var(--primary),var(--subBlue));
  color:#fff;font-size:1.5rem;font-weight:700;letter-spacing:.14em;
  box-shadow:0 8px 24px rgba(3,152,157,.3);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease;
}
.news-detail-btn:hover{
  transform:translateY(-3px);box-shadow:0 14px 32px rgba(3,152,157,.4);opacity:1;color:#fff;
}

@media (max-width:767px){
  .news-detail{padding:10rem 0 12rem;}
  .news-detail-title{font-size:2.8rem;}
  .news-detail-body{font-size:2.4rem;}
  .news-detail-thumb{aspect-ratio:4/3;}
}

/* legacy compat */
.postContent{
  padding-top:14rem;width:min(88rem,92%);margin:0 auto 12rem;
}
.postContent h2{font-family:"Noto Serif JP",serif;font-size:3.2rem;margin-bottom:2rem;color:var(--primary);}
.postContent span{font-size:1.4rem;color:var(--primary);margin-bottom:1rem;display:block;font-weight:700;letter-spacing:.12em;}
.postContent p{font-size:1.6rem;line-height:1.9;color:var(--ink);}
.postContent time{font-size:1.4rem;margin-bottom:1.2rem;display:block;color:var(--muted);}
.postContentImg{border-radius:18px;overflow:hidden;margin:0 auto 2rem;box-shadow:var(--shadowSoft);}


/* =======================================================
   SP MV ORDER FIX (画像→テキストの順に)
   ======================================================= */
@media(max-width:767px){
  .mvVisual{order:-1;}
}

/* =======================================================
   GOOGLE REVIEW CARDS
   ======================================================= */
.reviewSectionTitle{
  display:block;text-align:center;
  font-size:2rem;letter-spacing:.2em;color:var(--primary);
  font-weight:700;margin:6rem auto 4rem;
  position:relative;
}
.reviewGrid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:2.4rem;
  width:min(132rem,92%);margin:0 auto 5rem;
}
.reviewCard{
  background:#fff;border-radius:18px;
  padding:2.8rem 3rem;
  box-shadow:var(--shadowSoft);
  border:1px solid var(--line);
  text-align:left;position:relative;overflow:hidden;
}
.reviewCard::before{
  content:"\201C";
  position:absolute;top:.4rem;right:2rem;
  font-size:9rem;line-height:1;
  color:rgba(3,152,157,.1);
  font-family:"Cormorant Garamond",serif;
  pointer-events:none;
}
.reviewStars{
  font-size:2rem;letter-spacing:.08em;
  margin-bottom:1.4rem;color:#fbbc04;
}
.reviewMeta{
  font-size:1.3rem;color:var(--muted);
  letter-spacing:.08em;margin-bottom:1.8rem;
  font-weight:600;display:flex;align-items:center;gap:.8rem;
}
.reviewMeta::before{
  content:"G";
  display:inline-flex;align-items:center;justify-content:center;
  width:2.4rem;height:2.4rem;border-radius:50%;
  background:#4285f4;color:#fff;
  font-size:1.4rem;font-weight:700;flex-shrink:0;
}
.reviewTxt{
  font-size:1.5rem;line-height:1.95;
  color:var(--ink);font-weight:500;
}
@media(max-width:767px){
  .reviewGrid{grid-template-columns:1fr;gap:3rem;}
  .reviewCard{padding:3rem;}
  .reviewStars{font-size:3rem;}
  .reviewMeta{font-size:2rem;}
  .reviewTxt{font-size:2.4rem;}
}

/* =======================================================
   COLLAGE IMAGE (たくさんの方にご利用いただいています)
   ======================================================= */
.voicemix-collage{
  width:min(100rem,92%);margin:0 auto 4rem;
}
.voicemix-collage img{
  width:100%;border-radius:var(--radius);
  box-shadow:var(--shadow);
}

/* =======================================================
   WM POPUP MODAL — PC override (WMCBDQX01767882950)
   ======================================================= */
@media (min-width: 768px) {
  #WMCBDQX01767882950 .wm-modal-window {
    width: 380px !important;
    max-width: 380px !important;
  }
  #WMCBDQX01767882950 .wm-modal-window img {
    width: 100% !important;
    height: auto !important;
  }
  #WMCBDQX01767882950 .wm-modal-content,
  #WMCBDQX01767882950 .wm-modal-body-content {
    width: 380px !important;
    max-width: 380px !important;
    font-size: 0.9em !important;
  }
}
