@charset "UTF-8";

body {
  font-family: 'Noto Sans JP', sans-serif;
  color: #333333;
}

.c-wrapper {
  display: flex;
}

.u-desktop {
  display: none;
}

@media screen and (max-width: 767px) {
  .u-desktop {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .u-mobile {
    display: none;
  }
}


/* pcの電話番号発信対応 */
@media(min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}


/* ホバー */
a {
  text-decoration: none;
  color: inherit;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

@media screen and (max-width: 767px) {
  a:hover {
    opacity: 0.8;
  }
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

/* Remove default padding */
ul,
ol {
  padding: 0;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}


ul,
ol {
  list-style: none;
}


a:not([class]) {
  text-decoration-skip-ink: auto;
}

div h2 {
  font-size:22px;
  font-weight:600;
}





img {
  display: block;
  width: 100%;
}


article>*+* {
  margin-top: 1em;
}


input,
button,
textarea,
select {
  font: inherit;
}

/*common*/
.inner {
  max-width: 1080px;
  padding: 0 20px;
  margin: 0 auto;
  width:100%;
}


@media screen and (max-width: 768px) {
  .inner {
    width: 90%;/*90%*/
    margin: 0 auto;
    padding: 0 0px;
  }
}

/*wrap*/
.p-dia_wrap {
font-size:16px;
margin: 30px auto;
}

/*main*/


#p-dia_suggestion_content {
  padding:0 20px;
}

.p-dia_second_content_inner {
  max-width: 1080px;
  margin: 0 auto;
  width: 100%;
}


  
  /*デフォルトのボタン*/
  div.p-coating-top__btn {
    display:block;
    width:100%;
    margin:0 auto;
    text-align: center;
    color:#fff;
    background:#0B3290;
    line-height: 26px;
    padding: 20px 0;
    border-radius: 4px;
  }
  /*ホバー時のボタン*/
  div.p-coating-top__btn :hover {
    display:block;
    opacity: 0.5;
  }
  


/*ボタン*/
.c-btn {
  background: #f29b22;
  color: #333333;
  display: block;
  width: 300px;
  height: 50px;
  border-radius: 30px;
  border: 0;
  color: #fff;
}

.c-btn {
  display: inline-block;
  padding: 10px 20px;
  padding-top: 13px;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  border: none;
  border-radius: 30px;
  cursor: pointer;
  color: #fff;
  background: linear-gradient(135deg, #ff8c00, #ff4500);
  box-shadow: 0 4px 6px rgba(255, 69, 0, 0.1), 0 8px 15px rgba(255, 69, 0, 0.1);
  backdrop-filter: blur(10px);
  /* ガラスのようなぼかしを追加 */
  transition: background 0.3s ease, box-shadow 0.3s ease;
}

.c-btn:hover {
  background: linear-gradient(135deg, #ff4500, #ff8c00);
  box-shadow: 0 4px 6px rgba(255, 69, 0, 0.2), 0 8px 15px rgba(255, 69, 0, 0.2);
}

.c-btn-ecodia {
  display: block;
  margin-right: 0;
  margin-left: auto;
  margin-top: 20px;
  margin: 0 auto;
}
@media screen and (max-width:600px) {
  .c-btn-ecodia {
    margin: 0 auto;
    margin-top: 20px;
    width:100%;
  }
}


/*FEATURE*/
.feature__card-container {
  /*max-width: 1080px;*//*20240402追記*/
  margin: 50px auto;
  margin-bottom: 20px;
  background-color: #fff;
  padding: 20px;
  border-radius: 10px;
}

.flow-container-p {
  color:#ffffff;
  text-align: center;
}

/*FEATURE-CARD*/
.card-container {
  display: flex;
  justify-content: space-between;
  margin-top: 30px;
}

.feature__card {
  width:100%;
  background-color: #fff;
  padding: 16px;
  border-radius: 5px;
  box-sizing: border-box;
  position: relative;
}
.feature__card-img-box {
  position:relative;
}

.feature__card-wrapper {
  display: flex;
  gap:100px 40px;
  /*margin-bottom: 70px;*/
  max-width: 1080px;/*20240402追記*/
  margin: 0 auto 20px;/*20240402追記*/
}
.feature__card-wrapper-reverse {
  display: flex;
  flex-direction: row-reverse;
  gap:40px;
  /*margin-bottom: 70px;*/
  max-width: 1080px;/*20240402追記*/
  margin: 0 auto 20px;/*20240402追記*/
}

.feature__card-number {
  position: absolute;
  top:-40px;
  left:88%;
  font-size: min(5.3vw, 68px);
  font-weight: bold;
  font-family: 'Roboto Condensed', sans-serif;
  font-style: italic;
  font-weight:500;
  color: #aaaaaa;
}
.feature__card-number span {
  color: #0042E0;
  font-family: 'Roboto Condensed', sans-serif;
  font-style: italic;
  font-weight: 500;
}
.feature__card-number2 {
  position: absolute;
  top:-40px;
  left:2%;
  font-size: min(5.3vw, 68px);
  font-family: 'Roboto Condensed', sans-serif;
  font-style: italic;
  font-weight:500;
  color: #aaaaaa;
}
.feature__card-number2 span {
  color: #0042E0;
  font-family: 'Roboto Condensed', sans-serif;
  font-style: italic;
  font-weight: 500;
}
.feature__card-body {
  width:100%;/*80%*/
}

.feature__card-img {
  object-fit: cover;
  border-radius: 5px;
  margin-top: 10px;
  width: 100%;
}

.feature__card-title {
  font-size: 26px;
  color: #333;
  text-align: left;
  margin: 20px 0;
}

.feature__card-text {
  font-size: 14px;
  line-height: 1.7;
  text-align: left;
  color: #555;
}

@media screen and (max-width:768px) {
  .feature__card-number{
  top:-26px;
  left:2%;
  font-size: min(5.3vw, 68px);
  }

.feature__card-number2 {
  top:-26px;
  left:2%;
  font-size: min(5.3vw, 68px);
}
}

@media screen and (max-width:600px) {
  .feature__card-wrapper {
    display: block;
    gap:100px 20px;
  }
  .feature__card-wrapper-reverse {
    display: block;
    gap:100px 20px;
  }
  .feature__card-img {
    min-width:auto;
  }
  .feature__card-number,.feature__card-number2 {
    font-size:40px;
  }
  .feature__card-number,.feature__card-number2 span {
    font-size:40px;
  }
  .feature__card-title {
    font-size:23px;
  }

}


/*20240402追記*/
/*FLOW*/
.service_container-inner .service_container_title {
  position:absolute;
  top:0;
  left:50%;
  transform: translate(-50%, 0%);
  width:100%;
  text-align: center;
  }
.service_container_title {
  font-size:25px;
}

.p-coating-top_title {
  padding: 20px 20px 0;
  }
  
  .p-coating-top_title h2{
    color: #3D69D6;
    text-align: center;
    margin-bottom: 30px;
    font-size: min(4.3vw, 50px);
  }
  .p-coating-top_title p{
    text-align: center;
    margin-top: 0;
    margin-bottom: 50px;
  }

  .commitment-sub-menu {
    display: grid;
    grid-template-columns: 350px 350px;
    gap: 10px 30px;
    max-width: 700px;
    margin: 0 auto;
  }

  .commitment-sub-link {
    display: flex;
    margin: 10px;
    border: 1px solid #ccc;
    border-radius: 5px;
    line-height: 50px;
  }

  .commitment-sub-text {
    width:240px;
    font-size: 18px;
    padding: 5px 10px;
  }

  .commitment-sub-img {
    width:70px;
    margin: 0 0 0 auto;

  }

 .feature__card:nth-child(2n){
  background-color: #f5f5f5;
  
 }

  @media screen and (max-width:600px) {
    .commitment-sub-menu {
      display: grid;
      grid-template-columns: 1fr;
      gap:5px;
      margin: 0 auto;
    }

    .feature__card-container {
      /*max-width: 1080px;*//*20240402追記*/
      margin: 0px auto;
      margin-bottom: 20px;
      background-color: #fff;
      padding: 20px;
      border-radius: 10px;
    }
  }

  /*ヘッダー部分*/
.header-logo {
  width: 360px;
}

.header-logo a {
  display: flex;
}

.header-logo_link {
  
}

.header-logo_link img {
  width:150px;
}

.header-logo_text {
  padding: 17px 15px;
  color: #fff;
  width:200px;
  font-size: 16px;
}

.header-nav-list-item {
  position: relative;
  
}


@media screen and (max-width:600px) {
  .header-logo {
    width: 300px;
  }
  .header-logo span {
    display: inline;
    font-size: 14px;
  }

  .header-logo_link img {
    width:150px;
  }
}

@media screen and (min-width:600px) {


/*.gnavi__wrap {
  width: 1200px;
  margin: 0 auto;
}
*/
.gnavi__lists {
  display: flex;
}
.gnavi__list {
  /*width: 20%;*/
  height: 60px;
  /*background-color: #E5F0F8;*/
  position: relative;
  transition: all .3s;
}
.gnavi__list:hover {
  background-color: #0071BB;
}
/*
.gnavi__list:not(:first-child)::before {
  content: "";
  width: 1px;
  height: 100%;
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  transition: all .3s;
}
*/
.gnavi__list:hover::before {
  background-color: #0071BB;
  ;/*#0071BB*/
}
.gnavi__list a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  text-decoration: none;
  /*color: #1b4059;*/
  font-size: 15px;
  letter-spacing: 0.05em;
  font-weight: 600;
  transition: all .3s;
}
.gnavi__list:hover a {
  color: #fff;
}


.dropdown__lists {
  display: none;/*デフォルトでは非表示の状態にしておく*/
  width: 100%;
  position: absolute;
  top: 60px;
  left: 0;
  z-index: 10;
}
.header-nav-list-item:hover .dropdown__lists {
  display: block;/*Gナビメニューにホバーしたら表示*/
}
.dropdown__list {
  background-color: rgba(11, 50, 144, .9);/*rgb(78 94 132)*/
  height: 60px;
  transition: all .3s;
  position: relative;
  width:180px;
}
.dropdown__list:not(:first-child)::before{
  content: "";
  width: 100%;
  height: 1px;
  background-color: #3492d1;
  position: absolute;
  top: 0;
  left: 0;
}
.dropdown__list:hover {
  background-color: #003558;
}
.dropdown__list a {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  text-decoration: none;
  position: relative;
}
.dropdown__list a::before {
  content: '';
  display: block;
  width: 6px;
  height: 6px;
  border-top: 2px solid #fff;
  border-left: 2px solid #fff;
  transform: rotate(135deg);
  position: absolute;
  right: 15px;
  top: calc(50% - 5px);
}
}