@charset "UTF-8";

/* ========================================
   @media screen and (min-width: 768px),print
======================================== */
@media screen and (min-width: 768px), print {
  main {
    background: #f2f2f2;
    padding-block: 0 180px;
  }

  .p-mv {
    background: url(../images/amano/mv_bg.jpg) no-repeat top center/cover;
    margin-bottom: 169px;
    margin-inline: auto;
    max-width: 1920px;
    width: 100%;
  }

  .p-mv .l-inner.l-mv {
    padding-block: 136px 138px;
  }

  .p-mv .p-mv__con {
    margin-inline: auto;
    width: min(95%, 1100px);
  }

  .p-mv .p-mv__en {
    margin-bottom: 38px;
  }

  .p-mv .p-mv__ttl {
    margin-bottom: 60px;
  }

  .p-mv .p-mv__txt {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0.25em;
    line-height: 1.8;
  }

  .c-sec__en {
    margin-bottom: 37px;
    margin-inline: auto;
    width: min(95%, 1100px);
  }

  .c-sec__ttl {
    font-size: 50px;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 0.82;
    margin-bottom: 76px;
    margin-inline: auto;
    width: min(95%, 1100px);
  }

  .p-domain {
    margin-bottom: 91px;
  }

  .p-domain .l-inner.l-domain {
    width: 100%;
  }

  .p-domain .p-domain__img {
    margin-bottom: -111px;
    text-align: center;
  }

  .p-domain .p-domain__img img {
    height: auto;
    width: 100%;
  }

  .p-domain .p-domain__box {
    background: #f2f2f2;
    position: relative;
    width: min(85%, 1280px);
    height: 150px;
    margin-bottom: -92px;
  }

  .p-domain .p-domain__subttl {
    font-size: 28px;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.4642857143;
    margin-bottom: 100px;
    margin-inline: auto;
    width: min(95%, 1100px);
    position: relative;
  }

  .p-domain .p-domain__con {
    display: grid;
    gap: 0 6.2%;
    grid-template-columns: 37.3% 57.1%;
    margin-bottom: 97px;
    margin-inline: auto;
    width: min(95%, 1100px);
  }

  .p-domain .p-domain__con-left {
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.6;
  }

  .p-domain .p-domain__con-right p {
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.6;
    margin-bottom: 24px;
  }

  .p-domain .p-domain__con-right p.bottom {
    margin-bottom: 0;
  }

  .p-domain .p-domain__line {
    background: #e6e6e6;
    height: 1px;
    margin-inline: auto;
    width: min(95%, 1280px);
  }

  .p-idea {
    margin-bottom: 150px;
  }

  .p-idea .l-inner.l-idea {
    width: 100%;
  }

  .p-idea .p-idea__img {
    margin-bottom: -112px;
    text-align: center;
  }

  .p-idea .p-idea__img img {
    height: auto;
    width: 100%;
  }

  .p-idea .p-idea__box {
    background: #f2f2f2;
    position: relative;
    width: min(85%, 1280px);
    height: 150px;
    margin-bottom: -93px;
  }

  .p-idea .p-idea__subttl {
    font-size: 28px;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.4642857143;
    margin-bottom: 141px;
    margin-inline: auto;
    width: min(95%, 1100px);
    position: relative;
  }

  .p-idea .p-idea__con {
    display: grid;
    gap: 0 7.2%;
    grid-template-columns: 36.3% 56.1%;
    margin-bottom: 100px;
    margin-inline: auto;
    width: min(95%, 1100px);
  }

  .p-idea .p-idea__con-left {
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.6;
  }

  .p-idea .p-idea__con-right p {
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.6;
    margin-bottom: 24px;
  }

  .p-idea .p-idea__con-right p.bottom {
    margin-bottom: 0;
  }

  .p-idea .p-idea__line {
    background: #e6e6e6;
    height: 1px;
    margin-inline: auto;
    width: min(95%, 1280px);
  }

  .c-sec__en02 {
    margin-bottom: 21px;
  }

  .c-sec__ttl02 {
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.6;
    margin-bottom: 70px;
    padding-inline: 26px 0;
    position: relative;
  }

  .c-sec__ttl02:before {
    background: #2ca6e0;
    content: "";
    height: 10px;
    left: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 10px;
  }

  .p-philosophy {
    margin-bottom: 118px;
  }

  .p-philosophy .l-inner.l-philosophy {
    margin-inline: auto;
    width: min(95%, 1100px);
  }

  .p-philosophy .p-philosophy__items {
    display: grid;
    gap: 40px 60px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .p-philosophy .p-philosophy__item {
    background: #ffffff;
    padding-block: 34px 69px;
    padding-inline: 38px;
    position: relative;
    height: 290px;
  }

  .p-philosophy .p-philosophy__item-num {
    margin-bottom: 37px;
    position: relative;
    z-index: 1;
  }

  .p-philosophy .p-philosophy__item-ttl {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.8636363636;
    margin-bottom: 12px;
    position: relative;
    z-index: 1;
  }

  .p-philosophy .p-philosophy__item-txt {
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.6;
    position: relative;
    z-index: 1;
  }

  .p-philosophy .p-philosophy__items .p-philosophy__item:nth-child(1) .p-philosophy__item-bottom-num {
    right: 46px;
  }

  .p-philosophy .p-philosophy__item-bottom-num {
    bottom: 0;
    position: absolute;
    right: 32px;
  }

  .p-domain02 .l-inner.l-domain02 {
    margin-inline: auto;
    width: min(95%, 1100px);
  }

  .p-domain02 .p-domain02__items {
    display: grid;
    gap: 0 11px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-block: -32px 60px;
  }

  .p-domain02 .p-domain02__item a {
    display: block;
    position: relative;
  }

  .p-domain02 .p-domain02__item a h3 {
    color: #ffffff;
    font-size: 18px;
    font-weight: 500;
    left: 28px;
    letter-spacing: 0.05em;
    line-height: 1.3333333333;
    position: absolute;
    top: 23px;
  }

  .p-domain02 .p-domain02__item a .img img {
    height: auto;
    width: 100%;
  }

  .p-domain02 .p-domain02__item a .more {
    align-items: center;
    bottom: 23px;
    display: flex;
    gap: 0 12px;
    position: absolute;
    right: 23px;
  }

  .p-domain02 .p-domain02__item a .more img {
    vertical-align: middle;
  }

  .p-domain02 .p-domain02__item a .more .arrow {
    background: #ffffff;
    border-radius: 10px;
    padding: 0px 27px;
  }

  .p-domain02 .p-domain02__item a .more .arrow svg {
    vertical-align: middle;
  }

  .p-domain02 .p-domain02__link {
    text-align: center;
  }

  .p-domain02 .p-domain02__link a {
    display: block;
    position: relative;
  }

  .p-domain02 .p-domain02__link a img {
    height: auto;
    width: 100%;
  }

  .p-domain02 .p-domain02__link a .arrow {
    background: #ffffff;
    border-radius: 10px;
    bottom: 20px;
    padding: 0px 24px;
    position: absolute;
    right: 20px;
  }

  .p-domain02 .p-domain02__link a .arrow svg {
    vertical-align: middle;
  }
}

@media (any-hover: hover) {
  .p-domain02 .p-domain02__item a:hover .img img {
    opacity: 1;
  }

  .p-domain02 .p-domain02__link a:hover img {
    opacity: 1;
  }

  .p-domain02 .p-domain02__item a:hover .more .arrow {
    background: #2ca6e0;
  }

  .p-domain02 .p-domain02__link a:hover .arrow {
    background: #2ca6e0;
  }

  .p-domain02 .p-domain02__item a:hover .more svg path {
    fill: #ffffff;
  }

  .p-domain02 .p-domain02__link a:hover .arrow svg path {
    fill: #ffffff;
  }
}

/* ========================================
   @media screen and (max-width: 767px)
======================================== */
@media screen and (max-width: 767px) {
  main {
    background: #f2f2f2;
    padding-block: 0 17.493vw;
  }

  .p-main__ttl .en.amano img {
    height: auto;
    width: 39.13vw;
  }

  .p-mv {
    background: url(../images/amano/mv_bg_sp.jpg) no-repeat top
      center/cover;
    margin-bottom: 16.908vw;
    margin-inline: auto;
    width: 100%;
  }

  .p-mv .l-inner.l-mv {
    padding-block: 39.372vw 15.217vw;
  }

  .p-mv .p-mv__con {
    margin-inline: auto;
    width: min(95%, 83.5748792271vw);
  }

  .p-mv .p-mv__en {
    margin-bottom: 4.348vw;
  }

  .p-mv .p-mv__en img {
    height: auto;
    width: 27.053vw;
  }

  .p-mv .p-mv__ttl {
    margin-bottom: 8.213vw;
  }

  .p-mv .p-mv__ttl img {
    height: auto;
    width: 50.242vw;
  }

  .p-mv .p-mv__txt {
    font-size: 3.865vw;
    font-weight: 700;
    letter-spacing: 0.25em;
    line-height: 1.75;
  }

  .c-sec__en {
    margin-bottom: 3.382vw;
    margin-inline: auto;
    width: min(95%, 83.5748792271vw);
  }

  .c-sec__ttl {
    font-size: 5.314vw;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.6363636364;
    margin-bottom: 7.246vw;
    margin-inline: auto;
    width: min(95%, 83.5748792271vw);
  }

  .p-domain {
    margin-bottom: 14.976vw;
  }

  .p-domain .l-inner.l-domain {
    width: 100%;
  }

  .p-domain .p-domain__img {
    margin-bottom: -29.435vw;
    text-align: center;
  }

  .p-domain .p-domain__img img {
    height: auto;
    width: 100%;
  }

  .p-domain .p-domain__box {
    background: #f2f2f2;
    height: 30.435vw;
    margin-bottom: -25.435vw;
    padding-block: 0;
    position: relative;
    width: min(95%, 84.5410628019vw);
  }

  .p-domain .p-domain__subttl {
    font-size: 4.348vw;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.6666666667;
    margin-bottom: 12.077vw;
    margin-inline: auto;
    padding-inline: 0 13.527vw;
    position: relative;
    width: min(95%, 83.5748792271vw);
    z-index: 1;
  }

  .p-domain .p-domain__con {
    display: grid;
    gap: 7.246vw 0;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    margin-bottom: 12.077vw;
    margin-inline: auto;
    width: min(95%, 83.5748792271vw);
  }

  .p-domain .p-domain__con-left {
    font-size: 3.865vw;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.75;
  }

  .p-domain .p-domain__con-right p {
    font-size: 3.623vw;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.6;
    margin-bottom: 5.797vw;
  }

  .p-domain .p-domain__con-right p.bottom {
    margin-bottom: 0;
  }

  .p-domain .p-domain__line {
    background: #e6e6e6;
    height: 0.242vw;
    margin-inline: auto;
    width: min(95%, 83.5748792271vw);
  }

  .p-idea {
    margin-bottom: 14.976vw;
  }

  .p-idea .l-inner.l-idea {
    width: 100%;
  }

  .p-idea .p-idea__img {
    margin-bottom: -15.942vw;
    text-align: center;
  }

  .p-idea .p-idea__img img {
    height: auto;
    width: 100%;
  }

  .p-idea .p-idea__box {
    background: #f2f2f2;
    height: 15.942vw;
    margin-bottom: -8.696vw;
    position: relative;
    width: min(95%, 84.5410628019vw);
  }

  .p-idea .p-idea__subttl {
    font-size: 4.348vw;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.6666666667;
    margin-bottom: 12.077vw;
    margin-inline: auto;
    padding-inline: 0 13.527vw;
    position: relative;
    width: min(95%, 83.5748792271vw);
    z-index: 1;
  }

  .p-idea .p-idea__con {
    display: grid;
    gap: 7.246vw 0;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    margin-bottom: 12.077vw;
    margin-inline: auto;
    width: min(95%, 83.5748792271vw);
  }

  .p-idea .p-idea__con-left {
    font-size: 3.865vw;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.75;
  }

  .p-idea .p-idea__con-right p {
    font-size: 3.623vw;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.6;
    margin-bottom: 5.797vw;
  }

  .p-idea .p-idea__con-right p.bottom {
    margin-bottom: 0;
  }

  .p-idea .p-idea__line {
    background: #e6e6e6;
    height: 0.242vw;
    margin-inline: auto;
    width: min(95%, 83.5748792271vw);
  }

  .c-sec__en02 {
    margin-bottom: 4.106vw;
    width: min(95%,83.5vw);
    margin-inline: auto;    
  }

  .c-sec__en02.philosophy img {
    height: auto;
    width: 60.628vw;
  }

  .c-sec__en02.domain img {
    height: auto;
    width: 39.13vw;
  }

  .c-sec__en02.domain02 img {
    height: auto;
    width: 39.13vw;
  }

  .c-sec__ttl02 {
    font-size: 3.623vw;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.6;
    margin-bottom: 7.246vw;
    padding-inline: 6.28vw 0;
    position: relative;
    width: min(95%,83.5vw);
    margin-inline: auto;    
  }

  .c-sec__ttl02:before {
    background: #2ca6e0;
    content: "";
    height: 2.415vw;
    left: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 2.415vw;
  }

  .p-philosophy {
    margin-bottom: 26.087vw;
  }

  .p-philosophy .l-inner.l-philosophy {
    margin-inline: auto;
    width: min(95%, 91.7vw);
  }

  .p-philosophy .p-philosophy__items {
    display: grid;
    gap: 3.865vw 0;
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .p-philosophy .p-philosophy__item {
    background: #ffffff;
    padding-block: 10.386vw 12.077vw;
    padding-inline: 9.179vw;
    position: relative;
  }

  .p-philosophy .p-philosophy__items .p-philosophy__item:nth-child(1) .p-philosophy__item-bottom-num img {
    height: auto;
    width: 9.42vw;
  }
  
  .p-philosophy .p-philosophy__items .p-philosophy__item:nth-child(2) .p-philosophy__item-bottom-num img {
    height: auto;
    width: 17.15vw;
  }
  
  .p-philosophy .p-philosophy__items .p-philosophy__item:nth-child(3) .p-philosophy__item-bottom-num img {
    height: auto;
    width: 17.874vw;
  }
  
  .p-philosophy .p-philosophy__items .p-philosophy__item:nth-child(4) .p-philosophy__item-bottom-num img {
    height: auto;
    width: 20.773vw;
  }
  
  .p-philosophy .p-philosophy__items .p-philosophy__item:nth-child(5) .p-philosophy__item-bottom-num img {
    height: auto;
    width: 17.633vw;
  }
  
  .p-philosophy .p-philosophy__items .p-philosophy__item:nth-child(6) .p-philosophy__item-bottom-num img {
    height: auto;
    width: 18.599vw;
  }
  
  .p-philosophy .p-philosophy__items .p-philosophy__item:nth-child(7) .p-philosophy__item-bottom-num img {
    height: auto;
    width: 17.391vw;
  }
  
  .p-philosophy .p-philosophy__items .p-philosophy__item:nth-child(8) .p-philosophy__item-bottom-num img {
    height: auto;
    width: 19.082vw;
  }

  .p-philosophy .p-philosophy__item-num {
    margin-bottom: 6.039vw;
  }

  .p-philosophy .p-philosophy__item-ttl {
    font-size: 4.348vw;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 2.2777777778;
    margin-bottom: 3.865vw;
  }

  .p-philosophy .p-philosophy__item-txt {
    font-size: 3.623vw;
    font-weight: 500;
    letter-spacing: 0em;
    line-height: 1.6;
    position: relative;
    z-index: 1;
  }

  .p-philosophy .p-philosophy__item-bottom-num {
    bottom: 0;
    position: absolute;
    right: 5.797vw;
  }

  .p-domain02 .l-inner.l-domain02 {
    margin-inline: auto;
    width: min(95%, 83.5748792271vw);
  }

  .p-domain02 .p-domain02__items {
    display: grid;
    gap: 2.415vw 0;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    margin-bottom: 7.246vw;
  }

  .p-domain02 .p-domain02__item a {
    display: block;
    position: relative;
  }

  .p-domain02 .p-domain02__item a h3 {
    color: #ffffff;
    font-size: 3.865vw;
    font-weight: 500;
    left: 4.831vw;
    letter-spacing: 0em;
    line-height: 1.5;
    position: absolute;
    top: 4.831vw;
    z-index: 1;
  }

  .p-domain02 .p-domain02__item a .img {

  }

  .p-domain02 .p-domain02__item a .img img {
    height: auto;
    width: 100%;
  }

  .p-domain02 .p-domain02__item a .more {
    align-items: center;
    display: flex;
    gap: 0 2.899vw;
    position: absolute;
    bottom: 3vw;
    right: 3vw;
    z-index: 1;
  }

  .p-domain02 .p-domain02__item a .more img {
    vertical-align: middle;
  }

  .p-domain02 .p-domain02__item a .more .arrow {
    background: #ffffff;
    border-radius: 2.415vw;
    padding: 0px 5.797vw;
  }

  .p-domain02 .p-domain02__item a .more .arrow svg {
    vertical-align: middle;
    width: 2.1vw;
  }

  .p-domain02 .p-domain02__link {
    text-align: center;
  }

  .p-domain02 .p-domain02__link a {
    display: block;
    position: relative;
  }

  .p-domain02 .p-domain02__link a img {
    height: auto;
    width: 100%;
  }

  .p-domain02 .p-domain02__link a .arrow {
    background: #ffffff;
    border-radius: 2.415vw;
    bottom: 1.831vw;
    padding: 0px 5.797vw;
    position: absolute;
    right: 2.831vw;
  }

  .p-domain02 .p-domain02__link a .arrow svg {
    vertical-align: middle;
    width: 2.1vw;
  }
}
