/* =========================================================
   てならいワークス キッズマイクラクラス LP
   カラーテーマ：マインクラフト × ブランドカラー
   ========================================================= */

:root{
  /* ブランドカラー */
  --orange: #F39A2E;
  --orange-deep: #E8742B;
  --yellow: #F8C530;
  --yellow-light: #FCE08A;

  /* マイクラカラー */
  --grass-green: #5DA130;
  --grass-green-dark: #3E7A1E;
  --grass-top: #7BB661;
  --dirt-brown: #8B5A2B;
  --dirt-brown-dark: #6B4423;
  --stone-gray: #7C7C7C;
  --sky-blue: #79C7F2;
  --sky-blue-light: #B7E3FB;
  --diamond: #4FE0D8;
  --redstone: #D32F2F;

  /* ベース */
  --text: #3a3027;
  --text-soft: #6b5f52;
  --bg-cream: #FFF9EF;
  --white: #ffffff;
  --line: #EFE4D2;

  --shadow: 0 8px 24px rgba(139,90,43,.12);
  --shadow-lg: 0 14px 40px rgba(139,90,43,.18);
  --radius: 18px;

  --font: "M PLUS Rounded 1c", -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
  --font-pixel: "Press Start 2P", var(--font);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; scroll-padding-top:78px; }

body{
  font-family:var(--font);
  color:var(--text);
  background:var(--bg-cream);
  line-height:1.85;
  font-weight:500;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul,ol{ list-style:none; }

.container{ width:92%; max-width:1100px; margin:0 auto; }
.container-narrow{ max-width:820px; }

.pc-only{ display:inline; }
.sp-only{ display:none; }

/* =========================================================
   ボタン
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-weight:800; text-align:center; line-height:1.35;
  border-radius:999px; transition:.25s; cursor:pointer; border:none;
  box-shadow:0 6px 0 rgba(0,0,0,.12), var(--shadow);
}
.btn:hover{ transform:translateY(-3px); box-shadow:0 9px 0 rgba(0,0,0,.12), var(--shadow-lg); }
.btn:active{ transform:translateY(2px); box-shadow:0 2px 0 rgba(0,0,0,.12); }

.btn-primary{
  background:linear-gradient(135deg,var(--orange) 0%, var(--orange-deep) 100%);
  color:#fff;
}
.btn-line{ background:#06C755; color:#fff; }
.btn-line:hover{ background:#05b34c; }

.btn-lg{ font-size:1.05rem; padding:1rem 1.8rem; }
.btn-xl{ font-size:1.2rem; padding:1.3rem 2rem; width:100%; }
.btn-xl i{ font-size:1.4rem; }

/* =========================================================
   ヘッダー
   ========================================================= */
.site-header{
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(8px);
  box-shadow:0 2px 12px rgba(139,90,43,.08);
  border-bottom:3px solid var(--grass-green);
  transition:.3s;
}
.header-inner{
  width:96%; max-width:1240px; margin:0 auto;
  display:flex; align-items:center; gap:1.2rem;
  height:72px;
}
.header-logo img{ height:42px; width:auto; }
.header-nav{ display:flex; gap:1.5rem; margin-left:auto; }
.header-nav a{
  font-weight:700; font-size:.95rem; color:var(--text-soft);
  position:relative; transition:.2s;
}
.header-nav a::after{
  content:""; position:absolute; left:0; bottom:-6px; width:0; height:3px;
  background:var(--orange); border-radius:3px; transition:.25s;
}
.header-nav a:hover{ color:var(--orange-deep); }
.header-nav a:hover::after{ width:100%; }
.header-cta{
  background:linear-gradient(135deg,var(--orange),var(--orange-deep));
  color:#fff; font-weight:800; font-size:.92rem;
  padding:.7rem 1.2rem; border-radius:999px;
  box-shadow:0 4px 0 rgba(0,0,0,.12);
  transition:.2s;
}
.header-cta:hover{ transform:translateY(-2px); }

.nav-toggle{
  display:none; flex-direction:column; gap:5px; background:none; border:none;
  cursor:pointer; padding:6px; margin-left:auto;
}
.nav-toggle span{ width:26px; height:3px; background:var(--orange-deep); border-radius:3px; transition:.3s; }
.nav-toggle.active span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.nav-toggle.active span:nth-child(2){ opacity:0; }
.nav-toggle.active span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

.mobile-nav{
  display:none; flex-direction:column;
  background:#fff; border-top:1px solid #f0e6d6;
  padding:.5rem 0 1rem;
}
.mobile-nav a{
  padding:.9rem 1.5rem; font-weight:700; border-bottom:1px dashed #f0e6d6;
}
.mobile-nav a:last-child{ border-bottom:none; }
.mobile-cta{
  margin:.8rem 1.5rem 0; text-align:center;
  background:linear-gradient(135deg,var(--orange),var(--orange-deep));
  color:#fff!important; border-radius:999px; border-bottom:none!important;
}

/* =========================================================
   ヒーロー
   ========================================================= */
.hero{
  position:relative; padding:120px 0 0; margin-top:0;
  background:linear-gradient(180deg, var(--sky-blue) 0%, var(--sky-blue-light) 60%, #E6F5FF 100%);
  overflow:hidden;
}
.hero-clouds .cloud{
  position:absolute; background:#fff; border-radius:60px; opacity:.85;
  box-shadow:0 14px 0 -2px #fff;
}
.cloud-1{ width:120px; height:34px; top:90px; left:8%; animation:float 6s ease-in-out infinite; }
.cloud-2{ width:80px; height:26px; top:150px; right:12%; animation:float 7s ease-in-out infinite .5s; }
.cloud-3{ width:100px; height:30px; top:240px; left:30%; animation:float 8s ease-in-out infinite 1s; }
@keyframes float{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-12px);} }

.hero-inner{
  position:relative; z-index:2;
  width:92%; max-width:1140px; margin:0 auto;
  display:grid; grid-template-columns:1.1fr .9fr; gap:2.5rem; align-items:center;
  padding-bottom:70px;
}
.hero-badge{
  display:inline-flex; align-items:center; gap:.4em;
  background:#fff; color:var(--grass-green-dark);
  font-weight:800; font-size:.9rem; padding:.4rem 1rem; border-radius:999px;
  box-shadow:0 3px 0 rgba(0,0,0,.1); margin-bottom:1.1rem;
}
.hero-badge i{ color:var(--redstone); }
.hero-title{
  font-size:2.5rem; font-weight:900; line-height:1.4; color:#33414a;
  margin-bottom:1rem;
}
.hl-yellow{ color:var(--orange-deep); }
.hl-orange{
  color:#fff; background:var(--orange-deep);
  padding:0 .3em .05em; border-radius:6px;
  display:inline-block; line-height:1.3;
}
.hero-sub-title{
  font-size:1.25rem; font-weight:800; color:var(--grass-green-dark);
  margin-bottom:1.1rem; line-height:1.5;
}
.hero-lead{
  font-size:1rem; color:#3a4750; font-weight:600; margin-bottom:1.8rem;
  background:rgba(255,255,255,.6); padding:.9rem 1.1rem; border-radius:12px;
}
.hero-lead strong{ color:var(--orange-deep); }
.hero-buttons{ display:flex; flex-direction:column; gap:.9rem; max-width:480px; }

.hero-image{ position:relative; }
.hero-image img{
  width:100%; border-radius:20px;
  border:6px solid #fff;
  box-shadow:var(--shadow-lg);
}
.hero-deco{
  position:absolute; font-size:2.6rem; filter:drop-shadow(2px 3px 2px rgba(0,0,0,.2));
  animation:float 4s ease-in-out infinite;
}
.hero-deco-1{ top:-22px; left:-18px; }
.hero-deco-2{ bottom:-18px; right:-12px; animation-delay:.8s; }

/* グラスブロックの地面 */
.hero-ground{
  position:relative; z-index:3; height:46px;
  background:
    linear-gradient(var(--grass-top) 0 14px, var(--grass-green) 14px 100%);
  border-top:4px solid var(--grass-green-dark);
  background-size:48px 100%;
  box-shadow:0 4px 10px rgba(0,0,0,.1) inset;
}
.hero-ground::after{
  content:""; position:absolute; left:0; bottom:0; width:100%; height:18px;
  background-image:
    linear-gradient(90deg, transparent 0 46px, rgba(0,0,0,.08) 46px 48px),
    linear-gradient(var(--dirt-brown), var(--dirt-brown));
  background-size:48px 100%, 48px 100%;
}

/* =========================================================
   セクション共通
   ========================================================= */
.section{ padding:5rem 0; position:relative; }
.section-title{ text-align:center; margin-bottom:3rem; }
.title-sub{
  display:block; font-family:var(--font-pixel); font-size:.95rem;
  color:var(--orange); letter-spacing:1px; margin-bottom:.9rem;
}
.title-main{
  display:inline-block; font-size:1.9rem; font-weight:900; color:var(--text);
  position:relative; padding-bottom:.6rem;
}
.title-main::after{
  content:""; position:absolute; left:50%; transform:translateX(-50%); bottom:0;
  width:64px; height:6px; border-radius:6px;
  background:repeating-linear-gradient(90deg,var(--yellow) 0 12px,var(--orange) 12px 24px);
}

/* =========================================================
   ② お悩み
   ========================================================= */
.worries{ background:var(--bg-cream); }
.worry-list{
  display:grid; grid-template-columns:repeat(2,1fr); gap:1.2rem; max-width:880px; margin:0 auto;
}
.worry-card{
  display:flex; align-items:center; gap:1rem;
  background:#fff; border-radius:14px; padding:1.3rem 1.4rem;
  box-shadow:var(--shadow); border-left:6px solid var(--yellow);
}
.worry-icon{
  flex-shrink:0; width:52px; height:52px; border-radius:12px;
  background:var(--yellow-light); color:var(--orange-deep);
  display:flex; align-items:center; justify-content:center; font-size:1.5rem;
}
.worry-card p{ font-size:1rem; font-weight:600; }
.worry-card strong{ color:var(--orange-deep); }

.worry-answer{
  text-align:center; margin-top:2.6rem;
  background:linear-gradient(135deg,var(--grass-green),var(--grass-green-dark));
  color:#fff; padding:2.2rem 1.5rem; border-radius:var(--radius);
  box-shadow:var(--shadow-lg); position:relative;
}
.worry-answer::before{
  content:"▼"; position:absolute; top:-22px; left:50%; transform:translateX(-50%);
  color:var(--grass-green); font-size:1.6rem;
}
.worry-answer-lead{ font-size:1.35rem; font-weight:900; margin-bottom:.6rem; }
.brand-text{ color:var(--yellow); }
.worry-answer p{ font-size:1rem; }

/* =========================================================
   ③ マインクラフト紹介
   ========================================================= */
.minecraft-intro{ background:#fff; }
.mc-intro-box{
  display:flex; gap:2rem; align-items:flex-start;
  background:var(--bg-cream); border-radius:var(--radius);
  padding:2.4rem; box-shadow:var(--shadow);
  border:3px dashed var(--grass-green);
}
.mc-intro-icon{
  flex-shrink:0; width:96px; height:96px; border-radius:16px;
  background:linear-gradient(135deg,var(--grass-top),var(--grass-green));
  color:#fff; font-size:3rem;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 0 var(--grass-green-dark);
}
.mc-intro-text h3{ font-size:1.3rem; color:var(--grass-green-dark); margin-bottom:1rem; line-height:1.5; }
.mc-intro-text p{ margin-bottom:.8rem; font-weight:600; }
.mc-intro-text strong{ color:var(--orange-deep); }

/* =========================================================
   ④ 5つの特徴
   ========================================================= */
.features{ background:var(--bg-cream); }
.feature-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem;
}
.feature-card{
  background:#fff; border-radius:var(--radius); padding:2rem 1.6rem 1.8rem;
  box-shadow:var(--shadow); position:relative; transition:.25s;
  border-bottom:6px solid var(--grass-green);
}
.feature-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.feature-num{
  position:absolute; top:1.1rem; right:1.3rem;
  font-family:var(--font-pixel); font-size:1.1rem; color:var(--yellow-light);
}
.feature-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:64px; height:64px; border-radius:14px;
  background:linear-gradient(135deg,var(--yellow),var(--orange));
  color:#fff; font-size:1.7rem; margin-bottom:1rem;
  box-shadow:0 4px 0 var(--orange-deep);
}
.feature-card h3{ font-size:1.12rem; color:var(--text); margin-bottom:.7rem; line-height:1.5; }
.feature-card p{ font-size:.92rem; color:var(--text-soft); font-weight:500; }
.feature-card strong{ color:var(--orange-deep); }

.feature-card-cta{
  background:linear-gradient(135deg,var(--orange),var(--orange-deep));
  color:#fff; text-align:center; border-bottom-color:var(--yellow);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
}
.feature-card-cta .feature-icon{
  background:#fff; color:var(--orange); box-shadow:0 4px 0 rgba(0,0,0,.15);
}
.feature-card-cta h3{ color:#fff; }
.feature-card-cta p{ color:#fff; opacity:.95; margin-bottom:1.2rem; }
.feature-card-cta .btn{
  background:#fff; color:var(--orange-deep); box-shadow:0 5px 0 rgba(0,0,0,.18);
  padding:.8rem 1.6rem; font-size:1rem;
}

/* =========================================================
   ⑤ カリキュラム
   ========================================================= */
.curriculum{ background:#fff; }
.curriculum-lead{ text-align:center; font-size:1.05rem; font-weight:600; margin-bottom:2.6rem; }
.time-badge{
  display:inline-block; background:var(--grass-green); color:#fff;
  font-weight:800; padding:.4rem 1.2rem; border-radius:999px; font-size:1.05rem;
  margin-bottom:.6rem; box-shadow:0 3px 0 var(--grass-green-dark);
}
.curriculum-lead strong{ color:var(--orange-deep); }

.flow-steps{ display:flex; flex-direction:column; gap:1.4rem; max-width:860px; margin:0 auto; }
.flow-step{
  background:var(--bg-cream); border-radius:var(--radius); padding:1.8rem 2rem;
  box-shadow:var(--shadow); position:relative; border-left:8px solid var(--orange);
}
.flow-step-head{ display:flex; align-items:center; gap:.8rem; margin-bottom:.7rem; }
.flow-no{
  font-family:var(--font-pixel); font-size:.85rem; color:var(--orange);
}
.flow-time{
  background:var(--yellow); color:var(--text); font-weight:800;
  font-size:.85rem; padding:.3rem .9rem; border-radius:999px;
}
.flow-step h3{ font-size:1.2rem; color:var(--grass-green-dark); margin-bottom:.6rem; }
.flow-step h3 i{ color:var(--orange); }
.flow-step p{ font-size:.96rem; font-weight:500; }
.flow-support{
  background:#fff; border-radius:12px; padding:.9rem 1.1rem; margin-top:.8rem;
  border:2px dashed var(--grass-green);
}
.flow-support i{ color:var(--redstone); }
.flow-support strong{ color:var(--grass-green-dark); }

/* =========================================================
   ⑥ 作品例
   ========================================================= */
.works{
  background:linear-gradient(180deg,var(--bg-cream),#FFF3DD);
}
.works-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.work-card{
  background:#fff; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow); transition:.25s; border:4px solid #fff;
}
.work-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.work-img{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.work-img img{ width:100%; height:100%; object-fit:cover; transition:.4s; }
.work-card:hover .work-img img{ transform:scale(1.06); }
.work-level{
  position:absolute; top:12px; left:12px;
  color:#fff; font-weight:800; font-size:.85rem;
  padding:.35rem .9rem; border-radius:6px;
  box-shadow:0 3px 0 rgba(0,0,0,.18);
}
.level-beginner{ background:var(--grass-green); }
.level-intermediate{ background:var(--orange); }
.level-advanced{ background:var(--redstone); }
.work-body{ padding:1.3rem 1.4rem 1.5rem; }
.work-body h3{ font-size:1.12rem; color:var(--text); margin-bottom:.5rem; }
.work-body p{ font-size:.92rem; color:var(--text-soft); }

/* =========================================================
   ⑦ 講師紹介
   ========================================================= */
.instructor{ background:#fff; }
.instructor-box{
  display:grid; grid-template-columns:280px 1fr; gap:2.5rem; align-items:center;
  max-width:960px; margin:0 auto;
  background:var(--bg-cream); border-radius:var(--radius); padding:2.5rem;
  box-shadow:var(--shadow);
}
.instructor-photo{ text-align:center; }
.instructor-photo img{
  width:100%; border-radius:16px; border:5px solid #fff; box-shadow:var(--shadow);
}
.instructor-name{
  display:inline-block; margin-top:1rem; font-size:1.1rem;
  background:var(--grass-green); color:#fff; padding:.4rem 1.4rem; border-radius:999px;
  box-shadow:0 3px 0 var(--grass-green-dark);
}
.instructor-message{ position:relative; }
.message-quote{ font-size:2.4rem; color:var(--yellow); }
.instructor-message p{ margin-bottom:.8rem; font-weight:500; }
.instructor-message strong{ color:var(--orange-deep); }

/* =========================================================
   ⑧ 募集要項
   ========================================================= */
.overview{ background:var(--bg-cream); }
.overview-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:1.8rem; align-items:start; }
.overview-table{
  background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
}
.ov-row{ display:grid; grid-template-columns:130px 1fr; border-bottom:2px solid var(--bg-cream); }
.ov-row:last-child{ border-bottom:none; }
.ov-row dt{
  background:var(--grass-green); color:#fff; font-weight:800; font-size:.92rem;
  padding:1rem .9rem; display:flex; align-items:center; gap:.4em;
}
.ov-row dd{ padding:1rem 1.2rem; font-weight:600; }
.time-note{ display:block; font-size:.85rem; color:var(--orange-deep); font-weight:800; margin-bottom:.5rem; }
.time-slots li{
  display:flex; gap:.8rem; align-items:center; padding:.35rem 0; font-weight:700;
}
.time-slots li span{
  background:var(--yellow); color:var(--text); font-size:.8rem; font-weight:800;
  padding:.15rem .7rem; border-radius:6px;
}

.prepare-box{
  background:#fff; border-radius:var(--radius); padding:1.8rem; box-shadow:var(--shadow);
  border-top:6px solid var(--redstone);
}
.prepare-box h3{ font-size:1.15rem; color:var(--redstone); margin-bottom:1.1rem; }
.prepare-list li{ margin-bottom:1.1rem; padding-left:1.5rem; position:relative; }
.prepare-list li::before{
  content:"\f00c"; font-family:"Font Awesome 6 Free"; font-weight:900;
  position:absolute; left:0; top:.2rem; color:var(--grass-green);
}
.prepare-list strong{ display:block; color:var(--text); margin-bottom:.2rem; }
.prepare-list span{ font-size:.85rem; color:var(--text-soft); }

/* =========================================================
   ⑨ 料金
   ========================================================= */
.price{ background:#fff; }
.price-note-top{ text-align:center; color:var(--text-soft); margin-bottom:1.6rem; font-weight:600; }
.price-cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.price-card{
  background:var(--bg-cream); border-radius:var(--radius); padding:1.8rem 1rem;
  text-align:center; box-shadow:var(--shadow); position:relative;
  border-bottom:6px solid var(--grass-green);
}
.price-card-main{
  background:linear-gradient(135deg,var(--orange),var(--orange-deep));
  color:#fff; border-bottom-color:var(--yellow); transform:scale(1.04);
}
.price-label{
  display:inline-block; background:var(--grass-green); color:#fff;
  font-weight:800; font-size:.9rem; padding:.3rem 1rem; border-radius:999px; margin-bottom:.9rem;
}
.price-card-main .price-label{ background:#fff; color:var(--orange-deep); }
.price-amount{ font-size:2.2rem; font-weight:900; color:var(--orange-deep); line-height:1.1; }
.price-card-main .price-amount{ color:#fff; }
.price-amount span{ font-size:1rem; font-weight:700; }
.price-tax{ display:block; font-size:.78rem; color:var(--text-soft); opacity:.75; margin-top:.35rem; }
.price-card-main .price-tax{ color:rgba(255,255,255,.8); opacity:1; }
.price-badge{
  display:inline-block; margin-top:.8rem; background:var(--yellow); color:var(--text);
  font-size:.78rem; font-weight:800; padding:.25rem .8rem; border-radius:6px;
}
.price-card-main .price-badge{ background:#fff; color:var(--orange-deep); }
.price-foot{ text-align:center; margin-top:1.6rem; font-size:.88rem; color:var(--text-soft); }

/* =========================================================
   ⑩ FAQ
   ========================================================= */
.faq{ background:var(--bg-cream); }
.faq-list{ display:flex; flex-direction:column; gap:1rem; }
.faq-item{
  background:#fff; border-radius:14px; box-shadow:var(--shadow); overflow:hidden;
  border-left:6px solid var(--yellow);
}
.faq-item summary{
  display:flex; align-items:center; gap:.9rem; cursor:pointer; list-style:none;
  padding:1.2rem 3rem 1.2rem 1.4rem; font-weight:800; font-size:1.02rem; position:relative;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
  content:"\f078"; font-family:"Font Awesome 6 Free"; font-weight:900;
  position:absolute; right:1.4rem; color:var(--orange); transition:.3s;
}
.faq-item[open] summary::after{ transform:rotate(180deg); }
.faq-q{
  flex-shrink:0; width:32px; height:32px; border-radius:8px;
  background:var(--orange); color:#fff; font-family:var(--font-pixel); font-size:.8rem;
  display:flex; align-items:center; justify-content:center;
}
.faq-a-wrap{
  display:flex; gap:.9rem; padding:0 1.4rem 1.3rem; align-items:flex-start;
}
.faq-a{
  flex-shrink:0; width:32px; height:32px; border-radius:8px;
  background:var(--grass-green); color:#fff; font-family:var(--font-pixel); font-size:.8rem;
  display:flex; align-items:center; justify-content:center;
}
.faq-a-wrap p{ font-weight:500; }

/* =========================================================
   ⑪ 入会の流れ
   ========================================================= */
.steps{ background:#fff; }
.enroll-steps{ display:flex; align-items:stretch; justify-content:center; gap:.5rem; flex-wrap:wrap; }
.enroll-step{
  flex:1; min-width:230px; max-width:300px;
  background:var(--bg-cream); border-radius:var(--radius); padding:2.2rem 1.5rem 1.8rem;
  text-align:center; box-shadow:var(--shadow); position:relative;
  border-top:6px solid var(--orange);
}
.enroll-num{
  display:inline-flex; align-items:center; justify-content:center;
  width:58px; height:58px; border-radius:50%;
  background:linear-gradient(135deg,var(--orange),var(--orange-deep));
  color:#fff; font-family:var(--font-pixel); font-size:1.2rem;
  margin-bottom:1rem; box-shadow:0 5px 0 rgba(0,0,0,.15);
}
.enroll-step h3{ font-size:1.12rem; color:var(--grass-green-dark); margin-bottom:.7rem; }
.enroll-step p{ font-size:.92rem; color:var(--text-soft); }
.enroll-arrow{ display:flex; align-items:center; color:var(--orange); font-size:1.6rem; }

/* =========================================================
   ⑫ アクセス
   ========================================================= */
.access{ background:var(--bg-cream); }
.access-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.8rem; }
.access-info{ background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.ac-row{ display:grid; grid-template-columns:120px 1fr; border-bottom:2px solid var(--bg-cream); }
.ac-row:last-child{ border-bottom:none; }
.ac-row dt{
  background:var(--grass-green); color:#fff; font-weight:800; font-size:.9rem;
  padding:1rem .8rem; display:flex; align-items:center; gap:.4em;
}
.ac-row dd{ padding:1rem 1.2rem; font-weight:600; font-size:.95rem; }
.ac-row dd a{ color:var(--orange-deep); font-weight:800; }
.ac-row dd small{ color:var(--text-soft); }
.access-map{
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
  min-height:360px; border:4px solid #fff;
}
.access-map iframe{ width:100%; height:100%; min-height:360px; display:block; }

/* =========================================================
   ⑬ CVエリア
   ========================================================= */
.cv{
  background:linear-gradient(135deg,var(--grass-green) 0%, var(--grass-green-dark) 100%);
  color:#fff; text-align:center; position:relative; overflow:hidden;
}
.cv-bg-blocks{
  position:absolute; inset:0; opacity:.13; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.4) 2px, transparent 2px),
    linear-gradient(90deg, rgba(255,255,255,.4) 2px, transparent 2px);
  background-size:44px 44px;
}
.cv .container{ position:relative; z-index:2; }
.cv-title{ font-size:1.9rem; font-weight:900; margin-bottom:1rem; text-shadow:2px 2px 0 rgba(0,0,0,.15); }
.cv-emoji{ display:block; font-size:2.6rem; margin-bottom:.4rem; }
.cv-lead{ font-size:1.05rem; margin-bottom:2rem; font-weight:600; }
.cv-buttons{ display:flex; flex-direction:column; gap:1rem; max-width:540px; margin:0 auto; }
.cv-buttons .btn span{ line-height:1.3; }
.cv-tel{ margin-top:2rem; }
.cv-tel p{ font-size:.92rem; opacity:.9; margin-bottom:.3rem; }
.cv-tel a{ font-size:1.8rem; font-weight:900; color:#fff; text-shadow:1px 1px 0 rgba(0,0,0,.2); }

/* =========================================================
   フッター
   ========================================================= */
.site-footer{
  background:var(--dirt-brown-dark); color:#fff; padding:3rem 0 2rem;
  border-top:6px solid var(--grass-green);
}
.footer-inner{ text-align:center; }
.footer-logo{ display:inline-block; background:#fff; padding:.8rem 1.4rem; border-radius:14px; margin-bottom:1.4rem; }
.footer-logo img{ height:46px; }
.footer-nav{ display:flex; flex-wrap:wrap; justify-content:center; gap:.6rem 1.6rem; margin-bottom:1.4rem; }
.footer-nav a{ font-weight:700; font-size:.92rem; opacity:.92; transition:.2s; }
.footer-nav a:hover{ color:var(--yellow); }
.footer-address{ font-size:.85rem; opacity:.8; margin-bottom:1.2rem; line-height:1.8; }
.footer-copy{ font-size:.8rem; opacity:.7; }

/* =========================================================
   追従ボタン & トップへ戻る
   ========================================================= */
.floating-cta{
  position:fixed; bottom:0; left:0; width:100%; z-index:900;
  display:none; gap:0;
  box-shadow:0 -4px 16px rgba(0,0,0,.18);
}
.float-btn{
  flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:.15rem; padding:.7rem 0; color:#fff; font-weight:800; font-size:.82rem;
}
.float-btn i{ font-size:1.25rem; }
.float-trial{ background:linear-gradient(135deg,var(--orange),var(--orange-deep)); }
.float-line{ background:#06C755; }

.back-to-top{
  position:fixed; right:18px; bottom:24px; z-index:910;
  width:48px; height:48px; border-radius:12px; border:none; cursor:pointer;
  background:var(--grass-green); color:#fff; font-size:1.1rem;
  box-shadow:0 4px 0 var(--grass-green-dark), var(--shadow);
  opacity:0; visibility:hidden; transform:translateY(10px); transition:.3s;
}
.back-to-top.show{ opacity:1; visibility:visible; transform:translateY(0); }
.back-to-top:hover{ transform:translateY(-3px); }

/* =========================================================
   スクロールアニメーション
   ========================================================= */
.fade-init{ opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s ease; }
.fade-in{ opacity:1; transform:translateY(0); }
@media(prefers-reduced-motion:reduce){
  .fade-init{ opacity:1; transform:none; transition:none; }
}

/* =========================================================
   レスポンシブ
   ========================================================= */
@media(max-width:980px){
  .hero-inner{ grid-template-columns:1fr; text-align:center; }
  .hero-buttons{ margin:0 auto; }
  .hero-image{ max-width:480px; margin:0 auto; }
  .feature-grid{ grid-template-columns:repeat(2,1fr); }
  .works-grid{ grid-template-columns:1fr 1fr; }
  .overview-grid,.access-grid{ grid-template-columns:1fr; }
  .price-cards{ grid-template-columns:repeat(2,1fr); }
  .price-card-main{ transform:none; }
  .instructor-box{ grid-template-columns:1fr; text-align:center; }
  .instructor-photo{ max-width:240px; margin:0 auto; }
}

@media(max-width:768px){
  html{ scroll-padding-top:66px; }
  .header-nav{ display:none; }
  .header-cta{ display:none; }
  .nav-toggle{ display:flex; }
  .header-inner{ height:60px; }
  .header-logo img{ height:36px; }
  .mobile-nav.open{ display:flex; }

  .pc-only{ display:none; }
  .sp-only{ display:inline; }

  .hero{ padding-top:90px; }
  .hero-title{ font-size:1.7rem; }
  .hero-sub-title{ font-size:1.05rem; }

  .section{ padding:3.5rem 0; }
  .title-main{ font-size:1.45rem; }
  .title-sub{ font-size:.8rem; }

  .worry-list{ grid-template-columns:1fr; }
  .mc-intro-box{ flex-direction:column; text-align:center; padding:1.8rem 1.3rem; }
  .mc-intro-icon{ margin:0 auto; }

  .feature-grid{ grid-template-columns:1fr; }
  .works-grid{ grid-template-columns:1fr; }
  .flow-step{ padding:1.4rem 1.3rem; }

  .enroll-steps{ flex-direction:column; align-items:center; }
  .enroll-arrow{ transform:rotate(90deg); }
  .enroll-step{ max-width:100%; width:100%; }

  .cv-title{ font-size:1.45rem; }
  .cv-tel a{ font-size:1.5rem; }

  .floating-cta{ display:flex; }
  body{ padding-bottom:58px; }
  .back-to-top{ bottom:72px; }
}

@media(max-width:420px){
  .price-cards{ grid-template-columns:1fr; }
  .hero-title{ font-size:1.5rem; }
}
