@charset "UTF-8";
/**  Mixins */
/*------------------------------------*\
    breakpoint vars
\*------------------------------------*/
/*------------------------------------*\
    breakpoint mixin
\*------------------------------------*/
/** Break desktop first**/
/** Global **/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&family=Noto+Serif+JP:wght@400;500;600;700&display=swap");
*,
*::before,
*::after {
    box-sizing: border-box; }

html {
    font-family: sans-serif;
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }

article, aside, figcaption, figure, footer, header, hgroup, main, nav, section {
    display: block; }

body {
    margin: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    text-align: left; }

[tabindex="-1"]:focus {
    outline: 0 !important; }

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible; }

h1, h2, h3, h4, h5, h6 {
    margin-top: 0;
    margin-bottom: 0.5rem; }

p {
    margin-top: 0;
    margin-bottom: 1rem; }

abbr[title],
abbr[data-original-title] {
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
    cursor: help;
    border-bottom: 0;
    -webkit-text-decoration-skip-ink: none;
    text-decoration-skip-ink: none; }

address {
    margin-bottom: 1rem;
    font-style: normal;
    line-height: inherit; }

ol,
ul,
dl {
    margin-top: 0;
    margin-bottom: 1rem; }

ol ol,
ul ul,
ol ul,
ul ol {
    margin-bottom: 0; }

dt {
    font-weight: 700; }

dd {
    margin-bottom: .5rem;
    margin-left: 0; }

blockquote {
    margin: 0 0 1rem; }

b,
strong {
    font-weight: bolder; }

small {
    font-size: 80%; }

sub,
sup {
    position: relative;
    font-size: 75%;
    line-height: 0;
    vertical-align: baseline; }

sub {
    bottom: -.25em; }

sup {
    top: -.5em; }

a {
    color: #6096C4;
    text-decoration: none; }
a:hover {
    opacity: .8; }

a:not([href]):not([tabindex]) {
    color: inherit;
    text-decoration: none; }

a:not([href]):not([tabindex]):hover, a:not([href]):not([tabindex]):focus {
    color: inherit;
    text-decoration: none; }

a:not([href]):not([tabindex]):focus {
    outline: 0; }

pre,
code,
kbd,
samp {
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 1em; }

pre {
    margin-top: 0;
    margin-bottom: 1rem;
    overflow: auto; }

figure {
    margin: 0;
    padding: 0; }

img {
    vertical-align: middle;
    border-style: none; }

svg {
    overflow: hidden;
    vertical-align: middle; }

table {
    border-collapse: collapse; }

caption {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    color: #6c757d;
    text-align: left;
    caption-side: bottom; }

th {
    text-align: inherit; }

label {
    display: inline-block;
    margin-bottom: 0.5rem; }

button {
    border-radius: 0; }

button:focus {
    outline: 1px dotted;
    outline: 5px auto -webkit-focus-ring-color; }

input,
button,
select,
optgroup,
textarea {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit; }

button,
input {
    overflow: visible; }

button,
select {
    text-transform: none; }

select {
    word-wrap: normal; }

button,
[type="button"],
[type="reset"],
[type="submit"] {
    -webkit-appearance: button; }

button:not(:disabled),
[type="button"]:not(:disabled),
[type="reset"]:not(:disabled),
[type="submit"]:not(:disabled) {
    cursor: pointer; }

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
    padding: 0;
    border-style: none; }

input[type="radio"],
input[type="checkbox"] {
    box-sizing: border-box;
    padding: 0; }

input[type="date"],
input[type="time"],
input[type="datetime-local"],
input[type="month"] {
    -webkit-appearance: listbox; }

textarea {
    overflow: auto;
    resize: vertical; }

fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0; }

legend {
    display: block;
    width: 100%;
    max-width: 100%;
    padding: 0;
    margin-bottom: .5rem;
    font-size: 1.5rem;
    line-height: inherit;
    color: inherit;
    white-space: normal; }

progress {
    vertical-align: baseline; }

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
    height: auto; }

[type="search"] {
    outline-offset: -2px;
    -webkit-appearance: none; }

[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none; }

::-webkit-file-upload-button {
    font: inherit;
    -webkit-appearance: button; }

output {
    display: inline-block; }

summary {
    display: list-item;
    cursor: pointer; }

template {
    display: none; }

[hidden] {
    display: none !important; }

:root {
    --white: #ffffff;
    --black: #000000;
    --smoke: #F4F5EF;
    --gray: #E5E5E5;
    --red: #DA0012;
    --primary: #2F505E;
    --second: #D75E5B;
    --text-body: #282828;
    --radius: 5px; }

/* Base Setting
---------------------------------------- */
html {
    scroll-behavior: smooth; }

body {
    margin: 0;
    padding: 0;
    font-size: 1rem;
    font-family: "Noto Sans JP", sans-serif;
    overflow-wrap: break-word;
    font-weight: 400;
    color: var(--white);
    overflow-x: hidden;
    line-height: 1.5;
    position: relative;
    width: 100%;
    background: var(--black); }
body.bg-black {
    background: var(--black);
    color: var(--white); }
body.page-id-35{background: var(--white);color: var(--text-body);}
a {
    transition: all 0.3s;
    color: var(--primary);
    outline: none !important; }
a:hover {
    opacity: 1;
    color: var(--second); }

h1, h2, h3, h4, h5, h6 {
    font-weight: 700;
    color: var(--primary); }

h1 {
    font-size: 2.25rem;
    line-height: 1.3; }
@media (min-width: 48em) {
    h1 {
        font-size: 2.875rem; } }

h2 {
    font-size: 2.5rem;
    line-height: 1.15; }
@media (min-width: 48em) {
    h2 {
        font-size: 3.5rem; } }

h3 {
    font-size: 2.125rem;
    line-height: 1.16; }
@media (min-width: 48em) {
    h3 {
        font-size: 2.5rem; } }

h4 {
    font-size: 1.75rem;
    line-height: 1.16; }
@media (min-width: 48em) {
    h4 {
        font-size: 2.25rem; } }

h5 {
    font-size: 1.25rem;
    line-height: 1.2; }
@media (min-width: 48em) {
    h5 {
        font-size: 1.5rem; } }

h6 {
    font-size: 1.125rem;
    line-height: 1.3; }
@media (min-width: 48em) {
    h6 {
        font-size: 1.25rem; } }

img {
    max-width: 100%;
    vertical-align: bottom; }

.container, .container-fluid {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 15px;
    position: relative; }

.header__navigation, .footer__navigation, .footer__right ul, .news ul, .model__list ul, .works__filter ul, .about__content ul, .history__content ul, .row-info__item > div ul, .equipment-section__list > ul {
    margin: 0;
    padding: 0;
    list-style: none; }

.btn,
button,
input[type="button"],
input[type="submit"], .btn-arrow, .btn-click, .form-row .form-col span, .checkbox__checkmark::after, .header:after, .header::before, .news__title, .news ul li > a::before, .model::after, .model__bottom, .flow__item.item3 .flow__title strong, .flow__item.item5 .flow__title strong, .instagram__heading, .history, .history .bg::after, .contact h2, .contact-info, .equipment-section__heading, .contact-section, .heading-cross {
    background: #960012;
    background: linear-gradient(90deg, #960012 0%, #da0012 50%, #960012 100%); }

input[type="text"],
input[type="email"],
input[type="password"],
input[type="phone"],
input[type="search"],
input[type="tel"],
textarea,
select {
    border: 1px solid #b2b2b2;
    border-radius: 0;
    padding: 10px 15px;
    outline: none !important;
    max-width: 100%; }
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="phone"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
textarea:focus,
select:focus {
    border-color: var(--black); }

.btn,
button,
input[type="button"],
input[type="submit"] {
    transition: all 0.3s;
    color: var(--white);
    padding: 13px 25px;
    min-width: 188px;
    text-align: center;
    font-weight: 900;
    display: inline-block;
    outline: none !important;
    border-radius: 0;
    text-transform: uppercase;
    border: 0;
    font-size: 20px; }
.btn:hover,
button:hover,
input[type="button"]:hover,
input[type="submit"]:hover {
    opacity: 0.9;
    color: var(--white); }
.btn svg,
button svg,
input[type="button"] svg,
input[type="submit"] svg {
    margin-right: 15px;
    max-height: 20px; }
.btn.btn-white,
button.btn-white,
input[type="button"].btn-white,
input[type="submit"].btn-white {
    color: var(--primary);
    background: var(--white); }

.btn-outline {
    transition: all 0.3s;
    text-align: center;
    font-weight: 700;
    display: inline-block;
    outline: none !important;
    background: none;
    text-transform: uppercase;
    min-width: 188px;
    border: 1px solid var(--white);
    border-radius: 0;
    padding: 12px 25px;
    color: var(--white);
    font-size: 20px; }
.btn-outline:hover {
    opacity: 0.9;
    color: var(--white); }
.btn-outline svg {
    margin-right: 15px;
    max-height: 20px; }
.btn-outline.btn-white {
    border-color: var(--white);
    color: var(--white); }

.btn-arrow {
    font-weight: 900;
    display: inline-flex;
    align-items: center;
    color: var(--white);
    padding: 10px 20px;
    clip-path: polygon(0% 0%, calc(100% - 22px) 0%, 100% 50%, calc(100% - 22px) 100%, 0% 100%);
    font-size: 18px; }
@media only screen and (min-width: 768px) {
    .btn-arrow {
        font-size: 27px; } }
.btn-arrow small {
    margin-left: 20px;
    font-size: 13px; }
@media only screen and (min-width: 768px) {
    .btn-arrow small {
        font-size: 18px; } }
.btn-arrow:hover {
    color: var(--white);
    opacity: 0.9; }

.btn-click {
    font-size: 22px;
    line-height: 30px;
    color: var(--white);
    display: inline-block;
    position: relative;
    padding: 10px 20px 10px 50px;
    min-width: 185px;
    text-align: center; }
.btn-click::before {
    content: "CLICK";
    text-transform: uppercase;
    display: flex;
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    font-size: 12px;
    font-weight: 900;
    line-height: 1;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    justify-content: center;
    padding: 0 9px;
    border-right: 1px solid var(--white);
    z-index: 1; }
.btn-click:hover {
    color: var(--white);
    opacity: 0.8 !important; }

.container-fluid {
    max-width: 1920px; }
@media (min-width: 48em) {
    .container-fluid {
        padding: 0 64px; } }

.hamburger {
    position: relative;
    width: 50px;
    height: 50px;
    line-height: 1;
    cursor: pointer;
    display: block;
    right: 0;
    z-index: 99;
    align-self: flex-end;
    border: 2px solid var(--white);
    opacity: 1; }
@media (min-width: 48em) {
    .hamburger {
        display: none; } }
.hamburger__line {
    width: 29px;
    height: 3px;
    background: var(--white);
    backface-visibility: hidden;
    position: absolute;
    display: block;
    margin: auto;
    transition: 0.3s all ease;
    transform: rotate(0deg);
    border-radius: 5px;
    top: calc(50% - 1.5px);
    left: calc(50% - 14.5px); }
.hamburger__line::before, .hamburger__line::after {
    content: "";
    transform-origin: center center;
    width: 29px;
    height: 3px;
    background: var(--white);
    backface-visibility: hidden;
    position: absolute;
    left: 0;
    top: 10px;
    transition: 0.3s all ease;
    border-radius: 5px;
    opacity: 1; }
.hamburger__line::after {
    top: -10px; }
.hamburger.active .hamburger__line {
    transform: rotate(225deg); }
.hamburger.active .hamburger__line::before {
    transform: rotate(-90deg);
    top: 0; }
.hamburger.active .hamburger__line::after {
    opacity: 0; }

.section--heading {
    font-size: 40px;
    line-height: 1;
    text-align: center;
    font-weight: 900;
    color: var(--black); }

.form-row {
    text-align: left;
    border-bottom: 1px solid #b2b2b2;
    padding: 24px 0; }
@media only screen and (min-width: 768px) {
    .form-row {
        display: flex; } }
.form-row .form-col {
    align-items: center;
    margin-bottom: 10px;
    display: flex;
    justify-content: space-between; }
@media only screen and (min-width: 768px) {
    .form-row .form-col {
        width: 255px;
        padding-right: 15px;
        align-items: flex-start;
        margin-bottom: 0; } }
.form-row .form-col label {
    margin: 0;
    font-weight: 500; }
@media only screen and (min-width: 768px) {
    .form-row .form-col label {
        margin: 10px 0 0; } }
.form-row .form-col span {
    font-size: 15px;
    display: inline-block;
    font-weight: 700;
    color: var(--white);
    padding: 2px 10px; }
@media only screen and (min-width: 768px) {
    .form-row .form-input {
        width: calc(100% - 255px); } }
.form-row .form-input input[type="text"],
.form-row .form-input input[type="email"],
.form-row .form-input input[type="password"],
.form-row .form-input input[type="phone"],
.form-row .form-input input[type="search"],
.form-row .form-input input[type="tel"],
.form-row .form-input textarea {
    width: 100%;
    font-weight: 300; }
.form-row .form-input p {
    margin: 0; }

.form-submit {
    margin-top: 45px; }

.wpcf7-spinner {
    display: none; }

.checkbox__container {
    display: block;
    position: relative;
    padding-left: 35px;
    margin: 0;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    font-size: 18px;
    display: inline-block; }
.checkbox__container:hover input ~ .checkmark {
    background-color: #ccc; }
.checkbox__container input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0; }
.checkbox__container input:checked ~ .checkbox__checkmark::after {
    display: block; }

.checkbox__checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 24px;
    width: 24px;
    border-radius: 50%;
    background: none;
    border: 1px solid #b2b2b2; }
.checkbox__checkmark::after {
    content: "";
    position: absolute;
    display: none;
    left: 4px;
    top: 4px;
    width: 14px;
    height: 14px;
    border-radius: 50%; }

.header__navigation, .footer__navigation {
    display: flex; }
.header__navigation li a, .footer__navigation li a {
    color: var(--white);
    font-size: 20px;
    line-height: 21px;
    display: block;
    text-transform: uppercase;
    position: relative;
    font-weight: 900; }
.header__navigation li a span{
    font-size: 13px;
    line-height: 1.6;
    font-weight: 400;
    margin-left: 10px;
}
@media (min-width: 768px){
    .header__navigation li a span{
        margin-left: 0;
        display: block;
        text-align: center;
    }
}
.header {
    position: fixed;
    background: #000;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 9999999;
}
.admin-bar .header {top:32px;}
.header:after, .header::before {
    content: "";
    width: 100%;
    right: 0;
    top: 0;
    height: 100%;
    max-width: 70%;
    background-size: cover;
    position: absolute;
    right: 0;
    z-index: 1;
    clip-path: polygon(120px 0, 100% 0, 100% 100%, 0% 100%); }
.header::before {
    background: var(--white);
    clip-path: polygon(118px 0, 100% 0, 100% 100%, -2px 100%); }
.header .container {
    max-width: 1503px;
    height: 120px;
    display: flex;
    position: relative;
    align-items: center;
    z-index: 2;
    column-gap: 20px;
    justify-content: space-between; }
@media only screen and (max-width: 767px) {
    .header__logo {
        width: 70%; } }
.header__logo img {
    height: auto;
    object-fit: contain;
    display: block;
    max-height: 100px; }
@media (min-width: 48em) {
    .header__logo img {
        width: 310px; } }
.header__navigation {
    column-gap: 40px;
    display: none; }
@media (min-width: 48em) {
    .header__navigation {
        display: flex; } }
@media only screen and (max-width: 767px) {
    .header__navigation {
        width: 100%;
        position: absolute;
        top: 100%;
        left: 0;
        padding: 20px;
        flex-direction: column;
        background: var(--black); }
    .header__navigation li a {
        display: block;
        border-bottom: 1px solid rgba(255, 255, 255, 0.5);
        height: 50px;
        line-height: 50px; }
    .header__navigation li a::after {
        right: 0;
        bottom: 50%;
        left: initial; }
    .header__navigation li:last-child a {
        border-bottom: none; } }
.header__navigation a::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -15px;
    transform: translateX(-50%);
    border-bottom: none;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 7px solid #fff; }
.wrap{padding-top:120px;}
.footer {
    padding-left: 20px;
    padding-right: 20px;
    background: var(--black); }
@media only screen and (max-width: 767px) {
    .footer {
        padding-top: 30px;
        padding-bottom: 20px; } }
.footer .container {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    color: var(--white);
    min-height: 155px;
    padding: 10px 0; }
@media only screen and (max-width: 767px) {
    .footer .container {
        flex-direction: column; } }
.footer .container a {
    color: var(--white);
    transition: opacity .3s; }
.footer .container a:hover {
    opacity: .8; }
.footer .container p {
    margin-bottom: 0; }
.footer__left img {
    display: block;
    width: 305px;
    height: auto;
    object-fit: cover;
    margin-bottom: 10px; }
.footer__left p {
    line-height: 21px; }
.footer__right {
    display: flex;
    flex-direction: column;
    justify-content: flex-end; }
@media only screen and (max-width: 767px) {
    .footer__right {
        margin-top: 20px; } }
.footer__right ul {
    margin-bottom: 5px; }
.footer__right p {
    text-align: right; }
@media only screen and (max-width: 767px) {
    .footer__right p {
        text-align: left; } }
.footer__navigation {
    column-gap: 20px; }
.footer__navigation li a {
    /*font-size: 15px;*/
    font-size: 14px; }
@media only screen and (max-width: 767px) {
    .footer__navigation {
        flex-wrap: wrap;
        column-gap: 20px;
        row-gap: 10px;
        margin-bottom: 20px !important; } }
.footer__social {
    margin-bottom: 30px; }
.footer__social ul {
    display: flex;
    column-gap: 20px;
    justify-content: flex-end; }
@media only screen and (max-width: 767px) {
    .footer__social ul {
        justify-content: flex-start; } }
.footer__social ul li {
    width: 32px;
    height: 32px;
    display: block; }
.footer__social ul li svg {
    width: 100%;
    height: 100%;
    object-fit: cover; }

/** Pages */
.hero {
    background: var(--black);
    position: relative;
    margin-bottom: 0 !important; }
.hero .container {
    max-width: 1393px; }
.hero .slick-dots {
    position: absolute;
    bottom: 30px; }
.hero .slick-dots li button::before {
    font-size: 16px;
    color: var(--white); }
.hero .slick-dots li.slick-active button::before {
    color: var(--white); }
.hero__item {
    position: relative; }
.hero__item figure {
    width: 100%;
    height: auto; }
.hero__item figure img {
    width: 100%;
    object-fit: cover; }
.hero__item--wrapper {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    color: #fff;
    display: flex;
    align-items: center; }
.hero__text {
    width: 100%;
    max-width: 861px; }
.hero__text h2 {
    font-weight: bold;
    font-size: 51px;
    line-height: 67px;
    color: var(--white);
    letter-spacing: .05em;
    margin-bottom: 30px;
    font-family: "Noto Serif JP", serif; }
@media only screen and (max-width: 767px) {
    .hero__text h2 {
        font-size: 8vw;
        line-height: 1.2;
        margin-bottom: 20px; } }
.hero__text strong {
    font-size: 22px;
    line-height: 25px;
    letter-spacing: 0.05em; }
@media only screen and (max-width: 767px) {
    .hero__text strong {
        font-size: 16px; } }

.news__title {
    text-transform: uppercase;
    width: 100%;
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center; }
.news__title h2 {
    font-size: 40px;
    line-height: 1;
    color: var(--black);
    text-transform: uppercase;
    text-align: center;
    font-weight: 900; }

.news ul {
    display: flex;
    justify-content: space-between; }
@media only screen and (max-width: 767px) {
    .news ul {
        flex-wrap: wrap; } }
.news ul li {
    width: 100%;
    border-right: 1px solid #ccc; }
.news ul li figure {
    width: 100%;height: 300px; }
.news ul li figure img {
    width: 100%;
    height: 100%;
    object-fit: cover; }
.news ul li > a {
    position: relative;
    display: block; }
.news ul li > a::before {
    content: "";
    width: 100%;
    height: 100%;
    opacity: 0;
    z-index: 1;
    transition: opacity .3s;
    position: absolute; }
.news ul li > a > span {
    position: absolute;
    top: 50%;
    left: 50%;
    color: #fff;
    transform: translate(-50%, -50%);
    z-index: 2;
    opacity: 0;
    transition: opacity .3s;
    text-transform: uppercase;
    font-size: 23px;
    font-weight: bold; }
.news ul li > a:hover::before {
    opacity: .7; }
.news ul li > a:hover > span {
    opacity: 1; }
.news ul li > span {
    color: #D40012;
    font-weight: bold; }
.news ul li a h2 {
    color: var(--white);
    font-size: 21px;
    line-height: 27px;
    font-weight: bold; }
.news ul li p {
    font-size: 15px;
    line-height: 21px;
    margin-bottom: 0; }

.news__item--content {
    padding: 10px; }
.news__item--content > span {
    font-weight: bold;
    color: #D40012; }

.model {
    background: var(--black);
    position: relative;
    padding-top: 90px;
    padding-bottom: 30px; }
.model .container {
    z-index: 2; }
.model::after {
    content: "";
    position: absolute;
    bottom: 129px;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    clip-path: polygon(100% 260px, 53% 100%, 100% 100%); }
@media only screen and (max-width: 767px) {
    .model::after {
        display: none; } }
.model:before {
    content: "";
    background: var(--white);
    position: absolute;
    bottom: 130px;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    clip-path: polygon(100% 259px, calc(53% - 1px) 100%, 100% 100%); }
@media only screen and (max-width: 767px) {
    .model:before {
        display: none; } }
.model__title > div {
    display: flex;
    align-items: flex-end;
    margin-bottom: 10px; }
@media only screen and (max-width: 1024px) {
    .model__title > div {
        flex-wrap: wrap; } }
.model__title > div h2 {
    font-size: 50px;
    line-height: 1;
    font-weight: bold;
    color: var(--white);
    letter-spacing: 0.08em; }
.model__title > div span {
    font-weight: bold;
    font-size: 30px;
    color: var(--white); }
.model__title p {
    font-weight: bold;
    font-size: 30px;
    color: #D40012; }
.model__list {
    display: flex;
    justify-content: space-between;
    position: relative;
    margin-top: 30px;
    margin-bottom: 30px; }
@media only screen and (max-width: 767px) {
    .model__list {
        flex-direction: column-reverse; } }
.model__list ul {
    width: 574px;
    padding-bottom: 80px; }
@media only screen and (max-width: 767px) {
    .model__list ul {
        padding-bottom: 40px;
        width: 100%; } }
.model__list ul li {
    position: relative;
    padding-left: 30px;
    font-size: 18px;
    line-height: 39px;
    color: var(--white);
    font-weight: bold; }
.model__list ul li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 10px;
    background: url(../images/check.png) no-repeat center;
    width: 21px;
    height: 21px;
    background-size: contain; }
.model figure {
    position: absolute;
    width: 580px;
    height: 630px;
    top: -65px;
    right: -87px;
    z-index: 2; }
@media only screen and (max-width: 767px) {
    .model figure {
        position: static;
        width: 100%;
        height: auto;
        object-fit: cover; } }
.model__bottom {
    height: 80px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    padding: 20px;
    z-index: 3;
    margin-bottom: 20px; }
@media only screen and (max-width: 767px) {
    .model__bottom {
        background: #900012;
        background: linear-gradient(90deg, #900012 0%, #d40012 50%, #900012 100%); } }
.model__bottom h3 {
    font-weight: 900;
    color: var(--white);
    line-height: 1;
    font-size: 28px; }
@media only screen and (max-width: 767px) {
    .model__bottom h3 {
        font-size: 18px;
        line-height: 1.2; } }
.model__bottom::after {
    content: "";
    width: 0;
    height: 0;
    position: absolute;
    bottom: -27px;
    left: 50%;
    transform: translateX(-50%);
    border-bottom: none;
    border-left: 62px solid transparent;
    border-right: 62px solid transparent;
    border-top: 30px solid #d40012; }
.model__bottom::before {
    content: "";
    width: 53%;
    height: 1px;
    border-top: 1px solid #fff;
    top: -1px;
    left: 0;
    position: absolute; }
@media only screen and (max-width: 767px) {
    .model__bottom::before {
        width: 100%; } }

.works {
    background: var(--black);
    padding-top: 70px;
    padding-bottom: 70px; }
@media only screen and (max-width: 767px) {
    .works {
        padding-top: 0;
        padding-bottom: 30px; } }
.works__heading {
    margin-bottom: 30px;
    color: var(--white); }
	
.works__heading h2 {
    color: var(--black);
    font-weight: 900;
    text-align: center;
    text-transform: uppercase;
	background: linear-gradient(90deg, #960012 0%, #da0012 50%, #960012 100%);
	padding:15px;margin-bottom:20px;
	}
.works__heading p {
    text-align: center;
    font-size: 18px;
    line-height: 30px;
    letter-spacing: .1em; }
.works__filter {
    margin-top: 70px;
    margin-bottom: 35px; }
.works__filter ul {
    display: flex;
    column-gap: 10px; }
@media only screen and (max-width: 767px) {
    .works__filter ul {
        flex-wrap: wrap; } }
.works__filter ul li {
    width: calc(100% - 10px);
    font-weight: 900; }
@media only screen and (max-width: 767px) {
    .works__filter ul li {
        max-width: calc(50% - 10px);
        margin-bottom: 10px; } }
.works__filter ul li a {
    color: var(--white);
    border: 2px solid var(--white);
    display: flex;
    height: 50px;
    padding-left: 27px;
    position: relative;
    white-space: nowrap; }
.works__filter ul li a span {
    border-top: 1px solid var(--white);
    text-transform: uppercase;
    transform: rotate(90deg);
    font-size: 12px;
    height: 20px;
    width: 48px;
    position: absolute;
    left: -12px;
    top: 12px;
    text-align: center; }
.works__filter ul li a strong {
    font-size: 18px;
    line-height: 45px; }
@media only screen and (max-width: 767px) {
    .works__filter ul li:nth-child(3) {
        max-width: 75%;
        margin-left: auto;
        margin-right: auto; } }
.works__gallery {
    display: flex;
    flex-wrap: wrap;
    column-gap: 2px;
    row-gap: 2px; }
.works__gallery a {
    display: block;
    width: 33%; }
@media only screen and (max-width: 767px) {
    .works__gallery a {
        width: 49.5%; } }
.works__gallery a figure {
    width: 100%;
    height: auto; }
.works__gallery a figure img {
    width: 100%;
    object-fit: cover; }

.flow {
    background: var(--black);
    color: var(--white);
    position: relative; }
.flow::before {
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 1; }
@media only screen and (max-width: 769px) {
    .flow::before {
        content: "";
        top: 0;
        background: linear-gradient(90deg, #900012 0%, #d40012 50%, #900012 100%);
        clip-path: polygon(0 93px, 100% 0%, 100% 100%, 0% 100%); } }
.flow__title {
    display: flex;
    align-items: flex-end;
    column-gap: 10px;
    margin-bottom: 30px; }
@media only screen and (max-width: 769px) {
    .flow__title {
        flex-wrap: wrap; } }
.flow__title strong {
    display: block;
    width: 40px;
    height: 40px;
    background: var(--black);
    color: #D40012;
    font-size: 35px;
    line-height: 40px;
    text-align: center; }
.flow__title h2 {
    color: var(--white);
    font-size: 35px;
    line-height: 30px;
    font-weight: 900; }
.flow__title span {
    color: var(--black);
    font-size: 25px;
    font-weight: bold; }
@media only screen and (max-width: 769px) {
    .flow__title span {
        color: var(--white); } }
.flow__item {
    position: relative;
    margin-bottom: 0;
    background-size: cover;
    min-height: 709px;
    z-index: 2; }
@media only screen and (max-width: 769px) {
    .flow__item {
        min-height: initial;
        padding-top: 110px;
        padding-bottom: 110px;
        background: none; } }
@media only screen and (max-width: 769px) {
    .flow__item .flow__item--wrapper {
        position: relative;
        z-index: 2; } }
.flow__item::before, .flow__item::after {
    position: relative;
    z-index: -1; }
.flow__item::before {
    top: 0; }
@media only screen and (max-width: 769px) {
    .flow__item::before {
        top: -20px; } }
.flow__item::after {
    bottom: 0; }
@media only screen and (max-width: 769px) {
    .flow__item::after {
        bottom: -20px;
        z-index: -1; } }
@media only screen and (max-width: 769px) {
    .flow__item figure {
        display: none; } }
.flow__item figure.mobile-image {
    display: none; }
@media only screen and (max-width: 769px) {
    .flow__item figure.mobile-image {
        display: block;
        position: relative;
        z-index: 33;
        padding: 20px; } }
.flow__item--wrapper {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    top: 0;
    left: 0;
    align-items: center;
    z-index: 2; }
@media only screen and (max-width: 769px) {
    .flow__item--wrapper {
        position: static; } }
.flow__item .item1 {
    margin-bottom: 50px;
    text-align: right; }
@media only screen and (max-width: 769px) {
    .flow__item .item1::after {
        content: "";
        background: url(../images/bg-process-black.svg) no-repeat center;
        background-size: cover;
        width: calc(100% + 30px);
        height: calc( 100% + 100vh);
        position: absolute;
        bottom: -220px;
        left: -15px;
        z-index: -1; } }
@media only screen and (max-width: 769px) {
    .flow__item .item1 {
        text-align: left;
        margin-bottom: 120px;
        position: relative; } }
.flow__item .item1 .flow__title {
    justify-content: flex-end; }
@media only screen and (max-width: 769px) {
    .flow__item .item1 .flow__title {
        justify-content: flex-start; }
    .flow__item .item1 .flow__title strong {
        color: var(--white);
        background: #900012;
        background: linear-gradient(90deg, #900012 0%, #d40012 50%, #900012 100%); } }
.flow__item.item0 {
    position: relative;
    z-index: 2;
    min-height: 720px; }
@media only screen and (max-width: 769px) {
    .flow__item.item0 {
        padding-bottom: 0;
        overflow: hidden; } }
@media (min-width: 48em) {
    .flow__item.item0 {
        background: url(../images/item12.png) no-repeat center;
        background-size: 1605px auto; } }
.flow__item.item3 {
    position: relative;
    z-index: 1;
    min-height: 738px; }
@media (min-width: 48em) {
    .flow__item.item3 {
        background: url(../images/item3.png) no-repeat center bottom;
        background-size: 1605px auto; } }
.flow__item.item3 figure {
    position: relative;
    z-index: 2; }
@media (min-width: 48em) {
    .flow__item.item3 figure img {
        opacity: 0; } }
@media only screen and (max-width: 769px) {
    .flow__item.item3 figure.mobile-image {
        margin-top: 20%;
        margin-bottom: 30px; } }
@media only screen and (max-width: 769px) {
    .flow__item.item3, .flow__item.item5 {
        z-index: 2; } }
.flow__item.item3::before, .flow__item.item5::before {
    position: absolute;
    z-index: 1;
    width: 100%;
    height: 100%;
    left: 0;
    background: url(../images/bg-process-black.svg) no-repeat center;
    background-size: 1605px auto; }
@media only screen and (max-width: 769px) {
    .flow__item.item3::before, .flow__item.item5::before {
        content: "";
        top: 0; } }
.flow__item.item3 .container, .flow__item.item5 .container {
    display: flex;
    justify-content: flex-end; }
@media only screen and (max-width: 769px) {
    .flow__item.item3 .container, .flow__item.item5 .container {
        display: block; } }
.flow__item.item3 .flow__item--text, .flow__item.item5 .flow__item--text {
    width: 100%;
    max-width: 330px; }
.flow__item.item3 .flow__title strong, .flow__item.item5 .flow__title strong {
    color: var(--black); }
.flow__item.item3 .flow__title span, .flow__item.item5 .flow__title span {
    color: #d40012; }
@media only screen and (max-width: 769px) {
    .flow__item.item3 .flow__title span, .flow__item.item5 .flow__title span {
        color: var(--white); } }
.flow__item.item3, .flow__item.item4, .flow__item.item5, .flow__item.item6 {
    margin-top: -300px; }
@media only screen and (max-width: 769px) {
    .flow__item.item3, .flow__item.item4, .flow__item.item5, .flow__item.item6 {
        margin-top: -45px; } }
@media (min-width: 48em) {
    .flow__item.item4 {
        background: url(../images/item4.png) no-repeat center;
        background-size: 1605px auto; } }
@media only screen and (max-width: 769px) {
    .flow__item.item4 {
        padding-top: 0;
        padding-bottom: 0; } }
.flow__item.item4 figure {
    position: relative; }
@media only screen and (max-width: 769px) {
    .flow__item.item4 figure.mobile-image {
        margin-bottom: 30px; } }
.flow__item.item6 {
    position: relative;
    min-height: 530px; }
@media only screen and (max-width: 767px) {
    .flow__item.item6 {
        padding-top: 0;
        padding-bottom: 40px; } }
.flow__item.item6 .container {
    display: flex;
    justify-content: flex-end;
    position: relative;
    z-index: 2; }
@media (min-width: 48em) {
    .flow__item.item6 .flow__item--wrapper {
        align-items: flex-end;
        padding-bottom: 100px; } }
.flow__item.item6 .flow__item--text {
    max-width: 487px; }
@media (min-width: 48em) {
    .flow--bottom {
        background: url(../images/item56.png) no-repeat center bottom;
        background-size: 1605px auto; } }

.break {
    width: 100%;
    height: auto;
    position: relative;
    background: var(--black); }
.break figure {
    width: 100%;
    height: auto;
    max-width: 1604px;
    margin: 0 auto; }
.break figure img {
    width: 100%;
    object-fit: cover;
    height: auto; }
.break__heading {
    width: 100%;
    height: 152px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: rgba(0, 0, 0, 0.7);
    position: absolute;
    left: 0;
    bottom: 0; }
@media only screen and (max-width: 767px) {
    .break__heading {
        height: auto;
        padding-top: 15px;
        padding-bottom: 15px; } }
.break__heading h2 {
    font-weight: 900;
    color: var(--white);
    font-size: 50px;
    line-height: 1; }
@media only screen and (max-width: 767px) {
    .break__heading h2 {
        font-size: 5vw; } }

.instagram {
    background: var(--black);
    padding-top: 60px;
    padding-bottom: 60px; }
@media only screen and (max-width: 767px) {
    .instagram {
        padding-top: 30px;
        padding-bottom: 30px; } }
.instagram__heading {
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center; }
.instagram__heading h2 {
    font-size: 40px;
    line-height: 1;
    color: var(--black);
    text-transform: uppercase;
    font-weight: 900; }
.instagram__list {
    display: flex; }
@media only screen and (max-width: 767px) {
    .instagram__list {
        flex-wrap: wrap; } }
.instagram__list a {
    width: 100%; }
@media only screen and (max-width: 767px) {
    .instagram__list a {
        max-width: 50%; } }

.access {
    background: #fff;
    padding-top: 40px;
    padding-bottom: 40px; }
.access h2 {
    margin-bottom: 20px; }
.access .map iframe {
    width: 100%;
    height: 400px; }

.about {
    background: #fff;
    padding-top: 40px;
    padding-bottom: 40px;
    color:var(--black);  }
.about .section--heading {
    padding-bottom: 20px;
    border-bottom: 2px solid var(--black);
    margin-bottom: 45px; }
.about__content {
    display: flex;
    justify-content: space-between;
    column-gap: 40px; }
@media only screen and (max-width: 767px) {
    .about__content {
        flex-direction: column; } }
.about__content ul li {
    font-size: 18px;
    display: flex; }
@media only screen and (max-width: 767px) {
    .about__content ul li {
        flex-direction: column; } }
.about__content ul li div {
    margin-bottom: 10px;
    line-height: 29px; }
.about__content ul li div:first-child {
    font-weight: bold;
    padding-left: 25px;
    width: 160px; }
@media only screen and (max-width: 767px) {
    .about__content ul li div:first-child {
        padding-left: 0;
        width: auto; } }
.about__content ul li div:first-child::before {
    content: "■";
    color: #D40012;
    font-weight: bold;
    font-size: 14px;
    margin-top: 5px;
    margin-right: 5px; }
.about__content ul li div:last-child {
    font-weight: 500; }
.about__content ul li.address__full {
    flex-direction: column; }
.about__content ul li.address__full > div {
    width: 100%;
    padding-left: 25px; }
@media only screen and (max-width: 767px) {
    .about__content ul li.address__full > div {
        padding-left: 0; } }
.about__content ul li.address__full > div span {
    display: block;
    color: #D40012;
    font-weight: bold; }
.about__text figure {
    margin-bottom: 70px;
    max-width: 480px; }
.about__text ul li > div {
    padding-left: 5px; }

.history {
    position: relative; }
.history .container {
    position: relative;
    z-index: 2; }
.history::after {
    content: "";
    width: calc(50% + 21px);
    height: 100%;
    right: 0;
    top: 0;
    position: absolute;
    z-index: 1;
    clip-path: polygon(-1px 0, 100% 0, 100% 100%, 219px 100%);
    background: var(--white); }
@media only screen and (max-width: 767px) {
    .history::after {
        display: none; } }
.history .bg {
    width: calc(50% + 20px);
    height: 100%;
    right: 0;
    top: 0;
    position: absolute;
    z-index: 2;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 220px 100%);
    background: var(--black); }
.history .bg::before {
    content: "";
    width: 100%;
    height: calc(100% + 2px);
    top: -1px;
    left: 0;
    position: absolute;
    background: var(--black);
    clip-path: polygon(1px 0, 100% 0, 100% 100%, 222px 100%); }
@media only screen and (max-width: 767px) {
    .history .bg {
        display: none; } }
.history .bg::after {
    content: "";
    width: 100%;
    height: 226px;
    position: absolute;
    left: 0;
    bottom: 0;
    border-top: 1px solid #fff; }
.history__title {
    font-size: 40px;
    line-height: 1;
    color: var(--white);
    padding-top: 25px;
    padding-bottom: 30px; }
.history__wrapper {
    display: flex;
    justify-content: space-between; }
@media only screen and (max-width: 767px) {
    .history__wrapper {
        flex-direction: column; } }
.history__content {
    display: flex;
    justify-content: space-between;
    color: var(--white); }
@media only screen and (max-width: 767px) {
    .history__content {
        flex-direction: column; } }
.history__content ul li {
    display: flex;
    font-size: 18px;
    line-height: 29px; }
.history__content ul li div:first-child {
    min-width: 110px;
    font-weight: bold; }
.history__content ul li div:last-child {
    font-weight: normal; }
.history .contact-box {
    width: 100%;
    max-width: 440px;
    color: var(--white);
    padding-left: 20px;
    margin-top: -76px; }
@media only screen and (max-width: 767px) {
    .history .contact-box {
        padding-left: 0;
        margin-top: initial;
        padding-bottom: 30px; } }
.history .contact-box__phone {
    min-height: 340px; }
@media only screen and (max-width: 767px) {
    .history .contact-box__phone {
        min-height: initial;
        margin-top: 30px; } }
.history .contact-box__phone h3 {
    color: var(--white);
    font-size: 36px;
    line-height: 1;
    text-transform: uppercase;
    font-weight: 900; }
.history .contact-box__phone > strong {
    font-weight: 900;
    color: #D40012;
    line-height: 1;
    text-transform: uppercase;
    font-size: 25px;
    margin-bottom: 10px;
    display: block; }
@media only screen and (max-width: 767px) {
    .history .contact-box__phone > strong {
        color: var(--white); } }
.history .contact-box__phone p {
    font-weight: 500;
    color: var(--white);
    font-size: 18px; }
.history .contact-box__tel {
    padding-left: 50px;
    white-space: nowrap; }
@media only screen and (max-width: 767px) {
    .history .contact-box__tel {
        padding-left: 0;
        white-space: initial; } }
.history .contact-box__tel strong {
    font-weight: 900;
    color: var(--white);
    font-size: 25px;
    text-transform: uppercase; }
.history .contact-box__tel h2 {
    font-size: 55px;
    font-weight: 900;
    color: #fff;
    line-height: 1; }
@media only screen and (max-width: 767px) {
    .history .contact-box__tel h2 {
        font-size: 30px;color:#fff; } }
.history .contact-box__form {
    min-height: 220px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    padding-left: 90px; }
@media only screen and (max-width: 767px) {
    .history .contact-box__form {
        padding-left: 0;
        min-height: initial;
        margin-top: 20px; } }
.history .contact-box__form figure {
    width: 68px;
    height: 47px;
    margin-bottom: 10px; }
.history .contact-box__form > strong {
    font-size: 22px;
    font-weight: 900;
    color: var(--white);
    line-height: 1;
    margin-bottom: 10px;
    text-align: center;
    display: block; }

.recruit-intro {
    text-align: center;
    padding: 45px 0 40px; }
@media only screen and (min-width: 992px) {
    .recruit-intro {
        padding: 45px 0 90px; } }
.recruit-intro h2 {
    font-size: 30px;
    line-height: 40px;
    color: var(--red);
    font-weight: 900;
    margin: 0 0 30px; }
@media only screen and (min-width: 768px) {
    .recruit-intro h2 {
        font-size: 50px;
        line-height: 58px; } }
.recruit-intro p {
    font-weight: 300; }
@media only screen and (min-width: 768px) {
    .recruit-intro p {
        font-size: 18px; } }
.recruit-intro__buttons {
    margin-top: 30px; }
@media only screen and (min-width: 768px) {
    .recruit-intro__buttons {
        margin-top: 40px; } }
.recruit-intro__buttons a {
    margin: 10px 15px; }
@media only screen and (min-width: 992px) {
    .recruit-intro__buttons a {
        margin: 15px 20px; } }

.row-info {
    padding: 20px 0 60px; }
@media only screen and (min-width: 992px) {
    .row-info {
        padding: 40px 0 115px; } }
.row-info__item {
    display: flex;
    padding: 26px 20px;
    color: var(--black); }
@media only screen and (min-width: 768px) {
    .row-info__item {
        padding: 26px 50px; } }
@media only screen and (min-width: 992px) {
    .row-info__item {
        padding: 26px 100px; } }
.row-info__item label {
    margin: 0;
    font-weight: 700;
    width: 105px;
    padding-left: 14px;
    position: relative;
    padding-right: 15px; }
@media only screen and (min-width: 768px) {
    .row-info__item label {
        width: 205px; } }
.row-info__item label::before {
    content: "";
    width: 10px;
    height: 10px;
    display: inline-block;
    background: var(--red);
    position: absolute;
    top: 8px;
    left: 0; }
.row-info__item > div {
    width: calc(100% - 105px);
    font-size: 18px;
    font-weight: 500; }
@media only screen and (min-width: 768px) {
    .row-info__item > div {
        width: calc(100% - 205px); } }
.row-info__item > div strong {
    font-weight: 900; }
.row-info__item > div p:last-of-type {
    margin-bottom: 0; }
.row-info__item > div ul {
    margin: 0 0 10px; }
.row-info__item > div ul li {
    padding-left: 7px;
    position: relative; }
.row-info__item > div ul li::before {
    content: "";
    display: block;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--red);
    position: absolute;
    top: 12px;
    left: 0; }
.row-info__item > div h3 {
    font-size: 23px;
    color: var(--red);
    margin: 0 0 5px;
    font-weight: 900; }
.row-info__item:nth-child(even) {
    background: url("../images/bg-caro.png") repeat 0 0; }
.row-info__button {
    margin-top: 15px;
    text-align: center; }
@media only screen and (min-width: 768px) {
    .row-info__button {
        margin-top: 30px; } }
@media only screen and (min-width: 992px) {
    .row-info__button {
        margin-top: 70px; } }

.mid-career {
    padding: 40px 0; }
@media only screen and (min-width: 768px) {
    .mid-career {
        padding: 80px 0; } }

.entry-form {
    text-align: center;
    padding-top: 45px;
    color: var(--black); }
@media only screen and (min-width: 992px) {
    .entry-form {
        margin-top: 120px;
        border-top: 2px solid var(--red); } }
.entry-form h2 {
    color: var(--red);
    font-size: 30px;
    margin: 0 0 20px;
    font-weight: 900; }
@media only screen and (min-width: 992px) {
    .entry-form h2 {
        font-size: 40px;
        margin: 0 0 45px; } }
.entry-form p {
    font-weight: 300; }
@media only screen and (min-width: 768px) {
    .entry-form p {
        font-size: 18px; } }
.entry-form__form {
    max-width: 824px;
    margin: 20px auto 60px; }
@media only screen and (min-width: 768px) {
    .entry-form__form {
        margin: 60px auto 90px; } }

.contact {
    text-align: center;
    padding: 60px 0 80px; }
@media only screen and (min-width: 768px) {
    .contact {
        padding: 60px 0 55px; } }
.contact h1 {
    font-size: 30px;
    font-weight: 900;
    color: var(--white);
    text-transform: uppercase;
    margin: 0 0 30px; }
@media only screen and (min-width: 768px) {
    .contact h1 {
        font-size: 40px;
        margin: 0 0 45px; } }
.contact h2 {
    font-size: 22px;
    font-weight: 900;
    text-transform: uppercase;
    color: var(--black);
    padding: 20px 0;
    margin: 0 0 40px; }
@media only screen and (min-width: 768px) {
    .contact h2 {
        font-size: 30px; } }
@media only screen and (min-width: 768px) {
    .contact p {
        font-size: 18px;
        line-height: 30px; } }
.contact__form {
    max-width: 825px;
    margin: 20px auto 0; }
@media only screen and (min-width: 768px) {
    .contact__form {
        margin: 90px auto 0; } }
.contact__form .checkbox__container {
    margin-right: 50px; }
@media only screen and (min-width: 768px) {
    .contact__form .checkbox__container {
        margin-right: 120px; } }
.contact__form .checkbox__container:last-child {
    margin-right: 0; }
.contact__form .form-row .form-col span {
    color: var(--black); }
.contact__form input[type="text"],
.contact__form input[type="email"],
.contact__form input[type="password"],
.contact__form input[type="phone"],
.contact__form input[type="search"],
.contact__form input[type="tel"],
.contact__form textarea,
.contact__form select {
    border-color: var(--white); }
@media only screen and (max-width: 767px) {
    .contact--confirm {
        padding: 60px 0 30px; } }
.contact--confirm .contact__form {
    margin: 30px auto 0; }
@media only screen and (min-width: 992px) {
    .contact--confirm .form-row {
        padding: 29px 0; } }
.contact--confirm .form-row .form-col label {
    margin: 0; }
@media only screen and (min-width: 768px) {
    .contact--confirm .form-row .form-col {
        display: flex;
        align-items: center; } }
.contact--confirm .form-submit {
    margin-top: 35px; }
.contact--confirm .form-submit button {
    margin: 10px; }
@media only screen and (min-width: 768px) {
    .contact--confirm .form-submit button {
        margin: 10px 20px; } }
@media only screen and (max-width: 767px) {
    .contact--confirm .form-submit button {
        min-width: 140px; } }

.contact-info {
    color: var(--white);
    text-align: center; }
@media only screen and (min-width: 768px) {
    .contact-info {
        font-size: 18px; } }
.contact-info .container {
    position: relative; }
.contact-info .container::before {
    content: "";
    background: url("../images/car.svg") no-repeat 100% 100% transparent;
    position: absolute;
    bottom: 100%;
    right: 15px;
    width: 135px;
    height: 47px; }
@media only screen and (min-width: 768px) {
    .contact-info .container::before {
        right: 0; } }
.contact-info__inner {
    max-width: 855px;
    margin: 0 auto;
    padding: 45px 0 35px; }
@media only screen and (min-width: 768px) {
    .contact-info p {
        line-height: 30px; } }
.contact-info hr {
    border: 0;
    border-top: 1px solid var(--white);
    margin: 25px 0; }
.contact-info h2 {
    color: var(--white);
    margin: 0;
    font-size: 28px;
    font-weight: 900; }
@media only screen and (min-width: 768px) {
    .contact-info h2 {
        font-size: 36px; } }
.contact-info h3 {
    color: var(--white);
    margin: 0;
    font-size: 40px;
    font-weight: 900; }
@media only screen and (min-width: 768px) {
    .contact-info h3 {
        font-size: 54px; } }
.contact-info h3 small {
    font-size: 20px;
    margin-right: 5px; }
@media only screen and (min-width: 768px) {
    .contact-info h3 small {
        font-size: 25px; } }

/** Section */
.banner-page {
    padding: 20px 0 0;
    position: relative;
    z-index: 1;
    background: var(--black); }
@media only screen and (min-width: 768px) {
    .banner-page {
        padding: 60px 0 0; } }
.banner-page figure {
    margin-bottom: 30px; }
@media only screen and (min-width: 768px) {
    .banner-page figure {
        position: absolute;
        right: -135px;
        top: 0;
        z-index: -1;
        margin-bottom: 0;
        max-width: 73%; } }
.banner-page .container {
    max-width: 100%; }
@media only screen and (min-width: 1200px) {
    .banner-page .container {
        padding: 0 30px; } }
@media only screen and (min-width: 1500px) {
    .banner-page .container {
        padding: 0 95px; } }
.banner-page h1 {
    color: var(--white);
    font-size: 45px;
    font-weight: 900;
    margin: 0;
    text-indent: -2px; }
@media only screen and (min-width: 768px) {
    .banner-page h1 {
        font-size: 65px;
        text-indent: -4px; } }
@media only screen and (min-width: 1200px) {
    .banner-page h1 {
        font-size: 90px;
        text-indent: -10px; } }
.banner-page h3 {
    color: var(--white);
    font-size: 20px;
    font-weight: 900;
    margin: 0; }
@media only screen and (min-width: 768px) {
    .banner-page h3 {
        font-size: 22px; } }
.banner-page h2 {
    font-size: 30px;
    line-height: 45px;
    font-weight: 900;
    color: var(--white);
    margin: 40px 0 0;
    text-indent: -16px; }
@media only screen and (min-width: 768px) {
    .banner-page h2 {
        font-size: 40px;
        line-height: 71px;
        margin: 45px 0 0;
        text-indent: -33px; } }
@media only screen and (min-width: 1200px) {
    .banner-page h2 {
        font-size: 55px;
        margin: 85px 0 0; } }
.banner-page p {
    color: var(--white);
    text-align: center;
    padding: 40px 0;
    margin: 0; }
@media only screen and (min-width: 768px) {
    .banner-page p {
        padding: 75px 0; } }
@media only screen and (min-width: 1200px) {
    .banner-page p {
        margin: 220px 0 0; } }
.banner-page.text-bottom {
    position: relative;
    min-height: 400px;
    padding: 40px 0;
    display: flex;
    align-items: flex-end; }
@media only screen and (min-width: 768px) {
    .banner-page.text-bottom {
        min-height: 550px; } }
@media only screen and (min-width: 992px) {
    .banner-page.text-bottom {
        min-height: 650px; } }
.banner-page.text-bottom h2 {
    text-indent: 0; }
.banner-page.text-bottom figure {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    right: auto;
    top: 0;
    z-index: -1;
    margin-bottom: 0;
    max-width: none;
    overflow: hidden; }
.banner-page.text-bottom figure img {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    object-fit: cover;
    z-index: 1; }
.banner-page.text-bottom h1,
.banner-page.text-bottom h3 {
    color: var(--red); }

.equipment-section__heading {
    text-align: center;
    padding: 21px 0;
    margin: 0 0 45px; }
@media only screen and (min-width: 768px) {
    .equipment-section__heading {
        margin: 0 0 60px; } }
.equipment-section__heading h2 {
    color: var(--black);
    font-size: 30px;
    font-weight: 900;
    margin: 0 0 2px; }
@media only screen and (min-width: 768px) {
    .equipment-section__heading h2 {
        font-size: 40px; } }
.equipment-section__heading h3 {
    color: var(--black);
    font-size: 16px;
    margin: 0;
    font-weight: 300; }

.equipment-section__images {
    margin: 0 0 30px; }
@media only screen and (min-width: 768px) {
    .equipment-section__images {
        display: flex;
        margin: 0 0 55px; } }
.equipment-section__images figure {
    border: 1px solid var(--black); }
@media only screen and (min-width: 768px) {
    .equipment-section__images figure {
        flex-basis: 0;
        flex-grow: 1; } }

.equipment-section__body > h2 {
    color: var(--white);
    font-size: 24px;
    font-weight: 900;
    border-bottom: 1px solid var(--white);
    text-align: center;
    padding: 15px 0;
    margin: 0 0 40px; }
@media only screen and (min-width: 768px) {
    .equipment-section__body > h2 {
        font-size: 30px; } }

.equipment-section__group {
    max-width: 824px;
    margin: 0 auto 35px; }
@media only screen and (min-width: 768px) {
    .equipment-section__group {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between; } }
.equipment-section__group--col {
    margin-bottom: 40px; }
@media only screen and (min-width: 768px) {
    .equipment-section__group--col {
        width: calc(50% - 30px); } }
@media only screen and (min-width: 992px) {
    .equipment-section__group--col {
        width: calc(50% - 45px); } }
.equipment-section__group--none-border .equipment-section__list ul {
    padding: 6px 0;
    border-bottom: 1px solid var(--white); }
.equipment-section__group--none-border .equipment-section__list ul li {
    border-bottom: 0;
    padding-top: 6px;
    padding-bottom: 6px;
    align-items: flex-end; }

.equipment-section__list > h3 {
    display: flex;
    align-items: center;
    color: var(--white);
    font-size: 18px;
    border-bottom: 1px solid var(--white);
    padding-bottom: 10px;
    margin: 0;
    letter-spacing: 1px;
    justify-content: space-between;
    position: relative;
    padding-left: 20px; }
@media only screen and (min-width: 768px) {
    .equipment-section__list > h3 {
        font-size: 20px; } }
.equipment-section__list > h3::before {
    content: "";
    width: 12px;
    height: 12px;
    display: inline-block;
    background: var(--red);
    position: absolute;
    top: 7px;
    left: 0; }
.equipment-section__list > h3 span {
    font-size: 18px;
    font-weight: 500;
    padding-left: 10px; }

@media only screen and (min-width: 768px) {
    .equipment-section__list > ul {
        font-size: 18px; } }

.equipment-section__list > ul li {
    border-bottom: 1px dashed var(--white);
    display: flex;
    justify-content: space-between;
    padding: 11px 8px 11px 33px;
    position: relative; }
.equipment-section__list > ul li::before {
    content: "";
    display: block;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--red);
    position: absolute;
    top: 23px;
    left: 24px; }
.equipment-section__list > ul li label {
    margin: 0; }

.contact-section {
    position: relative;
    z-index: 1;
    text-align: center;
    color: var(--white);
    margin-top: 20px; }
@media only screen and (min-width: 768px) {
    .contact-section {
        font-size: 18px;
        margin-top: 30px; } }
.contact-section::after {
    content: "";
    width: 100%;
    background: var(--white);
    height: 50%;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: -1; }
@media only screen and (min-width: 992px) {
    .contact-section::after {
        width: calc(50% + 75px);
        height: 100%;
        clip-path: polygon(150px 0, 100% 0, 100% 100%, 0% 100%); } }
.contact-section h2 {
    font-size: 24px;
    font-weight: 900;
    color: var(--white); }
@media only screen and (min-width: 768px) {
    .contact-section h2 {
        font-size: 30px; } }
.contact-section h3 {
    color: var(--white);
    font-size: 35px;
    font-weight: 900; }
@media only screen and (min-width: 768px) {
    .contact-section h3 {
        font-size: 54px; } }
.contact-section h3 small {
    font-size: 20px; }
@media only screen and (min-width: 768px) {
    .contact-section h3 small {
        font-size: 25px; } }
.contact-section hr {
    border: 0;
    border-top: 1px solid var(--white);
    margin: 25px 0; }
.contact-section svg {
    max-width: 68px;
    margin-bottom: 16px; }
@media only screen and (min-width: 992px) {
    .contact-section__inner {
        display: flex;
        justify-content: space-between; } }
.contact-section__inner > div {
    padding: 35px 0; }
@media only screen and (min-width: 992px) {
    .contact-section__inner > div {
        width: calc(50% - 30px); } }
@media only screen and (min-width: 1200px) {
    .contact-section__inner > div {
        width: calc(50% - 50px); } }
.contact-section__right {
    color: var(--black); }
.contact-section__right h2,
.contact-section__right h3 {
    color: var(--black); }
.contact-section__right hr {
    border-color: var(--black); }

.heading-cross {
    position: relative; }
@media only screen and (min-width: 768px) {
    .heading-cross::after {
        content: "";
        width: 20vw;
        position: absolute;
        height: calc(100% - 5px);
        bottom: 0;
        right: 0;
        background: var(--white); } }
@media only screen and (min-width: 992px) {
    .heading-cross::after {
        width: 30vw; } }
.heading-cross h2 {
    font-size: 25px;
    font-weight: 900;
    color: var(--white);
    margin: 0; }
@media only screen and (min-width: 768px) {
    .heading-cross h2 {
        font-size: 30px; } }
@media only screen and (min-width: 992px) {
    .heading-cross h2 {
        font-size: 41px; } }
@media only screen and (min-width: 1200px) {
    .heading-cross h2 {
        white-space: nowrap; } }
.heading-cross p {
    font-weight: 500;
    font-size: 18px;
    margin: 0;
    color: var(--white); }
@media only screen and (min-width: 768px) {
    .heading-cross__inner {
        display: flex; } }
@media only screen and (max-width: 768px) {
    .heading-cross__inner {
        padding: 20px 0; } }
@media only screen and (min-width: 768px) {
    .heading-cross__left {
        flex-basis: 0;
        padding: 17px 0; } }
.heading-cross__right {
    position: relative;
    z-index: 1; }
@media only screen and (min-width: 768px) {
    .heading-cross__right {
        flex-grow: 1;
        clip-path: polygon(97px 0, 100% 0, 100% 100%, 0% 100%);
        display: flex;
        align-items: center;
        padding-left: 130px;
        background: var(--white);
        bottom: -1px;
        margin-top: 4px; } }
@media only screen and (min-width: 768px) {
    .heading-cross__right p {
        color: var(--black); } }

html #wpadminbar {
    position: fixed;
}
ul#breadcrumbs{padding:10px 0;list-style:none;display:flex;align-items:center;border-bottom:1px solid #fff;margin-bottom:50px;}
ul#breadcrumbs li{color:#fff;text-transform:uppercase;}
ul#breadcrumbs li.separator{margin:0 0 0 5px;}
ul#breadcrumbs li a{color:#fff;text-transform:uppercase;}

a.gotop {
    position: fixed;
    right: 20px;
    /*リキャプチャを入れた関係で50→80に*/
    bottom: 80px;
    z-index: 99999;
}
.article-detail {
    padding: 60px 0 55px;
}
.article-detail h1 {
    font-size: 40px;
    margin: 0 0 45px;
    font-weight: 900;
    color: var(--white);
    text-transform: uppercase;
    text-align:center;
}
.article-content{min-height:50vh;}
#new-graduate,#mid-career,#part{margin-bottom:120px;}
.admin-bar #new-graduate,.admin-bar #mid-career, .admin-bar #part{margin-bottom:152px;}
#page{padding-top:30px;}
.page__title {
    text-transform: uppercase;
    width: 100%;
    padding: 25px 0;
    display: flex;
    justify-content: center;
    flex-direction:column;
    align-items: center;
    background: linear-gradient(90deg, #960012 0%, #da0012 50%, #960012 100%);
}
.page__title h2 {
    font-size: 40px;
    line-height: 1;
    color: var(--black);
    text-transform: uppercase;
    text-align: center;
    font-weight: 900;
    width:100%;
}
.page__title h3 {
    font-size: 20px;
    line-height: 1;
    color: var(--black);
    text-align: center;
    font-weight: 900;
    width:100%;
}
.privacy-policy #content{padding:0 0 20px;color:#fff;border-bottom:1px solid #fff;width:80%;margin:0 auto 50px;}
.privacy-policy #content h2.title{color:#fff;font-size:25px;border-bottom:1px solid #fff;margin-bottom:20px;padding-bottom:5px;}
.privacy-policy #content strong{color:#DA0012;}
.wpcf7-back{margin-left:20px;}
.wpcf7-radio .wpcf7-list-item{margin-left:0;}
.wpcf7-radio .wpcf7-list-item label{display: block;
                                    position: relative;
                                    padding-left: 35px;
                                    margin: 0 120px 0 0;
                                    cursor: pointer;
                                    -webkit-user-select: none;
                                    -moz-user-select: none;
                                    -ms-user-select: none;
                                    user-select: none;
                                    font-size: 18px;
                                    display: inline-block;}
.wpcf7-radio .wpcf7-list-item label.last {
    margin-right: 0;
}
.wpcf7-radio .wpcf7-list-item label input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}
.wpcf7-radio .wpcf7-list-item label .wpcf7-list-item-label::before {
    position: absolute;
    top: 0;
    left: 0;
    height: 24px;
    width: 24px;
    border-radius: 50%;
    background: none;
    border: 1px solid #b2b2b2;
}
.wpcf7-radio .wpcf7-list-item label input:checked ~ .wpcf7-list-item-label::after {
    display: block;
}
.wpcf7-radio .wpcf7-list-item label .wpcf7-list-item-label::after {
    content: "";
    position: absolute;
    display: none;
    left: 4px;
    top: 4px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: linear-gradient(90deg, #960012 0%, #da0012 50%, #960012 100%);
}

#news-content{display: flex;flex-wrap:wrap;justify-content:space-between;}
#news-content #contentleft{width:170px;}
#news-content #contentright{width:calc(100% - 200px);}
#news-content #contentleft .sidebar-header-widget{color:#DA0012;font-weight:600;margin-bottom:30px;}
#news-content #contentleft .sidebar-contain-widget ul{padding:0;list-style:none;}
#news-content #contentleft .sidebar-contain-widget ul li{padding:0 0 10px 0;margin-bottom:10px;display:flex;justify-content: space-between;color:#fff;border-bottom:1px solid #fff;}
#news-content #contentleft .sidebar-contain-widget ul li a{background:url(../images/bg_archive.png) no-repeat 0 4px;position:relative;color:#fff;padding:0 25px 0 30px;}
#news-content #contentleft .sidebar-contain-widget ul li a span{position:absolute;right:0;}
ul#pnews{display:flex;flex-direction:column;padding:0;list-style:none;}
ul#pnews li.particle{margin-bottom:25px;}
ul#pnews li.particle .pheader .ptitle{display:flex;align-items: center;border-bottom:1px solid #fff;margin-bottom:20px;line-height:30px;}
ul#pnews li.particle .pheader .ptitle .pdate{color:#DA0012;margin-right:20px;font-weight:600;}
ul#pnews li.particle .pheader .ptitle .title{color:#fff;font-size:18px;margin:0;width:100%;}
ul#pnews li.particle .detail{display:flex;flex-wrap:wrap;justify-content:space-between;}
ul#pnews li.particle .detail .pimg{width:calc(50% - 20px);height:200px;}
ul#pnews li.particle .detail .pimg img{object-fit:cover;width:100%;height:100%;}
ul#pnews li.particle .detail .pcontent{width:50%;color:#fff;}
ul#pnews li.particle .detail .pcontent p.more{text-align:right;}
.paging{display:flex;flex-wrap:wrap;justify-content:center;color:#fff;width: 100%;border-top:1px solid #fff;padding-top:15px;}
.paging .page-numbers{color:#fff;padding:3px 10px;border:1px solid #fff;margin:0 5px;}
.paging .page-numbers.current, .paging .page-numbers:hover{border:1px solid #DA0012;}
.news_detail .pheader {display:flex;flex-direction:column;border-bottom:1px solid #fff;margin-bottom:20px;line-height:30px;}
.news_detail .pheader .pdate{color:#DA0012;margin-right:20px;font-weight:600;margin-bottom:10px;}
.news_detail .pheader .title{color:#fff;font-size:18px;margin:0 0 10px;}
.news_detail .pheader .detail{border-bottom:1px solid #fff;}
.news_detail .navigation{display:flex;flex-wrap:wrap;justify-content:center;}
.news_detail .navigation .pagination-previous {font-size:0px;}
.news_detail .navigation .pagination-previous a{font-size:0px;background:url(../images/btn-old.png);width:114px;height:40px;display: block;}
.news_detail .navigation .pagination-next {font-size:0px;}
.news_detail .navigation .pagination-next a{font-size:0px;background:url(../images/btn-new.png);width:114px;height:40px;display: block;}
.works__filter ul li.active a {
    background: #DA0012;
}
#works__gallery .works__gallery{display:none;}
#works__gallery .works__gallery.active{display:flex;}
.works__gallery a figure {
    width: 100%;
    height: 310px;
	position:relative;
}
.works__gallery a figure img{
    width: 100%;
    height: 100%;
    object-fit:cover;
}
.works__gallery a h3{position:absolute;bottom:0;left:0;width:100%;background: linear-gradient(90deg, #960012 0%, #da0012 50%, #960012 100%);color:#fff;text-align:center;padding:15px;margin:0;font-size:20px;}
.slick-dots li button{min-width:unset;}
.header-top{background: linear-gradient(90deg, #960012 0%, #da0012 50%, #960012 100%);text-align:center;padding:20px;margin-top:50px;}
.header-top h1 {color: #000;margin: 0;text-transform: uppercase;}
.equipment .header-top h1 {margin: 0;text-transform: uppercase;}
.equipment .header-top h3 {color: var(--black);font-size: 16px;margin: 0;font-weight: 300;}
.equipment .banner-page  {
  padding: 0;
}.equipment .banner-page .container {
  padding: 0;
}
.equipment .banner-page p {margin: 0;}
.flogo{color:#fff;font-size:29px;font-weight:700;display: flex;}
.page-id-35 .header-top h1 {
  color: #fff;
}
@media only screen and (max-width: 767px) {
    .header .container {
        width: 100%;
        margin: 0;
    }
    .admin-bar .header {
        top: 46px;
    }
    .article-detail h1 {
        font-size: 30px;
        margin: 0 0 30px;
    }
    .privacy-policy #content{width:96%;margin:0 auto 50px;}
    .wpcf7-back{margin-top:20px;margin-left:0;}
    #news-content #contentleft{width:100%;order:2;margin-top:30px;}
    #news-content #contentright{width:100%;margin-bottom:20px;}
    ul#pnews li.particle .detail .pimg{width:100%;height:auto;margin-bottom:15px;}
    ul#pnews li.particle .detail .pcontent{width:100%;}
    .works__filter ul li {
        max-width: 100% !important;
        width: 100% !important;
        margin-bottom: 10px;
        margin-left: 0 !important;
    }
    .works__gallery a figure {
        width: 100%;
        height: 150px;
    }
}
@media screen and (min-width: 1024px){   
    .pcbr { display:block; }
    .spbr { display:none; }
}
@media screen and (max-width: 1024px){   
    .pcbr { display:none; }
    .spbr { display:block; }
}
@media (max-width: 575px){
    a:active{
        color: #666 !important;
    }
}
.custom-wpcf7c-confirmed .form-row .form-input input[type="text"], .custom-wpcf7c-confirmed .form-row .form-input input[type="email"], .custom-wpcf7c-confirmed .form-row .form-input input[type="password"], .custom-wpcf7c-confirmed .form-row .form-input input[type="phone"], .custom-wpcf7c-confirmed .form-row .form-input input[type="search"], .custom-wpcf7c-confirmed .form-row .form-input input[type="tel"], .custom-wpcf7c-confirmed .form-row .form-input textarea{
  background: #000 !important;
  border: 0 !important;
  color: #fff !important;
}
body .custom-wpcf7c-confirmed input:-internal-autofill-selected, body .custom-wpcf7c-confirmed input:-webkit-autofill  {
  background: #000 !important;
  border: 0 !important;
  color: #fff !important;
}
.custom-wpcf7c-confirmed .form_text{display:none;}