@charset "UTF-8";
html {
  font-size: 62.5%;
}

* {
  line-height: 1em;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body, h1, h2, h3, h4, h5, h6, p, div, dl, dt, dd, ul, ol, li, blockquote, th, td, pre, form, fieldset, input, textarea {
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

fieldset, img {
  border: 0;
}

address, caption, cite, code, dfn, em, th, var {
  font-style: normal;
  font-weight: normal;
}

ol, ul {
  list-style: none;
}

caption, th {
  text-align: left;
}

q:before, q:after {
  content: "";
}

abbr, acronym {
  border: 0;
}

body {
  text-align: justify;
  text-justify: inter-ideograph;
  height: 100.5%;
  word-wrap: break-word;
}

p, dd, li {
  word-break: normal;
}

.left {
  text-align: left !important;
}

.center {
  text-align: center !important;
}

.right {
  text-align: right !important;
}

.none {
  display: none !important;
}

.fleft {
  float: left;
}

.fright {
  float: right;
}

img {
  font-size: 0;
  line-height: 0;
}

.accessibility {
  display: none;
}

.cf:before,
.cf:after {
  content: " ";
  display: table;
}

.cf:after {
  clear: both;
}

.cf {
  *zoom: 1;
}

.m0 {
  margin: 0 !important;
}

.mr0 {
  margin-right: 0 !important;
}

.mr10 {
  margin-right: 10px !important;
}

.ml0 {
  margin-left: 0 !important;
}

.ml5 {
  margin-left: 5px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.ml15 {
  margin-left: 15px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.ml25 {
  margin-left: 25px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.ml35 {
  margin-left: 35px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mb55 {
  margin-bottom: 55px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mt0 {
  margin-top: 0 !important;
}

.pb0 {
  padding-bottom: 0 !important;
}

.pb5 {
  padding-bottom: 5px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.pb35 {
  padding-bottom: 35px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.p0 {
  padding: 0 !important;
}

.w50 {
  width: 50px;
}

.font_l {
  font-size: 1.2em;
}

.font_s {
  font-size: 0.8em;
}

#index-entry-end {
  padding: 75px 0 0;
}

#page-recruit {
  background: #000;
  color: #fff;
  font-size: 16px;
  font-size: 1.6rem;
}
#page-recruit .wrap-site {
  width: 1200px;
  margin: 0 auto;
}
#page-recruit .inner-section {
  padding: 100px 0;
}
#page-recruit p, #page-recruit dd {
  line-height: 1.8;
}
#page-recruit .ttl-section {
  color: #d60b17;
  font-weight: bold;
  font-size: 32px;
  font-size: 3.2rem;
}
#page-recruit .ttl-section span {
  transform: rotate(-90deg);
  display: inline-block;
  font-weight: normal;
  font-size: 60px;
  font-size: 6rem;
  color: #5e646a;
  padding: 0 25px 0 0;
}
#page-recruit .bg-light {
  color: #363d44;
  background: #ecefea;
}
#page-recruit .bg-lighter {
  color: #363d44;
  background: #fff;
}
#page-recruit .row {
  margin: 0;
}
#page-recruit .col-xs-6 {
  padding: 0;
}
#page-recruit .col-xs-6 img {
  width: 100%;
}
#page-recruit #header {
  padding: 200px 0 0;
  height: 1000px;
}
#page-recruit #header #ttl-page {
  text-align: center;
  position: relative;
  margin: 0 0 50px;
}
#page-recruit #header #ttl-page .logo {
  position: absolute;
  left: 50%;
  bottom: -15px;
  margin-left: -60px;
}
#page-recruit #header #catch-page strong,
#page-recruit #header #catch-page span {
  display: block;
  text-align: center;
}
#page-recruit #header #catch-page strong {
  font-size: 100px;
  font-size: 10rem;
  margin: 0 0 25px;
}
#page-recruit #header #catch-page strong#end-msg {
  font-size: 50px;
  font-size: 5rem;
  line-height: 1.2;
}
#page-recruit #header #catch-page span {
  font-size: 32px;
  font-size: 3.2rem;
  font-weight: bold;
  margin: 0 0 20px;
}
#page-recruit #container-entry {
  padding: 0 0 150px;
  max-width: 1100px;
  width: 100%;
  margin: 50px auto 0;
  display: flex;
  justify-content: space-between;
}
#page-recruit #container-entry .btn {
  text-align: center;
  width: 45%;
}
#page-recruit #container-entry .btn a {
  display: block;
  padding: 20px 0;
  color: #fff;
  background: #d60b17;
  font-weight: bold;
  font-size: 24px;
  font-size: 2.4rem;
  text-decoration: none;
  width: 100%;
}
#page-recruit #container-entry .btn p {
  font-size: 18px;
  font-size: 1.8rem;
  margin-top: 20px;
  text-align: left;
  font-weight: bold;
}
#page-recruit #container-entry .btn-gray {
  text-align: center;
  width: 45%;
}
#page-recruit #container-entry .btn-gray span {
  display: block;
  padding: 20px 0;
  color: #8A929A;
  background: #5E646A;
  font-weight: bold;
  font-size: 24px;
  font-size: 2.4rem;
  text-decoration: none;
  width: 100%;
}
#page-recruit #container-entry .btn-gray p {
  font-size: 18px;
  font-size: 1.8rem;
  margin-top: 20px;
  text-align: left;
  font-weight: bold;
}
#page-recruit main {
  background: rgba(0, 0, 0, 0.3);
}
#page-recruit .main-visual__movie {
  position: absolute;
  left: 0;
  z-index: -90;
  width: 100%;
  overflow: hidden;
}
#page-recruit .main-visual__movie video {
  height: 100vh;
}
#page-recruit .video-layer {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  display: block;
  content: " ";
  opacity: 0.25;
  z-index: -90;
  background: url(../images/pages/recruit/bg_header_1709.jpg) center 0 no-repeat;
  background-size: 100% auto;
}
#page-recruit #copyright {
  text-align: center;
  padding: 30px 0;
}

#page-recruit-form {
  font-size: 16px;
  font-size: 1.6rem;
}
#page-recruit-form .wrap-site {
  width: 960px;
  margin: 0 auto;
}
#page-recruit-form header {
  background: url(../images/pages/recruit/bg_header.jpg) center 0 no-repeat;
  background-size: 100% auto;
  padding: 50px 0;
  margin: 0 0 25px;
}
#page-recruit-form #logo-site {
  color: #fff;
  font-size: 30px;
  font-size: 3rem;
  font-weight: bold;
}
#page-recruit-form .page-ttl {
  color: #d60b17;
  font-weight: bold;
  margin: 0 0 50px;
}
#page-recruit-form #breadcrumbs {
  margin: 0 0 75px;
}
#page-recruit-form #breadcrumbs li {
  display: inline;
}
#page-recruit-form #breadcrumbs li span {
  padding: 0 5px;
}
#page-recruit-form #form-step {
  margin: 0 0 50px;
}
#page-recruit-form #form-step ol {
  text-align: center;
}
#page-recruit-form #form-step li {
  float: left;
  color: #666;
  width: 33.3333%;
  color: #aaa;
  padding: 10px 0;
  border-top: 1px solid #d7d8d8;
  border-bottom: 1px solid #d7d8d8;
  font-weight: bold;
  font-size: 16px;
  font-size: 1.6rem;
  position: relative;
  text-align: center;
}
#page-recruit-form #form-step li span {
  display: inline-block;
  font-size: 18px;
  font-size: 1.8rem;
  border: 2px solid #aaa;
  padding: 4px 8px;
  margin: 0 10px 0 0;
  border-radius: 15px;
}
#page-recruit-form #form-step li em {
  font-weight: bold;
}
#page-recruit-form #form-step li.current {
  color: #000;
}
#page-recruit-form #form-step li.current span {
  color: #d60b17;
  border-color: #d60b17;
}
#page-recruit-form #form-step li::before {
  position: absolute;
  display: block;
  content: " ";
  width: 0;
  height: 0;
  border: 26px solid transparent;
  border-left: 26px solid #d7d8d8;
  top: -1px;
  right: -38px;
}
#page-recruit-form #form-step li::after {
  position: absolute;
  display: block;
  content: " ";
  width: 0;
  height: 0;
  border: 24px solid transparent;
  border-left: 24px solid #fff;
  top: 1px;
  right: -34px;
}
#page-recruit-form #form-step li:first-child {
  border-left: 1px solid #d7d8d8;
}
#page-recruit-form #form-step li:last-child {
  border-right: 1px solid #d7d8d8;
}
#page-recruit-form #form-step li:last-child::before, #page-recruit-form #form-step li:last-child::after {
  display: none;
}
#page-recruit-form .validation-errors .error {
  color: #bc313e;
  background: #fadce3;
  padding: 0 15px 5px;
}
#page-recruit-form .validation-errors .error:first-child {
  padding-top: 15px;
}
#page-recruit-form .validation-errors .error:last-child {
  padding-bottom: 15px;
  margin: 0 0 25px;
}
#page-recruit-form .validation-errors .error span {
  font-weight: bold;
}
#page-recruit-form .form-group-container {
  margin: 0 0 25px;
  padding: 0 0 25px;
  border-bottom: 1px solid #ecefea;
}
#page-recruit-form .form-group-container dt {
  font-weight: bold;
  font-size: 18px;
  font-size: 1.8rem;
  margin: 0 0 15px;
}
#page-recruit-form .form-group-container dt span {
  display: inline-block;
  color: #fff;
  background: #d60b17;
  padding: 2px 4px;
  font-size: 14px;
  font-size: 1.4rem;
}
#page-recruit-form .form-group-container dd {
  font-size: 22px;
  font-size: 2.2rem;
}
#page-recruit-form .form-group-container dd input[type=text] {
  font-size: 20px;
  font-size: 2rem;
  line-height: 20px;
  width: 100%;
  padding: 5px 0;
  text-indent: 5px;
}
#page-recruit-form .form-group-container dd label {
  display: inline-block;
  margin: 0 25px 0 0;
}
#page-recruit-form #mgs-status {
  margin: 0 0 50px;
}
#page-recruit-form .form-actions {
  padding: 75px 0 0;
  margin: 0 0 50px;
  text-align: center;
}
#page-recruit-form .form-actions .btn {
  display: inline-block;
  padding: 20px 150px;
  color: #fff;
  background: #d60b17;
  font-weight: bold;
  font-size: 24px;
  font-size: 2.4rem;
  text-decoration: none;
  border: none;
  cursor: pointer;
}
#page-recruit-form #thx-msg {
  text-align: center;
  padding: 50px 0 0;
  margin: 0 0 100px;
}
#page-recruit-form #thx-msg p {
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 2;
}
#page-recruit-form #thx-notice {
  background: #ecefea;
  padding: 25px;
  margin: 0 0 100px;
}
#page-recruit-form #thx-notice p {
  line-height: 2;
}
#page-recruit-form footer {
  text-align: center;
  padding: 30px 0;
  background: #000;
  color: #ddd;
}

#nav-trigger {
  position: fixed;
  z-index: 9999;
  color: #fff;
  padding: 20px 15px;
  top: 50px;
  left: 50px;
}

#btn-trigger {
  display: inline-block;
  position: relative;
  background: rgba(231, 20, 25, 0.9);
  width: 70px;
  height: 70px;
}

#btn-trigger-icon {
  display: block;
  position: absolute;
  top: 50%;
  left: 20px;
  width: 45px;
  height: 3px;
  margin: -1px 0 0 -7px;
  background: #fff;
  transition: 0.2s;
}

#btn-trigger-icon:before, #btn-trigger-icon:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 45px;
  height: 3px;
  background: #fff;
  transition: 0.3s;
}

#btn-trigger-icon:before {
  margin-top: -15px;
}

#btn-trigger-icon:after {
  margin-top: 11px;
}

#btn-trigger .close {
  background: transparent;
}

#btn-trigger .close:before, #btn-trigger .close:after {
  margin-top: 0;
}

#btn-trigger .close:before {
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
}

#btn-trigger .close:after {
  transform: rotate(-135deg);
  -webkit-transform: rotate(-135deg);
}

#nav-global {
  display: none;
  position: fixed;
  z-index: 9999;
  color: #fff;
  top: 140px;
  left: 65px;
  overflow: hidden;
}
#nav-global ul {
  padding: 45px 45px 45px 30px;
  background: rgba(231, 20, 25, 0.9);
}
#nav-global li {
  margin: 0 0 45px;
}
#nav-global li:last-child {
  margin: 0;
}
#nav-global a {
  display: block;
  color: #fff;
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: bold;
  padding: 5px;
}

.close #nav-global {
  display: block;
}

/*---ページ先頭アンカー
--------------------------------------------------------------------------*/
#to-pagetop {
  display: table;
  width: 50px;
  position: fixed;
  right: 50px;
  bottom: 50px;
  z-index: 999;
  filter: alpha(opacity=0);
  -ms-filter: "alpha( Opacity=0 )";
  -moz-opacity: 0;
  opacity: 0;
}
#to-pagetop a {
  display: table-cell;
  color: #fff;
  background: rgba(231, 20, 25, 0.9);
  height: 50px;
  vertical-align: middle;
  text-align: center;
}

.estimate-section {
  display: none;
}

#page-career {
  background: #000;
  color: #fff;
  font-size: 16px;
  font-size: 1.6rem;
}
#page-career .wrap-site {
  width: 1200px;
  margin: 0 auto;
}
#page-career .inner-section {
  padding: 100px 0;
}
#page-career p,
#page-career dd {
  line-height: 1.8;
}
#page-career .ttl-section {
  color: #d60b17;
  font-weight: bold;
  font-size: 32px;
  font-size: 3.2rem;
}
#page-career .ttl-section span {
  transform: rotate(-90deg);
  display: inline-block;
  font-weight: normal;
  font-size: 60px;
  font-size: 6rem;
  color: #5e646a;
  padding: 0 25px 0 0;
}
#page-career .bg-light {
  color: #363d44;
  background: #ecefea;
}
#page-career .bg-lighter {
  color: #363d44;
  background: #fff;
}
#page-career .row {
  margin: 0;
}
#page-career .col-xs-6 {
  padding: 0;
}
#page-career .col-xs-6 img {
  width: 100%;
}
#page-career #header {
  background: url(../images/pages/recruit/bg_header.jpg) center 0 no-repeat;
  background-size: 100% auto;
  background-size: cover;
  padding: 200px 0 0;
  height: 1000px;
}
#page-career #header #ttl-page {
  text-align: center;
  position: relative;
  margin: 0 0 50px;
}
#page-career #header #ttl-page .logo {
  position: absolute;
  left: 50%;
  bottom: -15px;
  margin-left: -60px;
}
#page-career #header #catch-page strong,
#page-career #header #catch-page span {
  display: block;
  text-align: center;
}
#page-career #header #catch-page strong {
  font-size: 100px;
  font-size: 10rem;
  margin: 0 0 25px;
}
#page-career #header #catch-page strong#end-msg {
  font-size: 50px;
  font-size: 5rem;
  line-height: 1.2;
}
#page-career #header #catch-page span {
  font-size: 32px;
  font-size: 3.2rem;
  font-weight: bold;
  margin: 0 0 20px;
}
#page-career #container-outline .catch-section {
  font-size: 32px;
  font-size: 3.2rem;
  font-weight: bold;
}
#page-career #container-outline .catch-section span {
  display: block;
  margin: 0 0 25px;
}
#page-career #container-about .catch-section {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 0 0 25px;
}
#page-career #container-about p {
  margin: 0 0 25px;
}
#page-career #container-about .right {
  padding: 25px 0 0;
}
#page-career #container-about #products-detail {
  padding: 15px 0 50px;
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
}
#page-career #container-company .photo {
  margin: 0 0 30px;
  display: flex;
  justify-content: space-between;
}
#page-career #container-company .photo div {
  width: 48%;
}
#page-career #container-company .photo img {
  width: 100%;
}
#page-career #container-company .ttl-box {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 30px 0;
  line-height: 1.5;
}
#page-career #container-company #box-company-outline p {
  margin: 10px 0 30px;
}
#page-career #container-work .photo {
  margin: 50px 0;
}
#page-career #container-work .photo img {
  width: 100%;
}
#page-career #container-work .ttl-box {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 0 0 30px;
}
#page-career #container-work #box-work-outline p {
  margin: 0 0 30px;
}
#page-career #container-work .box-staff dl {
  margin: 0 0 30px;
}
#page-career #container-work .box-staff dt {
  font-weight: bold;
  margin: 0 0 5px;
}
#page-career #container-workflow .photo {
  margin: 0 0 60px;
  display: flex;
  justify-content: space-between;
}
#page-career #container-workflow .photo div {
  width: 48%;
}
#page-career #container-workflow .photo img {
  width: 100%;
}
#page-career #container-workflow .ttl-box {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 30px 0 15px;
  line-height: 1.5;
}
#page-career #container-workflow #box-workflow-outline p {
  line-height: 1.5;
  margin-bottom: 10px;
}
#page-career #container-application .ttl-body {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 0 0 25px;
}
#page-career #container-application .ttl-box {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 0 0 15px;
}
#page-career #container-application .box-application {
  margin: 0 0 50px;
}
#page-career #container-application dl {
  overflow: hidden;
  margin: 0 0 5px;
}
#page-career #container-application dt,
#page-career #container-application dd {
  line-height: 1.8;
}
#page-career #container-application dt {
  float: left;
  width: 7em;
}
#page-career #container-application dd {
  margin-left: 8em;
  margin-bottom: 20px;
}
#page-career #container-application dd span {
  display: inline-block;
  line-height: 2;
}
#page-career #container-application dd p {
  line-height: 1.6;
  margin: 0 0 20px 12px;
}
#page-career #container-application dd p:last-child {
  margin: 0 0 35px 12px;
}
#page-career #container-application .box-adjustment-lines {
  margin-top: 10px;
}
#page-career .ttl-type {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  color: #d60b17;
  margin: 0 0 10px;
  line-height: 1.4;
  padding: 15px 0 0;
}
#page-career .ttl-type:first-child {
  padding: 0;
}
#page-career .ttl-job {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.4;
  position: relative;
  padding: 0 0 0 12px;
  margin: 0 0 5px;
}
#page-career .ttl-job::before {
  content: " ";
  position: absolute;
  width: 5px;
  height: 5px;
  background: #d60b17;
  border-radius: 5px;
  top: 8px;
  left: 0;
}
#page-career #container-flow .ttl-box {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 0 0 15px;
}
#page-career #container-flow .box-flow {
  margin: 0 0 50px;
}
#page-career #container-flow dl {
  overflow: hidden;
  margin: 0 0 5px;
}
#page-career #container-flow dt,
#page-career #container-flow dd {
  line-height: 2;
}
#page-career #container-flow dt {
  float: left;
  width: 5em;
}
#page-career #container-flow dd {
  margin-left: 6em;
}
#page-career #container-flow #how-entry {
  padding: 15px 0 0;
  margin: 0 0 25px;
}
#page-career #container-flow #how-entry h4 {
  font-weight: bold;
  margin: 0 0 15px 18px;
  position: relative;
}
#page-career #container-flow #how-entry h4::before {
  position: absolute;
  content: " ";
  display: block;
  width: 12px;
  height: 12px;
  background: #000;
  top: 2px;
  left: -18px;
}
#page-career #container-flow #how-entry p {
  padding: 0 0 15px 18px;
}
#page-career #container-flow #info-contact {
  background: #ecefea;
  font-weight: bold;
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 2;
  padding: 15px 25px;
}
#page-career #entry-test-info {
  background: #ecefea;
  padding: 15px;
  margin: 5px 0 0;
  line-height: 1.2;
}
#page-career #container-entry {
  padding: 0 0 150px;
}
#page-career #container-entry .btn {
  text-align: center;
}
#page-career #container-entry .btn a {
  display: inline-block;
  padding: 20px 150px;
  color: #fff;
  background: #d60b17;
  font-weight: bold;
  font-size: 24px;
  font-size: 2.4rem;
  text-decoration: none;
}
#page-career #end-entry-msg {
  display: inline-block;
  background: #f78da9;
  color: #fff;
  font-weight: bold;
  padding: 8px 12px;
  margin: 0 0 15px;
}
#page-career #copyright {
  text-align: center;
  padding: 30px 0;
}

#page-career-form {
  font-size: 16px;
  font-size: 1.6rem;
}
#page-career-form .wrap-site {
  width: 960px;
  margin: 0 auto;
}
#page-career-form header {
  background: url(../images/pages/recruit/bg_header.jpg) center 0 no-repeat;
  background-size: 100% auto;
  padding: 50px 0;
  margin: 0 0 25px;
}
#page-career-form #logo-site {
  color: #fff;
  font-size: 30px;
  font-size: 3rem;
  font-weight: bold;
}
#page-career-form .page-ttl {
  color: #d60b17;
  font-weight: bold;
  margin: 0 0 50px;
}
#page-career-form #breadcrumbs {
  margin: 0 0 75px;
}
#page-career-form #breadcrumbs li {
  display: inline;
}
#page-career-form #breadcrumbs li span {
  padding: 0 5px;
}
#page-career-form #form-step {
  margin: 0 0 50px;
}
#page-career-form #form-step ol {
  text-align: center;
}
#page-career-form #form-step li {
  float: left;
  color: #666;
  width: 33.3333%;
  color: #aaa;
  padding: 10px 0;
  border-top: 1px solid #d7d8d8;
  border-bottom: 1px solid #d7d8d8;
  font-weight: bold;
  font-size: 16px;
  font-size: 1.6rem;
  position: relative;
  text-align: center;
}
#page-career-form #form-step li span {
  display: inline-block;
  font-size: 18px;
  font-size: 1.8rem;
  border: 2px solid #aaa;
  padding: 4px 8px;
  margin: 0 10px 0 0;
  border-radius: 15px;
}
#page-career-form #form-step li em {
  font-weight: bold;
}
#page-career-form #form-step li.current {
  color: #000;
}
#page-career-form #form-step li.current span {
  color: #d60b17;
  border-color: #d60b17;
}
#page-career-form #form-step li::before {
  position: absolute;
  display: block;
  content: " ";
  width: 0;
  height: 0;
  border: 26px solid transparent;
  border-left: 26px solid #d7d8d8;
  top: -1px;
  right: -38px;
}
#page-career-form #form-step li::after {
  position: absolute;
  display: block;
  content: " ";
  width: 0;
  height: 0;
  border: 24px solid transparent;
  border-left: 24px solid #fff;
  top: 1px;
  right: -34px;
}
#page-career-form #form-step li:first-child {
  border-left: 1px solid #d7d8d8;
}
#page-career-form #form-step li:last-child {
  border-right: 1px solid #d7d8d8;
}
#page-career-form #form-step li:last-child::before, #page-career-form #form-step li:last-child::after {
  display: none;
}
#page-career-form .validation-errors .error {
  color: #bc313e;
  background: #fadce3;
  padding: 0 15px 5px;
}
#page-career-form .validation-errors .error:first-child {
  padding-top: 15px;
}
#page-career-form .validation-errors .error:last-child {
  padding-bottom: 15px;
  margin: 0 0 25px;
}
#page-career-form .validation-errors .error span {
  font-weight: bold;
}
#page-career-form .form-group-container {
  margin: 0 0 25px;
  padding: 0 0 25px;
  border-bottom: 1px solid #ecefea;
}
#page-career-form .form-group-container dt {
  font-weight: bold;
  font-size: 18px;
  font-size: 1.8rem;
  margin: 0 0 15px;
}
#page-career-form .form-group-container dt span {
  display: inline-block;
  color: #fff;
  background: #d60b17;
  padding: 2px 4px;
  font-size: 14px;
  font-size: 1.4rem;
}
#page-career-form .form-group-container dd {
  font-size: 22px;
  font-size: 2.2rem;
}
#page-career-form .form-group-container dd input[type=text] {
  font-size: 20px;
  font-size: 2rem;
  line-height: 20px;
  width: 100%;
  padding: 5px 0;
  text-indent: 5px;
}
#page-career-form .form-group-container dd label {
  display: inline-block;
  margin: 0 25px 0 0;
}
#page-career-form #mgs-status {
  margin: 0 0 50px;
}
#page-career-form .form-actions {
  padding: 75px 0 0;
  margin: 0 0 50px;
  text-align: center;
}
#page-career-form .form-actions .btn {
  display: inline-block;
  padding: 20px 150px;
  color: #fff;
  background: #d60b17;
  font-weight: bold;
  font-size: 24px;
  font-size: 2.4rem;
  text-decoration: none;
  border: none;
  cursor: pointer;
}
#page-career-form #thx-msg {
  text-align: center;
  padding: 50px 0 0;
  margin: 0 0 100px;
}
#page-career-form #thx-msg p {
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 2;
}
#page-career-form #thx-notice {
  background: #ecefea;
  padding: 25px;
  margin: 0 0 100px;
}
#page-career-form #thx-notice p {
  line-height: 2;
}
#page-career-form footer {
  text-align: center;
  padding: 30px 0;
  background: #000;
  color: #ddd;
}

#nav-trigger {
  position: fixed;
  z-index: 9999;
  color: #fff;
  padding: 20px 15px;
  top: 50px;
  left: 50px;
}

#btn-trigger {
  display: inline-block;
  position: relative;
  background: rgba(231, 20, 25, 0.9);
  width: 70px;
  height: 70px;
}

#btn-trigger-icon {
  display: block;
  position: absolute;
  top: 50%;
  left: 20px;
  width: 45px;
  height: 3px;
  margin: -1px 0 0 -7px;
  background: #fff;
  transition: 0.2s;
}

#btn-trigger-icon:before,
#btn-trigger-icon:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 45px;
  height: 3px;
  background: #fff;
  transition: 0.3s;
}

#btn-trigger-icon:before {
  margin-top: -15px;
}

#btn-trigger-icon:after {
  margin-top: 11px;
}

#btn-trigger .close {
  background: transparent;
}

#btn-trigger .close:before,
#btn-trigger .close:after {
  margin-top: 0;
}

#btn-trigger .close:before {
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
}

#btn-trigger .close:after {
  transform: rotate(-135deg);
  -webkit-transform: rotate(-135deg);
}

#nav-global {
  display: none;
  position: fixed;
  z-index: 9999;
  color: #fff;
  top: 140px;
  left: 65px;
  overflow: hidden;
}
#nav-global ul {
  padding: 45px 45px 45px 30px;
  background: rgba(231, 20, 25, 0.9);
}
#nav-global li {
  margin: 0 0 45px;
}
#nav-global li:last-child {
  margin: 0;
}
#nav-global a {
  display: block;
  color: #fff;
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: bold;
  padding: 5px;
}

.close #nav-global {
  display: block;
}

/*---ページ先頭アンカー
--------------------------------------------------------------------------*/
#to-pagetop {
  display: table;
  width: 50px;
  position: fixed;
  right: 50px;
  bottom: 50px;
  z-index: 999;
  filter: alpha(opacity=0);
  -ms-filter: "alpha( Opacity=0 )";
  -moz-opacity: 0;
  opacity: 0;
}
#to-pagetop a {
  display: table-cell;
  color: #fff;
  background: rgba(231, 20, 25, 0.9);
  height: 50px;
  vertical-align: middle;
  text-align: center;
}

.estimate-section {
  display: none;
}

#page-graduates {
  background: #07335D;
  color: #fff;
  font-size: 16px;
  font-size: 1.6rem;
}
#page-graduates .wrap-site {
  width: 1200px;
  margin: 0 auto;
}
#page-graduates .inner-section {
  padding: 100px 0;
}
#page-graduates p, #page-graduates dd {
  line-height: 1.8;
}
#page-graduates .ttl-section {
  color: #d60b17;
  font-weight: bold;
  font-size: 32px;
  font-size: 3.2rem;
}
#page-graduates .ttl-section span {
  transform: rotate(-90deg);
  display: inline-block;
  font-weight: normal;
  font-size: 60px;
  font-size: 6rem;
  color: #5e646a;
  padding: 0 25px 0 0;
}
#page-graduates .bg-light {
  color: #363d44;
  background: #ecefea;
}
#page-graduates .bg-lighter {
  color: #363d44;
  background: #fff;
}
#page-graduates .row {
  margin: 0;
}
#page-graduates .col-xs-6 {
  padding: 0;
}
#page-graduates .col-xs-6 img {
  width: 100%;
}
#page-graduates #header {
  background: url(../images/pages/graduates/bg_header.jpg) center 0 no-repeat;
  background-size: 100% auto;
  padding: 100px 0 0;
  height: 1000px;
}
#page-graduates #header .header__headtxt {
  font-size: 32px;
  font-size: 3.2rem;
  font-weight: bold;
  margin: 0 0 20px;
  text-align: center;
}
#page-graduates #header #ttl-page {
  text-align: center;
  position: relative;
  margin: 0 0 50px;
}
#page-graduates #header #ttl-page .logo {
  position: absolute;
  left: 50%;
  bottom: -15px;
  margin-left: -60px;
}
#page-graduates #header #catch-page p,
#page-graduates #header #catch-page span {
  display: block;
  text-align: center;
}
#page-graduates #header #catch-page p {
  font-size: 100px;
  font-size: 10rem;
  margin: 0 0 45px;
}
#page-graduates #header #catch-page p#end-msg {
  font-size: 75px;
  font-size: 7.5rem;
  line-height: 1.3;
  font-weight: lighter;
}
#page-graduates #header #catch-page span {
  font-size: 32px;
  font-size: 3.2rem;
  font-weight: bold;
  margin: 0 0 20px;
  line-height: 1.7;
  letter-spacing: 1px;
}
#page-graduates #container-outline .catch-section {
  font-size: 32px;
  font-size: 3.2rem;
  font-weight: bold;
}
#page-graduates #container-outline .catch-section span {
  display: block;
  margin: 0 0 50px;
  line-height: 1.7;
  letter-spacing: 1px;
}
#page-graduates #container-outline .catch-section__space {
  padding: 50px;
}
#page-graduates #container-about .catch-section {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 0 0 25px;
}
#page-graduates #container-about p {
  margin: 0 0 25px;
}
#page-graduates #container-about .right {
  padding: 25px 0 0;
}
#page-graduates #container-about #products-detail {
  padding: 15px 0 50px;
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
}
#page-graduates #container-company .photo {
  margin: 0 0 30px;
  display: flex;
  justify-content: space-between;
}
#page-graduates #container-company .photo div {
  width: 48%;
}
#page-graduates #container-company .photo img {
  width: 100%;
}
#page-graduates #container-company .ttl-box {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 30px 0;
  line-height: 1.5;
}
#page-graduates #container-company #box-company-outline p {
  margin: 10px 0 30px;
}
#page-graduates #container-workflow .photo {
  margin: 0 0 60px;
  display: flex;
  justify-content: space-between;
}
#page-graduates #container-workflow .photo div {
  width: 48%;
}
#page-graduates #container-workflow .photo img {
  width: 100%;
}
#page-graduates #container-workflow .ttl-box {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 30px 0 15px;
  line-height: 1.5;
}
#page-graduates #container-workflow #box-workflow-outline p {
  line-height: 1.5;
  margin-bottom: 10px;
}
#page-graduates #container-career .ttl-box {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 30px 0 15px;
  line-height: 1.5;
}
#page-graduates #container-career #box-career-outline p {
  line-height: 1.5;
  margin-bottom: 10px;
  padding-bottom: 20px;
}
#page-graduates #container-work .photo {
  margin: 50px 0;
}
#page-graduates #container-work .photo img {
  width: 100%;
}
#page-graduates #container-work .ttl-box {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 0 0 30px;
}
#page-graduates #container-work #box-work-outline p {
  margin: 0 0 30px;
}
#page-graduates #container-work .box-staff dl {
  margin: 0 0 30px;
}
#page-graduates #container-work .box-staff dt {
  font-weight: bold;
  margin: 0 0 10px;
}
#page-graduates #container-application .ttl-body {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 0 0 25px;
}
#page-graduates #container-application .ttl-box {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 0 0 15px;
}
#page-graduates #container-application .box-application {
  margin: 0 0 50px;
}
#page-graduates #container-application dl {
  overflow: hidden;
  margin: 0 0 5px;
}
#page-graduates #container-application dt, #page-graduates #container-application dd {
  line-height: 1.8;
}
#page-graduates #container-application dt {
  float: left;
  width: 7em;
}
#page-graduates #container-application dd {
  margin-left: 8em;
  margin-bottom: 20px;
}
#page-graduates #container-application dd span {
  display: inline-block;
  text-indent: -1em;
  padding: 0 0 0 1em;
  line-height: 2;
}
#page-graduates #container-application .box-adjustment-lines {
  margin-top: 10px;
}
#page-graduates #container-flow .ttl-box {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  margin: 0 0 15px;
}
#page-graduates #container-flow .ttl-box-min {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
  margin: 30px 0 15px;
}
#page-graduates #container-flow .ttl-box-red {
  color: #D70C18;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
  margin: 30px 0 15px;
}
#page-graduates #container-flow .box-flow {
  margin: 0 0 50px;
}
#page-graduates #container-flow dl {
  overflow: hidden;
  margin: 0 0 5px;
}
#page-graduates #container-flow dt, #page-graduates #container-flow dd {
  line-height: 2;
}
#page-graduates #container-flow dt {
  float: left;
  width: 5em;
}
#page-graduates #container-flow dd {
  margin-left: 6em;
}
#page-graduates #container-flow #how-entry {
  padding: 15px 0 0;
  margin: 0 0 25px;
}
#page-graduates #container-flow #how-entry h4 {
  font-weight: bold;
  margin: 0 0 15px 18px;
  position: relative;
}
#page-graduates #container-flow #how-entry h4::before {
  position: absolute;
  content: " ";
  display: block;
  width: 12px;
  height: 12px;
  background: #000;
  top: 2px;
  left: -18px;
}
#page-graduates #container-flow #how-entry p {
  padding: 0 0 15px 18px;
}
#page-graduates #container-flow #info-contact {
  background: #fff;
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 2;
  padding: 15px 25px;
  margin-top: 90px;
}
#page-graduates #entry-test-info {
  background: #ecefea;
  padding: 15px;
  margin: 5px 0 0;
  line-height: 1.2;
}
#page-graduates #container-entry {
  padding: 0 0 150px;
}
#page-graduates #container-entry .btn {
  text-align: center;
}
#page-graduates #container-entry .btn a {
  display: inline-block;
  padding: 20px 120px;
  color: #fff;
  background: #d60b17;
  font-weight: bold;
  font-size: 22px;
  font-size: 2.2rem;
  text-decoration: none;
}
#page-graduates #end-entry-msg {
  display: inline-block;
  background: #f78da9;
  color: #fff;
  font-weight: bold;
  padding: 8px 12px;
  margin: 0 0 15px;
}
#page-graduates #copyright {
  text-align: center;
  padding: 30px 0;
}

#page-graduates-form {
  font-size: 16px;
  font-size: 1.6rem;
}
#page-graduates-form .wrap-site {
  width: 960px;
  margin: 0 auto;
}
#page-graduates-form header {
  background: url(../images/pages/recruit/bg_header.jpg) center 0 no-repeat;
  background-size: 100% auto;
  padding: 50px 0;
  margin: 0 0 25px;
}
#page-graduates-form #logo-site {
  color: #fff;
  font-size: 30px;
  font-size: 3rem;
  font-weight: bold;
}
#page-graduates-form .page-ttl {
  color: #d60b17;
  font-weight: bold;
  margin: 0 0 50px;
}
#page-graduates-form #breadcrumbs {
  margin: 0 0 75px;
}
#page-graduates-form #breadcrumbs li {
  display: inline;
}
#page-graduates-form #breadcrumbs li span {
  padding: 0 5px;
}
#page-graduates-form #form-step {
  margin: 0 0 50px;
}
#page-graduates-form #form-step ol {
  text-align: center;
}
#page-graduates-form #form-step li {
  float: left;
  color: #666;
  width: 33.3333%;
  color: #aaa;
  padding: 10px 0;
  border-top: 1px solid #d7d8d8;
  border-bottom: 1px solid #d7d8d8;
  font-weight: bold;
  font-size: 16px;
  font-size: 1.6rem;
  position: relative;
  text-align: center;
}
#page-graduates-form #form-step li span {
  display: inline-block;
  font-size: 18px;
  font-size: 1.8rem;
  border: 2px solid #aaa;
  padding: 4px 8px;
  margin: 0 10px 0 0;
  border-radius: 15px;
}
#page-graduates-form #form-step li em {
  font-weight: bold;
}
#page-graduates-form #form-step li.current {
  color: #000;
}
#page-graduates-form #form-step li.current span {
  color: #d60b17;
  border-color: #d60b17;
}
#page-graduates-form #form-step li::before {
  position: absolute;
  display: block;
  content: " ";
  width: 0;
  height: 0;
  border: 26px solid transparent;
  border-left: 26px solid #d7d8d8;
  top: -1px;
  right: -38px;
}
#page-graduates-form #form-step li::after {
  position: absolute;
  display: block;
  content: " ";
  width: 0;
  height: 0;
  border: 24px solid transparent;
  border-left: 24px solid #fff;
  top: 1px;
  right: -34px;
}
#page-graduates-form #form-step li:first-child {
  border-left: 1px solid #d7d8d8;
}
#page-graduates-form #form-step li:last-child {
  border-right: 1px solid #d7d8d8;
}
#page-graduates-form #form-step li:last-child::before, #page-graduates-form #form-step li:last-child::after {
  display: none;
}
#page-graduates-form .validation-errors .error {
  color: #bc313e;
  background: #fadce3;
  padding: 0 15px 5px;
}
#page-graduates-form .validation-errors .error:first-child {
  padding-top: 15px;
}
#page-graduates-form .validation-errors .error:last-child {
  padding-bottom: 15px;
  margin: 0 0 25px;
}
#page-graduates-form .validation-errors .error span {
  font-weight: bold;
}
#page-graduates-form .form-group-container {
  margin: 0 0 25px;
  padding: 0 0 25px;
  border-bottom: 1px solid #ecefea;
}
#page-graduates-form .form-group-container dt {
  font-weight: bold;
  font-size: 18px;
  font-size: 1.8rem;
  margin: 0 0 15px;
}
#page-graduates-form .form-group-container dt span {
  display: inline-block;
  color: #fff;
  background: #d60b17;
  padding: 2px 4px;
  font-size: 14px;
  font-size: 1.4rem;
}
#page-graduates-form .form-group-container dd {
  font-size: 22px;
  font-size: 2.2rem;
}
#page-graduates-form .form-group-container dd input[type=text] {
  font-size: 20px;
  font-size: 2rem;
  line-height: 20px;
  width: 100%;
  padding: 5px 0;
  text-indent: 5px;
}
#page-graduates-form .form-group-container dd label {
  display: inline-block;
  margin: 0 25px 0 0;
}
#page-graduates-form #mgs-status {
  margin: 0 0 50px;
}
#page-graduates-form .form-actions {
  padding: 75px 0 0;
  margin: 0 0 50px;
  text-align: center;
}
#page-graduates-form .form-actions .btn {
  display: inline-block;
  padding: 20px 150px;
  color: #fff;
  background: #d60b17;
  font-weight: bold;
  font-size: 24px;
  font-size: 2.4rem;
  text-decoration: none;
  border: none;
  cursor: pointer;
}
#page-graduates-form #thx-msg {
  text-align: center;
  padding: 50px 0 0;
  margin: 0 0 100px;
}
#page-graduates-form #thx-msg p {
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 2;
}
#page-graduates-form #thx-notice {
  background: #ecefea;
  padding: 25px;
  margin: 0 0 100px;
}
#page-graduates-form #thx-notice p {
  line-height: 2;
}
#page-graduates-form footer {
  text-align: center;
  padding: 30px 0;
  background: #000;
  color: #ddd;
}

#nav-trigger {
  position: fixed;
  z-index: 9999;
  color: #fff;
  padding: 20px 15px;
  top: 50px;
  left: 50px;
}

#btn-trigger {
  display: inline-block;
  position: relative;
  background: rgba(231, 20, 25, 0.9);
  width: 70px;
  height: 70px;
}

#btn-trigger-icon {
  display: block;
  position: absolute;
  top: 50%;
  left: 20px;
  width: 45px;
  height: 3px;
  margin: -1px 0 0 -7px;
  background: #fff;
  transition: 0.2s;
}

#btn-trigger-icon:before, #btn-trigger-icon:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 45px;
  height: 3px;
  background: #fff;
  transition: 0.3s;
}

#btn-trigger-icon:before {
  margin-top: -15px;
}

#btn-trigger-icon:after {
  margin-top: 11px;
}

#btn-trigger .close {
  background: transparent;
}

#btn-trigger .close:before, #btn-trigger .close:after {
  margin-top: 0;
}

#btn-trigger .close:before {
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
}

#btn-trigger .close:after {
  transform: rotate(-135deg);
  -webkit-transform: rotate(-135deg);
}

#nav-global {
  display: none;
  position: fixed;
  z-index: 9999;
  color: #fff;
  top: 140px;
  left: 65px;
  overflow: hidden;
}
#nav-global ul {
  padding: 45px 45px 45px 30px;
  background: rgba(231, 20, 25, 0.9);
}
#nav-global li {
  margin: 0 0 45px;
}
#nav-global li:last-child {
  margin: 0;
}
#nav-global a {
  display: block;
  color: #fff;
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: bold;
  padding: 5px;
}

.close #nav-global {
  display: block;
}

/*---ページ先頭アンカー
--------------------------------------------------------------------------*/
#to-pagetop {
  display: table;
  width: 50px;
  position: fixed;
  right: 50px;
  bottom: 50px;
  z-index: 999;
  filter: alpha(opacity=0);
  -ms-filter: "alpha( Opacity=0 )";
  -moz-opacity: 0;
  opacity: 0;
}
#to-pagetop a {
  display: table-cell;
  color: #fff;
  background: rgba(231, 20, 25, 0.9);
  height: 50px;
  vertical-align: middle;
  text-align: center;
}

.estimate-section {
  display: none;
}

/* =========================================================================
 基本レイアウト
========================================================================= */
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}
@font-face {
  font-family: "Helvetica Neue";
  src: local("Helvetica Neue Regular");
  font-weight: 100;
}
@font-face {
  font-family: "Helvetica Neue";
  src: local("Helvetica Neue Regular");
  font-weight: 200;
}
body {
  font-size: 16px;
  font-size: 1.6rem;
  font-family: "BlinkMacSystemFont", "Roboto", "Helvetica Neue", Arial, "Yu Gothic", YuGothic, Meiryo, "M+ 1p", sans-serif;
  color: #212121;
  background: #fff;
  position: relative;
  /*&.android{
    font-size: 13px !important;
  }*/
}

/* IE10以上 */
@media all and (-ms-high-contrast: none) {
  body {
    font-family: Verdana, Meiryo, sans-serif;
  }
}
p {
  line-height: 1.6;
}

#nojs {
  background: #f3f3f3;
  padding: 5px 0;
}

.font-ex {
  font-family: Arial, sans-serif;
  font-weight: bold;
}

.separator {
  border-bottom: 1px solid #e0e0e0;
}

.br {
  display: block;
  line-height: 1.6;
}

.grid-container {
  width: 1200px;
  margin: 0 auto;
}

.local-content__ttl {
  font-size: 40px;
  font-size: 4rem;
  margin: 0 0 75px;
  font-weight: bold;
}
.local-content__ttl-s {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 0 0 25px;
  font-weight: bold;
}
.local-content__outline {
  margin: 0 0 75px;
}
.local-content__inner {
  margin: 0 0 100px;
}
.local-content__box {
  margin: 0 0 50px;
}
.local-content__head {
  border-bottom: 5px solid #dadada;
  margin: 0 0 50px;
}
.local-content__head .local-content__ttl {
  margin: 0 0 50px;
}
.local-content__head-text {
  font-size: 28px;
  font-size: 2.8rem;
  margin: 0 0 50px;
  font-weight: bold;
  color: #d60b17;
  line-height: 1.4;
}
.local-content__img-separator {
  height: 400px;
}
.local-content__table.stretch th,
.local-content__table.stretch td {
  width: 200px;
  text-align: center;
}
.local-content__table th {
  padding: 12px 10px;
  font-weight: bold;
  border-bottom: 2px solid #dadada;
}
.local-content__table td {
  padding: 12px 10px;
  border-bottom: 2px solid #dadada;
}
.local-content__notice {
  background: #fad2d4;
  color: #2c0205;
  font-weight: bold;
  padding: 10px 15px;
  margin: 0 0 50px;
}
.local-content__row {
  display: flex;
  justify-content: space-between;
}
.local-content__row-box {
  width: 45%;
}
.local-content__dl {
  display: flex;
  border-bottom: 1px solid #dadada;
  padding: 20px 4px;
}
.local-content__dl dt {
  width: 6em;
  line-height: 1.4;
  font-weight: bold;
}
.local-content__dl dd {
  flex: 1;
  line-height: 1.4;
}
.local-content-photo__list {
  display: flex;
  justify-content: space-between;
}
.local-content-photo__list.few:after {
  content: "";
  display: block;
  width: 40%;
}
.local-content-photo__list.col2:after {
  content: "";
  display: block;
  width: 60%;
}
.local-content-photo__item {
  width: 17%;
}
.local-content__btn {
  max-width: 350px;
  margin: 0 auto;
  text-align: center;
}
.local-content__btn a {
  display: block;
  color: #fff;
  background: #d60b17;
  font-weight: bold;
  padding: 15px 0;
  text-decoration: none;
  font-weight: bold;
  border-radius: 6px;
}
.local-content__btn.inversion a {
  background: #212121;
}
.local-content__btn.emphasis {
  max-width: 550px;
}
.local-content__btn.emphasis a {
  font-size: 26px;
  font-size: 2.6rem;
}
.local-content__btn i {
  padding: 0 0 0 10px;
}

/*--- リンク
--------------------------------------------------------------------------*/
a {
  text-decoration: underline;
  color: #d60b17;
}

/*--- イメージ
--------------------------------------------------------------------------*/
a img {
  transition: all 0.25s ease;
}
a:hover img {
  filter: alpha(opacity=80);
  -ms-filter: "alpha( Opacity=80 )";
  -moz-opacity: 0.8;
  opacity: 0.8;
}

/*--- リスト
--------------------------------------------------------------------------*/
.disc-list {
  padding: 8px 0 0;
  margin: 0 0 1em;
}
.disc-list li {
  padding-left: 18px;
  line-height: 1.6;
  position: relative;
  margin: 0 0 5px;
}
.disc-list li::before {
  content: " ";
  background: #43505c;
  width: 10px;
  height: 10px;
  top: 8px;
  left: 2px;
  position: absolute;
  border-radius: 10px;
}

.latin-list {
  margin: 0 0 1em;
}
.latin-list li {
  list-style: lower-latin;
  margin: 0 0 5px 25px;
  line-height: 1.6;
}

/*---ページ先頭アンカー
--------------------------------------------------------------------------*/
#to-pagetop {
  display: table;
  width: 50px;
  position: fixed;
  right: 50px;
  bottom: 50px;
  z-index: 999;
  filter: alpha(opacity=0);
  -ms-filter: "alpha( Opacity=0 )";
  -moz-opacity: 0;
  opacity: 0;
}
#to-pagetop a {
  display: table-cell;
  color: #fff;
  background: rgba(231, 20, 25, 0.9);
  height: 50px;
  vertical-align: middle;
  text-align: center;
}

.common-contact-container {
  background: url(../images/common/bg_estimate.jpg) center center no-repeat;
  background-size: cover;
  padding: 100px 0;
}

.common-contact-content {
  color: #fff;
  text-align: center;
}
.common-contact-content__ttl {
  font-size: 38px;
  font-size: 3.8rem;
  margin: 0 0 25px;
  line-height: 1.2;
  font-weight: bold;
}
.common-contact-content__outline {
  font-size: 18px;
  font-size: 1.8rem;
  text-align: center;
  margin: 0 0 15px;
  line-height: 1.4;
  font-weight: bold;
}
.common-contact-content__notice {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
  margin: 0 0 35px;
}
.common-contact-content__notice p {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: normal;
}
.common-contact-content__tel {
  margin: 0 0 25px;
}
.common-contact-content__tel-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 0 15px;
}
.common-contact-content__tel-label {
  font-weight: bold;
  padding: 0 7px;
}
.common-contact-content__tel-no {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
  padding: 0 7px;
}
.common-contact-content__tel-no a {
  text-decoration: none;
  color: #f2f2f2;
}
.common-contact-content__btn-wrap {
  margin: 0 auto 35px !important;
  justify-content: center;
}
.common-contact-content__btn-wrap a {
  display: block;
}

.estimate-section {
  padding: 150px 0;
  background: url(../images/common/bg_estimate.jpg) center center no-repeat;
  background-size: cover;
}

.footer {
  background: #212121;
  padding: 100px 0 80px;
}

.footer__content {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.footer-logo {
  margin: 0 0 50px;
}
.footer-logo a {
  display: flex;
  align-items: center;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
}
.footer-logo__logo {
  margin: 0 15px 0 0;
}
.footer-logo__name {
  font-size: 20px;
  font-size: 2rem;
}

.nav-out-site__list {
  display: flex;
}
.nav-out-site__item {
  padding: 0 0 0 35px;
}
.nav-out-site__item a img {
  transition: all 0.25s ease;
  height: 32px;
}
.nav-out-site__item a:hover img {
  opacity: 0.7;
}

.nav-footer a {
  color: #fff;
  font-weight: bold;
  text-decoration: none;
}
.nav-footer__list {
  display: flex;
  margin: 0 0 45px;
}
.nav-footer__item {
  padding: 0 20px 0 0;
}
.nav-footer__item a {
  font-size: 12px;
  font-size: 1.2rem;
}
.nav-footer__item a:hover {
  text-decoration: underline;
}

.copyright {
  color: #fff;
  text-align: right;
  font-size: 14px;
  font-size: 1.4rem;
}

body {
  -webkit-text-size-adjust: 100%;
}

img {
  max-width: 100%;
  height: auto;
}

/* for IE */
img {
  -ms-interpolation-mode: bicubic;
}

/* for IE8 */
img {
  width: auto;
}

/*
* html body img{
  width: 100%;
}*/
.catch-line-height {
  line-height: 1.6;
}

@media only screen and (max-width: 991px) {
  #catch-page {
    text-align: center;
  }
  #index-entry-end {
    padding: 75px 0 0;
  }
  #index-entry-end #catch-page {
    font-size: 20px !important;
  }
  #index-entry-end #end-msg {
    font-size: 28px !important;
    line-height: 1.6;
  }
}
@media only screen and (max-width: 1199px) {
  #page-recruit .wrap-site {
    width: auto;
  }
  #page-recruit .ttl-section {
    font-size: 28px;
    font-size: 2.8rem;
    position: relative;
    top: -30px;
  }
  #page-recruit .ttl-section span {
    padding: 0 30px 0 0;
  }
  #page-recruit #header {
    padding: 80px 0 0;
    height: 740px;
    background-size: auto 100%;
  }
  #page-recruit #container-entry {
    width: 90%;
  }
  #page-recruit #container-outline .catch-section {
    font-size: 24px;
    font-size: 2.4rem;
  }
  #page-recruit #container-outline .catch-section span {
    margin: 0 0 30px;
  }
  #page-recruit #container-outline .catch-section .catch-line-height {
    line-height: 1.6;
  }
  #page-recruit #container-entry .btn a, #page-recruit #container-entry .btn-gray span {
    font-size: 20px;
    font-size: 2rem;
  }
}
@media only screen and (max-width: 991px) {
  #page-recruit p, #page-recruit dd {
    line-height: 2;
  }
  #page-recruit .ttl-section {
    font-size: 40px;
    font-size: 4rem;
    left: -15px;
    margin: 0 0 25px;
  }
  #page-recruit .ttl-section span {
    padding: 0 15px 0 0;
  }
  #page-recruit .body-section {
    padding: 0 25px;
  }
  #page-recruit #header {
    padding: 150px 0 0;
  }
  #page-recruit #header #ttl-page {
    padding: 0 75px;
  }
  #page-recruit #container-outline .catch-section {
    font-size: 30px;
    font-size: 3rem;
  }
  #page-recruit #container-about .catch-section {
    font-size: 26px;
    font-size: 2.6rem;
    line-height: 1.4;
  }
  #page-recruit #products-detail {
    display: none;
  }
  #page-recruit #container-work .ttl-box {
    font-size: 26px;
    font-size: 2.6rem;
  }
  #page-recruit #container-work .box-staff {
    padding: 45px 0 0;
    border-top: 1px solid #444;
  }
  #page-recruit #container-work .box-staff dl {
    margin: 0 0 45px;
  }
  #page-recruit #container-work .box-staff dt {
    font-weight: bold;
    font-size: 20px;
    font-size: 2rem;
    margin: 0 0 15px;
  }
  #page-recruit #container-application .ttl-body {
    font-size: 28px;
    font-size: 2.8rem;
    margin: 0 0 45px;
  }
  #page-recruit #container-application .ttl-box {
    font-size: 24px;
    font-size: 2.4rem;
    margin: 0 0 25px;
  }
  #page-recruit #container-application dl {
    margin: 0 0 15px;
    padding: 0 0 15px;
    border-bottom: 1px solid #ccc;
  }
  #page-recruit #container-application dt {
    font-weight: bold;
  }
  #page-recruit #container-flow .ttl-box {
    font-size: 24px;
    font-size: 2.4rem;
    margin: 0 0 25px;
  }
}
@media only screen and (max-width: 767px) {
  #page-recruit .ttl-section {
    font-size: 30px;
    font-size: 3rem;
    left: 0;
    margin: 0;
  }
  #page-recruit .ttl-section span {
    transform: rotate(0deg);
    font-size: 36px;
    font-size: 3.6rem;
  }
  #page-recruit .inner-section {
    padding: 75px 0;
  }
  #page-recruit .body-section {
    padding: 0 15px;
  }
  #page-recruit #header {
    padding: 75px 0 0;
    height: 800px;
  }
  #page-recruit #header #ttl-page {
    padding: 0 25px;
    margin: 0 0 85px;
  }
  #page-recruit #header #ttl-page .logo {
    bottom: -50px;
  }
  #page-recruit #header #catch-page {
    padding: 0 25px;
  }
  #page-recruit #header #catch-page strong {
    font-size: 60px;
    font-size: 6rem;
    margin: 0 0 25px;
  }
  #page-recruit #header #catch-page span {
    display: inline;
    font-size: 24px;
    font-size: 2.4rem;
    margin: 0 0 20px;
    line-height: 1.8;
  }
  #page-recruit #container-outline .catch-section {
    font-size: 20px;
    font-size: 2rem;
    margin: 0 0 25px;
  }
  #page-recruit #container-outline .catch-section span {
    line-height: 1.6;
    margin: 0;
    display: inline;
  }
  #page-recruit #container-about .catch-section {
    font-size: 22px;
    font-size: 2.2rem;
  }
  #page-recruit #container-work .ttl-box {
    font-size: 20px;
    font-size: 2rem;
    line-height: 1.4;
  }
  #page-recruit #container-work .box-staff dl {
    margin: 0 0 30px;
  }
  #page-recruit #container-work .box-staff dt {
    line-height: 1.4;
  }
  #page-recruit #container-application .ttl-body {
    font-size: 20px;
    font-size: 2rem;
    margin: 0 0 45px;
  }
  #page-recruit #container-application .ttl-box {
    font-size: 18px;
    font-size: 1.8rem;
    margin: 0 0 25px;
  }
  #page-recruit #container-application dt {
    float: none;
    width: auto;
  }
  #page-recruit #container-application dd {
    margin: 0;
  }
  #page-recruit #container-flow .inner-section {
    padding-bottom: 25px;
  }
  #page-recruit #container-flow .ttl-box {
    font-size: 20px;
    font-size: 2rem;
  }
  #page-recruit #container-entry {
    padding: 0 20px 75px;
    margin-top: 30px;
    width: 100%;
    flex-direction: column;
  }
  #page-recruit #container-entry .btn {
    width: 100%;
  }
  #page-recruit #container-entry .btn a {
    display: block;
    padding: 20px 0px;
    font-size: 20px;
    font-size: 2rem;
  }
  #page-recruit #container-entry .btn p {
    margin-top: 10px;
    font-size: 16px;
    font-size: 1.6rem;
  }
  #page-recruit #container-entry .btn-gray {
    width: 100%;
    margin-top: 40px;
  }
  #page-recruit #container-entry .btn-gray p {
    margin-top: 10px;
    font-size: 16px;
    font-size: 1.6rem;
  }
}
@media only screen and (max-width: 480px) {
  #page-recruit .ttl-section {
    font-size: 26px;
    font-size: 2.6rem;
  }
  #page-recruit .ttl-section span {
    font-size: 30px;
    font-size: 3rem;
  }
  #page-recruit p, #page-recruit dd {
    font-size: 14px;
    font-size: 1.4rem;
  }
}

@media only screen and (max-width: 980px) {
  #page-recruit-form .wrap-site {
    width: auto;
    padding: 0 25px;
  }
}
@media only screen and (max-width: 767px) {
  #page-recruit-form .page-ttl {
    font-size: 24px;
    font-size: 2.4rem;
  }
  #page-recruit-form #breadcrumbs {
    display: none;
  }
  #page-recruit-form #form-step {
    border-top: 1px solid #ecefea;
    position: relative;
    margin: 0 25px 30px;
  }
  #page-recruit-form #form-step li {
    position: relative;
    margin-top: -26px;
    text-align: center;
    width: 34%;
    border: none;
  }
  #page-recruit-form #form-step li::before, #page-recruit-form #form-step li::after {
    display: none;
  }
  #page-recruit-form #form-step li:first-child, #page-recruit-form #form-step li:last-child {
    border: none;
    width: 33%;
  }
  #page-recruit-form #form-step li:first-child {
    text-align: left;
  }
  #page-recruit-form #form-step li:last-child {
    text-align: right;
  }
  #page-recruit-form #form-step li span {
    background: #fff;
    margin: 0;
  }
  #page-recruit-form #form-step li em {
    display: none;
  }
  #page-recruit-form .form-actions {
    padding: 50px 0 0;
  }
  #page-recruit-form .form-actions .btn {
    display: block;
    width: 100%;
    padding: 20px 0;
    font-size: 22px;
    font-size: 2.2rem;
    text-align: center;
  }
  #page-recruit-form #confirm-actions {
    overflow: hidden;
  }
  #page-recruit-form #confirm-actions button {
    width: 48%;
    float: left;
  }
  #page-recruit-form #confirm-actions button:last-child {
    float: right;
  }
  #page-recruit-form #thx-notice p {
    line-height: 1.6;
  }
}
@media only screen and (max-width: 480px) {
  #page-recruit-form #logo-site {
    font-size: 28px;
    font-size: 2.8rem;
  }
  #page-recruit-form #logo-site img {
    width: 50px;
  }
  #page-recruit-form #thx-msg {
    padding: 25px 0 0;
    margin: 0 0 50px;
  }
  #page-recruit-form #thx-msg p {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 2;
  }
  #page-recruit-form #thx-notice {
    background: #ecefea;
    padding: 15px;
    margin: 0 0 50px;
  }
  #page-recruit-form #thx-notice p {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.6;
  }
}

@media only screen and (max-width: 991px) {
  #btn-trigger {
    background: rgba(0, 0, 0, 0.6);
  }
  #nav-trigger {
    top: 15px;
    left: 15px;
  }
  #to-pagetop {
    right: 25px;
    bottom: 35px;
  }
  #nav-global {
    top: 105px;
    left: 30px;
  }
}
@media only screen and (max-width: 767px) {
  #nav-trigger {
    top: 10px;
    left: 10px;
    padding: 0;
  }
  #btn-trigger {
    width: 50px;
    height: 50px;
  }
  #btn-trigger-icon {
    width: 25px;
    margin: -1px 0 0 -7px;
  }
  #btn-trigger-icon:before, #btn-trigger-icon:after {
    width: 25px;
    height: 3px;
  }
  #btn-trigger-icon:before {
    margin-top: -10px;
  }
  #btn-trigger-icon:after {
    margin-top: 6px;
  }
  #nav-global {
    top: 60px;
    left: 10px;
  }
  #nav-global ul {
    padding: 25px 45px 25px 30px;
  }
  #nav-global li {
    margin: 0 0 25px;
  }
  #nav-global a {
    font-size: 20px;
    font-size: 2rem;
  }
  #to-pagetop {
    right: 15px;
    bottom: 25px;
  }
}
.catch-line-height {
  line-height: 1.6;
}

@media only screen and (max-width: 1199px) {
  #page-career .wrap-site {
    width: auto;
  }
  #page-career .ttl-section {
    font-size: 28px;
    font-size: 2.8rem;
    position: relative;
    top: -30px;
  }
  #page-career .ttl-section span {
    padding: 0 30px 0 0;
  }
  #page-career #header {
    padding: 80px 0 0;
    height: 740px;
    background-size: auto 100%;
  }
  #page-career #container-outline .catch-section {
    font-size: 24px;
    font-size: 2.4rem;
  }
  #page-career #container-outline .catch-section span {
    margin: 0 0 30px;
  }
  #page-career #container-outline .catch-section .catch-line-height {
    line-height: 1.6;
  }
}
@media only screen and (max-width: 991px) {
  #page-career p, #page-career dd {
    line-height: 2;
  }
  #page-career .ttl-section {
    font-size: 40px;
    font-size: 4rem;
    left: -15px;
    margin: 0 0 25px;
  }
  #page-career .ttl-section span {
    padding: 0 15px 0 0;
  }
  #page-career .body-section {
    padding: 0 25px;
  }
  #page-career #header {
    padding: 150px 0 0;
  }
  #page-career #header #ttl-page {
    padding: 0 75px;
  }
  #page-career #container-outline .catch-section {
    font-size: 30px;
    font-size: 3rem;
  }
  #page-career #container-about .catch-section {
    font-size: 26px;
    font-size: 2.6rem;
    line-height: 1.4;
  }
  #page-career #products-detail {
    display: none;
  }
  #page-career #container-work .ttl-box {
    font-size: 26px;
    font-size: 2.6rem;
  }
  #page-career #container-work .box-staff {
    padding: 45px 0 0;
    border-top: 1px solid #444;
  }
  #page-career #container-work .box-staff dl {
    margin: 0 0 45px;
  }
  #page-career #container-work .box-staff dt {
    font-weight: bold;
    font-size: 20px;
    font-size: 2rem;
    margin: 0 0 15px;
  }
  #page-career #container-application .ttl-body {
    font-size: 28px;
    font-size: 2.8rem;
    margin: 0 0 45px;
  }
  #page-career #container-application .ttl-box {
    font-size: 24px;
    font-size: 2.4rem;
    margin: 0 0 25px;
  }
  #page-career #container-application dl {
    margin: 0 0 15px;
    padding: 0 0 15px;
    border-bottom: 1px solid #ccc;
  }
  #page-career #container-application dt {
    font-weight: bold;
  }
  #page-career #container-flow .ttl-box {
    font-size: 24px;
    font-size: 2.4rem;
    margin: 0 0 25px;
  }
}
@media only screen and (max-width: 767px) {
  #page-career .ttl-section {
    font-size: 30px;
    font-size: 3rem;
    left: 0;
    margin: 0;
  }
  #page-career .ttl-section span {
    transform: rotate(0deg);
    font-size: 36px;
    font-size: 3.6rem;
  }
  #page-career .inner-section {
    padding: 75px 0;
  }
  #page-career .body-section {
    padding: 0 15px;
  }
  #page-career #header {
    padding: 75px 0 0;
    height: 600px;
  }
  #page-career #header #ttl-page {
    padding: 0 25px;
    margin: 0 0 125px;
  }
  #page-career #header #ttl-page .logo {
    bottom: -45px;
  }
  #page-career #header #catch-page {
    padding: 0 25px;
  }
  #page-career #header #catch-page strong {
    font-size: 60px;
    font-size: 6rem;
    margin: 0 0 25px;
  }
  #page-career #header #catch-page span {
    display: inline;
    font-size: 24px;
    font-size: 2.4rem;
    margin: 0 0 20px;
    line-height: 1.8;
  }
  #page-career #container-outline .catch-section {
    font-size: 20px;
    font-size: 2rem;
    margin: 0 0 25px;
  }
  #page-career #container-outline .catch-section span {
    line-height: 1.6;
    margin: 0;
    display: inline;
  }
  #page-career #container-about .catch-section {
    font-size: 22px;
    font-size: 2.2rem;
  }
  #page-career #container-work .ttl-box {
    font-size: 20px;
    font-size: 2rem;
    line-height: 1.4;
  }
  #page-career #container-work .box-staff dl {
    margin: 0 0 30px;
  }
  #page-career #container-work .box-staff dt {
    line-height: 1.4;
  }
  #page-career #container-application .ttl-body {
    font-size: 20px;
    font-size: 2rem;
    margin: 0 0 45px;
  }
  #page-career #container-application .ttl-box {
    font-size: 18px;
    font-size: 1.8rem;
    margin: 0 0 25px;
  }
  #page-career #container-application dt {
    float: none;
    width: auto;
  }
  #page-career #container-application dd {
    margin: 0;
  }
  #page-career #container-flow .inner-section {
    padding-bottom: 25px;
  }
  #page-career #container-flow .ttl-box {
    font-size: 20px;
    font-size: 2rem;
  }
  #page-career #container-entry {
    padding: 0 20px 75px;
  }
  #page-career #container-entry .btn a {
    display: block;
    padding: 20px 0px;
    font-size: 20px;
    font-size: 2rem;
  }
}
@media only screen and (max-width: 480px) {
  #page-career .ttl-section {
    font-size: 26px;
    font-size: 2.6rem;
  }
  #page-career .ttl-section span {
    font-size: 30px;
    font-size: 3rem;
  }
  #page-career p, #page-career dd {
    font-size: 14px;
    font-size: 1.4rem;
  }
}

@media only screen and (max-width: 980px) {
  #page-career-form .wrap-site {
    width: auto;
    padding: 0 25px;
  }
}
@media only screen and (max-width: 767px) {
  #page-career-form .page-ttl {
    font-size: 24px;
    font-size: 2.4rem;
  }
  #page-career-form #breadcrumbs {
    display: none;
  }
  #page-career-form #form-step {
    border-top: 1px solid #ecefea;
    position: relative;
    margin: 0 25px 30px;
  }
  #page-career-form #form-step li {
    position: relative;
    margin-top: -26px;
    text-align: center;
    width: 34%;
    border: none;
  }
  #page-career-form #form-step li::before, #page-career-form #form-step li::after {
    display: none;
  }
  #page-career-form #form-step li:first-child, #page-career-form #form-step li:last-child {
    border: none;
    width: 33%;
  }
  #page-career-form #form-step li:first-child {
    text-align: left;
  }
  #page-career-form #form-step li:last-child {
    text-align: right;
  }
  #page-career-form #form-step li span {
    background: #fff;
    margin: 0;
  }
  #page-career-form #form-step li em {
    display: none;
  }
  #page-career-form .form-actions {
    padding: 50px 0 0;
  }
  #page-career-form .form-actions .btn {
    display: block;
    width: 100%;
    padding: 20px 0;
    font-size: 22px;
    font-size: 2.2rem;
    text-align: center;
  }
  #page-career-form #confirm-actions {
    overflow: hidden;
  }
  #page-career-form #confirm-actions button {
    width: 48%;
    float: left;
  }
  #page-career-form #confirm-actions button:last-child {
    float: right;
  }
  #page-career-form #thx-notice p {
    line-height: 1.6;
  }
}
@media only screen and (max-width: 480px) {
  #page-career-form #logo-site {
    font-size: 28px;
    font-size: 2.8rem;
  }
  #page-career-form #logo-site img {
    width: 50px;
  }
  #page-career-form #thx-msg {
    padding: 25px 0 0;
    margin: 0 0 50px;
  }
  #page-career-form #thx-msg p {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 2;
  }
  #page-career-form #thx-notice {
    background: #ecefea;
    padding: 15px;
    margin: 0 0 50px;
  }
  #page-career-form #thx-notice p {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.6;
  }
}

@media only screen and (max-width: 991px) {
  #btn-trigger {
    background: rgba(0, 0, 0, 0.6);
  }
  #nav-trigger {
    top: 15px;
    left: 15px;
  }
  #to-pagetop {
    right: 25px;
    bottom: 35px;
  }
  #nav-global {
    top: 105px;
    left: 30px;
  }
}
@media only screen and (max-width: 767px) {
  #nav-trigger {
    top: 10px;
    left: 10px;
    padding: 0;
  }
  #btn-trigger {
    width: 50px;
    height: 50px;
  }
  #btn-trigger-icon {
    width: 25px;
    margin: -1px 0 0 -7px;
  }
  #btn-trigger-icon:before, #btn-trigger-icon:after {
    width: 25px;
    height: 3px;
  }
  #btn-trigger-icon:before {
    margin-top: -10px;
  }
  #btn-trigger-icon:after {
    margin-top: 6px;
  }
  #nav-global {
    top: 60px;
    left: 10px;
  }
  #nav-global ul {
    padding: 25px 45px 25px 30px;
  }
  #nav-global li {
    margin: 0 0 25px;
  }
  #nav-global a {
    font-size: 20px;
    font-size: 2rem;
  }
  #to-pagetop {
    right: 15px;
    bottom: 25px;
  }
}
.catch-line-height {
  line-height: 1.6;
}

@media only screen and (max-width: 1199px) {
  #page-graduates .wrap-site {
    width: auto;
  }
  #page-graduates .ttl-section {
    font-size: 28px;
    font-size: 2.8rem;
    position: relative;
    top: -30px;
  }
  #page-graduates .ttl-section span {
    padding: 0 30px 0 0;
  }
  #page-graduates #header {
    padding: 80px 0 0;
    height: 960px;
    background-size: auto 100%;
  }
  #page-graduates #container-outline .catch-section {
    font-size: 24px;
    font-size: 2.4rem;
  }
  #page-graduates #container-outline .catch-section span {
    margin: 0 0 30px;
  }
  #page-graduates #container-outline .catch-section .catch-line-height {
    line-height: 1.6;
  }
}
@media only screen and (max-width: 991px) {
  #page-graduates dd,
  #page-graduates p {
    line-height: 2;
  }
  #page-graduates .ttl-section {
    font-size: 40px;
    font-size: 4rem;
    left: -15px;
    margin: 0 0 25px;
  }
  #page-graduates .ttl-section span {
    padding: 0 15px 0 0;
  }
  #page-graduates .body-section {
    padding: 0 25px;
  }
  #page-graduates #header {
    padding: 150px 0 0;
  }
  #page-graduates #header #ttl-page {
    padding: 0 75px;
  }
  #page-graduates #container-outline .catch-section {
    font-size: 30px;
    font-size: 3rem;
  }
  #page-graduates #container-about .catch-section {
    font-size: 26px;
    font-size: 2.6rem;
    line-height: 1.4;
  }
  #page-graduates #products-detail {
    display: none;
  }
  #page-graduates #container-work .ttl-box {
    font-size: 26px;
    font-size: 2.6rem;
  }
  #page-graduates #container-work .box-staff {
    padding: 45px 0 0;
    border-top: 1px solid #444;
  }
  #page-graduates #container-work .box-staff dl {
    margin: 0 0 45px;
  }
  #page-graduates #container-work .box-staff dt {
    font-weight: bold;
    font-size: 20px;
    font-size: 2rem;
    margin: 0 0 15px;
  }
  #page-graduates #container-application .ttl-body {
    font-size: 28px;
    font-size: 2.8rem;
    margin: 0 0 45px;
  }
  #page-graduates #container-application .ttl-box {
    font-size: 24px;
    font-size: 2.4rem;
    margin: 0 0 25px;
  }
  #page-graduates #container-application dl {
    margin: 0 0 15px;
    padding: 0 0 15px;
    border-bottom: 1px solid #ccc;
  }
  #page-graduates #container-application dt {
    font-weight: bold;
  }
  #page-graduates #container-flow .ttl-box {
    font-size: 24px;
    font-size: 2.4rem;
    margin: 0 0 25px;
  }
}
@media only screen and (max-width: 767px) {
  #page-graduates .ttl-section {
    font-size: 30px;
    font-size: 3rem;
    left: 0;
    margin: 0;
  }
  #page-graduates .ttl-section span {
    transform: rotate(0deg);
    font-size: 36px;
    font-size: 3.6rem;
  }
  #page-graduates .inner-section {
    padding: 75px 0;
  }
  #page-graduates .body-section {
    padding: 0 15px;
  }
  #page-graduates #header {
    padding: 75px 0 0;
    height: 800px;
  }
  #page-graduates #header #ttl-page {
    padding: 0 25px;
    margin: 0 0 125px;
  }
  #page-graduates #header #ttl-page .logo {
    bottom: -45px;
  }
  #page-graduates #header #catch-page {
    padding: 0 25px;
  }
  #page-graduates #header #catch-page strong {
    font-size: 60px;
    font-size: 6rem;
    margin: 0 0 25px;
  }
  #page-graduates #header #catch-page span {
    font-size: 24px;
    font-size: 2.4rem;
    margin: 0 auto 20px;
    line-height: 1.8;
  }
  #page-graduates #header #catch-page p#end-msg {
    font-size: 40px;
    font-size: 4rem;
  }
  #page-graduates #header .header__headtxt {
    font-size: 24px;
    font-size: 2.4rem;
  }
  #page-graduates #container-outline .catch-section {
    font-size: 20px;
    font-size: 2rem;
    margin: 0 0 25px;
  }
  #page-graduates #container-outline .catch-section span {
    line-height: 1.6;
    margin: 0;
    display: inline;
  }
  #page-graduates #container-about .catch-section {
    font-size: 22px;
    font-size: 2.2rem;
  }
  #page-graduates #container-work .ttl-box {
    font-size: 20px;
    font-size: 2rem;
    line-height: 1.4;
  }
  #page-graduates #container-work .box-staff dl {
    margin: 0 0 30px;
  }
  #page-graduates #container-work .box-staff dt {
    line-height: 1.4;
  }
  #page-graduates #container-application .ttl-body {
    font-size: 20px;
    font-size: 2rem;
    margin: 0 0 45px;
  }
  #page-graduates #container-application .ttl-box {
    font-size: 18px;
    font-size: 1.8rem;
    margin: 0 0 25px;
  }
  #page-graduates #container-application dt {
    float: none;
    width: auto;
  }
  #page-graduates #container-application dd {
    margin: 0;
  }
  #page-graduates #container-flow .inner-section {
    padding-bottom: 25px;
  }
  #page-graduates #container-flow .ttl-box {
    font-size: 20px;
    font-size: 2rem;
  }
  #page-graduates #container-entry {
    padding: 0 20px 75px;
  }
  #page-graduates #container-entry .btn a {
    display: block;
    padding: 20px 0;
    font-size: 20px;
    font-size: 2rem;
  }
}
@media only screen and (max-width: 480px) {
  #page-graduates .ttl-section {
    font-size: 26px;
    font-size: 2.6rem;
  }
  #page-graduates .ttl-section span {
    font-size: 30px;
    font-size: 3rem;
  }
  #page-graduates dd,
  #page-graduates p {
    font-size: 14px;
    font-size: 1.4rem;
  }
  #page-graduates #header {
    height: 600px;
  }
  #page-graduates #header .header__headtxt {
    font-size: 16px;
    font-size: 1.6rem;
  }
  #page-graduates #header #catch-page p#end-msg {
    font-size: 30px;
    font-size: 3rem;
  }
  #page-graduates #header #catch-page span {
    font-size: 18px;
    font-size: 1.8rem;
  }
  #page-graduates #header #ttl-page {
    margin-bottom: 70px;
  }
  #page-graduates #container-outline .catch-section span {
    font-size: 18px;
    font-size: 1.8rem;
  }
  #page-graduates #container-outline .catch-section span br {
    display: none;
  }
  #page-graduates #container-about .catch-section {
    font-size: 18px;
    font-size: 1.8rem;
  }
  #page-graduates #container-company .ttl-box {
    font-size: 18px;
    font-size: 1.8rem;
    margin-bottom: 15px;
  }
  #page-graduates #container-company #box-company-outline p {
    line-height: 1.5;
  }
  #page-graduates #container-work .ttl-box {
    font-size: 18px;
    font-size: 1.8rem;
  }
  #page-graduates #container-work .box-staff dt {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

@media only screen and (max-width: 980px) {
  #page-graduates-form .wrap-site {
    width: auto;
    padding: 0 25px;
  }
}
@media only screen and (max-width: 767px) {
  #page-graduates-form .page-ttl {
    font-size: 24px;
    font-size: 2.4rem;
  }
  #page-graduates-form #breadcrumbs {
    display: none;
  }
  #page-graduates-form #form-step {
    border-top: 1px solid #ecefea;
    position: relative;
    margin: 0 25px 30px;
  }
  #page-graduates-form #form-step li {
    position: relative;
    margin-top: -26px;
    text-align: center;
    width: 34%;
    border: none;
  }
  #page-graduates-form #form-step li::after, #page-graduates-form #form-step li::before {
    display: none;
  }
  #page-graduates-form #form-step li:first-child, #page-graduates-form #form-step li:last-child {
    border: none;
    width: 33%;
  }
  #page-graduates-form #form-step li:first-child {
    text-align: left;
  }
  #page-graduates-form #form-step li:last-child {
    text-align: right;
  }
  #page-graduates-form #form-step li span {
    background: #fff;
    margin: 0;
  }
  #page-graduates-form #form-step li em {
    display: none;
  }
  #page-graduates-form .form-actions {
    padding: 50px 0 0;
  }
  #page-graduates-form .form-actions .btn {
    display: block;
    width: 100%;
    padding: 20px 0;
    font-size: 22px;
    font-size: 2.2rem;
    text-align: center;
  }
  #page-graduates-form #confirm-actions {
    overflow: hidden;
  }
  #page-graduates-form #confirm-actions button {
    width: 48%;
    float: left;
  }
  #page-graduates-form #confirm-actions button:last-child {
    float: right;
  }
  #page-graduates-form #thx-notice p {
    line-height: 1.6;
  }
}
@media only screen and (max-width: 480px) {
  #page-graduates-form #logo-site {
    font-size: 28px;
    font-size: 2.8rem;
  }
  #page-graduates-form #logo-site img {
    width: 50px;
  }
  #page-graduates-form #thx-msg {
    padding: 25px 0 0;
    margin: 0 0 50px;
  }
  #page-graduates-form #thx-msg p {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 2;
  }
  #page-graduates-form #thx-notice {
    background: #ecefea;
    padding: 15px;
    margin: 0 0 50px;
  }
  #page-graduates-form #thx-notice p {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.6;
  }
}

@media only screen and (max-width: 991px) {
  #btn-trigger {
    background: rgba(0, 0, 0, 0.6);
  }
  #nav-trigger {
    top: 15px;
    left: 15px;
  }
  #to-pagetop {
    right: 25px;
    bottom: 35px;
  }
  #nav-global {
    top: 105px;
    left: 30px;
  }
}
@media only screen and (max-width: 767px) {
  #nav-trigger {
    top: 10px;
    left: 10px;
    padding: 0;
  }
  #btn-trigger {
    width: 50px;
    height: 50px;
  }
  #btn-trigger-icon {
    width: 25px;
    margin: -1px 0 0 -7px;
  }
  #btn-trigger-icon:after,
  #btn-trigger-icon:before {
    width: 25px;
    height: 3px;
  }
  #btn-trigger-icon:before {
    margin-top: -10px;
  }
  #btn-trigger-icon:after {
    margin-top: 6px;
  }
  #nav-global {
    top: 60px;
    left: 10px;
  }
  #nav-global ul {
    padding: 25px 45px 25px 30px;
  }
  #nav-global li {
    margin: 0 0 25px;
  }
  #nav-global a {
    font-size: 20px;
    font-size: 2rem;
  }
  #to-pagetop {
    right: 15px;
    bottom: 25px;
  }
}
@media only screen and (max-width: 991px) {
  .common-contact-container {
    padding: 45px 0;
  }
  .common-contact-content {
    color: #fff;
  }
  .common-contact-content__ttl {
    font-size: 22px;
    font-size: 2.2rem;
    margin: 0 0 25px;
    font-weight: bold;
  }
  .common-contact-content__outline {
    font-size: 16px;
    font-size: 1.6rem;
    margin: 0 0 15px;
  }
  .common-contact-content__notice {
    font-size: 16px;
    font-size: 1.6rem;
    margin: 0 0 35px;
  }
  .common-contact-content__notice p {
    font-size: 14px;
    font-size: 1.4rem;
  }
  .common-contact-content__tel {
    margin: 0 0 25px;
  }
  .common-contact-content__tel-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 0 15px;
  }
  .common-contact-content__tel-label {
    font-weight: bold;
    padding: 0 5px;
    font-size: 14px;
    font-size: 1.4rem;
  }
  .common-contact-content__tel-no {
    font-size: 18px;
    font-size: 1.8rem;
    font-weight: bold;
    padding: 0 5px;
  }
  .common-contact-content__tel-no a {
    text-decoration: none;
    color: #f2f2f2;
  }
  .common-contact-content__tel-notice p {
    font-size: 14px;
    font-size: 1.4rem;
  }
  .common-contact-content__btn-wrap {
    margin: 0 auto 35px !important;
    justify-content: center;
  }
  .common-contact-content__btn-wrap a {
    display: block;
  }
  .footer {
    padding: 50px 0 40px;
  }
  .footer__content {
    display: block;
  }
  .footer-logo {
    display: none;
  }
  .nav-out-site {
    margin: 0 0 25px;
  }
  .nav-out-site__list {
    justify-content: center;
  }
  .nav-out-site__item {
    padding: 0 15px;
  }
  .nav-footer__list {
    display: block;
    margin: 0 0 45px;
    border-top: 1px solid #414141;
  }
  .nav-footer__item {
    padding: 12px 0;
    border-bottom: 1px solid #414141;
  }
  .nav-footer__item a {
    display: block;
    font-size: 14px;
    font-size: 1.4rem;
    text-align: center;
  }
  .copyright {
    text-align: center;
  }
  .estimate-content__tel-wrap {
    display: block;
    margin: 0 0 15px;
  }
  .estimate-content__tel-label {
    font-size: 16px;
    font-size: 1.6rem;
    padding: 0;
    margin: 0 0 10px;
  }
  .estimate-content__tel-no {
    font-size: 30px;
    font-size: 3rem;
    font-weight: bold;
  }
}
@media only screen and (max-width: 1300px) {
  .grid-container {
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0 50px;
  }
}
@media only screen and (max-width: 1199px) {
  .grid-container {
    width: 1000px;
    padding: 0 25px;
  }
  .local-content__ttl {
    font-size: 32px;
    font-size: 3.2rem;
    margin: 0 0 50px;
  }
  .local-content__head {
    margin: 0 0 35px;
  }
  .local-content__head .local-content__ttl {
    margin: 0 0 35px;
  }
}
@media only screen and (max-width: 991px) {
  .grid-container {
    width: auto;
    margin: 0;
    padding: 0 15px;
  }
  .local-content__ttl {
    font-size: 24px;
    font-size: 2.4rem;
    margin: 0 0 25px;
  }
  .local-content__outline {
    margin: 0 0 45px;
  }
  .local-content__inner {
    margin: 0 0 50px;
  }
  .local-content__box {
    margin: 0 0 25px;
  }
  .local-content__head {
    margin: 0 0 20px;
  }
  .local-content__head .local-content__ttl {
    margin: 0 0 20px;
  }
  .local-content__head-text {
    font-size: 20px;
    font-size: 2rem;
    margin: 0 0 25px;
  }
  .local-content__img-separator {
    height: 250px;
  }
  .local-content__row {
    display: block;
  }
  .local-content__row-box {
    width: auto;
    padding: 0 0 25px;
  }
  .local-content__row-box:last-child {
    padding: 0;
  }
  .local-content__table.stretch th,
  .local-content__table.stretch td {
    width: 100px;
  }
  .local-content__table th {
    font-size: 14px;
    font-size: 1.4rem;
    white-space: nowrap;
    line-height: 1.2;
  }
  .local-content__table td {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.2;
  }
  .local-content__btn a {
    padding: 12px 0;
  }
  .local-content__btn.emphasis {
    max-width: auto;
  }
  .local-content__btn.emphasis a {
    font-size: 20px;
    font-size: 2rem;
  }
  .local-content__btn i {
    padding: 0 0 0 5px;
  }
}