/* juku-with WF 共通CSS（ワイヤーフレーム／青系・レスポンシブ） */
:root{
  --blue:#1a5fb4; --blue-d:#13427e; --blue-l:#eaf2fb;
  --ink:#333; --g:#e4e4e4; --line:#ccc; --muted:#8a8a8a;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:"Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;color:var(--ink);line-height:1.7;background:#fff}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.container{width:92%;max-width:1080px;margin:0 auto}

/* WFプレースホルダ（画像枠） */
.ph{background:var(--g);border:1px dashed var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.82rem;text-align:center;padding:8px}

/* WF注記バー */
.wfbar{background:#fff3cd;border-bottom:1px solid #e0c97f;color:#7a5c00;font-size:.78rem;text-align:center;padding:5px}

/* ヘッダー */
.header{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--line);z-index:100}
.header__inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.logo{font-weight:800;color:var(--blue-d);font-size:1.15rem}
.gnav{display:none;gap:4px}
.gnav a{padding:6px 10px;font-size:.88rem}
.gnav a:hover{color:var(--blue)}
.header__right{display:flex;gap:10px;align-items:center}
.tel{font-weight:700;color:var(--blue-d);font-size:.82rem;line-height:1.2;text-align:right}
.tel small{display:block;font-weight:400;color:var(--muted);font-size:.7rem}
.hamburger{font-size:1.6rem;color:var(--blue-d);background:none;border:none;cursor:pointer}

.btn{display:inline-block;background:var(--blue);color:#fff;padding:9px 18px;border-radius:6px;font-weight:700;font-size:.85rem;text-align:center}
.btn--lg{padding:15px 32px;font-size:1.05rem}
.btn--ghost{background:#fff;color:var(--blue);border:2px solid var(--blue)}

/* セクション共通 */
section{padding:46px 0}
.sec-head{text-align:center;margin-bottom:28px}
.sec-head .en{display:block;color:var(--blue);font-size:.78rem;letter-spacing:.12em;font-weight:700;margin-bottom:4px}
.sec-head h2{font-size:1.45rem;color:var(--blue-d)}
.lead{text-align:center;color:#555;margin-bottom:24px}

/* FV */
.fv{background:var(--blue-l)}
.fv__ph{height:58vw;max-height:460px}
.fv__copy{text-align:center;padding:26px 0}
.fv__copy h1{font-size:1.5rem;color:var(--blue-d);margin-bottom:14px;line-height:1.4}
.fv__copy .sub{color:#555;margin-bottom:18px}
.fv__cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* グリッド/カード */
.grid{display:grid;gap:16px}
.cols-3{grid-template-columns:1fr}
.card{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff}
.card__ph{height:130px}
.card__body{padding:14px}
.card__body h3{color:var(--blue-d);font-size:1.05rem;margin-bottom:6px}
.card__body p{font-size:.9rem;color:#555}

/* 悩み */
.worry{background:var(--blue-l)}
.worry ul{display:grid;gap:12px}
.worry li{background:#fff;border-radius:8px;padding:14px 18px;border-left:4px solid var(--blue)}

/* 選ばれる理由 */
.reason__item{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--line)}
.reason__num{flex-shrink:0;width:46px;height:46px;background:var(--blue);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem}
.reason__txt h3{color:var(--blue-d);margin-bottom:4px}

/* 実績/宣言バンド */
.promise{background:var(--blue);color:#fff;text-align:center}
.promise h2{color:#fff;font-size:1.6rem}
.promise .big{font-size:2.4rem;font-weight:900;display:block;margin:8px 0}

/* バナー枠 */
.banner .ph{height:42vw;max-height:300px}

/* 投稿リスト */
.posts{display:grid;gap:14px}
.post{display:flex;gap:14px;border-bottom:1px solid var(--line);padding-bottom:14px}
.post__ph{flex-shrink:0;width:120px;height:64px}
.post__meta{font-size:.78rem;color:var(--muted)}

/* CTAバンド */
.cta-band{background:var(--blue-d);color:#fff;text-align:center}
.cta-band h2{color:#fff;margin-bottom:8px}
.cta-band p{margin-bottom:16px}
.cta-band .btn{background:#fff;color:var(--blue-d);margin:6px}

/* フッター */
.footer{background:#222;color:#ccc;padding:30px 0;font-size:.84rem}
.footer__cols{display:grid;gap:18px}
.footer a:hover{color:#fff}
.footer .copy{margin-top:18px;border-top:1px solid #444;padding-top:14px;font-size:.75rem;color:#999}

/* レスポンシブ */
@media(min-width:768px){
  .gnav{display:flex}
  .hamburger{display:none}
  .cols-3{grid-template-columns:repeat(3,1fr)}
  .worry ul{grid-template-columns:repeat(2,1fr)}
  .fv__copy h1{font-size:2.3rem}
  .sec-head h2{font-size:1.9rem}
  .footer__cols{grid-template-columns:2fr 1fr 1fr}
}
@media(min-width:980px){
  .cols-5{grid-template-columns:repeat(5,1fr)}
}

/* ===== 「見てわかる」用パーツ ===== */
section{padding:56px 0}
.icon-circle{width:64px;height:64px;border-radius:50%;background:var(--blue-l);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 12px}
/* アイコン3カード（特長・悩み） */
.feature-grid{display:grid;gap:18px;grid-template-columns:1fr}
.feature-card{text-align:center;padding:24px 18px;border:1px solid var(--line);border-radius:14px;background:#fff}
.feature-card h3{color:var(--blue-d);margin:4px 0 6px}
.feature-card p{font-size:.9rem;color:#555}
/* ステップ（入塾の流れ・無料体験の流れ） */
.steps{display:grid;gap:12px}
.step{display:flex;gap:14px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px 16px}
.step__no{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800}
.step h3{color:var(--blue-d);font-size:1rem}
/* 数字（実績の視覚化） */
.stat-row{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;text-align:center}
.stat__num{font-size:2.6rem;font-weight:900;color:var(--blue);line-height:1}
.stat__num small{font-size:1rem}
.stat__label{font-size:.85rem;color:#555;margin-top:4px}
/* 成績保証ボックス */
.guarantee{background:#fff;border:3px solid var(--blue);border-radius:18px;padding:30px 24px;text-align:center;max-width:700px;margin:0 auto}
.guarantee .ttl{display:inline-block;background:var(--blue);color:#fff;font-weight:800;padding:5px 18px;border-radius:999px;font-size:.9rem;margin-bottom:12px}
.guarantee .big{font-size:2.2rem;font-weight:900;color:var(--blue-d);line-height:1.3}
.guarantee .big em{color:var(--blue);font-style:normal}
/* 料金カード */
.price-card{border:1px solid var(--line);border-radius:14px;overflow:hidden;max-width:520px;margin:0 auto}
.price-card__head{background:var(--blue);color:#fff;padding:12px;text-align:center;font-weight:700}
.price-card__body{padding:24px;text-align:center}
.price__amount{font-size:2.2rem;font-weight:900;color:var(--blue-d)}
.price__amount small{font-size:1rem;color:#555;font-weight:400}
.price__note{font-size:.85rem;color:#555;margin-top:8px}
.badge{display:inline-block;background:#e8f5ec;color:#1a8f4a;border:1px solid #a9d9be;border-radius:999px;padding:3px 12px;font-size:.8rem;font-weight:700;margin:4px}
/* 声・口コミ */
.voice-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px}
.voice-card__head{display:flex;gap:10px;align-items:center;margin-bottom:8px}
.voice-card__avatar{width:44px;height:44px;border-radius:50%;background:var(--g);flex-shrink:0}
.voice-card__name{font-size:.82rem;color:var(--muted)}
.voice-card p{font-size:.9rem}
.stars{color:#f5a623;font-size:.9rem}
/* 講師紹介 */
.teacher-card{text-align:center;border:1px solid var(--line);border-radius:12px;padding:18px;background:#fff}
.teacher-card__photo{width:96px;height:96px;border-radius:50%;margin:0 auto 10px}
/* FAQ */
.faq__item{margin-bottom:10px}
.faq__q{background:var(--blue-l);padding:13px 16px;border-radius:8px;font-weight:700;color:var(--blue-d);position:relative}
.faq__q::before{content:"Q ";color:var(--blue)}
.faq__a{padding:10px 16px;color:#555;font-size:.92rem}
.faq__a::before{content:"A ";color:var(--blue);font-weight:700}
/* 安心バー */
.assure{background:#e8f5ec;border:1px solid #a9d9be;border-radius:10px;padding:14px 18px;text-align:center;color:#1a8f4a;font-weight:700}
/* パンくず・下層見出し */
.page-hero{background:var(--blue-l);padding:30px 0;text-align:center}
.page-hero h1{color:var(--blue-d);font-size:1.6rem}
.breadcrumb{font-size:.78rem;color:var(--muted);padding:8px 0}
@media(min-width:768px){
  .feature-grid{grid-template-columns:repeat(3,1fr)}
  .feature-grid.cols2{grid-template-columns:repeat(2,1fr)}
}
