/* Header, Footer, Layout 관련 CSS 작성 */

/* Header { */
.header {position: fixed; z-index: 10; left: 0; top: 0; width: 100%; box-shadow: 0 6px 10px rgba(0,0,0,0.05); backdrop-filter: blur(3px); transition: .5s;}
.header.is-loaded {top: -100px;}
.header::before {content: ''; position: absolute; inset: 0; background: linear-gradient(180deg,rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0.1) 100%); opacity: .35; z-index: -1; height: 100%; transition: .5s;}
.header .wrapper {width: 100%; padding: 0 50px;}
.header-content {height: 100px; display: flex; align-items: center; justify-content: space-between; position: relative;}
.header-content .logo a {font-size: 0; display: block;}
.header-content .logo .color {display: none;}

.gnb {height: 100%;}
.depth1 {display: flex; align-items: center; height: 100%;}
.depth1 > li {height: 100%; display: flex; align-items: center; justify-content: center; padding: 0 40px;}
.depth1-link {font-weight: 500; font-size: 23px; color: var(--white-color); transition: .3s;}

.depth2-wrap {position: fixed; top: 100px; left: 0; width: 100%; display: none; border-top: 1px solid var(--color-c8);}
.depth2 {display: flex; align-items: stretch; background-color: var(--white-color); width: 100%;}
.depth2-head {background: url('../img/depth2-head-bg.png') no-repeat bottom/cover; width: 20%; padding: 50px; color: var(--white-color);}
.depth2-title {font-weight: 600; font-size: 30px; font-family: 'A2Z';}
.depth2-text {font-weight: 300; font-size: 18px; line-height: 1.5; margin-top: 24px;}
.depth2-body {width: 80%; padding: 40px 50px;}
.depth2-list {display: flex; align-items: flex-start; flex-wrap: wrap; gap: 30px;}
.depth2-list li {width: calc((100% - (30px * 3)) / 4);}
.depth2-link {display: flex; align-items: center; justify-content: space-between; height: 54px; border-radius: 6px; border: 1px solid var(--color-cd); padding-left: 20px; padding-right: 15px; font-weight: 400; font-size: 18px; color: var(--black-color); transition: .3s;}
.depth2-link::before {background-color: var(--main-color); border-radius: 6px;}
.depth2-link::after {content: '\ea6e'; font-family: 'remixicon' !important; font-size: 20px; transition: .3s; color: var(--color-76);}
.depth2-link[target="_blank"]::after {content: '\ecaf';}

.depth2-link:hover {border-color: var(--main-color); color: var(--white-color);}
.depth2-link:hover::after {color: var(--white-color);}

.depth1 > li:hover .depth1-link {color: var(--main-color);}

.rnb {display: flex; align-items: center; gap: 0 20px;}
.rnb-item {}
.rnb-item.mobile-menu {display: none;}
.rnb-sns-links {display: flex; align-items: center; gap: 10px;}
.rnb-sns-link {display: block; font-size: 0; border-radius: 50%; width: 40px; aspect-ratio: 1 / 1;}

.menu-btn {display: flex; align-items: center; justify-content: center; width: 30px; aspect-ratio: 1 / 1; border: none; background-color: transparent;}
.menu-btn span {width: 100%; height: 2px; background-color: var(--white-color); position: relative; transition: .3s;}
.menu-btn span::before {content: ''; width: 100%; height: 2px; background-color: var(--white-color); position: absolute; top: -10px; left: 0; transition: .3s;}
.menu-btn span::after {content: ''; width: 100%; height: 2px; background-color: var(--white-color); position: absolute; top: 10px; left: 0; transition: .3s;}

.header.is-white {background-color: var(--white-color); backdrop-filter: none;}
.header.is-white::before {opacity: 0;}
.header.is-white .logo .color {display: block;}
.header.is-white .logo .white {display: none;}
.header.is-white .depth1-link {color: var(--black-color);}
.header.is-white .menu-btn span {background-color: var(--black-color);}
.header.is-white .menu-btn span::before {background-color: var(--black-color);}
.header.is-white .menu-btn span::after {background-color: var(--black-color);}

.menu-dim {position: fixed; top: 0; right: 0; left: 0; bottom: 0; z-index: 11; background-color: rgba(0,0,0,0.5); display: none;}
.menu {position: fixed; top: 0; right: -360px; z-index: 12; height: 100%; width: 360px; max-width: 100%; background-color: var(--white-color); box-shadow: 0 0 20px rgba(0,0,0,0.2); transition: .5s;}
.menu.is-active {right: 0;}
.menu-content {}
.menu-head {display: flex; align-items: center; justify-content: space-between; height: 80px; background: url('../img/depth2-head-bg.png') no-repeat bottom/cover; padding: 0 1rem;}
.menu-head .rnb-sns-link {width: 30px;}
.menu-close-btn {display: flex; align-items: center; justify-content: center; width: 30px; aspect-ratio: 1 / 1; border: none; background-color: var(--white-color); border-radius: 50%; font-size: 22px;}
.menu-body {height: calc(100% - 80px); padding: 1rem; overflow-y: auto;}

.menu-depth1 {}
.menu-depth1 > li {border-bottom: 1px solid var(--color-c8);}
.menu-depth1-btn {width: 100%; display: flex; align-items: center; justify-content: space-between; background-color: transparent; border: none; font-weight: 500; font-size: 20px; color: var(--black-color); font-family: 'A2Z'; padding: 14px 0; transition: .3s;}
.menu-depth1-btn::after {content: '\ea4e'; font-family: 'remixicon' !important; font-size: 20px; transition: .3s; color: var(--color-76); transition: .3s;}
.menu-depth1-btn.is-open {color: var(--main-color);}
.menu-depth1-btn.is-open::after {transform: rotate(180deg);}
.menu-depth2 {padding: 1rem; display: none;}
.menu-depth2 > li {}
.menu-depth2 > li ~ li {margin-top: 4px;}
.menu-depth2-link {font-weight: 400; font-size: 18px; display: flex; align-items: center; gap: 0 5px;}
.menu-depth2-link[target="_blank"]::after {content: '\ecaf'; font-family: 'remixicon' !important; color: var(--color-76);}
/* } Header */

/* Footer { */
.footer {padding: 30px 0 60px; background-color: var(--white-color); /*border-top: 1px solid var(--color-c8);*/}
.sub-footer {border-top: 1px solid var(--color-c8);}
.footer-content {display: flex; align-items: flex-end; justify-content: space-between;}
.footer-content-left {width: 660px; max-width: 100%;}
.footer-logo {display: inline-block; font-size: 0;}
.footer-info {display: flex; width: 100%; justify-content: space-between; border-top: 1px solid var(--color-c8); margin-top: 30px; padding-top: 25px;}
.footer-info-item {font-weight: 400; font-size: 17px; z-index: 1; color: var(--black-color);}
.footer-info-item .title {}
.footer-info-item .content {margin-top: 10px; color: var(--color-73);}
.footer-copyright {font-weight: 400; font-size: 17px; color: #767676; margin-top: 20px;}
.footer-content-left .footer-copyright {display: none;}
.footer-content-right {display: flex; flex-direction: column; align-items: flex-end;}
.footer-relate-site {position: relative;}
.footer-relate-btn {border-radius: 6px; display: flex; align-items: center; justify-content: space-between; height: 52px; background-color: var(--color-ec); border: none; min-width: 200px; padding-left: 20px; padding-right: 14px; font-weight: 400; font-size: 16px; color: var(--color-73); transition: .3s;}
.footer-relate-btn i {transition: .3s;}
.footer-relate-btn.is-open {box-shadow: 0 0 0 2px var(--color-73);}
.footer-relate-btn.is-open i {transform: rotate(180deg);}
.footer-relate-btn:hover {box-shadow: 0 0 0 2px var(--color-73);}
.footer-relate-list {position: absolute; bottom: calc(100% + 10px); display: flex; flex-direction: column; align-items: center; justify-content: center; z-index: 2; min-width: 100%; padding: 20px; background-color: var(--white-color); box-shadow: 0 6px 10px rgba(0,0,0,0.1); border-radius: 6px; gap: 5px 0; display: none;}
.footer-relate-link {display: flex; align-items: center; width: 100%; font-weight: 400; font-size: 16px; color: var(--color-73); text-align: center; transition: .3s;}
.footer-relate-link:hover {color: var(--main-color); font-weight: 500;}
.footer-btns {display: flex; align-items: center; gap: 0 40px; margin-top: 38px;}
.footer-btn {font-weight: 400; font-size: 17px; color: var(--color-73); position: relative; line-height: 1; transition: .3s;}
.footer-btn:hover {text-decoration: underline; text-underline-offset: 3px;}
.footer-btn.point-color {color: var(--main-color);}
.footer-btn::before {content: ''; width: 3px; aspect-ratio: 1 / 1; border-radius: 50%; background-color: var(--color-73); position: absolute; top: 8px; right: -20px;}
.footer-btn:last-child::before {display: none;}

.page-top-btn {position: fixed; right: calc((100vw - 1756px) / 2); bottom: 30px; z-index: 2; display: flex; align-items: center; justify-content: center; width: 60px; aspect-ratio: 1 / 1; border-radius: 6px; background-color: #072248; border: none; color: var(--white-color); font-size: 24px; transition: .3s; opacity: 0; visibility: hidden;}
.page-top-btn.is-show {opacity: 1; visibility: visible;}
.page-top-btn.is-end {bottom: 280px;}
/* } Footer */

/* Main Layout { */
/* } Main Layout */

/* Sub Layout { */
.sub {padding-top: 100px;}

.sub-location {border-bottom: 1px solid var(--color-c8); border-top: 1px solid var(--color-c8); background-color: #F6F9FC;}
.sub-location-ul {display: flex; align-items: center; height: 60px; gap: 15px;}
.sub-location-li {position: relative; display: flex; align-items: center; gap: 15px; height: 100%;}
.sub-location-li::after {content: "\ea6e"; font-family: 'remixicon' !important; color: var(--color-61);}
.sub-location-li:last-child::after {display: none;}
.sub-location-li.home {}
.sub-location-li.home .sub-location-link {width: 20px; aspect-ratio: 1 / 1; display: flex; align-items: center; justify-content: center; color: var(--color-61); font-size: 18px;}
.sub-location-link {font-family: 'A2Z'; font-weight: 400; font-size: 14px; color: var(--color-61); transition: .3s;}
.sub-location-link:hover {color: var(--main-color);}
.sub-location-btn {height: 100%; display: flex; gap: 15px; background-color: transparent; border: none; align-items: center; font-family: 'A2Z'; transition: .3s;}
.sub-location-btn::after {content: "\ea4f"; font-family: 'remixicon' !important; color: var(--color-61); font-size: 20px;}
.sub-location-list {position: absolute; top: 100%; left: 0; z-index: 2; display: flex; flex-direction: column; background-color: var(--white-color); box-shadow: 0 4px 8px rgba(0,0,0,0.1); border-radius: 5px; padding: 14px 16px; min-width: 150px; display: none;}
.sub-location-list .sub-location-link ~ .sub-location-link {margin-top: 6px;}

.sub-location-li:last-child .sub-location-btn {color: var(--main-color);}
.sub-location-li:last-child .sub-location-btn::after {color: var(--main-color);}

.sub-common {margin-top: 70px;}
.sub-page-title {border-bottom: 1px solid var(--color-c8); padding-bottom: 40px;}
.sub-page-title .title {font-weight: 600; font-size: 50px; color: var(--black-color); line-height: 1;}
.sub-page-title .text {font-weight: 300; font-size: 18px; color: var(--color-61); margin-top: 20px;}

.sub-contents {padding-top: 50px; padding-bottom: 100px;}

.sub-section {}
.sub-section ~ .sub-section {margin-top: 50px;}
/* } Sub Layout */

/* 만족도 조사 { */
.sub-foot {margin-top: 70px;}
.sub-foot > .container {width: 100%; padding: 0;}
.satisfaction {border: 1px solid #eee; border-radius: 10px; overflow: hidden;}
.satisfaction-head {background-color: #f5f5f5; padding: 20px 40px;}
.satisfaction-info {display: flex; align-items: center; gap: 40px;}
.satisfaction-info-item {display: flex; align-items: center; gap: 5px; font-size: 17px; color: #000000; position: relative;}
.satisfaction-info-item::before {content: ''; width: 1px; height: 13px; background-color: #ccc; position: absolute; top: 50%; right: -20px; transform: translateY(-50%);}
.satisfaction-info-item:last-child::before {display: none;}
.satisfaction-info-item .t {display: flex; align-items: center; font-weight: 500; gap: 4px;}
.satisfaction-info-item i {font-weight: normal; font-size: 20px;}
.satisfaction-info-item .a {font-weight: 400; color: #666666;}
.satisfaction-caution {padding-top: 13px;}
.satisfaction-caution p {font-weight: 400; font-size: 15px; color: #666666;}
.satisfaction-body {padding: 20px 40px;}
.question {}
.question-item {}
.question-item ~ .question-item {margin-top: 20px;}
.question-ask {font-weight: 400; font-size: 18px; color: #333333;}
.question-ask .pen-text {display: inline-block; position: relative;}
.question-ask .pen-text::before {content: ''; width: 105%; height: 20px; border-radius: 10px; background-color: #E1F1FF; position: absolute; bottom: -5px; left: -5px; z-index: -1;}
.question-ans {padding-top: 13px; display: flex; align-items: center; gap: 40px;}
.question-ans .question-input {display: flex; align-items: center; gap: 5px;}
.question-ans .question-input .i-input {border: 1px solid #D9D9D9; border-radius: 3px; height: 40px; min-width: 180px; padding: 0 15px; font-weight: 400; font-size: 16px; color: #000000;}
.question-ans .question-input button[type="submit"] {height: 40px; display: flex; align-items: center; justify-content: center; font-weight: 500; font-size: 16px; background-color: #FFFFFF; border: 1px solid #000000; border-radius: 3px; padding: 0 20px; width: 100px; appearance: none; -webkit-appearance: none; color: var(--black-color);}

.radio-wrap {display: flex; align-items: center; gap: 10px 20px; flex-wrap: wrap;}
.radio-wrap.center {justify-content: center;}
.radio-item {}
.radio-item input[type=radio] {appearance: none; margin: 0;}
.radio-item input[type=radio] + label {position: relative; font-weight: 400; font-size: 17px; padding-left: 30px; cursor: pointer;}
.radio-item input[type=radio] + label::before {content: ''; width: 22px; height: 22px; border-radius: 50%; border: 1px solid #D9D9D9; position: absolute; top: -2px; left: 0; background-color: var(--white-color);}
.radio-item input[type=radio] + label::after {content: ''; width: 14px; height: 14px; border-radius: 50%; position: absolute; top: 3px; left: 5px; background-color: var(--main-color); opacity: 0;}
.radio-item input[type=radio]:checked + label::before {border-color: var(--main-color);}
.radio-item input[type=radio]:checked + label::after {opacity: 1;}

.radio-item input[type=radio]:focus + label::before {outline: 3px dotted #ff0000;}

@media screen and (max-width:1024px) {
  .satisfaction-head {padding: 20px;}
  .satisfaction-body {padding: 20px;}
  .satisfaction-info-item {font-size: 15px;}
  .satisfaction-info-item i {font-size: 18px;}
  .satisfaction-caution p {line-height: 1.2;}
  .question-ask {font-size: 16px;}
  .question-ans {gap: 10px; flex-direction: column; align-items: flex-start; padding-top: 20px;}
  .question-ans .question-input {width: 100%;}
  .question-ans .question-input .i-input {width: calc(100% - 100px - 5px); font-size: 15px; padding: 0 10px;}
  .question-ans .question-input .i-input::placeholder {font-size: 15px;}

  .radio-wrap {gap: 10px;}
  .radio-item input[type=radio] + label {font-size: 15px; padding-left: 24px;}
  .radio-item input[type=radio] + label::before {width: 18px; height: 18px; top: -1px;}
  .radio-item input[type=radio] + label::after {width: 12px; height: 12px; left: 4px;}
}
@media screen and (max-width:768px) {
  .sub-foot {margin-top: 60px;}
  .satisfaction-info {flex-direction: column; gap: 5px; align-items: flex-start;}
  .satisfaction-info-item {line-height: 1;}
  .satisfaction-info-item::before {display: none;}
  .satisfaction-caution p {font-size: 14px;}
  .question-ask {font-size: 15px;}
  .question-ans .question-input .i-input {font-size: 14px; height: 36px;}
  .question-ans .question-input .i-input::placeholder {font-size: 14px;}
  .question-ans .question-input button[type="submit"] {font-size: 14px; padding: 0 10px; height: 36px;}
}
@media screen and (max-width:425px) {
  .sub-foot {margin-top: 40px;}
  .satisfaction-info-item {font-size: 14px;}
  .satisfaction-info-item i {font-size: 16px;}
  .satisfaction-caution p {font-size: 14px;}
  .question-ask {font-size: 14px;}
  .question-ask .pen-text::before {height: 14px;}
  .question-ans {padding-top: 14px;}
  .question-ans .question-input .i-input {font-size: 13px; padding: 0 8px; height: 32px; width: calc(100% - 75px);}
  .question-ans .question-input .i-input::placeholder {font-size: 13px;}
  .question-ans .question-input button[type="submit"] {width: 70px; font-size: 13px; padding: 0 8px; height: 32px;}

  .radio-item input[type=radio] + label {font-size: 13px; padding-left: 20px;}
  .radio-item input[type=radio] + label::before {width: 15px; height: 15px;}
  .radio-item input[type=radio] + label::after {width: 9px; height: 9px;}
}
/* } 만족도 조사 */

/* ====================  반응형 ==================== */
@media screen and (max-width:1800px) {
  /* Header */
  .header .wrapper {padding: 0 1.5rem;}

  /* Footer */
  .page-top-btn {right: 1.5rem; bottom: 1.5rem;}

  /* Common */
  .wrapper {width: 100%; padding-left: 1.5rem; padding-right: 1.5rem;}

}
@media screen and (max-width:1640px) { /* 서브용 쿼리 구간 */
  /* Common */
  .wrapper2 {width: 100%; padding-left: 1.5rem; padding-right: 1.5rem;}

}
@media screen and (max-width:1440px) {
  /* Header */
  .header-content {height: 80px;}
  .header-content .logo {width: 150px;}
  .rnb-sns-links {gap: 5px;}
  .rnb-sns-link {width: 34px;}
  .rnb-item {display: none;}
  .rnb-item.mobile-menu {display: block;}

  .gnb {display: none;}

  /* Footer */
  .footer {padding: 30px 0;}
  .footer-content {flex-direction: column-reverse;}
  .footer-content-left {width: 100%; margin-top: 20px;}
  .footer-content-right {width: 100%; flex-direction: row; justify-content: space-between; align-items: center;}
  .footer-logo {width: 150px;}
  .footer-copyright {display: none;}
  .footer-btns {margin-top: 0;}
  .footer-info {margin-top: 10px; padding-top: 10px; justify-content: flex-start; gap: 0 20px;}
  .footer-info-item {display: flex; align-items: center; gap: 0 10px;}
  .footer-info-item .content {margin-top: 0;}
  .footer-content-left .footer-copyright {display: block;}

  .page-top-btn {width: 46px; border-radius: 2px; font-size: 22px;}

  /* Common */

  /* Sub */
  .sub {padding-top: 80px;}

  .sub-common {margin-top: 50px;}
  .sub-page-title .title {font-size: 40px;}
  .sub-page-title .text {font-size: 16px;}

}
@media screen and (max-width:1024px) {
  /* Header */
  .header-content {height: 60px;}
  .header-content .logo {width: 132px;}

  .menu-head {height: 60px;}
  .menu-body {height: calc(100% - 60px);}

  /* Footer */
  .footer-logo {width: 132px;}
  .footer-relate-btn {height: 40px; padding: 0 12px;}
  .footer-relate-list {padding: 10px;}

  .footer-copyright {font-size: 15px;}

  .page-top-btn.is-end {bottom: 230px;}

  /* Common */

  /* Sub */
  .sub {padding-top: 60px;}

  .sub-page-title {padding-bottom: 20px;}
  .sub-page-title .title {font-size: 34px;}
  .sub-page-title .text {font-size: 15px; margin-top: 10px;}

  .sub-location-ul {height: 50px; gap: 0 10px;}
  .sub-location-li {gap: 0 10px;}
  .sub-location-btn {font-size: 15px;}

}
@media screen and (max-width:768px) {
  /* Header */
  .header {backdrop-filter: none;}
  .header .wrapper {padding: 0 1rem;}
  .header-content .logo {width: 120px;}
  .menu-btn {width: 24px;}
  .menu-btn span::before {top: -8px;}
  .menu-btn span::after {top: 8px;}

  .menu-head .rnb-sns-link {width: 24px;}
  .menu-close-btn {width: 24px; font-size: 20px;}
  .menu-depth1-btn {font-size: 18px;}
  .menu-depth2 {padding: .5rem;}
  .menu-depth2-link {font-size: 16px;}

  /* Footer */
  .footer-content-right {flex-direction: column; align-items: flex-start; gap: 20px 0;}
  .footer-logo {display: none;}
  .footer-info {flex-direction: column; align-items: flex-start; gap: 0;}
  .footer-info-item {font-size: 15px;}
  .footer-info-item ~ .footer-info-item {margin-top: 4px;}
  .footer-copyright {font-size: 13px; margin-top: 10px;}
  .footer-relate-btn {font-size: 14px;}
  .footer-content-left {margin-top: 10px;}
  .footer-btns {gap: 0 10px;}
  .footer-btn {font-size: 15px;}
  .footer-btn::before {display: none;}

  .page-top-btn {right: 1rem; bottom: 1rem; width: 34px; font-size: 20px;}

  /* Common */
  .wrapper {padding-left: 1rem; padding-right: 1rem;}
  .wrapper2 {padding-left: 1rem; padding-right: 1rem;}

  /* Sub */
  .sub-section ~ .sub-section {margin-top: 30px;}

  .sub-page-title .title {font-size: 26px;}
  .sub-page-title .text {font-size: 13px;}

  .sub-contents {padding-top: 30px; padding-bottom: 60px;}

  .sub-location {display: none;}

}
@media screen and (max-width:425px) {
  /* Header */

  /* Footer */
  .footer-info-item {align-items: flex-start; font-size: 14px; gap: 0 5px;}
  .footer-btn {font-size: 14px;}
  .footer-relate-site {width: 100%;}
  .footer-relate-btn {width: 100%; border-radius: 2px; height: 34px;}

  .page-top-btn.is-end {bottom: 280px;}

  /* Common */
  html, body {font-size: 12px;}

  /* Sub */
  .sub-page-title .title {font-size: 22px;}
  .sub-page-title .text {display: none;}

}