@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,700&display=swap");

.philosophy {
  position: relative; }
  .philosophy__content {
    width: 490px; }
  .philosophy__copy {
    font-size: 46px;
    font-size: 2.875rem;
    line-height: 1.195;
    color: #D4004E;
    letter-spacing: 0.08em;
    margin-top: 55px;
    font-weight: 900; }
  .philosophy__add {
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 2.142;
    color: #D4004E;
    padding-left: 21px;
    margin-top: 17px;
    letter-spacing: 0.4em;
    font-weight: bold;
    position: relative; }
    .philosophy__add::after {
      content: '';
      position: absolute;
      background-color: #D4004E;
      width: 5px;
      height: 2px;
      left: 2px;
      top: 50%; }
    .philosophy__add::before {
      content: '';
      position: absolute;
      background-color: #D4004E;
      width: 5px;
      height: 2px;
      left: 145px;
      top: 50%; }
  .philosophy__adds {
    font-size: 10px;
    font-size: 0.625rem;
    line-height: 3;
    color: #D4004E;
    padding-left: 21px;
    letter-spacing: 0.4em;
    font-weight: bold; }
  .philosophy__txt {
    font-size: 15px;
    font-size: 0.9375rem;
    line-height: 2.133;
    letter-spacing: 0.08em;
    margin-top: 46px; }
  .philosophy__txts {
    font-size: 15px;
    font-size: 0.9375rem;
    line-height: 2.133;
    letter-spacing: 0.08em;
    margin-top: 21px; }
  .philosophy__bg {
    position: absolute;
    width: 583px;
    right: 0;
    top: 0;
    z-index: -1; }
    .philosophy__bg img {
      width: 100%; }

@media (max-width: 768px) {
  .philosophy__bg {
    padding-top: 32px;
    width: auto;
    margin: 0 calc(50% - 50vw); }
    .philosophy__bg img {
      width: 100%; }
  .philosophy__content {
    width: 100%; }
  .philosophy__copy {
    margin-top: 130px;
    font-size: 46px;
    font-size: 2.875rem;
    line-height: 1.195;
    letter-spacing: 0.08em; }
  .philosophy__add {
    margin-top: 17px;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 2.142; }
  .philosophy__adds {
    font-size: 10px;
    font-size: 0.625rem;
    line-height: 3; }
  .philosophy__txt {
    margin-top: 41px;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 2.285;
    letter-spacing: .08em; }
  .philosophy__txts {
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 2.285;
    letter-spacing: .08em;
    margin-top: 17px; } }

.company {
  margin-top: 93px;
  position: relative; }
  .company__ttl {
    position: absolute; }
  .company__inner {
    padding-top: 32px;
    margin-left: 25px;
    list-style: none; }
  .company__list {
    display: flex;
    background-color: #F2F3F7;
    padding: 27px 47px 27px 36px;
    border-top: 2px solid #fff; }
    .company__list:first-child {
      padding-top: 49px;
      border: none; }
  .company__info {
    width: 99px;
    font-size: 13px;
    font-size: 0.8125rem;
    letter-spacing: 0.015em;
    line-height: 1.615;
    position: relative; }
    .company__info::after {
      content: '';
      height: 100%;
      width: 1px;
      background-color: #000;
      position: absolute;
      right: 0; }
  .company__details {
    flex: 1; }
  .company__txt {
    font-size: 13px;
    font-size: 0.8125rem;
    letter-spacing: 0.015em;
    line-height: 1.615;
    padding-left: 30px; }
  .company__btn {
    display: block;
    width: 82px;
    height: 20px;
    font-size: 10px;
    font-size: 0.625rem;
    letter-spacing: 0.015em;
    line-height: 20px;
    color: #fff;
    text-decoration: none;
    margin-top: 14px;
    margin-left: 30px;
    background-color: #D4004E;
    text-align: center; }

@media (max-width: 768px) {
  .company {
    margin-top: 40px; }
    .company__inner {
      margin-left: 0; }
    .company__list {
      padding: 31px 18px 31px 23px; }
      .company__list:last-child {
        padding-bottom: 35px; }
    .company__info {
      width: 65px;
      font-size: 14px;
      font-size: 0.875rem;
      line-height: 2.214;
      letter-spacing: 0.015em; }
    .company__txt {
      font-size: 14px;
      font-size: 0.875rem;
      line-height: 1.5;
      letter-spacing: 0.015em;
      padding-left: 23px; }
    .company__btn {
      width: 116px;
      height: 31px;
      line-height: 31px;
      font-size: 14px;
      font-size: 0.875rem;
      letter-spacing: 0.015em;
      margin-left: 23px; } }

.access {
  margin-top: 92px; }
  .access__ttl {
    position: absolute; }
  .access__txt_tokyo {
    margin: 50px 0 43px;
    padding: 28px 28px 26px 41px;
    font-size: 13px;
    font-size: 0.8125rem;
    line-height: 2;
    letter-spacing: 0.08em;
    background-color: #F2F3F7; }
  .access__txt_osaka {
    margin-top: 50px;
    padding: 28px 28px 26px 41px;
    font-size: 13px;
    font-size: 0.8125rem;
    line-height: 2;
    letter-spacing: 0.08em;
    background-color: #F2F3F7; }

#map__tokyo {
  height: 340px;
  width: 100%;
  top: 35px;
  z-index: 0;
  margin-bottom: 83px; }

#map__osaka {
  height: 340px;
  width: 100%; }

@media (max-width: 768px) {
  #map__tokyo, #map__osaka {
    margin: 0 calc(50% - 50vw);
    width: auto;
    margin-bottom: 83px; } }

@media (max-width: 768px) {
  .access {
    margin-top: 60px; }
    .access__txt_tokyo {
      margin-top: 30px 0 26px;
      padding: 29px 20px 25px 25px;
      font-size: 14px;
      font-size: 0.875rem;
      line-height: 2;
      letter-spacing: .08em; }
    .access__txt_osaka {
      margin-top: 30px;
      padding: 29px 20px 25px 25px;
      font-size: 14px;
      font-size: 0.875rem;
      line-height: 2;
      letter-spacing: .08em; } }

.member {
  margin-top: 101px; }
  .member__inner {
    margin-top: 39px;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
  .member__list {
    width: 27.1%;
    max-width: 266px;
    position: relative;
    margin-bottom: 69px; }
    .member__list:last-child {
      margin-bottom: 0; }
  .member__img {
    width: 100%; }
    .member__img img {
      width: 100%; }
  .member__content {
    padding: 31px 23px 40px 33px;
    background-color: #D4004E;
    color: #fff; }
  .member__name {
    font-size: 24px;
    font-size: 1.5rem;
    line-height: 1.083;
    letter-spacing: 0.08em; }
  .member__job {
    margin-top: 8px;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1.857;
    letter-spacing: 0.08em; }
  .member__txt {
    margin-top: 18px;
    font-size: 13px;
    font-size: 0.8125rem;
    line-height: 2;
    letter-spacing: 0.006em; }

@media (max-width: 768px) {
  .member {
    margin-top: 58px; }
    .member__inner {
      margin-top: 48px; }
    .member__list {
      width: 47%; }
      .member__list:last-child {
        margin-bottom: 0; }
    .member__img {
      padding-bottom: 0;
      margin: 0 auto; }
    .member__content {
      width: 100%;
      height: auto;
      padding: 15px 15px 15px 15px; }
    .member__name {
      font-size: 18px;
      font-size: 1.125rem; } }

@media (max-width: 414px) {
  .member__img {
    max-width: none; }
  .member__content {
    width: 100%;
    height: auto; } }
