@charset "utf-8";

@import url("setting.css");

a{ color: var(--color-02); text-decoration:none; transition: 0.2s all;}
a:hover{ color: var(--color-01); text-decoration: none;}
a:focus{ text-decoration: none;}

section{ padding: 80px 0; }

.container{ max-width: 1640px; padding: 0 20px; }
.container.w2{ max-width: 1240px; }
.container.w3{ max-width: 546px; }

/*** HEADER ***/
header{ width: 100%; height: 105px; padding: 0; background: var(--color-01); border-bottom: 0px solid #ccc; display: flex; align-items: stretch; }

.logo{ width: 500px; height: 100%; margin: 0; padding: 0; background: var(--color-02); border-bottom-right-radius: 50px;}
.logo a{ width: 350px; height: 65px; margin: 20px 50px; background: url(../../img/pic-logo.webp) center center no-repeat; background-size: cover; display: block; text-indent: -9999px; }
/*** /HEADER ***/

/*** BREADCRUMB ***/
nav[aria-label="breadcrumb"]{ padding:8px 0 7px 0; font-size: .875em; color: #999; background: #f9f9f9; border-top: 0px solid #ddd; border-bottom: 1px solid #ddd; }
ol.breadcrumb{ margin: 0; padding: 0;}
.breadcrumb-item:before{ color: #999 !important; }
.breadcrumb-item.active{ color: var(--color-01); font-weight: bold; }
ol.breadcrumb a{ color: #999; }
ol.breadcrumb a:hover{ color: var(--color-01); }
/*** /BREADCRUMB ***/

/*** CNT ***/
main{ min-height: calc(100vh - 725px); }
main.h_2{ min-height: calc(100vh - 345px); display: flex; align-items: center; justify-content: center; }
main iframe{ width: 100% !important; height: auto !important; aspect-ratio: 16 / 9 !important; }

#i_catagory{ background: url('../../img/bg-catagory.webp') left top no-repeat; background-size: cover; }

.box_wrap{ margin: 12px 0; padding: 0px; background: var(--color-11); border: 0px solid #ccc; transition:0.2s all; }
.box_wrap .box_img{ transition:0.5s all; -webkit-backface-visibility: hidden; -webkit-transform: translateZ(0) scale(1.0, 1.0); }
.box_wrap:hover .box_img{ transform: scale(1.25, 1.25); }
.box_wrap p{ width: 100%; margin: 15px 0 2px 0; text-overflow: ellipsis; white-space: nowrap; overflow: hidden; }
.box_wrap .box{ width: 100%; height: 100%; }
.box_wrap .box_img_wrap{ width: 100%; height: 100%; position: relative; overflow: hidden;}
.box_wrap .box_img_wrap .box_overlay{ width: 100%; height: 100%; color: #fff; font-size: 2em; line-height: 1em; position: absolute; z-index: 1; display: table; background: rgba(0, 0, 0, .5); opacity: 0; transition:0.5s all; }
.box_wrap .box_img_wrap .box_overlay2{ width: 100%; height: auto; padding: 10px; color: #fff; font-size: 1em; line-height: 1em; position: absolute; bottom: 0; z-index: 1; display: table; background: rgba(0, 0, 0, .75); opacity: 1; transition:0.5s all; text-align: center; }
.box_wrap .box_img_wrap .box_overlay2 br{ display: none; }
.box_wrap .box .box_overlay p, .box_wrap .box .box_overlay2 p{ display: table-cell; vertical-align: middle; text-align: center; }
.box_wrap .box img{ width: 100%; height: auto; }
a:hover .box_wrap{ box-shadow: 0 0 10px rgba(0, 0, 0, 1.0);}
a:hover .box_wrap .box .box_overlay{ opacity: 1; }
a:hover .box_wrap .box .box_overlay2{ opacity: 0; }
.box_wrap .box_txt{ padding: 15px 20px; background: var(--color-12); }
.box_wrap .box_txt p{ margin: 0; padding: 0; line-height: 1.5em; }

#i_intro{ padding: 70px 80px; background: rgba(255, 255, 255, .75); }
#i_intro h2{ margin-bottom: 40px; font-weight: 700; line-height: 1.5em; text-align: center; }
#i_intro h2 span{ margin: 0 5px; padding: 0 10px 2px 10px; background: var(--color-01); }
#i_intro h2 br:nth-child(2){ display: none; }

#ft{ background: var(--color-01); }
.ft_wrap{ margin: 10px 0; display: flex; }
.ft_ico{ width: 220px; border-left: 5px solid #000; text-align: center; }
.ft_ico img{ width: 110px; height: auto; }
.ft_txt{ width: calc(100% - 220px); }
.ft_txt h3{ margin-bottom: 20px; font-weight: 700; }
.ft_txt p{ text-align: justify; }

#i_yt{ padding: 0px 0; background: #000; /*background: url(../../img/bg-i_yt.webp) fixed center center no-repeat; background-size: cover;*/ position: relative; }
#i_yt h2{ color: #fff; text-shadow: 0 0 10px rgba(0,0,0,.75); letter-spacing: 5px; text-indent: -5px; line-height: 1.5em; text-align: center; }
#i_yt .btn_wrap{ width: 100%; margin: 0; position: absolute; bottom: 55px; left: 0; z-index: 1; text-align: center; }
#i_yt .btn_wrap a{ width: 150px; margin: 0 auto; padding: 10px 10px; background: var(--color-01); display: flex; align-items: center; justify-content: center; transition:0.3s all; }
#i_yt .btn_wrap a:hover{ color: #000; transform: scale(1.05, 1.05);}
#i_yt .btn_wrap i{ margin: 3px 5px 0 0; font-size: 1.25em; line-height: 1em; }
#i_yt .btn_wrap p{ line-height: 1em; }

.vid_wrap iframe{ width: 100%; display: block; }
.embed-responsive { height: 0; padding: 0; position: relative; display: block; overflow: hidden;}
.embed-responsive .embed-responsive-item, .embed-responsive iframe, .embed-responsive embed, .embed-responsive object, .embed-responsive video { width: 100%; height: 100%; position: absolute; top: 0; left: 0; bottom: 0; border: 0;}
.embed-responsive-16by9 { padding-bottom: 56.25%;}
.embed-responsive-4by3 { padding-bottom: 75%;}

#i_other{ padding: 0;}
.flip_wrap{ width: 100%; height: 300px; /*perspective: 1000px;*/}
.flip_box{ width: 100%; height: 100%; position: relative; text-align: center; transition: transform 0.6s; transform-style: preserve-3d;}
.flip_wrap:hover .flip_box{ transform: rotateY(180deg);}
.flip_front, .flip_back{ width: 100%; height: 100%; color: #fff; position: absolute; display: flex; align-items: center; justify-content: center; -webkit-backface-visibility: hidden; backface-visibility: hidden;}
.flip_front{ background: rgba(0, 0, 0, .65);}
.flip_back{ background: rgba(0, 0, 0, .9); transform: rotateY(180deg);}

.bnr_inr{ height: 760px; position: relative; }
.bnr_inr .bnr_overlay{ width: 50%; height: 100%; color: var(--color-12); background: rgba(0,0,0,.5); display: flex; align-items: center; justify-content: center; flex-wrap: wrap; }
.bnr_inr .bnr_txt{ max-width: 600px; margin: 0 auto; padding: 50px; }
.bnr_inr .bnr_txt h1{ margin-bottom: 20px; letter-spacing: 5px; line-height: 1.25em; }
.bnr_inr .bnr_txt p{ font-size: 1.25em; line-height: 2em; text-align: justify; }
.bnr_evt{ background: url('../../img/bg-bnr_evt.webp') center center no-repeat; background-size: cover; }
.bnr_vis{ background: url('../../img/bg-bnr_vis.webp') center center no-repeat; background-size: cover; }
.bnr_eqp{ background: url('../../img/bg-bnr_eqp.webp') center center no-repeat; background-size: cover; }
.bnr_prop{ background: url('../../img/bg-bnr_prop.webp') center center no-repeat; background-size: cover; }
.bnr_serv{ background: url('../../img/bg-bnr_serv.webp') center center no-repeat; background-size: cover; }

.bnr_news{ height: 380px; background: url('../../img/bg-bnr_news.webp') center center no-repeat; background-size: cover; }
.bnr_news .bnr_overlay{ width: 100%; }
.bnr_news .bnr_txt{ max-width: 820px; text-align: center; }

.sublist_wrap{ margin: 0; padding: 0; background: var(--color-12); white-space: nowrap; text-align: center; }
.sublist_wrap a{ margin: 0; padding: 10px 0 12px 0; display: inline-block; }
.sublist_wrap a .sublist{ margin: 0 -2px; padding: 0 40px; border-left: 1px solid #000; }
.sublist_wrap a:last-child .sublist{ border-right: 1px solid #000; }
.sublist p{ line-height: 1em; text-align: center; }
.sublist_scroll{ /*max-width: 716px;*/ width: 100%; height: auto; margin: 0 auto; padding: 17px 0 0 0; overflow-x: scroll; }
.sublist_scroll::-webkit-scrollbar { width: 0 !important; opacity: 0; }
.sublist_scroll a.current{ color: var(--color-01); }
.btn_scroll{ display: none; }

.news_wrap{ padding: 40px; background: var(--color-12); border-radius: 20px; display: flex; }
.news_img{ width: 230px; border-radius: 10px; }
.news_img img{ width: 100%; height: auto; }
.news_txt{ width: calc(100% - 230px); padding-left: 40px; position: relative; }
.news_txt h3{ margin-bottom: 20px; font-weight: 700; line-height: 1.125em; }
.news_txt p{ height: 104px; }
.news_txt a{ float: right; margin-top: 42px; font-weight: 700; display: flex; }
.news_txt a span{ margin: 2px 10px 0 0; }
.news_txt a i{ width: 30px; height: 30px; line-height: 30px; background: var(--color-01); border-radius: 50%; text-align: center; transition:0.2s all; }
.news_txt a:hover i{ color: var(--color-12); }

#news_dtl .container{ min-height: calc(100vh - 725px); padding: 80px 90px; background: var(--color-12); }
#news_dtl h2{ margin-bottom: 30px; padding-bottom: 30px; text-align: justify; line-height: 1.25em; border-bottom: 1px solid #000;}
#news_dtl h3{ margin-bottom: 20px; }

.dtl_func{ margin: 40px 0 0 0; padding: 0; list-style; none; text-align: center; }
.dtl_func li{ margin: 0 -4px; padding: 0 40px; border-right: 1px solid #000; display: inline-block; text-align: center; }
.dtl_func li:last-child{ border-right: 0;}
.dtl_func li a.disabled{ color: #ccc;}

#cont{ }
#cont .container{ min-height: calc(100vh - 725px); padding: 80px 90px; background: var(--color-12); }
#cont h2{ margin-bottom: 40px; font-weight: 700; }
#cont h2 span{ margin-left: 20px; color: var(--color-01); font-size: .65em; font-weight: 400; }
.btn-submit{ padding: 10px 48px 12px 48px; color: var(--color-12); font-size: 1em; background: var(--color-04); border: 0; border-radius: 0px; display: inline-block; transition: 0.5s;}
.btn-submit:hover{ color: var(--color-12); background: color-mix(in srgb, var(--color-02), transparent 10%);}
#cont h4{ margin-bottom: 10px; line-height: 1.5em; }

#abm_dtl h2{ line-height: 1.25em; }

.quote_1{ text-overflow: ellipsis; white-space: nowrap; overflow: hidden;}
.quote_2{ overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.quote_3{ overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; }
.quote_4{ overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; }
/*** /CNT ***/

/*** CONTACT ***/
.gmap{ width: 100%; height: 780px; margin: 0; display: block; }
/*** /CONTACT ***/

/*** PAGINATION ***/
.pagination_wrap{ width: 100%; overflow: hidden; }
.pagination{ float: left; margin: 40px 0 0 0; }
.pagination a{ color: #666; }
.pagination a:hover{ color: #666; background: #f6f6f6; }
.pagination .active .page-link{ background: var(--color-01); border-color: #dee2e6; }

.pagination_jump{ float: right; margin: 40px 0 0 0; padding: 0; list-style: none; }
.pagination_jump select.form-select{ width: auto; min-height: 38px; margin: 0 5px; padding: 0 35px 0 10px; background-color: var(--color-12); border: 1px solid #dee2e6; border-radius: 3px; display: inline-block; cursor: pointer; }
/*** /PAGINATION ***/

/*** FOOTER ***/
footer{ margin: 0; padding: 40px 0; color: var(--color-12); background: var(--color-02) url('../../img/pic-flogo.webp') left 15% bottom 10px no-repeat; background-size: 150px auto; text-align: center; overflow: hidden; }
footer p{ margin: 5px 0; }
footer p br{ display: none; }
footer p span{ margin: 0 10px 0 0; display: inline-block; }
footer p span:last-child{ margin: 0; }
footer a{ color: var(--color-12); }

.social_wrap{ height: 100vh; position: fixed; display: flex; right: 0; z-index: 510; align-items: center; }
.social{ margin: 0; padding: 0px 10px; list-style: none; background: rgba(255,255,255,0.5); border-top-left-radius: 10px; border-bottom-left-radius: 10px; }
.social li a{ width: 30px; margin: 10px 0; display: block; }

.f_social_wrap{ display: none; }
/*** /FOOTER ***/

/*** CAPTCHA ***/
#captcha_code{ float: left; width: 120px; text-align: center; }
.captcha_wrap{ float: left; margin: 10px 0 0 10px; }
/*** /CAPTCHA ***/

/*** BTN ***/
.btn{ border-radius: 0; }
.btn_wrap{ width: 100%; margin:30px 0 0 0; }

.btn-primary{ background: var(--color-01) !important; border-color: var(--color-01) !important; }
.btn-primary:hover, .btn-primary:focus{ background: var(--color-02) !important; border-color: var(--color-02) !important;}
/*** /BTN ***/

/*** MODAL ***/
.modal{ z-index: 999999; }
.modal-header{ color: #fff; background: var(--color-01); }
.modal-open { padding-right: 0 !important;}
.modal-backdrop { opacity: .9 !important; }
.modal-content{ position: relative; }
.btn-close-wrap{ background-color: #2faeff; border-radius: 0; border-top-right-radius: 5px; border-bottom-left-radius: 5px; position: absolute; top: 0; right: 0; z-index: 10; }
.btn-close{ padding: 15px 15px; position: absolute; top: 0; right: 0; z-index: 10;}
.modal-body{ padding: 30px 30px 30px 30px; color: #333; overflow: hidden; }
.modal-body h4{ font-weight: 700; line-height: 1.25em; text-align: center; }
.modal-body h4 span{ font-size: .6em; font-weight: 400; display: block; text-transform: uppercase; }
.modal-body button{ margin-top: 5px; margin-bottom: 5px; }
.modal-body a:hover{ color: var(--color-12); }

#popModal .modal-body{ padding: 0;}
#popModal .btn-close-custom{ width: 26px; height: 26px; line-height: 24px; border-radius: 50%; position: absolute; top: 10px; right: 10px; color: #fff; background: #000; }
/*** /MODAL ***/

/*** POPOVER ***/
[data-bs-toggle="popover"]{ cursor: pointer; }
.popover{ padding:5px; border: 5px solid #ccc; border-radius: 10px; }
.popover-arrow{ display: none !important; }
/*** /POPOVER ***/


@media screen and (-webkit-min-device-pixel-ratio:0) { /* Chrome */
}

@media all and (-ms-high-contrast:none){ /* IE 11 */
     *::-ms-backdrop, .label_name{ }
}

@supports (display:-ms-grid) { /* Edge */
}