@charset "UTF-8";
header {
  box-sizing: border-box;
  padding: 30px; }
  header a img:hover {
    opacity: 0.7; }

#nav-toggle {
  display: none;
  position: absolute;
  right: 12px;
  top: 14px;
  width: 24px;
  height: 36px;
  cursor: pointer;
  z-index: 101; }
  #nav-toggle div {
    position: relative; }
  #nav-toggle span {
    display: block;
    position: absolute;
    height: 4px;
    width: 100%;
    background: #666;
    left: 0;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out; }
    #nav-toggle span:nth-child(1) {
      top: 0; }
    #nav-toggle span:nth-child(2) {
      top: 11px; }
    #nav-toggle span:nth-child(3) {
      top: 22px; }

#top-head,
.head-inner {
  width: 100%;
  padding: 0; }

#top-head {
  top: 0;
  position: fixed;
  margin-top: 0;
  background: #fff;
  box-shadow: 0 1px 6px 0 rgba(32, 33, 36, 0.28);
  z-index: 999; }

/* Fixed reset */
#head-container {
  width: 100%;
  height: 56px;
  z-index: 999;
  position: relative;
  box-sizing: border-box;
  padding: 10px; }
  #head-container .logo {
    position: absolute;
    max-width: 160px;
    width: 50%;
    top: 0; }

#global-nav {
  position: absolute;
  /* 開いてないときは画面外に配置 */
  top: -500px;
  background: #fff;
  width: 100%;
  text-align: center;
  padding: 0;
  -webkit-transition: .5s ease-in-out;
  -moz-transition: .5s ease-in-out;
  transition: .5s ease-in-out; }
  #global-nav .main-list {
    list-style: none;
    position: static;
    right: 0;
    bottom: 0;
    font-size: 1.4rem; }
    #global-nav .main-list li {
      float: none;
      position: static;
      box-sizing: border-box; }
      #global-nav .main-list li:nth-child(2) a {
        border-bottom: 0; }
      #global-nav .main-list li .main-list-sub li a {
        background: #fff;
        color: #333;
        box-sizing: border-box;
        border: 1px solid #333; }
      #global-nav .main-list li a {
        color: #fff;
        background: #333;
        border-bottom: 1px solid #fff; }
        #global-nav .main-list li a:last-child {
          margin: 0; }

.main-list-sub {
  letter-spacing: -.5em;
  width: 100%;
  font-size: 0; }
  .main-list-sub li {
    letter-spacing: normal;
    display: inline-block;
    vertical-align: middle;
    width: 33.333%;
    font-size: 1.2rem; }

#top-head #global-nav ul li a, #top-head.fixed #global-nav ul li a {
  width: 100%;
  display: block;
  padding: 0.5em 0;
  text-decoration: none; }

#nav-toggle {
  display: block; }

/* #nav-toggle 切り替えアニメーション */
.open #nav-toggle span:nth-child(1) {
  top: 11px;
  -webkit-transform: rotate(315deg);
  -moz-transform: rotate(315deg);
  transform: rotate(315deg); }
.open #nav-toggle span:nth-child(2) {
  width: 0;
  left: 50%; }
.open #nav-toggle span:nth-child(3) {
  top: 11px;
  -webkit-transform: rotate(-315deg);
  -moz-transform: rotate(-315deg);
  transform: rotate(-315deg); }
.open #global-nav {
  /* #global-nav top + #head-container height */
  -moz-transform: translateY(556px);
  -webkit-transform: translateY(556px);
  transform: translateY(556px); }

/* #global-nav スライドアニメーション */
/* sp-modal */
.head-contact-sp {
  position: absolute;
  display: inline-block;
  letter-spacing: -.5em;
  width: 80px;
  font-size: 0;
  top: 12px;
  right: 50px; }
  .head-contact-sp li {
    letter-spacing: normal;
    display: inline-block;
    vertical-align: top;
    width: 46%; }
    .head-contact-sp li:last-child {
      margin: 0 0 0 8%; }
    .head-contact-sp li a {
      display: block; }

.remodal {
  padding: 30px 20px !important;
  /*jsの上書き*/ }

.head-contact-tel-box .time {
  margin: 0;
  background: #000;
  display: block;
  color: #fff;
  padding: 4px 6px;
  border-radius: 4px; }
.head-contact-tel-box .tel a {
  font-size: 3.0rem;
  text-decoration: none;
  color: #000;
  font-weight: bold;
  position: relative;
  padding: 0 0 0 45px; }
  .head-contact-tel-box .tel a:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 14%;
    width: 38px;
    height: 22px;
    background: url(../img/icon_free.svg) no-repeat;
    background-size: contain; }
.head-contact-tel-box .line a {
  font-size: 2.6rem;
  text-decoration: underline;
  font-weight: bold;
  color: #00b900;
  position: relative;
  padding: 0 0 0 35px; }
  .head-contact-tel-box .line a:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 30px;
    height: 30px;
    background: url(../img/icon_line.svg) no-repeat;
    background-size: contain; }
.head-contact-tel-box .tel-lead {
  font-size: 1.6rem; }
  .head-contact-tel-box .tel-lead .red a {
    color: #ff0000;
    font-weight: bold;
    text-decoration: none; }
  .head-contact-tel-box .tel-lead .fb {
    font-weight: bold; }
.head-contact-tel-box:last-child {
  margin: 1.5em 0 0; }
  .head-contact-tel-box:last-child .time {
    background: #ff0000; }

.head-contact-lead {
  text-align: center;
  font-weight: bold;
  font-size: 1.4rem;
  margin: 0 0 1.0em;
  font-weight: bold; }

.head-contact-pc {
  display: none; }

/* sp-modal */
/*media Queries タブレットサイズ（768px以上）
----------------------------------------------------*/
/*media Queries PCサイズ（1000px以上）
----------------------------------------------------*/
@media only screen and (min-width: 1000px) {
  #head-container {
    width: 1100px;
    margin: 0 auto;
    padding: 0;
    height: 134px; }

  #head-container .logo {
    max-width: initial;
    width: 230px;
    top: 28%; }

  #nav-toggle {
    display: none; }

  #global-nav {
    position: relative;
    top: -1px;
    border-top: 2px solid #ff0000; }
    #global-nav .main-list {
      width: 1000px;
      height: 43.4px;
      margin: 0 auto;
      letter-spacing: -.5em; }
      #global-nav .main-list li {
        letter-spacing: normal;
        display: inline-block;
        width: 20%;
        vertical-align: top;
        position: relative; }
        #global-nav .main-list li:hover > ul > li {
          height: auto;
          overflow: visible;
          transition: .5s; }
        #global-nav .main-list li .main-list-sub {
          top: 46px;
          width: 200%;
          text-align: left; }
          #global-nav .main-list li .main-list-sub li {
            height: 0;
            overflow: hidden;
            border: 0; }
            #global-nav .main-list li .main-list-sub li a {
              text-align: center;
              background: #ff0000;
              color: #fff;
              border: 0; }
              #global-nav .main-list li .main-list-sub li a:hover {
                background: #8f0000; }
        #global-nav .main-list li a {
          border-bottom: 0;
          background: #fff;
          color: #ff0000;
          font-weight: bold;
          border-right: 1px dotted #d4d4d4; }
          #global-nav .main-list li a:first-child {
            border-left: 1px dotted #d4d4d4; }
          #global-nav .main-list li a:hover {
            color: #8f0000; }

  #top-head #global-nav ul li a, #top-head.fixed #global-nav ul li a {
    padding: 0.75em 0;
    overflow: hidden; }

  /* sp-modal */
  .head-contact-sp {
    display: none; }

  .head-contact-pc {
    display: block;
    position: absolute;
    width: 840px;
    right: 0;
    top: 10px;
    letter-spacing: normal; }
    .head-contact-pc li {
      letter-spacing: normal;
      display: inline-block;
      vertical-align: top;
      box-sizing: border-box; }
      .head-contact-pc li:first-child {
        width: 478px; }
      .head-contact-pc li:last-child {
        margin: 0 0 0 18px;
        padding: 0 0 0 18px;
        width: 340px;
        border-left: 1px solid #d4d4d4; }
    .head-contact-pc .head-contact-tel-box-wrap {
      letter-spacing: -.5em; }
    .head-contact-pc .head-contact-tel-box {
      letter-spacing: normal;
      display: inline-block;
      text-align: center;
      vertical-align: top;
      width: 234px; }
      .head-contact-pc .head-contact-tel-box:last-child {
        margin: 0 0 0 10px; }
      .head-contact-pc .head-contact-tel-box .time {
        font-size: 1.2rem;
        padding: 0; }
      .head-contact-pc .head-contact-tel-box .tel {
        line-height: 1.2; }
        .head-contact-pc .head-contact-tel-box .tel a {
          font-size: 2.2rem;
          padding: 0 0 0 32px; }
          .head-contact-pc .head-contact-tel-box .tel a:before {
            width: 26px;
            height: 15px; }
      .head-contact-pc .head-contact-tel-box .line {
        line-height: 1.2;
        margin: 4px 0 0; }
        .head-contact-pc .head-contact-tel-box .line a {
          font-size: 1.8rem;
          padding: 0 0 0 26px; }
          .head-contact-pc .head-contact-tel-box .line a:before {
            width: 22px;
            height: 22px;
            bottom: 0; }
      .head-contact-pc .head-contact-tel-box .tel-lead {
        font-size: 1.2rem;
        line-height: 1.2; }
        .head-contact-pc .head-contact-tel-box .tel-lead a {
          display: inline-block; }

  .head-contact-lead {
    margin: 0 0 0.25em;
    font-size: 1.6rem; } }
