﻿:root {
  --header-h: 120px;
  --hero-text: #ffffff;
  --hero-shadow: 0 2px 12px rgba(0,0,0,.45);
  --black: #111111;
  --dark: #1a1a1a;
  --white: #ffffff;
  --gray-50: #f8f8f8;
  --gray-100: #f2f2f2;
  --gray-200: #e3e3e3;
  --gray-300: #d0d0d0;
  --gray-500: #888888;
  --gray-700: #4f4f4f;
  --point: #ff1f67;
  --deep-blue: #121826;
  --content-max: 1280px;
  --radius: 18px;
  --shadow: 0 10px 30px rgba(0,0,0,.12);
}

* { box-sizing: border-box; }
html {scroll-behavior: smooth;}
body {margin: 0; color: #111111; background: #fff; line-height: 1.45; font-family: "Pretendard", "Noto Sans KR", "Malgun Gothic", sans-serif;}
a {color: inherit; text-decoration: none;}
button {font: inherit; cursor: pointer; border: 0; background: none;}
/*img {display: block; max-width: 100%;}*/
ul, ol {margin: 0; padding: 0; list-style: none;}

.wrap {min-height: 100vh; overflow-x: hidden;}

.container {width: min(calc(100% - 40px), var(--content-max)); margin: 0 auto;}

/* header */
.header              {position: sticky; inset: 0 0 auto 0; z-index: 1000; height: var(--header-h); transition: background .25s ease, box-shadow .25s ease; color: #fff;}
.header.is-solid     {background: rgba(0,0,0,.88); box-shadow: 0 4px 16px rgba(0,0,0,.22); backdrop-filter: blur(8px);}
.header__inner       {width: min(calc(100% - 40px), 1680px); height: 100%; margin: 0 auto; display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 10px;}
.header__upper       {display: flex; justify-content: flex-end; align-items: center; gap: 8px; width: 100%;}
.header__under       {display: flex; justify-content: space-between; align-items: center; gap: 24px; width: 100%;}


.main-page #header,
.main-page .header{
    position: fixed !important;
    top:0;
    left:0;
    right:0;
    z-index:1000;
}
.brand               {display: flex; align-items: center; gap: 14px; min-width: 220px;}
.brand__logo         {height:50px;}
.brand__text         {font-size: 1.65rem; font-weight: 500; letter-spacing: -0.03em; text-shadow: var(--hero-shadow); white-space: nowrap; }

.gnb {display: flex; align-items: center; justify-content: center;  flex: 1 1 auto;}/*gap: clamp(28px, 4vw, 90px);*/
.gnb a {position: relative; font-size: 1.3rem; font-weight: 600; text-shadow: var(--hero-shadow);}
.gnb a::after {content: ""; position: absolute; left: 0; bottom: -10px; width: 100%; height: 3px; border-radius: 99px; background: var(--point); transform: scaleX(0); transform-origin: center;
               transition: transform .25s ease;}
.gnb a:hover::after,
.gnb a:focus-visible::after {transform: scaleX(1);}

.util {display: flex; justify-content: flex-end; align-items: center; gap: 16px; white-space: nowrap; min-width: 240px;}
.util a {font-size: .92rem; font-weight: 700; text-shadow: var(--hero-shadow);}
.menu-btn {width: 52px; height: 52px; border-radius: 50%; display: grid; place-items: center; position: relative; 
           background: rgba(0,0,0,.22); border: 1px solid rgba(255,255,255,.18); backdrop-filter: blur(6px);}
.menu-btn span,
.menu-btn::before,
.menu-btn::after {content: ""; position: absolute; width: 24px; height: 3px; background: #fff; border-radius: 99px; transition: .25s ease;}
.menu-btn span { transform: translateY(0); }
.menu-btn::before { transform: translateY(-8px); }
.menu-btn::after { transform: translateY(8px); }
.menu-btn[aria-expanded="true"] span { opacity: 0; }
.menu-btn[aria-expanded="true"]::before { transform: rotate(45deg); }
.menu-btn[aria-expanded="true"]::after { transform: rotate(-45deg); }

.mobile-panel {position: fixed; inset: var(--header-h) 0 auto auto; width: min(86vw, 380px); background: rgba(8,8,8,.96); color: #fff; padding: 22px;
               border-radius: 0 0 0 24px; box-shadow: 0 18px 40px rgba(0,0,0,.28); transform: translateX(110%); transition: transform .25s ease; z-index: 999;}
.mobile-panel.is-open {transform: translateX(0);}
.mobile-panel nav,
.mobile-panel .mobile-util {display: grid; gap: 12px;}
.mobile-panel nav a,
.mobile-panel .mobile-util a {display: block; padding: 14px 12px; border-radius: 14px; background: rgba(255,255,255,.06); font-weight: 700;}
.mobile-panel .mobile-util   {margin-top: 16px;}

/* hero */
.hero {position: relative; min-height: 100svh; height: 100svh; color: var(--hero-text); background: #000; overflow: hidden;}
.hero::before {content: ""; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(0,0,0,.45) 0%, rgba(0,0,0,.15) 28%, rgba(0,0,0,.28) 60%, rgba(0,0,0,.48) 100%);
               z-index: 1; pointer-events: none;}
.hero__slides {position: absolute; inset: 0;}
.hero__slide  {position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0; transform: scale(1.05); transition: opacity .9s ease, transform 5.8s ease;}
.hero__slide.is-active {opacity: 1; transform: scale(1);}
.hero__slide::after {content: ""; position: absolute; inset: 0; background: rgba(0,0,0,.15);}

/*메인 이미지*/
.visual-img-01 {background-image:url("/reservation/images/website/main/visual-img-01.png");}
.visual-img-02 {background-image:url("/reservation/images/website/main/visual-img-02.png");}
.visual-img-03 {background-image:url("/reservation/images/website/main/visual-img-03.png");}
/*.visual-img-04 {background-image:url("/reservation/images/website/main/visual-img-04.png");}*/

/*메인 슬라이드 이미지*/
.hero__slide

.hero__content {position: relative; z-index: 2; height: 100%; padding-top: var(--header-h);}
.hero__copy {position: absolute; left: 50%; top: 48%; transform: translate(-50%, -50%); text-align: center; width: min(92vw, 1000px); text-shadow: 0 2px 14px rgba(0,0,0,.55);}
.hero__copy .eyebrow {font-size: clamp(1.55rem, 2.1vw, 2.4rem); font-weight: 500; margin-bottom: 14px; letter-spacing: -0.03em;}
.hero__copy .title {font-size: clamp(2.8rem, 4vw, 5.1rem); line-height: 1.13; font-weight: 800; letter-spacing: -0.05em; margin: 0;}
.swimming-link {padding: 25px 0 0;}
.swimming-link button {height: 79px; border: 2px solid #fff; color: #fff; padding: 0 15px; font-size: 1.225rem;}
.swimming-link button:hover {border: 2px solid #ffffff; background-color: #fff; color: #000;}

.hero-facility      {position: absolute; left: 8px; top: 55%; transform: translateY(-50%); z-index: 3; display: flex; flex-direction: column; gap: 8px; width: 146px;}
.hero-facility__btn {width: 160px; min-height: 74px; padding: 8px 8px; border-radius: 10px; color: #fff; background: rgba(76,76,76,.82); border: 1px solid rgba(255,255,255,.16); backdrop-filter: blur(4px);
                     display: grid; place-items: center; gap: 6px; text-align: center; font-size: .92rem; font-weight: 700; box-shadow: 0 8px 24px rgba(0,0,0,.18);
                     transition: transform .2s ease, background .2s ease;}
.hero-facility__btn.is-active,
.hero-facility__btn:hover,
.hero-facility__btn:focus-visible {background: rgba(0,0,0,.86); transform: translateX(4px);}
.hero-facility__icon              {height: 40px;}

.hero-mobile-links {display: none;}

.tool-circle {width: 60px; height: 60px; border-radius: 50%; background: rgba(255,255,255,.92); color: #111; font-size: 1.6rem; font-weight: 800;
              display: grid; place-items: center; color: #fff; box-shadow: 0 10px 24px rgba(0,0,0,.2);}
.tool-circle--my {background: var(--point); color: #fff; font-size: 1.35rem;}
.tool-rect {width: 100px; min-height: 84px; display: flex; flex-direction: column; justify-content: center; border-radius: 16px; color: #fff; padding: 10px 8px; gap: 8px;
            background: rgba(0,0,0,.76); box-shadow: 0 10px 24px rgba(0,0,0,.2);}
.font-tool__label {font-size: .925rem; font-weight: 500; line-height: 1.15; text-align: center;}
.font-tool__actions {display: flex; align-items: center; justify-content: center; gap: 1px; font-size: 1.5rem; font-weight: 900;}
.font-zoom-in-btn,
.font-zoom-out-btn {width: 50%; border: 1px solid #fff; color: #fff; height: 40px;}
.font-zoom-in-btn  {border-radius: 50% 0 0 50%;}
.font-zoom-out-btn {border-radius: 0 50% 50% 0;}

.font-tool__percent {display: inline-flex; align-items: center; justify-content: center; min-width: 52px; padding: 3px 10px; border-radius: 999px;
                     font-size: .95rem; font-weight: 800; background: #fff; color: #111;}

.scroll-bullets {display: flex; flex-direction: column; gap: 12px; align-items: center;}
.scroll-bullets button {width: 14px; height: 14px; border-radius: 50%; border: 2px solid rgba(255,255,255,.9); background: transparent; transition: transform .2s ease, background .2s ease;}
.scroll-bullets button.is-active {background: var(--point); border-color: var(--point); transform: scale(1.15);}

.hero-video {position: absolute; right: 92px; bottom: 54px; width: min(27vw, 330px); aspect-ratio: 16 / 9; z-index: 3; border-radius: 22px;
             background: rgba(0,0,0,.9); box-shadow: 0 16px 32px rgba(0,0,0,.28); overflow: hidden;}
.hero-video__button {width: 100%; height: 100%; color: #fff; display: grid; place-items: center; position: relative;}
.hero-video__button::before {content: ""; border-style: solid; border-width: 34px 0 34px 52px; border-color: transparent transparent transparent #fff; margin-left: 8px;}

.hero-pagination {position: absolute; left: 50%; bottom: 18px; display: flex; align-items: center; gap: 16px; justify-content: center; min-width: 220px;
                  transform: translateX(-50%); z-index: 3; padding: 12px 22px; border-radius: 999px; background: rgba(0,0,0,.8); box-shadow: 0 12px 24px rgba(0,0,0,.22); color: #fff;}
.hero-pagination__count {font-size: 1.65rem; font-weight: 800; letter-spacing: -0.03em;}
.hero-pagination__count em {color: var(--point); font-style: normal;}
.hero-pagination__controls {display: flex; align-items: center; gap: 10px;}
.hero-pagination__controls button {color: #fff; font-size: 1.2rem; font-weight: 800;}

/* sections */
.section {position: relative; scroll-margin-top: calc(var(--header-h) + 10px);}
.main-content {background: #f1f1f1; padding: 28px 0 0;}
.main-grid {display: grid; grid-template-columns: minmax(0, 1.7fr) minmax(290px, .72fr); gap: 26px; align-items: start;}
.block-title {display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px;}
.block-title h2 {margin: 0; font-size: 2rem; letter-spacing: -0.04em; line-height: 1.2;}
.more-btn {display: inline-flex; align-items: center; justify-content: center; height: 40px; padding: 0 18px; background: #000; color: #fff; border-radius: 0; font-size: .98rem;font-weight: 700;}

notice
.notice-tabs {display: flex; flex-wrap: wrap; gap: 22px; margin-bottom: 12px; padding-inline-end: 140px;}
.notice-tab {position: relative; color: #444; font-size: 1rem; font-weight: 500; padding: 4px 0;}
.notice-tab.is-active {color: #111; font-weight: 800;}
.notice-head-controls {position: absolute; right: 0; top: 46px; display: flex; gap: 6px;}
.mini-nav-btn {min-width: 48px; height: 42px; background: #fff; border: 1px solid #999; box-shadow: 2px 2px 0 rgba(0,0,0,.14); font-size: 1.55rem; font-weight: 900; display: grid; place-items: center;}

.notice-board {border: 1px solid #858585; background: #f3f3f3;}
.notice-board__headline {display: grid; grid-template-columns: 120px 1fr; min-height: 78px; border-bottom: 1px solid #666;}
.notice-board__date {background: #000; color: #fff; display: grid; place-items: center; text-align: center; font-weight: 800; font-size: 1.05rem; line-height: 1.15; letter-spacing: -0.02em;}
.notice-board__top-title {display: flex; align-items: center; padding: 0 22px; font-size: 1.05rem; font-weight: 700;}
.notice-list {padding: 2px 22px 1px;}
.notice-list li {display: grid; grid-template-columns: 1fr auto; gap: 18px; align-items: center; min-height: 42px; font-size: 1rem;}
.notice-list li + li {margin-top: 2px;}
.notice-list time {color: #7a7a7a; font-size: .95rem;}

/*alarm*/

.alarm-card {background: #fff; border-radius: 14px; overflow: hidden; box-shadow: var(--shadow);}
.alarm-visual {position: relative; background: linear-gradient(180deg, #0b87d5 0%, #1697e8 100%); min-height: 238px; padding:0px; color: #fff;}
.alarm-visual__title {font-size: 1.2rem; font-weight: 700; text-align: center; margin-bottom: 18px;}
.alarm-visual__board {display: grid; place-items: center; font-size: 3rem; font-weight: 900; letter-spacing: -0.05em; text-shadow: 0 3px 10px rgba(0,0,0,.16); margin-bottom: 16px;}
.alarm-visual__line {height: 18px; background: rgba(255,255,255,.9); color: #0b78bd; display: grid; place-items: center; font-size: .76rem; font-weight: 700; margin-bottom: 12px;}
.alarm-visual__desc {text-align: center; font-size: .88rem; line-height: 1.5; opacity: .97;}
.alarm-footer {display: flex; align-items: center; justify-content: center; gap: 16px; padding: 10px 18px; background: #222; color: #fff; font-weight: 800; font-size: 1.65rem;}
.alarm-footer__count em {color: var(--point); font-style: normal;}
.alarm-footer button {color: #fff; font-size: 1.15rem; font-weight: 900;}
.alarm-visual{
    height:240px;
    overflow:hidden;
}

.alarm-slide img{
    width:100%;
    height:100%;
    object-fit:cover;
}
.mid-sections {padding: 18px 0 26px;}
.mid-grid {display: grid; grid-template-columns: 250px minmax(0, 1fr); gap: 22px; align-items: start;}

.voice-card {min-height: 245px; border-radius: 12px; background: #dce9f4; padding: 26px 22px; box-shadow: inset 0 0 0 1px rgba(0,0,0,.06); position: relative; overflow: hidden;}
.voice-card h3,
.facility-links h3 {margin: 0 0 0px; font-size: 1.95rem; letter-spacing: -0.05em; line-height: 1.2;}
.voice-card p {margin: 0; font-size: 1.05rem; color: #2a2a2a; line-height: 1.45; word-break: keep-all;}
.voice-card strong {display: block; margin-top: 12px; color: #0f3f86; font-size: 1.12rem;}
.voice-card::after {content: "◔"; position: absolute; right: 20px; bottom: 8px; font-size: 5rem; color: rgba(18,45,88,.48); line-height: 1;}

.facility-links h3 {margin-bottom: 16px;}
.facility-grid {display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px;}
.facility-card {display: flex; align-items: center; gap: 16px; min-height: 84px; border-radius: 10px; padding: 16px 16px; border: 1px solid rgba(0,0,0,.14);
                box-shadow: inset 0 0 0 1px rgba(255,255,255,.35); transition: transform .18s ease, box-shadow .18s ease;}
.facility-card:hover,
.facility-card:focus-visible {transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,.08);}
.facility-card:nth-child(8n+1),
.facility-card:nth-child(8n+8) { background: #ead9cb; }
.facility-card:nth-child(8n+2),
.facility-card:nth-child(8n+3) { background: #dce8d0; }
.facility-card:nth-child(8n+4),
.facility-card:nth-child(8n+5),
.facility-card:nth-child(8n+6) { background: #d5e0eb; }
.facility-card:nth-child(8n+7) { background: #efe1b7; }
.facility-card__icon {flex: 0 0 auto; border: 2px solid #435163; border-radius: 14px; display: grid; place-items: center; font-size: 1.55rem; font-weight: 800;
                      width: 48px; height: 48px; color: #435163; background: rgba(255,255,255,.26);}
.facility-card__text {min-width: 0; line-height: 1.2;}
.facility-card__text .sub {display: block; font-size: .93rem; color: #333; font-weight: 600; margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}
.facility-card__text .name {display: block; font-size: 1rem; font-weight: 800; letter-spacing: -0.04em;}

.footer {background: linear-gradient(180deg, #1d2332 0%, #00477A 100%); color: #fff; margin-top: 22px;}
.footer__inner {width: min(calc(100% - 40px), var(--content-max)); margin: 0 auto; padding: 36px 0 32px;}
.footer__brand {display: flex; align-items: center; gap: 14px; margin-bottom: 28px; opacity: .95;}
.footer__brand-mark {width: 50px; height: 50px; border-radius: 14px; background: linear-gradient(140deg, #8e96aa, #60677b); display: grid; place-items: center; font-size: 1.7rem; font-weight: 900;}
.footer__brand-text {font-size: 1.8rem; font-weight: 700; line-height: 1.15; letter-spacing: -0.04em;}
.footer__brand-text small {display: block; margin-top: 2px; font-size: .8rem; font-weight: 500; opacity: .8;}
.footer__info {font-size: 1.02rem; color: rgba(255,255,255,.86); line-height: 1.75;}
.footer__line {height: 1px; background: rgba(255,255,255,.18); margin: 26px 0 18px;}
.footer__bottom {display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; font-size: .98rem; color: rgba(255,255,255,.88);}
.footer__links {display: flex; flex-wrap: wrap; gap: 18px; font-weight: 600;}
.footer__links a:first-child,
.footer__links a:last-child {color: #7ab0ff;}

.floating-nav {display: flex; position: fixed; right: 16px; top: 45%; transform: translateY(-50%); z-index: 950; flex-direction: column; align-items: center; gap: 16px;}
.floating-nav .tool-circle,
.floating-nav .tool-rect {box-shadow: 0 12px 24px rgba(0,0,0,.16);}
.floating-nav .scroll-bullets button {border-color: #aaa;}

/* modal */
.video-modal {position: fixed; inset: 0; z-index: 1200; display: none; align-items: center; justify-content: center; padding: 20px; background: rgba(0,0,0,.72); }
.video-modal.is-open {display: flex;}
.video-modal__dialog {width: min(100%, 960px); aspect-ratio: 16 / 9; background: #000; border-radius: 18px; overflow: hidden; position: relative; box-shadow: 0 24px 60px rgba(0,0,0,.35);}
.video-modal__close {position: absolute; right: 12px; top: 12px; width: 44px; height: 44px; border-radius: 50%; background: rgba(0,0,0,.6); color: #fff; font-size: 1.5rem; z-index: 1;}
.video-modal iframe {width: 100%; height: 100%; border: 0;}

/* btn */
.btn-sm {height: 30px; padding: 0 10px; font-size: .97rem; font-weight: 500;}
.btn-pink-outline {border: 1px solid #ff1f67; color: #ff1f67;}
.btn-bright-blue-outline {border: 1px solid #50fbf8; color: #50fbf8;}
.btn-bright-blue-outline:hover {background-color:#50fbf8; color: #000000;}

.d-none {display: none;}

/* responsive */
@media (max-width: 1480px) {
    .hero-facility {width: 132px;}
    .hero-facility__btn {min-height: 68px; font-size: .86rem;}
    .hero-video {width: min(25vw, 280px);}
}

@media (max-width: 1200px) {
    :root { --header-h: 82px; }
    .gnb {gap: 34px;}
    .gnb a {font-size: 1.12rem;}
    .util {min-width: auto;}
    .hero-facility {left: 12px; width: 118px;}
    .hero-video {right: 84px; bottom: 74px;}
    .main-grid,
    .mid-grid {grid-template-columns: 1fr;}
    .facility-grid {grid-template-columns: repeat(3, minmax(0, 1fr));}
}

@media (max-width: 960px) {
    :root { --header-h: 76px; }
    .header {background: rgba(16,18,22,.88); box-shadow: 0 4px 14px rgba(0,0,0,.18); backdrop-filter: blur(8px);}
    .header__inner {width: min(calc(100% - 24px), 100%); gap: 12px;}
    .brand__text {font-size: 1.06rem;}
    .gnb,
    .util a {display: none;}
    .util {gap: 10px; min-width: auto;}
    .menu-btn {width: 48px; height: 48px;}
    .hero {min-height: auto; height: auto; padding-top: var(--header-h);}
    .hero__slides,
    .hero__slide {position: absolute; inset: 0;}
/*     .hero__content {min-height: calc(100svh - var(--header-h));} */
    .hero__copy {top: 22%; transform: translate(-50%, 0); width: min(92vw, 640px);}
    .hero__copy .eyebrow {font-size: 1.4rem; margin-bottom: 8px;}
    .hero__copy .title {font-size: 2.65rem;}
    .hero-facility {display: none;}
    .hero-mobile-links {display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px 8px; position: absolute; left: 50%; top: 75%;
                        transform: translateX(-50%); z-index: 3; width: calc(100% - 24px); max-width: 720px;}
    .hero-mobile-links a {min-height: 62px; background: rgba(0,0,0,.34); border-top: 1px solid rgba(255,255,255,.18); border-bottom: 1px solid rgba(255,255,255,.18);
                          color: white important! display: grid; place-items: center; text-align: center; padding: 8px 4px; font-size: .92rem; font-weight: 700; backdrop-filter: blur(2px);}
    .hero-mobile-links span {display: block; font-size: 1.35rem; margin-bottom: 3px;}
    .tool-circle {width: 54px; height: 54px; font-size: 1.45rem;}
    .hero-video {position: absolute; left: 50%; right: auto; bottom: 72px; transform: translateX(-50%); width: calc(100% - 84px); max-width: 440px;}
    .hero-pagination {display: none;}
    .main-content {padding-top: 20px;}
    .block-title h2 {font-size: 1.72rem;}
    .notice-tabs {gap: 16px; padding-inline-end: 118px; font-size: .94rem;}
    .notice-head-controls {top: 42px;}
    .facility-grid {grid-template-columns: repeat(2, minmax(0, 1fr));}
    .footer__brand-text {font-size: 1.5rem;}

    .floating-nav {bottom: 50px;}
}

@media (max-width: 640px) {
    :root {--header-h: 72px;}
    html {font-size: 15px;}
    .container,
    .footer__inner {width: calc(100% - 24px);}
    .header__inner {width: calc(100% - 24px);}
    .brand {min-width: auto; gap: 10px;}
    .brand__mark {width: 40px; height: 40px;}
    .brand__mark::before {font-size: 24px;}
    .brand__text {font-size: 1rem;}
    .hero__content {min-height: calc(100svh - var(--header-h));}
    .hero__copy {top: 13.5%; width: calc(100% - 28px);}
    .hero__copy .eyebrow {font-size: 1rem;}
    .hero__copy .title {font-size: 2.05rem; line-height: 1.2;}
    .hero-mobile-links {top: 65%; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 8px 6px;}
    .hero-mobile-links a {min-height: 56px; font-size: .8rem; padding: 6px 4px;}
    .hero-mobile-links span {font-size: 1.18rem; margin-bottom: 2px;}
    .tool-circle {width: 48px; height: 48px; font-size: 1.25rem;}
    .font-tool__label {font-size: .75rem;}
    .font-tool__actions {font-size: 1.25rem; gap: 6px;}
    .font-tool__percent {min-width: 44px; font-size: .82rem;}
    .hero-video {width: calc(100% - 48px); bottom: 84px; border-radius: 18px;}
    .scroll-bullets {gap: 10px;}
    .scroll-bullets button {width: 12px; height: 12px;}
    .block-title {align-items: flex-start;}
    .block-title h2 {font-size: 1.82rem;}
    .more-btn {height: 36px; padding-inline: 14px; font-size: .88rem;}
    .notice-tabs {gap: 14px; padding-inline-end: 106px; font-size: .9rem; overflow-x: auto; flex-wrap: nowrap; scrollbar-width: none;}
    .notice-tabs::-webkit-scrollbar {display: none;}
    .notice-head-controls {top: 40px;}
    .mini-nav-btn {min-width: 40px; height: 38px; font-size: 1.35rem;}
    .notice-board__headline {grid-template-columns: 98px 1fr;}
    .notice-board__date {font-size: .95rem;}
    .notice-board__top-title {padding: 0 12px; font-size: .96rem;}
    .notice-list {padding: 14px 12px;}
    .notice-list li {grid-template-columns: minmax(0, 1fr) auto; min-height: 34px; gap: 10px; font-size: .95rem;}
    .notice-list li a {white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}
    .alarm-visual {min-height: 230px; padding-inline: 14px;}
    .alarm-visual__board {font-size: 2.4rem;}
    .voice-card {min-height: auto; padding: 20px 16px 60px;}
    .voice-card h3,
    .facility-links h3 {font-size: 1.7rem;}
    .facility-grid {grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px;}
    .facility-card {min-height: 78px; gap: 10px; padding: 12px 12px;}
    .facility-card__icon {width: 40px; height: 40px; font-size: 1.2rem; border-radius: 12px;}
    .facility-card__text .sub {font-size: .8rem;}
    .facility-card__text .name {font-size: 1rem;}
    .footer__inner {padding-top: 28px;}
    .footer__brand {margin-bottom: 18px;}
    .footer__brand-mark {width: 44px; height: 44px; font-size: 1.45rem;}
    .footer__brand-text {font-size: 1.28rem;}
    .footer__info,
    .footer__bottom {font-size: .88rem;}
    .footer__links {gap: 10px 14px;}
}

/* ===== 메인페이지 헤더 겹침 처리 ===== */

.main-page .header{
    background: transparent;
    box-shadow: none;
}

.main-page .hero{
    margin-top: 0px;
}

.main-page .main-content{
    margin-top: var(--header-h);
}
/* 메인페이지 헤더 투명 */
.main-page #header{
    background: transparent;
    box-shadow: none;
}

.main-page #header .inr{
    background: transparent;
}
.main-page #header > .inr > nav > .gnb > li > a{
    color:#fff;
}
#header.is-solid{
    background:#fff !important;
}

.site-logo{
    margin:0;
}

#header .site-logo a{
    display:flex !important;
    align-items:center;
    gap:12px;
}
.site-logo img{
    height:60px;
    width:auto;
    display:block;
}

.site-logo span{
    font-size:28px;
    font-weight:600;
    color:inherit;
    white-space:nowrap;
}
/* 1차 메뉴 */
.main-page #header .gnb > li > a{
    color:#fff;
}

/* 2차 메뉴 */
#header .gnb > li > ul.sub_menu > li > a{
    color:#111;
}

/* 3차 메뉴 */
#header .gnb > li > ul.sub_menu > li > ul > li > a{
    color:#111;
}
.hero-facility__btn,
.hero-facility__btn:link,
.hero-facility__btn:visited,
.hero-facility__btn:hover,
.hero-facility__btn:active{
    color:#fff !important;
}

/* 960px 이하에서 홍보영상 숨김 */
@media (max-width:960px){
    .hero-video{
        display:none !important;
    }
     #header{
        position: relative !important;
    }

    .main-page #header .inr{
        background:#0e1220 !important;
    }
    .hero-facility__mob{
    color:white !important;
    }
    .main-page .main-content{
    margin-top: 0px;
}
/* 인스타 */
.area_util_top .sns img{
    width:25px;
    height:25px;
}

/* ===============================
   기본 (서브페이지 = 검정)
=============================== */
#header .gnb > li > a,
#header .site-logo span,
#header .util a {
    color:#111 !important;
}

/* ===============================
   메인 페이지만 흰색
=============================== */
.main-page #header .gnb > li > a,
.main-page #header .site-logo span,
.main-page #header .util a {
    color:#fff !important;
}

