@charset "UTF-8";
:root {
  --color-theme: #00c73c;
  --font-color-theme: #3a32a2;
  --font-color-default: #221816;
  --font-color-default-soft: rgba(#221816, 0.8);
  --font-color-black: #292929;
  --font-color-violet: #4a42cc;
  --font-color-blue: #182249;
  --font-color-gray: #929292;
  --font-color-gray-soft: #e6e6e6;
  --font-color-gray-pastel: #f8f8f8;
  --font-color-red: #dc3545;
  --font-color-pink: #e77786;
  --font-color-yellow: #00c73c;
  --font-color-blue: #0d6efd;
  --font-color-blue-soft: #4f9fcf;
  --link-color-hover: #06357a;
  --link-color-hover-soft: rgba(10, 88, 202, .3);
  --bg-color-gray: #ebebeb;
  --bg-color-gray-soft: #f7f7f7;
  --bg-color-violet: #f5f5ff;
  --bg-color-blue: #f6f9ff;
  --bg-color-black: #222222;
  --border-color-gray-hard: #717376;
  --border-color-gray-soft: #ebebeb;
  --border-color-gray-pastel:#f7f7f7;
  --section-gap: 120px;
  --section-padding: 95px;
}

/* http://meyerweb.com/eric/tools/css/reset/
   v2.0-modified | 20110126
   License: none (public domain)
*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* make sure to set some focus styles for accessibility */
:focus {
  outline: 0;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration,
input[type=search]::-webkit-search-results-button,
input[type=search]::-webkit-search-results-decoration {
  -webkit-appearance: none;
  -moz-appearance: none;
}

input[type=search] {
  -webkit-appearance: none;
  -moz-appearance: none;
  box-sizing: content-box;
}

textarea {
  overflow: auto;
  vertical-align: top;
  resize: vertical;
}

/**
 * Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3.
 */
audio,
canvas,
video {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  max-width: 100%;
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address styling not present in IE 7/8/9, Firefox 3, and Safari 4.
 * Known issue: no IE 6 support.
 */
[hidden] {
  display: none;
}

/**
 * 1. Correct text resizing oddly in IE 6/7 when body `font-size` is set using
 *    `em` units.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
  font-size: 100%;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
  -ms-text-size-adjust: 100%;
  /* 2 */
}

/**
 * Address `outline` inconsistency between Chrome and other browsers.
 */
a:focus {
  outline: thin dotted;
}

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
  outline: 0;
}

/**
 * 1. Remove border when inside `a` element in IE 6/7/8/9 and Firefox 3.
 * 2. Improve image quality when scaled in IE 7.
 */
img {
  border: 0;
  /* 1 */
  -ms-interpolation-mode: bicubic;
  /* 2 */
}

/**
 * Address margin not present in IE 6/7/8/9, Safari 5, and Opera 11.
 */
figure {
  margin: 0;
}

/**
 * Correct margin displayed oddly in IE 6/7.
 */
form {
  margin: 0;
}

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct color not being inherited in IE 6/7/8/9.
 * 2. Correct text not wrapping in Firefox 3.
 * 3. Correct alignment displayed oddly in IE 6/7.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  white-space: normal;
  /* 2 */
  *margin-left: -7px;
  /* 3 */
}

/**
 * 1. Correct font size not being inherited in all browsers.
 * 2. Address margins set differently in IE 6/7, Firefox 3+, Safari 5,
 *    and Chrome.
 * 3. Improve appearance and consistency in all browsers.
 */
button,
input,
select,
textarea {
  font-size: 100%;
  /* 1 */
  margin: 0;
  /* 2 */
  vertical-align: baseline;
  /* 3 */
  *vertical-align: middle;
  /* 3 */
  font-family: inherit;
}

/**
 * Address Firefox 3+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
button,
input {
  line-height: normal;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Chrome, Safari 5+, and IE 6+.
 * Correct `select` style inheritance in Firefox 4+ and Opera.
 */
button,
select {
  text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 * 4. Remove inner spacing in IE 7 without affecting normal text inputs.
 *    Known issue: inner spacing remains in IE 6.
 */
button,
html input[type=button],
input[type=reset],
input[type=submit] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
  *overflow: visible;
  /* 4 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}

/**
 * 1. Address box sizing set to content-box in IE 8/9.
 * 2. Remove excess padding in IE 8/9.
 * 3. Remove excess padding in IE 7.
 *    Known issue: excess padding remains in IE 6.
 */
input[type=checkbox],
input[type=radio] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
  *height: 13px;
  /* 3 */
  *width: 13px;
  /* 3 */
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome
 *    (include `-moz` to future-proof).
 */
input[type=search] {
  -webkit-appearance: textfield;
  /* 1 */
  /* 2 */
  box-sizing: content-box;
}

/**
 * Remove inner padding and search cancel button in Safari 5 and Chrome
 * on OS X.
 */
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Remove inner padding and border in Firefox 3+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

/**
 * 1. Remove default vertical scrollbar in IE 6/7/8/9.
 * 2. Improve readability and alignment in all browsers.
 */
textarea {
  overflow: auto;
  /* 1 */
  vertical-align: top;
  /* 2 */
}

/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

html,
button,
input,
select,
textarea {
  color: #222;
}

::-moz-selection {
  background: #b3d4fc;
  text-shadow: none;
}

::selection {
  background: #b3d4fc;
  text-shadow: none;
}

img {
  vertical-align: middle;
}

fieldset {
  border: 0;
  margin: 0;
  padding: 0;
}

textarea {
  resize: vertical;
}

.chromeframe {
  margin: 0.2em 0;
  background: #ccc;
  color: #000;
  padding: 0.2em 0;
}

@font-face {
  font-family: WOFF2_0;
  src: url(fonts/nnsn/woff2/NanumSquareNeoTTF-aLt.woff2);
}
@font-face {
  font-family: WOFF2_1;
  src: url(fonts/nnsn/woff2/NanumSquareNeoTTF-bRg.woff2);
}
@font-face {
  font-family: WOFF2_2;
  src: url(fonts/nnsn/woff2/NanumSquareNeoTTF-cBd.woff2);
}
@font-face {
  font-family: WOFF2_3;
  src: url(fonts/nnsn/woff2/NanumSquareNeoTTF-dEb.woff2);
}
@font-face {
  font-family: WOFF2_4;
  src: url(fonts/nnsn/woff2/NanumSquareNeoTTF-eHv.woff2);
}
@font-face {
  font-family: "NanumSquareNeoVF";
  src: url("fonts/nnsn/woff2/NanumSquareNeo-Variable.woff2") format("font-woff2");
  font-weight: 100 900;
  font-style: normal;
}
* {
  box-sizing: border-box;
}
*:before, *:after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
}

body {
  overflow-x: hidden;
  font-family: "Noto Sans KR", "Montserrat", "NanumSquareNeoVF", sans-serif;
  word-break: keep-all;
  letter-spacing: -0.057em;
  color: var(--font-color-default);
  min-width: 320px;
  margin: 0;
  padding: 0;
  line-height: 1.8;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  letter-spacing: inherit;
}

button, a, input, textarea {
  outline: 0;
  border: none;
  -moz-outline-style: none;
}

input {
  font-size: 16px;
}

p {
  word-break: keep-all;
}

.is-empty {
  font-size: 20px;
  padding: 50px 0;
  text-align: center;
  color: #6c757d;
  font-size: 16px;
}

.hidden,
.readonly {
  display: none !important;
}

.unselectable {
  -moz-user-select: -moz-none;
  -webkit-user-select: none;
  -o-user-select: none;
  user-select: none;
}

.clear::after {
  content: "";
  display: table;
  clear: both;
}

.sr-only {
  position: absolute;
  left: -10000px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.text-ellipsis {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.bg-cover {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

@media all and (min-width: 1025px) {
  .mb-only {
    display: none !important;
  }
}
@media all and (max-width: 1024px) {
  .pc-only {
    display: none !important;
  }
}
.svg-defs {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
}

:root {
  --theme-color: #19ac4f;
  --theme-color-dark: #148c3f;
  /* ——— Accent Colors ——— */
  --color-orange: #FF6B35;
  --color-mint: #3FE0D0;
  --color-sky: #6EC1E4;
  --color-red: #D7263D;
  --color-red-light: #d63c50;
  /* ——— Neutral Colors ——— */
  --color-gray-light: #E0E0E0;
  --color-gray: #CCCCCC;
  /* ——— 컨테이너 너비 & 분할 설정 ——— */
  --container-width: 1680px;
  --container-padding: 40px;
  --columns: 4;
  --col: calc(var(--container-width) / var(--columns));
  --offset: calc((100% - var(--container-width)) / 2 - var(--scroll-width)); /* 수정: 스크롤바 보정 추가 */
  /* ——— 선 색상 & 두께 ——— */
  --color-major: rgba(0, 0, 0, 0.06);
  --thick: 1px;
  --grid-minor: 40px;
  --color-minor: rgba(0, 0, 0, 0.03);
  --border-radius-normal: 16px;
}

#smooth-content {
  background: #fcfeff;
}

.container {
  width: 100%;
  max-width: var(--container-width);
  padding: 0 var(--container-padding);
  margin: 0 auto;
}

.container-narrow {
  max-width: 1180px;
  margin: 0 auto;
  width: 100%;
}

.wrap {
  overflow-x: hidden;
  padding-top: 102px;
}

.inner-wrap {
  min-width: 320px;
  min-height: 100vh;
}

.vertical-text {
  /* 1) 표준 속성 (Chrome, Firefox, Safari 최신) */
  writing-mode: vertical-rl; /* 수직 배치, 줄은 오른쪽→왼쪽 */
  text-orientation: upright; /* 글자 회전 없이 똑바로 세우기 */
  /* 2) WebKit 계열 접두어 */
  -webkit-writing-mode: vertical-rl;
  -webkit-text-orientation: upright;
  /* 3) IE/Edge 레거시 호환 (IE 10~11) */
  -ms-writing-mode: tb-rl;
  /* 4) 레이아웃 조정 */
  display: inline-block; /* 블록 레벨이면서 인라인 흐름에 포함 */
  padding: 0.5em; /* 여백 예시 */
  line-height: 1.4; /* 줄 간격 조절 */
}

.button-rounded {
  position: relative;
  display: inline-flex;
  height: 42px;
  align-items: center;
  justify-content: center;
  z-index: 0;
  background: var(--theme-color);
  border-radius: 8px;
  overflow: hidden;
  --tw-shadow: inset 0 -8px 10px #ffffff1f;
  transition: background-color 0.3s;
}
.button-rounded:hover {
  background: var(--theme-color-dark);
  --tw-shadow: inset 0 -6px 10px #ffffff6f;
}
.button-rounded:hover .button-color {
  background: var(--theme-color-dark);
}
.button-rounded.big {
  height: 52px;
}
.button-rounded.big .button-title {
  font-size: 18px;
}
.button-rounded.red {
  background: var(--color-red);
  --tw-shadow: inset 0 -8px 10px #ffffff1f;
  border-radius: 10px;
}
.button-rounded.red:hover {
  background: var(--color-red-light);
  --tw-shadow: inset 0 -6px 10px #ffffff6f;
}
.button-rounded.red:hover .button-color {
  background: var(--color-red-light);
}
.button-rounded.red .button-color {
  background: var(--color-red);
}
.button-rounded span {
  display: block;
}

.button-back {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  container-type: size;
  z-index: -30;
  filter: blur(2px);
}

.button-back-inner {
  position: absolute;
  animation: slide 3s ease-in-out infinite alternate;
  height: 100%;
  height: 100cqh;
  aspect-ratio: 1;
}

.button-back-image {
  background: conic-gradient(from 225deg, transparent 0, #fff 90deg, transparent 90deg);
  animation: spin-around 6s infinite linear;
  inset: -100%;
  position: absolute;
  width: 114px;
  height: 114px;
}

.button-color {
  position: absolute;
  top: 1.4px;
  left: 1.4px;
  right: 1.4px;
  bottom: 1.4px;
  background: var(--theme-color);
  inset: 1px;
  border-radius: 8px;
  z-index: -20;
  transition: background-color 0.3s;
  filter: blur(2px);
}
.button-color:hover {
  background: black;
}

.button-gradient {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  box-shadow: 0 0 rgba(0, 0, 0, 0), 0 0 rgba(0, 0, 0, 0), var(--tw-shadow);
  border-radius: 8px;
  transition-duration: 0.3s;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.button-title {
  position: relative;
  color: #fff;
  font-size: 16px;
  letter-spacing: 0;
  padding: 0 1.4em;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.08);
}
.button-title span {
  display: inline;
}

@keyframes slide {
  to {
    transform: translate(calc(100cqw - 100%));
  }
}
@keyframes spin-around {
  0% {
    transform: translateZ(0) rotate(0);
  }
  15%, 35% {
    transform: translateZ(0) rotate(90deg);
  }
  65%, 85% {
    transform: translateZ(0) rotate(270deg);
  }
  to {
    transform: translateZ(0) rotate(1turn);
  }
}
.fixed-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  max-height: 102px;
  padding: 16.52px 0;
  z-index: 5000;
  will-change: background-color, backdrop-filter, box-shadow, color;
  transition: box-shadow 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), background-color 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), color 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), -webkit-backdrop-filter 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
  transition: box-shadow 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), background-color 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), backdrop-filter 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), color 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
  transition: box-shadow 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), background-color 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), backdrop-filter 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), color 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), -webkit-backdrop-filter 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
  background: rgba(255, 255, 255, 0.6);
  box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.1);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}
.fixed-header .container-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

h1.logo a {
  display: flex;
  align-items: center;
  font-family: "Gowun Batang", serif;
}
h1.logo a img, h1.logo a svg {
  width: 300px;
}

.main-nav > ul {
  display: flex;
  gap: 80px;
}

.main-menu-title {
  padding: 18px;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0;
}

.header-ui {
  display: flex;
  align-items: center;
  gap: 80px;
}

.headline div {
  width: 0.95em;
  display: inline-block;
  line-height: 1;
}

.fixed-header.theme-white {
  color: #fff;
}
.fixed-header.theme-white svg {
  fill: #ffffff;
}
.fixed-header.theme-dark {
  color: #000;
}
.fixed-header.theme-dark svg {
  fill: #000000;
}

.main-menu-title span {
  position: relative;
}
.main-menu-title span::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 4px;
  background: var(--theme-color);
  position: absolute;
  top: -3px;
  left: -15px;
  opacity: 0;
  animation: spin 2s linear infinite;
}

.active .main-menu-title span::before,
.main-menu-title:hover span::before {
  opacity: 1;
}

.current .main-menu-title span::before {
  background-color: #d13744;
  opacity: 1;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.header-ui .btn-hamburg {
  padding: 10px;
  margin-right: -10px;
  cursor: pointer;
  display: none !important;
}

.hamburger {
  position: relative;
  display: block;
  width: 23px;
  height: 18.4px;
  backface-visibility: hidden;
  cursor: pointer;
}
.hamburger .opener .bar {
  position: absolute;
  left: 0;
  display: block;
  width: 100%;
  height: 2px;
  background: var(--theme-color);
  backface-visibility: hidden;
}
.hamburger .opener .bar.top {
  top: 0;
}
.hamburger .opener .bar.mid {
  top: 50%;
  transform: translateY(-50%);
}
.hamburger .opener .bar.bot {
  bottom: 0;
}
.hamburger .closer .bar {
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  width: 100%;
  height: 2px;
}
.hamburger .closer .bar.left {
  transform: translateY(-50%) rotate(-45deg);
}
.hamburger .closer .bar.right {
  transform: translateY(-50%) rotate(45deg);
}
.hamburger .closer .bar .bar-inner {
  display: block;
  width: 100%;
  height: 100%;
  background: #bb311f;
  backface-visibility: hidden;
}

.hamburger .opener .bar {
  transition: opacity 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), transform 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.hamburger .opener .bar.top {
  transition-delay: 0.2s;
}
.hamburger .opener .bar.mid {
  transition-delay: 0.25s;
}
.hamburger .opener .bar.bot {
  transition-delay: 0.3s;
}

.hamburger .closer .bar .bar-inner {
  transition: opacity 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), transform 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.hamburger .closer .bar.left .bar-inner {
  transition-delay: 0;
  opacity: 0;
  transform: translateX(10px);
}
.hamburger .closer .bar.right .bar-inner {
  transition-delay: 0.05s;
  opacity: 0;
  transform: translateX(-10px);
}

.btn-hamburg.active .hamburger .opener .bar.top {
  transform: translateX(-10px);
  opacity: 0;
  transition-delay: 0;
}
.btn-hamburg.active .hamburger .opener .bar.mid {
  transform: translateX(5px) translateY(-50%);
  opacity: 0;
  transition-delay: 0.05s;
}
.btn-hamburg.active .hamburger .opener .bar.bot {
  transform: translateX(-5px);
  opacity: 0;
  transition-delay: 0.1s;
}
.btn-hamburg.active .hamburger .closer .bar.left .bar-inner {
  transform: none;
  opacity: 1;
  transition-delay: 0.2s;
}
.btn-hamburg.active .hamburger .closer .bar.right .bar-inner {
  transform: none;
  opacity: 1;
  transition-delay: 0.25s;
}

.cd-morph-dropdown .dropdown-content ul > li a:hover .menu-inner {
  background: #f9fbff;
}
.cd-morph-dropdown .dropdown-content ul > li a:hover .menu-icon {
  color: #0288d1;
  background: #eef4ff;
}
.cd-morph-dropdown .dropdown-content ul > li a:hover .menu-title {
  color: #0288d1;
}
.cd-morph-dropdown .dropdown-content ul > li a:hover .menu-desc {
  color: #404674;
}

.menu-inner {
  display: flex;
  width: 100%;
  gap: 10px;
  padding: 5px;
  border-radius: 10px;
  min-width: 145px;
}

.menu-icon {
  flex: 0 0 30px;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: #fafafa;
  color: #757575;
}
.menu-icon i {
  font-size: 12px;
}

.menu-text {
  flex: 1 1 0;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  line-height: 1;
  letter-spacing: 0;
  padding-right: 20px;
}

.menu-title {
  flex: 1 1 100%;
  white-space: nowrap;
  font-size: 15px;
}

.menu-desc {
  font-size: 14px;
  flex: 1 1 100%;
  color: #919191;
  white-space: nowrap;
}

.cd-morph-dropdown {
  position: relative;
  align-items: center;
  display: flex;
  -moz-user-select: -moz-none;
  -webkit-user-select: none;
  -o-user-select: none;
  user-select: none;
}
.cd-morph-dropdown::before {
  content: "mobile";
  display: none;
}
.cd-morph-dropdown.nav-open .morph-dropdown-wrapper {
  display: block;
}
.cd-morph-dropdown .morph-dropdown-wrapper {
  display: none;
  position: absolute;
  top: 60px;
  left: 0;
  width: 100%;
  padding: 1.2em 5%;
  background-color: #FFFFFF;
}
.cd-morph-dropdown .dropdown-content li::after {
  clear: both;
  content: "";
  display: block;
}

@media only screen and (min-width: 1024px) {
  .cd-morph-dropdown::before {
    content: "desktop";
  }
  .cd-morph-dropdown .morph-dropdown-wrapper {
    display: block;
    top: 30px;
    width: auto;
    padding: 0;
    box-shadow: none;
    background-color: transparent;
    transition: all 0.3s cubic-bezier(0, 1, 1, 1);
  }
  .cd-morph-dropdown .dropdown-list {
    position: absolute;
    top: 0;
    left: 0;
    visibility: hidden;
    opacity: 0;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.03), 0 -15px 20px rgba(0, 0, 0, 0.01);
    border-radius: 14px;
    transition: all 0.3s cubic-bezier(0, 1, 1, 1);
  }
  .cd-morph-dropdown .dropdown-list::before, .cd-morph-dropdown .dropdown-list::after {
    content: "";
    position: absolute;
    transition: all 0.3s cubic-bezier(0, 1, 1, 1);
  }
  .cd-morph-dropdown .dropdown-list::before {
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    height: 0;
    width: 0;
    border: 8px solid transparent;
    border-bottom-color: #FFFFFF;
    opacity: 0;
  }
  .cd-morph-dropdown .dropdown-list::after {
    bottom: 100%;
    left: 0;
    width: 100%;
    height: 30px;
    display: none;
  }
  .cd-morph-dropdown .dropdown-list > ul {
    position: relative;
    z-index: 1;
    height: 100%;
    width: 100%;
    overflow: hidden;
    transition: transform 0.3s;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.03), 0 -15px 20px rgba(0, 0, 0, 0.01);
    border-radius: 14px;
    background: #fff;
  }
  .cd-morph-dropdown.is-dropdown-visible .dropdown-list {
    visibility: visible;
    opacity: 1;
  }
  .cd-morph-dropdown.is-dropdown-visible .dropdown-list > ul {
    transform: none;
  }
  .cd-morph-dropdown.is-dropdown-visible .dropdown-list::before {
    opacity: 1;
  }
  .cd-morph-dropdown .dropdown {
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0;
    visibility: hidden;
    width: 100%;
    pointer-events: none;
    transition: all 0.3s cubic-bezier(0, 1, 1, 1);
  }
  .cd-morph-dropdown .dropdown.active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
  .cd-morph-dropdown .dropdown.move-left .dropdown-content, .cd-morph-dropdown .dropdown.move-right .dropdown-content {
    opacity: 0;
  }
  .cd-morph-dropdown .dropdown.move-left .dropdown-content {
    transform: translate3d(-70%, 0, 0);
  }
  .cd-morph-dropdown .dropdown.move-right .dropdown-content {
    transform: translate3d(70%, 0, 0);
  }
  .cd-morph-dropdown .dropdown-content {
    text-align: left;
    opacity: 1;
    width: 100%;
    transition: all 0.3s cubic-bezier(0, 1, 1, 1);
  }
  .cd-morph-dropdown .dropdown-content .dropdown-label-wrapper {
    display: block;
    padding: 1rem 2rem;
    margin-bottom: 1.2em;
  }
  .cd-morph-dropdown .dropdown-content .dropdown-label-content {
    position: relative;
    padding-left: 1.7em;
  }
  .cd-morph-dropdown .dropdown-content p {
    font-size: 14px;
    letter-spacing: -0.526px;
    color: var(--font-color-default);
    opacity: 0.6;
    font-weight: 500;
    word-break: keep-all;
  }
  .cd-morph-dropdown .dropdown-content .dropdown-label {
    line-height: 1;
    color: var(--font-color-default);
    opacity: 0.8;
    font-weight: bold;
    font-weight: 600;
    transition: opacity 0.3s cubic-bezier(0, 1, 1, 1);
  }
  .cd-morph-dropdown .dropdown-content .dropdown-label:hover {
    opacity: 1;
  }
  .cd-morph-dropdown .dropdown-content .dropdown-label-wrapper {
    display: block;
    padding: 20px 35px;
    background: var(--bg-color-gray-soft);
    border-radius: 4px;
  }
  .cd-morph-dropdown .dropdown-content .dropdown-content-inner {
    display: flex;
    min-width: 0;
    justify-self: center;
  }
  .cd-morph-dropdown .dropdown-content .dropdown-content-inner ul {
    padding: 5px;
  }
  .cd-morph-dropdown .dropdown-content ul > li {
    flex: 0 1 100%;
  }
  .cd-morph-dropdown .dropdown-content ul > li.current a {
    color: #0288d1;
  }
  .cd-morph-dropdown .dropdown-content ul > li.current a .dropdown-link {
    opacity: 1;
    transform: none;
  }
  .cd-morph-dropdown .dropdown-content ul > li.current a span {
    opacity: 1;
  }
  .cd-morph-dropdown .dropdown-content ul > li.current a i {
    opacity: 1;
  }
  .cd-morph-dropdown .dropdown-content ul > li a {
    position: relative;
    display: block;
    font-size: 16px;
    color: var(--font-color-default);
    pointer-events: auto;
    z-index: 1;
  }
  .cd-morph-dropdown .dropdown-content ul > li a .dropdown-link {
    display: flex;
    align-items: center;
    height: 40px;
  }
  .cd-morph-dropdown .dropdown-content ul > li a span {
    opacity: 0.8;
    transition: opacity 0.3s cubic-bezier(0, 1, 1, 1);
    letter-spacing: -0.526px;
  }
  .cd-morph-dropdown .dropdown-content ul > li a:hover .dropdown-link {
    color: var(--font-color-green);
  }
  .cd-morph-dropdown .dropdown-content ul > li a:hover span {
    opacity: 1;
  }
  .cd-morph-dropdown .dropdown-content ul > li a:hover i {
    opacity: 1;
  }
  .cd-morph-dropdown .dropdown-content {
    width: 100%;
  }
  .cd-morph-dropdown .dropdown-content ul {
    display: flex;
    flex-direction: column;
  }
  .cd-morph-dropdown .dropdown-content h2 {
    font-size: 1.8rem;
    text-transform: none;
    font-weight: normal;
    color: #1A1A1A;
    margin-bottom: 0.6em;
  }
  .cd-morph-dropdown .bg-layer {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    height: 1px;
    width: 1px;
    background-color: #FFFFFF;
    opacity: 0;
    border-radius: 8px;
    pointer-events: none;
    transition: all 0.3s cubic-bezier(0, 1, 1, 1);
  }
  .cd-morph-dropdown .bg-layer.is-dropdown-visible {
    opacity: 1;
  }
}
.cd-morph-dropdown .dropdown-content ul > li.current a .menu-icon {
  background: #0288d1;
  color: #fff;
}

.header-etc {
  display: flex;
  gap: 40px;
}
.header-etc .urinong {
  width: 62px;
}

.search-box {
  display: flex;
  background: rgba(255, 255, 255, 0.5);
  border-radius: 10px;
  overflow: hidden;
  background: #f5f5f5;
}
.search-box input, .search-box button {
  height: 42px;
}
.search-box input {
  background: transparent;
  padding: 0 1em;
}

.header-search {
  display: flex;
  align-items: center;
}

.header-search-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 42px;
  padding: 0 0.8em;
  border-radius: 10px 0 0 10px;
  background: #19ac4f;
  color: #fff;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.2);
  font-size: 20px;
}

.footer {
  margin: 80px 0 40px 0;
}
.footer .footer-inner {
  background: #ebf4d2;
  border-radius: 15px;
  padding: 40px;
}
.footer .footer-row {
  display: flex;
  min-width: 0;
}
.footer .footer-col.logo {
  margin-right: 80px;
  flex: 0 0 310px;
}
.footer .footer-col.logo img {
  width: 100%;
  max-width: 230px;
}
.footer .footer-col.info {
  flex: 0 1 auto;
  min-width: 0;
  display: flex;
  align-items: center;
}
.footer .info-row {
  display: flex;
  flex-wrap: wrap;
}
.footer .info-col {
  flex: 1 1 50%;
  display: flex;
  margin: 0.3em 0;
}
.footer .info-col.call {
  order: -1;
}
.footer .info-col.call .label {
  color: #18ac4e;
  font-weight: bold;
}
.footer .info-col.number .content a {
  font-weight: bold;
  font-variant-numeric: lining-nums tabular-nums;
  letter-spacing: 0;
}
.footer .info-col .label, .footer .info-col .content {
  display: inline-block;
}
.footer .info-col .label {
  width: 140px;
  font-weight: 500;
}
.footer .info-col .content a:hover {
  color: #0288d1;
}

.copyrighter {
  font-size: 14px;
  font-variant-numeric: lining-nums tabular-nums;
  letter-spacing: 0;
  text-align: center;
  padding-top: 21px;
  margin-top: 40px;
  border-top: 1px solid #18ac4e;
  font-weight: 300;
}

.page-id-login .footer {
  margin: 0 !important;
  background: #ebf4d2;
}

@media all and (max-width: 1440px) {
  .footer .info-col {
    flex: 1 1 100%;
  }
  .footer .footer-row {
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .footer .footer-col.logo {
    display: flex;
    justify-content: center;
    align-items: center;
    flex: 1 1 100%;
    margin: 0;
  }
  .footer .info-row {
    margin-top: 40px;
  }
  .footer .info-col {
    flex: 1 1 50%;
  }
}
@media all and (max-width: 1024px) {
  .footer .footer-row {
    flex-wrap: nowrap;
  }
  .footer .footer-col.logo {
    margin-right: 40px;
    min-width: 241px;
    flex: 0 0 241px;
  }
  .footer .footer-col.info {
    flex: 1 1 0;
  }
  .footer .info-row {
    margin-top: 0;
  }
  .footer .info-col {
    flex: 1 1 100%;
  }
  .footer .footer-inner {
    padding: 20px;
  }
  .footer .footer-col.info,
  .copyrighter {
    margin-top: 20px;
  }
}
@media all and (max-width: 800px) {
  .footer .footer-row {
    flex-wrap: wrap;
  }
  .footer .footer-col.logo {
    min-width: auto;
    flex: 1 1 100%;
    margin: 0;
  }
  .footer .footer-col.info {
    flex: 1 1 100%;
  }
  .footer .info-col .label {
    width: 90px;
    opacity: 0.6;
    font-size: 14px;
    margin-right: 0.4em;
  }
  .footer .info-col .content {
    width: auto;
    margin-right: 0.4em;
    font-size: 14px;
    padding-left: 1em;
  }
}
@media all and (max-width: 640px) {
  .footer {
    margin: 40px 0 20px 0;
  }
  .footer .footer-col.logo img {
    max-width: 180px;
  }
  .footer .footer-col.info, .copyrighter {
    font-size: 12px;
  }
}
@media all and (max-width: 400px) {
  .footer .info-col .label {
    width: auto;
  }
}
.subpage-top {
  padding-top: 40px;
}
.subpage-top .hero-container {
  max-height: 480px;
  height: 480px;
  overflow: hidden;
}
.subpage-top img.hero {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.hero-container {
  position: relative;
  border-radius: 9999px;
  overflow: hidden;
}
.hero-container .hero-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}
.hero-container .hero-overlay small {
  font-size: 28px;
  color: #fff;
  line-height: 1;
  margin-bottom: 0.4em;
}
.hero-container .hero-overlay h2 {
  text-align: center;
  font-size: 50px;
  color: #fff;
  letter-spacing: 0;
  font-weight: bold;
}

.page-subtitle {
  line-height: 1;
}
.page-subtitle span, .page-subtitle div {
  display: inline-block;
  white-space: pre;
}

.page-small {
  display: flex;
  justify-content: center;
  align-items: center;
}

.page-top-title {
  display: flex;
  justify-content: center;
  align-items: center;
}

.page-top-title-inner {
  background: rgba(24, 172, 78, 0.7);
  padding: 1.5em 3em;
  border-radius: 9999px;
}

.breadcrumb {
  display: flex;
  align-items: center;
  font-size: 0.95rem;
  gap: 0.5em;
}
.breadcrumb a {
  color: #555;
  text-decoration: none;
}
.breadcrumb a:hover {
  text-decoration: underline;
}
.breadcrumb a i {
  margin-right: 0.25em;
}
.breadcrumb .breadcrumb-dropdown {
  position: relative;
  display: inline-block;
}
.breadcrumb .breadcrumb-dropdown .breadcrumb-toggle {
  background: none;
  border: none;
  font: inherit;
  cursor: pointer;
  padding: 5px 10px;
  border-radius: 7px;
  transition: background 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #333;
}
.breadcrumb .breadcrumb-dropdown .breadcrumb-toggle:hover {
  background: #f5f5f5;
}
.breadcrumb .breadcrumb-dropdown .breadcrumb-toggle.is-current {
  font-weight: bold;
  color: #111;
}
.breadcrumb .breadcrumb-dropdown .dropdown-menu {
  display: none;
  position: absolute;
  left: 0;
  top: calc(100% + 4px);
  background: #fff;
  z-index: 1000;
  min-width: 160px;
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.06), 0 -7.5px 10px rgba(0, 0, 0, 0.02);
  border-radius: 7px;
  overflow: hidden;
}
.breadcrumb .breadcrumb-dropdown .dropdown-menu li {
  list-style: none;
}
.breadcrumb .breadcrumb-dropdown .dropdown-menu li a {
  display: block;
  padding: 0.5em 1em;
  color: #333;
  font-size: 14px;
  text-decoration: none;
}
.breadcrumb .breadcrumb-dropdown .dropdown-menu li a:hover {
  background: #f9fbff;
  color: #0288d1;
}
.breadcrumb .breadcrumb-dropdown.is-open .dropdown-menu {
  display: block;
}

.breadcrumb-separator {
  margin: 0 0.4em;
  color: #bbb;
  font-size: 0.8em;
  vertical-align: middle;
}

i.breadcrumb-opened,
i.breadcrumb-closed {
  font-size: 13px;
}

i.breadcrumb-opened {
  display: none;
  color: #19ac4f;
  margin-top: 3px;
}

i.breadcrumb-closed {
  color: #ddd;
}

.breadcrumb-container {
  padding: 20px 0;
}

.breadcrumb .home {
  margin-right: 10px;
}
.breadcrumb .home > span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  color: #fff;
  background: #19ac4f;
  border-radius: 16px;
}
.breadcrumb .home > span i {
  margin: 0;
}
.breadcrumb .home > span:hover {
  background: #148c3f;
}

.breadcrumb .breadcrumb-dropdown.is-open .breadcrumb-toggle {
  background: #f5f5f5;
}
.breadcrumb .breadcrumb-dropdown.is-open i.breadcrumb-opened {
  display: inline-block;
}
.breadcrumb .breadcrumb-dropdown.is-open i.breadcrumb-closed {
  display: none;
}

.breadcrumb .breadcrumb-dropdown .breadcrumb-toggle {
  color: #666666;
}

:root {
  --main-slide-pad: 100px; /* 좌우/상하 확장 패딩 */
}

.page-header .swiper-container {
  width: 100%;
  height: 790px;
}

.image-wrapper {
  width: 100%;
  height: 790px;
}

.slide {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  position: relative;
  text-align: center;
  font-size: 18px;
  background: #fff;
  overflow: hidden;
}
.slide .image-wrapper, .slide-image {
  position: absolute;
  top: calc(-1 * var(--main-slide-pad));
  left: calc(-1 * var(--main-slide-pad));
  width: calc(100% + var(--main-slide-pad) * 2);
  height: calc(100% + var(--main-slide-pad) * 2);
  background-position: 50% 50%;
  background-size: cover;
}
.slide-title {
  font-size: 80px;
  line-height: 1;
  white-space: normal;
  word-break: break-word;
  color: #FFF;
  z-index: 100;
  font-family: simplehae;
  text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.38);
}
.slide-title span {
  white-space: pre;
  display: inline-block;
  opacity: 0;
}
.slide .image-wrapper .slide-image {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.slide-button {
  flex: 1 1 100%;
  margin-top: 80px;
}

.slideshow {
  position: relative;
  height: 100vh;
  max-height: 790px;
}
.slideshow .slide-title-wrap {
  max-width: 1024px;
  margin: 0 auto;
  padding: 0 50px;
  line-height: 1.4;
}
.slideshow-pagination {
  position: absolute;
  bottom: 5rem;
  left: 0;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  transition: 0.3s opacity;
  z-index: 10;
}
.slideshow-pagination-item {
  display: flex;
  align-items: center;
}
.slideshow-pagination-item .pagination-number {
  opacity: 0.5;
}
.slideshow-pagination-item:hover, .slideshow-pagination-item:focus {
  cursor: pointer;
}
.slideshow-pagination-item:last-of-type .pagination-separator {
  width: 0;
}
.slideshow-pagination-item.active .pagination-number {
  opacity: 1;
}
.slideshow-pagination-item.active .pagination-separator {
  width: 10vw;
}
.slideshow .swiper-pagination {
  --swiper-pagination-bullet-width:14px;
  --swiper-pagination-bullet-height:14px;
  --swiper-pagination-color:var(--font-color-green);
  --swiper-pagination-bullet-opacity: 1;
  --swiper-pagination-bullet-inactive-color:var(--bg-brown);
  --swiper-pagination-bullet-inactive-opacity:1;
  --swiper-pagination-bottom:20px;
}
.slideshow-navigation-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  z-index: 1000;
  transition: all 0.3s ease;
  background: rgba(0, 0, 0, 0.2);
  color: #FFF;
}
.slideshow-navigation-button:hover {
  cursor: pointer;
  background: rgba(0, 0, 0, 0.5);
}
.slideshow-navigation-button.prev {
  left: 0;
}
.slideshow-navigation-button.next {
  right: 0;
}

.slideshow-navigation {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.slideshow-navigation .container {
  display: flex;
  flex-wrap: wrap;
  gap: var(--grid-gap);
  width: 100%;
  margin: 0 auto;
  justify-content: space-between;
}

.swiper-button-next,
.swiper-button-prev,
.swiper-pagination-bullet {
  cursor: pointer;
  position: relative;
  z-index: 1;
}

.slideshow-navigation-button {
  cursor: pointer;
  z-index: 10;
}

.page-header {
  position: relative;
}

.slideshow-text {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
  pointer-events: none;
  color: #fff;
  line-height: 1.2;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.4);
}
.slideshow-text .txt-title {
  font-size: 48px;
  font-weight: 100;
  margin-bottom: 0.5em;
}
.slideshow-text .txt-content {
  font-size: 80px;
  font-weight: bold;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  background: #fff;
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: #c0ff00 !important;
}

@media all and (max-width: 1440px) {
  .page-header .swiper-container {
    height: 640px;
  }
  .slideshow {
    max-height: 640px;
  }
  .slideshow-text .txt-title {
    font-size: 40px;
  }
  .slideshow-text .txt-content {
    font-size: 60px;
  }
}
@media all and (max-width: 1024px) {
  .page-header .swiper-container {
    height: 480px;
  }
  .slideshow {
    max-height: 480px;
  }
  .slideshow-text .txt-title {
    font-size: 30px;
  }
  .slideshow-text .txt-content {
    font-size: 45px;
  }
}
@media all and (max-width: 640px) {
  .page-header .swiper-container {
    height: 320px;
  }
  .slideshow {
    max-height: 320px;
  }
  .slideshow-text .txt-title {
    font-size: 20px;
  }
  .slideshow-text .txt-content {
    font-size: 30px;
  }
  .slideshow-text,
  .slideshow-navigation .container {
    padding-top: 60px;
  }
  .slideshow-navigation-button {
    width: 40px;
    height: 40px;
  }
}
.main-section-header small {
  display: block;
  font-size: 20px;
  color: #18ac4e;
  line-height: 1;
  margin-bottom: 1em;
}

.main-title {
  font-size: 50px;
  font-weight: bold;
  line-height: 1;
  color: #1a1b1d;
}

@media all and (max-width: 1024px) {
  .main-title {
    font-size: 40px;
  }
  .main-section-header small {
    font-size: 18px;
  }
}
@media all and (max-width: 640px) {
  .main-title {
    font-size: 30px;
  }
  .main-section-header small {
    font-size: 16px;
  }
}
.button-round-type-1 {
  display: inline-flex;
  justify-content: space-between;
  align-items: center;
  height: 50px;
  background: #18ac4e;
  color: #fff;
  border-radius: 9999px;
  padding-left: 10px;
  border: 2px solid #18ac4e;
}
.button-round-type-1 .button-text {
  padding: 0 40px;
}
.button-round-type-1 .button-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 9999px;
  background: #fff;
  color: #18ac4e;
}

@media all and (min-width: 1025px) {
  .button-round-type-1:hover {
    border-color: #148c3f;
  }
  .button-round-type-1:hover .button-icon {
    background: #148c3f;
    color: #fff;
  }
}
@media all and (max-width: 1024px) {
  .button-round-type-1 {
    height: 46px;
  }
  .button-round-type-1 .button-icon {
    width: 42px;
    height: 42px;
  }
  .button-round-type-1 .button-text {
    font-size: 14px;
  }
}
.more-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-weight: 500;
  font-size: 16px;
  text-decoration: none;
  line-height: 1;
  margin-left: auto;
}

.plus-to-arrow line,
.plus-to-arrow polyline {
  transition: all 0.4s cubic-bezier(0.68, -0.55, 0.27, 1.55);
  transform-origin: center;
}

.line-arrowhead {
  opacity: 0;
  transform: scale(0.5);
}

/* Hover 상태: + → > */
.more-link:hover .line-vertical {
  opacity: 0;
  transform: scaleX(0);
}

.more-link:hover .line-horizontal {
  transform: translateX(-2px) scaleX(2);
  transform-origin: center right;
}

.more-link:hover .line-arrowhead {
  opacity: 1;
  transform: scale(1);
}

.main-section-2 {
  position: relative;
  padding: 80px 0;
  background: #ebf4d2;
}
.main-section-2 .section-box {
  display: flex;
}

.section-col.content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  flex: 0 0 33.333333%;
  padding-right: 40px;
}
.section-col.content small {
  font-size: 20px;
}
.section-col.content p {
  color: #1a1b1d;
  font-size: 18px;
  margin: 2em 0;
}
.section-col.slidearea {
  flex: 0 1 66.666666%;
  max-width: 66.666666%;
}
.slidearea-container {
  width: 100%;
  overflow: hidden;
}
.slidearea-container .slide {
  background: transparent !important;
}

.slide-business {
  position: relative;
  width: 100%;
  color: #fff;
  border-radius: 15px;
  overflow: hidden;
}
.slide-business .thumbnail {
  width: 100%;
  aspect-ratio: 510/440;
  overflow: hidden;
}
.slide-business .thumbnail img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: 100%;
}

.slide-controller {
  display: flex;
  align-items: center;
  margin-top: 40px;
}
.slide-controller:hover .swiper-scrollbar-drag {
  height: 200%;
  top: -50%;
}
.slide-controller .swiper-scrollbar-drag {
  cursor: grab;
}

.slide-current,
.slide-next {
  flex: 0 0 auto;
  font-weight: bold;
  width: 30px;
  text-align: center;
}

.business-buttons {
  display: flex;
  flex: 0 0 70px;
}
.business-buttons button {
  flex: 0 0 30px;
  height: 30px;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
}

.slide-bar-container {
  position: relative;
  flex: 1 1 0;
  height: 4px;
  display: flex;
  align-items: center;
}
.slide-bar-container .swiper-scrollbar {
  top: 0 !important;
}

.swiper-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
}
.swiper-controls .current-index,
.swiper-controls .current-index-2 {
  font-weight: bold;
  width: 30px;
  text-align: center;
}
.swiper-controls .progress-bar {
  flex: 1;
  height: 2px;
  background-color: #eee;
  position: relative;
  overflow: hidden;
}
.swiper-controls .progress-bar .progress-fill {
  height: 100%;
  background-color: #000;
  width: 0%;
  left: 0;
  position: absolute;
  top: 0;
  transition: all 0.4s ease;
}
.swiper-controls .swiper-button-prev,
.swiper-controls .swiper-button-next {
  background: none;
  border: none;
  font-size: 16px;
  cursor: pointer;
  padding: 0 5px;
}

@media all and (max-width: 1280px) {
  .section-box {
    flex-wrap: wrap;
  }
  .section-col.content {
    flex: 1 1 100%;
    padding-right: 0;
  }
  .section-col.content p br {
    display: none;
  }
  .slide-controller {
    margin-bottom: 50px;
  }
  .section-col.slidearea {
    flex: 1 1 100%;
    max-width: 100%;
  }
  .swipe-section-2 .slide a {
    display: block;
    width: 100%;
  }
}
@media all and (max-width: 1024px) {
  .section-col.content p {
    font-size: 16px;
  }
}
@media all and (max-width: 640px) {
  .main-section-2 {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .section-col.content p {
    font-size: 14px;
  }
  .slide-next {
    display: none;
  }
  .slide-controller {
    margin: 20px 0;
  }
  .section-buttons {
    display: flex;
    justify-content: center;
  }
}
.main-section-3 {
  padding: 80px 0;
}
.main-section-3 .main-row {
  display: flex;
  margin-top: -40px;
  margin-left: -40px;
}
.main-section-3 .main-col {
  padding-top: 40px;
  padding-left: 40px;
}
.main-section-3 .section-contents {
  margin-top: 40px;
}

.product-item {
  position: relative;
}

.product-thumb {
  aspect-ratio: 794/513;
  border-radius: 15px;
  overflow: hidden;
}
.product-thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}

.product-text {
  line-height: 1.4;
  margin-top: 2em;
}
.product-text h3 {
  font-size: 30px;
}
.product-text small {
  font-size: 20px;
  font-weight: 100;
}

@media all and (min-width: 1025px) {
  .product-item a:hover .product-thumb::before {
    opacity: 1;
  }
  .product-item a:hover .product-thumb img {
    transform: scale(1.1);
    filter: blur(5px);
  }
  .product-item a:hover .product-text {
    opacity: 1;
    transform: none;
  }
  .product-thumb {
    position: relative;
  }
  .product-thumb::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.4);
    opacity: 0;
    transition: opacity 1s cubic-bezier(0.075, 0.82, 0.165, 1);
    will-change: opacity;
    z-index: 1;
  }
  .product-thumb img {
    transform: none;
    transition: transform 1s cubic-bezier(0.075, 0.82, 0.165, 1), filter 1s cubic-bezier(0.075, 0.82, 0.165, 1);
    will-change: transform, filter;
  }
  .product-text {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    opacity: 0;
    transform: scale(1.1);
    transition: opacity 1s cubic-bezier(0.075, 0.82, 0.165, 1), transform 1s cubic-bezier(0.075, 0.82, 0.165, 1);
    will-change: opacity, transform;
    z-index: 2;
  }
}
@media all and (max-width: 1024px) {
  .main-section-3 .main-row {
    margin-top: -20px;
    margin-left: -20px;
  }
  .main-section-3 .main-col {
    padding-top: 20px;
    padding-left: 20px;
  }
  .product-text {
    margin-top: 1em;
  }
  .product-text small {
    font-size: 18px;
  }
  .product-text h3 {
    font-size: 22px;
  }
}
@media all and (max-width: 640px) {
  .main-section-3 {
    padding: 50px 0;
  }
  .main-section-3 .main-row {
    flex-wrap: wrap;
  }
  .main-section-3 .main-col {
    flex: 1 1 100%;
  }
  .product-text {
    margin-top: 0.5em;
  }
  .product-text small {
    font-size: 16px;
  }
  .product-text h3 {
    font-size: 20px;
  }
}
.main-section-4 {
  background: #f1f1f1;
  padding: 80px 0;
}

.main-video {
  max-width: 1360px;
  width: 100%;
  margin: 0 auto;
}

.video-wrap {
  max-width: 960px;
  margin: 0 auto;
}

.video-embed {
  width: 100%;
  display: block;
  aspect-ratio: 1.7777777778;
}
@supports not (aspect-ratio: 1/1) {
  .video-embed {
    position: relative;
  }
  .video-embed::before {
    content: "";
    display: block;
    padding-top: calc(100% * 9 / 16);
  }
  .video-embed > * {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }
}
.video-embed iframe,
.video-embed .player,
.video-embed video {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
.video-embed.rounded {
  border-radius: 12px;
  overflow: hidden;
}
.video-embed.shadow {
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
}

@media all and (max-width: 640px) {
  .main-section-4 {
    padding: 40px 20px;
  }
}
@media all and (max-width: 480px) {
  .main-section-4 {
    padding: 40px 0;
  }
}
.guide-box {
  background-color: #f5f5f5;
  border-radius: 15px;
  padding: 20px 20px;
  margin-bottom: 40px;
  font-size: 14px;
  color: #757575;
  line-height: 1.4;
}
.guide-box .guide-title {
  font-weight: 600;
  margin-bottom: 10px;
  display: block;
  font-size: 15px;
  color: #222;
}
.guide-box .guide-list {
  list-style: disc;
  padding-left: 18px;
}
.guide-box .guide-list li {
  margin-bottom: 6px;
}
.guide-box .guide-list li .highlight {
  color: #0288d1;
  font-weight: 500;
}
.guide-box .guide-list li strong {
  color: #d13744;
}

@media all and (max-width: 1024px) {
  .guide-box {
    margin-bottom: 20px;
  }
}
@media all and (max-width: 640px) {
  .guide-box {
    font-size: 12px;
  }
}
.page-id-search main.content {
  padding-bottom: 80px;
}
.page-id-search .filter-wrapper {
  max-width: 600px;
}
.page-id-search .pagination {
  margin-top: 40px;
}
.page-id-search .content h3 a {
  width: 100%;
  display: block;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.search-section {
  margin-top: 40px;
}

.list-heading {
  margin-bottom: 40px;
}
.list-heading .maeul-section-title {
  width: 100%;
}
.list-heading .title-content {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: flex-end;
}
.list-heading .title-content .label {
  opacity: 0.5;
  font-size: 14px;
}
.list-heading .title-content-text span {
  opacity: 0.5;
  font-weight: normal;
  font-size: 14px;
}

.sch_word {
  background: #19ac4f;
  border-radius: 7px;
}

.section-search-list + .section-search-list {
  margin-top: 40px;
}

.event-view-info .badge {
  display: flex;
  align-items: center;
  height: 30px;
}

.badge-expired {
  background-color: #d13744;
  color: #fff;
  font-size: 12px;
  padding: 2px 6px;
  border-radius: 7px;
  vertical-align: middle;
}

.badge-continue {
  font-size: 12px;
  padding: 2px 6px;
  border-radius: 7px;
  vertical-align: middle;
  color: #f9fbff;
  background: #0288d1;
}

.expired .content h3 a {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
  width: 100%;
}
.expired .content h3 a .subject-content {
  position: relative;
  color: #757575;
  padding-left: 5px;
  padding-right: 5px;
}
.expired .content h3 a .subject-content::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 2px;
  background: #000;
  opacity: 0.5;
}

.list-heading-notice {
  margin-bottom: 0 !important;
}

.search-header {
  margin: 40px 0;
}
.search-header h2 {
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0;
  line-height: 1.4;
  margin-bottom: 20px;
}
.search-header h2 span {
  opacity: 0.5;
  font-weight: normal;
}
.search-header h2 mark {
  position: relative;
  background: transparent;
  border-radius: 7px;
  padding: 0 0.6em;
  margin-right: 0.5em;
}
.search-header h2 mark i {
  position: absolute;
  top: 0;
  color: #19ac4f;
  font-size: 10px;
}
.search-header h2 mark i.start {
  left: 0;
  transform: translate(0, 0);
}
.search-header h2 mark i.end {
  right: 0;
  transform: translate(0, 0);
}

.search-summary {
  display: flex;
  gap: 20px;
  padding: 0;
  list-style: none;
}
.search-summary li {
  width: 100%;
  height: 100%;
  border: 1px solid #f1f1f1;
  border-radius: 16px;
  padding: 20px;
  flex: 1 1 160px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.search-summary li strong {
  font-size: 0.95rem;
  color: #333;
  margin-bottom: 0.25rem;
}
.search-summary li span {
  font-size: 1.2rem;
  font-weight: bold;
  color: #111;
}

.search-tabs {
  margin-bottom: 80px;
  border-top: 1px solid #f1f1f1;
  border-bottom: 1px solid #f1f1f1;
  padding: 20px 0;
}
.search-tabs ul {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.search-tabs li {
  margin: 0;
}
.search-tabs a {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.4em 1em;
  background: #f5f5f5;
  border: 1px solid #f1f1f1;
  border-radius: 9px;
  color: #000;
  font-size: 14px;
  text-decoration: none;
  transition: background 0.2s;
  height: 40px;
}
.search-tabs a .count {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #19ac4f;
  padding: 0 0.5em 0 0.4em;
  border-radius: 10px;
  font-size: 10px;
  color: #fff;
  margin-left: 0.4em;
  min-width: 2em;
  text-align: center;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.2);
}
.search-tabs a:hover {
  background: #fff;
  color: #1f2937;
}
.search-tabs a.active {
  background: #19ac4f;
  font-weight: 600;
  color: #fff;
  border-color: #19ac4f;
}
.search-tabs a.active .count {
  background: #fff;
  color: #148c3f;
}

.fake-checkbox input[type=checkbox] {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  border: 0;
  padding: 0;
  white-space: nowrap;
  clip-path: inset(100%);
  clip: rect(0 0 0 0);
  overflow: hidden;
}

.login-split-wrap {
  display: flex;
  min-height: 100vh;
  font-family: "Noto Sans KR", sans-serif;
}
.login-split-wrap .login-left,
.login-split-wrap .login-right {
  padding-top: 113px;
  padding-bottom: 113px;
}
.login-split-wrap .login-left {
  flex: 1;
  background: linear-gradient(135deg, #148c3f 0%, #18ac4e 100%);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding-right: 160px;
  min-width: 0;
}
.login-split-wrap .login-left .login-msg-box {
  text-align: left;
}
.login-split-wrap .login-left .login-msg-box .login-main-msg {
  font-size: 2rem;
  line-height: 1.6;
  font-weight: 700;
  margin-bottom: 16px;
}
.login-split-wrap .login-left .login-msg-box .login-sub-msg {
  font-size: 1rem;
  opacity: 0.9;
  margin-bottom: 16px;
}
.login-split-wrap .login-left .login-msg-box a {
  font-size: 20px;
  font-variant-numeric: lining-nums tabular-nums;
  letter-spacing: 0;
  font-weight: 500;
}
.login-split-wrap .login-left .login-msg-box a:hover {
  color: #0066ff;
}
.login-split-wrap .login-right {
  flex: 1;
  background: #f7f8f9;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-left: 160px;
  min-width: 0;
}
.login-split-wrap .login-right .login-form-box {
  width: 100%;
  max-width: 380px;
  background: #fff;
  border-radius: 15px;
  padding: 40px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
}
.login-split-wrap .login-right .login-logo {
  font-size: 1.5rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 32px;
  color: #19ac4f;
}
.login-split-wrap .login-right form .form-group {
  margin-bottom: 16px;
}
.login-split-wrap .login-right form .form-group .form-input {
  width: 100%;
  height: 42px;
  padding: 0 16px;
  border: 1px solid #ddd;
  border-radius: 15px;
  font-size: 1rem;
}
.login-split-wrap .login-right form .form-group .form-input:focus {
  border-color: #19ac4f;
  outline: none;
}
.login-split-wrap .login-right form .form-options {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  font-size: 0.9rem;
  margin-bottom: 24px;
}
.login-split-wrap .login-right form .form-options .checkbox {
  display: flex;
  align-items: center;
}
.login-split-wrap .login-right form .form-options .checkbox input[type=checkbox] {
  margin-right: 8px;
}
.login-split-wrap .login-right form .form-submit .btn-login {
  width: 100%;
  height: 42px;
  background-color: #19ac4f;
  color: #fff;
  font-size: 1rem;
  border: none;
  border-radius: 15px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}
.login-split-wrap .login-right form .form-submit .btn-login:hover {
  background-color: #00b338;
}

.fake-checkbox {
  top: 20px;
  right: 20px;
  display: flex;
  align-items: center;
  z-index: 1;
}
.fake-checkbox .label-checkbox-text {
  margin-left: 0.4em;
}
.fake-checkbox input[type=checkbox] {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  border: 0;
  padding: 0;
  white-space: nowrap;
  clip-path: inset(100%);
  clip: rect(0 0 0 0);
  overflow: hidden;
}
.fake-checkbox .label-checkbox {
  position: relative;
}
.fake-checkbox .label-checkbox .checkbox-rect {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #ebebeb;
  width: 20px;
  height: 20px;
  border-radius: 5px;
  font-size: 14px;
  color: var(--bg-color-gray-soft);
  transform-origin: center;
  animation: animateHeartOut 0.3s linear forwards;
  background-color: rgba(255, 255, 255, 0.9);
}
.fake-checkbox .label-checkbox .checkbox-rect i {
  opacity: 0;
}
.fake-checkbox svg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  cursor: pointer;
  overflow: visible;
  width: 30px;
  height: 30px;
}
.fake-checkbox svg .main-circ {
  transform-origin: 29.5px 29.5px;
}
.fake-checkbox input:checked + label .checkbox-rect {
  border: 2px solid rgba(10, 88, 202, 0.3);
  color: #0a58ca;
  transform: scale(0.2);
  animation: animateHeart 0.3s linear forwards 0.25s;
  background-color: #fff;
}
.fake-checkbox input:checked + label .checkbox-rect i {
  opacity: 1;
}
.fake-checkbox input[disabled]:checked + label .checkbox-rect {
  border: 2px solid #f5f5f5;
  color: var(--border-color-gray-soft);
  transform: scale(0.2);
  animation: animateHeart 0.3s linear forwards 0.25s;
}
.fake-checkbox input[disabled]:checked + label .checkbox-rect i {
  opacity: 1;
}
.fake-checkbox input:checked + label svg .main-circ {
  transition: all 2s;
  animation: animateCircle 0.3s linear forwards;
  opacity: 1;
}
.fake-checkbox input:checked + label svg .grp1 {
  opacity: 1;
  transition: 0.1s all 0.3s;
}
.fake-checkbox input:checked + label svg .grp1 .oval1 {
  transform: scale(0) translate(0, -30px);
  transform-origin: 0 0 0;
  transition: 0.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp1 .oval2 {
  transform: scale(0) translate(10px, -50px);
  transform-origin: 0 0 0;
  transition: 1.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp2 {
  opacity: 1;
  transition: 0.1s all 0.3s;
}
.fake-checkbox input:checked + label svg .grp2 .oval1 {
  transform: scale(0) translate(30px, -15px);
  transform-origin: 0 0 0;
  transition: 0.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp2 .oval2 {
  transform: scale(0) translate(60px, -15px);
  transform-origin: 0 0 0;
  transition: 1.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp3 {
  opacity: 1;
  transition: 0.1s all 0.3s;
}
.fake-checkbox input:checked + label svg .grp3 .oval1 {
  transform: scale(0) translate(30px, 0px);
  transform-origin: 0 0 0;
  transition: 0.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp3 .oval2 {
  transform: scale(0) translate(60px, 10px);
  transform-origin: 0 0 0;
  transition: 1.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp4 {
  opacity: 1;
  transition: 0.1s all 0.3s;
}
.fake-checkbox input:checked + label svg .grp4 .oval1 {
  transform: scale(0) translate(30px, 15px);
  transform-origin: 0 0 0;
  transition: 0.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp4 .oval2 {
  transform: scale(0) translate(40px, 50px);
  transform-origin: 0 0 0;
  transition: 1.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp5 {
  opacity: 1;
  transition: 0.1s all 0.3s;
}
.fake-checkbox input:checked + label svg .grp5 .oval1 {
  transform: scale(0) translate(-10px, 20px);
  transform-origin: 0 0 0;
  transition: 0.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp5 .oval2 {
  transform: scale(0) translate(-60px, 30px);
  transform-origin: 0 0 0;
  transition: 1.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp6 {
  opacity: 1;
  transition: 0.1s all 0.3s;
}
.fake-checkbox input:checked + label svg .grp6 .oval1 {
  transform: scale(0) translate(-30px, 0px);
  transform-origin: 0 0 0;
  transition: 0.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp6 .oval2 {
  transform: scale(0) translate(-60px, -5px);
  transform-origin: 0 0 0;
  transition: 1.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp7 {
  opacity: 1;
  transition: 0.1s all 0.3s;
}
.fake-checkbox input:checked + label svg .grp7 .oval1 {
  transform: scale(0) translate(-30px, -15px);
  transform-origin: 0 0 0;
  transition: 0.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp7 .oval2 {
  transform: scale(0) translate(-55px, -30px);
  transform-origin: 0 0 0;
  transition: 1.5s transform 0.3s;
}
.fake-checkbox input:checked + label svg .grp2 {
  opacity: 1;
  transition: 0.1s opacity 0.3s;
}
.fake-checkbox input:checked + label svg .grp3 {
  opacity: 1;
  transition: 0.1s opacity 0.3s;
}
.fake-checkbox input:checked + label svg .grp4 {
  opacity: 1;
  transition: 0.1s opacity 0.3s;
}
.fake-checkbox input:checked + label svg .grp5 {
  opacity: 1;
  transition: 0.1s opacity 0.3s;
}
.fake-checkbox input:checked + label svg .grp6 {
  opacity: 1;
  transition: 0.1s opacity 0.3s;
}
.fake-checkbox input:checked + label svg .grp7 {
  opacity: 1;
  transition: 0.1s opacity 0.3s;
}

@keyframes animateCircle {
  40% {
    transform: scale(10);
    opacity: 1;
    fill: #DD4688;
  }
  55% {
    transform: scale(11);
    opacity: 1;
    fill: #D46ABF;
  }
  65% {
    transform: scale(12);
    opacity: 1;
    fill: #CC8EF5;
  }
  75% {
    transform: scale(13);
    opacity: 1;
    fill: transparent;
    stroke: #CC8EF5;
    stroke-width: 0.5;
  }
  85% {
    transform: scale(17);
    opacity: 1;
    fill: transparent;
    stroke: #CC8EF5;
    stroke-width: 0.2;
  }
  95% {
    transform: scale(18);
    opacity: 1;
    fill: transparent;
    stroke: #CC8EF5;
    stroke-width: 0.1;
  }
  100% {
    transform: scale(19);
    opacity: 1;
    fill: transparent;
    stroke: #CC8EF5;
    stroke-width: 0;
  }
}
@keyframes animateHeart {
  0% {
    transform: scale(0.2);
  }
  40% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes animateHeartOut {
  0% {
    transform: scale(1.4);
  }
  100% {
    transform: scale(1);
  }
}
.footer-admin {
  display: flex;
  align-items: center;
  gap: 20px;
}
.footer-admin a {
  font-size: 14px;
  color: #555;
}

.bbs-view-header {
  word-break: break-all !important;
  word-break: auto-phrase !important;
}

.more-item-title {
  font-size: 14px !important;
}
.more-item-title a {
  color: #0d6efd;
  letter-spacing: 0;
  text-decoration-line: underline;
  text-decoration-style: dotted;
  font-variant-numeric: lining-nums tabular-nums;
  font-size: 12px;
}
.more-item-title a:hover {
  color: #06357a;
}
.more-item-title a small {
  color: #757575 !important;
}

.subpage-container {
  padding-top: 60px;
}

@media all and (max-width: 1024px) {
  .subpage-container {
    padding-top: 40px;
  }
}
@media all and (max-width: 640px) {
  .subpage-container {
    padding-top: 20px;
  }
}
.intro {
  background: #fff;
  color: #222;
  /* 본문 */
  /* 리스트: 숫자 배지 + 내용 */
}
.intro-container {
  max-width: 920px;
  width: 100%;
  margin: 0 auto;
}
.intro-title {
  font-size: 36px;
  font-weight: bold;
  letter-spacing: -0.01em;
  line-height: 1.25;
  text-align: center;
  margin-bottom: 40px;
}
.intro-summary {
  font-size: 20px;
  margin-bottom: 20px;
}
.intro-paragraph {
  margin: 0 0 10px;
  font-size: 16.5px;
  line-height: 1.9;
  color: #555;
}
.intro-list {
  list-style: none;
  margin: 10px 0 10px;
  padding: 12px 10px;
  background: #f7f8f9;
  border: 1px solid #e9ecef;
  border-radius: 12px;
}
.intro-item {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 12px;
  align-items: start;
  padding: 12px 6px;
  border-bottom: 1px dashed #e9ecef;
}
.intro-item:last-child {
  border-bottom: 0;
}
@media (max-width: 640px) {
  .intro-item {
    grid-template-columns: 36px 1fr;
    gap: 10px;
    padding: 10px 4px;
  }
}
.intro-num {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid #e9ecef;
  color: #18ac4e;
  display: grid;
  place-items: center;
  font-weight: 800;
  font-size: 14px;
  margin-top: 3px;
}
.intro-item-title {
  display: inline-block;
  font-weight: 800;
  color: #222;
  margin-bottom: 4px;
}
.intro-item-desc {
  margin: 0;
  color: #555;
  font-size: 16px;
}

.intro-chart {
  text-align: center;
  margin-top: 80px;
}
.intro-chart img {
  max-width: 100%;
}

@media all and (max-width: 1024px) {
  .intro-title {
    font-size: 25px;
  }
  .intro-summary {
    font-size: 18px;
  }
  .intro-chart {
    margin-top: 60px;
  }
}
@media all and (max-width: 640px) {
  .intro-title {
    font-size: 22px;
    margin-bottom: 20px;
  }
  .intro-summary {
    margin-bottom: 10px;
  }
  .intro-chart {
    margin-top: 40px;
  }
}
.vision.subpage-container {
  padding-top: 0 !important;
}

.image-thumb {
  border-radius: 15px;
  overflow: hidden;
}
.image-thumb img {
  width: 100%;
}

.page-hero-image {
  position: relative;
}

.slogan-text {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  font-weight: bold;
  letter-spacing: -0.01em;
  line-height: 1.25;
  text-align: center;
  z-index: 2;
}

.circle-animation {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
  isolation: isolate;
}

.ga-bubble {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  aspect-ratio: 1/1;
  border-radius: 50%;
  will-change: transform, opacity;
  -webkit-mask-image: radial-gradient(circle at 50% 50%, #000 68%, transparent 100%);
  mask-image: radial-gradient(circle at 50% 50%, #000 68%, transparent 100%);
}

.vision-content {
  margin-top: 80px;
}

.vision-section {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.vision-section + .vision-section {
  margin-top: 80px;
}

.vision-content-header {
  flex: 1 1 100%;
  text-align: center;
  font-size: 30px;
  color: #18ac4e;
}

.wave-bg {
  background-image: url("../img/vision/bg_title.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 100% 100%;
  padding: 40px 20px;
}

.vision-item {
  text-align: center;
}
.vision-item strong {
  display: block;
  font-size: 20px;
  color: #432216;
  line-height: 1.6;
  margin-bottom: 1em;
}
.vision-item + .vision-item {
  position: relative;
  margin-top: 20px;
  padding-top: 35px;
}
.vision-item + .vision-item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 15px;
  height: 15px;
  border-radius: 99px;
  background: #18ac4e;
  transform: translateX(-50%);
}

.vision-group {
  padding-top: 40px;
}
.vision-group + .vision-group {
  position: relative;
  margin-top: 40px;
  padding-top: 60px;
}
.vision-group + .vision-group::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 20px;
  background: #f5f9e8;
}

.vision-image img {
  max-width: 100%;
}

@media all and (max-width: 1024px) {
  .slogan-text {
    font-size: 25px;
  }
  .vision-content {
    margin-top: 40px;
  }
  .vision-content-header {
    font-size: 22px;
  }
  .vision-item strong {
    font-size: 18px;
  }
  .vision-section + .vision-section {
    margin-top: 40px;
  }
  .vision-group {
    padding-top: 20px;
  }
  .vision-group + .vision-group {
    margin-top: 20px;
    padding-top: 30px;
  }
  .vision-group + .vision-group::before {
    height: 10px;
  }
}
@media all and (max-width: 640px) {
  .slogan-text {
    font-size: 22px;
  }
  .vision-content {
    margin-top: 20px;
  }
  .wave-bg {
    padding: 20px 10px;
  }
  .vision-content-header {
    font-size: 20px;
  }
  .vision-section + .vision-section {
    margin-top: 20px;
  }
  .vision-item p br {
    display: none;
  }
}
.history-inner {
  display: flex;
  gap: 80px;
}

.history-media {
  flex: 0 0 357px;
}
.history-media figure {
  display: block;
  border-radius: 15px;
  overflow: hidden;
}
.history-media img {
  width: 100%;
}

.history-list {
  flex: 1 1 0;
}

.history-item {
  display: flex;
  line-height: 1;
  align-items: flex-start;
}
.history-item:last-child .history-text::before {
  display: none;
}

.history-year {
  position: relative;
  flex: 0 0 2.3em;
  font-size: 30px;
  font-weight: bold;
  padding-right: 40px;
  margin-right: 40px;
}
.history-year::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  transform: translate(50%, -50%);
  background: #18ac4e;
}

.history-text {
  position: relative;
  flex: 1 1 0;
  font-size: 18px;
  line-height: 1.6;
  padding-top: 0.6px;
  padding-bottom: 80px;
}
.history-text::before {
  content: "";
  position: absolute;
  top: 15px;
  left: -41px;
  width: 1px;
  height: 100%;
  background: #18ac4e;
}

@media all and (max-width: 1024px) {
  .history-media {
    flex-basis: 270px;
  }
  .history-inner {
    gap: 40px;
  }
  .history-year {
    font-size: 22px;
  }
  .history-text {
    font-size: 16px;
    padding-top: 0;
    padding-bottom: 40px;
  }
}
@media all and (max-width: 800px) {
  .history-inner {
    flex-direction: column;
  }
  .history-media {
    text-align: center;
  }
  .history-media figure {
    display: inline-block;
    line-height: 1;
  }
  .history-media img {
    max-width: 357px;
  }
}
@media all and (max-width: 640px) {
  .history.subpage-container {
    padding-top: 0;
  }
  .history-media {
    flex-basis: 100%;
  }
  .history-media figure {
    width: 100%;
  }
  .history-media img {
    max-width: 100%;
  }
  .history-inner {
    gap: 20px;
  }
  .history-year {
    font-size: 20px;
  }
  .history-text {
    font-size: 16px;
    padding-top: 0;
    padding-bottom: 20px;
  }
  .history-year {
    padding-right: 20px;
    margin-right: 20px;
  }
  .history-text::before {
    left: -21px;
  }
}
.location.subpage-container {
  padding-top: 0 !important;
}

.root_daum_roughmap .cont {
  display: none !important;
}

.location .map-container {
  position: relative;
}
.location #map {
  width: 100%;
  aspect-ratio: 16/9;
  min-height: 360px;
  border-radius: 15px;
  overflow: hidden;
}

/* 반응형 브레이크포인트 (사용자 기본 규칙 준수) */
@media all and (max-width: 1280px) {
  #map {
    min-height: 320px;
  }
}
@media all and (max-width: 1024px) {
  #map {
    min-height: 300px;
  }
}
@media all and (max-width: 640px) {
  #map {
    min-height: 260px;
  }
}
.location-info {
  margin-top: 80px;
}
.location-info h3 {
  font-size: 36px;
  font-weight: bold;
  letter-spacing: -0.01em;
  line-height: 1.25;
  margin-bottom: 40px;
  margin-bottom: 40px;
}

.location-row {
  display: flex;
}

.location-col {
  flex: 1 1 50%;
  min-width: 0;
}

.location-info-row {
  display: flex;
  flex-direction: column;
}

.location-info-item {
  display: flex;
}
.location-info-item > span {
  min-width: 0;
}
.location-info-item .info-label {
  flex: 0 0 1.5em;
}
.location-info-item .info-txt {
  flex: 1 1 0;
  font-variant-numeric: lining-nums tabular-nums;
}
.location-info-item .info-txt a {
  color: #0288d1;
}

.info-label i {
  color: #18ac4e;
}

@media all and (max-width: 1024px) {
  .location-info {
    margin-top: 60px;
  }
  .location-info h3 {
    font-size: 25px;
  }
}
@media all and (max-width: 640px) {
  .location-info {
    margin-top: 40px;
  }
  .location-info h3 {
    margin-bottom: 20px;
  }
  .location-row {
    flex-direction: column;
  }
}
.business.subpage-container {
  padding-top: 0 !important;
}

.webzine {
  display: flex;
  gap: 80px;
}
.webzine + .webzine {
  margin-top: 80px;
}

.webzine-thumb {
  flex: 0 0 45.625%;
  min-width: 0;
}
.webzine-thumb .webzine-thumb-inner {
  border-radius: 15px;
  overflow: hidden;
  aspect-ratio: 73/52;
}
.webzine-thumb .webzine-thumb-inner img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.webzine-info {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  align-items: center;
}
.webzine-info .info-image {
  margin-bottom: 20px;
}
.webzine-info .info-image .happy700 {
  max-width: 30%;
  width: 227px;
}
.webzine-info h4 {
  font-size: 20px;
  color: #432216;
  font-weight: bold;
}
.webzine-info p {
  margin-top: 20px;
}
.webzine-info p strong {
  display: block;
  font-weight: bold;
  font-size: 18px;
  margin-top: 20px;
}
.webzine-info .info-biz {
  margin-top: 40px;
}
.webzine-info .info-biz ul {
  display: flex;
  gap: 0 20px;
  flex-wrap: wrap;
}
.webzine-info .info-biz ul li img {
  height: 75px;
  width: auto;
}

.business .labels {
  margin-top: 40px;
}
.business .labels ul {
  display: flex;
  gap: 20px;
}
.business .labels ul li img {
  width: 92px;
}

@media all and (min-width: 801px) {
  .webzine:nth-child(even) .webzine-info {
    order: -1;
  }
}
.business.store {
  margin-top: 80px;
}
.business.store h3 {
  font-size: 20px;
  font-weight: bold;
  color: #18ac4e;
}

.store-container {
  background: #f5f9e8;
  padding: 40px;
}

.store-row {
  display: flex;
  gap: 80px;
  justify-content: space-between;
}

.store-col.info {
  min-width: 270px;
  display: flex;
  align-items: center;
}
.store-col.info ul {
  margin-top: 20px;
  font-weight: bold;
}
.store-col.info .store-button {
  margin-top: 40px;
}
.soter-button-row {
  display: flex;
  align-items: center;
  gap: 20px;
}
.soter-button-row span {
  font-size: 20px;
  font-weight: bold;
  color: #18ac4e;
}
.soter-button-row img {
  width: 70px;
}

.store-images-row {
  display: flex;
  gap: 40px;
}

.store-images-col {
  flex: 0 1 33.333333%;
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.store-images-col .thumb .thumb-inner {
  border-radius: 15px;
  overflow: hidden;
}
.store-images-col .thumb .thumb-inner img {
  width: 100%;
}

.business.store .labels {
  display: flex;
  justify-content: center;
  margin-top: 20px;
}

.business.store .labels ul li img {
  width: 70px;
}

@media all and (max-width: 1440px) {
  .webzine {
    gap: 40px;
  }
}
@media all and (max-width: 1280px) {
  .store-images-row {
    gap: 20px;
  }
  .business.store .labels ul {
    gap: 10px;
  }
  .business.store .labels ul li img {
    width: 50px;
  }
}
@media all and (max-width: 1024px) {
  .webzine-info h4 {
    font-size: 18px;
  }
  .webzine-info p strong {
    font-size: 16px;
  }
  .webzine-info .info-biz ul li img {
    height: 50px;
  }
  .business.store {
    margin-top: 40px;
  }
  .business.store h3,
  .soter-button-row span {
    font-size: 18px;
  }
  .store-row {
    flex-wrap: wrap;
    gap: 40px;
  }
  .store-row .store-col.info {
    flex: 1 1 100%;
  }
  .info-inner {
    display: flex;
    width: 100%;
    gap: 40px;
    align-items: flex-end;
    justify-content: space-between;
  }
}
@media all and (max-width: 800px) {
  .webzine {
    flex-direction: column;
    gap: 20px;
  }
  .webzine + .webzine {
    margin-top: 40px;
  }
  .webzine-info .info-image {
    margin-bottom: 10px;
  }
  .webzine-info p,
  .webzine-info p strong {
    margin-top: 10px;
  }
  .business .labels {
    margin-top: 20px;
  }
  .business .labels ul li img {
    width: 70px;
  }
  .webzine-info .info-image .happy700 {
    max-width: 180px;
  }
  .webzine-info .info-biz ul {
    gap: 0 10px;
  }
  .store-images-row {
    flex-direction: column;
  }
  .store-container {
    padding: 20px;
  }
}
@media all and (max-width: 640px) {
  .info-inner {
    flex-wrap: wrap;
    gap: 0;
  }
  .info-inner > div {
    flex: 1 1 100%;
  }
  .store-col.info .store-button {
    margin-top: 20px;
  }
  .store-col.images {
    flex: 1 1 100%;
    width: 100%;
  }
  .business.store .labels ul li img {
    width: 70px;
  }
  .business.store .labels {
    margin-top: 10px;
  }
  .webzine-info .info-biz ul li img {
    height: 35px;
  }
  .webzine-info p > br {
    display: none;
  }
  .store-row {
    gap: 20px;
  }
  .soter-button-row img {
    width: 45px;
  }
  .soter-button-row {
    gap: 10px;
  }
}
.is-bbs .subpage-container {
  padding-top: 40px;
}

.nothing {
  padding: 80px;
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  border-radius: 15px;
  background: #f5f5f5;
}
.nothing .nothing-message {
  font-size: 14px;
  color: #787878;
  letter-spacing: 0;
  border-radius: 16px;
}

@media all and (max-width: 1024px) {
  .is-bbs .subpage-container {
    padding-top: 0;
  }
}
.board .section-text {
  margin-bottom: 40px;
}
.board .section-row {
  display: flex;
  margin-top: -40px;
  margin-left: -40px;
  flex-wrap: wrap;
}
.board .section-col {
  flex: 0 0 33.333333%;
  min-width: 0;
  padding-left: 40px;
  padding-top: 40px;
}

.video-item .thumbnail {
  position: relative;
  border-radius: var(--border-radius-normal);
  overflow: hidden;
}
.video-item .thumbnail a {
  position: relative;
  display: flex;
  aspect-ratio: 16/9;
}
.video-item .thumbnail img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transform: none;
  transition: transform 1s cubic-bezier(0.075, 0.82, 0.165, 1);
  will-change: transform;
}
.video-item .content {
  margin-top: 10px;
}
.video-item .content h3 {
  font-size: 18px;
}
.video-item .content h3 a .subject-content {
  word-break: break-all;
}

.video-overlay {
  display: none;
}

.video-item .thumbnail a img {
  transition: filter 1s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.video-item .thumbnail a:hover img {
  filter: blur(5px);
}
.video-item .thumbnail a:hover .video-overlay {
  opacity: 1;
}

.video-overlay {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 1s cubic-bezier(0.075, 0.82, 0.165, 1);
  opacity: 0;
}

.video-play-circle {
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.3);
  border-radius: 50%;
  color: #fff;
}

@media all and (max-width: 1024px) and (min-width: 641px) {
  .video-item {
    display: flex;
  }
  .video-item .thumbnail {
    flex: 0 0 50%;
  }
  .video-item .content {
    flex: 0 0 50%;
    margin-top: 0;
    padding-left: 40px;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    display: flex;
  }
}
@media all and (max-width: 1024px) {
  .board .section-text {
    padding-bottom: 0;
  }
  .board .section-row {
    flex-wrap: wrap;
  }
  .board .section-col {
    flex: 1 1 100%;
  }
}
@media all and (max-width: 640px) {
  .video-item .content h3 {
    font-size: 18px;
  }
  .video-item .content {
    margin-top: 10px;
  }
  .board .section-text {
    margin-bottom: 20px;
  }
  .board .section-row {
    margin-top: -20px;
    margin-left: -20px;
  }
  .board .section-col {
    padding-left: 20px;
    padding-top: 20px;
  }
}
.section-3 {
  background: var(--bg-beige);
  padding: 100px 0;
}

.section-3 .main-title {
  margin-bottom: 30px;
}

.section-3 ul {
  display: flex;
  flex-wrap: wrap;
  margin-left: -50px;
  margin-top: -50px;
}

.section-3 ul li {
  padding-left: 50px;
  padding-top: 50px;
  flex: 0 0 25%;
}

.section-3 ul li a {
  display: inline-block;
  width: 100%;
  height: 100%;
}

.program-item {
  position: relative;
  height: 100%;
  border-radius: 20px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

.program-thumb {
  aspect-ratio: 400/332;
  overflow: hidden;
}

.program-thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
}

.read-more {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 50px;
}

.read-more .link {
  position: relative;
  z-index: 1;
}

.program-content {
  padding: 15px 20px 20px 20px;
  color: var(--font-color-brown);
}

.program-content h3 {
  font-size: 20px;
  line-height: 1.4;
}

.program-content dl {
  font-size: 16px;
  margin-top: 20px;
  font-variant-numeric: lining-nums tabular-nums;
  letter-spacing: 0;
}

.program-content dl .program-row {
  display: flex;
  align-items: flex-start;
}
.program-content dl .program-row i {
  font-size: 14px;
}

.program-content dl .program-row + .program-row {
  margin-top: 0.4em;
}

.program-content dl .program-row dt {
  flex: 0 0 2em;
  max-width: 2em;
  text-align: center;
  margin-right: 0.4em;
  letter-spacing: 0;
}

.section-3 ul li a img {
  transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.section-3 ul li a:hover img {
  transform: scale(1.1);
}

@media all and (max-width: 1280px) {
  .program-content {
    padding: 15px 20px 20px 20px;
  }
  .program-content h3 {
    font-size: 20px;
  }
  .program-content dl .program-row dt {
    max-width: 1.5em;
    margin-right: 0.3em;
  }
  .program-content dl {
    font-size: 16px;
    margin-top: 10px;
  }
}
@media all and (max-width: 1024px) {
  .section-3 {
    padding: 80px 0;
  }
  .section-3 ul {
    margin-left: -30px;
    margin-top: -30px;
  }
  .section-3 ul li {
    flex: 1 1 50%;
    padding-top: 30px;
    padding-left: 30px;
  }
}
@media all and (max-width: 640px) {
  .section-3 {
    padding: 60px 0;
  }
  .section-3 ul {
    margin-left: -20px;
    margin-top: -20px;
  }
  .section-3 ul li {
    flex-basis: 100%;
    padding-top: 20px;
    padding-left: 20px;
  }
  .section-3 .main-title {
    margin-bottom: 10px;
  }
}
.header-ui .btn-hamburg {
  display: flex;
}

.hamburg {
  --bar-width:2px;
  --box-size: 30px;
  --bar-gap: calc(var(--box-size) / 7) ;
  position: relative;
}

.hamburg-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hamburg {
  width: var(--box-size);
  height: var(--box-size);
  background: transparent;
}
.hamburg .do-open {
  display: flex;
  flex-direction: column;
  gap: var(--bar-gap);
}
.hamburg .do-open i.bar {
  width: 100%;
  height: var(--bar-width);
  background: #000;
}
.hamburg .do-open i.bar.top {
  width: 50%;
  margin-right: auto;
  transform: rotate(-45deg);
}
.hamburg .do-open i.bar.mid {
  transform: rotate(-45deg);
}
.hamburg .do-open i.bar.bot {
  width: 50%;
  margin-left: auto;
  transform: rotate(-45deg);
}
.hamburg .do-close {
  flex-direction: column;
}
.hamburg .do-close i.bar {
  position: relative;
  width: 100%;
  height: var(--bar-width);
  background: #000;
}
.hamburg .do-close i.bar.left {
  transform: rotate(-45deg);
  top: calc(var(--bar-width) / 2);
}
.hamburg .do-close i.bar.right {
  transform: rotate(45deg);
  bottom: calc(var(--bar-width) / 2);
}

.hamburg {
  --transition-duration: 0.6s;
  --stagger-delay: calc(var(--transition-duration) / 6);
  --beetween-delay: calc(var(--transition-duration) / 2);
  --easing-out: cubic-bezier(0.33, 1, 0.68, 1);
  --easing-in: cubic-bezier(0, 1, 0, 1);
}
.hamburg i.bar {
  pointer-events: none;
}
.hamburg .do-open i.bar {
  will-change: opacity, transform;
  transition: transform var(--transition-duration) var(--easing-in), opacity var(--transition-duration) var(--easing-in);
}
.hamburg .do-open i.bar.top {
  transition-delay: calc(var(--stagger-delay) * 3 + var(--beetween-delay));
}
.hamburg .do-open i.bar.mid {
  transition-delay: calc(var(--stagger-delay) + var(--beetween-delay));
}
.hamburg .do-open i.bar.bot {
  transition-delay: calc(var(--stagger-delay) * 2 + var(--beetween-delay));
}
.hamburg .do-close i.bar {
  opacity: 0;
  transition: transform var(--transition-duration) var(--easing-out), opacity var(--transition-duration) var(--easing-out);
}
.hamburg .do-close i.bar.left {
  transition-delay: var(--stagger-delay);
  transform: rotate(-45deg) translateX(60px);
}
.hamburg .do-close i.bar.right {
  transition-delay: calc(var(--stagger-delay) * 2);
  transform: rotate(45deg) translateX(-60px);
}
.hamburg.active .do-open i.bar {
  opacity: 0;
  transform: none;
  transition: transform var(--transition-duration) var(--easing-out), opacity var(--transition-duration) var(--easing-out);
}
.hamburg.active .do-open i.bar.top {
  transition-delay: calc(var(--stagger-delay) * 3);
  transform: rotate(-45deg) translateX(60px);
}
.hamburg.active .do-open i.bar.mid {
  transition-delay: var(--stagger-delay);
  transform: rotate(-45deg) translateX(60px);
}
.hamburg.active .do-open i.bar.bot {
  transition-delay: calc(var(--stagger-delay) * 2);
  transform: rotate(-45deg) translateX(60px);
}
.hamburg.active .do-close i.bar {
  opacity: 1;
  will-change: opacity, transform;
  transition: transform var(--transition-duration) var(--easing-in), opacity var(--transition-duration) var(--easing-in);
}
.hamburg.active .do-close i.bar.left {
  transition-delay: calc(var(--stagger-delay) + var(--beetween-delay));
  transform: rotate(-45deg) translateX(0);
}
.hamburg.active .do-close i.bar.right {
  transition-delay: calc(var(--stagger-delay) * 2 + var(--beetween-delay));
  transform: rotate(45deg) translateX(0);
}

@media all and (min-width: 1025px) {
  .hamburg .do-open i.bar {
    position: relative;
    overflow: hidden;
  }
  .hamburg .do-open i.bar::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.7);
    transform: translateX(100%);
    transition: transform 0.2s cubic-bezier(0.86, 0, 0.14, 1);
  }
  .hamburg .do-open i.bar.top::before {
    transform-origin: center left;
  }
  .hamburg .do-open i.bar.mid::before {
    transform: translateX(-100%);
    transform-origin: center right;
  }
  .hamburg .do-open i.bar.bot::before {
    transform-origin: center left;
  }
  .hamburg:hover .do-open i.bar::before {
    transform: translateX(0);
  }
  .hamburg .do-close i.bar {
    position: relative;
    overflow: hidden;
  }
  .hamburg .do-close i.bar::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    transform: translateX(-100%);
    transition: transform 0.2s cubic-bezier(0.86, 0, 0.14, 1);
  }
  .hamburg .do-close i.bar.left::before {
    transform-origin: center left;
  }
  .hamburg .do-close i.bar.right::before {
    transform: translateX(100%);
    transform-origin: center right;
  }
  .hamburg:hover .do-close i.bar::before {
    transform: translateX(0);
  }
}
/* 1) 오프캔버스 전체 */
.offcanvas {
  position: fixed;
  inset: 0; /* top/right/bottom/left: 0 */
  overflow: hidden;
  pointer-events: none;
  z-index: 50;
}

/* 2) 기울어진 덮개: 근사 대각선 길이 */
.full-cover {
  position: absolute;
  top: 50%;
  left: 50%;
  /* vmax × √2 ≈ 1.4142 */
  width: var(--diag, 141.42vmax);
  height: var(--diag, 141.42vmax);
  transform: translate(-50%, -50%) rotate(45deg);
  transform-origin: center;
  pointer-events: none;
}

/* 3) 3분할 슬라이스 */
.slice {
  position: absolute;
  top: 0;
  height: 100%;
  width: 33.3333%;
  transform: scaleX(0);
  transition: transform 0.6s cubic-bezier(0.86, 0, 0.14, 1), background-color 0.6s cubic-bezier(0.86, 0, 0.14, 1);
  clip-path: inset-rectangle(from top, from right, from bottom, from left);
  background-color: rgb(98, 149, 202);
}

.slice--1 {
  left: 0;
  width: calc(33.3333% + 1px); /* 1px 오버랩 */
  transform-origin: left center;
}

.slice--2 {
  left: calc(33.3333% - 1px); /* 1px 당겨오기 */
  width: calc(33.3333% + 2px); /* 양쪽 각각 1px 오버랩 */
  transform-origin: center center;
}

.slice--3 {
  left: calc(66.6666% - 1px); /* 1px 당겨오기 */
  width: calc(33.3333% + 1px); /* 1px 오버랩 */
  transform-origin: right center;
}

/* 4) 애니메이션 토글 */
.offcanvas {
  pointer-events: none;
}

.menu-open .offcanvas {
  pointer-events: auto;
  z-index: 5000;
}
.menu-open .offcanvas .slice {
  transform: scaleX(1);
}

.menu-content {
  position: absolute;
  inset: 0; /* full-cover 위에 꽉 차게 */
  display: flex;
  align-items: center; /* 수직 중앙 */
  justify-content: center; /* 수평 중앙 */
}

#smooth-wrapper {
  transition: transform 0.6s cubic-bezier(0.86, 0, 0.14, 1), opacity 0.6s cubic-bezier(0.86, 0, 0.14, 1), filter 0.6s cubic-bezier(0.86, 0, 0.14, 1);
}

.menu-open .offcanvas .slice {
  background: #fafafa;
}
.menu-open #smooth-wrapper {
  opacity: 0;
  transform: scale(0.998);
  filter: blur(1vw);
}
.menu-open h1.logo a {
  color: #fff;
}
.menu-open h1.logo .title {
  text-shadow: none;
}
.menu-open .main-menu-title {
  text-shadow: none;
}
@keyframes gradient {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}
.menu-scrollable-wrapper {
  overflow-x: hidden;
  overflow-y: auto;
  width: 100%;
  height: 100%;
}
.menu-scrollable-wrapper .container {
  height: 100%;
}
.menu-scrollable-wrapper .menu-row {
  display: flex;
  gap: 160px;
}
.menu-scrollable-wrapper .menu-row .menu-col {
  flex: 1 1 50%;
  min-width: 0;
}
.menu-scrollable-wrapper .menu-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.menu-content {
  padding-top: 70px;
}

.mobile-nav {
  line-height: 1;
}
.mobile-nav a {
  display: inline-flex;
}
.mobile-nav .depth1 .depth1-li + .depth1-li {
  margin-top: 2rem;
}
.mobile-nav .depth1 .depth1-li.current .depth1-li-a {
  color: #999;
}
.mobile-nav .depth1 .depth1-li .depth1-li-a {
  font-size: 30px;
}
.mobile-nav .depth2 {
  display: flex;
  margin-top: 1.5rem;
  padding-left: 1rem;
}
.mobile-nav .depth2 .depth2-li {
  flex: 0 0 auto;
  min-width: 0;
}
.mobile-nav .depth2 .depth2-li + .depth2-li {
  position: relative;
  margin-left: 1rem;
  padding-left: 1rem;
}
.mobile-nav .depth2 .depth2-li + .depth2-li::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 1px;
  height: 60%;
  background: #999;
  transform-origin: center center;
  transform: translateY(-50%) rotate(30deg);
  margin-top: 1px;
}
.mobile-nav .depth2 .depth2-li.current .depth2-li-a {
  color: #999;
}
.mobile-nav .depth2 .depth2-li .depth2-li-a {
  font-size: 18px;
  line-height: 1;
}

.mobile-info {
  line-height: 1;
}
.mobile-info .site-name {
  font-size: 20px;
  white-space: nowrap;
}
.mobile-info .site-contact {
  margin-top: 2rem;
}
.mobile-info .contact-item {
  position: relative;
  display: block;
  padding-bottom: 1rem;
  margin-bottom: 1rem;
}
.mobile-info .contact-item:last-child {
  margin: 0;
}
.mobile-info .contact-item::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: rgba(0, 0, 0, 0.25);
}
.mobile-info .contact-item .label {
  display: block;
  margin-bottom: 0.8rem;
  font-size: 14px;
  opacity: 0.6;
}
.mobile-info .contact-item .content {
  display: block;
  padding-left: 1rem;
  font-variant-numeric: lining-nums tabular-nums;
  letter-spacing: 0;
  font-size: 12px;
  line-height: 1.2;
}

.site-name span,
.mobile-info .contact-item .label span,
.mobile-info .contact-item .content span,
.depth1-li-a span {
  display: inline-block;
}

.depth1-li-a,
.depth2,
.depth2-li-a,
.site-name,
.mobile-info .contact-item .label,
.mobile-info .contact-item .content {
  overflow: hidden;
}

.depth1-li-a span,
.depth2-li-a span,
.site-name span,
.mobile-info .contact-item .label span,
.mobile-info .contact-item .content span {
  will-change: transform, opacity;
  opacity: 0;
  transform: translateY(30px);
  transition: transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.depth2-li::before {
  display: block;
  will-change: opacity;
  opacity: 0;
  transition: opacity 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.menu-open .depth2-li::before {
  opacity: 1;
  transition: opacity 2s cubic-bezier(0.22, 0.61, 0.36, 1) 0.6s;
}

.menu-open .depth1-li-a span,
.menu-open .depth2-li-a span,
.menu-open .site-name span,
.menu-open .mobile-info .contact-item .label span,
.menu-open .mobile-info .contact-item .content span {
  opacity: 1;
  transform: none;
  transition: transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s;
}

.mobile-info .contact-item::before {
  will-change: transform;
  transform-origin: left center;
  transform: scale(0);
  transition: transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.menu-open .mobile-info .contact-item::before {
  transform: scale(1);
  transition: transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1) 0.6s;
}

@media all and (max-width: 800px) {
  .menu-scrollable-wrapper .menu-row {
    gap: 40px;
  }
}
@media all and (max-width: 640px) {
  .menu-scrollable-wrapper .container {
    height: auto;
  }
  .menu-scrollable-wrapper .menu-wrapper {
    padding: 5px;
    padding-top: 4rem;
    padding-bottom: 25px;
  }
  .menu-scrollable-wrapper .menu-row {
    flex-wrap: wrap;
    gap: calc(4rem + 11px);
  }
  .menu-scrollable-wrapper .menu-row .menu-col {
    flex: 1 1 100%;
  }
  .mobile-info {
    background: rgba(255, 255, 255, 0.05);
    padding: 20px;
    border-radius: 16px;
  }
  .mobile-info {
    background-color: transparent;
    transition: background-color 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
  }
  .menu-open .mobile-info {
    background-color: #18ac4e;
    color: #fff;
    transition: background-color 0.6s 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
  }
  .mobile-info .contact-item::before {
    background: rgba(255, 255, 255, 0.5);
  }
}
.mobile-nav .depth2 {
  flex-wrap: wrap;
  gap: 1em 0;
}

.menu-container {
  min-width: 341px;
  max-width: 341px;
  width: 341px;
}

.mobile-nav .depth2 .depth2-li:nth-child(4) {
  margin: 0;
  padding: 0;
}
.mobile-nav .depth2 .depth2-li:nth-child(4)::before {
  display: none;
}

@media all and (max-width: 1280px) {
  .container-narrow {
    max-width: auto;
    padding: 0 20px;
  }
}
@media all and (max-width: 1024px) {
  :root {
    --container-width: 100%;
    --container-padding: 20px;
    --theme-color: #0055a4;
    --theme-color-dark: #00407c;
    /* ——— Accent Colors ——— */
    --color-orange: #FF6B35;
    --color-mint: #3FE0D0;
    --color-sky: #6EC1E4;
    --color-red: #D7263D;
    --color-red-light: #d63c50;
  }
  .fixed-header {
    left: 10px;
    top: 10px;
    right: 10px;
    padding: 0;
    width: auto;
    background: hsla(0, 0%, 100%, 0.6);
    box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.1);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    padding-bottom: 0;
    border-radius: 16px;
    overflow: hidden;
    transition: all 0.6s cubic-bezier(0.86, 0, 0.14, 1);
  }
  .fixed-header .container {
    padding: 5px;
  }
  .menu-open .fixed-header {
    background: transparent;
    -webkit-backdrop-filter: none;
            backdrop-filter: none;
    box-shadow: none;
  }
  h1.logo .title {
    font-size: 20px;
    text-shadow: none;
  }
  .cd-morph-dropdown {
    display: none;
  }
  .header-ui .btn-hamburg {
    margin-right: -5px;
  }
  .wrap {
    padding-top: 0;
  }
}
@media all and (max-width: 640px) {
  :root {
    --container-padding: 20px;
  }
}
@media all and (max-width: 1690px) {
  .header-ui {
    gap: 60px;
  }
  .header-etc {
    gap: 20px;
  }
  .main-nav > ul {
    gap: 60px;
  }
  .main-menu-title {
    padding: 10px;
    font-size: 18px;
  }
  .search-box input {
    max-width: 180px;
  }
  .header-search-submit {
    font-size: 14px;
    padding: 0 1em;
  }
  .search-box input, .search-box .header-search-submit, .header-search-submit {
    height: 38px;
  }
}
@media all and (max-width: 1440px) {
  .header-etc {
    gap: 20px;
  }
}
@media all and (max-width: 1280px) {
  .header-ui {
    gap: 40px;
  }
  .main-nav > ul {
    gap: 40px;
  }
  .main-menu-title {
    padding: 10px;
    font-size: 16px;
  }
  h1.logo a img, h1.logo a svg {
    width: 230px;
  }
}
@media all and (max-width: 1024px) {
  .fixed-header svg,
  .fixed-header.theme-dark svg,
  .fixed-header.theme-white svg {
    fill: #000 !important;
    will-change: fill;
    transition: fill 0.6s cubic-bezier(0.86, 0, 0.14, 1);
  }
  .menu-open .fixed-header svg,
  .menu-open .fixed-header.theme-dark svg,
  .menu-open .fixed-header.theme-white svg {
    fill: #fff !important;
  }
  .header-etc {
    gap: 20px;
  }
  .search-box,
  .header-search-submit {
    border-radius: 12px;
  }
  .mobile-search .header-search-submit {
    transition: background-color 0.6s cubic-bezier(0.22, 0.61, 0.36, 1), color 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
  }
  .menu-open .mobile-search .header-search-submit {
    background: #fff;
    color: #1c1d1d;
  }
  .header-ui {
    gap: 20px;
    padding-right: 10px;
  }
  .header-ui .btn-hamburg {
    display: flex !important;
    padding: 0;
    margin: 0;
  }
  h1.logo a {
    padding: 10px;
  }
  h1.logo a img, h1.logo a svg {
    max-width: none;
    height: 38px;
    width: auto;
  }
  .search-box input {
    max-width: 200px;
  }
  .urinong {
    display: none;
  }
}
@media all and (min-width: 641px) {
  .mobile-search {
    display: none;
  }
}
@media all and (max-width: 640px) {
  .search-box {
    display: none;
  }
  h1.logo a {
    padding: 5px;
  }
}
@media all and (max-width: 480px) {
  .search-box input {
    max-width: 170px;
  }
}
@media all and (max-width: 1690px) {
  .breadcrumb .home > span {
    width: 38px;
    height: 38px;
  }
  .breadcrumb .home > span i {
    font-size: 12px;
  }
}
@media all and (max-width: 1440px) {
  .subpage-top .hero-container {
    height: 300px;
  }
  .hero-container .hero-overlay h2 {
    font-size: 40px;
  }
}
@media all and (max-width: 1024px) {
  .subpage-top {
    margin-top: 88px;
    padding-top: 20px;
  }
  .subpage-top .hero-container {
    height: 250px;
  }
  .hero-container .hero-overlay small {
    font-size: 22px;
  }
  .hero-container .hero-overlay h2 {
    font-size: 30px;
  }
}
@media all and (max-width: 640px) {
  .subpage-top {
    margin-top: 78px;
    padding-top: 0;
  }
  .breadcrumb .home > span {
    width: 30px;
    height: 30px;
    border-radius: 12px;
  }
  .subpage-top .hero-container {
    height: 200px;
  }
  .hero-container .hero-overlay small {
    font-size: 18px;
  }
  .hero-container .hero-overlay h2 {
    padding-top: 0;
    font-size: 22px;
  }
  .breadcrumb-container {
    padding: 10px 0;
  }
  .breadcrumb {
    gap: 0.3em;
  }
  .breadcrumb .breadcrumb-dropdown .breadcrumb-toggle {
    font-size: 14px;
    padding: 5px 7px;
  }
  .breadcrumb .breadcrumb-dropdown .dropdown-menu li a {
    font-size: 12px;
  }
  .breadcrumb .breadcrumb-dropdown .dropdown-menu {
    left: 50%;
    transform: translateX(-50%);
  }
  .hero-container {
    border-radius: 15px;
  }
  .page-top-title-inner {
    padding: 1em 2em;
    border-radius: 10px;
  }
  .subpage-top .hero-container {
    height: 150px;
  }
}
@media all and (max-width: 1690px) {
  .maeul-filter .filter-form .filter-select, .maeul-filter .filter-form .filter-input,
  .maeul-filter .filter-form .filter-submit .filter-btn {
    height: 38px;
  }
}
@media all and (max-width: 1280px) {
  .maeul-filter .filter-form .filter-group {
    flex: 1 1 calc(50% - 40px);
  }
}
@media all and (max-width: 1024px) {
  .maeul-filter .filter-form .filter-group {
    flex: 1 1 100%;
  }
  .maeul-list .card-grid {
    flex: 1 1 50%;
  }
}
@media all and (max-width: 640px) {
  .maeul-filter .filter-form .filter-input-wrap,
  .maeul-filter .filter-form .filter-submit {
    flex: 1 1 100%;
  }
  .maeul-filter .filter-form .filter-row,
  .maeul-filter .filter-form .filter-group {
    gap: 10px;
  }
  .maeul-filter .filter-container {
    padding: 20px;
  }
  .maeul-filter .filter-form .filter-input {
    width: 100%;
  }
  .maeul-filter .filter-form .filter-group.fixed-width {
    min-width: 0;
  }
  .maeul-list .card-row {
    margin-top: -20px;
    margin-left: -20px;
  }
  .maeul-list .card-grid {
    padding-top: 20px;
    padding-left: 20px;
  }
  .maeul-list .card-grid,
  .map-col.list .maeul-list .card-grid {
    flex: 1 1 100%;
  }
  .maeul-list .card-text {
    margin-top: 10px;
  }
}
@media all and (max-width: 1690px) {
  .maeul-gallery .maeul-gallery-nav button .icon {
    width: 38px;
    height: 38px;
    border-radius: 38px;
  }
}
@media all and (max-width: 1440px) {
  .maeul-header h2 {
    font-size: 30px;
  }
}
@media all and (max-width: 1024px) {
  .maeul-hero {
    aspect-ratio: 167/111;
  }
  .info-flex-table .info-row .info-cell .label {
    flex: 0 0 115px;
  }
  .info-details .info-row {
    flex-wrap: wrap;
  }
  .info-details .info-col.map,
  .info-details .info-col.text {
    flex: 1 1 100%;
  }
}
@media all and (max-width: 800px) {
  .info-flex-table .info-row {
    border: none;
  }
  .info-flex-table .info-row .info-cell {
    flex: 1 1 100%;
    border-bottom: 1px solid #f1f1f1;
  }
}
@media all and (max-width: 640px) {
  .maeul-header h2 {
    font-size: 22px;
  }
  .maeul-header small {
    flex: 1 1 100%;
    margin-top: 10px;
  }
  .maeul-header {
    margin-bottom: 20px;
  }
  .maeul-detail section + section {
    margin-top: 20px;
  }
  .maeul-gallery {
    margin: 20px 0;
  }
  .maeul-section-header .title-content {
    font-size: 18px;
  }
  .maeul-gallery .maeul-gallery-nav button .icon {
    width: 30px;
    height: 30px;
    border-radius: 30px;
  }
  .maeul-header small,
  .info-flex-table .info-row .info-cell {
    font-size: 14px;
  }
  .info-flex-table .info-row .info-cell .label,
  .info-flex-table .info-row .info-cell .value {
    padding: 15px 10px;
  }
  .info-details .info-grid .grid {
    flex: 1 1 100%;
  }
  .info-details .info-grid {
    margin-left: -20px;
    margin-top: -20px;
  }
  .info-details .info-grid .grid {
    padding-top: 10px;
    padding-left: 10px;
  }
  .info-details .info-grid .grid {
    min-height: 0;
  }
  .info-details .info-grid .grid dt {
    font-size: 16px;
  }
  .info-details .info-grid .grid dd {
    font-size: 14px;
    word-break: keep-all;
  }
  .page-back.bottom {
    margin-top: 20px;
  }
}
@media all and (max-width: 1024px) {
  .map-col.map {
    padding-right: 20px;
  }
  .search-map {
    padding: 20px;
  }
  .map-col.map {
    flex: 0 1 50%;
    min-height: 0 !important;
  }
  .map-col.map .search-map {
    position: static;
  }
  .map-col.list {
    flex: 1 1 50%;
  }
  .map-col.list .maeul-list .card-grid {
    flex: 1 1 100%;
  }
  .map-wrapper .label-container .label {
    font-size: 11px;
  }
}
@media all and (max-width: 640px) {
  .map-row {
    flex-wrap: wrap;
  }
  .map-col.map {
    padding-right: 0;
    padding-bottom: 20px;
  }
  .map-col.map,
  .map-col.list {
    flex: 1 1 100%;
  }
  .page-id-map .maeul-list .container {
    padding: 0;
  }
}
@media all and (max-width: 640px) and (min-width: 481px) {
  .map-wrapper {
    padding: 20px;
  }
}
@media all and (max-width: 480px) {
  .map-wrapper .label-container .label {
    font-size: 10px;
  }
}
@media all and (max-width: 1440px) {
  .council-container h3 {
    font-size: 30px;
  }
}
@media all and (max-width: 1024px) {
  .council-container .council-row {
    justify-content: center;
  }
  .council-container .council-col.info {
    flex: 1 1 100%;
  }
}
@media all and (max-width: 640px) {
  .council-container .council-col.thumbnail {
    padding-right: 0;
    flex: 1 1 100%;
  }
  .council-container .info-flex-table {
    border-radius: 0;
  }
  .council-container article + article {
    margin-top: 20px;
  }
  .branches-section {
    margin-top: 40px;
  }
  .council-container h3 {
    margin-bottom: 20px;
    padding: 20px;
    font-size: 22px;
  }
}
@media all and (max-width: 640px) {
  .search-header {
    margin: 20px 0;
  }
  .search-header h2 {
    font-size: 18px;
  }
  .search-summary {
    gap: 10px;
  }
  .search-tabs {
    padding: 10px 0;
    margin-bottom: 40px;
  }
  .search-tabs ul {
    gap: 10px;
  }
  .search-tabs a {
    padding: 0.2em 0.5em;
    font-size: 12px;
    height: 30px;
  }
  .search-summary li {
    padding: 20px 10px;
    line-height: 1;
  }
  .search-summary li strong {
    margin-bottom: 10px;
  }
  .list-heading {
    margin-bottom: 20px;
  }
  .page-id-search .list-type-1 .th {
    display: none;
  }
  .page-id-search main.content {
    padding-bottom: 40px;
  }
}
@media all and (max-width: 1280px) {
  .login-split-wrap .login-left {
    padding: 80px 20px;
    justify-content: center;
  }
  .login-split-wrap .login-right {
    padding: 80px 20px;
    justify-content: center;
  }
}
@media all and (max-width: 1024px) {
  .login-split-wrap {
    min-height: auto;
    flex-wrap: wrap;
  }
  .login-split-wrap .login-left {
    flex: 1 1 100%;
    padding: 40px 20px;
    justify-content: center;
    padding-top: 118px;
  }
  .login-split-wrap .login-right {
    flex: 1 1 100%;
    padding: 40px 20px;
    justify-content: center;
  }
  .login-split-wrap .login-right form .form-group .form-input,
  .login-split-wrap .login-right form .form-submit .btn-login {
    border-radius: 12px;
  }
}
@media all and (max-width: 640px) {
  .login-split-wrap .login-right .login-form-box {
    max-width: 100%;
    padding: 20px;
  }
  .login-split-wrap .login-right .login-logo {
    margin-bottom: 20px;
  }
  .login-split-wrap .login-left .login-msg-box {
    text-align: center;
  }
  .login-split-wrap .login-left .login-msg-box .login-main-msg {
    font-size: 22px;
    text-align: center;
  }
  .login-split-wrap .login-right .login-logo {
    font-size: 22px;
  }
  .login-split-wrap .login-left .login-msg-box .login-sub-msg {
    font-size: 14px;
    word-break: break-all;
    text-align: left;
    display: block;
  }
  .login-split-wrap .login-left .login-msg-box .login-sub-msg br {
    display: none;
  }
  .login-split-wrap .login-left .login-msg-box a {
    font-size: 18px;
  }
  .login-split-wrap .login-left {
    padding: 20px;
    padding-top: 88px;
  }
  .login-split-wrap .login-right {
    padding: 20px;
  }
}
.bbs-view-item img {
  max-width: 100%;
}

.bbs-view-header .bbs-view-info .info.date {
  font-variant-numeric: lining-nums tabular-nums;
  letter-spacing: 0;
}

@media all and (max-width: 1024px) {
  .board {
    padding-top: 0;
  }
}