@charset "utf-8";

.commitment {padding:var(--space-40) var(--space-80); margin-top:var(--space-100); background:#f2f2f2;}
.commitment-title {font-style:italic; font-size:var(--font-size-26); line-height:1.3em; letter-spacing:-.03em; color:#000; font-weight:600; margin-bottom:var(--space-20);}
.commitment-content {line-height:1.3em; letter-spacing:-.03em; color:#000; font-weight:500;}
.commitment-content .tagline {margin-top:10px; line-height:1.3em; text-align:right; letter-spacing:-.03em; color:#2e3192;}

.sub-depth {font-size:var(--font-size-20); gap:var(--space-30); margin-bottom:12px; display:flex; align-items:center; color:#666; font-family:var(--font-industry); font-weight:500;}
.sub-depth span {position:relative;}
.sub-depth span:after {width:10px; height:14px; right:-20px; content:''; position:absolute; top:50%; transform:translateY(-50%); background-image:url('../images/common/lnb-arrow.png'); background-size:contain; background-repeat:no-repeat; background-position:50% 50%;}
.sub-depth span:last-child:after {display:none;}
.sub-depth .home {width:20px; height:16px; display:block; background-image:url('../images/common/home.png'); background-size:contain; background-repeat:no-repeat; background-position:center;}

.sub-title {margin-bottom:var(--space-40); font-family:var(--font-industry);}
.sub-title.mg { margin-bottom: 10px; }
.sub-title h1 {font-size:var(--font-size-36); line-height:1.3em; letter-spacing:-.03em; color:var(--color-bk);}
.sub-title h1 br {display:none;}
.sub-title h1 .desc {font-size:var(--font-size-15); color:#a8a8a8; padding-left:12px; font-weight:400; letter-spacing:-.03em;}
/* .sub-title h1 .underline {text-decoration:underline; text-underline-offset:4px; font-weight:400; text-decoration:underline; text-decoration-thickness:2px;} */

.info-wrap {max-width:1080px; margin:0 auto; display:flex; gap:var(--space-60);}
/* .info-map {max-width:470px; flex:1;}
.info-map iframe {width:100%; height:100%;} */

.contact-info {color:#666; flex:1;}
.contact-info h2 {font-size:var(--font-size-26); line-height:1.2em; letter-spacing:0; font-weight:600; margin-bottom:3px; color:#000;}
.contact-info .inquiry-notice {font-size:var(--font-size-20); line-height:1.2em; letter-spacing:0;}
.contact-info section {margin-top:var(--space-30);}

.contact-info h3 {font-size:var(--font-size-20); margin-bottom:5px; line-height:1.2em; letter-spacing:0; font-weight:600; color:#000;}
.contact-info address {font-size:var(--font-size-18); line-height:1.2em; letter-spacing:0; font-style:normal;}
.contact-info address p {margin-bottom:10px;}
.contact-info .office-info address p {margin-bottom:var(--space-25);}
.contact-info address p:last-child {margin-bottom:0 !important;}
.contact-info ul {margin-top:12px;}
.contact-info li {line-height:1.2em; letter-spacing:0;}
.contact-info a[href^="mailto:"] {color:#0033cc; text-decoration:underline; font-weight:normal;}

.employment-info {margin-top:var(--space-80);}
.employment-info strong {font-size:var(--font-size-26); display:block; color:#000; margin-bottom:var(--space-20);}
.employment-info p {font-size:var(--font-size-20); color:#666; line-height:1.2em; letter-spacing:0;}

.map-area {margin-bottom:100px; text-align:center;}

.contact-list {display:flex; flex-wrap:wrap; gap:var(--space-100); justify-content:space-between;}
.contact-list .item {width:33.3333%; max-width:320px; line-height:1.4em; letter-spacing:0; color:#1a1a1a; font-weight:500;}
.contact-list .item .topbar {padding:15px 0 var(--space-20); border-top:2px solid #1a1a1a; font-size:var(--font-size-22); line-height:1.2em; letter-spacing:0; font-weight:600; display:block;}
.contact-list .item a {color:#001eff;}

.popup-modal {display:none; color:#1a1a1a; position:fixed; top:0; left:0; width:100%; height:100%; background-color:rgba(0, 0, 0, .4); z-index:1000;}
.popup-content {min-width:360px; max-width:360px; padding:var(--space-40); position:absolute; top:50%; left:50%; transform:translate(-50%, -50%); background-color:#fff; border-radius:5px;}
.popup-header {margin-bottom:12px;}
.popup-close {width:15px; height:15px; top:20px; right:20px; font-size:30px; position:absolute; background:none; border:none; display:flex; align-items:center; justify-content:center; cursor:pointer;}
.popup-body {line-height:1.2em; font-weight:500;}
.popup-body a {color:#001eff; text-decoration:none;}
.popup-common-title {margin-bottom:var(--space-20); border-radius:8px; padding:10px; font-family:var(--font-industry); text-align:center; line-height:1.13em; letter-spacing:0; font-weight:700; color:#fff; background-color:#37497f;}

.prd-tab {display:flex; align-items:center; gap:10px; margin-bottom:var(--space-30);}
.prd-tab .col {gap:var(--space-20); flex:1; display:flex; align-items:center;}
.prd-tab .board-search {margin-bottom:0;}

.prd-tab-inner ul {gap:12px; display:flex; align-items:center; text-align:center;}
.prd-tab-inner ul li a {display:block; color:#a8a8a8; font-weight:500; border:1px solid #ddd; border-radius:30px;}
.prd-tab-inner ul li:hover a,
.prd-tab-inner ul li.active a {color:#fff;}
.prd-tab-inner ul.ty-large li a {min-width:113px; font-size:var(--font-size-15); padding:7px 15px;}
.prd-tab-inner ul.ty-large li:hover a,
.prd-tab-inner ul.ty-large li.active a {background:#ef2d1a; border-color:#ef2d1a;}
.prd-tab-inner ul.ty-small li a {font-size:13px; min-width:90px; padding:0 15px;}
.prd-tab-inner ul.ty-small li:hover a,
.prd-tab-inner ul.ty-small li.active a {background:#5bc3e7; border-color:#5bc3e7;}

.product-table table {width:100%; border-collapse:collapse; text-align:center;}
.product-table thead th {height:78px; font-size:var(--font-size-15); background:#f2f2f2; color:#4d4d4d; font-weight:600; padding:10px;}
.product-table thead th i {width:23px; height:10px; display:inline-block; background-image:url('../images/sub/prd-filter.png'); background-size:contain; background-repeat:no-repeat; background-position:center;}
.product-table tbody td {height:55px; font-size:var(--font-size-15); border-bottom:1px solid #ddd; color:#444; position:relative;}
.product-table tbody td a.modal-open:hover {font-weight:700;}
.product-table thead th,
.product-table tbody td {border-right:1px solid #ddd;}
.product-table thead th:last-child,
.product-table tbody td:last-child {border-right:none;}
.product-table .download {display:inline-flex; align-items:center; justify-content:center;}
.product-table button {border:0;}
.product-table th small {padding-left:20px; display:block; line-height:.5em;}

.modal {max-width:230px; min-width:230px; top:-50px; right:-200px; display:none; position:absolute; width:100%; padding:0; border-radius:20px; overflow:hidden; box-shadow:1px 3px 10px rgba(0,0,0,.5);}
.modal-content {padding:13px 15px; display:flex; gap:var(--space-30); position:relative; background-color:#fff; width:100%;}
.modal-content .image {width:255px;}
.modal-content .thumb {position:relative; padding-bottom:80%; overflow:hidden;}
.modal-content .thumb img {position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); -ms-transform:translate(-50%,-50%); -webkit-transform:translate(-50%,-50%); width:auto !important; height:auto !important; max-width:100%; max-height:100%; object-fit:contain;}
.modal-content .thumb:after {content:""; position:absolute; top:0; left:0; right:0; bottom:0; border:1px solid rgba(0,0,0,.08);}

.modal-content .text {flex:1;}
.modal-content .text .title {margin-bottom:12px; font-weight:600; color:#e73820; line-height:1.38em; letter-spacing:0;}
.modal-content .text .desc {color:#666; line-height:1.38em; letter-spacing:0;}
.modal-content .text .value {font-weight:600; line-height:1.3em; color:#333;}
.modal-content .text .typ {margin:6px 0 3px; color:#fff;}
.modal-content .text .typ span {padding:0 13px; line-height:22px; border-radius:30px; display:inline-block;}
.modal-content .text .typ span.ty1 {background-color:#e73820;}
.modal-content .text .typ span.ty2 {background-color:#5bc3e7;}
.modal-content .text .info {line-height:1.55em;}

.inq-required {font-size:var(--font-size-22); margin-bottom:var(--space-30); color:#1a1a1a; font-weight:600; margin-bottom:var(--space-20); letter-spacing:-0.03em; line-height:1.4em;}
.inq-required span {color:#ff0000;}

.quote-top {text-align:center; font-size:var(--font-size-22); color:#e73820; font-weight:600; margin-top:12px; letter-spacing:-0.03em; line-height:1.4em;}

.pd-tit { font-weight: 500; margin-bottom: 30px; }