﻿@charset "UTF-8";
/*************************
フォーム関連のスタイルリセット
**************************/
button,
input[type=submit] {
  background: none;
  border: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  color: inherit;
}

input[type=text],
input[type=number],
input[type=tel],
input[type=email],
input[type=url],
input[type=password],
input[type=search],
textarea {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/*
layout
*/
/*
color
*/
/*
pxをvwに変換

ウインドウ幅1400pxに対して要素幅50pxの場合
getvw(50,1400)となる
*/
/*
メディアクエリ
記述例
body{
  @include msw('max',1200){
    background-color: red;
  }
}
*/
/*
ICON FONT
*/
/************************************************************
SCREEN ALL
*************************************************************/
/************************************************************
SCREEN SP
*************************************************************/
/************************************************************
SCREEN PC
*************************************************************/
/************************************************************
SCREEN ALL
*************************************************************/
/************************************************************
SCREEN SP
*************************************************************/
@media screen and (max-width:767px) {
  .kv .kv-pic {
    width: calc(100% - 7.6923076923vw);
    margin: 0 0 0 auto;
  }
}
/************************************************************
SCREEN PC
*************************************************************/
@media screen and (min-width:768px) {
  .kv .kv-pic {
    width: 92.19%;
    max-width: calc(1400px + (100% - 1400px) / 2);
    margin: 0 0 0 auto;
  }
}
/************************************************************
SCREEN ALL
*************************************************************/
/************************************************************
SCREEN SP
*************************************************************/
@media screen and (max-width:767px) {
  section.philosophy {
    margin-top: 60px;
    padding: 60px 0;
    position: relative;
  }
  section.philosophy::before {
    content: "";
    display: block;
    width: calc(100% - 7.6923076923vw - 55px);
    background-color: #F2F6FD;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
  }
  section.philosophy .philosophy-boxes {
    position: relative;
  }
  section.philosophy .philosophy-box {
    border-top: 1px solid #CED6E7;
    padding: 30px 0;
    position: relative;
  }
  section.philosophy .philosophy-box::before {
    content: "";
    display: block;
    width: 110px;
    border-top: 1px solid #0C3387;
    position: absolute;
    top: -1px;
    left: 0;
  }
  section.philosophy .philosophy-box:last-child {
    border-bottom: 1px solid #CED6E7;
  }
  section.philosophy .philosophy-box .philosophy-box-title-01 {
    font-size: 24px;
    font-weight: bold;
    color: #0C3387;
    margin-bottom: 15px;
  }
  section.philosophy .philosophy-box .philosophy-box-title-02 {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.5em;
    letter-spacing: 0.05em;
  }
  section.philosophy .philosophy-box .philosophy-box-txt-01 {
    font-size: 20px;
    font-weight: bold;
    line-height: 1.5em;
    letter-spacing: 0.05em;
  }
  section.philosophy .philosophy-box .philosophy-box-txt-02 {
    font-size: 14px;
    line-height: 1.7em;
    letter-spacing: 0.05em;
  }
  section.philosophy .philosophy-box .philosophy-box-title-02 + .philosophy-box-txt-02 {
    margin-top: 20px;
  }
  section.philosophy .philosophy-box .philosophy-box-txt-02 + .philosophy-box-title-02 {
    margin-top: 30px;
  }
}
/************************************************************
SCREEN PC
*************************************************************/
@media screen and (min-width:768px) {
  section.philosophy {
    margin-top: 100px;
    padding: 100px 0;
    position: relative;
  }
  section.philosophy::before {
    content: "";
    display: block;
    width: calc(92.19% - 90px);
    max-width: calc(1400px + (100% - 1400px) / 2 - 90px);
    background-color: #F2F6FD;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
  }
  section.philosophy .philosophy-boxes {
    position: relative;
  }
  section.philosophy .philosophy-box {
    border-top: 1px solid #CED6E7;
    display: flex;
    padding: 40px 0;
    position: relative;
  }
  section.philosophy .philosophy-box::before {
    content: "";
    display: block;
    width: 22%;
    border-top: 1px solid #0C3387;
    position: absolute;
    top: -1px;
    left: 0;
  }
  section.philosophy .philosophy-box:last-child {
    border-bottom: 1px solid #CED6E7;
  }
  section.philosophy .philosophy-box .philosophy-box-head {
    width: 22%;
    min-width: 22%;
  }
  section.philosophy .philosophy-box .philosophy-box-body {
    width: 100%;
    padding-left: 30px;
  }
  section.philosophy .philosophy-box .philosophy-box-title-01 {
    font-size: 30px;
    font-weight: bold;
    color: #0C3387;
  }
  section.philosophy .philosophy-box .philosophy-box-title-02 {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.5em;
    letter-spacing: 0.05em;
  }
  section.philosophy .philosophy-box .philosophy-box-txt-01 {
    font-size: 24px;
    font-weight: bold;
    line-height: 1.5em;
    letter-spacing: 0.05em;
  }
  section.philosophy .philosophy-box .philosophy-box-txt-02 {
    font-size: 14px;
    line-height: 1.7em;
    letter-spacing: 0.05em;
  }
  section.philosophy .philosophy-box .philosophy-box-title-02 + .philosophy-box-txt-02 {
    margin-top: 20px;
  }
  section.philosophy .philosophy-box .philosophy-box-txt-02 + .philosophy-box-title-02 {
    margin-top: 30px;
  }
}
/************************************************************
SCREEN ALL
*************************************************************/
section.vi .vi-title {
  text-align: center;
}

/************************************************************
SCREEN SP
*************************************************************/
@media screen and (max-width:767px) {
  section.vi {
    padding: 100px 0;
  }
  section.vi .vi-boxes {
    width: 84.6153846154vw;
    margin: 0 auto;
  }
  section.vi .vi-box {
    margin-top: 60px;
  }
  section.vi .vi-box .vi-box-pic {
    width: 56.4102564103vw;
    max-width: 240px;
    margin: 0 auto;
  }
  section.vi .vi-box .vi-box-pic-border {
    border: 1px solid #CED6E7;
  }
  section.vi .vi-box .vi-box-body {
    width: 100%;
    margin-top: 20px;
  }
  section.vi .vi-box .vi-box-title {
    text-align: center;
  }
  section.vi .vi-box .vi-box-title .vi-box-title-01 {
    font-size: 16px;
    font-weight: bold;
    line-height: 1.5em;
    letter-spacing: 0.05em;
    color: #0C3387;
  }
  section.vi .vi-box .vi-box-title .vi-box-title-02 {
    font-size: 24px;
    font-weight: bold;
    line-height: 1.5em;
    letter-spacing: 0.05em;
  }
  section.vi .vi-box .vi-box-title .vi-box-title-02 .color-box {
    display: inline-block;
    width: 20px;
    height: 20px;
    background-color: #083388;
    margin-right: 8px;
  }
  section.vi .vi-box .vi-box-title .vi-box-title-02 .color-num {
    font-size: 14px;
    font-weight: 400;
  }
  section.vi .vi-box .vi-box-title .vi-box-title-01 + .vi-box-title-02 {
    margin-top: 5px;
  }
  section.vi .vi-box .vi-box-txts {
    margin-top: 10px;
  }
  section.vi .vi-box .vi-box-txts .vi-box-txt-01 {
    font-size: 16px;
    line-height: 2em;
    letter-spacing: 0.05em;
  }
}
/************************************************************
SCREEN PC
*************************************************************/
@media screen and (min-width:768px) {
  section.vi {
    padding: 150px 0;
  }
  section.vi .vi-boxes {
    width: 900px;
    margin: 0 auto;
  }
  section.vi .vi-box {
    margin-top: 60px;
    display: flex;
    gap: 0 60px;
  }
  section.vi .vi-box .vi-box-pic {
    width: 240px;
    min-width: 240px;
  }
  section.vi .vi-box .vi-box-pic-border {
    border: 1px solid #CED6E7;
  }
  section.vi .vi-box .vi-box-body {
    width: 100%;
  }
  section.vi .vi-box .vi-box-title .vi-box-title-01 {
    font-size: 18px;
    font-weight: bold;
    line-height: 1.5em;
    letter-spacing: 0.05em;
    color: #0C3387;
  }
  section.vi .vi-box .vi-box-title .vi-box-title-02 {
    font-size: 24px;
    font-weight: bold;
    line-height: 1.5em;
    letter-spacing: 0.05em;
  }
  section.vi .vi-box .vi-box-title .vi-box-title-02 .color-box {
    display: inline-block;
    width: 20px;
    height: 20px;
    background-color: #083388;
    margin-right: 8px;
  }
  section.vi .vi-box .vi-box-title .vi-box-title-02 .color-num {
    font-size: 14px;
    font-weight: 400;
    margin-left: 15px;
  }
  section.vi .vi-box .vi-box-title .vi-box-title-01 + .vi-box-title-02 {
    margin-top: 5px;
  }
  section.vi .vi-box .vi-box-txts {
    margin-top: 10px;
  }
  section.vi .vi-box .vi-box-txts .vi-box-txt-01 {
    font-size: 16px;
    line-height: 2em;
    letter-spacing: 0.05em;
  }
}