@charset "UTF-8";
/* COMPASS
 * ----------------------------------------------- */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}

q, blockquote {
  quotes: none;
}
q:before, q:after, blockquote:before, blockquote:after {
  content: "";
  content: none;
}

a img {
  border: none;
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block;
}

/* BASE
 * ----------------------------------------------- */
/* ADDITIONAL RESET
 * ----------------------------------------------- */
*,
*:before,
*:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

body * {
  max-height: 99999em;
}

body img {
  max-height: none;
}

input,
label,
select,
button,
textarea {
  margin: 0;
  border: 0;
  padding: 0;
  display: inline-block;
  vertical-align: middle;
  white-space: normal;
  background: none;
  font: inherit;
  line-height: 1;
}

input:focus,
button:focus,
select:focus {
  outline: 0;
}

/* Make webkit render the search input like a normal text field */
input[type=search] {
  -webkit-appearance: textfield;
}

/* Turn off the recent search for webkit. It adds about 15px padding on the left */
::-webkit-search-decoration {
  display: none;
}

/* Turn off scroll bars in IE unless needed */
textarea {
  overflow: auto;
  white-space: pre-line;
}

/* PRINTING
 * ----------------------------------------------- */
@media print {
  body {
    -webkit-print-color-adjust: exact;
  }

  html,
  body {
    margin: 0;
  }

  @page {
    margin: 0;
  }
  @page :left {
    margin: 0;
  }
  @page :right {
    margin: 0;
  }
  @page :first {
    margin-top: 0;
  }
  .wow {
    visibility: visible !important;
  }
}
/* GENERAL
 * ----------------------------------------------- */
.overflow-hidden {
  overflow: hidden !important;
}

body {
  color: #4D4D4D;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.4;
  -webkit-text-size-adjust: none;
  -moz-text-size-adjust: none;
  -ms-text-size-adjust: none;
  padding-top: 100px;
}
body.is-pt0 {
  padding-top: 0 !important;
}

.is-lato {
  font-family: "Lato", sans-serif;
}

.is-notosan {
  font-family: "Noto Sans JP", sans-serif;
}

.is-serif {
  font-family: "Noto Serif JP", serif;
}

.is-barlow {
  font-family: "Barlow Condensed", sans-serif;
}

/* HELPERS
 * ----------------------------------------------- */
.pointer {
  cursor: pointer;
}

a {
  color: #4D4D4D;
  text-decoration: none;
}

small {
  font-size: 80%;
}

.hidden {
  display: none;
}

.invisible {
  visibility: hidden;
}

.text-nowrap {
  white-space: nowrap;
}

.container {
  position: relative;
  font-family: "Noto Sans JP", sans-serif;
}

.wrapper {
  max-width: 1000px;
  padding-left: 10px;
  padding-right: 10px;
  margin-left: auto;
  margin-right: auto;
}

.trans.is-block {
  display: block;
}

main, .main-wrapper {
  font-family: "Noto Sans JP", sans-serif;
}
main p:not(.text-desc):not(.desc):not(.text-catchcopy), .main-wrapper p:not(.text-desc):not(.desc):not(.text-catchcopy) {
  line-height: inherit;
}
main .wrapper.is-small, .main-wrapper .wrapper.is-small {
  max-width: 950px;
}
main .wrapper.is-mb60, .main-wrapper .wrapper.is-mb60 {
  margin-bottom: 60px;
}
main .wrapper.is-mb40, .main-wrapper .wrapper.is-mb40 {
  margin-bottom: 40px;
}

/* RESPONSIVE
 * ----------------------------------------------- */
.small-inline {
  display: block;
}

.small-show {
  display: none;
}

@media (min-width: 1100.1px) {
  .desktop-block {
    display: block;
  }
}
@media print, (min-width: 768px) {
  a.tel, a.tel-pointer {
    pointer-events: none;
  }

  .trans {
    filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
    opacity: 1;
    -moz-transition: opacity 0.26s ease;
    -o-transition: opacity 0.26s ease;
    -webkit-transition: opacity 0.26s ease;
    transition: opacity 0.26s ease;
  }
  .trans:hover {
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80);
    opacity: 0.8;
  }

  .sm {
    display: none !important;
  }

  .md-block {
    display: block !important;
  }
}
@media screen and (min-width: 768.1px) {
  .pc-show {
    display: block !important;
  }

  .sp-show {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .pc-show {
    display: none !important;
  }

  .sp-show {
    display: block !important;
  }
}
@media (max-width: 767px) {
  body {
    padding-top: 0 !important;
  }
}
@media (max-width: 576px) {
  body {
    font-size: 14px;
  }

  main .wrapper.is-mb60, main .wrapper.is-mb30, .main-wrapper .wrapper.is-mb60, .main-wrapper .wrapper.is-mb30 {
    margin-bottom: 30px;
  }

  .small-block {
    display: block;
  }
  .small-inline {
    display: inline-block;
  }
  .small-show {
    display: block;
  }

  .container {
    width: auto;
    min-width: 320px;
  }

  .wrapper {
    width: auto;
    margin: 0;
    padding-left: 10px;
    padding-right: 10px;
  }
}
/* PARTS
 * ----------------------------------------------- */
.is-toggle-nav .header-row {
  top: 0;
}

.logo {
  display: inline-block;
  color: #754C24;
}
.logo .link {
  display: block;
  color: currentColor;
}
.logo .img {
  line-height: 1;
}
.logo .text {
  font-weight: 500;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
  line-height: 1;
}

header {
  position: relative;
  padding: 0;
}
header .logo {
  text-align: center;
  width: 135px;
  height: 95px;
  padding: 10px;
  background-color: #fff;
}
header .logo .img {
  display: block;
  margin-bottom: 0.15rem;
}
header .logo .text {
  font-size: 17px;
}

.header-fixed {
  width: 100%;
  position: fixed;
  z-index: 980;
  left: 0;
  top: 0;
}
.header-row {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: flex-start;
  align-items: flex-start;
  position: fixed;
  z-index: 999;
  width: 100%;
  left: 0;
  top: 100px;
  -moz-transition: all 0.25s ease;
  -o-transition: all 0.25s ease;
  -webkit-transition: all 0.25s ease;
  transition: all 0.25s ease;
}
.header-row.is-top {
  top: 0;
}
.header-row .left {
  position: absolute;
  z-index: 10;
  top: 0;
  left: 0;
}
.header-row .right {
  position: absolute;
  z-index: 10;
  top: 0;
  right: 0;
}

@media (max-width: 767px) {
  .logo {
    width: 130px;
  }

  .header-primary {
    display: none;
  }
  .header-fixed {
    min-width: 100%;
  }
  .header-fixed + main {
    margin-top: 0;
  }
  .header-row {
    top: 0;
  }
}
@media (max-width: 740px) {
  header .logo {
    width: 100px;
    height: 70px;
  }
  header .logo img {
    width: 80px;
  }
  header .logo .text {
    font-size: 12px;
  }
}
footer {
  padding: 0;
  margin: 0;
  color: #4D4D4D;
  background-color: #eee;
}
footer .logo {
  color: #000;
}
footer .logo .link {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-end;
  align-items: flex-end;
}
footer .logo .text {
  font-size: 20px;
  margin-left: 15px;
}

.copyright {
  font-size: 10px;
  font-family: "Noto Sans JP", sans-serif;
  text-align: right;
  letter-spacing: 0.08em;
  padding-left: 20px;
}

.fnav {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 -8px;
}
.fnav > * {
  padding: 0 8px;
}
.fnav-item {
  text-align: center;
}
.fnav-link {
  position: relative;
  display: inline-block;
  font-size: 11px;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.1em;
  color: currentColor;
}
.fnav-link:before {
  content: ">";
  display: inline-block;
  color: #ED0614;
  margin-right: 3px;
}

.footer-row {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.footer-nav {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
  -webkit-align-items: center;
  align-items: center;
}
.footer-totop {
  background-color: #ED0614;
  text-align: center;
  padding: 0;
}
.footer-totop .totop {
  -moz-user-select: -moz-none;
  -ms-user-select: none;
  -webkit-user-select: none;
  user-select: none;
  display: block;
  text-transform: uppercase;
  font-size: 18px;
  font-weight: 500;
  font-family: "Barlow Condensed", sans-serif;
  color: #fff;
  line-height: 1;
  padding: 15px 0;
}
.footer-totop .ico {
  display: inline-block;
  padding-top: 15px;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: 35px;
  background-image: url(../img/common/ico_totop.png);
}
.footer-main {
  padding: 20px 20px;
}
@media (max-width: 1100px) {
  .footer-nav {
    display: block;
  }
}
@media (max-width: 767px) {
  .footer-row {
    display: block;
  }
  .footer-logo {
    text-align: center;
    margin-bottom: 15px;
  }
  .footer-nav .fnav {
    -webkit-justify-content: center;
    justify-content: center;
    padding-bottom: 10px;
  }
  .footer-nav .copyright {
    text-align: center;
    padding: 0;
  }
}

@media (max-width: 740px) {
  footer .logo .text {
    font-size: 14px;
  }
}
@media (max-width: 767px) {
  .footer-primary #shutto-component-8 #Footer_Container .Left {
    font-size: 14px;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
@media screen and (max-width: 768px) {
  .footer-primary #shutto-component-8 #Footer_Container ul#f_navi_3 {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}

.navbar-wrapper {
  z-index: 10;
}

.nav-link {
  width: 300px;
  text-align: left;
  display: block;
  padding: 10px 0;
  margin-bottom: 8px;
  color: #ED0614;
  font-size: 31px;
  font-weight: 500;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
  letter-spacing: -0.025em;
  line-height: 1;
  text-decoration: none;
}
.nav-main {
  text-align: center;
  display: flex;
  flex-wrap: wrap;
  max-width: 1096px;
  margin: 0 auto;
  position: relative;
  z-index: 9;
}
.nav-item {
  width: auto;
  position: relative;
  color: #fff;
  width: 25%;
  padding: 15px 20px;
}
.nav-main .nav-item:nth-of-type(2) a{
	pointer-events: none;
	opacity: .5;
}
.nav-dropdown {
  width: 100%;
  text-align: left;
}
.nav-dropdown .dropdown-item {
  position: relative;
  color: #fff;
  font-size: 13px;
  font-weight: 500;
  padding: 0 10px 0 1em;
  letter-spacing: 0.05em;
  line-height: 1.6;
  display: block;
}
.nav-dropdown .dropdown-item:not(:first-child) {
  margin-top: 15px;
}
.nav-dropdown .dropdown-item:before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}
.nav-dropdown .dropdown-item.is-disabled {
  pointer-events: none;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=60);
  opacity: 0.6;
}

.navbar-nav {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}
.navbar-link, .navbar-toggler {
  position: relative;
  z-index: 10;
}
.navbar-link {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  text-align: center;
  background-color: #754C24;
  padding: 10px 30px;
}
.navbar-link .link {
  position: relative;
  display: inline-block;
  color: #fff;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-align: center;
  text-transform: uppercase;
  padding-right: 60px;
}
.navbar-link .link:after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 50px;
  height: 13px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url(../img/common/ico_arrow_white.png);
}
.navbar-toggler {
  cursor: pointer;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  width: 65px;
  height: 65px;
  background: #ED0614;
  padding: 5px;
  line-height: 0;
  text-align: center;
}
.navbar-toggler .toggler-btn {
  position: relative;
  display: inline-block;
  width: 25px;
  height: 22px;
  margin-bottom: 8px;
}
.navbar-toggler .toggler-btn span {
  display: block;
  width: 100%;
  height: 2px;
  position: absolute;
  left: 0;
  background: #fff;
}
.navbar-toggler .toggler-btn span:nth-child(1) {
  -moz-animation: menu-bar01 0.75s forwards;
  -webkit-animation: menu-bar01 0.75s forwards;
  animation: menu-bar01 0.75s forwards;
  top: 0;
}
.navbar-toggler .toggler-btn span:nth-child(2) {
  top: 50%;
  filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
  opacity: 1;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -moz-transition: all 0.25s 0.25s;
  -o-transition: all 0.25s 0.25s;
  -webkit-transition: all 0.25s;
  -webkit-transition-delay: 0.25s;
  transition: all 0.25s 0.25s;
}
.navbar-toggler .toggler-btn span:nth-child(3) {
  bottom: 0;
  -moz-animation: menu-bar02 0.75s forwards;
  -webkit-animation: menu-bar02 0.75s forwards;
  animation: menu-bar02 0.75s forwards;
}
.navbar-toggler .toggler-btn.is-active span:nth-of-type(1) {
  -moz-animation: active-menu-bar01 0.75s forwards;
  -webkit-animation: active-menu-bar01 0.75s forwards;
  animation: active-menu-bar01 0.75s forwards;
}
.navbar-toggler .toggler-btn.is-active span:nth-of-type(2) {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
  opacity: 0;
}
.navbar-toggler .toggler-btn.is-active span:nth-of-type(3) {
  -moz-animation: active-menu-bar03 0.75s forwards;
  -webkit-animation: active-menu-bar03 0.75s forwards;
  animation: active-menu-bar03 0.75s forwards;
}
.navbar-toggler .toggler-text {
  display: block;
  font-size: 13px;
  letter-spacing: 0.06em;
  color: #fff;
  text-transform: uppercase;
  line-height: 1;
}
.navbar-toggler .toggler-text .open {
  display: none;
}
.navbar-toggler .toggler-text .close {
  display: block;
}
.navbar-toggler.is-active .toggler-text .open {
  display: block;
}
.navbar-toggler.is-active .toggler-text .close {
  display: none;
}
.navbar-collapse {
  display: none;
  position: fixed;
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
  background-color: rgba(0, 0, 0, 0.9);
}
.navbar-collapse .middle {
  position: relative;
  height: 100%;
  padding: 50px 0;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
}
.navbar-collapse.is-active .middle {
  overflow: auto;
}

@media print, (min-width: 768px) {
  .middle .line-wrap {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
  }
  .middle .line-vertical {
    max-width: 1096px;
    margin: 0 auto;
    position: relative;
    height: 100%;
  }
  .middle .line-vertical span {
    display: block;
    height: 100%;
    position: absolute;
    width: 1px;
    background: #333;
    top: 0;
    left: 0;
  }
  .middle .line-vertical .line2 {
    left: 25%;
  }
  .middle .line-vertical .line3 {
    left: 50%;
  }
  .middle .line-vertical .line4 {
    left: 75%;
  }
  .middle .line-vertical .line5 {
    left: 100%;
  }
}
@media (max-width: 740px) {
  .line-wrap {
    display: none !important;
  }

  .navbar-link {
    padding: 10px 15px;
  }
  .navbar-link .link {
    font-size: 16px;
    padding-right: 30px;
  }
  .navbar-link .link:after {
    width: 25px;
    height: 7px;
  }
  .navbar-toggler {
    width: 50px;
    height: 50px;
  }
  .navbar-toggler .toggler-text {
    font-size: 10px;
  }
  .navbar-collapse .middle {
    flex-direction: column;
    justify-content: flex-start;
  }

  .nav-main {
    display: block;
  }

  .nav-item {
    width: auto;
    display: flex;
    padding: 15px 0;
    -webkit-align-items: center;
    align-items: center;
  }
  .nav-item:not(:last-child) {
    border-bottom: 1px solid #333;
  }

  .nav-link {
    font-size: 20px;
    width: 120px;
    padding: 10px;
    margin: 0;
  }

  .nav-dropdown .dropdown-item {
    margin: 0;
  }
}
@media (max-width: 576px) {
  .nav-item {
    padding-top: 10px;
    padding-bottom: 10px;
  }
  .nav-dropdown .dropdown-item {
    font-size: 13px;
    line-height: 2;
  }

  .navbar-collapse .middle {
    padding: 60px 10px 10px 10px;
  }
  .navbar-toggler .toggler-btn span:nth-of-type(1) {
    top: 4px;
  }
  .navbar-toggler .toggler-btn span:nth-of-type(2) {
    margin-top: 2px;
  }
  .navbar-toggler .toggler-btn.is-active span:nth-of-type(3) {
    bottom: -4px;
  }
}
@media (max-width: 320px) {
  .nav-link {
    font-size: 20px;
    width: 100px;
  }
  .nav-dropdown .dropdown-item {
    font-size: 14px;
    line-height: 2;
  }

  .navbar-collapse .middle {
    padding: 60px 10px 10px 10px;
  }
}
@-webkit-keyframes menu-bar01 {
  0% {
    -moz-transform: translateY(10px) rotate(45deg);
    -ms-transform: translateY(10px) rotate(45deg);
    -webkit-transform: translateY(10px) rotate(45deg);
    transform: translateY(10px) rotate(45deg);
  }
  50% {
    -moz-transform: translateY(10px) rotate(0);
    -ms-transform: translateY(10px) rotate(0);
    -webkit-transform: translateY(10px) rotate(0);
    transform: translateY(10px) rotate(0);
  }
  100% {
    -moz-transform: translateY(0) rotate(0);
    -ms-transform: translateY(0) rotate(0);
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0);
  }
}
@keyframes menu-bar01 {
  0% {
    -moz-transform: translateY(10px) rotate(45deg);
    -ms-transform: translateY(10px) rotate(45deg);
    -webkit-transform: translateY(10px) rotate(45deg);
    transform: translateY(10px) rotate(45deg);
  }
  50% {
    -moz-transform: translateY(10px) rotate(0);
    -ms-transform: translateY(10px) rotate(0);
    -webkit-transform: translateY(10px) rotate(0);
    transform: translateY(10px) rotate(0);
  }
  100% {
    -moz-transform: translateY(0) rotate(0);
    -ms-transform: translateY(0) rotate(0);
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0);
  }
}
@-webkit-keyframes menu-bar02 {
  0% {
    -moz-transform: translateY(-10px) rotate(-45deg);
    -ms-transform: translateY(-10px) rotate(-45deg);
    -webkit-transform: translateY(-10px) rotate(-45deg);
    transform: translateY(-10px) rotate(-45deg);
  }
  50% {
    -moz-transform: translateY(-10px) rotate(0);
    -ms-transform: translateY(-10px) rotate(0);
    -webkit-transform: translateY(-10px) rotate(0);
    transform: translateY(-10px) rotate(0);
  }
  100% {
    -moz-transform: translateY(0) rotate(0);
    -ms-transform: translateY(0) rotate(0);
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0);
  }
}
@keyframes menu-bar02 {
  0% {
    -moz-transform: translateY(-10px) rotate(-45deg);
    -ms-transform: translateY(-10px) rotate(-45deg);
    -webkit-transform: translateY(-10px) rotate(-45deg);
    transform: translateY(-10px) rotate(-45deg);
  }
  50% {
    -moz-transform: translateY(-10px) rotate(0);
    -ms-transform: translateY(-10px) rotate(0);
    -webkit-transform: translateY(-10px) rotate(0);
    transform: translateY(-10px) rotate(0);
  }
  100% {
    -moz-transform: translateY(0) rotate(0);
    -ms-transform: translateY(0) rotate(0);
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0);
  }
}
@-webkit-keyframes active-menu-bar01 {
  0% {
    -moz-transform: translateY(0) rotate(0);
    -ms-transform: translateY(0) rotate(0);
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0);
  }
  50% {
    -moz-transform: translateY(10px) rotate(0);
    -ms-transform: translateY(10px) rotate(0);
    -webkit-transform: translateY(10px) rotate(0);
    transform: translateY(10px) rotate(0);
  }
  100% {
    -moz-transform: translateY(10px) rotate(45deg);
    -ms-transform: translateY(10px) rotate(45deg);
    -webkit-transform: translateY(10px) rotate(45deg);
    transform: translateY(10px) rotate(45deg);
  }
}
@keyframes active-menu-bar01 {
  0% {
    -moz-transform: translateY(0) rotate(0);
    -ms-transform: translateY(0) rotate(0);
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0);
  }
  50% {
    -moz-transform: translateY(10px) rotate(0);
    -ms-transform: translateY(10px) rotate(0);
    -webkit-transform: translateY(10px) rotate(0);
    transform: translateY(10px) rotate(0);
  }
  100% {
    -moz-transform: translateY(10px) rotate(45deg);
    -ms-transform: translateY(10px) rotate(45deg);
    -webkit-transform: translateY(10px) rotate(45deg);
    transform: translateY(10px) rotate(45deg);
  }
}
@-webkit-keyframes active-menu-bar03 {
  0% {
    -moz-transform: translateY(0) rotate(0);
    -ms-transform: translateY(0) rotate(0);
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0);
  }
  50% {
    -moz-transform: translateY(-10px) rotate(0);
    -ms-transform: translateY(-10px) rotate(0);
    -webkit-transform: translateY(-10px) rotate(0);
    transform: translateY(-10px) rotate(0);
  }
  100% {
    -moz-transform: translateY(-10px) rotate(-45deg);
    -ms-transform: translateY(-10px) rotate(-45deg);
    -webkit-transform: translateY(-10px) rotate(-45deg);
    transform: translateY(-10px) rotate(-45deg);
  }
}
@keyframes active-menu-bar03 {
  0% {
    -moz-transform: translateY(0) rotate(0);
    -ms-transform: translateY(0) rotate(0);
    -webkit-transform: translateY(0) rotate(0);
    transform: translateY(0) rotate(0);
  }
  50% {
    -moz-transform: translateY(-10px) rotate(0);
    -ms-transform: translateY(-10px) rotate(0);
    -webkit-transform: translateY(-10px) rotate(0);
    transform: translateY(-10px) rotate(0);
  }
  100% {
    -moz-transform: translateY(-10px) rotate(-45deg);
    -ms-transform: translateY(-10px) rotate(-45deg);
    -webkit-transform: translateY(-10px) rotate(-45deg);
    transform: translateY(-10px) rotate(-45deg);
  }
}
* {
  outline-style: none;
}

section > *:last-child, div:not(.row) > *:last-child, ul:not(.row):not(.staff-list):not(.list):not(.group-paper) > *:last-child, li > *:last-child, dl > *:last-child, dt > *:last-child, dd > *:last-child, th > *:last-child, td > *:last-child {
  margin-bottom: 0;
}

iframe {
  border: 0;
  width: 100%;
}

img {
  vertical-align: middle;
  max-width: 100%;
}

.mb0 {
  margin-bottom: 0 !important;
}

.mt-20 {
  margin-top: -20px !important;
}

.is-font-16 {
  font-size: 16px !important;
}

hr.line-solid {
  margin: 55px 0;
  border: 0;
  border-bottom: 1px solid #fff;
}

.coming-soon {
  pointer-events: none;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  position: absolute;
  z-index: 10;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  color: #fff;
  text-transform: uppercase;
  font-size: 16px;
  text-align: center;
  letter-spacing: 0.1em;
}

.mr-center {
  margin-left: auto !important;
  margin-right: auto !important;
}

.text-left {
  text-align: left !important;
}
.text-right {
  text-align: right !important;
}
.text-center {
  text-align: center !important;
}
.text-justify {
  text-align: justify !important;
}
.text-bold {
  font-weight: 700 !important;
}
.text-white {
  color: #fff;
}
.text-red {
  color: #ED0614;
}
.text-sky {
  color: #29B6FF;
}
.text-brown {
  color: #754C24;
}
.text-desc {
  font-size: 13px;
  line-height: 2;
  letter-spacing: 0.06em;
  margin-bottom: 35px;
}

.embed {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  overflow: hidden;
}
.embed-1by1:before {
  padding-top: 100%;
}
.embed-4by3:before {
  padding-top: 75%;
}
.embed .embed-item, .embed iframe {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.bg-red {
  background-color: #ED0614;
  color: white;
}
.bg-red .btn:hover {
  border-color: #fff;
}
.bg-green {
  background-color: #2D9E48;
  color: white;
}
.bg-brown {
  background-color: #754C24;
  color: white;
}
.bg-sky {
  background-color: #DFF7FD;
}

.box-red {
  border: 1px solid #ED0614;
  border-radius: 15px;
  padding: 35px 15px 15px;
}
.box-red.is-padding {
  padding-left: 40px;
  padding-right: 40px;
}
.box-process-arrow {
  text-align: center;
  margin: 30px 0;
}
.box-process-arrow img {
  width: 165px;
}
.box-process {
  background-color: #fff;
  padding: 55px 65px 30px;
  color: #4D4D4D;
}
.box-process .text {
  font-size: 13px;
  line-height: 2 !important;
  letter-spacing: 0.06em;
  margin-bottom: 40px;
}
@media (max-width: 767px) {
  .box-process-arrow img {
    width: 80px;
  }
}
@media (max-width: 576px) {
  .box-red {
    padding: 40px 20px 20px;
  }
  .box-red.is-padding {
    padding-left: 20px;
    padding-right: 20px;
  }
  .box-process-arrow {
    margin: 15px 0;
  }
  .box-process-arrow img {
    width: 55px;
  }
  .box-process {
    padding: 45px 45px 30px;
  }
}
@media screen and (max-width: 480px) {
  .box-process {
    padding: 30px 15px 30px;
  }
}

.clearfix::after {
  display: block;
  content: "";
  clear: both;
}

@media (min-width: 1100.1px) {
  .sticky.is-fixed {
    position: fixed;
    z-index: 100;
    top: 0;
    left: 0;
    width: 100%;
    padding: 0;
    background-color: #ED0614;
  }
}
@media screen and (max-width: 480px) {
  .equal-height {
    height: auto !important;
  }

  hr.line-solid {
    margin: 30px 0 40px;
  }
}
.row {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: -10px;
  margin-right: -10px;
}
.row > * {
  position: relative;
  width: 100%;
  padding-left: 10px;
  padding-right: 10px;
  margin-bottom: 20px;
}
.row .col {
  -webkit-flex-basis: 0;
  flex-basis: 0;
  -webkit-flex-grow: 1;
  flex-grow: 1;
  max-width: 100%;
}
.row .col-auto {
  -webkit-flex: 0 0 auto;
  flex: 0 0 auto;
  max-width: auto;
  width: auto;
}
.row .col.w100 {
  -webkit-flex: 0 0 100%;
  flex: 0 0 100%;
  max-width: 100%;
}
.row.center {
  -webkit-justify-content: center;
  justify-content: center;
}
.row-wrap {
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}
.row-0 {
  margin-left: -0px;
  margin-right: -0px;
}
.row-0 > * {
  padding-left: 0px;
  padding-right: 0px;
  margin-bottom: 0px;
}
.row-10 {
  margin-left: -10px;
  margin-right: -10px;
}
.row-10 > * {
  padding-left: 10px;
  padding-right: 10px;
  margin-bottom: 20px;
}
.row-15 {
  margin-left: -15px;
  margin-right: -15px;
}
.row-15 > * {
  padding-left: 15px;
  padding-right: 15px;
  margin-bottom: 30px;
}
.row-20 {
  margin-left: -20px;
  margin-right: -20px;
}
.row-20 > * {
  padding-left: 20px;
  padding-right: 20px;
  margin-bottom: 40px;
}
.row-30 {
  margin-left: -30px;
  margin-right: -30px;
}
.row-30 > * {
  padding-left: 30px;
  padding-right: 30px;
  margin-bottom: 60px;
}
.row-50 {
  margin-left: -50px;
  margin-right: -50px;
}
.row-50 > * {
  padding-left: 50px;
  padding-right: 50px;
  margin-bottom: 100px;
}
.row.one .col {
  flex: 0 0 100%;
  max-width: 100%;
}
.row.two .col {
  flex: 0 0 50%;
  max-width: 50%;
}
.row.three .col {
  flex: 0 0 33.33%;
  max-width: 33.33%;
}
.row.four .col {
  flex: 0 0 25%;
  max-width: 25%;
}
.row.five .col {
  flex: 0 0 20%;
  max-width: 20%;
}

@media (max-width: 992px) {
  .row-0-large {
    margin-left: -0px;
    margin-right: -0px;
  }
  .row-0-large > * {
    padding-left: 0px;
    padding-right: 0px;
    margin-bottom: 0px;
  }
  .row-10-large {
    margin-left: -10px;
    margin-right: -10px;
  }
  .row-10-large > * {
    padding-left: 10px;
    padding-right: 10px;
    margin-bottom: 20px;
  }
  .row-15-large {
    margin-left: -15px;
    margin-right: -15px;
  }
  .row-15-large > * {
    padding-left: 15px;
    padding-right: 15px;
    margin-bottom: 30px;
  }
  .row-20-large {
    margin-left: -20px;
    margin-right: -20px;
  }
  .row-20-large > * {
    padding-left: 20px;
    padding-right: 20px;
    margin-bottom: 40px;
  }
  .row-30-large {
    margin-left: -30px;
    margin-right: -30px;
  }
  .row-30-large > * {
    padding-left: 30px;
    padding-right: 30px;
    margin-bottom: 60px;
  }
  .row-50-large {
    margin-left: -50px;
    margin-right: -50px;
  }
  .row-50-large > * {
    padding-left: 50px;
    padding-right: 50px;
    margin-bottom: 100px;
  }
  .row.one-large .col {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .row.two-large .col {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .row.three-large .col {
    flex: 0 0 33.33%;
    max-width: 33.33%;
  }
  .row.four-large .col {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .row.five-large .col {
    flex: 0 0 20%;
    max-width: 20%;
  }
}
@media (max-width: 767px) {
  .row-0-medium {
    margin-left: -0px;
    margin-right: -0px;
  }
  .row-0-medium > * {
    padding-left: 0px;
    padding-right: 0px;
    margin-bottom: 0px;
  }
  .row-10-medium {
    margin-left: -10px;
    margin-right: -10px;
  }
  .row-10-medium > * {
    padding-left: 10px;
    padding-right: 10px;
    margin-bottom: 20px;
  }
  .row-15-medium {
    margin-left: -15px;
    margin-right: -15px;
  }
  .row-15-medium > * {
    padding-left: 15px;
    padding-right: 15px;
    margin-bottom: 30px;
  }
  .row-20-medium {
    margin-left: -20px;
    margin-right: -20px;
  }
  .row-20-medium > * {
    padding-left: 20px;
    padding-right: 20px;
    margin-bottom: 40px;
  }
  .row-30-medium {
    margin-left: -30px;
    margin-right: -30px;
  }
  .row-30-medium > * {
    padding-left: 30px;
    padding-right: 30px;
    margin-bottom: 60px;
  }
  .row-50-medium {
    margin-left: -50px;
    margin-right: -50px;
  }
  .row-50-medium > * {
    padding-left: 50px;
    padding-right: 50px;
    margin-bottom: 100px;
  }
  .row.one-medium .col {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .row.two-medium .col {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .row.three-medium .col {
    flex: 0 0 33.33%;
    max-width: 33.33%;
  }
  .row.four-medium .col {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .row.five-medium .col {
    flex: 0 0 20%;
    max-width: 20%;
  }
  .row .col.medium-w100 {
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (max-width: 576px) {
  .row-0-small {
    margin-left: -0px;
    margin-right: -0px;
  }
  .row-0-small > * {
    padding-left: 0px;
    padding-right: 0px;
    margin-bottom: 0px;
  }
  .row-10-small {
    margin-left: -10px;
    margin-right: -10px;
  }
  .row-10-small > * {
    padding-left: 10px;
    padding-right: 10px;
    margin-bottom: 20px;
  }
  .row-15-small {
    margin-left: -15px;
    margin-right: -15px;
  }
  .row-15-small > * {
    padding-left: 15px;
    padding-right: 15px;
    margin-bottom: 30px;
  }
  .row-20-small {
    margin-left: -20px;
    margin-right: -20px;
  }
  .row-20-small > * {
    padding-left: 20px;
    padding-right: 20px;
    margin-bottom: 40px;
  }
  .row-30-small {
    margin-left: -30px;
    margin-right: -30px;
  }
  .row-30-small > * {
    padding-left: 30px;
    padding-right: 30px;
    margin-bottom: 60px;
  }
  .row-50-small {
    margin-left: -50px;
    margin-right: -50px;
  }
  .row-50-small > * {
    padding-left: 50px;
    padding-right: 50px;
    margin-bottom: 100px;
  }
  .row.one-small .col {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .row.two-small .col {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .row.three-small .col {
    flex: 0 0 33.33%;
    max-width: 33.33%;
  }
  .row.four-small .col {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .row.five-small .col {
    flex: 0 0 20%;
    max-width: 20%;
  }
  .row .col.small-w100 {
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (max-width: 320px) {
  .row.one-ex-small .col {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
.keyvisual {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  height: 120px;
  color: #fff;
  margin: 0;
  padding: 0;
  background-color: #1ea1f2;
}
.keyvisual-heading {
  font-size: 40px;
  font-weight: 700;
}

h1, h2, h3, h4, h5, h6 {
  position: relative;
  font-weight: 500;
  line-height: 1.4;
}

.heading-top {
  font-size: 26px;
  font-weight: 700;
  font-family: "Noto Sans JP", sans-serif;
  text-align: center;
  color: #754C24;
  letter-spacing: 0.1em;
}
.heading-top > * {
  display: block;
  line-height: 1.2;
}
.heading-top .is-big {
  font-size: 85px;
  font-style: italic;
  letter-spacing: 0.05em;
}
.heading-top.is-blue {
  color: #004898;
}
.heading-top.is-white {
  color: white;
}
.heading-top.is-brown {
  color: #754C24;
}
.heading-top.is-black {
  color: #333;
}
.heading-road {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  font-size: 21px;
  font-weight: 700;
  line-height: 1.715;
  letter-spacing: 0.12em;
  color: #004898;
  margin-bottom: 25px;
  margin-left: -10px;
}
.heading-road > * {
  display: block;
}
.heading-road .ico {
  -webkit-flex: 0 0 100px;
  flex: 0 0 100px;
  max-width: 100px;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-end;
  align-items: flex-end;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
  padding: 10px 1.1em;
  height: 75px;
  font-size: 34px;
  font-weight: 400;
  font-family: "Barlow Condensed", sans-serif;
  font-style: italic;
  color: #ED0614;
  letter-spacing: 0;
  line-height: 1;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url(../img/common/ico_road.png);
}
.heading-road .text {
  -webkit-flex-grow: 1;
  flex-grow: 1;
  padding-left: 20px;
}
.heading-section {
  color: #004898;
  padding-top: 40px;
  text-align: center;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: 229px;
  background-image: url(../img/common/ico_earth.png);
}
.heading-section .header, .heading-section .section, .heading-section .number, .heading-section .text {
  display: block;
}
.heading-section .header {
  font-weight: 500;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
  letter-spacing: -0.025em;
  line-height: 1;
  text-transform: uppercase;
}
.heading-section .section {
  font-size: 20px;
}
.heading-section .number {
  font-size: 32px;
}
.heading-section .text {
  font-size: 21px;
  font-weight: 700;
  letter-spacing: 0.12em;
  margin: 15px 0;
}
.heading-primary {
  font-size: 35px;
  font-weight: 700;
  font-family: "Lato", sans-serif;
  text-align: center;
  margin-bottom: 15px;
}
.heading-primary .eng {
  display: block;
  font-size: 145px;
  font-style: italic;
  line-height: 1;
  letter-spacing: 0.025em;
  margin-bottom: 0;
}
.heading-primary .jp {
  display: block;
  font-size: 35px;
}
.heading-primary .label {
  font-size: 40px;
  font-weight: 400;
  font-family: "Barlow Condensed", sans-serif;
  position: absolute;
  top: -0.5em;
  text-transform: uppercase;
  letter-spacing: -0.025em;
}
.heading-primary.is-red {
  color: #ED1C24;
}
.heading-primary.is-blue {
  color: #004898;
}
.heading-secondary {
  position: relative;
  font-size: 36px;
  font-weight: 700;
  color: #ED0614;
  text-align: center;
  letter-spacing: 0.05em;
  padding-bottom: 20px;
  margin-bottom: 30px;
}
.heading-secondary:after {
  content: "";
  position: absolute;
  width: 60px;
  height: 5px;
  bottom: 0;
  left: 50%;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: #ED0614;
}
.heading-secondary.is-white {
  color: #fff;
}
.heading-secondary.is-white:after {
  background-color: #fff;
}
.heading-secondary.is-brown {
  color: #754C24;
}
.heading-secondary.is-brown:after {
  background-color: #754C24;
}
.heading-secondary.is-green {
  color: #39B54A;
}
.heading-secondary.is-green:after {
  background-color: #39B54A;
}
.heading-secondary.is-italic {
  font-style: italic;
}
.heading-tertiary {
  display: block;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-align: center;
  background-color: #29B6FF;
  color: #fff;
  padding: 18px 15px;
  border-top: 1px solid #29B6FF;
  border-bottom: 1px solid #29B6FF;
  margin-bottom: 40px;
}
.heading-tertiary.is-white {
  color: #29B6FF;
  background-color: #fff;
}
.heading-tertiary.is-blue {
  color: #fff;
  background-color: #2E3192;
  border-color: #2E3192;
}
.heading-tertiary.is-blue-light {
  background-color: #1C6FB1;
  border-color: #1C6FB1;
}
.heading-tertiary.is-blue-transparent {
  color: #2E3192;
  border-color: #2E3192;
  background-color: transparent;
}
.heading-tertiary.is-blue-light-transparent {
  color: #1C6FB1;
  border-color: #1C6FB1;
  background-color: transparent;
}
.heading-quaternary {
  position: relative;
  z-index: 1;
  max-width: 610px;
  font-size: 60px;
  font-style: italic;
  font-weight: 600;
  padding: 40px 20px 20px 0;
  color: #fff;
  line-height: 1;
  background-color: #ED0614;
  margin-bottom: 70px;
}
.heading-quaternary:before {
  content: "";
  position: absolute;
  height: 100%;
  width: 100vw;
  top: 0;
  right: 100%;
  z-index: -1;
  background-color: #ED0614;
}

.title-primary {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.1em;
  margin-bottom: 30px;
  text-align: center;
}
.title-primary.is-brown {
  color: #754C24;
}
.title-primary.is-green {
  color: #2D9E48;
}
.title-primary.is-blue {
  color: #004898;
}
.title-secondary {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-align: center;
  margin-bottom: 20px;
}
.title-secondary .ico {
  display: block;
  position: relative;
  padding-bottom: 12px;
}
.title-secondary .ico:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 100px;
  height: 4px;
  background-color: #29B6FF;
}
.title-tertiary {
  font-size: 21px;
  line-height: 1.9 !important;
  letter-spacing: 0.08em;
  text-align: center;
  color: #754C24;
  margin-bottom: 10px;
}
.title-red {
  min-width: 280px;
  display: inline-block;
  color: #fff;
  font-size: 17px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: 1.5;
  padding: 10px 20px;
  background-color: #ED0614;
}
.title-red.is-short {
  min-width: 215px;
}

@media (min-width: 1100.1px) {
  .title-primary.is-mb40 {
    margin-bottom: 40px;
  }
}
@media (max-width: 767px) {
  .heading-primary {
    font-size: 30px;
  }
  .heading-primary .eng {
    font-size: 120px;
  }
  .heading-primary .jp {
    font-size: 30px;
  }
  .heading-primary .label {
    font-size: 0.3em;
  }
  .heading-road {
    font-size: 18px;
  }
  .heading-quaternary {
    margin-bottom: 40px;
  }
}
@media (max-width: 740px) {
  .heading-top {
    font-size: 16px;
  }
  .heading-top .is-big {
    font-size: 35px;
  }

  .title-tertiary {
    font-size: 18px;
  }
}
@media (max-width: 576px) {
  .heading-primary {
    font-size: 30px;
  }
  .heading-primary .eng {
    font-size: 90px;
  }
  .heading-primary .jp {
    font-size: 25px;
  }
  .heading-section {
    background-size: 160px;
    padding-top: 30px;
  }
  .heading-section .section {
    font-size: 16px;
  }
  .heading-section .number {
    font-size: 26px;
  }
  .heading-section .text {
    font-size: 18px;
  }
  .heading-quaternary {
    font-size: 50px;
    padding: 20px 10px 10px 0;
  }
}
@media screen and (max-width: 480px) {
  .heading-primary {
    font-size: 30px;
  }
  .heading-primary .eng {
    font-size: 60px;
    margin-bottom: 5px;
  }
  .heading-primary .jp {
    font-size: 16px;
  }
  .heading-road {
    font-size: 16px;
    margin: 0 0 15px 0;
  }
  .heading-road .ico {
    -webkit-flex: 0 0 70px;
    flex: 0 0 70px;
    max-width: 70px;
    padding: 17px 25px;
    font-size: 25px;
  }
  .heading-road .text {
    padding-left: 10px;
  }
  .heading-secondary {
    font-size: 28px;
  }
  .heading-secondary.is-sp-small {
    font-size: 24px;
    padding-bottom: 0;
  }
  .heading-quaternary {
    font-size: 40px;
    padding: 20px 10px 10px 0;
  }

  .title-primary {
    font-size: 18px;
  }
  .title-tertiary {
    font-size: 16px;
  }
}
@media (max-width: 320px) {
  .heading-top {
    font-size: 14px;
  }
  .heading-top .is-big {
    font-size: 30px;
  }
  .heading-secondary {
    font-size: 24px;
  }
}
.badges {
  position: relative;
}
.badges-item {
  position: absolute;
  z-index: 1;
  left: 0;
  top: 0;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.breadcrumb {
  background-color: #eee;
}
.breadcrumb .item {
  display: inline-block;
}
.breadcrumb .item + .item:before {
  content: "/";
  display: inline-block;
  margin: 0 5px;
}
.breadcrumb .link {
  display: inline-block;
  color: blue;
  -moz-transition: color 0.26s ease;
  -o-transition: color 0.26s ease;
  -webkit-transition: color 0.26s ease;
  transition: color 0.26s ease;
}
@media print, (min-width: 768px) {
  .breadcrumb .link:hover, .breadcrumb .link:focus, .breadcrumb .link:active {
    color: black;
  }
}
@media only screen and (max-width: 767px) {
  .breadcrumb .link {
    font-size: 12px;
  }
}

.btn {
  cursor: pointer;
  display: inline-block;
  min-width: 330px;
  background-color: #fff;
  border: 1px solid #ED0614;
  padding: 18px 30px;
  color: #ED0614;
  font-size: 15px;
  font-weight: 700;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.5;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none;
  vertical-align: middle;
  -moz-border-radius: 0;
  -webkit-border-radius: 0;
  border-radius: 0;
  -moz-user-select: -moz-none;
  -ms-user-select: none;
  -webkit-user-select: none;
  user-select: none;
  -moz-transition: opacity 0.15s ease-in-out, color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  -o-transition: opacity 0.15s ease-in-out, color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  -webkit-transition: opacity 0.15s ease-in-out, color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  transition: opacity 0.15s ease-in-out, color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
.btn .ico {
  display: block;
  position: relative;
  padding-right: 15px;
}
.btn .ico:after {
  content: "";
  position: absolute;
  top: calc(50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 0;
  width: 0;
  height: 0;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 8px solid currentColor;
}
.btn-note {
  font-size: 10px;
  margin: 15px 0;
}
.btn-note.is-big {
  font-size: 13px;
}
.btn.is-big {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.05em;
  min-width: 470px;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;
  border: 0;
}
.btn.is-big .ico:after {
  border-top-width: 10px;
  border-bottom-width: 10px;
  border-left-width: 15px;
}
.btn.is-disabled {
  background-color: #b7b7b7;
  border-color: #b7b7b7;
  color: #fff;
  pointer-events: none;
}
.btn-arrow {
  padding: 20px 20px;
  display: block;
  width: 100%;
  letter-spacing: 0.05em;
  font-size: 16px;
  font-weight: 700;
  border-color: #fff;
  color: #333;
}
.btn-arrow .arrow {
  display: block;
  padding-right: 80px;
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 68px;
  background-image: url(../img/common/ico_arrow_brown.png);
}
.btn-arrow .arrow.is-center {
  padding-left: 80px;
}
.btn-arrow.is-green .arrow {
  background-image: url("../img/common/ico_arrow_green.png");
}
.btn-group {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin-left: 10px;
  margin-right: 10px;
}
.btn-group > * {
  padding: 0 10px;
}
.btn-group.inline {
  display: block;
}
.btn-group.inline > * {
  margin-bottom: 25px;
}
.btn-totop {
  color: #fff;
  background-color: #FC0D1B;
  border: 2px solid #FC0D1B;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 20px 35px;
  min-width: auto;
}
.btn-totop .arrow {
  position: relative;
  display: block;
  padding-right: 60px;
}
.btn-totop .arrow:after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 50px;
  height: 100%;
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
  background-image: url(../img/common/ico_paper_white.png);
}
.btn-toworks {
  color: #fff;
  background-color: #754C24;
  border: 2px solid #754C24;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 20px 35px;
  min-width: auto;
}
.btn-toworks .arrow {
  position: relative;
  display: block;
  padding-right: 60px;
}
.btn-toworks .arrow:after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 50px;
  height: 100%;
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
  background-image: url(../img/common/ico_paper_white.png);
}
.btn-prev, .btn-next {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  position: relative;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  color: #754C24;
  padding: 20px 5px;
  letter-spacing: 0.05em;
  width: 200px;
  min-width: auto;
  border: 0;
}
.btn-prev:after, .btn-next:after {
  content: "";
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 5px;
  left: 0;
  bottom: 0;
  background-color: #754C24;
}
.btn-prev .arrow, .btn-next .arrow {
  position: relative;
  display: block;
}
.btn-prev .arrow:after, .btn-next .arrow:after {
  content: "";
  position: absolute;
  top: 0;
  width: 50px;
  height: 100%;
  background-repeat: no-repeat;
  background-size: contain;
}
.btn-prev.is-disabled, .btn-next.is-disabled {
  background: none;
  color: #b7b7b7;
}
.btn-prev.is-disabled:after, .btn-next.is-disabled:after {
  background-color: #b7b7b7;
}
.btn-prev .arrow:after {
  left: -70px;
  background-position: left center;
  background-image: url("../img/common/ico_paper_brown_prev.png");
}
.btn-prev.is-disabled .arrow:after {
  background-image: url("../img/common/ico_paper_gray_prev.png");
}
.btn-next .arrow:after {
  right: -70px;
  background-position: left center;
  background-image: url("../img/common/ico_paper_brown_next.png");
}
.btn-next.is-disabled .arrow:after {
  background-image: url("../img/common/ico_paper_gray_next.png");
}
@media print, (min-width: 768px) {
  .btn:hover {
    color: #fff;
    background-color: #ED0614;
  }
  .btn-prev:hover, .btn-next:hover {
    background-color: #fff;
    color: #754C24;
  }
  .btn-totop:hover {
    color: #FC0D1B;
    background-color: #fff;
  }
  .btn-totop:hover .arrow:after {
    background-image: url("../img/common/ico_paper_red.png");
  }
  .btn-toworks:hover {
    color: #754C24;
    background-color: #fff;
  }
  .btn-toworks:hover .arrow:after {
    background-image: url("../img/common/ico_paper_brown_next.png");
  }
  .btn-arrow:hover {
    background-color: #fff;
    border-color: #fff;
    color: #333;
  }
}
@media (max-width: 740px) {
  .btn {
    min-width: auto;
    font-size: 14px;
    padding: 15px 25px;
  }
  .btn-arrow {
    font-size: 14px;
  }
  .btn-arrow .arrow {
    padding-right: 45px;
    background-size: 40px;
  }
  .btn-arrow .arrow.is-center {
    padding-left: 45px;
  }
}
@media screen and (max-width: 480px) {
  .btn.is-big {
    font-size: 16px;
    padding: 20px;
    min-width: auto;
    width: 100%;
  }
  .btn.is-big .ico:after {
    border-top-width: 7px;
    border-bottom-width: 7px;
    border-left-width: 10px;
  }
}
@media (max-width: 576px) {
  .btn-totop, .btn-toworks {
    padding: 10px 10px;
  }
  .btn-totop .arrow, .btn-toworks .arrow {
    padding-right: 35px;
  }
  .btn-totop .arrow:after, .btn-toworks .arrow:after {
    width: 35px;
  }
  .btn-prev:after, .btn-next:after {
    height: 3px;
  }
  .btn-prev .arrow:after, .btn-next .arrow:after {
    width: 35px;
  }
  .btn-prev .arrow:after {
    left: -40px;
  }
  .btn-next .arrow:after {
    right: -40px;
  }
}

.card-link {
  display: block;
}
.card-figure {
  position: relative;
  margin-bottom: 10px;
}
.card-figure .figure {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  overflow: hidden;
  padding-bottom: 65%;
}
.card-figure .figure img, .card-figure .figure .item {
  position: absolute;
  top: 50%;
  left: 50%;
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  max-width: initial;
  min-width: initial;
  height: 100%;
}
.card-content {
  padding: 0;
}
.card-heading {
  font-size: 20px;
}
.card-nextcalbee {
  background-color: #fff;
  border: 5px solid #fff;
  text-align: center;
  height: 100%;
}
.card-nextcalbee .card-figure .figure {
  padding-bottom: 82%;
}
.card-nextcalbee .card-body {
  padding-bottom: 10px;
}
.card-nextcalbee .card-heading {
  font-size: 31px;
  font-weight: 500;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
  color: #ED0614;
  letter-spacing: -0.025em;
  margin-bottom: 5px;
}
.card-nextcalbee .card-desc {
  font-size: 15px;
  font-weight: 700;
  font-family: "Noto Sans JP", sans-serif;
  color: #333;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
.card-nextcalbee a{
	pointer-events: none;
	position: relative;
	width: 100%;
	height: 100%;
}
.card-nextcalbee a:before,
.card-nextcalbee a:after{
	content: '';
	display: block;
	position: absolute;
}
.card-nextcalbee a:before{
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,.4);
	top: 0;
	left: 0;
	z-index: 1;
}
.card-nextcalbee a:after{
	content: 'Coming Soon';
	color: #fff;
	line-height: 1.0;
	font-weight: bold;
	font-size: 18px;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	z-index: 2;
}
.card-aboutcalbee {
  width: 210px;
  max-width: 100%;
}
.card-aboutcalbee .bg {
  display: inline-block;
  padding: 5px;
  line-height: 1;
  background-color: #fff;
}
.card-aboutcalbee .card-body {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  margin-top: -25px;
}
.card-aboutcalbee .card-body .arrow {
  padding-bottom: 20px;
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: 68px;
  background-image: url("../img/common/ico_arrow_slider.png");
}
.card-aboutcalbee .card-figure {
  margin-bottom: 0;
}
.card-aboutcalbee .card-heading {
  text-transform: uppercase;
  font-size: 40px;
  font-weight: 500;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
  color: #ED0614;
  line-height: 1;
  margin-bottom: 5px;
}
.card-aboutcalbee .card-heading .bg {
  padding: 0 5px;
}
.card-aboutcalbee .card-desc {
  font-size: 16px;
  font-weight: 700;
  font-family: "Noto Sans JP", sans-serif;
  color: #754C24;
}
.card-aboutcalbee .card-desc .bg {
  padding: 5px;
}
.card-work {
  max-width: 220px;
  margin-left: auto;
  margin-right: auto;
}
.card-work .card-figure {
  margin-bottom: 5px;
}
.card-work .card-figure .figure {
  padding-bottom: 230px;
}
.card-work .card-label {
  font-size: 12px;
  display: inline-block;
  width: 110px;
  padding: 4px 5px;
  color: #fff;
  text-align: center;
  background-color: #333;
  letter-spacing: 0.15em;
  margin-bottom: 10px;
}
.card-work .card-title {
  font-size: 21px;
  font-weight: 500;
  color: #754C24;
  margin-bottom: 5px;
}
.card-work .card-text {
  font-size: 12px;
  line-height: 1.66;
  letter-spacing: 0.06em;
}
.card-work.is-brown .card-label {
  background-color: #754C24;
}
.card-work.is-green .card-label {
  background-color: #43A047;
}
.card-work.is-blue .card-label {
  background-color: #0277BD;
}
.card-work.is-orange .card-label {
  background-color: #F15A24;
}
@media (max-width: 740px) {
  .card-nextcalbee .card-heading {
    font-size: 20px;
  }
  .card-nextcalbee .card-desc {
    font-size: 10px;
  }
  .card-nextcalbee .card-figure .figure {
    padding-bottom: 80%;
  }
  .card-aboutcalbee {
    width: 140px;
  }
  .card-aboutcalbee .card-heading {
    font-size: 26px;
  }
  .card-aboutcalbee .card-desc {
    font-size: 10px;
  }
}
@media (max-width: 320px) {
  .card-nextcalbee .card-link {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
  }
  .card-nextcalbee .card-figure {
    -webkit-flex: 0 0 120px;
    flex: 0 0 120px;
    max-width: 120px;
    margin-bottom: 0;
  }
  .card-nextcalbee .card-body {
    -webkit-flex-grow: 1;
    flex-grow: 1;
    padding-bottom: 0;
    text-align: center;
  }
  .card-nextcalbee .card-figure .figure {
    padding-bottom: 0;
    min-height: 100px;
    height: 100%;
  }
  .card-aboutcalbee {
    width: 125px;
  }
  .card-aboutcalbee .card-figure {
    width: 100px;
  }
}

input, textarea, select {
  width: 100%;
  display: block;
  font-weight: 400;
  line-height: initial;
  padding: 10px 10px;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid #999;
  border-radius: 5px;
}
input:focus, textarea:focus, select:focus {
  outline: 0;
}
input .is-error, textarea .is-error, select .is-error {
  border-color: #B70000 !important;
}

input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #666;
}
input::-moz-placeholder, textarea::-moz-placeholder {
  color: #666;
}
input:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #666;
}
input:-moz-placeholder, textarea:-moz-placeholder {
  color: #666;
}

textarea {
  resize: none;
  height: 200px;
}

select {
  word-wrap: normal;
  background-repeat: no-repeat;
  background-position: calc(100% - 8px) 50%;
  background-size: 8px;
  background-image: url("../img/common/ico_select.png");
  -moz-appearance: none;
  -webkit-appearance: none;
}
select:invalid {
  color: #666;
}
select option {
  color: currentColor;
}
select option[value=""][disabled] {
  display: none;
}

.form .label {
  display: inline-block;
  vertical-align: middle;
}
.form .required {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  line-height: 1;
  vertical-align: middle;
  border-radius: 4px;
  padding: 2px 5px;
  background-color: #B70000;
  margin-left: 15px;
}
.form .error {
  color: #B70000 !important;
}
.form-wrapper {
  width: 700px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.form-group {
  position: relative;
  display: block;
  margin: 0;
  padding: 25px 0;
}
.form-label {
  position: relative;
  display: block;
  margin-bottom: 10px;
}
.form-control {
  display: block;
}
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .form input {
    line-height: 2;
  }
}
@media print, (min-width: 768px) {
  .form.form-inline .form-group {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: center;
    align-items: center;
    margin: 0 -10px;
  }
  .form.form-inline .form-group > * {
    padding: 0 10px;
    margin: 0;
  }
  .form.form-inline .form-group.is-block {
    display: block;
  }
  .form.form-inline .form-label {
    -webkit-flex: 0 0 200px;
    flex: 0 0 200px;
    max-width: 200px;
  }
  .form.form-inline .form-control {
    -webkit-flex-grow: 1;
    flex-grow: 1;
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .form textarea {
    height: 150px;
  }
}

.mw-wrap {
  display: block;
}

.mw_wp_form .error {
  font-size: 93%;
  color: #B70000;
  display: block;
}
.mw_wp_form .akismet_error {
  display: block;
}
.mw_wp_form .vertical-item {
  display: block;
}
.mw_wp_form .vertical-item + .vertical-item {
  margin-top: 5px;
}
.mw_wp_form .horizontal-item + .horizontal-item {
  margin-left: 10px;
}

.mw_wp_form .ui-datepicker .ui-datepicker-title select.ui-datepicker-month, .mw_wp_form .ui-datepicker .ui-datepicker-title select.ui-datepicker-year {
  width: 40%;
  margin: 0 5px;
}

.mw-wp-form-deprecated-message {
  background: #fdeeee;
  border: 1px solid #f7bdb8;
  border-radius: 5px;
  color: #af4040;
  font-size: 13px;
  line-height: 1.6;
  margin: 0 0 10px;
  padding: 1em;
}

.mw_wp_form input[type="file"] {
  display: inline-block;
}

.mwform-file-delete {
  cursor: pointer;
  visibility: hidden;
}

.mwform-tel-field input[type="text"], .mwform-zip-field input[type="text"] {
  display: inline-block;
  width: auto;
}

.mwform-checkbox-field label, .mwform-radio-field label {
  font-weight: normal;
  margin-bottom: 0;
}
.mwform-checkbox-field input[type="checkbox"], .mwform-checkbox-field input[type="radio"], .mwform-radio-field input[type="checkbox"], .mwform-radio-field input[type="radio"] {
  position: absolute;
  width: 10px;
  z-index: -1;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
  opacity: 0;
}
.mwform-checkbox-field span, .mwform-radio-field span {
  display: inline-block;
  position: relative;
  vertical-align: top;
  padding-left: 1.5em;
  line-height: 1.2;
}
.mwform-checkbox-field span:after, .mwform-radio-field span:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 1rem;
  height: 1rem;
  border: 1px solid #ddd;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
.mwform-checkbox-field input[type="checkbox"] ~ span:after, .mwform-radio-field input[type="checkbox"] ~ span:after {
  border-radius: 0.25rem;
}
.mwform-checkbox-field input[type="radio"] ~ span:after, .mwform-radio-field input[type="radio"] ~ span:after {
  border-radius: 50%;
}
.mwform-checkbox-field input[type="checkbox"]:checked ~ span:after, .mwform-radio-field input[type="checkbox"]:checked ~ span:after {
  background-image: url("../img/common/ico_checkbox.png");
}
.mwform-checkbox-field input[type="radio"]:checked ~ span:after, .mwform-radio-field input[type="radio"]:checked ~ span:after {
  background-image: url("../img/common/ico_radio.png");
}

.post-content p {
  margin-bottom: 1em;
}
.post-content img {
  margin-bottom: 1em;
}
.post-content blockquote {
  padding-left: 40px;
}
.post-content ul,
.post-content ol {
  margin-bottom: 1.5em;
  padding-left: 40px;
}
.post-content ol {
  list-style: decimal;
}
.post-content ul {
  list-style: disc;
}
.post-content h1 {
  margin-bottom: 1.5em;
  font-size: 1.6em;
  font-weight: bold;
}
.post-content h2 {
  margin-bottom: 1.5em;
  font-size: 1.4em;
  font-weight: bold;
}
.post-content h3 {
  margin-bottom: 1.5em;
  font-size: 1.2em;
  font-weight: bold;
}
.post-content h4,
.post-content h5,
.post-content h6 {
  margin-bottom: 1.5em;
  font-size: 1em;
  font-weight: bold;
}
.post-content b,
.post-content strong {
  font-weight: bold;
}
.post-content i,
.post-content em {
  font-style: italic;
}
.post-wrapper {
  position: relative;
}
.post-item {
  position: relative;
}
.post-detail {
  position: relative;
}

.ul-pager {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
}
.ul-pager li {
  margin: 0 5px;
}
.ul-pager .page-numbers {
  min-width: 36px;
  display: inline-block;
  text-align: center;
  padding: 7px 8px;
  line-height: 1;
  border: 1px solid #264A89;
  color: #264A89;
  background-color: #fff;
  -moz-transition: background-color 0.26s ease, color 0.26s ease;
  -o-transition: background-color 0.26s ease, color 0.26s ease;
  -webkit-transition: background-color 0.26s ease, color 0.26s ease;
  transition: background-color 0.26s ease, color 0.26s ease;
}
.ul-pager .page-numbers.current, .ul-pager .page-numbers:hover {
  background-color: #264A89;
  color: #fff;
}
.ul-pager .arrow .ico {
  display: inline-block;
  position: relative;
  min-width: 36px;
  height: 100%;
  border: 1px solid #264A89;
  color: #264A89;
  background-color: #fff;
}
.ul-pager .arrow .ico:before {
  content: "";
  position: absolute;
  width: 0.625rem;
  height: 0.625rem;
  top: calc(50% + .1em);
  -moz-transform: rotate(45deg) translate(-50%, -50%);
  -ms-transform: rotate(45deg) translate(-50%, -50%);
  -webkit-transform: rotate(45deg) translate(-50%, -50%);
  transform: rotate(45deg) translate(-50%, -50%);
}
.ul-pager .arrow .ico.current, .ul-pager .arrow .ico:hover {
  background-color: #264A89;
}
.ul-pager .arrow .ico.current:before, .ul-pager .arrow .ico:hover:before {
  border-color: #fff !important;
}
.ul-pager .arrow.prev .ico:before {
  left: calc(50% - .1em);
  border-left: 0.125rem solid #264A89;
  border-bottom: 0.125rem solid #264A89;
}
.ul-pager .arrow.next .ico:before {
  right: calc(50% - .2em);
  border-top: 0.125rem solid #264A89;
  border-right: 0.125rem solid #264A89;
}
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .ul-pager .page-numbers {
    padding: 10px 8px 5px 8px;
  }
}
@media only screen and (max-width: 374px) {
  .ul-pager .page-numbers {
    min-width: 30px;
    padding: 7px 5px;
  }
  .ul-pager .arrow .ico {
    min-width: 30px;
    padding: 7px 5px;
  }
}

.list-dots {
  position: relative;
  color: #4D4D4D;
  font-style: 13px;
  line-height: 2;
  padding-left: 28px;
  padding-right: 28px;
}
.list-dots:not(:last-child) {
  border-bottom: 1px dashed currentColor;
  margin-bottom: 10px;
  padding-bottom: 15px;
}
.list-dots li {
  position: relative;
  padding-left: 18px;
}
.list-dots li:before {
  content: "●";
  color: currentColor;
  position: absolute;
  top: 0;
  left: 0;
}
.list-dots.is-green li:before {
  color: #70BF45;
}
.list-dots.is-big {
  font-size: 21px;
}
.list-dots.is-big li {
  padding: 0 30px;
}
@media (max-width: 576px) {
  .list-dots {
    padding-left: 15px;
    padding-right: 15px;
  }
  .list-dots.is-big {
    font-size: 15px;
  }
}

.media {
  position: relative;
  margin: 35px 0;
}
.media::after {
  display: block;
  content: "";
  clear: both;
}
.media:first-child {
  margin-top: 0;
}
.media-wrapper {
  position: relative;
  margin-bottom: 40px;
}
.media-figure {
  position: relative;
  text-align: center;
  margin-top: 10px;
}
.media-figure img {
  display: inline-block;
}
.media-body.is-pt10 {
  padding-top: 10px;
}
.media-heading {
  font-size: 21px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.8;
  margin-bottom: 20px;
}
.media-text {
  font-size: 13px;
  line-height: 1.925;
  text-align: justify;
}
.media-text.space {
  letter-spacing: -0.04em;
}
.media .left {
  float: left;
  margin-right: 50px;
  margin-bottom: 30px;
}
.media .right {
  float: right;
  margin-left: 50px;
  margin-bottom: 30px;
}
.media.is-sky .media-heading {
  color: #29B6FF;
}
.media.is-blue-light .media-heading {
  color: #1C6FB1;
}
.media.is-blue .media-heading {
  color: #004898;
}
.media.is-flex {
  display: -webkit-flex;
  display: flex;
  margin-left: -25px;
  margin-right: -25px;
}
.media.is-flex > * {
  padding: 0 25px;
}
.media.is-flex .media-figure {
  -webkit-flex: 0 0 420px;
  flex: 0 0 420px;
  max-width: 420px;
}
.media.is-flex .media-figure.is-center {
  -webkit-align-self: center;
  align-self: center;
}
.media.is-flex .media-body {
  -webkit-flex-grow: 1;
  flex-grow: 1;
}
.media.is-flex .media-text {
  letter-spacing: 0.1em;
}
.media.is-flex .media-text > * {
  margin-bottom: 30px;
}
@media (max-width: 767px) {
  .media-body.is-pt10 {
    padding-top: 0;
  }
  .media.is-flex .media-figure {
    -webkit-flex: 0 0 250px;
    flex: 0 0 250px;
    max-width: 250px;
  }
  .media-text.space {
    letter-spacing: 0;
  }
}
@media (max-width: 576px) {
  .media-figure img {
    width: 100%;
  }
  .media-heading {
    font-size: 20px;
    line-height: 1.5;
    margin-bottom: 10px;
  }
  .media .left, .media .right {
    float: none;
    margin: 0 0 20px 0;
  }
  .media.is-sky .media-figure {
    margin-top: 0;
  }
  .media.is-sky .media-heading {
    margin-bottom: 10px;
    line-height: 1.5;
  }
  .media.is-flex {
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .media.is-flex .media-body, .media.is-flex .media-figure {
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
  }
  .media.is-flex .media-figure img {
    max-width: 300px;
  }
}

.table-wrapper {
  position: relative;
  margin-bottom: 40px;
}
.table-wrapper.is-mb70 {
  margin-bottom: 70px;
}
.table-basic {
  background-color: #F2F2F2;
  border: 1px solid #000;
}
.table-basic th, .table-basic td {
  border: 1px solid #000;
  vertical-align: middle;
  padding: 10px 20px;
  font-weight: 400;
}
.table-basic th {
  font-size: 20px;
  line-height: 1.8;
  color: #000;
  background-color: #FFF8E1;
  letter-spacing: 0.05em;
}
.table-basic td {
  font-size: 13px;
  color: #4D4D4D;
  line-height: 1.925;
  letter-spacing: 0.1em;
  padding-top: 25px;
  padding-bottom: 25px;
}
.table-basic .col-01 {
  width: 190px;
  background-color: #FFECB3;
}
.table-basic .col-02 {
  width: 245px;
}
.table-primary {
  width: 100%;
  border: 1px solid #2E3192;
  letter-spacing: 0.08em;
  line-height: 1.8;
}
.table-primary tr:last-child th {
  border-color: #2E3192;
}
.table-primary th, .table-primary td {
  padding: 13px 10px;
}
.table-primary th {
  width: 170px;
  font-size: 16px;
  color: #fff;
  background-color: #2E3192;
  border-bottom: 1px solid white;
  text-align: center;
  vertical-align: middle;
}
.table-primary td {
  font-size: 14px;
  border-bottom: 1px solid #2E3192;
}
.table-secondary {
  font-size: 13px;
  line-height: 1.925;
}
.table-secondary tr.is-blue th {
  color: #004898;
}
.table-secondary tr.is-green th {
  color: #009245;
}
.table-secondary tr.is-pink th {
  color: #EB70A7;
}
.table-secondary th, .table-secondary td {
  vertical-align: top;
  padding-top: 12px;
  padding-bottom: 12px;
}
.table-secondary th {
  width: 55px;
  padding-right: 5px;
}
@media (max-width: 576px) {
  .table-wrapper.is-mb70 {
    margin-bottom: 40px;
  }
  .table-wrapper.is-small-scroll {
    overflow: auto;
  }
  .table-wrapper.is-small-scroll table {
    width: 750px;
  }
  .table-primary th {
    width: 140px;
  }
}
@media screen and (max-width: 480px) {
  .table-primary thead, .table-primary tbody, .table-primary tr, .table-primary th, .table-primary td {
    display: block;
  }
  .table-primary tr:last-child td {
    border-bottom: 0;
  }
  .table-primary th, .table-primary td {
    width: 100%;
  }
  .table-primary th {
    border: 0;
  }
}

.accordion {
  position: relative;
  margin-bottom: 30px;
}
.accordion-wrapper {
  position: relative;
}
.accordion-heading {
  position: relative;
  cursor: pointer;
  font-size: 20px;
  font-weight: 700;
  color: #333;
  padding: 10px 30px 10px 0;
  border-bottom: 1px solid;
}
.accordion-heading:after {
  content: "+";
  font-size: 1em;
  font-weight: 700;
  position: absolute;
  top: 0.4em;
  right: 0;
}
.accordion-content {
  display: none;
  padding: 10px 0;
}

.tabs-wrapper {
  position: relative;
  max-width: 920px;
  margin: 0 auto 50px;
}
.tabs-btn {
  position: relative;
  display: block;
  line-height: 1.5;
  padding: 25px 10px;
  font-size: 20px;
  font-weight: 500;
  text-align: center;
  color: #fff;
  background-color: #d2d2d2;
  -moz-transition: background-color 0.26s ease, color 0.26s ease;
  -o-transition: background-color 0.26s ease, color 0.26s ease;
  -webkit-transition: background-color 0.26s ease, color 0.26s ease;
  transition: background-color 0.26s ease, color 0.26s ease;
}
.tabs-btn:after {
  content: "";
  position: absolute;
  top: calc(50% - .7em);
  right: 30px;
  width: 0.625em;
  height: 0.625em;
  border-top: 0.125em solid currentcolor;
  border-right: 0.125em solid currentcolor;
  -moz-transform: rotate(135deg) translateY(-50%);
  -ms-transform: rotate(135deg) translateY(-50%);
  -webkit-transform: rotate(135deg) translateY(-50%);
  transform: rotate(135deg) translateY(-50%);
}
.tabs-link {
  display: -webkit-flex;
  display: flex;
  margin: 0 -35px 75px;
}
.tabs-link li, .tabs-link .item {
  width: 50%;
  cursor: pointer;
  padding: 0 35px;
}
.tabs-link li.is-current .tabs-btn, .tabs-link .item.is-current .tabs-btn {
  background-color: #ED0614;
}
.tabs-content {
  display: none;
  padding: 0;
}
.tabs-content.is-current {
  display: inherit;
}
@media (max-width: 576px) {
  .tabs-link {
    margin: 0 -15px 40px;
  }
  .tabs-link li, .tabs-link .item {
    padding: 0 15px;
  }
  .tabs-btn {
    font-size: 18px;
    padding: 15px 10px;
  }
  .tabs-btn:after {
    right: 10px;
  }
}
@media screen and (max-width: 480px) {
  .tabs-link {
    margin: 0 -5px 30px;
  }
  .tabs-link li, .tabs-link .item {
    padding: 0 5px;
  }
  .tabs-btn {
    font-size: 16px;
    padding: 10px 25px 10px 10px;
  }
}
@media (max-width: 320px) {
  .tabs-btn {
    font-size: 12px;
  }
}

.modal {
  display: none;
  overflow: hidden;
  position: fixed;
  z-index: 999;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  font-family: "Noto Sans JP", sans-serif;
}
.modal-wrapper {
  display: none;
}
.modal-close {
  cursor: pointer;
  position: absolute;
  z-index: 10;
  width: 50px;
  height: 50px;
  top: 30px;
  right: 30px;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: contain;
  background-image: url(../img/common/ico_close.png);
}
.modal-content {
  width: 1300px;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  position: absolute;
  z-index: 10;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 50px 60px 90px;
}
.modal-header {
  margin-bottom: 40px;
}
.modal-body {
  height: 700px;
  max-height: 100%;
  overflow: auto;
  color: #fff;
  font-size: 15px;
  line-height: 2;
}
.modal-body p {
  margin-bottom: 2rem;
  line-height: inherit;
}
.modal-over {
  position: absolute;
  z-index: 5;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.9);
}
@media (max-width: 767px) {
  .modal-content {
    width: 90%;
    height: 90%;
    padding: 35px 10px;
  }
  .modal-close {
    width: 25px;
    height: 25px;
    top: 0;
    right: 0;
  }
  .modal-body {
    height: 100%;
  }
  .modal-body p {
    margin-bottom: 1rem;
  }
  .modal .terms-wrapper {
    height: 100%;
  }
}
@media (max-width: 576px) {
  .modal-body {
    font-size: 12px;
    height: 100%;
    line-height: 1.8;
  }
  .modal-body p {
    margin-bottom: 1rem;
  }
}
@media (max-width: 320px) {
  .modal-body {
    font-size: 11px;
  }
  .modal-content {
    padding-left: 0;
    padding-right: 0;
  }
}

.group-paper {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: flex-end;
  align-items: flex-end;
  margin: 0 -22px;
}
.group-paper > * {
  padding: 0 22px;
  -webkit-flex: 0 0 33.33%;
  flex: 0 0 33.33%;
  max-width: 33.33%;
}
.group-paper .col:nth-child(1) .btn {
  margin-left: auto;
}
.group-paper .col:nth-child(3) .btn {
  margin-right: auto;
}
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .group-paper > * {
    -webkit-flex: 0 0 33.33%;
    flex: 0 0 33.33%;
    max-width: 33.33%;
  }
}
@media (max-width: 767px) {
  .group-paper .col:nth-child(1) {
    -webkit-order: 1;
    order: 1;
    -webkit-flex: 0 0 50%;
    flex: 0 0 50%;
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
    min-width: 50%;
    margin-bottom: 20px;
  }
  .group-paper .col:nth-child(3) {
    -webkit-order: 2;
    order: 2;
    -webkit-flex: 0 0 50%;
    flex: 0 0 50%;
    min-width: 50%;
    margin-bottom: 20px;
  }
  .group-paper .col:nth-child(2) {
    -webkit-order: 3;
    order: 3;
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    min-width: 100%;
  }
  .group-paper .col:nth-child(2) .btn-next {
    margin-right: auto;
  }
}
@media screen and (max-width: 480px) {
  .group-paper {
    padding-left: 20px;
    padding-right: 20px;
    width: 380px;
    max-width: 100%;
    margin: 0 auto;
  }
  .group-paper .btn {
    width: 100%;
  }
  .group-paper .col:nth-child(1), .group-paper .col:nth-child(3) {
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    min-width: 100%;
    margin-bottom: 5px;
  }
  .group-paper .col:nth-child(1) p, .group-paper .col:nth-child(3) p {
    text-align: center !important;
  }
  .group-paper .col:nth-child(3) {
    margin-bottom: 20px;
  }
}
@media (max-width: 320px) {
  .group-paper {
    padding-left: 0;
    padding-right: 0;
  }
}

.slider:not(.slick-initialized) .slide:not(:first-of-type) {
  display: none;
}

.ping-global .link {
  display: block;
  width: 200px;
  height: 230px;
  text-align: center;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: contain;
  background-image: url(../img/top/ico_ping.png);
  position: relative;
  padding: 40px 10px 10px;
  transition: transform 0.3s cubic-bezier(0.04, 0.51, 0.4, 1.24);
  -ms-transform: translateY(0px);
  transform: translateY(0px);
}
.ping-global .link:hover {
  -ms-transform: translateY(-30px);
  transform: translateY(-30px);
}
.ping-global.is-center .link {
  margin-left: auto;
  margin-right: auto;
}
.ping-global.is-left .link {
  margin-right: auto;
}
.ping-global.is-right .link {
  margin-left: auto;
}
.ping-global .heading {
  font-size: 40px;
  font-weight: 500;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
  color: #004898;
  line-height: 1.2;
  letter-spacing: -0.025em;
  margin-bottom: 5px;
}
.ping-global .heading .is-small {
  font-size: 33px;
}
.ping-global .desc {
  font-size: 15px;
  font-weight: 700;
  font-family: "Noto Sans JP", sans-serif;
  color: #333;
  letter-spacing: 0.05em;
}
.ping-global .desc.small {
  font-size: 14px;
}
@media (max-width: 740px) {
  .ping-global {
    margin-left: auto;
    margin-right: auto;
  }
  .ping-global .link {
    width: 140px;
    height: 180px;
    padding-top: 30px;
  }
  .ping-global .heading {
    font-size: 30px;
  }
  .ping-global .heading .is-small {
    font-size: 26px;
  }
  .ping-global .desc {
    font-size: 12px;
  }
  .ping-global .desc.small {
    font-size: 11px;
  }
}
@media (max-width: 320px) {
  .ping-global {
    width: 120px;
    height: 160px;
    padding-top: 25px;
  }
  .ping-global .heading {
    font-size: 25px;
  }
  .ping-global .heading .is-small {
    font-size: 22px;
  }
}

.loop-slider {
  height: 50vh;
}
.loop-slider .item {
  position: relative;
  width: 54vh;
  height: 100%;
  margin-left: -25vh;
}
.loop-slider .item img {
  position: absolute;
  top: 50%;
  left: 50%;
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  max-width: initial;
  min-width: 100%;
  height: 100%;
}

.process-wrapper {
  margin-bottom: 50px;
}
.process-steplist {
  position: relative;
  margin-bottom: 50px;
}
.process-steplist .list {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
  margin: 0 -8px;
}
.process-steplist .list > * {
  padding: 0 8px;
  -webkit-flex: 0 0 99px;
  flex: 0 0 99px;
  max-width: 99px;
}
.process-steplist .link {
  display: block;
  padding-top: 40px;
}
.process-steplist .item {
  margin-bottom: 15px;
}
.process-steplist .item:last-child .process-item:after {
  content: none;
}
.process-steplist .desc {
  font-size: 15px;
  text-align: center;
  letter-spacing: 0.1em;
}
.process-item {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  position: relative;
  text-align: center;
  padding: 5px;
  margin: 0;
  background-color: #fff;
  color: #754C24;
  line-height: 1.5 !important;
  font-size: 17px;
  font-weight: 700;
  font-style: italic;
}
.process-item:after {
  content: "";
  position: absolute;
  z-index: 10;
  right: -11px;
  top: 50%;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 6px solid #fff;
}
.process-item .number {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  text-align: center;
  position: absolute;
  left: 50%;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  top: -35px;
  width: 45px;
  height: 45px;
  border-radius: 50%;
  background-color: #754C24;
  color: #fff;
  line-height: 1;
  font-size: 23px;
  font-weight: 500;
  font-style: initial;
  font-family: "Barlow Condensed", sans-serif;
}
.process-step {
  position: relative;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  background-color: #F2F2F2;
  border-bottom: 2px solid #ED0614;
  padding: 20px 20px;
  margin: 0 0 38px 0;
}
.process-step > * {
  padding: 0 5px;
}
.process-step:not(:last-child):after {
  content: "";
  position: absolute;
  left: 50%;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  bottom: -30px;
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 15px solid #ED0614;
}
.process-step .title {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
}
.process-step .title > * {
  line-height: 1.2;
  vertical-align: middle;
  margin: 0;
}
.process-step .title .number {
  color: #ED0614;
  font-size: 45px;
  font-weight: 300;
  font-family: "Barlow Condensed", sans-serif;
}
.process-step .title .text {
  color: #754C24;
  font-size: 31px;
  font-weight: 500;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1;
  margin-left: 30px;
}
.process-step .title .text .small {
  font-size: 19px;
}
.process-step .step-content {
  font-size: 13px;
  font-weight: 600;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 2;
  letter-spacing: 0.08em;
}
.process-step .step-header {
  -webkit-flex: 0 0 340px;
  flex: 0 0 340px;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
}
.process-step .step-content {
  -webkit-flex-grow: 1;
  flex-grow: 1;
}
.process-step .step-img {
  -webkit-flex: 0 0 125px;
  flex: 0 0 125px;
  text-align: center;
}
.process-step .step-img img {
  width: 100px;
}
.process-step .step-title {
  -webkit-flex-grow: 1;
  flex-grow: 1;
  padding: 0 10px;
  font-style: italic;
}
.process-staff .tooltips {
  position: relative;
  display: inline-block;
  background-color: #ED0614;
  color: #fff;
  font-size: 13px;
  letter-spacing: 0.06em;
  line-height: 1.3;
  padding: 5px 30px;
  margin-bottom: 22px;
}
.process-staff .tooltips:after {
  content: "";
  position: absolute;
  left: 50%;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  bottom: -5px;
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid #ED0614;
}
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .process-steplist .list > * {
    -webkit-flex: 0 0 99px;
    flex: 0 0 99px;
    max-width: 99px;
  }
}
@media screen and (max-width: 740px) {
  .process-step {
    display: block;
  }
  .process-step-header, .process-step-content {
    display: block;
    width: 100%;
  }
  .process-step-header {
    margin-bottom: 15px;
  }
}
@media screen and (max-width: 480px) {
  .process-steplist .desc {
    font-size: 10px;
  }
  .process-step .step-img {
    -webkit-flex: 0 0 65px;
    flex: 0 0 65px;
  }
  .process-step .title .number {
    font-size: 35px;
  }
  .process-step .title .text {
    font-size: 27px;
    margin-left: 15px;
  }
  .process-staff .tooltips {
    font-size: 12px;
  }
}

.staff-list {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
  margin: 0 -10px;
}
.staff-list > * {
  padding: 0 10px;
  margin-bottom: 20px;
}
.staff-list .clean {
  width: 100%;
  margin: 0;
}
.staff-item {
  width: 215px;
  background-color: #754C24;
  color: #fff;
  font-size: 13px;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.3;
}
.staff-item .big {
  font-size: 15px;
}
.staff-item .link {
  display: block;
  color: currentColor;
}
.staff-item .flex {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
}
.staff-item .col:nth-child(1) {
  -webkit-flex: 0 0 85px;
  flex: 0 0 85px;
}
.staff-item .col:nth-child(2) {
  -webkit-flex-grow: 1;
  flex-grow: 1;
  text-align: center;
  padding: 5px;
}

.circle-calbee {
  overflow: hidden;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  width: 320px;
  height: 320px;
  background-color: #fff;
  border: 3px solid #ED0614;
  border-radius: 50%;
  padding: 10px;
  text-align: center;
  font-size: 13px;
}
.circle-calbee > * {
  margin-bottom: 35px;
}
.circle-calbee > *:nth-child(1) {
  margin-top: -40px;
}
@media (max-width: 767px) {
  .circle-calbee {
    width: 260px;
    height: 260px;
  }
  .circle-calbee > * {
    margin-bottom: 20px;
  }
  .circle-calbee > *:nth-child(1) {
    margin-top: -20px;
  }
}
@media (max-width: 576px) {
  .circle-calbee {
    width: 220px;
    height: 220px;
    margin-bottom: 30px;
  }
  .circle-calbee > * {
    margin-bottom: 10px;
  }
  .circle-calbee > *:nth-child(1) {
    margin-top: 0;
  }
  .circle-calbee img {
    width: 160px;
  }
}

.diagram-wrapper {
  margin-bottom: 30px;
}
.diagram-item {
  position: relative;
}
.diagram-item:after {
  content: "";
  position: absolute;
  width: 45px;
  height: 30px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url("../img/about/calbee/ico_arrow_01.png");
}
.diagram-item .header {
  text-align: center;
  position: relative;
  z-index: 10;
}
.diagram-item .content {
  margin-top: -20px;
}
.diagram-item.item01 {
  width: 410px;
  max-width: 100%;
  padding: 0 15px;
}
.diagram-item.item01:after {
  right: -50px;
  top: 50%;
}
.diagram-item.item02 {
  position: relative;
  left: -20px;
  margin-top: 40px;
}
.diagram-item.item02:after {
  bottom: 0;
  left: 40px;
  -moz-transform: rotate(135deg);
  -ms-transform: rotate(135deg);
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}
.diagram-item.item02 .content {
  margin-top: 25px;
}
.diagram-item.item03 {
  margin-top: 10px;
}
.diagram-item.item03:after {
  content: none;
}
.diagram-media {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  font-size: 13px;
  line-height: 1.75;
  text-align: center;
  margin: 0 -30px;
}
.diagram-media > .col {
  padding: 0 30px;
  margin-bottom: 0;
}
.diagram-media > .col:not(:last-child) {
  border-right: 1px dashed currentColor;
}
.diagram-media > .col:nth-child(1) {
  -webkit-flex: 0 0 270px;
  flex: 0 0 270px;
  max-width: 270px;
}
.diagram-media > .col:nth-child(2) {
  -webkit-flex-grow: 1;
  flex-grow: 1;
}
.diagram-media p {
  margin-bottom: 15px;
}
.diagram-media .row > .col {
  margin-bottom: 0;
}
@media screen and (max-width: 900px) {
  .diagram-item.item01:after {
    top: 25%;
  }
  .diagram-item.item02 {
    position: static;
  }
  .diagram-item.item03 {
    margin-top: 0;
  }
}
@media (max-width: 767px) {
  .diagram-media {
    display: block;
    margin: 0;
  }
  .diagram-media > .col {
    padding: 0;
    padding-bottom: 30px;
    margin-bottom: 30px;
    max-width: 100%;
  }
  .diagram-media > .col:not(:last-child) {
    border-right: 0;
    border-bottom: 1px dashed currentColor;
  }
  .diagram-media > .col:nth-child(1) {
    max-width: 100%;
    text-align: center;
  }
  .diagram-media .row > .col {
    margin-bottom: 15px;
  }
  .diagram-item.item01 {
    margin: 0 auto 70px;
  }
  .diagram-item.item01:after {
    top: auto;
    bottom: -50px;
    right: 50%;
    -moz-transform: translateX(50%) rotate(90deg);
    -ms-transform: translateX(50%) rotate(90deg);
    -webkit-transform: translateX(50%) rotate(90deg);
    transform: translateX(50%) rotate(90deg);
  }
  .diagram-item.item02 {
    margin-top: 70px;
    text-align: center;
  }
  .diagram-item.item02:after {
    top: auto;
    bottom: -50px;
    left: 50%;
    -moz-transform: translateX(-50%) rotate(90deg);
    -ms-transform: translateX(-50%) rotate(90deg);
    -webkit-transform: translateX(-50%) rotate(90deg);
    transform: translateX(-50%) rotate(90deg);
  }
  .diagram-item.item03 {
    margin-top: 70px;
  }
}

.celbee-group {
  border: 5px solid #fff;
  background-color: #fff;
  height: 100%;
  color: #4D4D4D;
}
.celbee-group .header {
  font-size: 18px;
  font-weight: 700;
  padding: 15px 10px;
  text-align: center;
  letter-spacing: 0.1em;
  color: #fff;
  background-color: #ABB3C0;
  margin-bottom: 0;
}
.celbee-group .title {
  font-size: 16px;
  font-weight: 700;
}
.celbee-group .border {
  margin: 30px 0;
  border: 0;
  border-bottom: 2px dotted #ED0614;
}
.celbee-group .note {
  font-size: 10px;
  text-align: right;
}
.celbee-group .content {
  padding: 35px 20px 20px;
}
.celbee-group .content > * {
  margin-bottom: 30px;
}
@media (max-width: 767px) {
  .celbee-group {
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
  }
}

.timeline-wrapper {
  margin-bottom: 50px;
}
@media (max-width: 576px) {
  .timeline-wrapper {
    margin-bottom: 30px;
  }
}

.senior-employees {
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  color: #fff;
  margin-left: auto;
  margin-right: auto;
}
.senior-employees .content {
  display: -webkit-flex;
  display: flex;
  background-color: rgba(41, 182, 255, 0.85);
  padding: 10px 0;
}
.senior-employees .content > * {
  padding: 0 10px;
}
.senior-employees .content.is-blue {
  background-color: rgba(46, 49, 146, 0.85);
}
.senior-employees .content.is-blue .banner {
  color: #2E3192;
}
.senior-employees .content.is-blue02 {
  background-color: rgba(28, 111, 177, 0.85);
}
.senior-employees .content.is-blue02 .banner {
  color: #1c6fb1;
}
.senior-employees .banner {
  width: 165px;
  height: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  text-align: center;
  background-color: rgba(255, 255, 255, 0.9);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 2;
  color: #29B6FF;
}
.senior-employees .list-staff {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 -25px;
}
.senior-employees .list-staff > * {
  padding: 0 25px;
  -webkit-flex: 0 0 240px;
  flex: 0 0 240px;
  max-width: 240px;
}
.senior-employees .list-staff > *:not(:last-child) {
  border-right: 1px solid #fff;
}
.senior-employees .staff {
  width: 100%;
  position: relative;
  color: white;
  margin-left: auto;
  margin-right: auto;
}
.senior-employees .staff-link {
  display: block;
  color: currentColor;
}
.senior-employees .staff-avatar {
  margin-bottom: 5px;
}
.senior-employees .staff-title {
  font-size: 15px;
  line-height: 1.65;
  padding-right: 50px;
  background-repeat: no-repeat;
  background-position: bottom 0.5em right;
  background-size: 50px;
  background-image: url("../img/common/ico_arrow_slider.png");
}
@media (max-width: 576px) {
  .senior-employees .content {
    display: block;
  }
  .senior-employees .content > * {
    margin-bottom: 10px;
  }
  .senior-employees .banner {
    width: 100%;
    padding: 10px;
  }
}
@media screen and (max-width: 480px) {
  .senior-employees {
    width: 300px;
  }
  .senior-employees .list-staff {
    margin: 0;
  }
  .senior-employees .list-staff > * {
    padding: 0;
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
  }
  .senior-employees .list-staff > *:not(:last-child) {
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-right: 0;
    border-bottom: 1px solid #fff;
  }
}

.talk-staff {
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
}
.talk-staff .staff-img {
  overflow: hidden;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  border: 1px solid #333;
  margin: 0 auto;
}
.talk-staff .staff-content {
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-flex-grow: 1;
  flex-grow: 1;
  letter-spacing: 0.1em;
  border-right: 1px solid #666;
  padding: 25px 0 10px 0;
}
.talk-staff .staff-name {
  font-size: 15px;
  margin-bottom: 10px;
}
.talk-staff .staff-name > * {
  display: block;
}
.talk-staff .staff-name .jp {
  font-size: 27px;
  font-weight: 700;
  margin-bottom: 5px;
}
.talk-staff .staff-text {
  font-size: 13px;
  line-height: 1.75 !important;
}
.talk-staff.is-blue .staff-img {
  border-color: #004898;
}
.talk-staff.is-blue .staff-name {
  color: #004898;
}
.talk-staff.is-green .staff-img {
  border-color: #009245;
}
.talk-staff.is-green .staff-name {
  color: #009245;
}
.talk-staff.is-pink .staff-img {
  border-color: #EB70A7;
}
.talk-staff.is-pink .staff-name {
  color: #EB70A7;
}
@media (max-width: 576px) {
  .talk-staff .staff-content {
    border: 0;
  }
}
@media screen and (max-width: 480px) {
  .talk-staff .staff-name {
    font-size: 12px;
  }
  .talk-staff .staff-name .jp {
    font-size: 22px;
  }
}

section, .common {
  padding-top: 65px;
  padding-bottom: 65px;
}
section.lead, .common.lead {
  padding-top: 105px;
}
@media (max-width: 740px) {
  section.lead, .common.lead {
    padding-top: 80px;
  }
}

.section-header {
  margin-bottom: 35px;
}
.section-header .desc {
  font-size: 15px;
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.06em;
  text-align: center;
  margin-bottom: 20px;
}
.section-header .desc .small {
  font-size: 13px;
}
.section-content {
  position: relative;
}
.section-paper {
  overflow: hidden;
  padding-top: 85px;
  padding-bottom: 85px;
}
@media (min-width: 1100.1px) {
  .section-header.is-mb70 {
    margin-bottom: 70px;
  }
  .section-header.is-mb60 {
    margin-bottom: 60px;
  }
  .section-header.is-mb50 {
    margin-bottom: 50px;
  }
  .section-header.is-mb30 {
    margin-bottom: 30px;
  }
}
@media (max-width: 576px) {
  .section-paper {
    padding-top: 30px;
    padding-bottom: 50px;
  }
}
@media screen and (max-width: 480px) {
  .section-header .desc {
    font-size: 13px;
  }
}

/* PAGES
 * ----------------------------------------------- */
.page-top.is-toggle-nav #fp-nav, .page-top.is-toggle-nav .fullpage-arrow {
  z-index: -1;
}
.page-top.is-toggle-nav .header-row {
  top: 0;
}
@media (max-width: 767px) {
  .page-top .header-row {
    top: 0;
  }
}

.fullpage-arrow .arrow-prev, .fullpage-arrow .arrow-next {
  -moz-transition: opacity 0.25s ease;
  -o-transition: opacity 0.25s ease;
  -webkit-transition: opacity 0.25s ease;
  transition: opacity 0.25s ease;
}
@media screen and (min-width: 768.1px) {
  .fullpage-arrow .arrow-prev, .fullpage-arrow .arrow-next {
    opacity: 1 !important;
  }
}

.is-animated.is-show {
  visibility: visible !important;
}

.top-modal {
  padding-top: 2.5rem;
  line-height: 2;
}

#fp-nav.fp-right {
  right: 10px;
}

#fp-nav ul li a span, .fp-slidesNav ul li a span {
  width: 12px;
  height: 12px;
  margin: 0;
  background-color: #fff;
  border: 2px solid #fff;
}

#fp-nav ul li a.active span, .fp-slidesNav ul li a.active span, #fp-nav ul li:hover a.active span, .fp-slidesNav ul li:hover a.active span {
  background-color: #ED0614;
  margin: 0;
}

#fp-nav ul li:hover a span, .fp-slidesNav ul li:hover a span {
  width: 12px;
  height: 12px;
  margin: 0;
  background-color: #ED0614;
}

.fullpage section {
  padding: 0;
  margin: 0;
}
.fullpage .wrapper {
  margin-bottom: 0 !important;
}
.fullpage-header {
  margin-bottom: 30px;
}
.fullpage-main {
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
}
.fullpage-arrow {
  display: inline-block;
  position: fixed;
  z-index: 100;
  right: 0;
  bottom: 0;
  -moz-transition: bottom 0.26s ease;
  -o-transition: bottom 0.26s ease;
  -webkit-transition: bottom 0.26s ease;
  transition: bottom 0.26s ease;
}
.fullpage-arrow > * {
  margin-top: 5px;
}
.fullpage-btn {
  display: block;
  width: 35px;
  height: 90px;
  writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  background-color: #000;
  color: #fff;
  font-size: 13px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 10px;
}
.fullpage-btn .ico {
  background-repeat: no-repeat;
  background-size: 10px;
}
.fullpage-btn.prev .ico {
  padding-top: 30px;
  background-position: top center;
  background-image: url("../img/common/ico_btn_back.png");
}
.fullpage-btn.next .ico {
  padding-bottom: 30px;
  background-position: bottom center;
  background-image: url("../img/common/ico_btn_next.png");
}
@media (max-width: 740px) {
  .fullpage-content {
    padding-top: 0;
  }
  .fullpage-btn {
    font-size: 12px;
    padding: 5px 5px;
    width: 25px;
    height: 80px;
  }
}
@media screen and (max-width: 480px) {
  .fullpage-arrow {
    bottom: 0 !important;
  }
}
@media (max-width: 320px) {
  .fullpage-btn {
    font-size: 10px;
    height: 60px;
  }
  .fullpage-btn .ico {
    background-size: 8px;
  }
  .fullpage-btn.prev .ico {
    padding-top: 20px;
  }
  .fullpage-btn.next .ico {
    padding-bottom: 20px;
  }
}

.top-slider .item {
  height: 100vh;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
@media print, (min-width: 768px) {
  .top-slider .item-01 {
    background-image: url("../img/top/kv_01.jpg");
  }
  .top-slider .item-02 {
    background-image: url("../img/top/kv_02.jpg");
  }
  .top-slider .item-03 {
    background-image: url("../img/top/kv_03.jpg");
  }
  .top-slider .item-04 {
    background-image: url("../img/top/kv_04.jpg");
  }
  .top-slider .item-05 {
    background-image: url("../img/top/kv_05.jpg");
  }
}
@media (max-width: 767px) {
  .top-slider .item {
    height: calc(100vh);
  }
  .top-slider .item-01 {
    background-image: url("../img/top/sp/kv_01.jpg");
  }
  .top-slider .item-02 {
    background-image: url("../img/top/sp/kv_02.jpg");
  }
  .top-slider .item-03 {
    background-image: url("../img/top/sp/kv_03.jpg");
  }
  .top-slider .item-04 {
    background-image: url("../img/top/sp/kv_04.jpg");
  }
  .top-slider .item-05 {
    background-image: url("../img/top/sp/kv_05.jpg");
  }
}

@media (max-width: 576px) {
  .section-top-nav {
    display: none;
  }
}

.section-top-slider {
  padding: 0 !important;
}
.section-top-slider .slick-slide > * {
  line-height: 0;
}
.section-top-slider .slider-heading {
  position: absolute;
  z-index: 10;
  top: 230px;
  right: -80px;
  font-size: 30px;
  letter-spacing: 0.08em;
  color: #fff;
}
.section-top-slider .slider-heading .bg {
  display: inline-block;
  background-color: #ED0614;
  line-height: 1;
  padding: 5px 10px;
  margin-bottom: 10px;
  vertical-align: middle;
}
.section-top-slider .slider-heading .bg > * {
  display: inline-block;
  vertical-align: middle;
  line-height: 1;
}
.section-top-slider .slider-heading .is-big {
  font-size: 73px;
  font-style: italic;
}
.section-top-slider .slider-heading .is-small {
  font-size: 13px;
}
.section-top-slider .slider-btn {
  position: absolute;
  z-index: 10;
  bottom: 120px;
  left: -60px;
  width: 155px;
  height: 130px;
  text-align: center;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: contain;
  background-image: url(../img/common/ico_bg_btn_01.png);
}
.section-top-slider .slider-btn .link {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  height: 100%;
  width: 100%;
  color: #fff;
}
.section-top-slider .slider-btn .text {
  display: inline-block;
  text-transform: uppercase;
  font-size: 29px;
  font-weight: 500;
  font-family: "Barlow Condensed", sans-serif;
  font-style: italic;
  letter-spacing: -0.025em;
  line-height: 1;
  padding-bottom: 18px;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 63px;
  background-image: url(../img/common/ico_arrow_slider.png);
}
.section-top-slider .header-primary {
  position: relative;
  z-index: 100;
}
.section-top-slider .heading-wrapper {
  position: absolute;
  z-index: 20;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.section-top-slider .heading-wrapper .wrapper {
  position: relative;
  height: 100%;
}

.section-top-nextcalbee {
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/top/bg_next_calbee.jpg);
}
.section-top-nextcalbee .fullpage-main {
  max-width: 730px;
}

.section-top-global {
  background-repeat: no-repeat, repeat-x;
  background-size: 100%, 100% 100%;
  background-position: bottom center;
  background-image: url("../img/top/bg_global_02.jpg"), url("../img/top/bg_global.jpg");
  background-color: #ADCBD7;
}
.section-top-global .fullpage-main {
  max-width: 820px;
}

.section-top-about-calbee {
  background-color: #ED0614;
  background-repeat: no-repeat;
  background-position: right -300px bottom -220px, top 220px left -70px, top right 20%, bottom center;
  background-size: 800px, 170px, 110px, 150px;
  background-image: url("../img/top/ico_calbee_1.png"), url("../img/top/ico_deco_03.png"), url("../img/top/ico_deco_02.png"), url("../img/top/ico_deco_04.png");
}
.section-top-about-calbee .fullpage-content {
  height: 80%;
}
.section-top-about-calbee .fullpage-main {
  max-width: 100%;
  margin-left: -90px;
}
.section-top-about-calbee .fullpage-header {
  margin-bottom: 0;
}
.section-top-about-calbee .heading-top {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  color: #fff;
  font-style: italic;
}
.section-top-about-calbee .heading-top .desc {
  -webkit-order: 1;
  order: 1;
  font-size: 53px;
  font-weight: 500;
  font-family: "Barlow Condensed", sans-serif;
  padding-right: 15px;
  margin-right: 0;
}
.section-top-about-calbee .heading-top .heading {
  -webkit-order: 2;
  order: 2;
  font-size: 120px;
  font-weight: 700;
  margin-right: 0;
}

.section-top-works {
  padding: 0 !important;
}
.section-top-works .works-block {
  position: absolute;
  z-index: 10;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 370px;
  height: 370px;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  background-color: rgba(117, 76, 36, 0.8);
  padding: 15px;
  margin: 0 auto;
}
.section-top-works .heading-top {
  padding-bottom: 30px;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 68px;
  background-image: url(../img/common/ico_arrow_slider.png);
}
.section-top-works .heading-top .is-big {
  font-size: 80px;
}

.section-top-job {
  padding: 0 !important;
}
.section-top-job .fullpage-header {
  margin-bottom: 60px;
}
.section-top-job .fullpage-content {
  height: 100%;
}
.section-top-job .box {
  position: relative;
  z-index: 10;
  width: 580px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}
@media print, (min-width: 768px) {
  .section-top-job .box-job {
    position: static;
  }
}
.section-top-job .box-job:after {
  content: "";
  pointer-events: none;
  position: absolute;
  top: 30%;
  right: 20px;
  width: 140px;
  height: 214px;
  z-index: -1;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url("../img/top/img_job_03.png");
}
.section-top-job .box-job .box-image {
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 20;
  background-repeat: no-repeat;
  background-position: top 48% left 8%, bottom left 8%, bottom 20px right 30px;
  background-size: 85px, 100px, 82px;
  background-image: url("../img/top/img_job_01.png"), url("../img/top/img_job_02.png"), url("../img/top/img_job_04.png");
}
.section-top-job .box-job .fullpage-main {
  position: relative;
  z-index: 5;
}
.section-top-job .btn-group {
  width: 440px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.section-top-job .btn-group .btn {
  width: 100%;
}
.section-top-job .heading-top .is-big {
  font-size: 49px;
}
.section-top-job .left {
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/top/bg_job_offer.jpg);
}
.section-top-job .right {
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/top/bg_recruit_info.jpg);
}
.section-top-job .row {
  height: 100%;
}
.section-top-job .row .col {
  width: 50%;
  margin-bottom: 0;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
}

.section-top-footer {
  height: auto !important;
  padding-top: 0 !important;
}
.section-top-footer .fp-tableCell {
  height: auto !important;
}

@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .fullpage-btn .ico {
    padding-right: 0;
  }

  .loop-slider .item img {
    max-width: none;
  }
}
@media (max-width: 1100px) {
  .section-top-slider .slider-heading {
    right: 0;
  }
  .section-top-slider .slider-heading .is-big {
    font-size: 65px;
  }
  .section-top-slider .slider-btn {
    left: 0;
    bottom: 50px;
  }

  .section-top-global {
    background-size: 160%, 100% 100%;
  }

  .section-top-about-calbee {
    background-size: 670px, 170px, 110px, 150px;
  }
  .section-top-about-calbee .fullpage-main {
    margin-left: 0;
  }

  .section-top-job .box-job:after {
    top: 90px;
    right: -40px;
    width: 140px;
    height: 160px;
  }
  .section-top-job .box-job .box-image {
    background-size: 75px, 80px, 75px;
    background-position: top 48% left, bottom left 3%, bottom 20px right 30px;
  }
}
@media screen and (min-width: 768.1px) {
  .top-modal {
    font-size: 16px;
  }

  .section-top-global .col:nth-child(1) .ping-global {
    margin-top: 30px;
  }
  .section-top-global .col:nth-child(2) .ping-global {
    margin-top: 150px;
  }

  .section-top-about-calbee .col:nth-of-type(2) {
    margin-top: 190px;
    margin-left: -35px;
  }
  .section-top-about-calbee .col:nth-of-type(3) {
    margin-top: 0;
    margin-left: -10px;
  }
}
@media screen and (min-width: 992.1px) {
  .section-top-about-calbee .col:nth-of-type(1) {
    margin-left: 80px;
  }
  .section-top-about-calbee .col:nth-of-type(2) {
    margin-top: 190px;
    margin-left: -210px;
  }
  .section-top-about-calbee .col:nth-of-type(3) {
    margin-top: 20px;
    margin-left: -160px;
  }
}
@media screen and (min-width: 520px) {
  .section-top-about-calbee .heading-top {
    text-align: center;
  }
}
@media (max-width: 767px) {
  #fp-nav ul li:nth-child(1) {
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
    opacity: 0;
  }

  .section-top-slider .slider-heading {
    left: 50px;
    right: auto;
  }
  .section-top-slider .slider-btn {
    bottom: 80px;
    left: 50px;
  }

  .section-top-job .fullpage-header {
    margin-bottom: 30px;
  }

  .section-top-about-calbee .row.four-column {
    width: 550px;
    max-width: 100%;
  }
  .section-top-about-calbee .row.four-column .col {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media (max-width: 740px) {
  #fp-nav.right {
    right: 2px;
    top: 130px;
  }

  .section-top-global {
    background-size: 100%, 100% 100%;
  }
  .section-top-global .fullpage-main {
    padding-left: 0;
    padding-right: 0;
    width: 490px;
    max-width: 100%;
  }
  .section-top-global .ping-global {
    margin-left: auto;
    margin-right: auto;
  }
  .section-top-global .ping-global.is-left .link, .section-top-global .ping-global.is-right .link {
    margin-left: auto;
    margin-right: auto;
  }

  .section-top-slider .slider-heading {
    font-size: 15px;
    left: 20px;
    top: 50%;
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
  .section-top-slider .slider-heading .bg {
    margin-bottom: 5px;
  }
  .section-top-slider .slider-heading .is-big {
    font-size: 40px;
  }
  .section-top-slider .slider-btn {
    width: 100px;
    height: 100px;
    left: 20px;
    bottom: 20px;
  }
  .section-top-slider .slider-btn .text {
    font-size: 20px;
  }

  .section-top-nextcalbee .fullpage-content {
    padding-top: 50px;
    padding-bottom: 30px;
  }
  .section-top-nextcalbee .fullpage-main {
    padding-left: 0;
    padding-right: 0;
    width: 490px;
    max-width: 100%;
  }
  .section-top-nextcalbee .row-15 {
    margin-left: 5px;
    margin-right: 5px;
  }
  .section-top-nextcalbee .row-15 > * {
    padding: 0 5px;
  }

  .section-top-about-calbee {
    background-size: 550px, 50px, 50px, 50px;
    background-position: right -100px bottom -90px, top 130px right -20px, top right 0, bottom left 20px;
  }
  .section-top-about-calbee .fullpage-content {
    height: 100%;
    padding-top: 70px;
  }
  .section-top-about-calbee .fullpage-main {
    padding-left: 0;
    padding-right: 0;
  }
  .section-top-about-calbee .fullpage-header {
    margin-bottom: 20px;
  }
  .section-top-about-calbee .heading-top {
    text-align: center;
  }
  .section-top-about-calbee .heading-top .heading {
    font-size: 50px;
  }
  .section-top-about-calbee .heading-top .desc {
    padding: 0 10px;
    font-size: 25px;
  }

  .section-top-works .fullpage-content {
    padding-top: 0;
  }
  .section-top-works .heading-top .is-big {
    font-size: 50px;
  }
  .section-top-works .works-block {
    width: 250px;
    height: 250px;
  }

  .section-top-job .fullpage-content {
    padding-top: 0;
  }
  .section-top-job .fullpage-header {
    margin-bottom: 20px;
  }
  .section-top-job .heading-top .is-big {
    font-size: 30px;
  }
  .section-top-job .btn-group {
    width: 270px;
  }
  .section-top-job .btn-group.inline > * {
    margin-bottom: 10px;
  }
  .section-top-job .box-job:after {
    top: -10px;
    right: 10px;
    width: 70px;
    height: 110px;
  }
  .section-top-job .box-job .box-image {
    height: calc(100% + 35px);
    background-size: 60px, 40px, 55px;
    background-position: top 50px left, bottom 20px left 10px, bottom 30px right 10px;
  }
  .section-top-job .btn {
    font-size: 14px;
    min-width: none;
  }
  .section-top-job .row .col {
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    padding-top: 80px;
  }
}
@media (max-width: 760px) and (min-width: 480px) {
  #fp-nav.fp-right {
    right: 5px;
    top: 125px;
  }
}
@media (max-width: 576px) {
  .section-top-about-calbee {
    background-size: 400px, 50px, 50px, 50px;
  }

  .section-top-about-calbee .four-large {
    justify-content: center;
  }

  .section-top-slider .heading-wrapper {
    background: #ed0614;
    top: auto;
    bottom: 0;
    height: auto;
  }
  .section-top-slider .heading-wrapper .wrapper {
    padding: 0;
    position: static;
  }
  .section-top-slider .heading-wrapper .slider-heading {
    position: static;
    transform: none;
    padding: 20px 15px 30px;
    font-size: 20px;
  }
  .section-top-slider .heading-wrapper .slider-heading span {
    white-space: nowrap;
  }
  .section-top-slider .heading-wrapper .slider-heading .is-big {
    font-size: 54px;
  }
  .section-top-slider .heading-wrapper .slider-heading .bg {
    margin-bottom: 7px;
  }
  .section-top-slider .slider-btn {
    left: auto;
    bottom: 100%;
    right: 30px;
  }
}
@media only screen and (max-width: 374px) {
  .section-top-slider .heading-wrapper .slider-heading {
    font-size: 18px;
  }
  .section-top-slider .heading-wrapper .slider-heading .is-big {
    font-size: 45px;
  }
}
@media screen and (max-width: 480px) {
  #fp-nav.right {
    top: calc(50% - 40px);
  }

  .section-top-job .row {
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .section-top-job .row .col {
    overflow: hidden;
    height: 50vh;
    flex: 0 0 100%;
    max-width: 100%;
  }
  .section-top-job .row .col:nth-child(1) {
    padding-top: 75px;
    height: calc(50vh + 30px);
  }
  .section-top-job .row .col:nth-child(2) {
    padding-top: 40px;
    height: calc(50vh - 30px);
  }
  .section-top-job .heading-top .is-big {
    font-size: 25px;
  }
  .section-top-job .btn-group {
    width: auto;
    padding: 0 20px;
  }
  .section-top-job .btn {
    font-size: 12px;
    padding: 12px 10px;
  }
  .section-top-job .box-job {
    height: 100%;
  }
  .section-top-job .box-job .box-image {
    height: 100%;
    background-position: top 10px left, bottom left 10px, bottom 38% right 5px;
    background-size: 40px, 40px, 39px;
  }

  .section-top-about-calbee {
    background-image: url("../img/top/sp/bg_about_calbee.jpg");
    background-size: cover;
    background-position: center top;
  }
  .section-top-about-calbee .heading-top {
    text-align: left;
  }

  .section-top-global {
    background-image: url("../img/top/sp/bg_global.jpg");
  }
  .section-top-global .col {
    margin-bottom: 0;
  }
  .section-top-global .col:nth-child(3) {
    margin-top: -10px;
  }

  .section-top-nextcalbee {
    background-image: url("../img/top/sp/bg_next_calbee.jpg");
  }
  .section-top-nextcalbee .fullpage-content {
    padding-top: 75px;
  }
  .section-top-nextcalbee .row.row-15 > * {
    margin-bottom: 10px;
  }
  .section-top-nextcalbee .row.row-15 .col {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media (max-width: 320px) {
  #fp-nav.is-bottom {
    top: 30%;
  }

  .section-top-slider .slider-heading {
    font-size: 16px;
  }
  .section-top-slider .slider-heading .is-big {
    font-size: 30px;
  }

  .section-top-job .box-job:after {
    top: 40px;
    right: 0;
    width: 60px;
    height: 90px;
  }
  .section-top-job .box-job .box-image {
    height: calc(100% + 7px);
    background-size: 45px, 35px, 45px;
    background-position: top 40px left, bottom -20px left 10px, bottom 10px right 0px;
  }
  .section-top-job .row .col:nth-child(2) {
    padding-top: 20px;
  }

  .section-top-about-calbee .row .col:nth-child(2n+1) {
    flex: 0 0 130px;
    max-width: 130px;
  }
  .section-top-about-calbee .row .col:nth-child(2n) {
    flex: 0 0 160px;
    max-width: 160px;
  }

  .section-top-nextcalbee .row.row-15 > * {
    margin-bottom: 10px;
  }
  .section-top-nextcalbee .row.row-15 .col {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .section-top-global .fullpage-content {
    padding-top: 65px;
  }
}
.box-calbee {
  position: relative;
  margin-bottom: 45px;
}
.box-calbee .flex {
  display: -webkit-flex;
  display: flex;
  border-radius: 999px;
  overflow: hidden;
  color: #fff;
  text-align: center;
}
.box-calbee .flex > * {
  -webkit-flex: 0 0 50%;
  flex: 0 0 50%;
  max-width: 50%;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: center;
  flex-direction: center;
  -webkit-justify-content: center;
  justify-content: center;
  padding: 40px 30px;
  height: 290px;
}
.box-calbee .left {
  background-color: #39B54A;
  padding-right: 180px;
  padding-left: 60px;
}
.box-calbee .right {
  background-color: #754C24;
  padding-left: 180px;
  padding-right: 60px;
}
.box-calbee .content {
  font-size: 15px;
  line-height: 1.9;
}
.box-calbee .content .label {
  display: inline-block;
  border: 1px solid #fff;
  padding: 7px 10px;
  line-height: 1.2;
  margin-bottom: 10px;
  min-width: 115px;
}
.box-calbee .mid {
  position: absolute;
  top: -15px;
  left: 50%;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
.box-future {
  max-width: 600px;
  color: #1A1A1A;
  font-size: 15px;
  font-weight: 500;
  line-height: 2.4;
  letter-spacing: 0.06em;
  text-align: center;
  background-color: #fff;
  padding: 40px 20px;
  margin: 0 auto 55px;
}
.box-future > * {
  margin-bottom: 20px;
}
.box-vision {
  max-width: 790px;
  color: #65432B;
  border: 1px solid currentColor;
  padding: 35px 35px 30px;
  margin: 0 auto 30px;
}
.box-vision .item {
  text-align: center;
  max-width: 280px;
  margin-left: auto;
  margin-right: auto;
}
.box-vision .ico {
  margin-bottom: 20px;
}
.box-vision .title {
  position: relative;
  z-index: 5;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.6;
  color: #fff;
  border-radius: 999px;
  padding: 5px;
  background-color: #70BF45;
}
.box-vision .price {
  font-size: 57px;
  line-height: 1;
  margin-top: -0.2em;
}
.box-vision .price .number {
  display: inline-block;
  font-size: 150px;
  font-style: italic;
  font-weight: 300;
  font-family: "Barlow Condensed", sans-serif;
}
.box-vision .price .symboy {
  display: inline-block;
  font-size: 100px;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
}
.box-vision .border {
  border-right: 1px solid currentColor;
}
.box-vision .col {
  margin-bottom: 0;
}
.box-vision-list {
  font-size: 13px;
  margin-bottom: 40px;
}
.box-vision-list .title-primary {
  margin-bottom: 13px;
  text-align: left;
}
.box-vision-list ul, .box-vision-list ol {
  padding: 0;
  letter-spacing: 0.04em;
}
.box-vision-list .col {
  margin: 0;
  padding: 30px 30px 30px;
}
.box-vision-list .col:nth-child(1), .box-vision-list .col:nth-child(2) {
  border-bottom: 1px solid;
}
.box-vision-list .col:nth-child(1), .box-vision-list .col:nth-child(3) {
  border-right: 1px solid;
}
.box-make {
  overflow: hidden;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  width: 205px;
  height: 205px;
  background-color: #fff;
  border-radius: 50%;
  text-align: center;
  margin: 0 auto;
}
.box-make .title {
  font-size: 18px;
  font-weight: 500;
  color: #754C24;
  line-height: 1.55;
  letter-spacing: 0.08em;
}
.box-culture {
  overflow: hidden;
  background-color: #fff;
  padding: 35px 50px;
  margin-bottom: 40px;
  color: #4D4D4D;
}
.box-culture .heading {
  position: relative;
  font-size: 46px;
  font-weight: 500;
  font-style: italic;
  color: #754C24;
  letter-spacing: 0.1em;
  line-height: 1.35;
  padding: 10px 10px 10px 70px;
  margin-bottom: 30px;
  background-repeat: no-repeat;
  background-position: left top 10px;
  background-size: 1.12em;
  background-image: url("../img/common/ico_face.png");
}
.box-culture .heading:after {
  content: "";
  position: absolute;
  z-index: 1;
  bottom: 0;
  left: -90px;
  width: 100%;
  height: 2px;
  background-color: #ED0614;
}
.box-culture .media {
  margin: 30px 0;
}
.box-culture .media .left, .box-culture .media .right {
  margin-bottom: 15px;
}
.box-culture .media-figure {
  margin-top: 10px;
}
.box-culture .media-body {
  padding-top: 0;
}
.box-culture .media-heading {
  font-weight: 700;
  color: #754C24;
  margin-bottom: 10px;
}
.box-culture .media-text {
  line-height: 1.85;
}
.box-culture-other {
  overflow: hidden;
  max-width: 780px;
  margin-left: auto;
  margin-right: auto;
  padding: 50px 0;
}
.box-culture-other .header {
  margin-bottom: 40px;
  text-align: center;
}
.box-culture-other .heading {
  display: inline-block;
  font-size: 32px;
  letter-spacing: 0.08em;
  min-width: 500px;
  padding: 20px;
  border: 1px solid currentColor;
  text-align: center;
}
.box-culture-other .list-dots {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin: 0 -20px;
  color: #fff;
}
.box-culture-other .list-dots > * {
  -webkit-flex: 0 0 auto;
  flex: 0 0 auto;
  max-width: auto;
  padding: 0 20px;
  margin-bottom: 10px;
}
@media screen and (max-width: 880px) {
  .box-calbee .content {
    font-size: 13px;
  }
  .box-make {
    width: 170px;
    height: 170px;
  }
  .box-make .title {
    font-size: 14px;
  }
}
@media (max-width: 767px) {
  .box-calbee .flex > * {
    height: 230px;
    padding: 20px 20px;
  }
  .box-calbee .left {
    padding-left: 30px;
    padding-right: 120px;
  }
  .box-calbee .right {
    padding-right: 30px;
    padding-left: 120px;
  }
  .box-vision .price {
    font-size: 45px;
  }
  .box-vision .price .number {
    font-size: 120px;
  }
  .box-vision .price .symboy {
    font-size: 80px;
  }
  .box-culture .heading {
    font-size: 33px;
    padding-left: 50px;
  }
  .box-culture-other .list-dots {
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    margin: 0;
  }
}
@media (max-width: 576px) {
  .box-calbee .flex > * {
    height: 230px;
    padding: 20px 20px;
  }
  .box-calbee .mid {
    position: static;
    -moz-transform: initial;
    -ms-transform: initial;
    -webkit-transform: initial;
    transform: initial;
    margin-bottom: 30px;
  }
  .box-calbee .mid .circle-calbee {
    margin: auto;
  }
  .box-vision {
    max-width: 400px;
  }
  .box-vision .col:not(:last-child) {
    margin-bottom: 30px;
    padding-bottom: 30px;
  }
  .box-vision .border {
    border-right: none;
    border-bottom: 1px solid currentColor;
  }
  .box-vision-list {
    overflow: hidden;
  }
  .box-vision-list .col {
    border: none !important;
    border-bottom: 1px solid currentColor !important;
  }
  .box-culture-other .header {
    margin-bottom: 20px;
  }
  .box-culture-other .heading {
    min-width: auto;
    font-size: 22px;
    padding: 10px;
    width: 100%;
  }
}
@media screen and (max-width: 480px) {
  .box-calbee .flex {
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    border-radius: 10vw;
  }
  .box-calbee .flex > * {
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
    display: block;
    height: auto;
    padding: 20px;
  }
  .box-future {
    font-size: 14px;
    line-height: 2;
    padding: 20px 15px;
    margin-bottom: 30px;
  }
  .box-vision {
    margin-bottom: 30px;
  }
  .box-vision .price {
    font-size: 35px;
  }
  .box-vision .price .number {
    font-size: 100px;
  }
  .box-vision .price .symboy {
    font-size: 60px;
  }
  .box-culture {
    padding: 20px;
  }
  .box-culture .heading {
    font-size: 26px;
    padding: 10px 0 9px 35px;
  }
  .box-culture .heading:after {
    left: -30px;
  }
  .box-culture-other {
    padding: 20px 0;
  }
}

.section-about-process {
  padding-bottom: 145px;
}

.section-about-calbee-top {
  position: relative;
  padding-bottom: 35vw;
  background-color: #3ea1da;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: cover;
  background-image: url("../img/about/calbee/img_bg_01.jpg");
}
.section-about-calbee-top .heading-secondary {
  font-style: italic;
}
.section-about-calbee-top .heading-secondary:after {
  content: none;
}

.section-about-calbee-timeline {
  padding-top: 90px;
  padding-bottom: 90px;
}

.section-about-calbee-diagram {
  padding-top: 75px;
  padding-bottom: 75px;
  font-size: 13px;
}

.section-about-calbee-group {
  padding-top: 85px;
  padding-bottom: 65px;
}

.section-about-future-top {
  padding-bottom: 110px;
  background-color: #2D9E48;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: 100% 100%;
  background-image: url("../img/about/future/bg_01.jpg");
}
.section-about-future-top .text-catchcopy {
  font-size: 36px;
  font-weight: 700;
  padding-left: 0.5em;
  line-height: 1.25em;
}

.section-about-future-vision {
  padding-top: 75px;
  padding-bottom: 90px;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: cover;
  background-image: url("../img/about/future/bg_02.jpg");
}

.section-about-future-make {
  padding-top: 110px;
  padding-bottom: 90px;
}
.section-about-future-make .media-heading {
  font-weight: 500;
}
.section-about-future-make .media-figure {
  margin-top: 0;
}

.section-about-culture {
  padding-bottom: 65px;
}
.section-about-culture .culture-content {
  margin-bottom: 55px;
}

@media (min-width: 1100.1px) {
  .section-about-calbee-top .heading-primary .eng {
    font-size: 124px;
    margin-bottom: 15px;
  }
  .section-about-calbee-top .heading-secondary {
    font-size: 31px;
  }

  .section-about-future-top .heading-primary .eng {
    font-size: 137px;
    margin-bottom: 10px;
  }
  .section-about-future-top .text-desc {
    margin-bottom: 45px;
  }

  .section-about-future-make .row.four {
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  .section-about-future-make .row.four .col {
    -webkit-flex: 0 0 225px;
    flex: 0 0 225px;
    max-width: 225px;
  }
  .section-about-future-make .col:nth-child(1) .box-make .title {
    padding-top: 10px;
  }
  .section-about-future-make .media-heading {
    margin-bottom: 25px;
  }
  .section-about-future-make .media-text {
    line-height: 2;
  }
  .section-about-future-make .media-body {
    padding-top: 10px;
  }

  .section-about-culture .media-heading {
    font-size: 22px;
  }
}
@media (max-width: 767px) {
  .section-about-calbee-top {
    padding-bottom: 40vw;
    background-size: contain;
  }
  .section-about-calbee-top .section-header {
    margin-bottom: 30px;
    padding-bottom: 30px;
  }

  .section-about-future-make .media.is-box {
    max-width: 380px;
    margin-left: auto;
    margin-right: auto;
  }

  .section-about-culture {
    padding-bottom: 30px;
  }
}
@media (max-width: 576px) {
  .section-about-process {
    padding-bottom: 80px;
  }

  .section-about-calbee-timeline, .section-about-calbee-diagram, .section-about-calbee-group {
    padding-top: 50px;
    padding-bottom: 50px;
  }

  .section-about-future-top {
    padding-bottom: 50px;
  }

  .section-about-future-vision, .section-about-future-make {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
@media screen and (max-width: 480px) {
  .section-about-process {
    padding-bottom: 40px;
  }

  .section-about-culture .culture-content {
    margin-bottom: 20px;
  }
}
.box-global-vision {
  overflow: hidden;
  border: 1px solid #1C6FB1;
  border-radius: 20px;
  padding: 30px;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin: 0 auto 85px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url(../img/global/about/bg_04.jpg);
}
.box-global-vision .row {
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
}
.box-global-vision .col {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-self: flex-start;
  align-self: flex-start;
}
.box-global-vision .col:not(:first-child) {
  border-left: 1px solid #1C6FB1;
}
.box-global-vision .content {
  width: 300px;
  max-width: 100%;
  margin: 10px auto 0;
}
.box-global-vision .title {
  font-size: 22px;
  margin-bottom: 30px;
}
.box-global-vision .light {
  color: #1C6FB1;
}
.box-global-vision .text {
  font-size: 34px;
  line-height: 1.75;
}
.box-global-vision .price {
  font-size: 36px;
  font-weight: 500;
  font-family: "Barlow Condensed", sans-serif;
  margin-bottom: 10px;
}
.box-global-vision .price * {
  display: inline-block;
  line-height: 1;
}
.box-global-vision .price .symboy {
  font-size: 50px;
}
.box-global-vision .price .number {
  font-size: 73px;
}
.box-global-vision .price.is-big {
  font-size: 57px;
}
.box-global-vision .price.is-big .symboy {
  font-size: 77px;
}
.box-global-vision .price.is-big .number {
  font-size: 116px;
}
@media (max-width: 576px) {
  .box-global-vision {
    max-width: 400px;
  }
  .box-global-vision .col {
    display: block;
  }
  .box-global-vision .col:not(:first-child) {
    border-left: 0;
    border-top: 1px solid #1C6FB1;
    padding-bottom: 25px;
  }
  .box-global-vision .title {
    margin-bottom: 20px;
  }
  .box-global-vision .text {
    font-size: 28px;
  }
}
.box-talk-staff {
  max-width: 740px;
  margin: 0 auto 30px;
}
.box-talk-staff .col {
  position: relative;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
}
.box-talk-staff .col:last-child .staff-content {
  border: 0 !important;
}
@media (max-width: 576px) {
  .box-talk-staff {
    max-width: 400px;
  }
}

.section-row {
  display: -webkit-flex;
  display: flex;
  margin: 0 -25px;
}
.section-row > * {
  padding: 0 25px;
}
.section-row .section-image {
  -webkit-flex: 0 0 400px;
  flex: 0 0 400px;
  max-width: 400px;
  padding-top: 12px;
}
.section-row .section-image .row > * {
  margin-bottom: 13px;
}
.section-row .section-image .img {
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .section-row {
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0;
  }
  .section-row > * {
    padding: 0;
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
    margin-bottom: 20px;
  }
  .section-row .section-image {
    -webkit-order: 2;
    order: 2;
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
  }
  .section-row .section-table {
    -webkit-order: 1;
    order: 1;
  }
}

.interview-staff {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
  -webkit-align-items: flex-start;
  align-items: flex-start;
  line-height: 1.75;
  margin: 0 -40px 20px;
}
.interview-staff > * {
  padding: 10px 40px;
}
.interview-staff > *:not(:last-child) {
  border-right: 3px solid #ED0614;
}
.interview-staff .name {
  font-size: 15px;
  font-weight: 500;
  color: #004898;
}
.interview-staff .name .jp {
  display: block;
  font-size: 27px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 10px;
}
.interview-staff .text {
  font-size: 13px;
}
@media screen and (max-width: 480px) {
  .interview-staff {
    -webkit-justify-content: center;
    justify-content: center;
    margin: 0 -20px 20px;
  }
  .interview-staff > * {
    padding: 10px 20px;
  }
}

.media-road {
  display: -webkit-flex;
  display: flex;
  margin: 0 -25px;
  font-size: 13px;
  line-height: 1.925;
  letter-spacing: 0.02em;
  text-align: justify;
  margin-bottom: 60px;
}
.media-road p, .media-road .text {
  line-height: 1.925;
}
.media-road > * {
  position: relative;
  padding: 0 25px;
  -webkit-flex: 0 0 50%;
  flex: 0 0 50%;
  max-width: 50%;
}
@media (max-width: 767px) {
  .media-road {
    margin-left: -15px;
    margin-right: -15px;
  }
  .media-road > * {
    padding: 0 15px;
  }
  .media-road .content {
    -webkit-flex: 0 0 60%;
    flex: 0 0 60%;
    max-width: 60%;
  }
  .media-road .thumb {
    -webkit-flex: 0 0 40%;
    flex: 0 0 40%;
    max-width: 40%;
  }
  .media-road .thumb .img {
    max-width: 100% !important;
  }
}
@media (max-width: 576px) {
  .media-road {
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 30px;
  }
  .media-road > * {
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
  }
  .media-road .content, .media-road .thumb {
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
    margin-bottom: 20px !important;
  }
  .media-road .content {
    -webkit-order: 1;
    order: 1;
    margin-bottom: 20px !important;
  }
  .media-road .thumb {
    -webkit-order: 2;
    order: 2;
    margin-bottom: 20px !important;
  }
  .media-road .thumb .img {
    position: static !important;
    max-width: 300px !important;
  }
}

.section-global-about-top {
  padding-bottom: 65px;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: cover;
  background-image: url(../img/global/about/bg_01.jpg);
}

.section-global-about-brand {
  padding-top: 65px;
  padding-bottom: 20px;
}

.section-global-about-products {
  background-color: #fff;
  padding-top: 30px;
  padding-bottom: 140px;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 100%;
  background-image: url(../img/global/about/bg_02.jpg);
}
.section-global-about-products .section-content {
  overflow: hidden;
}
.section-global-about-products .row {
  margin-bottom: 30px;
}

.section-global-about-business {
  padding-top: 65px;
  padding-bottom: 120px;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: cover;
  background-image: url(../img/global/about/bg_03.jpg);
  background-color: #89d0ec;
}

.section-global-about-sales {
  padding-bottom: 125px;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: contain;
  background-image: url(../img/global/about/bg_05.jpg);
}

.section-global-talk-top {
  padding-top: 0;
  background-color: #DFF7FD;
}
.section-global-talk-top .heading-primary .eng {
  letter-spacing: -0.01em;
  font-weight: 500;
  font-family: "Barlow Condensed", sans-serif;
}
.section-global-talk-top .section-keyvisual {
  height: 48.5vw;
  padding: 0;
  margin: 0;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  background-image: url(../img/global/talk/kv_01.jpg);
}
.section-global-talk-top .section-background {
  padding-top: 60px;
  margin-top: -230px;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: contain;
  background-image: url(../img/global/talk/earth.png);
}

.section-global-interview-top {
  padding: 0;
  margin: 0;
}
.section-global-interview-top .heading-primary {
  color: #fff;
  text-align: left;
  font-weight: 500;
}
.section-global-interview-top .heading-primary .eng {
  font-family: "Barlow Condensed", sans-serif;
  letter-spacing: 0;
  margin-bottom: 20px;
}
.section-global-interview-top .section-keyvisual {
  height: 620px;
  padding: 0;
  margin: 0;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  background-image: url(../img/global/interview/kv_01.jpg);
}
.section-global-interview-top .section-heading {
  height: 480px;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  padding: 50px 95px;
  margin: -270px 0 0 0;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% 100%;
  background-image: url(../img/global/interview/bg_01.png);
}
.section-global-interview-top .wrapper {
  margin-top: -150px;
  overflow: hidden;
}
.section-global-interview-top .desc {
  max-width: 730px;
  margin-left: auto;
  text-align: left;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.77;
}

.section-global-interview-road {
  overflow: hidden;
  padding-top: 55px;
}
.section-global-interview-road .wrapper:not(:last-child) {
  margin-bottom: 120px;
}
.section-global-interview-road .image {
  margin-bottom: 70px;
}
.section-global-interview-road .road-01 .content {
  margin-top: 145px;
}
.section-global-interview-road .road-01 .img {
  position: relative;
  left: 20px;
}
.section-global-interview-road .road-02 .img {
  position: absolute;
  top: 60px;
  left: -130px;
  max-width: none;
}
.section-global-interview-road .road-03 {
  margin-bottom: 150px;
}
.section-global-interview-road .road-03 .img {
  position: absolute;
  top: 110px;
  left: 63px;
  max-width: none;
}
.section-global-interview-road .road-04 .heading-road .text {
  letter-spacing: 0.1em;
}
.section-global-interview-road .road-04 .img {
  position: absolute;
  left: 30px;
  top: -80px;
  max-width: none;
}

.section-global-interview-message {
  padding: 0;
  margin: 0;
}
.section-global-interview-message .heading {
  font-size: 34px;
  font-weight: 500;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
  letter-spacing: 0;
  line-height: 1.4;
  margin-bottom: 35px;
}
.section-global-interview-message .flex {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  min-height: 580px;
  color: #fff;
  background-color: #004898;
  line-height: 1.925;
  font-size: 13px;
}
.section-global-interview-message .flex > * {
  -webkit-flex: 0 0 50%;
  flex: 0 0 50%;
  max-width: 50%;
  padding: 20px 90px;
}
.section-global-interview-message .flex .thumb {
  min-height: 580px;
  background-repeat: no-repeat;
  background-position: top right;
  background-size: cover;
  background-image: url(../img/global/interview/img_06.jpg);
}
.section-global-interview-message .note {
  text-align: right;
  padding: 20px 90px;
  font-size: 11px;
  letter-spacing: 0.2em;
}

@media screen and (max-width: 1440px) {
  .section-global-talk-top .section-background {
    margin-top: -220px;
  }
}
@media (min-width: 1100.1px) {
  .section-row .section-image.is-big {
    -webkit-flex: 0 0 450px;
    flex: 0 0 450px;
    max-width: 450px;
  }

  .section-global-about-top .heading-primary .eng {
    font-size: 160px;
  }
  .section-global-about-top .heading-primary .jp {
    font-size: 37px;
  }
  .section-global-about-top .section-header {
    margin-bottom: 55px;
  }
  .section-global-about-top .section-header .desc {
    font-size: 16px;
  }

  .section-global-about-sales .col {
    margin-bottom: 0;
  }
  .section-global-about-sales .col:nth-child(2) .box-global-vision .title {
    margin-bottom: 20px;
  }

  .section-global-talk-top .heading-primary {
    margin-bottom: 30px;
  }
  .section-global-talk-top .heading-primary .eng {
    font-size: 122px;
    margin-bottom: 10px;
  }
  .section-global-talk-top .heading-primary .jp {
    font-size: 23px;
  }
  .section-global-talk-top .section-header {
    margin-bottom: 40px;
  }
  .section-global-talk-top .section-header .desc {
    font-size: 16px;
  }

  .section-global-talk-section {
    padding-top: 90px;
    padding-bottom: 90px;
  }

  .section-global-interview-top .heading-primary {
    margin-top: -30px;
  }
  .section-global-interview-top .heading-primary .eng {
    font-size: 84px;
  }
  .section-global-interview-top .heading-primary .jp {
    font-size: 25px;
    font-weight: 700;
  }
  .section-global-interview-top .heading-primary .jp .small {
    font-size: 17px;
  }
  .section-global-interview-top .section-header .desc {
    font-size: 13px;
  }
}
@media (max-width: 1100px) {
  .section-global-talk-top .heading-primary .eng {
    font-size: 105px;
  }
  .section-global-talk-top .section-background {
    margin-top: -110px;
  }

  .section-global-interview-top .heading-primary .eng {
    font-size: 80px;
  }
  .section-global-interview-top .heading-primary .jp {
    font-size: 25px;
  }
  .section-global-interview-top .section-heading {
    padding: 50px 50px;
  }

  .section-global-interview-message .flex > * {
    padding: 20px 60px;
  }
}
@media (max-width: 992px) {
  .section-global-about-top .calbee-img {
    width: 450px;
  }

  .section-global-talk-top .heading-primary .eng {
    font-size: 90px;
  }

  .section-global-interview-top .section-heading {
    height: 400px;
    margin-top: -200px;
  }
  .section-global-interview-top .heading-primary .jp {
    font-size: 20px;
  }
  .section-global-interview-top .wrapper {
    margin-top: -80px;
  }

  .section-global-interview-message .flex > * {
    padding: 20px 40px;
  }
}
@media (max-width: 767px) {
  .section-global-talk-top .heading-primary .eng {
    font-size: 90px;
  }
  .section-global-talk-top .heading-primary .jp {
    font-size: 18px;
  }
  .section-global-talk-top .section-background {
    margin-top: -100px;
  }

  .section-global-interview-road .wrapper {
    margin-bottom: 70px;
  }
  .section-global-interview-road .road-01 .content {
    margin-top: 0;
  }
  .section-global-interview-road .road-01 .img {
    position: relative;
    left: auto;
    top: 110px;
  }
  .section-global-interview-road .road-02 .content, .section-global-interview-road .road-02 .thumb {
    -webkit-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
  }
  .section-global-interview-road .road-02 .img {
    position: relative;
    left: 0;
    top: 120px;
  }
  .section-global-interview-road .road-03 {
    margin-bottom: 50px;
  }
  .section-global-interview-road .road-03 .img {
    position: absolute;
    top: 110px;
    left: 0;
    max-width: none;
  }
  .section-global-interview-road .road-04 .heading-road .text {
    letter-spacing: 0.1em;
  }
  .section-global-interview-road .road-04 .img {
    position: absolute;
    left: 0;
    top: 110px;
    max-width: none;
  }

  .section-global-interview-message .heading {
    margin-bottom: 20px;
  }
  .section-global-interview-message .flex {
    min-height: 650px;
    height: auto;
  }
  .section-global-interview-message .flex > * {
    padding: 10px;
  }
  .section-global-interview-message .note {
    padding: 20px 20px;
  }

  .section-global-interview-top .heading-primary .eng {
    font-size: 60px;
  }
  .section-global-interview-top .heading-primary .jp {
    font-size: 16px;
  }
}
@media (max-width: 576px) {
  .section-global-about-top .calbee-img {
    width: 350px;
  }

  .section-global-about-brand,
  .section-global-about-products,
  .section-global-about-business,
  .section-global-about-sales {
    padding-bottom: 50px;
  }

  .section-global-about-business {
    background-size: contain;
  }

  .section-global-talk-top {
    padding-bottom: 30px;
  }
  .section-global-talk-top .heading-primary .eng {
    font-size: 70px;
  }
  .section-global-talk-top .heading-primary .jp {
    font-size: 15px;
  }
  .section-global-talk-top .section-keyvisual {
    height: 65vw;
    background-image: url("../img/global/talk/sp/kv_01.jpg");
    background-position: top center;
  }

  .section-global-interview-top .heading-primary .eng {
    font-size: 40px;
  }
  .section-global-interview-top .heading-primary .jp {
    font-size: 16px;
  }
  .section-global-interview-top .section-keyvisual {
    height: 400px;
    background-image: url("../img/global/interview/sp/kv_01.jpg");
  }
  .section-global-interview-top .section-heading {
    height: 200px;
    margin-top: -100px;
    padding: 20px;
  }
  .section-global-interview-top .wrapper {
    margin-top: -20px;
  }

  .section-global-interview-road .wrapper {
    margin-bottom: 40px;
  }
  .section-global-interview-road .road-02 .content, .section-global-interview-road .road-02 .thumb {
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
    margin-bottom: 20px;
  }
  .section-global-interview-road .road-02 .img {
    position: static;
  }

  .section-global-interview-message .flex {
    display: block;
  }
  .section-global-interview-message .flex > * {
    width: 100%;
    max-width: 100%;
  }
  .section-global-interview-message .flex .thumb {
    height: 80vw !important;
    min-height: auto;
  }
  .section-global-interview-message .note {
    padding: 10px;
    text-align: left;
  }
}
@media screen and (max-width: 480px) {
  .section-global-talk-top .heading-primary .eng {
    font-size: 55px;
  }
  .section-global-talk-top .section-keyvisual {
    height: 100vw;
    background-position: top center;
  }
  .section-global-talk-top .section-background {
    padding-top: 35px;
    margin-top: -20vw;
  }

  .section-global-interview-top .section-heading {
    height: auto;
    background-color: #004898;
    border-bottom: 3px solid #ED0614;
    background-image: none;
  }
  .section-global-interview-top .wrapper {
    margin-top: 20px;
  }

  .section-global-interview-road {
    padding-top: 20px;
  }
}
@media (max-width: 320px) {
  .section-global-talk-top {
    padding-bottom: 20px;
  }
  .section-global-talk-top .heading-primary .eng {
    font-size: 45px;
  }
  .section-global-talk-top .section-keyvisual {
    height: 100vw;
    background-position: top center;
  }
}
.recruit-keyvisual {
  position: relative;
  height: 400px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url("../img/recruit/faq/kv_01.jpg");
}
@media (max-width: 576px) {
  .recruit-keyvisual {
    height: 280px;
  }
}
@media screen and (max-width: 480px) {
  .recruit-keyvisual {
    background-image: url("../img/recruit/faq/sp/kv_01.jpg");
  }
}

.faq-wrapper {
  margin-bottom: 30px;
}
.faq-item {
  margin-bottom: 50px;
}
.faq-question {
  position: relative;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  font-size: 19px;
  font-weight: 500;
  color: #754C24;
  padding: 15px 20px 15px 70px;
  background-color: #fff;
  margin-bottom: 25px;
}
.faq-question > * {
  padding: 10px;
}
.faq-question:after {
  content: "Q";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 55px;
  height: 100%;
  color: #fff;
  font-size: 23px;
  font-family: "Noto Serif JP", serif;
  text-align: center;
  line-height: 1;
  padding: 15px;
  background-color: #65432B;
}
.faq-answer {
  font-size: 13px;
  line-height: 1.925;
  letter-spacing: 0.06em;
}
@media (max-width: 576px) {
  .faq-item {
    margin-bottom: 35px;
  }
  .faq-question {
    font-size: 16px;
    margin-bottom: 15px;
  }
}
@media screen and (max-width: 480px) {
  .faq-question {
    padding: 10px 10px 10px 70px;
  }
  .faq-question:after {
    padding: 10px;
  }
}

.block-welfare {
  background-color: #fff;
  margin-bottom: 110px;
}
.block-welfare .header {
  margin-bottom: 45px;
}
.block-welfare .heading {
  position: relative;
  font-size: 23px;
  font-weight: 700;
  color: #FFF;
  padding: 23px 10px;
  margin-bottom: 30px;
  letter-spacing: 0.08em;
	background-color: #ED0614;
	width: 100%;
	text-align: center;
}

.block-welfare .content {
  padding: 10px 70px 45px 70px;
}
.block-welfare .media {
  margin-bottom: 60px;
}
.block-welfare .media-heading {
  font-size: 19px;
  color: #754C24;
  border-left: 4px solid #754C24;
  line-height: 1.3;
  padding-left: 10px;
  margin-bottom: 18px;
}
.block-welfare .media img {
  max-width: 350px;
}
.block-welfare .text {
  font-size: 13px;
  line-height: 1.925;
  margin-bottom: 40px;
}
.block-welfare .table-wrapper {
  margin-bottom: 30px;
}
@media (max-width: 767px) {
  .block-welfare {
    margin-bottom: 80px;
  }
  .block-welfare .header {
    margin-bottom: 30px;
  }
  .block-welfare .heading {
    padding-left: 10px;
  }
  .block-welfare .content {
    padding: 10px 30px 30px;
  }
  .block-welfare .media {
    margin-bottom: 50px;
  }
  .block-welfare .media .img-number {
    width: 200px;
  }
}
@media (max-width: 576px) {
  .block-welfare {
    margin-bottom: 40px;
  }
  .block-welfare .header {
    margin-bottom: 20px;
  }
  .block-welfare .heading {
    padding: 15px 10px 15px 10px;
  }
  .block-welfare .content {
    padding: 10px 20px 20px;
  }
}

.section-recruit-faq-top, .section-recruit-welfare-top {
  overflow: hidden;
  padding-top: 0;
  padding-bottom: 160px;
  background-color: #F2F2F2;
}
.section-recruit-faq-top .recruit-keyvisual + .wrapper, .section-recruit-welfare-top .recruit-keyvisual + .wrapper {
  margin-top: -65px;
}

.section-recruit-faq-top .recruit-keyvisual {
  background-image: url("../img/recruit/faq/kv_01.jpg");
}

.section-recruit-welfare-top {
  padding-bottom: 60px;
}
.section-recruit-welfare-top .recruit-keyvisual {
  background-image: url("../img/recruit/welfare/kv_01.jpg");
}
.section-recruit-welfare-top .section-content {
  margin-bottom: 50px;
}

@media (min-width: 1100.1px) {
  .section-recruit-welfare-top .heading-quaternary {
    font-size: 49px;
    padding-top: 52px;
  }
}
@media (max-width: 576px) {
  .section-recruit-faq-top, .section-recruit-welfare-top {
    padding-bottom: 50px;
  }

  .section-recruit-welfare-top .recruit-keyvisual {
    background-image: url("../img/recruit/welfare/sp/kv_01.jpg");
  }
}
.page-joboffer {
  background-color: #EAEAEA;
}

.question-wrapper {
  padding: 0 70px;
}
@media (max-width: 767px) {
  .question-wrapper {
    padding: 0;
  }
}

.list-question {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 -10px;
}
.list-question > * {
  padding: 0 10px;
  -webkit-flex: 0 0 50%;
  flex: 0 0 50%;
  max-width: 50%;
}
.list-question .item {
  position: relative;
}
.list-question .item02 .cloud-item {
  position: relative;
  margin-top: 70px;
  margin-left: 60px;
}
.list-question .item03 {
  margin-top: 0;
}
.list-question .item03 .cloud-content > * {
  padding: 0 5px;
}
.list-question .item03 .cloud-content .ques {
  margin-bottom: 10px;
}
.list-question .item04 .cloud-wrapper {
  position: relative;
  left: 100px;
}
.list-question .item04 .cloud-item {
  position: relative;
  margin-top: 50px;
}
.list-question .item05 {
  -webkit-flex: 0 0 100%;
  flex: 0 0 100%;
  max-width: 100%;
  margin-top: 5px;
  margin-left: 65px;
}
.list-question .item05 .cloud-content .ques {
  margin-bottom: 25px;
}
.list-question .item05 .cloud-content .text {
  margin-top: 15px;
}
@media (max-width: 767px) {
  .list-question .item {
    margin-bottom: 20px;
  }
  .list-question .item:nth-child(2n+1) .cloud-modal {
    left: 30px;
  }
  .list-question .item:nth-child(2n) .cloud-modal {
    right: 30px;
  }
  .list-question .item02 .cloud-item, .list-question .item04 .cloud-item {
    margin: 0;
  }
  .list-question .item02 .cloud-wrapper, .list-question .item04 .cloud-wrapper {
    position: static;
  }
  .list-question .cloud-modal {
    left: auto;
    right: auto;
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
}
@media (max-width: 576px) {
  .list-question > * {
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
  }
  .list-question .item {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
  }
  .list-question .item .cloud-modal {
    left: 50% !important;
    right: 50% !important;
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
}

.list-potato {
  position: relative;
}
.list-potato .item01 {
  position: absolute;
  top: 0;
  right: 120px;
}
.list-potato .item01 .potato-modal {
  left: 10%;
}
.list-potato .item01 .potato-modal .content {
  width: 450px;
  max-width: 100%;
}
.list-potato .item02 {
  position: absolute;
  top: 65px;
  left: 60px;
}
.list-potato .item02 .potato-modal {
  left: 100%;
}
.list-potato .item03 {
  position: absolute;
  right: 30px;
  top: 390px;
}
.list-potato .item03 .potato-modal {
  width: 500px;
  left: 30%;
}
.list-potato .item03 .potato-modal .content {
  max-width: 400px;
}
.list-potato .item04 {
  position: absolute;
  left: 20px;
  top: 655px;
}
.list-potato .item04 .potato-modal {
  left: 80%;
}
@media (max-width: 576px) {
  .list-potato {
    margin-bottom: 50px;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-align-items: center;
    align-items: center;
  }
  .list-potato > * {
    padding: 10px;
    text-align: center;
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
    margin-bottom: 20px;
  }
  .list-potato .item {
    position: static !important;
    margin-left: auto;
    margin-right: auto;
  }
  .list-potato .item .potato-modal {
    left: 50% !important;
    right: 50% !important;
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
}

.list-staff-joboffer .item01 {
  position: absolute;
  top: 60px;
  right: 40px;
}
.list-staff-joboffer .item01 .staff-modal,
.list-staff-joboffer .item01 .staff-wrapper > span {
  left: -240px;
}
.list-staff-joboffer .staff-wrapper > span {
  position: absolute;
  top: -30px;
  width: 400px;
  font-size: 18px;
  font-weight: 700;
  color: #000;
  text-align: right;
  display: block;
  margin-bottom: 10px;
  z-index: 1000;
}
.list-staff-joboffer .staff-modal > span {
  font-size: 18px;
  font-weight: 700;
  color: #000;
  text-align: right;
  display: none;
  margin-bottom: 10px;
}
.list-staff-joboffer .item02 .staff-wrapper > span,
.list-staff-joboffer .item02 .staff-modal > span {
  text-align: left;
}
.list-staff-joboffer .item02 {
  position: absolute;
  top: 250px;
  left: 60px;
}
.list-staff-joboffer .item02 .staff-modal,
.list-staff-joboffer .item02 .staff-wrapper > span {
  left: 160px;
}
.list-staff-joboffer .item03 {
  position: absolute;
  top: 550px;
  right: 65px;
}
.list-staff-joboffer .item03 .staff-modal,
.list-staff-joboffer .item03 .staff-wrapper > span {
  left: -400px;
}
@media (max-width: 576px) {
  .list-staff-joboffer {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: center;
    justify-content: center;
  }
  .list-staff-joboffer > * {
    padding: 10px;
    text-align: center;
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
    margin-bottom: 30px;
  }
  .list-staff-joboffer .item {
    position: static !important;
    text-align: center;
  }
  .list-staff-joboffer .item .staff-modal {
    top: 50%;
    left: 50% !important;
    right: 50% !important;
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
  .list-staff-joboffer .staff-wrapper > span {
    width: 320px;
    top: -11px;
    margin: 0 auto;
    left: -27px !important;
    right: 0;
    z-index: 1;
  }
  .list-staff-joboffer .staff-modal > span {
    display: block;
  }
  .list-staff-joboffer .staff-wrapper.is-active > span {
    display: none;
  }
}

.cloud-wrapper, .potato-wrapper, .staff-wrapper {
  position: relative;
  display: inline-block;
}
.cloud-wrapper .is-over, .potato-wrapper .is-over, .staff-wrapper .is-over {
  display: none;
  position: fixed;
  z-index: 10;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(198, 198, 198, 0.6);
}
.cloud-modal, .potato-modal, .staff-modal {
  display: none;
  position: absolute;
  top: 50%;
  left: 50%;
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  z-index: 2000;
  width: 100%;
  max-width: 500px;
  text-align: left;
}
.cloud-modal .content, .potato-modal .content, .staff-modal .content {
  padding: 20px 20px;
  color: #fff;
  border-radius: 12px;
  background-color: rgba(46, 49, 146, 0.95);
}
.cloud-modal .sub-title, .potato-modal .sub-title, .staff-modal .sub-title {
  font-size: 13px;
  font-weight: 700;
  color: #FFFF00;
  padding-left: 25px;
  margin-bottom: 13px;
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 18px;
  background-image: url("../img/common/ico_cloud.png");
}
.cloud-modal .title, .potato-modal .title, .staff-modal .title {
  font-size: 19px;
  font-weight: 500;
  margin-bottom: 10px;
}
.cloud-modal .text, .potato-modal .text, .staff-modal .text {
  font-size: 13px;
  line-height: 1.7;
}
@media screen and (max-width: 480px) {
  .cloud-modal, .potato-modal, .staff-modal {
    max-width: 480px;
  }
}

.cloud-item {
  position: relative;
  color: #000;
}
.cloud-link {
  position: relative;
  display: inline-block;
  color: currentColor;
}
.cloud-content {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  padding: 15px;
}
.cloud-content > * {
  padding: 0 8px;
}
.cloud-content .ques {
  font-size: 31px;
}
.cloud-content .ques .number {
  font-size: 50px;
}
.cloud-content .text {
  font-size: 19px;
  font-weight: 700;
  line-height: 1.735 !important;
}
.cloud-modal {
  width: 420px;
}
.cloud-modal .content {
  background-color: rgba(46, 49, 146, 0.95);
}
@media screen and (max-width: 480px) {
  .cloud-content .ques {
    font-size: 25px;
  }
  .cloud-content .number {
    font-size: 35px;
  }
  .cloud-content .text {
    font-size: 16px;
  }
}

.potato-modal {
  width: 400px;
}
.potato-modal .sub-title {
  color: #C1272D;
  background-image: url("../img/common/ico_cloud_red.png");
}
.potato-modal .content {
  color: #000;
  background-color: rgba(255, 255, 255, 0.9);
}
.potato-modal .title {
  font-weight: 700;
}

.staff-wrapper.is-active .item {
  position: relative;
  z-index: 1000;
}
.staff-modal {
  width: 400px;
  top: 0;
  left: 0;
  -moz-transform: none;
  -ms-transform: none;
  -webkit-transform: none;
  transform: none;
}
.staff-modal .overflow {
  overflow: auto;
  height: 450px;
  padding-right: 15px;
}
.staff-modal .content {
  color: #000;
  background-color: rgba(255, 255, 255, 0.9);
  position: relative;
  padding-right: 5px;
}
.staff-modal .content.arrow-right:after, .staff-modal .content.arrow-left:after {
  content: "";
  position: absolute;
  display: block;
  top: 5%;
}
.staff-modal .content.arrow-right:after {
  right: -20px;
  width: 0;
  height: 0;
  border-top: solid 9px transparent;
  border-bottom: solid 9px transparent;
  border-left: solid 20px rgba(255, 255, 255, 0.9);
}
.staff-modal .content.arrow-left:after {
  right: auto;
  left: -20px;
  border-top: solid 9px transparent;
  border-bottom: solid 9px transparent;
  border-left: 0 none;
  border-right: solid 20px rgba(255, 255, 255, 0.9);
}
.staff-modal dl {
  line-height: 2;
}
.staff-modal dl dt {
  font-size: 18px;
  font-weight: 700;
  position: relative;
  padding-left: 1.5em;
  margin-bottom: 12px;
  line-height: 1.5;
}
.staff-modal dl dt:before {
  content: "▼";
  color: #ED1C24;
  position: absolute;
  top: 0;
  left: 0;
  font-size: 1em;
}
.staff-modal dl dd {
  margin-bottom: 20px;
  line-height: 2;
  font-size: 13px;
  padding-left: 1.5em;
}
@media (max-width: 576px) {
  .staff-modal {
    width: 320px;
  }
}

.over-joboffer {
  position: fixed;
  display: none;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(198, 198, 198, 0.6);
  z-index: 999;
}

.bg-joboffer-01 {
  padding-top: 75px;
  padding-bottom: 310px;
  background-repeat: no-repeat;
  background-position: bottom 20px right, top center;
  background-size: 595px, 100% 100%;
  background-image: url("../img/joboffer/01/bg_02.png"), url("../img/joboffer/01/bg_01.jpg");
}

.bg-joboffer-02 {
  padding-top: 75px;
  padding-bottom: 310px;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  background-image: url(../img/joboffer/01/bg_03.png);
}

.section-joboffer-question {
  padding-top: 0;
  padding-bottom: 0;
}
.section-joboffer-question .section-header {
  margin-bottom: 160px;
}
@media (max-width: 576px) {
  .section-joboffer-question .section-header {
    margin-bottom: 60px;
  }
  .section-joboffer-question .section-header img {
    max-width: 85%;
  }
}

.section-joboffer-answer {
  padding-top: 0;
  margin-top: -110px;
}
.section-joboffer-answer .wrapper {
  min-height: 1700px;
}
.section-joboffer-answer .img {
  position: absolute;
  top: -210px;
  left: 20px;
}
@media (max-width: 576px) {
  .section-joboffer-answer {
    margin-top: -130px;
  }
  .section-joboffer-answer .img {
    width: 240px;
  }
}
@media screen and (max-width: 480px) {
  .section-joboffer-answer .img {
    top: -150px;
    left: -10px;
  }
}

@media screen and (max-width: 480px) {
  .list-question .item .cloud-modal,
  .list-potato .item .potato-modal,
  .list-staff-joboffer .item .staff-modal {
    max-width: 300px;
  }
}
.sliders-joboffer .slick-prev, .sliders-joboffer .slick-next {
  font-size: inherit;
  position: absolute;
  top: 50%;
  width: 20px;
  height: 20px;
}
.sliders-joboffer .slick-prev:after, .sliders-joboffer .slick-prev:before, .sliders-joboffer .slick-next:after, .sliders-joboffer .slick-next:before {
  content: none;
}
.sliders-joboffer .slick-prev {
  margin-top: -10px;
  left: -25px;
  border-left: 3px solid #E50012;
  border-top: 3px solid #E50012;
  -moz-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.sliders-joboffer .slick-next {
  margin-top: -10px;
  right: -25px;
  border-right: 3px solid #E50012;
  border-top: 3px solid #E50012;
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.box-special {
  padding: 45px;
  border-radius: 30px;
  background: #fff;
  margin: 0 auto 55px;
}
.box-special .is-mb0 {
  margin-bottom: 0;
}
.box-special .text-desc {
  text-align: center;
  font-size: 22px;
  margin-bottom: 0;
}
.box-special .inner-flex {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin: 0 -10px;
}
.box-special .inner-flex > * {
  padding-left: 10px;
  padding-right: 10px;
}
.box-special .inner-flex .slider {
  width: 480px;
  max-width: 100%;
}
.box-special .inner-flex .youtube {
  position: relative;
  max-width: 100%;
}
.box-special .inner-flex .youtube.is-bottom {
  -webkit-align-self: flex-end;
  align-self: flex-end;
}
.box-special .inner-flex .youtube .btnsmall {
  position: absolute;
  z-index: 10;
  bottom: 0;
}
.box-special .inner-box {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  border: 5px solid #E50012;
  border-radius: 15px;
  justify-content: space-between;
  padding: 0 25px;
  margin-top: 45px;
  margin-bottom: 45px;
}
.box-special .inner-box .content {
  width: 610px;
  font-size: 16px;
  font-weight: 500;
  font-family: "M PLUS Rounded 1c", sans-serif;
}
.box-special .inner-box .slider {
  padding-left: 15px;
  padding-right: 15px;
}
.box-special .inner-box .title {
  background: #E50012;
  color: #fff;
  width: 370px;
  max-width: 100%;
  padding: 5px 10px;
  margin-top: -32px;
  margin-bottom: 30px;
}
.box-special .inner-box .title dl {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-align-items: center;
  align-items: center;
  margin-bottom: 8px;
}
.box-special .inner-box .title dd {
  font-size: 24px;
  margin-left: 30px;
}
.box-special .inner-box .title .pros {
  border-top: 1px solid #fff;
  font-size: 14px;
  padding: 5px 0;
  margin: 0;
}
.box-special .inner-box p, .box-special .inner-box .text {
  margin-bottom: 15px;
  line-height: 1.6;
}
.box-special .inner-box .slider-wrapper {
  width: 318px;
  margin: 0;
}
.box-special .text {
  font-weight: 500;
  font-size: 20px;
  font-family: "M PLUS Rounded 1c", sans-serif;
  line-height: 1.7 !important;
  padding-right: 20px;
  margin-bottom: 35px;
  width: 100%;
}
.box-special .text span {
  color: #ED0614;
}
.box-special .text.is-mb80 {
  margin-bottom: 80px;
}
.box-special .slider-wrapper {
  width: 410px;
  max-width: 100%;
  margin-left: 30px;
}
.box-special .slider-wrapper .slick-slide > div {
  line-height: 0;
}
.box-special .slider-wrapper .slick-dots li button:before {
  font-size: 15px;
}
.box-special .slider-wrapper p {
  margin-bottom: 0 !important;
}
@media (max-width: 992px) {
  .box-special .inner-box {
    display: block;
  }
  .box-special .inner-box .content, .box-special .inner-box .slider {
    width: 100%;
    margin-bottom: 25px;
  }
  .box-special .inner-box .slider-wrapper {
    width: 320px;
    margin: 0 auto;
  }
}
@media (max-width: 767px) {
  .box-special .inner-flex {
    display: block;
  }
  .box-special .inner-flex .slider, .box-special .inner-flex .youtube {
    width: 100%;
    margin-bottom: 25px;
  }
  .box-special .inner-flex .youtube {
    width: 350px;
    margin-left: auto;
    margin-right: auto;
  }
  .box-special .slider-wrapper {
    margin-left: auto;
    margin-right: auto;
  }
}
@media (max-width: 576px) {
  .box-special .text {
    font-size: 16px;
  }
  .box-special .text.is-mb80 {
    margin-bottom: 35px;
  }
}
@media screen and (max-width: 480px) {
  .box-special {
    padding: 20px;
  }
  .box-special .slider-wrapper {
    padding-bottom: 30px;
  }
  .box-special .inner-box .title dl {
    display: block;
  }
  .box-special .inner-box .title dt, .box-special .inner-box .title dd {
    margin: 0 0 5px 0;
  }
  .box-special .inner-flex .youtube .btnsmall {
    width: 100px;
  }
}

.heading-joboffer {
  position: relative;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  padding-bottom: 60px;
  padding-right: 270px;
  margin-bottom: 40px;
  background-repeat: no-repeat;
  background-position: bottom left;
  background-size: auto 29px;
  background-image: url("../img/joboffer/02/ico_line.png");
}
.heading-joboffer .ico {
  position: absolute;
  z-index: 10;
  top: 0;
  right: 0;
}
.heading-joboffer .heading {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 48px;
  font-weight: 700;
  line-height: 1.25;
  color: #000;
}
.heading-joboffer .heading-ballon {
  display: inline-block;
  color: #fff;
  position: relative;
}
.heading-joboffer .heading-ballon .txt {
  font-size: 18px;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 600;
  position: absolute;
  text-align: center;
  right: 15px;
  top: 15px;
}
.heading-joboffer .heading-ballon .txt .big {
  font-size: 36px;
  margin-top: 8px;
}
.heading-joboffer .heading-ballon .txt span {
  display: block;
  line-height: 1;
}
@media (max-width: 767px) {
  .heading-joboffer {
    display: block;
    padding-right: 0;
  }
  .heading-joboffer .ico {
    position: static;
  }
  .heading-joboffer .col {
    margin-bottom: 25px;
  }
  .heading-joboffer .col:nth-child(2) {
    text-align: center;
  }
  .heading-joboffer .heading {
    font-size: 40px;
    text-align: center;
  }
}
@media (max-width: 576px) {
  .heading-joboffer .heading {
    font-size: 34px;
  }
}
@media screen and (max-width: 480px) {
  .heading-joboffer .heading {
    font-size: 27px;
  }
}

.section-joboffer-calbell {
  padding-top: 0;
  overflow: hidden;
}
.section-joboffer-calbell .wrapper {
  max-width: 1200px;
  background-color: #ED0614;
}
.section-joboffer-calbell .section-keyvisual {
  position: relative;
  height: 725px;
  margin-left: -10px;
  margin-right: -10px;
  border-bottom: 5px solid #fff;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-image: url("../img/joboffer/02/img_01.jpg");
}
.section-joboffer-calbell .section-keyvisual .logo {
  position: absolute;
  top: 60px;
  left: 75px;
  z-index: 10;
}
.section-joboffer-calbell .section-keyvisual .map {
  position: absolute;
  bottom: 40px;
  left: 90px;
  z-index: 10;
}
.section-joboffer-calbell .section-keyvisual .text {
  position: absolute;
  top: 60px;
  left: 480px;
}
.section-joboffer-calbell .section-anchor-link {
  text-align: center;
  padding: 20px 30px 0px 30px;
  margin: 0 -20px;
  background-color: #ffffff;
}
.section-joboffer-calbell .section-content {
  padding: 20px;
}
@media (max-width: 767px) {
  .section-joboffer-calbell .section-keyvisual {
    height: 560px;
  }
  .section-joboffer-calbell .section-keyvisual .logo {
    top: 200px;
    left: 30px;
  }
  .section-joboffer-calbell .section-keyvisual .text {
    top: 130px;
    left: 260px;
    right: auto;
    width: 300px;
  }
  .section-joboffer-calbell .section-keyvisual .map {
    width: 80%;
    left: 10%;
    bottom: 20px;
  }
  .section-joboffer-calbell .section-content {
    padding-left: 0;
    padding-right: 0;
  }
}
@media screen and (max-width: 480px) {
  .section-joboffer-calbell .section-keyvisual {
    text-align: center;
    padding-top: 80px;
  }
  .section-joboffer-calbell .section-keyvisual .logo, .section-joboffer-calbell .section-keyvisual .map, .section-joboffer-calbell .section-keyvisual .text {
    position: static;
    text-align: center;
    margin: 0 auto 25px;
    max-width: 100%;
  }
  .section-joboffer-calbell .section-keyvisual .text {
    width: 240px;
  }
  .section-joboffer-calbell .section-keyvisual .map {
    width: 340px;
  }
}

.page-joboffer-03 .modal-over {
  background-color: rgba(255, 255, 255, 0.8);
}
.page-joboffer-03 .modal-content {
  width: auto;
  padding: 0;
  height: 100%;
}
.page-joboffer-03 .modal-content .modal-close {
  display: none;
}
@media (max-width: 576px) {
  .page-joboffer-03 .modal-content {
    width: 90%;
  }
}

.modal-special-overflow {
  overflow: auto;
  height: 100%;
  padding-bottom: 0;
}

.modal-special-wrapper {
  width: 900px;
  max-width: 100%;
  margin: 0 auto;
  overflow: auto;
  color: #1A1A1A;
  background: white;
  border-radius: 30px;
  border: 6px solid;
  line-height: 1;
  letter-spacing: 0.05em;
  padding-bottom: 0;
}
.modal-special-wrapper .profiles {
  width: 600px;
  max-width: 100%;
}
.modal-special-wrapper .profiles .name {
  font-size: 18px;
  font-weight: 700;
  padding-bottom: 0;
  position: relative;
  border-bottom: 1px solid;
}
.modal-special-wrapper .profiles .name .jp, .modal-special-wrapper .profiles .name .eng {
  display: block;
  margin-bottom: 10px;
}
.modal-special-wrapper .profiles .name .jp {
  font-size: 45px;
}
.modal-special-wrapper .profiles .desc {
  font-size: 18px;
  font-weight: 700;
  padding: 13px 0;
}
.modal-special-wrapper .profiles .text {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.85;
}
.modal-special-wrapper .modal-header {
  margin-bottom: 0;
  position: relative;
}
.modal-special-wrapper .modal-header .title {
  text-align: center;
  font-size: 30px;
  padding: 30px 0;
  font-weight: 700;
  line-height: 1.3;
}
.modal-special-wrapper .modal-header .dept {
  text-align: center;
  padding: 25px 0;
  font-size: 40px;
  font-weight: 700;
  color: #fff;
  background-color: #eee;
}
.modal-special-wrapper .modal-staff {
  position: relative;
  color: #1A1A1A;
  padding: 40px;
}
.modal-special-wrapper .modal-staff .image {
  position: absolute;
  top: -80px;
  right: 0;
}
.modal-special-wrapper .modal-body {
  overflow: initial;
  color: #1A1A1A;
  padding: 25px 40px 40px 40px;
  height: auto;
}
.modal-special-wrapper .modal-question {
  position: relative;
  margin-bottom: 40px;
}
.modal-special-wrapper .modal-question .ques {
  min-height: 75px;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  position: relative;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.4;
  padding-left: 100px;
  margin-bottom: 20px;
}
.modal-special-wrapper .modal-question .ques:before {
  content: "Q";
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-align-items: center;
  align-items: center;
  position: absolute;
  top: 50%;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 0;
  width: 75px;
  height: 75px;
  border-radius: 38px;
  color: #fff;
  font-size: 40px;
  font-weight: 700;
  background-color: #333;
}
.modal-special-wrapper .modal-question .text {
  font-size: 14px;
  line-height: 1.85;
  letter-spacing: 0;
}
.modal-special-wrapper .modal-question .text p {
  line-height: inherit;
}
.modal-special-wrapper .modal-question .light {
  font-weight: 700;
}
.modal-special-wrapper .modal-footer {
  padding: 30px 40px;
}
.modal-special-wrapper .modal-footer .btn-close {
  width: 150px;
  margin: 0 auto;
  display: block;
  cursor: pointer;
  padding: 10px 0;
  border: 1px solid #000;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  border-radius: 5px;
  transition: opacity 0.3s ease-out;
}
.modal-special-wrapper.is-red {
  border-color: #ED0614;
}
.modal-special-wrapper.is-red .profiles .name {
  border-bottom-color: #ED0614;
}
.modal-special-wrapper.is-red .modal-header .title {
  color: #ED0614;
}
.modal-special-wrapper.is-red .modal-header .dept {
  background-color: #ED0614;
}
.modal-special-wrapper.is-red .modal-question .ques {
  color: #ED0614;
}
.modal-special-wrapper.is-red .modal-question .ques:before {
  background-color: #ED0614;
}
.modal-special-wrapper.is-red .modal-question .light {
  color: #ED0614;
}
.modal-special-wrapper.is-green {
  border-color: #39B54A;
}
.modal-special-wrapper.is-green .profiles .name {
  border-bottom-color: #39B54A;
}
.modal-special-wrapper.is-green .modal-header .title {
  color: #39B54A;
}
.modal-special-wrapper.is-green .modal-header .dept {
  background-color: #39B54A;
}
.modal-special-wrapper.is-green .modal-question .ques {
  color: #39B54A;
}
.modal-special-wrapper.is-green .modal-question .ques:before {
  background-color: #39B54A;
}
.modal-special-wrapper.is-green .modal-question .light {
  color: #39B54A;
}
.modal-special-wrapper.is-green-bold {
  border-color: #009245;
}
.modal-special-wrapper.is-green-bold .profiles .name {
  border-bottom-color: #009245;
}
.modal-special-wrapper.is-green-bold .modal-header .title {
  color: #009245;
}
.modal-special-wrapper.is-green-bold .modal-header .dept {
  background-color: #009245;
}
.modal-special-wrapper.is-green-bold .modal-question .ques {
  color: #009245;
}
.modal-special-wrapper.is-green-bold .modal-question .ques:before {
  background-color: #009245;
}
.modal-special-wrapper.is-green-bold .modal-question .light {
  color: #009245;
}
.modal-special-wrapper.is-green-light {
  border-color: #8BC34A;
}
.modal-special-wrapper.is-green-light .profiles .name {
  border-bottom-color: #8BC34A;
}
.modal-special-wrapper.is-green-light .modal-header .title {
  color: #8BC34A;
}
.modal-special-wrapper.is-green-light .modal-header .dept {
  background-color: #8BC34A;
}
.modal-special-wrapper.is-green-light .modal-question .ques {
  color: #8BC34A;
}
.modal-special-wrapper.is-green-light .modal-question .ques:before {
  background-color: #8BC34A;
}
.modal-special-wrapper.is-green-light .modal-question .light {
  color: #8BC34A;
}
.modal-special-wrapper.is-orange {
  border-color: #DD5A24;
}
.modal-special-wrapper.is-orange .profiles .name {
  border-bottom-color: #DD5A24;
}
.modal-special-wrapper.is-orange .modal-header .title {
  color: #DD5A24;
}
.modal-special-wrapper.is-orange .modal-header .dept {
  background-color: #DD5A24;
}
.modal-special-wrapper.is-orange .modal-question .ques {
  color: #DD5A24;
}
.modal-special-wrapper.is-orange .modal-question .ques:before {
  background-color: #DD5A24;
}
.modal-special-wrapper.is-orange .modal-question .light {
  color: #DD5A24;
}
.modal-special-wrapper.is-orange-light {
  border-color: #E3801E;
}
.modal-special-wrapper.is-orange-light .profiles .name {
  border-bottom-color: #E3801E;
}
.modal-special-wrapper.is-orange-light .modal-header .title {
  color: #E3801E;
}
.modal-special-wrapper.is-orange-light .modal-header .dept {
  background-color: #E3801E;
}
.modal-special-wrapper.is-orange-light .modal-question .ques {
  color: #E3801E;
}
.modal-special-wrapper.is-orange-light .modal-question .ques:before {
  background-color: #E3801E;
}
.modal-special-wrapper.is-orange-light .modal-question .light {
  color: #E3801E;
}
.modal-special-wrapper.is-modal-02 .modal-staff .image {
  top: 20px;
}
.modal-special-wrapper.is-modal-03 .modal-staff .image {
  right: 110px;
}
.modal-special-wrapper.is-modal-05 .modal-staff .image {
  width: 330px;
  right: 40px;
}
@media (max-width: 767px) {
  .modal-special-wrapper {
    width: 100%;
  }
}

@media only screen and (max-width: 767px) {
  .modal-special-wrapper .modal-staff .image {
    position: static;
  }
}
@media screen and (max-width: 480px) {
  .modal-special-wrapper .modal-question .ques {
    font-size: 18px;
    padding-left: 65px;
  }
  .modal-special-wrapper .modal-question .ques br {
    display: none;
  }
  .modal-special-wrapper .modal-question .ques:before {
    width: 50px;
    height: 50px;
    font-size: 26px;
  }
  .modal-special-wrapper .modal-header .title {
    font-size: 26px;
    padding: 25px 10px;
  }
}
.section-joboffer-special-article {
  padding-top: 0;
  padding-bottom: 0;
  border-bottom: 3px solid #ED0614;
}
.section-joboffer-special-article .wrapper {
  max-width: 1200px;
  padding-left: 0;
  padding-right: 0;
}
.section-joboffer-special-article .section-header {
  margin-bottom: 0;
}
.section-joboffer-special-article .contents-specal-01, .section-joboffer-special-article .contents-specal-02 {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
}
.section-joboffer-special-article .contents-specal-01 .inner, .section-joboffer-special-article .contents-specal-02 .inner {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: stretch;
  align-items: stretch;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 60px;
  height: 100%;
}
.section-joboffer-special-article .contents-specal-01 .inner > *:nth-child(2n+1), .section-joboffer-special-article .contents-specal-02 .inner > *:nth-child(2n+1) {
  text-align: left;
}
.section-joboffer-special-article .contents-specal-01 .inner > *:nth-child(2n), .section-joboffer-special-article .contents-specal-02 .inner > *:nth-child(2n) {
  text-align: right;
}
.section-joboffer-special-article .contents-specal-01 .item, .section-joboffer-special-article .contents-specal-02 .item {
  width: 100%;
}
.section-joboffer-special-article .contents-specal-01 .item a, .section-joboffer-special-article .contents-specal-02 .item a {
  display: block;
}
.section-joboffer-special-article .contents-specal-01 {
  background-image: url(../img/joboffer/03/bg_01.jpg);
  height: 1185px;
}
.section-joboffer-special-article .contents-specal-02 {
  background-image: url(../img/joboffer/03/bg_02.jpg);
  height: 2000px;
}
@media (min-width: 1100.1px) {
  .section-joboffer-special-article .contents-specal-01 .item01 {
    margin-top: -10px;
  }
  .section-joboffer-special-article .contents-specal-01 .item02 {
    margin-top: 70px;
    margin-right: 20px;
  }
  .section-joboffer-special-article .contents-specal-02 .item01 {
    margin-top: -6px;
    margin-left: 20px;
  }
  .section-joboffer-special-article .contents-specal-02 .item02 {
    margin-top: -20px;
  }
  .section-joboffer-special-article .contents-specal-02 .item03 {
    margin-top: -130px;
    margin-left: -40px;
  }
  .section-joboffer-special-article .contents-specal-02 .item04 {
    margin-top: -190px;
    margin-right: 15px;
  }
}
@media screen and (max-width: 480px) {
  .section-joboffer-special-article .contents-specal-01 {
    height: 800px;
  }
  .section-joboffer-special-article .contents-specal-02 {
    height: 1500px;
  }
  .section-joboffer-special-article .section-header {
    background: #f4ec09;
    padding-top: 50px;
  }
}
@media screen and (max-width: 375px) {
  .section-joboffer-special-article .contents-specal-01 .inner, .section-joboffer-special-article .contents-specal-02 .inner {
    padding: 30px;
  }
  .section-joboffer-special-article .contents-specal-01 {
    height: 700px;
  }
  .section-joboffer-special-article .contents-specal-02 {
    height: 1500px;
  }
}
@media screen and (max-width: 320px) {
  .section-joboffer-special-article .contents-specal-02 {
    height: 1120px;
  }
}

.is-relative {
  position: relative;
}

.work-title {
  position: relative;
  font-size: 37px;
  font-weight: 500;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
  color: #754C24;
  line-height: 1 !important;
  letter-spacing: -0.025em;
  text-align: center;
  padding-bottom: 5px;
  margin-bottom: 50px;
}
.work-title:before {
  content: "";
  width: 35px;
  height: 3px;
  position: absolute;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  background-color: #754C24;
}

.filters-wrapper {
  position: relative;
  margin-bottom: 50px;
}
.filters-list {
  margin-bottom: 35px;
}
.filters-list .list {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  margin: 0 -5px;
}
.filters-list .list > * {
  -webkit-flex: 0 0 20%;
  flex: 0 0 20%;
  max-width: 20%;
  padding: 0 5px;
  margin-bottom: 10px;
}
.filters-list .button {
  color: #fff;
  background-color: #333;
  display: block;
  text-align: center;
  padding: 13px 10px;
  font-size: 13px;
  letter-spacing: 0.15em;
}
.filters-list .button.is-red {
  background-color: #ED0614;
}
.filters-list .button.is-green {
  background-color: #43A047;
}
.filters-list .button.is-brown {
  background-color: #754C24;
}
.filters-list .button.is-orange {
  background-color: #F15A24;
}
.filters-list .button.is-blue {
  background-color: #0277BD;
}
@media (max-width: 576px) {
  .filters-list .list > * {
    -webkit-flex: 0 0 33.33%;
    flex: 0 0 33.33%;
    max-width: 33.33%;
  }
}
@media screen and (max-width: 480px) {
  .filters-list .list > * {
    -webkit-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
  }
}

.person-wrapper {
  position: relative;
}
.person-wrapper .block {
  position: absolute;
  bottom: -40px;
  right: 0;
  margin-top: -10px;
}
.person-avatar {
  width: 1080px;
  height: 600px;
  position: relative;
  left: -155px;
}
.person-avatar img {
  max-width: initial;
  width: 100%;
}
.person-info {
  text-align: right;
  margin-bottom: 30px;
}
.person-info .name {
  margin-bottom: 10px;
}
.person-info .name .eng, .person-info .name .jp {
  display: block;
  line-height: 1;
}
.person-info .name .eng {
  font-size: 121px;
  font-weight: 500;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
  color: #ED0614;
  letter-spacing: -0.025em;
  margin-bottom: 15px;
}
.person-info .name .jp {
  font-size: 37px;
  font-weight: 700;
  color: #754C24;
}
.person-info .dept {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.85;
}
.person-desc {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  font-size: 37px;
  font-weight: 500;
  font-family: "Noto Serif JP", serif;
  letter-spacing: 0.1em;
  line-height: 1.7;
  color: #754C24;
  text-align: left;
}
.person-profile {
  width: 385px;
  max-width: 100%;
  position: relative;
  z-index: 10;
  color: #fff;
  background-color: #ED0614;
  padding: 15px 30px 25px 0;
  margin-bottom: 60px;
}
.person-profile:before {
  content: "";
  position: absolute;
  z-index: -1;
  height: 100%;
  width: 100vw;
  right: 100%;
  top: 0;
  background: #ED0614;
}
.person-profile .title {
  font-size: 27px;
  font-weight: 500;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
  letter-spacing: -0.025em;
  list-style: 1px;
  margin-bottom: 10px;
}
.person-profile .text {
  font-size: 13px;
  line-height: 1.7;
}
.person-title {
  position: relative;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #ED0614;
  margin-bottom: 20px;
}
.person-title > * {
  display: block;
}
.person-title .number {
  position: relative;
  font-size: 57px;
  font-weight: 500;
  font-style: italic;
  font-family: "Barlow Condensed", sans-serif;
  color: #8C6239;
  line-height: 1;
  padding: 0 5px;
}
.person-title .number:after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 50%;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 45px;
  height: 6px;
  background-color: #8C6239;
}
.person-title .text {
  padding-left: 15px;
  margin-top: 0.5em;
}
.person-content .clearfix {
  margin-bottom: 65px;
}
.person-content .media-body {
  font-size: 13px;
  line-height: 1.9;
}
.person-thumb {
  position: relative;
  left: 65px;
  width: 1080px;
  height: 470px;
}
.person-banner {
  height: 550px;
  width: 100%;
  padding: 0;
  margin: 0;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.person-banner.person01 {
  background-image: url("../img/works/person01/img_04.jpg");
}
.person-banner.person02 {
  background-image: url("../img/works/person02/img_04.jpg");
}
.person-banner.person03 {
  background-image: url("../img/works/person03/img_04.jpg");
}
.person-banner.person04 {
  background-image: url("../img/works/person04/img_04.jpg");
}
.person-banner.person05 {
  background-image: url("../img/works/person05/img_04.jpg");
}
.person-banner.person06 {
  background-image: url("../img/works/person06/img_04.jpg");
}
.person-banner.person07 {
  background-image: url("../img/works/person07/img_04.jpg");
}
.person-banner.person08 {
  background-image: url("../img/works/person08/img_04.jpg");
}
.person-banner.person09 {
  background-image: url("../img/works/person09/img_04.jpg");
}
.person-banner.person10 {
  background-image: url("../img/works/person10/img_04.jpg");
}
.person-banner.person11 {
  background-image: url("../img/works/person11/img_04.jpg");
}
.person-banner.person12 {
  background-image: url("../img/works/person12/img_04.jpg");
}
.person-banner.person13 {
  background-image: url("../img/works/person13/img_04.jpg");
}
.person-banner.person14 {
  background-image: url("../img/works/person14/img_04.jpg");
}
.person-banner.person15 {
  background-image: url("../img/works/person15/img_04.jpg");
}
.person-banner.person16 {
  background-image: url("../img/works/person16/img_04.jpg");
}
.person-banner.person17 {
  background-image: url("../img/works/person17/img_04.jpg");
}
.person-banner.person18 {
  background-image: url("../img/works/person18/img_04.jpg");
}
.person-banner.person19 {
  background-image: url("../img/works/person19/img_04.jpg");
}
.person-banner.person20 {
  background-image: url("../img/works/person20/img_04.jpg");
}
.person-paper {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
}
.person-paper > * {
  padding: 0 25px;
  width: 50%;
}
.person-paper .btn {
  width: 300px;
  max-width: 100%;
  padding-left: 30px;
  padding-right: 30px;
}
@media screen and (min-width: 1024px) {
  .person-content .media-body {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    flex-direction: column;
  }
  .person-wrapper .block {
    min-width: 740px;
  }
  .person-desc {
    justify-content: flex-start;
    max-width: 490px;
    align-self: flex-start;
    margin-left: auto;
  }
}
@media (max-width: 992px) {
  .person-desc {
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
    right: 0;
    text-align: right;
    font-size: 28px;
    max-width: 100%;
  }
}
@media (max-width: 767px) {
  .person-info {
    margin-bottom: 10px;
  }
  .person-info .name .eng {
    font-size: 60px;
  }
  .person-info .name .jp {
    font-size: 20px;
  }
  .person-avatar {
    width: 100%;
    height: auto;
    left: 0;
    right: 0;
  }
  .person-avatar img {
    max-width: 100%;
  }
  .person-thumb {
    left: 0;
    width: 100%;
    height: auto;
  }
  .person-thumb img {
    max-width: 100%;
  }
  .person-desc {
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
    width: 100%;
    font-size: 20px;
    text-align: right;
    right: 0;
  }
  .person-banner {
    height: 400px;
  }
}
@media (max-width: 576px) {
  .person-wrapper .block {
    margin-top: 10px;
    position: static;
  }
  .person-info {
    text-align: left;
    margin-bottom: 10px;
  }
  .person-info .name .eng {
    font-size: 60px;
  }
  .person-info .name .jp {
    font-size: 20px;
  }
  .person-desc {
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
    position: absolute;
    top: 0;
    right: 0;
    padding: 10px;
    width: 220px;
    font-size: 17px;
    text-align: right;
  }
  .person-content .media-figure img {
    max-width: 300px;
  }
  .person-banner {
    height: 300px;
  }
  .person-paper {
    display: block;
    text-align: center;
  }
  .person-paper > * {
    margin-bottom: 20px;
    width: 100%;
  }
  .person-paper .btn {
    width: 300px;
    max-width: 100%;
  }
}
@media screen and (max-width: 375px) {
  .person-desc {
    font-size: 12px;
  }
}

.timeline-wrapper {
  position: relative;
}
.timeline-wrapper .flex {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.timeline-wrapper .flex > * {
  padding: 0 50px;
}
.timeline-list {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.1em;
}
.timeline-list .item {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  align-items: flex-start;
}
.timeline-list .item .time {
  position: relative;
  color: #754C24;
  -webkit-flex: 0 0 65px;
  flex: 0 0 65px;
  max-width: 65px;
  padding-right: 20px;
  text-align: right;
}
.timeline-list .item .time:after {
  content: "";
  position: absolute;
  top: 50%;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 0;
  width: 8px;
  height: 3px;
  background-color: #754C24;
}
.timeline-list .item .text {
  -webkit-flex-grow: 1;
  flex-grow: 1;
  padding: 0 0 25px 15px;
  color: #333;
  border-left: 1px solid #754C24;
}
.timeline-list .item:last-child .text {
  padding-bottom: 0;
}
.timeline-list p {
  margin: 1em 0;
}
@media (min-width: 1100.1px) {
  .timeline-wrapper .flex > * {
    -webkit-flex: 1 0 auto;
    flex: 1 0 auto;
    max-width: 100%;
  }
}
@media (max-width: 767px) {
  .timeline-wrapper .flex > * {
    padding: 0 30px;
  }
}
@media (max-width: 576px) {
  .timeline-wrapper .flex {
    display: block;
  }
  .timeline-wrapper .flex > * {
    padding: 0 20px;
    margin-bottom: 20px;
  }
  .timeline-list .item .text {
    word-break: initial;
  }
}

.heading-timeline {
  font-size: 32px;
  font-style: italic;
  font-weight: 500;
  font-family: "Barlow Condensed", sans-serif;
  line-height: 1;
}
.heading-timeline .big {
  font-size: 52px;
}
.heading-timeline .ico {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  text-align: center;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background-color: #fc0d1b;
  color: #fff;
  line-height: 0.9;
  margin: 0 auto;
}

.section-work-person {
  overflow: hidden;
  padding-top: 0;
  padding-bottom: 90px;
}
.section-work-person .section-content {
  margin-top: -105px;
}

.section-work-person-timeline {
  position: relative;
  padding: 120px 0 140px;
  background-color: #E2ECED;
}
.section-work-person-timeline .section-header {
  position: absolute;
  z-index: 10;
  width: 100%;
  top: -70px;
  left: 0;
}

.section-work-person-paper {
  padding-top: 85px;
  padding-bottom: 90px;
}

@media (min-width: 1100.1px) {
  .section-work-top {
    padding-bottom: 90px;
  }
  .section-work-top .section-header {
    margin-bottom: 25px;
  }
  .section-work-top .desc {
    font-size: 16px;
    letter-spacing: 0.05em;
  }

  .section-work-person.person02 .person-info .name .eng {
    letter-spacing: -0.04em;
  }
  .section-work-person.person13 .person-info .name .eng {
    letter-spacing: -0.06em;
  }
}
@media (max-width: 576px) {
  .section-work-person {
    padding-top: 80px;
  }
  .section-work-person .section-content {
    margin-top: 10px;
  }

  .section-work-person-timeline {
    padding-top: 100px;
    padding-bottom: 80px;
  }

  .section-work-person-paper {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}

/*# sourceMappingURL=style.css.map */

.btn-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 15px 0;
  margin-block: 0 100px;
}

.btn-red {
  font-size: 22px;
  padding: 30px 35px;
  width: 100%;
  max-width: 400px;
}

@media (max-width: 576px) {
  .btn-red {
    font-size: 18px;
    padding: 20px;
  }
}