@charset "UTF-8";
/*
Theme Name: Calidus
Theme URL: テーマのサイトのURI
Description: Calidusのホームページです。
Author: Calidus
*/

/*===============================================
●style_sp.css 
===============================================*/
@media screen and (max-width: 950px) {
  .pc_header img {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  .for_pc {
    display: none;
  }

  /*--------------------------------------------
		ヘッダー
--------------------------------------------*/
  .sp_header {
    height: 65px;
    display: flex;
    justify-content: space-between;
    padding: 0 5%;
    box-sizing: border-box;
  }

  .sp_header .logo {
    width: 100%;
    display: flex;
    justify-content: space-between;
  }

  .sp_header .logo img {
    width: 13rem;
    height: 60px;
  }

  .sp_header a.btn.contact {
    display: inline-block;
    margin-top: 1rem;
    font-size: 1.4rem;
    margin-right: 5rem;
    margin-bottom: 1rem;
  }

  .sp_header a.btn.contact:hover {
    background: #E4572D;
  }

  .nav {
    position: fixed;
    width: 67%;
    text-align: right;
  }

  /*ハンバーガーMENU*/
  nav.NavMenu {
    position: fixed;
    z-index: 12;
    top: 0;
    left: 0;
    background: #FBE7DE;
    text-align: center;
    width: 100%;
    height: 100%;
    display: none;
  }

  nav.NavMenu ul {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    padding: 0 5%;
    transform: translateY(-50%) translateX(-50%);
  }

  nav.NavMenu ul li {
    width: 100%;
    padding-bottom: 0px;
  }

  nav.NavMenu ul li img {
    max-width: 200px;
  }

  nav.NavMenu ul li a {
    display: block;
    padding: 12px 0;
    font-size: 1.8rem;
    font-weight: 700;
    color: #DD5519;
    text-decoration: none;
  }

  nav.NavMenu .contact .btn {
    width: 80%;
    max-width: 240px;
    font-size: 1.6rem;
    padding: 12px 12px;
    display: block;
    margin: 1rem auto 0;
  }

  /*ボタンのスタイル*/
  .Toggle {
    position: fixed;
    right: 4%;
    top: 2%;
    width: 45px;
    height: 45px;
    cursor: pointer;
    z-index: 13;
    display: block;
  }

  .Toggle span {
    display: block;
    position: absolute;
    width: 2.9rem;
    border-bottom: solid 3px #DD5519;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
    left: 6px;
  }

  .Toggle span:nth-child(1) {
    top: 22%;
  }

  .Toggle span:nth-child(2) {
    top: 41%;
    width: 2.2rem;
    left: 1.2rem;
  }

  .Toggle span:nth-child(3) {
    top: 60%;
    width: 1.5rem;
    left: 1.9rem;

  }

  .Toggle.active span:nth-child(1) {
    top: 18px;
    left: 6px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
    border-bottom: solid 3px #DD5519;
  }

  .Toggle.active span:nth-child(2),
  .Toggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
    border-bottom: solid 3px #DD5519;
  }

  .Toggle.active span:nth-child(2) {
    width: 2.9rem;
    left: 7px;
  }

  .Toggle.active span:nth-child(3) {
    width: 2.9rem;
    left: 7px;
  }

  /*--------------------------------------------
		サイト基本設定
--------------------------------------------*/
  section {
    padding: 60px 0;
  }

  .inner {
    max-width: 100%;
    padding: 0 5%;
  }

  h2 {
    font-size: 4.8rem;
    margin-bottom: 24px;
  }

  h3 {
    font-size: 2.4rem;
  }

  h4 {
    font-size: 1.8rem;
  }

  p {
    margin-bottom: 24px;
  }

  .btn {
    padding: 6px 12px;
  }

  table tr th {
    padding: 4px 14px;
    width: 29%;
  }

  table tr td {
    padding: 4px 14px;
    display: table-cell;
  }

  .ttlArea {
    background: #EFEFEF;
    background-image: url(img/title_bg_sp.svg);
    background-repeat: no-repeat;
    background-position: right 0px top 50%;
    padding: 20px 0;
  }

  /*--------------------------------------------
		フッター
--------------------------------------------*/
  footer {
    padding: 50px 0;
  }

  footer .contentsArea {
    display: block;
  }

  footer .btn {
    text-align: center;
    margin-bottom: 20px;
  }

  footer ul {
    display: block;
  }

  footer ul li {
    margin-right: 0;
  }

  footer .bottomArea {
    display: block;
  }

  footer .bottomArea a {
    font-weight: normal;
    display: block;
    margin-bottom: 20px;
  }

  /*--------------------------------------------
		トップページ
--------------------------------------------*/
  /* FV */
  /* #fv {
    height: 555px;
  } */

  /* #fv .keyimg {
    height: 50%;
    border-radius: 0 0 0 100px;
    width: calc(0% + 80%);
  }

  #fv .txtArea img.logo {
    max-width: 270px;
    margin-bottom: 14px;
  }

  #fv .txtArea img.main {
    max-width: 160px;
    left: 3%;
    top: -110%;
  }

  #fv .txtArea {
    z-index: 2;
    transform: translateY(140%);
    text-align: center;
  }

  #fv .txtArea p {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 20px;
    line-height: 1.5;
  }

  #fv .txtArea .btn {
    width: 100%;
    margin: 0 auto;
  } */

  /* News：最新記事 */
  #news_new {
    padding: 30px 0 0;
  }

  #news_new .new {
    max-width: 100%;
  }


  /*--------------------------------------------
		お問い合わせ
--------------------------------------------*/
  #contact {
    background: #DD5519;
    background-image: url(img/contact_bg.svg);
    background-repeat: no-repeat;
    background-position: right 1200% top 0px;
  }

  #contact .inner h2 {
    margin-bottom: 0;
  }

  #contact .contentsArea {
    padding: 30px 16px;
    max-width: 100%;
  }

  #contact .contact_txt {
    position: absolute;
    bottom: -60px;
    right: 0;
    max-width: 100%;
  }

  /*お問い合わせフォーム*/
  #contact .name {
    display: block;
  }

  #contact .name .name_sei,
  #contact .name .name_mei {
    width: 100%;
  }

  #contact input,
  #contact textarea {
    box-sizing: border-box;
  }

  .checkout div p span span {
    margin-left: 0rem;
    width: 100%;
    margin-bottom: 1rem;
  }

  .wpcf7-list-item {
    margin: 0;
  }

  #contact .send_button p:after {
    right: 14%;
  }

  /* News：ニュース */
  #top_news h2 {
    text-align: left;
    margin-left: 5%;
  }

  /*--------------------------------------------
    お問い合わせ完了
--------------------------------------------*/
  #thanks h2 {
    font-size: 2.4rem;
  }

  /*--------------------------------------------
    お知らせ
--------------------------------------------*/
  #news .inner {
    display: block;
  }

  #news .inner #main {
    width: 100%;
  }

  #news .inner #main ul li:last-child,
  #news .inner #side ul li:last-child {
    margin-bottom: 0;
  }

  #news #main .txtArea img {
    width: 100%;
  }

  /* カテゴリー */
  #news .inner #side {
    width: 100%;
    margin-top: 60px;
  }

  /*--------------------------------------------
		プライバシーポリシー
--------------------------------------------*/
  h2.privacy {
    font-size: 4.5rem !important;
  }

  #privacypolicy h4:before {
    height: 26px;
  }

}