@charset "utf-8";
/* =========================================================
   school-renewal.css
   西新校リニューアル構造の共通スタイル（薬院・他校にも展開予定）
   ※ /css/add.css の後（最後）に読み込む＝上書きが効く
   西新の各ページ内<style>から切り出したもの
   ========================================================= */

/* ---- 1. FV：残席バッジ(fv-urgent) ---- */
    .fv-stage{position:relative;line-height:0;}
    .fv-urgent{position:absolute;z-index:5;text-align:center;line-height:1.35;
      background:linear-gradient(135deg,#3ba3dd 0%,#00A5E3 100%);color:#fff;
      border:1px solid #fff;border-radius:12px;box-shadow:0 6px 18px rgba(0,0,0,.35);}
    .fv-urgent .fv-urgent-sub{display:block;font-weight:700;letter-spacing:.04em;}
    .fv-urgent .fv-urgent-main{display:block;font-weight:800;letter-spacing:.02em;}
    .fv-urgent .fv-urgent-main em{font-style:normal;color:#fff;}
    /* PC：右上の青空エリアに配置 */
    .slide-pc .fv-urgent{top:7%;right:3%;padding:14px 26px;}
    .slide-pc .fv-urgent .fv-urgent-sub{font-size:1.6rem;}
    .slide-pc .fv-urgent .fv-urgent-main{font-size:2.5rem;margin-top:3px;}
    /* SP：右上の壁エリアに配置 */
    .slide-sp .fv-urgent{top:3%;right:3%;padding:9px 15px;border-radius:10px;}
    .slide-sp .fv-urgent .fv-urgent-sub{font-size:1.25rem;}
    .slide-sp .fv-urgent .fv-urgent-main{font-size:1.75rem;margin-top:2px;}
  

/* ---- 2. キャンペーン帯(cp-area) ---- */
    .cp-area{background:rgba(0,165,227,0.76);padding:34px 0;position:relative;overflow:hidden;}
    .cp-area::before{content:'';position:absolute;top:-50%;right:-10%;width:500px;height:500px;
      background:rgba(255,255,255,0.1);border-radius:50%;z-index:1;}
    .cp-area::after{content:'';position:absolute;bottom:-30%;left:-10%;width:400px;height:400px;
      background:rgba(255,255,255,0.08);border-radius:50%;z-index:1;}
    .cp-box{background:rgba(255,255,255,0.98);border-radius:24px;padding:40px 40px 12px;max-width:1100px;
      margin:0 auto;box-shadow:0 4px 28px rgba(0,0,0,0.05);position:relative;z-index:2;text-align:center;}
    .cp-label{display:inline-block;background:#00A5E3;color:#fff;padding:11px 30px;border-radius:50px;
      font-weight:700;letter-spacing:0.08em;font-size:2.05rem;box-shadow:0 8px 20px rgba(0,165,227,0.4);
      border:solid 3px #fff;position:absolute;top:-24px;left:15%;transform:translateX(-50%);white-space:nowrap;}
    .cp-title{font-size:2.1rem;font-weight:700;color:#2c3e50;line-height:1.4;margin:0 0 22px;}
    .cp-title strong{color:#163d6b;}
    .cp-list{list-style:none;padding:0;margin:0 0 10px;display:flex;flex-direction:row;gap:16px;align-items:stretch;}
    .cp-list li{flex:1;display:flex;align-items:center;justify-content:center;text-align:center;
      background:#eef7fc;border:1px dashed #bcdff2;border-radius:8px;padding:20px 16px;
      font-size:1.8rem;font-weight:700;color:#333;line-height:1.45;}
    .cp-list li strong{color:#00A5E3;font-size:2.2rem;}
    .cp-list li s{color:#999;font-weight:400;font-size:0.78em;margin-right:4px;}
    .cp-deadline{font-size:1.4rem;color:#555;margin:0;}
    .cp-deadline span{color:#333;font-weight:700;font-size:1.55rem;}
    @media (max-width:767px){
      .cp-area{padding:28px 0;}
      .cp-box{padding:38px 18px 8px;border-radius:20px;}
      .cp-label{padding:9px 20px;font-size:1.2rem;}
      .cp-title{font-size:1.8rem;margin-bottom:18px;}
      .cp-list{flex-direction:column;gap:12px;}
      .cp-list li{font-size:1.8rem;padding:16px 16px;}
      .cp-list li strong{font-size:2.15rem;}
      .cp-deadline{font-size:1.35rem;}
    }
  

/* ---- 3. お悩み解決(solve/answer/.ico) ---- */
    /* アイコン共通（このサイトはFont Awesomeのグリフ未読込のためインラインSVGを使用） */
    .ico{width:1em;height:1em;fill:currentColor;vertical-align:-0.125em;flex:none;}
    /* 導入・CTA */
    .solve-hero{background:#e9f6fc;padding:60px 0;color:#444;}
    .solve-hero .solve-hero-inner{display:flex;align-items:center;gap:40px;flex-wrap:wrap;}
    .solve-hero .solve-hero-text{flex:1 1 440px;min-width:280px;}
    .solve-hero .solve-hero-img{flex:1 1 360px;min-width:280px;}
    .solve-hero .solve-hero-img img{width:100%;height:auto;border-radius:12px;display:block;box-shadow:0 8px 24px rgba(0,0,0,.25);}
    .solve-hero h2{font-size:26px;font-weight:bold;line-height:1.5;margin:0 0 24px;
      padding-left:16px;border-left:6px solid #00A5E3;color:#163d6b;}
    .solve-hero .solve-pains{list-style:none;padding:0;margin:0 0 22px;}
    .solve-hero .solve-pains li{background:#fff;border:1px solid #cfe9f5;
      border-radius:8px;padding:12px 18px;margin-bottom:10px;font-size:17px;font-weight:bold;color:#444;
      box-shadow:0 2px 8px rgba(0,0,0,.05);}
    .solve-hero .solve-lead{font-size:16px;line-height:1.9;margin:0 0 28px;color:#444;}
    .solve-hero .solve-cta{display:inline-flex;align-items:center;gap:12px;background:#E63976;color:#fff;
      font-size:20px;font-weight:bold;text-decoration:none;padding:18px 40px;border-radius:50px;
      box-shadow:0 8px 22px rgba(230,57,118,.4);transition:transform .2s,background .2s;}
    .solve-hero .solve-cta:hover{background:#d12e6a;transform:translateY(-2px);color:#fff;}
    .solve-hero .solve-cta .free{background:#fff;color:#E63976;font-size:14px;border-radius:50px;padding:4px 12px;}

    /* お悩み解決 3カラム */
    .solve-area{background:#fdf3f7;padding:60px 0;}
    .solve-head{text-align:center;margin-bottom:44px;}
    .solve-head h2{display:inline-block;font-size:30px;font-weight:bold;color:#333;
      background:linear-gradient(transparent 60%,#f7c4d8 60%);padding:0 14px;line-height:1.5;margin:0;}
    .solve-grid{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;}
    .solve-card{background:#fff;border-radius:14px;box-shadow:0 4px 18px rgba(230,57,118,.12);
      width:calc(33.333% - 16px);box-sizing:border-box;overflow:hidden;display:flex;flex-direction:column;}
    .solve-card .solve-card-head{background:#00A5E3;color:#fff;font-size:18px;font-weight:bold;
      text-align:center;padding:14px;}
    .solve-card .solve-card-img img{width:100%;height:175px;object-fit:cover;display:block;}
    .solve-card .solve-card-body{padding:24px 22px;display:flex;flex-direction:column;flex:1;}
    .solve-worry{font-size:15px;font-weight:bold;color:#163d6b;line-height:1.6;margin:0 0 18px;
      padding-bottom:16px;border-bottom:1px dashed #f3c0d3;}
    .solve-worry .solve-ic{color:#163d6b;margin-right:6px;}
    .solve-answer-tag{display:inline-block;background:#fff;color:#d61f26;font-size:13px;font-weight:bold;
      border:1px solid #d61f26;border-radius:4px;padding:3px 12px;margin-bottom:10px;}
    .solve-answer-title{font-size:16px;font-weight:bold;color:#d61f26;line-height:1.6;margin:0 0 10px;}
    .solve-answer-text{font-size:14px;line-height:1.85;color:#444;margin:0 0 18px;}
    .solve-schools{margin-top:auto;background:#f7fafc;border-radius:8px;padding:14px 16px;}
    .solve-schools .solve-schools-label{display:block;font-size:13px;font-weight:bold;color:#00A5E3;margin-bottom:6px;}
    .solve-schools p{font-size:13px;line-height:1.7;color:#333;font-weight:bold;margin:0;}

    /* ミッション */
    .mission-band{background:#fff;padding:60px 0;}
    .mission-inner{max-width:900px;margin:0 auto;text-align:center;}
    .mission-title{font-size:28px;font-weight:bold;color:#163d6b;line-height:1.6;margin:0 0 36px;}
    .mission-title .mission-ic{color:#E63976;margin-right:8px;}
    .mission-road{display:flex;align-items:stretch;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:36px;}
    .mission-node{flex:1 1 150px;max-width:190px;background:#fdf3f7;border-radius:60px;padding:18px 12px;text-align:center;}
    .mission-node img{width:80px;height:80px;margin:0 auto 10px;display:block;}
    .mission-node span{display:block;font-size:14px;font-weight:bold;color:#333;}
    .mission-arrow{display:flex;align-items:center;color:#00A5E3;font-size:22px;}
    .mission-text{font-size:16px;line-height:1.95;color:#444;text-align:left;}
    .mission-text strong{color:#E63976;}

    @media (max-width:991px){
      .solve-card{width:calc(50% - 12px);}
    }
    @media (max-width:767px){
      .solve-hero{padding:40px 0;}
      .solve-hero h2{font-size:21px;}
      .solve-hero .solve-pains li{font-size:15px;}
      .solve-hero .solve-cta{font-size:17px;padding:16px 26px;}
      .solve-area{padding:40px 0;}
      .solve-head h2{font-size:22px;padding:0 8px;}
      .solve-head{margin-bottom:32px;}
      .solve-grid{gap:18px;}
      .solve-card{width:100%;}
      .mission-band{padding:40px 0;}
      .mission-title{font-size:19px;}
      .mission-arrow{transform:rotate(90deg);}
      .mission-road{gap:10px;}
      .mission-node{flex:0 0 calc(50% - 5px);max-width:none;padding:14px 8px;border-radius:16px;}
      .mission-node img{width:48px;height:48px;margin-bottom:6px;}
      .mission-node span{font-size:12px;}
    }
  

/* ---- 4. 教室紹介(classroom-area) ---- */
    .classroom-area{background:#fff;padding:60px 0;}
    .classroom-area .classroom-head{text-align:center;margin-bottom:48px;}
    .classroom-area .classroom-head h2{display:inline-block;font-size:30px;font-weight:bold;color:#333;
      background:linear-gradient(transparent 60%,#f7c4d8 60%);padding:0 14px;line-height:1.5;margin:0;}
    .classroom-grid{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;}
    .classroom-grid figure{margin:0;width:calc(33.333% - 16px);box-sizing:border-box;}
    .classroom-grid figure img{width:100%;height:260px;object-fit:cover;border-radius:12px;display:block;
      box-shadow:0 4px 18px rgba(230,57,118,.12);transition:transform .3s ease,box-shadow .3s ease;}
    .classroom-grid figure img:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(230,57,118,.22);}
    @media (max-width:991px){
      .classroom-grid figure{width:calc(50% - 12px);}
    }
    @media (max-width:767px){
      .classroom-area{padding:40px 0;}
      .classroom-area .classroom-head{margin-bottom:32px;}
      .classroom-area .classroom-head h2{font-size:22px;padding:0 8px;}
      .classroom-grid{gap:16px;}
      .classroom-grid figure{width:calc(50% - 8px);}
      .classroom-grid figure img{height:160px;}
    }
  

/* ---- 5. 実績エリア(pv-area) ---- */
    .pv-area{background:#eef4f8;padding:60px 0;}
    .pv-panel{position:relative;overflow:hidden;background:linear-gradient(135deg,#3ba3dd 0%,#00A5E3 100%);
      border-radius:24px;padding:46px 40px;box-shadow:0 10px 30px rgba(43,143,206,.25);}
    .pv-watermark{position:absolute;top:50%;right:-10px;transform:translateY(-50%);
      font-size:120px;font-weight:800;letter-spacing:.08em;color:rgba(255,255,255,.12);
      line-height:1;writing-mode:vertical-rl;pointer-events:none;}
    .pv-head{text-align:center;color:#fff;margin-bottom:34px;position:relative;z-index:2;}
    .pv-head h2{font-size:30px;font-weight:bold;line-height:1.5;margin:0;color:#fff;}
    .pv-head .pv-en{font-size:14px;letter-spacing:.2em;font-weight:bold;margin:8px 0 0;opacity:.85;}
    .pv-grid{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;position:relative;z-index:2;}
    .pv-card{background:#fff;border-radius:16px;padding:30px 26px 26px;width:calc(33.333% - 16px);
      box-sizing:border-box;box-shadow:0 6px 20px rgba(0,0,0,.12);display:flex;flex-direction:column;}
    .pv-avatar{text-align:center;margin-bottom:14px;}
    .pv-avatar img{width:108px;height:108px;border-radius:50%;background:#eef4f8;display:inline-block;}
    .pv-lead{font-size:18px;font-weight:bold;color:#00A5E3;text-align:center;line-height:1.5;margin:0 0 14px;}
    .pv-text{font-size:14px;line-height:1.9;color:#444;margin:0 0 18px;}
    .pv-text .bold{font-weight:bold;color:#163d6b;}
    .pv-prof{margin:auto 0 0;text-align:right;font-size:13px;font-weight:bold;color:#00A5E3;}
    @media (max-width:991px){
      .pv-card{width:calc(50% - 12px);}
    }
    @media (max-width:767px){
      .pv-area{padding:40px 0;}
      .pv-panel{padding:34px 18px;border-radius:18px;}
      .pv-watermark{font-size:80px;}
      .pv-head h2{font-size:22px;}
      .pv-grid{gap:18px;}
      .pv-card{width:100%;}
    }
  

/* ---- 6. 体験レッスン誘導(tp-features) ---- */
    .tp-features{background:#fff;padding:8px 0 40px;}
    .tp-features .tp-inner{max-width:1080px;margin:0 auto;padding:0 16px;}
    .tp-features-head{position:relative;max-width:740px;margin:0 auto 30px;background:#00A5E3;color:#fff;border-radius:18px;text-align:center;padding:11px 10px;}
    .tp-features-head::after{content:"";position:absolute;left:50%;bottom:-15px;transform:translateX(-50%);border-left:16px solid transparent;border-right:16px solid transparent;border-top:16px solid #00A5E3;}
    .tp-features-head h2{margin:0;font-size:2.6rem;font-weight:700;line-height:1.45;color:#fff;}
    .tp-features-lead{text-align:center;color:#3a3a3a;font-size:1.05rem;margin:0 0 28px;line-height:1.8;}
    .tp-sp-br{display:none;}
    @media(max-width:560px){.tp-sp-br{display:inline;}}
    .tp-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
    .tp-fcard{background:#FEFAEE;border:1.5px solid #F5CB53;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;}
    .tp-fcard>img{width:100%;object-fit:contain;background:#fff;display:block;}
    .tp-fcard-body-wrap{padding:18px 20px 22px;}
    .tp-fcard-num{margin:0 0 10px;font-size:1.5rem;font-weight:800;color:#00A5E3;line-height:1.2;display:flex;align-items:center;gap:10px;}
    .tp-fcard-num span{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:1.8em;height:1.8em;border-radius:50%;background:#00A5E3;color:#fff;font-weight:900;font-size:1.1rem;}
    .tp-fcard-lead{margin:0 0 8px;font-size:1.07rem;font-weight:700;color:#3a3a3a;line-height:1.45;}
    .tp-fcard-text{margin:0;font-size:0.92rem;color:#4a4a4a;line-height:1.75;}
    .tp-fcard-text b{font-weight:700;color:#3a3a3a;}
    @media(max-width:760px){.tp-features-grid{grid-template-columns:1fr;}.tp-features-head h2{font-size:1.3rem;}.tp-features-lead{font-size:0.9rem;}}
    /* CTAボタンを他と同じピンクに揃える */
    .adlp-btn.line-btn.cv_area_2{background-color:#e63976 !important;}
    .adlp-btn.--free.line-btn.cv_area_2::before{color:#e63976 !important;}
    /* スマホ固定フッターCTA「無料体験レッスン」もキャタルピンクに */
    @media (max-width:767px){.fix-cta-xs.fix-cta-pill a.fix-cta1{background:#e63976 !important;}}
  

/* ---- 7. 料金(fee-note / price-block--join) ---- */
        .fee-note{font-size:12px !important;color:#848484;line-height:1.5;margin-top:2px !important;margin-bottom:12px !important;height:auto !important;}
        .price-block--join{display:flex;align-items:center;justify-content:center;gap:10px 28px;flex-wrap:wrap;padding:6px 10px;}
        .price-block--join h4{border-bottom:none !important;padding:10px 15px !important;}
        .price-block--join p.fee{margin:0 !important;padding:10px 15px !important;}
      

/* ---- 8. 振替案内(furikae) ---- */
    .furikae-area{padding:0 0 44px;margin-top:-80px;}
    .furikae-box{background:#FEFAEE;border:1.5px solid #F5CB53;border-radius:12px;padding:26px 30px;}
    .furikae-lead{font-size:18px;font-weight:700;color:#3a3a3a;margin:0 0 14px;line-height:1.5;}
    .furikae-list{margin:0 0 14px;padding:0;}
    .furikae-list li{position:relative;padding-left:26px;margin-bottom:8px;color:#4a4a4a;font-size:15px;line-height:1.7;list-style:none;}
    .furikae-list li::before{content:"✓";position:absolute;left:0;top:0;color:#d99400;font-weight:800;}
    .furikae-list strong{color:#d9820a;}
    .furikae-note{font-size:14px;color:#6a6a6a;line-height:1.85;margin:0;}
    @media(max-width:560px){.furikae-box{padding:20px 18px;}.furikae-lead{font-size:16px;}}
  

/* ---- 9. 新CTAフロー(cflow) ---- */
.cflow{background:#19a6df;padding:32px 0 34px;}
.cflow *{box-sizing:border-box;}
.cflow .cflow-inner{max-width:960px;margin:0 auto;padding:0 16px;}
.cflow-title{display:flex;align-items:center;justify-content:center;gap:14px;color:#fff;font-weight:700;font-size:30px;line-height:1.3;margin:0 0 16px;text-align:center;font-family:"dnp-shuei-mgothic-std","Noto Sans JP","Hiragino Sans","Hiragino Kaku Gothic ProN",sans-serif;}
.cflow-title::before,.cflow-title::after{content:"";flex:0 0 40px;height:2px;background:#fff;opacity:.9;}
.cflow-title .num{font-size:48px;line-height:1;margin:0 2px;}
.cflow-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;align-items:start;margin-bottom:18px;}
.cflow-steps img{width:100%;height:auto;display:block;}
.cflow-note{background:#fff;border-radius:8px;color:#1487c4;font-weight:700;font-size:19px;text-align:center;padding:12px 16px;line-height:1.45;margin:0 auto 22px;font-family:"dnp-shuei-mgothic-std","Noto Sans JP","Hiragino Sans","Hiragino Kaku Gothic ProN",sans-serif;}
.cflow-btnwrap{text-align:center;}
.cflow-btn{display:inline-flex;align-items:center;justify-content:center;gap:14px;background:#E63976;color:#fff;font-weight:600;font-size:26px;border-radius:999px;text-decoration:none;padding:18px 50px;max-width:640px;width:100%;font-family:"dnp-shuei-mgothic-std","Noto Sans JP","Hiragino Sans","Hiragino Kaku Gothic ProN",sans-serif;transition:background .2s;}
.cflow-btn:hover{background:#d12e6a;color:#fff;}
.cflow-btn .cflow-free{background:#fff;color:#E63976;font-weight:700;font-size:19px;padding:6px 16px;border-radius:999px;}
@media (max-width:767px){
  .cflow{padding:20px 0 22px;}
  .cflow-title{display:block;font-size:20px;margin-bottom:12px;}
  .cflow-title::before,.cflow-title::after{display:none;}
  .cflow-title .num{font-size:28px;vertical-align:-3px;}
  .cflow-steps{grid-template-columns:1fr;max-width:300px;margin:0 auto 12px;gap:0;}
  .cflow-steps img{margin-bottom:-7%;}
  .cflow-steps img:nth-child(2){margin-top:-13%;}
  .cflow-steps img:nth-child(3){margin-top:-10%;}
  .cflow-note{font-size:16px;padding:11px 14px;margin-bottom:14px;}
  .cflow-btn{font-size:18px;padding:14px 22px;gap:10px;}
  .cflow-btn .cflow-free{font-size:14px;padding:5px 12px;}
}


/* ---- 10. 校長メッセージ：背景を常に白に（nth-of-typeのパリティ差異対策・薬院対応） ---- */
.school_lp__section{background:#fff;}

/* ---- 11. PCのみ改行（スマホでは改行しない） ---- */
@media (max-width:767px){ .pc-br{display:none;} }

/* ---- 12. 生徒の成長実績例/教師紹介：2枚時もデスクトップで中央寄せ ---- */
.sec-result .row.justify-content-center{display:flex;flex-wrap:wrap;justify-content:center;}
