@charset "UTF-8";
html {
  scroll-behavior: smooth;
  overflow-x: hidden; }

#plus2025 {
  /* パソコンで見たときは"pc"のclassがついた画像が表示される */
  /* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
  /*===========
  セッティング
  =========*/
  background-color: #f9f9f9;
  color: #2e2624;
  font-family: 'Noto Sans JP', sans-serif;
  line-height: 1.9;
  letter-spacing: 0.05em;
  /*-----------breadcrumbs-----------*/
  /*画像リンク*/
  /*======
  CVボタン
  ======*/
  /*小ボタン*/
  /*popup*/
  /*======================
      Index
  ========================*/
  /*======
  inexpensive
  ======*/
  /*Page*/
  /*======
  Footer
  ======*/
  /*Fotter*/ }
  #plus2025 .pc {
    display: block !important; }
  #plus2025 .sp {
    display: none !important; }
  @media only screen and (max-width: 750px) {
    #plus2025 .pc {
      display: none !important; }
    #plus2025 .sp {
      display: block !important; } }
  #plus2025 a {
    color: #1d3b63; }
  #plus2025 h1, #plus2025 h2, #plus2025 h3, #plus2025 h4, #plus2025 h5, #plus2025 h6 {
    /* 見出しの行間と字間を調整 */
    line-height: 1.5;
    letter-spacing: 0.02em;
    color: #2e2624;
    /* 見出しも同じ色に */
    margin-top: 0;
    margin-bottom: 0; }
  #plus2025 h2 {
    background-color: transparent;
    border: none;
    padding: 0;
    border-radius: 0;
    margin-top: 0;
    margin-bottom: 0;
    color: #2e2624;
    font-weight: 600;
    font-size: 1.8rem;
    padding: 8px 0;
    text-align: center;
    position: relative;
    width: 100%; }
    #plus2025 h2 span {
      color: #787677;
      font-size: 16px;
      font-weight: 400;
      display: inline-block;
      transform: skewX(-20deg); }
  #plus2025 h2::after {
    content: "";
    display: block;
    width: 20%;
    height: 3px;
    background-color: #2e2624;
    margin: 0 auto;
    margin-top: 8px; }
  @media (min-width: 200px) and (max-width: 770px) {
    #plus2025 h2 {
      font-size: 1.5rem; } }
  #plus2025 h3 {
    font-size: 1.4rem; }
  @media (min-width: 200px) and (max-width: 770px) {
    #plus2025 h3 {
      font-size: 1.2rem; } }
  #plus2025 .subtext {
    font-size: 14px;
    color: #5A5A5A; }
  #plus2025 .breadcrumbs {
    background: #e6e6e6;
    font-size: 12px; }
  #plus2025 .image-link {
    position: relative;
    display: block;
    overflow: hidden;
    /*画像リンク*/ }
    #plus2025 .image-link::after {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: #ffffff;
      opacity: 0;
      transition: opacity 0.3s ease;
      z-index: 2; }
    #plus2025 .image-link:hover::after {
      opacity: 0.5; }
    #plus2025 .image-link img {
      display: block;
      width: 100%;
      height: auto; }
  #plus2025 .btn,
  #plus2025 a.btn,
  #plus2025 button.btn {
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.5;
    position: relative;
    display: inline-block;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    text-align: center;
    vertical-align: middle;
    text-decoration: none;
    letter-spacing: 0.1em;
    color: #212529;
    border-radius: 0.1rem; }
  #plus2025 a.btn--KCV {
    color: #fff;
    padding: 0.8rem 2rem;
    background-color: #cf243b;
    border-bottom: 5px solid #bd001d; }
  #plus2025 a.btn--KCV2 {
    color: #fff;
    max-width: 600px;
    width: 100%;
    padding: 1rem 0;
    background-color: #cf243b;
    border-bottom: 5px solid #bd001d; }
  #plus2025 a.btn--LINE {
    color: #fff;
    max-width: 600px;
    width: 100%;
    padding: 1rem 0;
    background-color: #06c655;
    border-bottom: 5px solid #069f55; }
  #plus2025 a.btn--KCV:hover {
    margin-top: 3px;
    color: #fff;
    background: #e07382;
    border-bottom: 2px solid #bd001d; }
  #plus2025 a.btn--KCV2:hover {
    margin-top: 3px;
    color: #fff;
    background: #e07382;
    border-bottom: 2px solid #bd001d; }
  #plus2025 a.btn--LINE:hover {
    margin-top: 3px;
    color: #fff;
    background: #8fe5b2;
    border-bottom: 2px solid #069f55; }
  #plus2025 a.btn--shadow {
    -webkit-box-shadow: 0 3px 5px rgba(0, 0, 0, 0.3);
    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.3); }
  #plus2025 .pop {
    margin-bottom: -15px;
    position: relative;
    z-index: 1; }
    #plus2025 .pop span {
      background: #FFFFFF;
      border: 1px solid #bd001d;
      padding: 5px 55px;
      border-radius: 30px;
      color: #bd001d;
      font-weight: bold; }
  #plus2025 .pop_LINE {
    margin-bottom: -15px;
    position: relative;
    z-index: 1; }
    #plus2025 .pop_LINE span {
      background: #FFFFFF;
      border: 1px solid #06c655;
      padding: 5px 55px;
      border-radius: 30px;
      color: #06c655;
      font-weight: bold; }
  #plus2025 .fa-position-right {
    position: absolute;
    top: calc(50% - .5em);
    right: 1rem; }
  #plus2025 .fa-line {
    font-size: 2rem; }
  #plus2025 .btn_BLine {
    font-size: 0.8rem;
    font-weight: 400;
    line-height: 1.2;
    position: relative;
    display: inline-block;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    text-align: center;
    vertical-align: middle;
    text-decoration: none;
    letter-spacing: 0.1em;
    color: #2b2b2b;
    border-radius: 0.1rem;
    border: 1px solid #2b2b2b; }
  #plus2025 .btn_BLine {
    max-width: 400px;
    width: 100%;
    padding: 15px 0;
    background-color: #FFFFFF; }
  #plus2025 .btn_BLine:hover {
    color: #fff;
    background: #2b2b2b; }
  #plus2025 .btn_pop01 {
    font-size: 0.8rem;
    font-weight: 400;
    line-height: 1.2;
    position: relative;
    display: inline-block;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    text-align: center;
    vertical-align: middle;
    text-decoration: none;
    letter-spacing: 0.1em;
    color: #FFFFFF;
    border-radius: 0.1rem;
    border: 1px solid #2b2b2b;
    width: 100%;
    padding: 15px 0;
    background-color: #333333; }
  #plus2025 .btn_pop01:hover {
    color: #333333;
    background: #ffffff; }
  #plus2025 .btn_pop02 {
    font-size: 0.8rem;
    font-weight: 400;
    line-height: 1.2;
    position: relative;
    display: inline-block;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    text-align: center;
    vertical-align: middle;
    text-decoration: none;
    letter-spacing: 0.1em;
    color: #000000;
    border-radius: 0.1rem;
    border: 1px solid #2b2b2b;
    width: 100%;
    padding: 15px 0;
    background-color: #e6e6e6; }
  #plus2025 .btn_pop02:hover {
    color: #FFFFFF;
    background: #2b2b2b; }
  #plus2025 #FV {
    background: url("/public/assets/images/plus/top2025/main_bg.jpg");
    background-size: cover; }
  #plus2025 #CVArea {
    background: #ededed;
    padding: 2rem 0; }
  #plus2025 #bg_report {
    /* 方眼紙模様に必須のスタイル */
    background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px)), linear-gradient(90deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px));
    background-size: 16px 16px;
    background-repeat: repeat;
    background-position: center center; }
  #plus2025 #AboutArea {
    background: url("/public/assets/images/plus/top2025/main_bg.jpg");
    padding: 1.5rem 0; }
    #plus2025 #AboutArea .message {
      font-family: "Shippori Mincho", serif;
      font-weight: 500;
      font-style: normal; }
      #plus2025 #AboutArea .message span {
        font-weight: 800;
        font-size: 18px; }
  #plus2025 #ProgramArea {
    margin-top: 40px; }
    #plus2025 #ProgramArea .subtext {
      font-size: 12px;
      color: #5A5A5A; }
  #plus2025 #Nenkan {
    background: url("/public/assets/images/plus/top2025/001.png") no-repeat;
    width: 100%;
    background-size: cover;
    padding: 30px 5px 20px 5px; }
    #plus2025 #Nenkan .BigTEXT {
      text-align: center;
      font-size: 2rem;
      font-weight: 700;
      color: #FFFFFF; }
      #plus2025 #Nenkan .BigTEXT span {
        font-size: 3.3rem; }
    @media (min-width: 200px) and (max-width: 770px) {
      #plus2025 #Nenkan .BigTEXT {
        font-size: 1.6rem;
        line-height: 2.5rem; }
        #plus2025 #Nenkan .BigTEXT span {
          font-size: 2.2rem; } }
  #plus2025 #PassRate {
    margin-top: 40px; }
    #plus2025 #PassRate table.Rate {
      max-width: 700px;
      margin: 0 auto; }
    #plus2025 #PassRate table {
      border-collapse: collapse;
      width: 100%;
      font-size: 13px; }
    #plus2025 #PassRate .tb01 th,
    #plus2025 #PassRate .tb01 td {
      padding: 5px;
      border: solid 1px #ccc;
      text-align: center;
      box-sizing: border-box; }
    #plus2025 #PassRate .tb01 th {
      background: #e6e6e6;
      /*  color: #fff;*/ }
    @media screen and (max-width: 640px) {
      #plus2025 #PassRate .tb01 .head {
        display: none; }
      #plus2025 #PassRate .tb01 {
        width: 100%; }
      #plus2025 #PassRate .tb01 td,
      #plus2025 #PassRate .tb01 th {
        display: block;
        width: 100%;
        border-bottom: none; }
      #plus2025 #PassRate .tb01 td {
        padding: 0px 12px 0 0;
        display: block;
        width: 100%;
        line-height: 2.5;
        text-align: left; }
      #plus2025 #PassRate .tb01 td:before {
        content: attr(data-label);
        font-weight: bold;
        padding: 0px 10px;
        display: inline;
        background-color: #d4d4d4;
        margin-right: 10px;
        float: left; }
      #plus2025 #PassRate .tb01 tr:last-child {
        border-bottom: solid 1px #ccc; } }
  #plus2025 #SupportStep {
    margin-top: 50px; }
    #plus2025 #SupportStep .fa-angle-double-right {
      color: #909090;
      font-size: 2rem; }
    #plus2025 #SupportStep .step-arrow {
      /* 絶対配置を設定 */
      position: absolute;
      /* 親要素の右端に配置 */
      right: -15px;
      /* または 0px に設定し、paddingなどで調整 */
      /* 上下中央に配置する */
      top: 50%;
      /* 自身の高さの半分だけ上にずらして、完全な中央に配置 */
      transform: translateY(-50%);
      /* 矢印を大きくしたり、色を変えたりするならここに追加 */
      font-size: 1.5rem;
      /* 例 */
      color: #333;
      /* 例 */ }
  #plus2025 #index_Counseling_Area {
    background-image: url("/public/assets/images/plus/top2025/cvbg001.jpg");
    background-size: cover;
    background-repeat: none;
    background-position: center;
    padding: 20px 0;
    /*		margin-top: 30px;*/ }
    #plus2025 #index_Counseling_Area p.cv {
      font-size: 40px;
      text-align: center;
      color: #171717;
      font-weight: 800;
      margin-bottom: 0;
      line-height: 1em;
      margin-bottom: 20px; }
    #plus2025 #index_Counseling_Area p.grd {
      background: linear-gradient(45deg, #030c1c 1%, #c7cad6 100%);
      /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      font-size: 30px;
      font-weight: 800; }
    #plus2025 #index_Counseling_Area span.sub {
      color: #ACB6E5;
      background-image: linear-gradient(90deg, #c2c2c2, #6f6f6f);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      font-size: 20px; }
    #plus2025 #index_Counseling_Area .in {
      text-align: center;
      font-weight: 400;
      font-size: 15px; }
  #plus2025 #Support {
    margin-top: 40px;
    /* 親要素: 相対配置を維持し、テキスト配置の基準とします */ }
    #plus2025 #Support img {
      max-width: 300px;
      width: 100%;
      margin: 0 auto; }
    #plus2025 #Support .title-wrapper {
      position: relative;
      margin-bottom: 5px;
      text-align: left; }
    #plus2025 #Support .subTITLE {
      /* 座標系の設定 */
      position: absolute;
      top: -25px;
      /* h3の少し上、マイナス値で上に移動（調整してください） */
      left: 0;
      /* 左端に配置（調整してください） */
      transform: skewX(-20deg);
      transform-origin: left top;
      /* 見た目の設定 */
      font-size: 24px;
      /* 小さめに（この数値を調整してください） */
      font-weight: 700;
      color: #cccccc;
      white-space: nowrap;
      opacity: 0.5;
      /* うっすら感を出す */
      z-index: 1; }
    #plus2025 #Support .title-wrapper h3 {
      position: relative;
      z-index: 2; }
    #plus2025 #Support .pushtext {
      font-size: 1.2em;
      color: #7d8faf;
      text-align: center;
      transform: skewX(-20deg); }
    #plus2025 #Support strong {
      font-size: 16px; }
  #plus2025 #VoiceArea {
    margin-top: 40px; }
    #plus2025 #VoiceArea p {
      line-height: 1.5rem;
      margin-bottom: 5px; }
    #plus2025 #VoiceArea .univname {
      font-size: 15px;
      font-weight: 500;
      margin-top: 5px; }
      #plus2025 #VoiceArea .univname span {
        background: #2A2A2A;
        color: #FFFFFF;
        padding: 0 10px; }
    #plus2025 #VoiceArea .text {
      font-size: 16px;
      font-weight: 500; }
    #plus2025 #VoiceArea .V_name {
      font-size: 13px; }
    #plus2025 #VoiceArea .voice_link {
      display: block; }
  #plus2025 #ss_Support {
    margin-top: 40px; }
    #plus2025 #ss_Support .bigtitle {
      font-weight: 900;
      font-size: 27px;
      text-align: center;
      color: #000000; }
      #plus2025 #ss_Support .bigtitle span.red {
        color: #e7264a;
        font-size: 45px; }
      #plus2025 #ss_Support .bigtitle span.green {
        color: #25af65;
        font-size: 45px; }
      #plus2025 #ss_Support .bigtitle span.orange {
        color: #f39918;
        font-size: 45px; }
  #plus2025 #Fixed {
    /* 画面下部の固定ボタン */
    /* ボタンを非表示にするクラス */ }
    #plus2025 #Fixed .fixed-btn-container {
      position: fixed;
      bottom: 0;
      left: 0;
      width: 100%;
      z-index: 1000;
      transition: opacity 0.3s ease;
      padding: 15px 0;
      box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.1);
      text-align: center;
      background: rgba(0, 0, 0, 0.7); }
    #plus2025 #Fixed .fixed-btn-container.is-hidden {
      opacity: 0;
      pointer-events: none;
      /* クリックを無効化 */ }
    #plus2025 #Fixed .in {
      max-width: 750px;
      width: 100%;
      margin: 0 auto; }
    #plus2025 #Fixed .ftbtn {
      font-size: 1rem;
      font-weight: 400;
      line-height: 1.5;
      position: relative;
      display: inline-block;
      cursor: pointer;
      -webkit-user-select: none;
      -moz-user-select: none;
      -ms-user-select: none;
      user-select: none;
      -webkit-transition: all 0.3s;
      transition: all 0.3s;
      text-align: center;
      vertical-align: middle;
      text-decoration: none;
      letter-spacing: 0.1em;
      color: #212529;
      border-radius: 0.1rem;
      width: 100%; }
    #plus2025 #Fixed a.btn--FTCV {
      color: #fff;
      padding: 10px;
      background-color: #cf243b;
      border-bottom: 5px solid #bd001d; }
    #plus2025 #Fixed a.btn--FTCV:hover {
      margin-top: 3px;
      color: #fff;
      background: #e07382;
      border-bottom: 2px solid #bd001d; }
    #plus2025 #Fixed a.btn--FTLINE {
      color: #fff;
      max-width: 600px;
      width: 100%;
      padding: 10px;
      background-color: #06c655;
      border-bottom: 5px solid #069f55; }
    #plus2025 #Fixed a.btn--FTLINE:hover {
      margin-top: 3px;
      color: #fff;
      background: #8fe5b2;
      border-bottom: 2px solid #069f55; }
  #plus2025 #inexpensive.Page {
    color: #3F3F3F;
    /* テキストコンテナに下端・左端の余白を追加 */
    /* テキストの可読性向上 */
    /*Pick*/
    /* container と row の幅を #FV の内側に広げる */
    /* テキストの可読性向上と中央寄せ */ }
    #plus2025 #inexpensive.Page .pushtext {
      font-size: 1.4em;
      color: #7d8faf;
      /*        padding: 20px 10px;*/
      transform: skewX(-20deg); }
    #plus2025 #inexpensive.Page #FV {
      /* === 背景画像の設定 === */
      background: url("/public/assets/images/plus/inexpensive/HeaderImg_001.jpg") no-repeat center right;
      background-size: cover;
      height: 300px;
      color: #FFFFFF;
      /* === Flexboxによるコンテンツ配置 === */
      display: flex;
      flex-direction: column;
      /* コンテンツを下から上へ積む（デフォルトはrow） */
      justify-content: flex-end;
      /* コンテンツ全体をコンテナの最下部に寄せる */ }
    #plus2025 #inexpensive.Page #FV .container {
      width: 100%;
      padding-bottom: 20px; }
    #plus2025 #inexpensive.Page #FV .fv-text {
      font-size: 2rem;
      font-weight: 700;
      line-height: 1.5;
      text-shadow: 3px 3px 4px rgba(0, 0, 0, 0.8); }
    @media (min-width: 200px) and (max-width: 770px) {
      #plus2025 #inexpensive.Page #FV .fv-text {
        font-size: 1.2rem; } }
    #plus2025 #inexpensive.Page #Pick01 {
      margin-top: 40px;
      padding-bottom: 30px;
      background-image: linear-gradient(170deg, rgba(2, 2, 2, 0.02) 0%, rgba(2, 2, 2, 0.02) 51%, transparent 51%, transparent 100%), linear-gradient(212deg, rgba(82, 82, 82, 0.01) 0%, rgba(82, 82, 82, 0.01) 39%, transparent 39%, transparent 100%), linear-gradient(95deg, rgba(73, 73, 73, 0.01) 0%, rgba(73, 73, 73, 0.01) 66%, transparent 66%, transparent 100%), linear-gradient(119deg, rgba(174, 174, 174, 0.01) 0%, rgba(174, 174, 174, 0.01) 67%, transparent 67%, transparent 100%), linear-gradient(43deg, rgba(237, 237, 237, 0.03) 0%, rgba(237, 237, 237, 0.03) 13%, transparent 13%, transparent 100%), linear-gradient(148deg, rgba(11, 11, 11, 0.01) 0%, rgba(11, 11, 11, 0.01) 9%, transparent 9%, transparent 100%), linear-gradient(17deg, rgba(233, 233, 233, 0.02) 0%, rgba(233, 233, 233, 0.02) 13%, transparent 13%, transparent 100%), linear-gradient(198deg, rgba(248, 248, 248, 0.02) 0%, rgba(248, 248, 248, 0.02) 43%, transparent 43%, transparent 100%), linear-gradient(199deg, rgba(125, 125, 125, 0.01) 0%, rgba(125, 125, 125, 0.01) 39%, transparent 39%, transparent 100%), linear-gradient(12deg, rgba(2, 2, 2, 0.02) 0%, rgba(2, 2, 2, 0.02) 46%, transparent 46%, transparent 100%), linear-gradient(341deg, rgba(227, 227, 227, 0.02) 0%, rgba(227, 227, 227, 0.02) 13%, transparent 13%, transparent 100%), linear-gradient(215deg, rgba(201, 201, 201, 0.03) 0%, rgba(201, 201, 201, 0.03) 56%, transparent 56%, transparent 100%), linear-gradient(199deg, rgba(189, 189, 189, 0.02) 0%, rgba(189, 189, 189, 0.02) 2%, transparent 2%, transparent 100%), linear-gradient(34deg, rgba(116, 116, 116, 0.03) 0%, rgba(116, 116, 116, 0.03) 63%, transparent 63%, transparent 100%), linear-gradient(50deg, rgba(230, 230, 230, 0.01) 0%, rgba(230, 230, 230, 0.01) 30%, transparent 30%, transparent 100%), linear-gradient(162deg, rgba(10, 10, 10, 0.02) 0%, rgba(10, 10, 10, 0.02) 58%, transparent 58%, transparent 100%), linear-gradient(327deg, rgba(35, 35, 35, 0.01) 0%, rgba(35, 35, 35, 0.01) 15%, transparent 15%, transparent 100%), linear-gradient(255deg, rgba(191, 191, 191, 0.03) 0%, rgba(191, 191, 191, 0.03) 74%, transparent 74%, transparent 100%), linear-gradient(311deg, rgba(210, 210, 210, 0.03) 0%, rgba(210, 210, 210, 0.03) 46%, transparent 46%, transparent 100%), linear-gradient(272deg, rgba(212, 212, 212, 0.01) 0%, rgba(212, 212, 212, 0.01) 19%, transparent 19%, transparent 100%), linear-gradient(90deg, white, white);
      /* === 全体設定 === */
      /* === ヘッダー（金額とラベル） === */
      /* === グラフ本体の設定 === */
      /* 100%幅の基準となる外側コンテナ */
      /* === グラフ本体の設定 === */
      /* 棒グラフ本体（Flexboxでセグメントを横並びにする） */
      /* === アニメーション実行のためのトリガークラスを追加 === */
      /* 親要素（.route-block）にis-animatedが付いたら、中の.cost-barにアニメーションを適用 */
      /* キーフレームはそのまま維持 */
      /* 正規ルートの最終幅は100% */
      /* 削減ルートの最終幅は52% */
      /* セグメント（内訳）のスタイル */
      /* 授業料の色 */
      /* 生活費の色 */
      /* 棒グラフが伸びるキーフレームアニメーション */
      /* === SP対応 === */
      /* === 解説ボックスの設定 === */
      /* 吹き出しのタイトル */
      /* 吹き出しの「しっぽ」部分（::beforeで作成） */
      /* 吹き出しの「しっぽ」の内側（::afterで作成し、::beforeの上に重ねる） */
      /* 本文テキスト */ }
      #plus2025 #inexpensive.Page #Pick01 .StrategyItem {
        font-size: 13px;
        color: #535353; }
        #plus2025 #inexpensive.Page #Pick01 .StrategyItem img {
          max-width: 160px;
          width: 100%; }
      #plus2025 #inexpensive.Page #Pick01 .Detail {
        font-size: 12px;
        color: #707070; }
      #plus2025 #inexpensive.Page #Pick01 .H3Title {
        background: #2B2B2B;
        padding: 10px 0; }
        #plus2025 #inexpensive.Page #Pick01 .H3Title h3.Cost {
          color: #FFFFFF !important; }
      #plus2025 #inexpensive.Page #Pick01 .cost-comparison {
        max-width: 900px;
        /* 最大幅を指定してPCでの見やすさを確保 */
        margin: 0 auto;
        margin-top: 40px; }
      #plus2025 #inexpensive.Page #Pick01 .route-block {
        margin-bottom: 50px; }
      #plus2025 #inexpensive.Page #Pick01 .route-header {
        display: flex;
        justify-content: space-between;
        align-items: flex-end;
        margin-bottom: 10px;
        font-weight: 800; }
      #plus2025 #inexpensive.Page #Pick01 .route-name {
        margin-top: 20px;
        font-size: 0.8rem;
        font-weight: 600;
        color: #333;
        line-height: 1rem; }
      #plus2025 #inexpensive.Page #Pick01 .route-total {
        font-size: 1.8rem;
        font-weight: 800;
        color: #cf243b;
        display: flex;
        align-items: flex-end; }
      #plus2025 #inexpensive.Page #Pick01 .reduction-tag {
        font-size: 1rem;
        color: #dc3545;
        /* 赤色 */
        background-color: #ffe8e8;
        padding: 2px 8px;
        border-radius: 4px;
        margin-left: 10px; }
      #plus2025 #inexpensive.Page #Pick01 .route-duration {
        text-align: right;
        font-size: 0.9rem;
        color: #6c757d;
        margin-top: 5px; }
      #plus2025 #inexpensive.Page #Pick01 .cost-bar-outer {
        height: 40px;
        background-color: #eee;
        position: relative;
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); }
      #plus2025 #inexpensive.Page #Pick01 .cost-bar {
        display: flex;
        height: 100%;
        align-items: center;
        overflow: hidden;
        /* widthは初期状態の0%を維持 */
        width: 0%; }
      #plus2025 #inexpensive.Page #Pick01 .route-block.is-animated .cost-bar {
        animation: bar-grow 1.5s ease-out forwards 0.3s; }
@keyframes bar-grow {
  to {
    width: 100%; } }
      #plus2025 #inexpensive.Page #Pick01 .regular-route-bar {
        max-width: 100%; }
      #plus2025 #inexpensive.Page #Pick01 .reduced-route-bar {
        max-width: 52%; }
      #plus2025 #inexpensive.Page #Pick01 .reduced-route-bar2 {
        max-width: 58.75%;
        /* 2350万 ÷ 4000万 = 0.5875 */ }
      #plus2025 #inexpensive.Page #Pick01 .fee-segment {
        height: 100%;
        display: flex;
        align-items: center;
        padding: 0 10px;
        font-size: 1.3rem;
        color: #FFFFFF;
        font-weight: bold;
        white-space: nowrap; }
      #plus2025 #inexpensive.Page #Pick01 .fee-segment.tuition {
        background-color: #1d3b63; }
      #plus2025 #inexpensive.Page #Pick01 .fee-segment.living {
        color: #262626;
        background-color: #f9b85b; }
@keyframes bar-grow {
  to {
    width: 100%; } }
      @media (max-width: 576px) {
        #plus2025 #inexpensive.Page #Pick01 .route-header {
          flex-direction: column;
          align-items: flex-start; }
        #plus2025 #inexpensive.Page #Pick01 .route-total {
          margin-top: 5px;
          font-size: 1.5rem; }
        #plus2025 #inexpensive.Page #Pick01 .fee-segment {
          font-size: 0.7rem;
          padding: 0 5px; } }
      #plus2025 #inexpensive.Page #Pick01 .explanation-box {
        margin-top: 40px;
        padding: 30px;
        background-color: #f8f9fa;
        /* やや薄いグレーの背景 */
        border-radius: 10px;
        border: 1px solid #dee2e6;
        position: relative; }
      #plus2025 #inexpensive.Page #Pick01 .explanation-title {
        font-size: 1.3rem;
        font-weight: bold;
        color: #1d3b63;
        /* 授業料の色と合わせて統一感を出す */
        margin-bottom: 15px;
        padding-bottom: 5px;
        border-bottom: 2px solid #dee2e6; }
      #plus2025 #inexpensive.Page #Pick01 .explanation-box::before {
        content: '';
        position: absolute;
        top: -20px;
        /* ボックスの上端に配置 */
        left: 50%;
        /* 中央に配置 */
        transform: translateX(-50%);
        width: 0;
        height: 0;
        /* 三角形を作る */
        border-style: solid;
        border-width: 0 15px 20px 15px;
        /* 上辺は0、下辺を20pxで三角形 */
        border-color: transparent transparent #dee2e6 transparent;
        /* ボーダーの色 */
        z-index: 1; }
      #plus2025 #inexpensive.Page #Pick01 .explanation-box::after {
        content: '';
        position: absolute;
        top: -18px;
        /* ::beforeより少し上に配置 */
        left: 50%;
        transform: translateX(-50%);
        width: 0;
        height: 0;
        /* 三角形を作る */
        border-style: solid;
        border-width: 0 15px 20px 15px;
        border-color: transparent transparent #f8f9fa transparent;
        /* 背景の色 */
        z-index: 2; }
      #plus2025 #inexpensive.Page #Pick01 .explanation-box p {
        line-height: 1.8;
        color: #474747;
        font-family: 'Hiragino Mincho ProN', '游明朝', YuMincho, 'serif';
        font-size: 1.05rem;
        /* 少し大きくして可読性を高める */ }
    #plus2025 #inexpensive.Page #Network {
      background-image: radial-gradient(circle at 32% 12%, rgba(229, 229, 229, 0.05) 0%, rgba(229, 229, 229, 0.05) 50%, rgba(101, 101, 101, 0.05) 50%, rgba(101, 101, 101, 0.05) 100%), radial-gradient(circle at 49% 59%, rgba(113, 113, 113, 0.05) 0%, rgba(113, 113, 113, 0.05) 50%, rgba(240, 240, 240, 0.05) 50%, rgba(240, 240, 240, 0.05) 100%), radial-gradient(circle at 16% 86%, rgba(118, 118, 118, 0.05) 0%, rgba(118, 118, 118, 0.05) 50%, rgba(207, 207, 207, 0.05) 50%, rgba(207, 207, 207, 0.05) 100%), linear-gradient(252deg, #e1f4ff, #f8fffd); }
    #plus2025 #inexpensive.Page #LastLastMessage {
      margin-top: 40px;
      /* === 背景画像の設定 === */
      background-image: repeating-linear-gradient(0deg, rgba(240, 245, 250, 0.05) 0px, rgba(240, 245, 250, 0.05) 1px, transparent 1px, transparent 11px, rgba(240, 245, 250, 0.05) 11px, rgba(240, 245, 250, 0.05) 12px, transparent 12px, transparent 32px), repeating-linear-gradient(45deg, rgba(240, 245, 250, 0.05) 0px, rgba(240, 245, 250, 0.05) 1px, transparent 1px, transparent 11px, rgba(240, 245, 250, 0.05) 11px, rgba(240, 245, 250, 0.05) 12px, transparent 12px, transparent 32px), repeating-linear-gradient(90deg, rgba(240, 245, 250, 0.05) 0px, rgba(240, 245, 250, 0.05) 1px, transparent 1px, transparent 11px, rgba(240, 245, 250, 0.05) 11px, rgba(240, 245, 250, 0.05) 12px, transparent 12px, transparent 32px), repeating-linear-gradient(45deg, rgba(240, 245, 250, 0.05) 0px, rgba(240, 245, 250, 0.05) 1px, transparent 1px, transparent 11px, rgba(240, 245, 250, 0.05) 11px, rgba(240, 245, 250, 0.05) 12px, transparent 12px, transparent 32px), linear-gradient(90deg, #26193f, #3f4e8f);
      color: #FFFFFF;
      height: 250px;
      /* === Flexboxによるコンテンツ配置の基準 === */
      display: flex;
      /* Flexコンテナにする */
      align-items: center;
      /* 縦方向の中央寄せ (row コンテンツ全体) */
      justify-content: center;
      /* 横方向の中央寄せ (row コンテンツ全体) */ }
      @media (min-width: 200px) and (max-width: 770px) {
        #plus2025 #inexpensive.Page #LastLastMessage {
          height: 300px; } }
    #plus2025 #inexpensive.Page #LastLastMessage .container, #plus2025 #inexpensive.Page #LastLastMessage .row {
      /*    width: 100%;*/
      height: 100%; }
    #plus2025 #inexpensive.Page #LastLastMessage .fv-text {
      font-size: 1.8rem;
      font-weight: 800;
      line-height: 1.5;
      text-shadow: 1px 1px 6px rgba(0, 0, 0, 0.9);
      text-align: center;
      /* テキスト自体を中央寄せ */ }
    #plus2025 #inexpensive.Page #LastLastMessage .sub {
      font-size: 1.3rem;
      font-weight: 500; }
  #plus2025 footer {
    background-color: #1e1e1e;
    margin-top: 30px;
    font-size: 12px;
    line-height: 1.8em;
    padding-bottom: 100px;
    padding-top: 30px;
    color: #FFFFFF; }
    #plus2025 footer .logo {
      color: #FFF;
      font-weight: 700;
      font-size: 30px; }
    #plus2025 footer ul.menu, #plus2025 footer .address {
      padding-left: 0; }
    #plus2025 footer .address span, #plus2025 footer .menu span {
      color: #FFF;
      font-weight: bold;
      border-bottom: 1px solid #c7c7c7;
      padding: 10px 0px;
      display: block;
      text-transform: uppercase;
      font-size: 16px;
      letter-spacing: 3px; }
    #plus2025 footer .address li a, #plus2025 footer .menu li a {
      color: #FFF;
      letter-spacing: 3px;
      text-decoration: none;
      font-size: 14px; }
    #plus2025 footer .address li, #plus2025 footer .menu li {
      margin: 20px 0px;
      list-style: none;
      display: block; }
    #plus2025 footer .address li a:hover, #plus2025 footer .menu li a:hover {
      text-decoration: underline;
      -webkit-transition: all 0.2s ease-in-out;
      -moz-transition: all 0.2s ease-in-out;
      -o-transition: all 0.2s ease-in-out;
      transition: all 0.2s ease-in-out; }
    #plus2025 footer .address .fa {
      margin-right: 10px;
      font-size: 18px; }

/*plus2025*/
