@import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css);

html, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, legend, caption,
tbody, tfoot, thead, table, label, tr, th, td {
  margin: 0;
  padding: 0;
  border: 0;
  font-weight: normal;
  outline: 0;
  vertical-align: baseline;
  list-style: none;
  font-family: 'Noto Sans JP','ヒラギノ角ゴシック','Hiragino Sans','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3','メイリオ', Meiryo,'Meiryo UI',YuGothic,'Yu Gothic','Yu Gothic UI',sans-serif;
  font-weight: 300; }

body {
  /*固定ヘッダー分の上余白をとる*/
  padding-top: 130px; }
  body.nopadding {
    padding-top: 0; }
  body.padding-alliance {
    padding-top: 65px;
  }

header {
  padding-right: 0; }

.header-bl {
  height: 60px;
  padding: 0 20px;
  background-color: rgba(255,255,255,.8);
  border: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000; }
  .header-bl.none {
    opacity: 0;
    pointer-events: none; }
  .header-bl__logo {
    position: relative; }
    .header-bl__logo a {
      display: block; }
      .header-bl__logo a:hover {opacity: .8; }
    .header-bl__logo img {
      height: 18px;
      width: 180px;
      max-width: 180px;
      margin: 0 auto;
      display: block; }
      .header-bl__logo img.logo_white {display: none; }
  .header-bl__content {
    display: flex;
    align-items: center; }

/*ヘッダーメニュー透明ver*/
.header-bl.green {
  background-color: #51b8b9; }
  .green .header-menu {
    color: #fff; }
    .green .header-menu__item.mail a {background: url('/images/client/after201909/beforelogin/headermenu_mail_white.png') no-repeat left center/18px auto; }
    .green .header-menu__item.help a {background: url('/images/client/after201909/beforelogin/headermenu_help_white.png') no-repeat left center/auto 18px; }
    .green .header-menu__item.person a {background: url('/images/client/after201909/beforelogin/headermenu_login_white.png') no-repeat left center/auto 18px; }
  .green .header-bl__logo img.logo_white {display: block; }
  .green .header-bl__logo img.logo_normal {display: none; }

.header-menu {
  color: #333;
  display: flex;
  align-items: center;
  font-size: 12px;
  line-height: 18px; }
  .header-menu__item {
     }
    .header-menu__item + .header-menu__item {
      margin-left: 20px; }
    .header-menu__item a {
      padding-left: 26px;
      color: inherit;
      display: block; }
    .header-menu__item.mail a {background: url('/images/client/after201909/beforelogin/headermenu_mail.png') no-repeat left center/18px auto; }
    .header-menu__item.help a {background: url('/images/client/after201909/beforelogin/headermenu_help.png') no-repeat left center/auto 18px; }
    .header-menu__item.person a {background: url('/images/client/after201909/beforelogin/headermenu_login.png') no-repeat left center/auto 18px; }
    .header-menu__item.fav a { 
      padding: 12px 8px;
      display: block;
      text-align: center; }
      .header-menu__item.fav a:hover {
        background-color: #f6f6f9; }
    .header-menu__item.fav span {
      padding-left: 24px;
      background: url('/images/client/icon_fav_gray.png') no-repeat left center/20px auto;
      display: block; }
      .green .header-menu__item.fav a {
        background-image: url('/images/client/icon_fav_white.png'); }
    .header-menu__item.greenbtn {
      position: relative; }
      .header-menu__item.greenbtn > a {
        padding: 12px 22px;
        background-color: #51b8b9;
        border: 2px solid #fff;
        color: #fff;
        display: block;
        text-align: center; }
    .header-menu__item.makeoffer {
      position: relative; }
      .header-menu__item.makeoffer:hover {
        opacity: .8; }
      .header-menu__item.makeoffer > a {
        padding: 12px 22px;
        background-color: #51b8b9;
        border: 2px solid #fff;
        color: #fff;
        display: block;
        text-align: center; }
      .header-menu__item.makeoffer span {
        padding-left: 24px;
        background: url(/images/client/icon_plus_white.png) no-repeat left center/auto 15px;
        color: #fff;
        display: block; }

    .header-menu__item.account {
      width: 270px;
      min-width: 180px;
      display: flex; }
      .header-menu__item.account:hover {
        background-color: #f6f6f9; }
      .header-menu__item.account:after {
        content: "\25BC";
        color: #858b94;
        position: absolute;
        top: 22px;
        right: 30px;
        font-size: 10px; }
    .header-menu__account-icon {
      width: 40px;
      min-width: 40px;
      height: 40px;
      padding: 0;
      margin-right: 1rem;
      background-repeat: no-repeat;
      background-position: center;
      background-size: cover;
      border-radius: 50%;
      display: block; }
    .header-menu__account-name {
      width: 360px;  
      white-space: nowrap;  
      overflow: hidden;  
      text-overflow: ellipsis;  
      -webkit-text-overflow: ellipsis;  
      -o-text-overflow: ellipsis;
      color: #858b94;
      font-size: 12px;
      cursor: pointer;
      display: flex;
      align-items: center; }
    .header-menu__drop {
      border-radius: 3px;
      box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.2);
      position: absolute;
      top: 55px;
      right: 20px;
      background-color: #fff; }
    .header-menu__drop li a {
      padding: 13px 20px;
      color: #000;
      font-size: 14px;
      cursor: pointer; }
      .header-menu__drop li a:hover {
        background-color: rgba(86, 184, 184, 0.3); }

.header-menu__drop {
  display:none; }
.header-menu__item.account input[type="checkbox"]{
  display:none; }
.header-menu__item.account label[for="drop"] {
  display:block; }
.header-menu__item.account label[for="drop"]::before {
  transform:rotate(225deg); }
#dropmenu:checked + .header-menu__drop {
  display:block; }

.header-signup {
  position: absolute;
  top: 100%; right: 0;
  width: 180px;
  padding-top: 5px;
  opacity: 0;
  pointer-events: none; }
  .header-signup__list {
    padding: 12px;
    background-color: #fff;
    box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.2); }
  .header-menu__item.greenbtn > a:hover + .header-signup,
  .header-signup:hover {
    opacity: 1;
    pointer-events: auto; }
  .header-signup__client a {
    padding-left: 24px;
    background: url('/images/client/icon_login_company.png') no-repeat left center;
    color: #51b8b9; }
    .header-signup__client a:hover {
      color: #51b8b9; }
  .header-signup__cast {
    margin-top: 10px; }
    .header-signup__cast a {
      padding-left: 24px;
      background: url('/images/client/icon_login_cast.png') no-repeat left center;
      color: #fb9943; }
      .header-signup__cast a:hover {
        color: #fb9943; }

.header-searchbox {
  max-width: 100%;
  width: 300px;
  margin-right: 20px;
  background-color: #fff;
  border: 1px solid #979797;
  border-radius: 2px;
  display: flex; }
  .header-searchbox__input {
    width: 100%;
    height: 30px;
    padding: 0 18px;
    border: none;
    display: flex;
    align-items: center;
    /*default.cssの方でinput全てに16pxがimportantであたるようになっているが、この目的は「16px未満のフォントサイズを指定するとスマホのinput要素タップ時にズームされてしまうのでそれを防ぐため」なので、無関係な本要素には11pxを上書きで指定する。理想は上記のinput全てにあたる16pxを解除したいところ。*/
    font-size: 11px !important; }
  .header-searchbox__btn {
    width: 40px;
    height: 30px;
    background: url('/images/client/after201909/beforelogin/icon_search_green.png') no-repeat center/18px auto;
    border-left: 1px solid #56b8b8; }

.area-breadcrumb {
  padding: 0 16px;
  border-bottom: 1px solid #ddd; }
  .area-breadcrumb__inner {
    max-width: 1120px;
    height: 40px;
    margin: 0 auto;
    display: flex;
    align-items: center; }

.top-production {
  background-color: #edf7f8;
  text-align: center;
  font-size: 12px;
  color: #333;
  padding: 20px 30px;
  margin-top: 30px;
  line-height: 1.83; }
  .top-production__green {
    color: #56b8b8;
    display: block;
    font-size: 14px;
    font-weight: bold; }
  .top-production__btn {
    margin-top: 20px;
    color: #fff;
    font-size: 18px;
    line-height: 1.25; }
    .top-production__btn a {
      margin: 0 auto;
      display: block;
      background-color: #56b8b8;
      max-width: 400px;
      padding: 13px;
      color: inherit;
      border-radius: 3px; }
      .top-production__btn a:hover {
        color: inherit;
        opacity: 0.8; }

.logouttop-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000; }

.logouttop-graybar {
  height: 30px;
  padding-left: 20px;
  background-color: #eeeff0;
  color: #444;
  display: flex;
  justify-content: space-between;
  align-items: center; }
  .logouttop-graybar__h1 {
    font-size: 10px; }
  .logouttop-graybar__menu {
    display: flex;
    align-items: center;
    font-size: 12px;
    line-height: 16px; }
    .logouttop-graybar__menu__item {
      padding: 0 20px; }
      .logouttop-graybar__menu__item + .logouttop-graybar__menu__item {
        border-left: 1px solid #444; }
      .logouttop-graybar__menu__item a:hover {opacity: .8; }

.logouttop-whitebar {
  padding: 0 20px;
  background-color: #fff;
  box-shadow: 0 2px 7px rgba(0,0,0,.05); }
  .logouttop-whitebar--hidden.logouttop-whitebar {
    display: block; }
  .logouttop-whitebar--hidden {
    display: none; }
  .logouttop-whitebar__inner {
    max-width: 1200px;
    height: 100px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center; }
  .logouttop-whitebar__logo {
    max-width: 244px; }
    .logouttop-whitebar__logo a {
      display: block; }
      .logouttop-whitebar__logo a:hover {opacity: .8; }
    .logouttop-whitebar__logo img {
      width: 244px;
      display: block; }
    .logouttop-whitebar__logo__caption {
      margin-bottom: 10px;
      font-size: 10px;
      line-height: 1; }
  .logouttop-whitebar__rightwrap {
    display: flex;
    align-items: center; }

.logouttop-whitebarscroll {
  padding: 0 20px;
  background-color: #fff;
  box-shadow: 0 2px 7px rgba(0,0,0,.05); 
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10000; }
  .logouttop-whitebarscroll--hidden {
    display: none; }
  .logouttop-whitebarscroll__inner {
    max-width: 1200px;
    height: 70px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center; }
  .logouttop-whitebarscroll__logo {
    max-width: 244px; }
    .logouttop-whitebarscroll__logo a {
      display: block; }
      .logouttop-whitebarscroll__logo a:hover {opacity: .8; }
    .logouttop-whitebarscroll__logo img {
      width: 244px;
      display: block; }
    .logouttop-whitebarscroll__logo__caption {
      margin-bottom: 10px;
      font-size: 10px;
      line-height: 1; }
  .logouttop-whitebarscroll__rightwrap {
    display: flex; }

.logouttop-usermenu {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 12px;
  line-height: 1;
  text-align: center; }
  .logouttop-usermenu__item {
    width: 120px; }
    .logouttop-usermenu__item a {
      padding-top: 32px;
      display: block; }
      .logouttop-usermenu__item a:hover {opacity: .8; }
    .logouttop-usermenu__item--search a {
      background: url('/images/logouttop/headermenu_search.png') no-repeat center top/23px auto; }
    .logouttop-usermenu__item--contact a {
      background: url('/images/logouttop/headermenu_contact.png') no-repeat center top/26px auto; }
    .logouttop-usermenu__item--help a {
      background: url('/images/logouttop/headermenu_help.png') no-repeat center top/16px auto; }

.logouttop-signmenu {
  margin-left: 16px;
  display: flex;
  align-items: center;
  font-size: 14px;
  line-height: 1;
  text-align: center; }
  .logouttop-signmenu__item {
    width: 120px; }
    .logouttop-signmenu__item + .logouttop-signmenu__item {
      margin-left: 10px; }
    .logouttop-signmenu__item a {
      width: 100%;
      padding: 10px;
      border: 1px solid #56b8b8;
      border-radius: 18px;
      display: block; }
      .logouttop-signmenu__item a:hover {opacity: .8; }
    .logouttop-signmenu__item--signin a {
      background-color: #fff;
      color: #56b8b8; }
    .logouttop-signmenu__item--signup a {
      background-color: #56b8b8;
      color: #fff; }


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

}

@media screen and (max-width: 1179px) { 
  .header-searchbox {
    width: auto;
    margin-left: 20px; }
    .header-searchbox__input {
      padding: 0 0 0 10px; }

  .header-menu__item.fav span,
  .header-menu__item.makeoffer span {
    display: none; }
  .header-menu__item.fav a {
    background: url('/images/client/icon_fav_gray.png') no-repeat center/20px auto;
    padding: 0px;
    width: 40px;
    height: 40px; }
  .header-menu__item.makeoffer a {
    background: #51b8b9 url(/images/client/icon_plus_white.png) no-repeat center/auto 15px;
    padding: 0px;
    width: 40px;
    height: 40px; }

}

@media screen and (min-width: 1025px) {
  .max1024 {display: none !important; }

}

@media screen and (max-width: 1024px) { 
  .min1025 {display: none !important; }

  .header-bl {
    padding-right: 10px; }

  .header-hbgbtn {
    width: 40px;
    height: 40px;
    background: url('/images/client/after201909/beforelogin/icon_hbg.png') no-repeat center/20px auto;
    position: relative;
    z-index: 30; }
    .header-hbgbtn.pushed {
      background: url('/images/client/after201909/beforelogin/icon_close.png') no-repeat center/14px auto; }
    .green .header-hbgbtn {
      background-image: url('/images/client/after201909/beforelogin/icon_hbg_white.png'); }
      .green .header-hbgbtn.pushed {
        background-image: url('/images/client/after201909/beforelogin/icon_close.png'); }

  .menupanel {
    max-height: 100vh;
    width: 300px;
    padding-bottom: 60px;
    background-color: #fff;
    color: #333;
    overflow-y: scroll;
    position: absolute;
    top: 0; right: -100%;
    transition: right .4s;
    z-index: 20; }
    .menupanel.open {
      right: 0; }
    .header-hbgmenu__item a {
      padding: 10px 14px;
      display: block; }
    .menupanel__head {
      padding: 64px 16px 24px; }
    .menupanel__footer {
      padding: 64px 16px 24px; }
    .menupanel__login {
      width: 100%;
      padding: 14px;
      border: 1px solid #51b8b9;
      border-radius: 2px;
      color: #51b8b9;
      display: block;
      font-size: 14px;
      line-height: 18px;
      text-align: center; }
      .menupanel__login:hover {
        color: #51b8b9; }
      .menupanel__login span {
        padding-left: 28px;
        background: url('/images/client/after201909/beforelogin/headermenu_login_green.png') no-repeat left center;
        display: inline-block;
        font-weight: bold;
        line-height: 18px; }
    .menupanel__signin {
      width: 100%;
      margin-top: 10px;
      padding: 14px;
      background-color: #51b8b9;
      border-radius: 2px;
      color: #fff;
      display: block;
      font-size: 14px;
      font-weight: bold;
      text-align: center; }
      .menupanel__signin:hover {
        color: #fff;
        opacity: .8; }
    .menupanel__search {
      margin-top: 24px;
      border: 1px solid #979797;
      border-radius: 2px;
      display: flex;
      position: relative; }
      .menupanel__search input {
        width: calc(100% - 40px);
        height: 48px;
        padding: 0 12px;
        border: none;
        display: flex;
        align-items: center;
        font-size: 16px; }
      .menupanel__search a {
        width: 40px;
        height: 48px;
        background: url('/images/client/after201909/beforelogin/icon_search_green.png') no-repeat center/18px auto;
        position: relative; }
        .menupanel__search a::before {
          content: "";
          position: absolute;
          top: 5px; bottom: 5px; left: 0;
          width: 1px;
          background-color: #51b8b9; }


  .panelhelplink {
    margin-bottom: 24px;
    line-height: 18px;
    text-align: center; }
    .panelhelplink a {
      padding-left: 26px;
      background: url('/images/client/after201909/beforelogin/headermenu_help.png') no-repeat left center/18px auto;
      display: inline-block;
      font-size: 16px; }

  .paneltel {
    margin-bottom: 24px;
    padding-top: 18px;
    border-top: 1px solid #333;
    line-height: 1.4;
    text-align: center; }
    .paneltel__tel {
      font-size: 28px;
      font-weight: bold; }
    .paneltel__caption {
      font-size: 14px; }

  .hbgmenu {
    padding: 0 16px;
    font-size: 14px; }
    .hbgmenu__item {
      border-top: 1px solid #333; }
      .hbgmenu__item:last-child {
        border-bottom: 1px solid #333; }
      .hbgmenu__item a {
        color: inherit; }
      .hbgmenu__item > a {
        padding: 20px 40px 20px 20px;
        background: url('/images/client/after201909/beforelogin/icon_more_black333.png') no-repeat right 12px center;
        display: block;
        font-weight: bold; }
    .hbgmenu__child {
      border-top: 1px solid #333; }
      .hbgmenu__child__item + .hbgmenu__child__item {
        border-top: 1px solid #ddd; }
      .hbgmenu__child__item > a {
        padding: 20px 40px 20px 20px;
        background: url('/images/client/after201909/beforelogin/accordion_open.png') no-repeat right 12px center;
        display: block; }
        .hbgmenu__child__item.open > a {
          background-image: url('/images/client/after201909/beforelogin/accordion_close.png'); }
    .hbgmenu__grandchild {
      padding: 10px 20px;
      background-color: #fafafa;
      border-top: 1px solid #ddd; }
      .hbgmenu__grandchild__item {
        padding-left: 20px; }
        .hbgmenu__grandchild__item:hover {
          color: #51b8b9; }
        .hbgmenu__grandchild__item:first-child {
          padding-left: 0; }
        .hbgmenu__grandchild__item > a {
          padding: 10px 0;
          display: block; }

  .menucover {
    position: fixed;
    top: 0; bottom: 0; left: 0; right: 0;
    background-color: rgba(0,0,0,.6);
    opacity: 0;
    pointer-events: none;
    transition-property: opacity, pointer-events;
    transition-duration: .3s;
    z-index: 10; }
    .menucover.on {
      opacity: 1;
      pointer-events: auto; }

}


@media screen and (max-width: 768px) {
  body {
    padding-top: 0px; }

  .logouttop-header {
    position: relative;
    max-height: 180px; }

  .logouttop-whitebar {
    padding: 0; }
    .logouttop-whitebar__inner {
      height: auto;
      display: block; }

  .logouttop-signmenu {
    margin: 0; }

  .logouttop-spheadbar {
    max-width: unset;
    height: 60px;
    padding: 0 16px;
    background-color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center; }
    .logouttop-spheadbar--fixed {
      position: fixed;
      top: 0; left: 0; right: 0;
      background-color: #fff; }
    .logoutto-spheadbar__caption {
      margin-bottom: 5px;
      font-size: 10px;
      line-height: 1;
      text-align: center; }
    .logouttop-spheadbar__logo {
      width: 244px;
      margin: 0 auto; }
      .logouttop-spheadbar__logo img {
        margin: 0 auto;
        display: block; }

  .logouttop-spscrollheader {
    max-width: unset;
    height: 60px;
    padding: 0;
    background-color: #fff;
    box-shadow: 0 2px 7px rgba(0,0,0,.15);
    display: flex;
    justify-content: center;
    align-items: center;
    position: fixed;
    top: 0; left: 0; right: 0; }
    .logouttop-spscrollheader--hidden {
      display: none; }
    .logouttop-spscrollheader__caption {
      margin-bottom: 5px;
      font-size: 10px;
      line-height: 1;
      text-align: center; }
    .logouttop-spscrollheader__logo {
      width: 244px; }
      .logouttop-spscrollheader__logo img {
        margin: 0 auto;
        display: block; }

  .logouttop-spusermenu {
    height: 60px;
    padding: 0 16px;
    background-color: #fff;
    border-top: 1px solid #dbdbdb;
    display: flex;
    flex-direction: column;
    justify-content: center; }

  .logouttop-anchormenu {
    padding: 1rem 16px;
    flex-wrap: wrap; }
    .logouttop-anchormenu__item {
      margin: 2px 0; }

  .logouttop-spsignmenu {
    height: 60px;
    padding: 0 16px;
    background-color: #fff;
    border-bottom: 1px solid #dbdbdb;
    display: flex;
    justify-content: center;
    align-items: center; }

  .logouttop-hbgmenu {
    position: fixed;
    top: 0; right: 0;
    width: 60px;
    height: 60px; }
    .logouttop-hbgmenu--60 {
      top: 60px; }
      .logouttop-hbgmenu--60--hidden {
        display: none; }
    .logouttop-hbgmenu__bg {
      position: fixed;
      top: 0; bottom: 0; left: 0; right: 0;
      background-color: rgba(0,0,0,.8);
      display: none;
      z-index: 999; }
      .logouttop-hbgmenu__bg--on {
        display: block; }
    .logouttop-hbgmenu__btn {
      width: 60px;
      height: 60px;
      background: url('/images/logouttop/hbg.png') no-repeat center/26px auto;
      display: block; }
      .logouttop-hbgmenu__btn--pushed {
        background: url('/images/logouttop/hbg_close.png') no-repeat center/20px auto; }

  .logouttop-hbgmenulist {
    width: 100vw;
    position: absolute;
    background-color: #fff;
    box-shadow: 0 2px 7px rgba(0,0,0,.15);
    font-size: 14px;
    top: 100%; right: -100vw;
    transition-property: right;
    transition-duration: .3s; }
    .logouttop-hbgmenulist--open {
      right: 0; }
    .logouttop-hbgmenulist__item {
      border-bottom: 1px solid #dbdbdb; }
      .logouttop-hbgmenulist__item--gray {
        padding: 8px 16px;
        background-color: #eeeff0;
        display: flex;
        justify-content: center; }
      .logouttop-hbgmenulist__item > a {
        padding: 14px;
        background: url('/images/logoutabout/arrow_toright_gray.png') no-repeat right 20px center/11px auto;
        display: block; }
        .logouttop-hbgmenulist__item > a span {
          padding-right: 32px;
          display: block;
          line-height: 18px; }
      .logouttop-hbgmenulist__item--search > a span {
        padding-left: 32px;
        background: url('/images/logouttop/headermenu_search.png') no-repeat left center/auto 18px; }
      .logouttop-hbgmenulist__item--contact > a span {
        padding-left: 32px;
        background: url('/images/logouttop/headermenu_contact.png') no-repeat left center/18px auto; }
      .logouttop-hbgmenulist__item--help > a span {
        padding-left: 32px;
        background: url('/images/logouttop/headermenu_help.png') no-repeat left center/auto 18px; }

  .headerbar-sp {
    height: 60px;
    padding: 0 16px;
    background-color: #fff;
    border-bottom: 1px solid #e5e8ec;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: fixed;
    top: 0; left: 0;
    z-index: 10;
    right: 0; }
    .headerbar-sp__logo {
      max-width: 142px; }
      .headerbar-sp__logo.center {
        margin: 0 auto;
        display: block; }
    .headerbar-sp__list {
      display: flex;
      align-items: center; }
      .headerbar-sp__list__item {
        width: 24px;
        height: 24px;
        margin-left: 12px; }
        .headerbar-sp__list__item > a {
          width: 100%;
          height: 100%;
          display: block;
          position: relative; }
        .headerbar-sp__list__item img {
          position: absolute;
          top: 50%; left: 50%;
          transform: translate(-50%, -50%); }

  .headermenu-sp {
    position: absolute;
    top: 100%;
    right: 0;
    width: 100vw;
    height: calc(100vh - 60px);
    background-color: rgba(0, 0, 0, 0.65);
    z-index: 10; }
    .headermenu-sp__list {
      display: flex;
      flex-wrap: wrap; }
      .headermenu-sp__list__item {
        width: calc(100% / 3);
        padding: 25px 0;
        background-color: #333340;
        border-top: 1px solid #5e6369;
        border-right: 1px solid #5e6369;
        color: #858b94;
        font-size: 12px; }
        .headermenu-sp__list__item:nth-of-type(1), .headermenu-sp__list__item:nth-of-type(2), .headermenu-sp__list__item:nth-of-type(3) {
          border-top: none; }
        .headermenu-sp__list__item:nth-of-type(3n) {
          border-right: none; }
        .headermenu-sp__list__item a {
          padding-top: 32px;
          background-position: center top;
          background-repeat: no-repeat;
          background-size: 19px auto;
          color: inherit;
          display: flex;
          justify-content: center;
          align-items: center; }
        .headermenu-sp__list__item.home a {
          background-image: url("/images/client/icon_home_glay.png"); }
        .headermenu-sp__list__item.offer a {
          background-image: url("/images/client/icon_offer_glay.png"); }
        .headermenu-sp__list__item.message a {
          background-image: url("/images/client/icon_messege_glay.png"); }
        .headermenu-sp__list__item.cast a {
          background-image: url("/images/client/icon_search_glay.png"); }
        .headermenu-sp__list__item.settlement a {
          background-image: url("/images/client/icon_payment_glay.png"); }
        .headermenu-sp__list__item.edit a {
          background-image: url("/images/client/icon_setting_glay.png"); }
    .headermenu-sp__makeoffer {
      width: 100%;
      padding: 36px;
      background-color: #56b8b8;
      color: #fff;
      display: inline-block;
      font-size: 16px;
      text-align: center; }
      .headermenu-sp__makeoffer > span {
        padding-left: 24px;
        background: url("/images/client/icon_plius_white.png") no-repeat left center/16px auto;
        display: inline-block; }
    .headermenu-sp__logout {
      position: fixed;
      bottom: 0;
      left: 0;
      right: 0;
      padding: 16px;
      background-color: #fff;
      color: #56b8b8;
      display: inline-block;
      font-size: 16px;
      text-align: center; }
      .headermenu-sp__logout > span {
        padding-right: 32px;
        background: url("/images/client/logout_green.png") no-repeat right center/auto 16px; }
    .headermenu-sp__fav {
      width: 100%;
      padding: 36px;
      background-color: #333340;
      border-top: 1px solid #5e6369;
      color: #979797;
      display: inline-block;
      font-size: 16px;
      text-align: center; }
      .headermenu-sp__fav > span {
        padding-left: 24px;
        background: url(/images/client/search/icon_fav_gray.png) no-repeat left center/11px auto;
        display: inline-block;
        line-height: 18px; }

  
  .sideheading {
    border-bottom: 1px solid #333;
    line-height: 1; }
    .sideheading a {
      padding: 10px 30px 10px 10px;
      background: url('/images/client/tri_toright_333.png') no-repeat right 1.2rem center/10px auto;
      display: block;
      font-weight: bold; }
      .sideheading.current a {
        background-image: url('/images/client/tri_toright_green.png');
        background-color: #EDF7F8;
        color: #51b8b9; }
      .sideheading a:hover {
        background-image: url('/images/client/tri_toright_green.png');
        color: #51b8b9; }

.sidemenu {
  font-size: 12px;
  line-height: 1.25; }
  .sidemenu__item {
    border-bottom: 1px solid #ddd;
    position: relative; }
    .sidemenu__item.current {
      background-color: #EDF7F8;
      color: #51b8b9; }
    .sidemenu__item.flexbox a {
      display: flex;
      justify-content: space-between;
      align-items: center; }
    .sidemenu__item:hover .sidemenu__child {
      opacity: 1;
      pointer-events: auto; }
    .sidemenu__item > a {
      padding: 10px 35px 10px 20px;
      background: url('/images/client/arrow_toright_333.png') no-repeat right 10px center/14px auto;
      display: block; }
      .sidemenu__item > a:hover {
        color: #51b8b9; }
    .sidemenu__item img {
      max-height: 20px; }
    .sidemenu__item__text {
      display: inline-block;
      font-size: 10px;
      font-weight: bold;
      text-align: right; }
  .sidemenu__child {
    width: 180px;
    position: absolute;
    top: 10px; left: calc(100% - 50px);
    padding: 10px 20px;
    background-color: #fff;
    border: 1px solid #ddd;
    color: #333;
    opacity: 0;
    pointer-events: none;
    z-index: 1; }
    .sidemenu__child__item + .sidemenu__child__item {
      margin-top: 12px; }
    .sidemenu__child__item a:hover {
      color: #51b8b9; }

.sidetextlink {
  margin: 10px 0 24px;
  color: #51b8b9;
  font-size: 1.2rem; }
  .sidetextlink.text-right {
    text-align: right; }

.sidebnr {
  font-size: 14px;
  line-height: 1.25;
  position: relative;
  text-align: center; }
  .sidebnr.green {
    margin: 24px 0;
    color: #fff; }
    .sidebnr.green > a {
      padding: 16px;
      background-color: #51b8b9;
      border-radius: 2px;
      display: block; }
      .sidebnr.green > a:hover {opacity: .8;}
  .sidebnr.white > a {
    padding: 14px;
    border: 1px solid #333;
    display: block;
    font-weight: bold; }
    .sidebnr.white a:hover {opacity: .8;}

  .side-signup {
    position: absolute;
    top: 5px; left: calc(100% - 10px);
    width: 180px;
    font-size: 12px;
    opacity: 0;
    pointer-events: none;
    text-align: left; }
    .side-signup__list {
      padding: 12px;
      background-color: #fff;
      box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.2); }
    .sidebnr.signup > a:hover + .side-signup,
    .side-signup:hover {  
      opacity: 1;
      pointer-events: auto; }
    .side-signup__client a {
      padding-left: 24px;
      background: url('/images/client/icon_login_company.png') no-repeat left center;
      color: #51b8b9; }
      .side-signup__client a:hover {
        opacity: .8; }
    .side-signup__cast {
      margin-top: 10px; }
      .side-signup__cast a {
        padding-left: 24px;
        background: url('/images/client/icon_login_cast.png') no-repeat left center;
        color: #fb9943; }
        .side-signup__cast a:hover {
          opacity: .8; }

  .sidehelplink {
    margin-bottom: 24px;
    line-height: 18px;
    text-align: center; }
    .sidehelplink a {
      padding-left: 26px;
      background: url('/images/client/after201909/beforelogin/headermenu_help.png') no-repeat left center/18px auto;
      display: inline-block;
      font-size: 12px; }

  .sidetel {
    margin-bottom: 24px;
    padding-top: 18px;
    border-top: 1px solid #333;
    text-align: center; }
    .sidetel__tel {
      font-size: 18px;
      font-weight: bold; }
    .sidetel__caption {
      font-size: 11px; }

  .sp-alliancemenu {
    padding: 0 16px; }

  .sideheading {
    padding: 20px 0; }

  .sidemenu__item.flexbox a {
    padding: 20px 35px 20px 20px; }

  .sidetextlink {
    font-size: 14px; }

}

/*
 * ログイン後ヘッダー　（PC）
 */
.top-header-fixed {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10;
}
.top-header-fixed__wrap {
  height: 60px;
  padding: 0 20px;
  background-color: rgba(255, 255, 255, 0.8);
  border: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.top-header-fixed__wrap__logo {
  position: relative;
}
.top-header-fixed__wrap__logo a {
  display: block;
}
.top-header-fixed__wrap__logo img {
  height: 18px;
  margin: 0 auto;
  display: block;
}

/*
 * ログイン後ヘッダー　（SP）
 */
@media screen and (max-width: 768px) {

  .logouttop-header-margin{
    height: 60px;
    margin: 0;
    padding: 0;
  }

  .fixed{
    position: fixed !important;
  }
  .top-headerbar-sp {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10;
    right: 0;
  }
  .top-headerbar-sp__wrap {
    height: 60px;
    padding: 0 16px;
    background-color: #fff;
    border-bottom: 1px solid #e5e8ec;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .top-headerbar-sp__logo {
    max-width: 142px;
  }
  .top-headerbar-sp__logo.center {
    margin: 0 auto;
    display: block;
  }
  .top-headerbar-sp__list {
    display: flex;
    align-items: center;
  }
  .top-headerbar-sp__list__item {
    width: 24px;
    height: 24px;
    margin-left: 12px;
  }
  .top-headerbar-sp__list__item > a {
    width: 100%;
    height: 100%;
    display: block;
    position: relative;
  }
  .top-headerbar-sp__list__item img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }

  .top-headermenu-sp {
    position: absolute;
    top: 100%;
    right: 0;
    width: 100vw;
    height: calc(100vh - 60px);
    background-color: rgba(0, 0, 0, 0.65);
    z-index: 10;
  }
  .top-headermenu-sp__list {
    display: flex;
    flex-wrap: wrap;
  }
  .top-headermenu-sp__list__item {
    width: calc(100% / 3);
    padding: 25px 0;
    background-color: #333340;
    border-top: 1px solid #5e6369;
    border-right: 1px solid #5e6369;
    color: #858b94;
    font-size: 12px;
  }
  .top-headermenu-sp__list__item:nth-of-type(1),
  .top-headermenu-sp__list__item:nth-of-type(2),
  .top-headermenu-sp__list__item:nth-of-type(3) {
    border-top: none;
  }
  .top-headermenu-sp__list__item:nth-of-type(3n) {
    border-right: none;
  }
  .top-headermenu-sp__list__item a {
    padding-top: 32px;
    background-position: center top;
    background-repeat: no-repeat;
    background-size: 19px auto;
    color: inherit;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .top-headermenu-sp__list__item.home a {
    background-image: url("/images/client/icon_home_glay.png");
  }
  .top-headermenu-sp__list__item.offer a {
    background-image: url("/images/client/icon_offer_glay.png");
  }
  .top-headermenu-sp__list__item.message a {
    background-image: url("/images/client/icon_messege_glay.png");
  }
  .top-headermenu-sp__list__item.cast a {
    background-image: url("/images/client/icon_search_glay.png");
  }
  .top-headermenu-sp__list__item.settlement a {
    background-image: url("/images/client/icon_payment_glay.png");
  }
  .top-headermenu-sp__list__item.edit a {
    background-image: url("/images/client/icon_setting_glay.png");
  }
  .top-headermenu-sp__makeoffer {
    width: 100%;
    padding: 36px;
    background-color: #56b8b8;
    color: #fff;
    display: inline-block;
    font-size: 16px;
    text-align: center;
  }
  .top-headermenu-sp__makeoffer > span {
    padding-left: 24px;
    background: url("/images/client/icon_plius_white.png") no-repeat left
      center/16px auto;
    display: inline-block;
  }
  .top-headermenu-sp__logout {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 16px;
    background-color: #fff;
    color: #56b8b8;
    display: inline-block;
    font-size: 16px;
    text-align: center;
  }
  .top-headermenu-sp__logout > span {
    padding-right: 32px;
    background: url("/images/client/logout_green.png") no-repeat right
      center/auto 16px;
  }
  .top-headermenu-sp__fav {
    width: 100%;
    padding: 36px;
    background-color: #333340;
    border-top: 1px solid #5e6369;
    color: #979797;
    display: inline-block;
    font-size: 16px;
    text-align: center;
  }
  .top-headermenu-sp__fav > span {
    padding-left: 24px;
    background: url(/images/client/search/icon_fav_gray.png) no-repeat left
      center/11px auto;
    display: inline-block;
    line-height: 18px;
  }
}