* {
    margin: 0;
    padding: 0;
    box-sizing: border-box
}

html,
body {
    font-family: 'Zen Kaku Gothic Antique', sans-serif;
    background-color: #fff;
    overflow-x: hidden;
    position: relative
}

p {
    line-height: 1.8em
}

a {
    text-decoration: none
}

a:visited,
a:hover,
a:active {
    color: #333333
}

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

.header-container {
    transition: background 0.3s ease
}

.header-container.scrolled {
    background: #091e9b;
    border-bottom: 1px solid #2aace3
}

.subpage .header-container {
    background: #fff
}

.subpage .header-container.scrolled {
    background: #fff;
    border-bottom: 1px solid #2aace3
}

header {
    position: fixed;
    top: 0px;
    z-index: 9999;
    width: 100%
}

header .header-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0px;
    background: transparent;
    flex-wrap: nowrap
}

header .header-container .logoarea {
    display: flex;
    flex-wrap: nowrap;
    padding-left: 70px
}

header .header-container .logoarea .logo {
    height: 50px
}

header .header-container .logoarea .la_txt {
    color: #fff;
    font-weight: bold;
    font-size: 14px;
    display: flex;
    padding: 0 20px;
    justify-content: flex-start;
    align-items: center;
    text-align: left;
    line-height: 1.6em;
    text-shadow: 2px 2px 4px rgba(53, 52, 52, 0.5)
}

header .header-container .header-right {
    /* default: let responsive.css control width on small screens */
    display: flex;
    justify-content: space-between
}

@media screen and (min-width: 992px) {
    header .header-container .header-right {
        width: 800px;
    }
}

header .header-container .header-right nav {
    width: 100%;
    max-width: 550px;
    padding: 30px;
    display: block
}

header .header-container .header-right nav ul {
    list-style: none;
    display: flex;
    align-items: center;
    gap: 40px;
    position: relative
}

header .header-container .header-right nav li {
    position: relative
}

header .header-container .header-right nav a {
    text-decoration: none;
    color: #fff;
    font-weight: normal
}

header .header-container .header-right nav .submenu {
    display: block;
    visibility: hidden;
    opacity: 0;
    position: absolute;
    top: 100%;
    left: 0;
    background-color: #fff;
    list-style: none;
    padding: 4px 0;
    border-radius: 10px;
    border: 2px solid #3FA9F5;
    box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.3);
    width: max-content;
    transition: visibility 0s 0.3s, opacity 0.3s ease-in-out
}

header .header-container .header-right nav li:hover .submenu {
    visibility: visible;
    opacity: 1;
    transition: visibility 0s 0s, opacity 0.3s ease-in-out
}

header .header-container .header-right nav .submenu li {
    padding: 5px 20px;
    color: #091E9B;
    display: flex;
    align-items: center
}

header .header-container .header-right nav .submenu li a {
    color: #091E9B;
    display: flex;
    align-items: center;
    text-decoration: none
}

header .header-container .header-right nav .submenu .arrow {
    margin-right: 10px;
    color: #3FA9F5;
    font-size: 18px
}

header .header-container .header-right .contact-info {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    width: 250px
}

header .header-container .header-right .contact-info img {
    display: block
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(-10px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

section.kanren-section {
    margin: 100px 0;
    background: url(img/home/kanren_bg.jpg) no-repeat center
}

section.kanren-section div.wrap {
    text-align: center;
    color: #fff;
    padding: 50px 0 100px 0
}

section.kanren-section div.wrap h4 {
    font-weight: normal;
    margin-bottom: 20px;
    border-left: 1px solid #fff;
    border-right: 1px solid #fff;
    display: inline-block;
    padding: 3px 10px 4px 10px;
    line-height: 1em;
    vertical-align: center
}

footer .footer-container {
    background-color: #091E9B;
    color: #fff;
    padding: 100px 10% 50px 10%
}

footer .footer-container h2.title {
    color: #fff
}

footer .footer-container div.wrap {
    padding: 0px 30px
}

footer .footer-container div.wrap div.topline {
    display: flex;
    align-items: center;
    width: 100%;
    border-bottom: 1px solid #3FA9F5;
    padding: 80px 0 120px 0
}

footer .footer-container div.wrap div.topline div.txt {
    width: 32%;
    padding-right: 84px
}

footer .footer-container div.wrap div.topline div.txt p.sub-title {
    margin-bottom: 40px
}

footer .footer-container div.wrap div.topline div.banner {
    width: 68%;
    display: flex;
    justify-content: flex-end
}

footer .footer-container div.wrap div.topline div.banner .tel,
footer .footer-container div.wrap div.topline div.banner .mail {
    display: block
}

footer .footer-container div.wrap div.topline div.banner .tel {
    margin: 0 30px 0 0
}

footer .footer-container div.wrap div.topline div.banner .mail {
    margin: 0
}

footer .footer-container div.wrap div.bottomline {
    padding: 100px 0;
    display: flex;
    justify-content: space-between
}

footer .footer-container div.wrap div.bottomline div.banner {
    width: 42%;
    display: flex
}

footer .footer-container div.wrap div.bottomline div.banner div.txt {
    padding-left: 40px
}

footer .footer-container div.wrap div.bottomline div.banner div.txt p.company_name {
    font-weight: bold
}

footer .footer-container div.wrap div.bottomline div.banner div.txt p a {
    color: #fff
}

footer .footer-container div.wrap div.bottomline div.menu {
    width: 55%;
    display: flex;
    justify-content: space-between
}

footer .footer-container div.wrap div.bottomline div.menu div.box {
    padding: 0px
}

footer .footer-container div.wrap div.bottomline div.menu div.box ul {
    list-style: none;
    padding: 0 10px;
    font-size: 14px
}

footer .footer-container div.wrap div.bottomline div.menu div.box ul li {
    margin-bottom: 20px
}

footer .footer-container div.wrap div.bottomline div.menu div.box ul li a {
    color: #fff
}

footer .footer-container div.wrap div.bottomline div.menu div.box ul li ul {
    list-style: disc;
    padding-left: 20px;
    padding-top: 20px
}

footer .footer-container div.wrap div.bottomline div.menu div.box ul li ul li {
    margin-bottom: 10px
}

footer .footer-container div.wrap div.bottomline div.menu div.box ul li ul li a {
    color: #fff
}

footer .footer-container div.wrap .copyright {
    text-align: center;
    font-size: 16px;
    color: #fff
}

h2.title {
    font-size: 48px;
    font-weight: normal;
    text-indent: -1em
}

h2.title:before {
    content: '・';
    color: #3FA9F5
}

p.sub-title {
    margin-bottom: 30px
}

.toppage .hero-section {
    width: 100%;
    position: relative;
    text-align: center;
    padding-left: 120px;
    background-color: #091E9B;
    overflow: hidden
}

.toppage .hero-section .hero-bg {
    width: 100%;
    object-fit: cover
}

.toppage .hero-section .hero-text {
    position: absolute;
    left: 160px;
    top: 40%
}

.toppage .hero-section .power-text {
    position: absolute;
    bottom: -3px;
    left: 70px;
    opacity: 0.7
}

.toppage .hero-section .scroll-icon {
    position: absolute;
    bottom: 10px;
    left: 80px;
    transform: translateX(-50%)
}

.toppage section.about-us-section {
    background-color: #091E9B;
    color: #fff
}

.toppage section.about-us-section div.wrap div.top-line {
    padding: 100px 0 10px 0;
    display: flex;
    width: 95%;
    max-width: 1444px;
    margin: auto;
}

.toppage section.about-us-section div.wrap div.top-line div.text {
    width: 50%;
    padding: 100px 20px 0 100px
}

.toppage section.about-us-section div.wrap div.top-line div.text h3.oomidashi {
    font-size: 46px;
    font-weight: normal;
    margin-bottom: 70px
}

.toppage section.about-us-section div.wrap div.top-line div.thumb {
    width: 50%;
    text-align: right
}

.toppage section.about-us-section div.bottom-line {
    overflow: hidden
}

.toppage section.about-us-section div.bottom-line object {
    max-width: 101%;
    transform: translate(-2px, 10px)
}

.toppage section.service-section {
    background: #fff
}

.toppage section.service-section div.wrap {
    padding: 150px 0
}

.toppage section.service-section div.wrap h2.title {
    color: #091E9B;
    text-align: center
}

.toppage section.service-section div.wrap p.sub-title {
    color: #091E9B;
    margin-bottom: 80px;
    text-align: center
}

.toppage section.service-section div.wrap div.list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.toppage section.service-section div.wrap div.list a.box {
    width: 33%;
    border: 1px solid #E9EFF4
}

.toppage section.service-section div.wrap div.viewall {
    padding: 50px;
    text-align: center
}

.toppage section.company-section {
    background: url(img/home/works_bg.jpg) no-repeat
}

.toppage section.company-section div.wrap {
    padding: 260px 10vw 130px 10vw
}

.toppage section.company-section div.wrap div.banner-area {
    max-width: 700px;
    padding: 50px 120px;
    background-color: #091E9B;
    color: #fff
}

.toppage section.company-section div.wrap div.banner-area p.sub-title {
    margin-bottom: 30px
}

.toppage section.company-section div.wrap div.banner-area .desc {
    margin-bottom: 60px
}

.toppage section.company-section div.wrap div.banner-area .view_more img {
    border: 1px solid #fff
}

.toppage section.company-section div.wrap div.works-area {
    margin: 400px 0 0 0;
    padding: 100px 20px 100px 20px;
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    background-color: #fff
}

.toppage section.company-section div.wrap div.works-area div.title-area {
    width: 300px;
    color: #091E9B;
    padding: 0 20px
}

.toppage section.company-section div.wrap div.works-area div.thumb-area {
    width: 100%;
    max-width: 920px
}

.toppage section.company-section div.wrap div.works-area div.thumb-area div.fld {
    justify-content: space-between;
    display: flex;
    flex-wrap: nowrap;
    gap: 25px;
    width: 100%;
    margin-bottom: 50px
}

.toppage section.company-section div.wrap div.works-area div.thumb-area div.fld div.box a {
    color: #000
}

.toppage section.company-section div.wrap div.works-area div.thumb-area div.viewall {
    text-align: center
}

.toppage section.recruit-section {
    margin-top: 100px;
    position: relative
}

.toppage section.recruit-section .recruit_banner {
    text-align: right
}

.toppage section.recruit-section .recruit_banner img {
    width: 90%
}

.toppage section.recruit-section div.wrap {
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100%;
    display: flex;
    justify-content: flex-end
}

.toppage section.recruit-section div.wrap div.txt_area {
    color: #fff;
    width: 35%;
    padding: 150px 10px
}

.toppage section.recruit-section div.wrap div.txt_area p.sub-title {
    margin-bottom: 50px
}

.toppage section.recruit-section div.wrap div.txt_area p.desc {
    margin-bottom: 50px
}

.toppage section.recruit-section .sq {
    position: absolute;
    bottom: -200px;
    left: 0px;
    z-index: -1
}

.subpage {
    padding-top: 120px
}

.subpage header .header-container .header-right nav a {
    color: #091E9B
}

.subpage .contact-info {
    border: 1px solid #091E9B
}

.subpage header .header-container .logoarea .la_txt {
    color: #091E9B;
    text-shadow: 2px 2px 4px rgba(57, 66, 168, 0.5)
}

.subpage section.hero-section {
    position: relative
}

.subpage section.hero-section div.hero-text {
    position: absolute;
    transform: translate(-50%, -50%);
    top: 50%;
    left: 50%;
    color: #fff;
    text-align: center
}

.subpage section.hero-section div.hero-text h1 {
    font-size: 60px
}

.subpage section.hero-section div.hero-text p.h1-sub {
    font-size: 60px;
    font-size: 21px
}

.subpage .wrap {
    width: 100%;
    max-width: 1260px;
    padding: 50px 30px;
    margin: auto
}

.subpage h2.title {
    color: #091E9B
}

.subpage p.sub-title {
    color: #091E9B
}

.hide_td {
    width: 60px;
    border: none !important
}

.view_td {
    color: #333
}

.company_page table {
    border-collapse: collapse;
    width: 600px;
    text-align: left;
    width: 100%;
    margin-bottom: 100px
}

.company_page table th,
.company_page table td {
    padding: 30px 0;
    border-bottom: 2px solid #ddd;
    vertical-align: top
}

.company_page table th {
    font-weight: bold;
    color: #000;
    width: 250px;
    text-align: left;
    border-bottom: 3px solid #091E9B
}

.company_page .message-section {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: #fff
}

.company_page .message-section .wrap {
    display: flex;
    align-items: center;
    justify-content: space-between
}

.company_page .message-section .txt_area {
    width: 60%
}

.company_page .message-section .txt_area h2.title {
    color: #091E9B
}

.company_page .message-section .txt_area p.sub-title {
    font-size: 18px;
    margin-bottom: 50px;
    color: #091E9B
}

.company_page .message-section .txt_area h3 {
    font-size: 28px;
    font-weight: bold;
    color: #3754BF;
    margin-bottom: 15px
}

.company_page .message-section .txt_area p.h3-sub {
    font-size: 16px;
    color: #3FA9F5;
    margin-bottom: 20px
}

.company_page .message-section .txt_area p.desc {
    font-size: 16px;
    line-height: 1.8;
    color: #333
}

.company_page .message-section .txt_area .desc2 {
    text-align: right;
    font-weight: normal
}

.company_page .message-section .thumb {
    width: 35%;
    text-align: right;
    padding-top: 50px
}

.company_page .message-section .thumb img {
    max-width: 100%;
    height: auto;
    border-radius: 0px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1)
}

.company_page .title_area {
    background-color: #E9EFF4
}

.company_page .title_area .sub-title {
    margin-bottom: 0px
}

.company_page .information-section {
    position: relative
}

.company_page .information-section .icon {
    position: absolute;
    right: 50px;
    top: 80px
}

.company_page .information-section .sub-title {
    font-size: 18px;
    margin-bottom: 30px
}

.company_page .information-section .info_content {
    padding: 100px 0px
}

.company_page .information-section .map_area {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
    padding: 0px
}

.company_page .information-section .map_area .map {
    flex: 1;
    justify-content: flex-start;
    text-align: left;
    background-color: #E9EFF4;
    padding: 40px;
    width: 100%;
    max-width: 880px
}

.company_page .information-section .map_area .map iframe {
    width: 100%;
    height: 245px;
    border: 0
}

.company_page .information-section .map_area .map .company_name {
    font-size: 16px;
    font-weight: bold;
    margin-top: 10px
}

.company_page .information-section .map_area .map .company_name a {
    text-decoration: none;
    color: #003399
}

.company_page .information-section .map_area .map .company_name a:hover {
    text-decoration: underline
}

.company_page .information-section .map_area .map .company_address {
    font-size: 16px;
    color: #1A1A1A;
    margin-top: 0px
}

.company_page .information-section .map_area .company_img {
    flex: 1;
    max-width: 314px;
    display: flex;
    justify-content: flex-end
}

.company_page .information-section .map_area .company_img img {
    width: 100%;
    height: auto;
    border-radius: 0px;
    box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.1);
    object-fit: cover
}

.service_page .label_area {
    position: relative
}

.service_page .label_area .number {
    font-size: 40px;
    color: #3FA9F5;
    z-index: 2;
    position: relative
}

.service_page .label_area h2 {
    display: inline-block;
    padding-left: 20px;
    font-size: 25px;
    color: #091E9B;
    position: relative;
    z-index: 2
}

.service_page .label_area .under_line {
    width: 1000px;
    height: 25px;
    background-color: #fff;
    display: block;
    top: 70%;
    position: absolute;
    left: -800px;
    bottom: 0px
}

.service_page .wrap {
    max-width: 1500px
}

.service_page .content {
    background-color: #fff;
    padding: 0px 20px 50px 20px;
    text-align: center;
    margin: 50px 0 100px 0
}

.service_page .content h3 {
    color: #fff;
    font-size: 22px;
    background-color: #091E9B;
    padding: 14px;
    text-align: center;
    max-width: 600px;
    margin: auto;
    transform: translate(0, -50%);
    margin-bottom: 60px
}

.service_page .content .desc {
    margin-bottom: 20px
}

.service_page .content .photo_area {
    display: flex;
    justify-content: space-between;
    gap: 50px;
    max-width: 1000px;
    margin:0 auto 100px auto;
}

.service_page .content .photo_area .box {
    width: 100%;
}

.service_page .content .sample_list {
    border: 4px solid #3FA9F5;
    border-radius: 20px;
    padding: 0 20px 50px 20px;
    margin: 100px auto;
    max-width: 1000px
}

.service_page .content .sample_list .label {
    padding: 0 30px;
    transform: translate(0, -50%);
    background-color: #fff;
    display: inline-block
}

.service_page .content .sample_list ul {
    max-width: 600px;
    margin: 0 auto;
    text-align: left;
    font-size: 20px;
    color: #091E9B;
    padding-left: 1em
}

.service_page .content .sample_list ul li {
    padding: 10px 0
}

.service_page .content .sample_list ul li::marker {
    color: #3FA9F5
}

.service_page main {
    background-color: #E9EFF4
}

.service_page .desc_area {
    max-width: 1200px;
    margin: auto
}

.service_page .desc_area p {
    max-width: 700px;
    padding: 100px 0;
    margin: auto
}

.service_page section.seigyo-section div.wrap div.desc_area {
    background: url(img/service/01_icon.svg) no-repeat left center
}

.service_page section.software-section div.wrap div.desc_area {
    background: url(img/service/02_icon.svg) no-repeat left center
}

.service_page section.denki-section div.wrap div.desc_area {
    background: url(img/service/03_icon.svg) no-repeat left center
}

.service_page section.denki-section div.wrap div.content .mark_area {
    position: relative
}

.service_page section.denki-section div.wrap div.content .mark_area img.illust {
    position: absolute;
    right: 10px;
    bottom: 0px
}

.service_page section.monozukuri-section {
    background: url(img/service/monozukuri_bg.jpg) no-repeat center center;
    background-size: cover;
    position: relative
}

.service_page section.monozukuri-section div.wrap {
    min-height: 100vh;
    position: relative
}

.service_page section.monozukuri-section div.wrap div.txt_area {
    position: absolute;
    right: 30px;
    top: 50%;
    transform: translate(0, -50%);
    max-width: 600px;
    height: auto;
    display: block;
    padding: 50px 80px;
    border-top: 5px solid #091E9B;
    background-color: #fff;
    text-align: center
}

.service_page section.monozukuri-section div.wrap div.txt_area p.label {
    text-align: center;
    margin-bottom: 10px
}

.service_page section.monozukuri-section div.wrap div.txt_area p {
    text-align: left;
    line-height: 2em
}

.works_page main {
    background-color: #E9EFF4
}

.works_page .area .label_area {
    position: relative;
    text-align: center
}

.works_page .area .label_area .under_line {
    height: 25px;
    width: 200px;
    background-color: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, 0)
}

.works_page .area .label_area h2 {
    font-size: 25px;
    color: #091E9B;
    position: relative
}

.works_page .area .fld {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    max-width: 1200px;
    gap: 50px;
    border-bottom: 1px solid #fff;
    padding: 80px 0
}

.works_page .area .fld .box {
    max-width: 366px
}

.works_page .area .fld .box img {
    margin-bottom: 10px
}

.works_page #image-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(25, 38, 99, 0.9);
    justify-content: center;
    align-items: center;
    opacity: 0;
    transition: opacity 0.3s ease
}

.works_page .modal-content {
    position: relative;
    text-align: center;
    padding: 80px 10% 0 10%;
    border: 1px solid #fff
}

.works_page .modal-image {
    width: 100%;
    max-width: 530px
}

.works_page .close-btn {
    display: block;
    margin: 15px auto 0;
    cursor: pointer;
    width: 189px;
    transform: translate(0, 50%)
}

.works_page .nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    font-size: 50px;
    font-weight: normal;
    color: white;
    cursor: pointer;
    padding: 10px
}

.works_page .nav {
    width: 20px;
    height: 20px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    display: inline-block;
    padding: 5px
}

.works_page .prev {
    transform: rotate(135deg);
    position: absolute;
    left: 20px
}

.works_page .next {
    transform: rotate(-45deg);
    position: absolute;
    right: 20px
}

.works_page .modal-label {
    color: #fff;
    text-align: left;
    padding: 10px 0
}

.recruit_page main {
    background-color: #fff
}

.recruit_page .title_area {
    background-color: #E9EFF4
}

.recruit_page .title_area .title {
    color: #091E9B;
    font-size: 48px;
    font-weight: normal;
    text-indent: -1em
}

.recruit_page .title_area .title:before {
    content: '・';
    color: #3FA9F5
}

.recruit_page .title_area .sub-title {
    color: #091E9B;
    margin-bottom: 30px
}

.recruit_page .staff-section .staff_content {
    margin-bottom: 50px
}

.recruit_page .staff-section .interview-box {
    margin-bottom: 60px;
    padding-bottom: 40px
}

.recruit_page .staff-section .interview-header {
    background-color: #E9EFF4;
    max-width: 970px;
    margin: auto;
    display: flex;
    padding: 60px 70px;
    position: relative;
    margin-bottom: 80px;
    align-items: flex-end
}

.recruit_page .staff-section .interview-header::before {
    content: "interview";
    position: absolute;
    top: 56px;
    left: 70px;
    color: #091E9B;
    font-size: 25px;
    letter-spacing: 1px
}

.recruit_page .staff-section .interview-header::after {
    content: "";
    position: absolute;
    top: 82px;
    left: -40px;
    width: 100px;
    height: 1px;
    background-color: #091E9B
}

.recruit_page .staff-section .interview-info {
    width: 40%;
    padding-right: 30px
}

.recruit_page .staff-section .interview-info .staff-name {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 10px
}

.recruit_page .staff-section .interview-info .department {
    font-size: 18px;
    color: #333;
    padding: 4px 30px;
    background-color: #ffffff;
    display: inline-block
}

.recruit_page .staff-section .staff-photo {
    background-color: #999;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    max-width: 385px
}

.recruit_page .staff-section .staff-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.recruit_page .staff-section .interview-box:nth-child(3) .staff-photo {
    max-height: calc(100% - 2px);
    overflow: hidden;
}

.recruit_page .staff-section .interview-box:nth-child(3) .staff-photo img {
    width: 100%;
    height: auto;
    display: block;
    margin-top: -2px;
    margin-bottom: -2px;
}


.recruit_page .staff-section .qa-list {
    padding: 0 50px;
    max-width: 900px;
    margin: 0px auto
}

.recruit_page .staff-section .under_thumb {
    padding: 100px 0;
    max-width: 900px;
    margin:0 auto;
    text-align: center;
}

.recruit_page .staff-section .qa-item {
    margin-bottom: 25px
}

.recruit_page .staff-section .qa-item .question {
    color: #091E9B;
    font-weight: normal;
    margin-bottom: 15px;
    display: flex;
    align-items: center
}

.recruit_page .staff-section .qa-item .question .q-mark {
    color: #091E9B;
    font-weight: bold;
    margin-right: 8px
}

.recruit_page .staff-section .qa-item .answer {
    color: #333;
    line-height: 1.8;
    padding-left: 25px
}

.recruit_page .event-section {
    padding: 30px 0;
    background-color: #091E9B
}

.recruit_page .event-section .title_area {
    background-color: #091E9B;
    text-align: center
}

.recruit_page .event-section .title_area .title,
.recruit_page .event-section .title_area .sub-title {
    color: #fff;
    margin-bottom: 0px
}

.recruit_page .event-section .event-description {
    color: #091E9B;
    background-color: #fff;
    padding: 10px 30px;
    text-align: center;
    margin-bottom: 30px;
    width: 90%;
    max-width: 600px;
    margin: auto
}

.recruit_page .event-section .event-photos {
    margin: 0 auto;
    max-width: 900px
}

.recruit_page .event-section .event-photos .photo-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 15px
}

.recruit_page .event-section .event-photos .photo-item {
    width: 32%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    position: relative
}

.recruit_page .event-section .event-photos .photo-item img {
    position: absolute;
    top: -2px;
    left: -2px;
    width: calc(100% + 4px);
    height: calc(100% + 4px);
    display: block;
    object-fit: cover;
    transition: transform 0.3s ease
}

.recruit_page .event-section .event-photos .photo-item img:hover {
    transform: scale(1.05)
}

.recruit_page .job-section {
    padding: 50px 0
}

.recruit_page .job-section .tab-container {
    margin-top: 30px
}

.recruit_page .job-section .tab-header {
    display: flex;
    justify-content: center
}

.recruit_page .job-section .tab-header .tab-button {
    width: 40%;
    max-width: 365px;
    background: none;
    border: none;
    padding: 15px 0;
    font-size: 16px;
    font-weight: bold;
    color: #333;
    cursor: pointer;
    transition: all 0.3s;
    background-color: #e1e5e9
}

.recruit_page .job-section .tab-header .tab-button.active {
    background-color: #091E9B;
    color: #fff
}

.recruit_page .job-section .tab-content {
    display: none;
    padding: 90px 70px;
    background-color: #fff;
    border: 2px solid #091E9B
}

.recruit_page .job-section .tab-content.active {
    display: block
}

.recruit_page .job-section .job-table {
    width: 100%;
    border-collapse: collapse
}

.recruit_page .job-section .job-table .blue {
    color: #091E9B
}

.recruit_page .job-section .job-table th,
.recruit_page .job-section .job-table td {
    padding: 20px 0;
    border-bottom: 1px solid #ddd;
    text-align: left;
    vertical-align: top
}

.recruit_page .job-section .job-table th {
    width: 160px;
    font-weight: bold;
    border-bottom: 2px solid #091E9B
}

.recruit_page .job-section .job-table td p {
    margin-bottom: 8px
}

.recruit_page .entry-section {
    background-color: #E9EFF4
}

.recruit_page .entry-section{
    position: relative;
}
.recruit_page .entry-section .line_area {
    position: absolute;
    right:0px;
    top: 50%;
    transform: translate(0, -50%);
}   

.recruit_page .entry-section .sub-title {
    margin-bottom: 0px
}

.recruit_page .entry-section .entry_content {
    max-width: 960px;
    margin: 0 auto;
    text-align: center
}

.recruit_page .entry-section .entry-description {
    color: #091E9B;
    margin-bottom: 30px;
    font-size: 16px
}

.recruit_page .entry-section .entry-buttons {
    display: flex;
    justify-content: center;
    gap: 20px;
    max-width: 700px;
    margin: 0 auto
}

.recruit_page .entry-section .entry-buttons .tel-button,
.recruit_page .entry-section .entry-buttons .mail-button {
    width: 50%
}

.recruit_page .entry-section .entry-buttons .tel-button a,
.recruit_page .entry-section .entry-buttons .mail-button a {
    display: block;
    transition: opacity 0.3s
}

.recruit_page .entry-section .entry-buttons .tel-button a:hover,
.recruit_page .entry-section .entry-buttons .mail-button a:hover {
    opacity: 0.8
}

.recruit_page .entry-section .entry-buttons .tel-button img,
.recruit_page .entry-section .entry-buttons .mail-button img {
    width: 100%;
    height: auto;
    display: block
}

.recruit_page .contact-section {
    padding: 50px 0;
    background-color: #091E9B
}

.recruit_page .contact-section .title_area {
    background-color: #091E9B
}

.recruit_page .contact-section .title_area .title,
.recruit_page .contact-section .title_area .sub-title {
    color: #fff
}

.recruit_page .contact-section .contact_content {
    max-width: 960px;
    margin: 0 auto;
    text-align: center
}

.recruit_page .contact-section .contact-message {
    color: #fff;
    margin-bottom: 30px
}

.recruit_page .contact-section .contact-methods {
    display: flex;
    justify-content: center;
    gap: 20px
}

.recruit_page .contact-section .contact-methods .tel-contact,
.recruit_page .contact-section .contact-methods .mail-contact {
    text-align: center
}

.recruit_page .contact-section .contact-methods .tel-button {
    display: inline-block;
    background-color: #fff;
    color: #091E9B;
    font-size: 24px;
    font-weight: bold;
    padding: 15px 40px;
    border-radius: 5px;
    text-decoration: none;
    margin-bottom: 10px;
    transition: background-color 0.3s
}

.recruit_page .contact-section .contact-methods .tel-button:hover {
    background-color: #f0f0f0
}

.recruit_page .contact-section .contact-methods .fax {
    color: #fff;
    font-size: 14px
}

.recruit_page .contact-section .contact-methods .mail-button {
    display: inline-block;
    background-color: #3FA9F5;
    color: #fff;
    font-size: 16px;
    font-weight: bold;
    padding: 20px 40px;
    border-radius: 5px;
    text-decoration: none;
    transition: background-color 0.3s
}

.recruit_page .contact-section .contact-methods .mail-button:hover {
    background-color: #2d96e0
}

.contact_page .contact-form-section {
    padding: 50px 0;
    background-color: #fff
}

.contact_page .contact-form-section .wrap .contact-form-content {
    max-width: 900px;
    margin: 0 auto
}

.contact_page form#contactForm {
    margin-bottom: 150px
}

.contact_page .form-group {
    display: flex;
    margin-bottom: 20px;
    align-items: flex-start;
    padding-bottom: 20px
}

.contact_page .form-group label {
    width: 250px;
    padding-right: 20px;
    padding-top: 10px;
    font-weight: bold;
    color: #333;
    flex-shrink: 0;
    position: relative
}

.contact_page .form-group .input-area {
    flex: 1
}

.contact_page .required,
.contact_page .optional {
    display: inline-block;
    padding: 4px 8px;
    border-radius: 6px;
    font-size: 14px;
    margin-left: 8px;
    font-weight: normal;
    position: absolute;
    right: 20px
}

.contact_page .required {
    background-color: #091E9B;
    color: white
}

.contact_page .optional {
    background-color: #3FA9F5;
    color: white
}

.contact_page input[type="text"],
.contact_page input[type="tel"],
.contact_page input[type="email"],
.contact_page select,
.contact_page textarea {
    width: 100%;
    padding: 10px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 16px;
    font-family: inherit;
    background-color: #E9EFF4
}

.contact_page textarea {
    resize: vertical
}

.contact_page .address-group .zip-container {
    display: flex;
    align-items: center;
    margin-bottom: 10px
}

.contact_page .address-group .zip-container .zip-prefix {
    margin-right: 5px
}

.contact_page .address-group .zip-container .zip-input {
    width: 80px;
    text-align: center
}

.contact_page .address-group .zip-container .zip-separator {
    margin: 0 5px
}

.contact_page .address-group .full-address {
    width: 100%
}

.contact_page .privacy-policy-section {
    margin-top: 40px;
    text-align: center
}

.contact_page .privacy-policy-section .privacy-agreement {
    margin-bottom: 20px
}

.contact_page .checkbox-container {
    display: inline-flex;
    align-items: center;
    position: relative;
    padding-left: 30px;
    cursor: pointer;
    font-size: 16px;
    user-select: none;
}

.contact_page .checkbox-container input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}

.contact_page .checkbox-container .checkmark {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translate(0,-50%);
    height: 16px;
    width: 16px;
    background-color: #fff;
    border: 2px solid #091E9B;
    border-radius: 0px;
}

.contact_page .checkbox-container:hover input~.checkmark {
    background-color: #ccc;
}

.contact_page .checkbox-container input:checked~.checkmark {
    background-color: #091E9B;
}

/* チェックマークのスタイル修正 */
.contact_page .checkbox-container .checkmark:after {
    content: "";
    position: absolute;
    display: none;
    left: 4px;
    top: 0px;
    width: 3px;
    height: 8px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.contact_page .checkbox-container input:checked~.checkmark:after {
    display: block;
}

.contact_page .privacy-note {
    font-size: 16px;
    margin-bottom: 10px
}

.contact_page .submit-button {
    margin-top: 30px
}

.contact_page .submit-button .btn-confirm {
    background-color: #091E9B;
    color: white;
    border: none;
    padding: 20px 40px;
    font-size: 20px;
    cursor: pointer;
    transition: background-color 0.3s;
    width: 100%;
    max-width: 350px
}

.contact_page .submit-button .btn-confirm:disabled,
.contact_page .submit-button .btn-confirm.is-disabled {
    background-color: #B3B8C5;
    cursor: not-allowed;
    opacity: 0.7;
}

.contact_page .submit-button .btn-confirm:disabled:hover,
.contact_page .submit-button .btn-confirm.is-disabled:hover {
    background-color: #B3B8C5;
}

.contact_page .submit-button .btn-confirm:hover {
    background-color: #3754BF
}

.contact_page .privacy-policy-box {
    padding: 30px
}

.contact_page .privacy-policy-box .privacy-title {
    font-size: 18px;
    margin-bottom: 6px;
    color: #091E9B;
    padding: 12px;
    border: 2px solid #091E9B;
    background-color: #fff;
    text-align: center
}

.contact_page .privacy-policy-box .privacy-content {
    font-size: 16px;
    line-height: 1.6;
    background-color: #E9EFF4;
    padding: 30px;
    height: 400px;
    overflow-y: scroll
}

.contact_page .privacy-policy-box .privacy-content h4 {
    margin: 20px 0 0px;
    color: #333
}

.contact_page .privacy-policy-box .privacy-content ol {
    padding-left: 20px;
    margin: 20px 0
}

.contact_page .privacy-policy-box .privacy-content address {
    margin-top: 20px;
    font-style: normal;
    line-height: 1.8
}

.thanks_page main {
    background-color: #fff
}

.thanks_page .thanks-message-section {
    padding: 50px 0 100px
}

.thanks_page .thanks-message-section .wrap {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 20px
}

.thanks_page .thanks-message-section .thanks-message-content {
    display: flex;
    justify-content: center;
    align-items: center
}

.thanks_page .thanks-message-section .message-box {
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.05);
    padding: 40px;
    text-align: center;
    max-width: 800px;
    width: 100%
}

.thanks_page .thanks-message-section .message-box h2 {
    font-size: 28px;
    font-weight: 700;
    color: #091E9B;
    margin-bottom: 30px
}

.thanks_page .thanks-message-section .message-box .thanks-icon {
    margin-bottom: 30px
}

.thanks_page .thanks-message-section .message-box .thanks-icon img {
    width: 80px;
    height: 80px;
    object-fit: contain
}

.thanks_page .thanks-message-section .message-box .thanks-text {
    font-size: 18px;
    line-height: 1.6;
    margin-bottom: 30px;
    color: #091E9B
}

.thanks_page .thanks-message-section .message-box .notice-text {
    font-size: 14px;
    line-height: 1.8;
    color: #666;
    background-color: #E9EFF4;
    padding: 20px;
    border-radius: 4px;
    margin-bottom: 30px
}

.thanks_page .thanks-message-section .message-box .button-area {
    margin-top: 30px
}

.thanks_page .thanks-message-section .message-box .button-area .btn-primary {
    display: inline-block;
    background-color: #091E9B;
    color: #fff;
    padding: 15px 40px;
    border-radius: 4px;
    font-size: 16px;
    font-weight: 700;
    text-decoration: none;
    transition: background-color 0.3s ease
}

.thanks_page .thanks-message-section .message-box .button-area .btn-primary:hover {
    background-color: #3754BF
}
