@charset "UTF-8";

@import url("https://img.seoul.co.kr/css/webfont_pretendard.css");

/* reset css */

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;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

caption {
    display: none;
}

html {
    scroll-behavior: smooth;
}

body {
    position: relative;
    font-family: "Pretendard";
    font-style: normal;
    font-weight: 400;
    line-height: 170%;
}

ol,
li,
dl,
dt,
dd {
    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;
}

a,
a:hover,
a:active,
a:link,
a:visited {
    text-decoration: none;
    outline: none;
    cursor: pointer;
}

a {
    font-family: inherit;
    font-size: inherit;
    font-style: inherit;
    font-weight: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: inherit;
}

:root {
    --bg-primary-100: #f26930;
    --bg-b-bg: #262323;
    --text-gray-100: #f8f8f8;
    --text-gray-200: #f4f4f4;
    --text-gray-300: #eee;
    --text-gray-400: #ddd;
    --text-gray-500: #999;
    --text-gray-600: #666;
    --text-gray-700: #444;
    --text-black: #111;
    --text-white: #fff;
    --etc-notice: #f00;
    --etc-notice-blue: #3a84ff;
}

/* headline text */
.h44 {
    color: var(--text-black, #111);
    /* PC/H_44 */
    font-family: Pretendard;
    font-size: 44px;
    font-style: normal;
    font-weight: 700;
    line-height: 1.4em;
    /* 136.364% */
    letter-spacing: -0.44px;
}

.h38 {
    color: var(--text-black, #111);
    /* PC/H_38 */
    font-family: Pretendard;
    font-size: 38px;
    font-style: normal;
    font-weight: 700;
    line-height: 48px;
    /* 126.316% */
    letter-spacing: -0.38px;
}

.h32 {
    color: var(--text-black, #111);
    /* PC/H_32 */
    font-family: Pretendard;
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: 44px;
    /* 137.5% */
    letter-spacing: -0.32px;
}

.h28 {
    color: var(--text-black, #111);
    /* PC/H_28 */
    font-family: Pretendard;
    font-size: 28px;
    font-style: normal;
    font-weight: 700;
    line-height: 40px;
    /* 142.857% */
    letter-spacing: -0.28px;
}

.h24 {
    color: var(--text-black, #111);
    /* PC/H_24 */
    font-family: Pretendard;
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: 34px;
    /* 141.667% */
    letter-spacing: -0.24px;
}

.h20 {
    color: var(--text-black, #111);
    /* PC/H_20 */
    font-family: Pretendard;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 30px;
    /* 150% */
    letter-spacing: -0.2px;
}

.h18 {
    color: var(--text-black, #111);
    /* PC/H_18 */
    font-family: Pretendard;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 30px;
    /* 166.667% */
    letter-spacing: -0.18px;
}

.h16 {
    color: var(--text-black, #111);
    /* PC/H_16 */
    font-family: Pretendard;
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 26px;
    /* 162.5% */
    letter-spacing: -0.16px;
}

.h15 {
    color: var(--text-black, #111);
    /* PC/H_15 */
    font-family: Pretendard;
    font-size: 15px;
    font-style: normal;
    font-weight: 700;
    line-height: 22px;
    /* 146.667% */
    letter-spacing: -0.15px;
}

.h14 {
    color: var(--text-black, #111);
    /* PC/H_14 */
    font-family: Pretendard;
    font-size: 14px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
    /* 171.429% */
    letter-spacing: -0.14px;
}

.e14 {
    color: var(--text-black, #111);
    /* PC/EN_14 */
    font-family: Montserrat;
    font-size: 14px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
    /* 171.429% */
    letter-spacing: -0.28px;
}

/* body text */
.body20 {
    color: var(--text-black, #111);
    /* PC/body_20 */
    font-family: Pretendard;
    font-size: 20px;
    font-style: normal;
    font-weight: 500;
    line-height: 32px;
    /* 160% */
    letter-spacing: -0.2px;
}

.body18 {
    color: var(--text-black, #111);
    /* PC/body_18 */
    font-family: Pretendard;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 32px;
    /* 177.778% */
    letter-spacing: -0.18px;
}

.body16 {
    color: var(--text-black, #111);
    /* PC/body_16 */
    font-family: Pretendard;
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: 28px;
    /* 175% */
    letter-spacing: -0.16px;
}

.body15 {
    font-family: Pretendard;
    font-size: 15px;
    font-style: normal;
    font-weight: 500;
    line-height: 24px;
    /* 160% */
    letter-spacing: -0.15px;
}

.body14 {
    color: var(--text-black, #111);
    /* PC/body_14 */
    font-family: Pretendard;
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 24px;
    /* 171.429% */
    letter-spacing: -0.14px;
}

.body13 {
    color: var(--text-black, #111);
    /* PC/body_13 */
    font-family: Pretendard;
    font-size: 13px;
    font-style: normal;
    font-weight: 500;
    line-height: 1.4em;
    /* 153.846% */
    letter-spacing: -0.13px;
}

.colorPrimary {
    color: var(--bg-primary-100);
}

.colorNotice {
    color: var(--etc-notice-blue);
}

.colorRed {
    color: var(--etc-notice);
}

.color111 {
    color: var(--text-black);
}

.color000 {
    color: var(--bg-b-bg);
}

.colorFFF {
    color: var(--text-white);
}

.color700 {
    color: var(--text-gray-700);
}

.color600 {
    color: var(--text-gray-600);
}

.color500 {
    color: var(--text-gray-500);
}

.color400 {
    color: var(--text-gray-400);
}

.color300 {
    color: var(--text-gray-300);
}

.color200 {
    color: var(--text-gray-200);
}

.color100 {
    color: var(--text-gray-100);
}

.hideText {
    overflow: hidden;
    text-indent: -9999px;
    color: transparent;
    font-size: 0;
}

.font0 {
    font-size: 0;
    color: transparent;
}

.popupBox {
    display: none;
    z-index: 1000;
    position: fixed;
    top: 50vh;
    left: 50%;
    transform: translate(-50%, -50%);
    background: var(--text-white);
    border-radius: 4px;
    width: 550px;
}

.popupBox .topSide {
    position: relative;
    display: flex;
    justify-content: center;
    padding: 17px 20px 5px;
}

.popupBox .topSide .icon {
    width: 12px;
    height: 19px;
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/popup-logo.png") no-repeat center;
    background-size: contain;
}

.popupBox .topSide .closeBtn {
    position: absolute;
    right: 24px;
    width: 28px;
    height: 28px;
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/closeBtn.png") no-repeat center;
    background-size: 95%;
    cursor: pointer;
}

.popupBox .contentSide {
    padding: 0 32px;
}

.popupBox .contentSide .scrollbar {
    height: 400px;
}

.popupBox .bottomSide {
    padding: 32px 32px 20px;
    display: flex;
    justify-content: center;
    gap: 8px;
}

.popupBox .bottomSide button {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px 12px;
    border-radius: 4px;
    min-width: 110px;
    height: 36px;
}

.popupBox .bottomSide .grayBtn {
    color: var(--text-black);
}

.dim {
    display: none;
    z-index: 1;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
}

.onlyMo {
    display: none;
}

.bold {
    font-weight: 600;
}

header {
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/header-bg.png") no-repeat center;
    padding: 68px 0 64px;
    background-size: cover;
}

header .headerWrap {
    display: flex;
    flex-direction: column;
    gap: 48px;
}

.header-top {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.header-bottom {
    font-size: 28px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    letter-spacing: -0.84px;
    color: rgba(255, 255, 255, 0.7);
}

.header-bottom strong {
    font-weight: 600;
}

.header-logo {
    width: 180px;
}

.header-logo img {
    width: 100%;
}

.header-title {
    width: 523px;
}

.header-title img {
    width: 100%;
}

.layoutWrap {
    max-width: 1280px;
    margin: 0 auto;
}

.formInputBox input:focus,
.formInputBox select:focus,
.formInputBox textarea:focus {
    transition: all 0.5s;
    outline: var(--text-black);
    border-color: black;
}

input:focus {
    border-color: var(--text-black) !important;
}

.formInputBox input[type="search"] {
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/search.png") no-repeat calc(100% - 16px) center;
    background-size: 20px;
}

.formInputBox input:not([type="checkbox"]):not([type="radio"]):not([type="file"]) {
    width: 100%;
    height: 48px;
    padding: 0 12px;
    border: 0;
    border: 1px solid #f1f1f1;
    background-color: #fff;
    box-sizing: border-box;
    font-size: 16px;
    font-family: "Pretendard";
    /* -webkit-appearance: none; */
    -webkit-border-radius: 5px;
    color: var(--text-black);
    text-align: left;
}

.formInputBox input:not([type="checkbox"]):not([type="radio"]):not([type="file"])::placeholder {
    font-weight: lighter;
}

input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration {
    display: none;
}

input[type="date"] {
    min-width: 170px;
}

input[type="radio" i] {
    padding: 0;
    margin: 0;
}

input[type="date"],
input[type="checkbox"]+label,
input[type="radio"]+label {
    cursor: pointer;
}

input[type="radio"],
input[type="checkbox"] {
    cursor: pointer;
    accent-color: var(--text-black);
}

input[type="checkbox"]+label {
    cursor: pointer;
}

input[type="date"] {
    width: 100%;
    font-size: 16px;
    font-family: "Pretendard";
}

.formInputBox input[type="file"] {
    border: 0;
    font-size: 14px;
    font-family: "Pretendard";
    padding: 0 8px 0 0;
}

.formInputBox input::placeholder,
.formInputBox textarea::placeholder {
    font-family: "Pretendard";
    font-size: 14px;
    font-weight: normal;
    color: var(--text-gray-500);
}

.form-textarea {
    font-family: "Pretendard";
    box-sizing: border-box;
    width: 100%;
    height: 200px;
    padding: 20px 16px;
    font-size: 17px;
    font-weight: 500;
    line-height: 1.45;
    border: 1px solid #d9d9d9;
    background: #f6f6f6;
    -webkit-appearance: none;
    -webkit-border-radius: 0;
}

.inputBox {
    position: relative;
    display: inline-block;
}

.search-reset {
    position: absolute;
    width: 1em;
    height: 1em;
    border: 1px solid green;
    padding: 0;
    cursor: pointer;
    background: green;
    border-radius: 50%;
    top: 50%;
    right: 0.5em;
    transform: translateY(-50%) rotateZ(45deg);
    z-index: 1;
    transition: all 0.065s;
}

.search-reset::before,
.search-reset::after {
    content: "";
    position: absolute;
    width: 0.6em;
    height: 2px;
    background: #fff;
    top: calc(50% - 1px);
    left: calc(50% - 0.3em);
}

.search-reset::after {
    transform: rotateZ(90deg);
}

.search-reset:disabled {
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
}

.dash {
    padding: 0 8px;
}

section.tabBoxWrap {
    margin: 70px 0 0;
}

.tabMenu {
    display: flex;
    align-items: center;
    gap: 80px;
    margin: 50px 0 60px;
    border-bottom: 1px solid var(--text-gray-400);
}

.tabMenu li {
    cursor: pointer;
    padding: 0 10px 11px;
}

.display-flex {
    display: flex;
    align-items: center;
}

.flex-column {
    flex-direction: column;
}

.flex-shrink {
    flex-shrink: 0;
}

.flex-start {
    align-items: flex-start;
    justify-content: flex-start;
}

.font0 {
    font-size: 0;
    color: transparent;
}

.gap6 {
    gap: 6px;
}

.gap8 {
    gap: 8px;
}

.gap10 {
    gap: 10px;
}

.gap20 {
    gap: 20px;
}

.gap32 {
    gap: 32px;
}

.gap40 {
    gap: 40px;
}

.gap60 {
    gap: 60px;
}

.width100 {
    width: 100px;
}

.width100p {
    width: 100%;
}

.width80 {
    width: 80px;
}

.maxWidth100 {
    max-width: 100px;
}

.mb20 {
    margin-bottom: 20px;
}

.mb30 {
    margin-bottom: 30px;
}

.mb60 {
    margin-bottom: 60px;
}

.form-flex-row {
    display: flex;
}

.display-flex {
    display: flex;
}

.justify-between {
    justify-content: space-between;
    width: 100%;
}

.justify-center {
    justify-content: center;
}

.form-row {
    padding: 10px 0;
    display: flex;
    align-items: center;
    width: 100%;
}

.form-row .labelBox {
    flex-shrink: 0;
    min-width: 200px;
}

.labelBox {
    font-weight: 600;
}

.form-flex-row .form-row .labelBox {
    min-width: 100px;
}

.form-row .labelBox.minWidth100 {
    min-width: 100px;
}

.innerBox .form-flex-row .form-row .labelBox.minWidth130,
.form-row .labelBox.minWidth130 {
    min-width: 130px;
}

.form-row .labelBox.minWidth200 {
    min-width: 200px;
}

.formButtomWrap {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin: 100px auto;
    width: 100%;
}

button {
    font-size: 14px;
    flex-shrink: 0;
}

a.btn:hover,
button:hover {
    cursor: pointer;
    transition: all 0.3s ease-in-out;
    opacity: 0.8;
}

.requireDot {
    position: relative;
}

.requireDot:after {
    content: "*";
    position: absolute;
    top: -2px;
    right: -9px;
    margin-left: 2px;
    font-weight: 400;
    font-size: 14px;
    width: 5px;
    height: 5px;
    border-radius: 10px;
    display: block;
    color: var(--bg-primary-100);
    /* background: var(--bg-primary-100); */
}

.checkbox,
.radioBox {
    display: flex;
    align-items: center;
}

.checkbox label,
.radioBox label {
    padding-left: 8px;
}

.form-control {
    position: relative;
    width: 100%;
    height: 48px;
    padding: 0 16px;
    border: 1px solid #f1f1f1;
    /* background-color: #f5f6f7; */
    box-sizing: border-box;
    font-size: 16px;
    font-family: "Pretendard";
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    -webkit-border-radius: 5px;
    color: var(--text-black);

    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/arrow.png") #fff calc(100% - 10px) center no-repeat;
    background-size: 20px;
    padding: 5px 30px 5px 10px;
    border-radius: 4px;
    outline: 0 none;
}

select {
    cursor: pointer;
}

select option {
    background-color: #fff;
    /* 옵션 배경 */
    color: #111;
}

select::-ms-expand {
    display: none;
}

.sideBox {
    box-sizing: border-box;
    width: 50%;
    padding: 30px 40px;
    border: 1px solid var(--text-gray-300);
    border-radius: 16px;
    box-shadow: 0 20px 24px -2px rgba(35, 48, 59, 0.1);
}

.leftSide {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.innerBox {
    background: #f7f7fa;
    padding: 16px 28px;
    border-radius: 16px;
}

textarea {
    padding: 8px;
    border: 1px solid #f1f1f1;
    width: 100%;
    font-size: 13px;
    color: var(--text-gray-600);
    font-family: "Pretendard";
    line-height: 1.4em;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.textareaBox {
    box-sizing: border-box;
    height: 156px;
    width: 100%;
    overflow-y: scroll;
    padding: 20px;
    border: 1px solid #e5e5ec;
    border-radius: 4px;
}

.moreInfo {
    text-decoration: underline;
    display: inline;
    padding: 0 20px;
    cursor: pointer;
}

section.gift {
    margin: 150px 0 0;
    position: relative;
    background: var(--text-gray-300);
    padding: 0 0 120px;
}

.giftTopSide {
    position: absolute;
    left: 50%;
    top: -42px;
    transform: translateX(-50%);
    display: flex;
    justify-content: center;
}

.giftTopSide .topTit {
    display: inline-flex;
    gap: 8px;
    align-items: center;
    justify-content: center;
    background: var(--bg-b-bg);
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: 44px;
    /* 137.5% */
    letter-spacing: -0.32px;
    padding: 20px 60px;
    border-radius: 100px;
}

.giftTopSide .icon {
    width: 34px;
    height: 34px;
    display: block;
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/iconset.png") no-repeat center;
    background-size: 299px;
    background-position: -144px -8px;
}

.giftInfo {
    padding: 90px 0 0;
    text-align: center;
    font-size: 32px;
    font-style: normal;
    font-weight: 500;
    line-height: 44px;
    /* 137.5% */
    letter-spacing: -0.32px;
}

.slide-gift {
    padding: 60px 0 17px;
}

.slide-gift li {
    display: flex;
    overflow: hidden;
}

.slide-gift li .box {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 280px;
    height: 425px;
    background: var(--text-white);
    border-radius: 12px;
    box-shadow: 2px 4px 12px 0 rgba(17, 17, 17, 0.28);
    margin: 15px;
}

.slide-gift li .box .boxImage {
    width: 100%;
    height: 280px;
    display: flex;
    align-items: center;
    justify-self: center;
    overflow: hidden;
    border-radius: 12px;
}

.slide-gift li .box .icon {
    z-index: 10;
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    width: 40px;
    height: 40px;
    border-radius: 20px;
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/iconset.png") #3a84ff no-repeat center;
    background-size: 299px;
    background-position: -193px -5px;
    box-shadow: 2px 4px 12px 0 rgba(17, 17, 17, 0.28);
}

.slide-gift li .box .boxBottom {
    position: relative;
    padding: 34px;
    text-align: center;
}

.btn-large .owl-prev:before {
    content: "";
    opacity: 1;
    position: absolute;
    top: 0;
    left: 0;
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/iconset.png") no-repeat center;
    background-size: 299px;
    background-position: 0 0;
    width: 50px;
    height: 50px;
}

.btn-large .owl-prev {
    font-size: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: -70px;
    border: 0;
    z-index: 10;
    cursor: pointer;
    width: 50px;
    height: 50px;
    background: 0;
}

.btn-large .owl-prev:hover:before {
    opacity: 0.8;
}

.btn-large .owl-next {
    font-size: 0;
    border: 0;
    background: 0;
    z-index: 1;
    cursor: pointer;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: auto;
    right: -70px;
    width: 50px;
    height: 50px;
}

.btn-large .owl-next:before {
    content: "";
    opacity: 1;
    position: absolute;
    top: 0;
    left: 0;
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/iconset.png") no-repeat center;
    background-size: 299px;
    background-position: -70px 0px;
    width: 50px;
    height: 50px;
}

.btn-large .owl-next:hover:before {
    opacity: 0.8;
}

.relative {
    position: relative;
}

.btn-L .owl-prev {
    position: absolute;
    display: block;
    top: 50%;
    left: -100px;
}

.btn-L .owl-next {
    position: absolute;
    display: block;
    top: 50%;
    right: -100px;
}

.tabContent {
    display: none;
}

.tabContent .sideBox.rightSide {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.tabContent.on {
    display: block;
}

.tabContent:nth-child(3) .sideBox {
    width: 100%;
}

.tabMenu li.active {
    color: var(--bg-primary-100);
    border-bottom: 4px solid var(--bg-primary-100);
}

.underline {
    padding-bottom: 22px;
    margin-bottom: 22px;
    border-bottom: 1px solid var(--text-gray-300);
}

.underline.small {
    padding-bottom: 10px;
}

.priceBox {
    margin-top: 32px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.priceBox .rightSide {
    display: flex;
    align-items: center;
    gap: 10px;
}

.labelTop {
    align-items: flex-start;
}

.labelTop .labelBox {
    padding-top: 10px;
}

.blockMargin {
    margin: 12px 0;
}

.agreeChkBox {
    margin: 20px 0 32px;
}

.calendar_wrap {
    width: 100%;
}

.grayBtn {
    height: 48px;
    border: 0;
    background: var(--text-gray-300);
    border-radius: 4px;
    padding: 0 16px;
}

.primaryBtn {
    border: 0;
    background: var(--bg-primary-100);
    border-radius: 4px;
    color: #fff;
    padding: 0 16px;
}

.subscribeBtn {
    width: 100%;
    height: 58px;
    max-width: 530px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.radioBox input[type="radio"] {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

.radioBox label {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
    position: relative;
    padding-left: 28px;
    font-size: 16px;
    color: #333;
}

.radioBox label::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    border: 1px solid #e5e5ec;
    border-radius: 50%;
    background: #f1f1f5;
    transition: all 0.2s ease;
}

.radioBox label::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 50%;
    transform: translateY(-50%) scale(1);
    width: 10px;
    height: 10px;
    background-color: #dbdbe4;
    border-radius: 50%;
    transition: transform 0.2s ease;
}

.radioBox input[type="radio"]:checked+label::before {
    border-color: var(--bg-primary-100);
    background: #fff;
}

.radioBox input[type="radio"]:checked+label::after {
    transform: translateY(-50%) scale(1);
    background-color: var(--bg-primary-100);
}

.radioBox input[type="radio"]:focus+label::before {
    box-shadow: 0 0 0 3px rgba(235, 190, 108, 0.2);
}

.radioSubInput input:not([type="checkbox"]):not([type="radio"]):not([type="file"]) {
    height: 27px; width: 33px; padding: 0 4px; text-align: center;
}

.checkbox input[type="checkbox"] {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

.checkbox label {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
    position: relative;
    padding-left: 28px;
    font-size: 14px;
    color: var(--text-black);
    line-height: 1.2em;
}

.checkbox label::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    border: 1px solid #e5e5ec;
    border-radius: 20px;
    background: #f1f1f5;
    transition: all 0.2s ease;
    background: none;
}

.checkbox label::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 10px;
    width: 14px;
    height: 12px;
}

.checkbox input[type="checkbox"]:checked+label::before {
    background-color: var(--bg-primary-100);
    border-color: var(--bg-primary-100);
}

.checkbox input[type="checkbox"]:checked+label::after {
    transform: translateY(-50%) scale(1);
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/iconset.png");
    background-size: 299px;
    background-repeat: no-repeat;
    background-position: -43px -73px;
}

.checkbox:hover label::before {
    border-color: var(--bg-primary-100);
}

.pay-1 .labelBox,
.pay-2 .labelBox {
    padding-right: 20px;
}

.pay-2 .bankInfo {
    padding-top: 10px;
}

.pay-3 {
    vertical-align: middle;
}

span.pay-3 {
    /* margin: 10px 0; */
    display: inline-block;
    width: 69px;
    height: 20px;
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/iconset.png") no-repeat;
    background-size: 299px;
    background-position: -226px -69px;
}

.naverPayment {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.naverPayment .topSide {
    display: flex;
    gap: 20px;
    align-items: center;
}

.naverPayment .leftSide {
    flex-shrink: 0;
    width: 120px;
    height: 120px;
    border-radius: 12px;
    /*
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/ban_smartstore.png") no-repeat center;
    background-size: cover;
    */
    background-color: #03c75a;
}

.naverPayment .leftSide img { border-radius: inherit; }

.goNaverPay {
    display: flex;
    align-items: center;
    gap: 6px;
    color: #03c75a;
    text-decoration: underline;
}

.goNaverPay .icon {
    margin-top: -1px;
    display: block;
    width: 37px;
    height: 20px;
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/iconset.png") no-repeat center;
    background-size: 299px;
    background-position: -166px -68px;
}

.naverPayment .rightSide {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 0;
}

footer {
    background: var(--text-black);
}

.footerWrap {
    display: flex;
    align-items: center;
    justify-self: center;
    padding: 63px;
    text-align: center;
}

.slide-gift.owl-theme .owl-nav.disabled+.owl-dots {
    margin-top: 16px;
}

.slide-gift.owl-theme .owl-dots .owl-dot span {
    width: 6px;
    height: 6px;
    margin: 5px 3px;
    background: #d6d6d6;
    display: block;
    -webkit-backface-visibility: visible;
    transition: opacity 200ms ease;
    border-radius: 30px;
}

.slide-gift.owl-theme .owl-dots .owl-dot.active span,
.owl-theme .owl-dots .owl-dot:hover span {
    background: var(--bg-primary-100);
}

.botWrap {
    position: relative;
    background: red;
}

.chatbotAI.show {
    position: fixed;
    bottom: 150px;
    right: 80px;
    width: 495px;
    height: 700px;
    opacity: 1;
}

.input-wrapper {
    position: relative;
    width: 100%;
}

.clear-input {
    width: 100%;
    padding: 10px 35px 10px 10px;
    box-sizing: border-box;
}

.btn-clear {
    display: none;
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 5;
    cursor: pointer;
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/iconset.png") no-repeat;
    background-size: 299px;
    background-position: -77px -68px;
    width: 20px;
    height: 20px;
}

/* selectbox */

.select-box {
    position: relative;
    width: 100%;
    user-select: none;
}

.select-box select {
    display: none;
}

.select-box.active {
    box-shadow: 0 8px 20px 0 rgba(0, 20, 55, 0.16);
}

.select-trigger {
    padding: 12px 16px;
    background: #fff;
    border: 1px solid #f1f1f1;
    border-radius: 6px;
    cursor: pointer;
    position: relative;
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 145%;
    /* 20.3px */
    letter-spacing: -0.35px;
    color: var(--text-gray-500);
}

.select-trigger.selected {
    color: var(--text-black);
}

.select-box.active .select-trigger {
    border: 1px solid var(--text-gray-700);
    border-bottom: 0;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    z-index: 1000;
    position: relative;
}

.select-trigger:after {
    content: "";
    position: absolute;
    right: 0px;
    top: 50%;
    transform: translateY(-50%) rotate(180deg);
    color: #999;
    transition: transform 0.3s;
    background: url("https://img.seoul.co.kr/img/company/subscribe/2026/arrow.png") calc(100% - 10px) center no-repeat;
    background-size: 20px;
    width: 40px;
    height: 40px;
}

.select-box.active .select-trigger:after {
    transform: translateY(-50%) rotate(0deg);
}

.select-options {
    box-sizing: border-box;
    display: none;
    position: absolute;
    top: calc(100%);
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid var(--text-gray-700);
    border-radius: 6px;
    border-top-right-radius: 0;
    border-top-left-radius: 0;
    z-index: 100;
    margin: 0;
    list-style: none;
    box-shadow: 0 8px 20px 0 rgba(0, 20, 55, 0.16);
    max-height: 150px;
    overflow-y: auto;
}

.select-options li {
    padding: 14px 16px;
    cursor: pointer;
    transition: background 0.2s;
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 145%;
    /* 20.3px */
    letter-spacing: -0.35px;
}

/* .select-options li:hover {
    background: #f8f9fa;
    color: var(--text-black);
} */

.select-options li:last-child {
    border-bottom-left-radius: 6px;
    border-bottom-right-radius: 6px;
}

.select-box.active .select-options {
    display: block;
    border-top: 1px solid #e5e5ec;
}

.searchArea .formInputBox {
    padding: 0;
    padding-top: 20px;
}

.search-result-wrap {
    margin-bottom: 20px;
}

.searchArea th {
    background: #f7f7fa;
    border: 1px solid #f7f7fa;
    padding: 16px 24px;
}

.searchArea td {
    padding: 16px 32px;
    border-top: 1px solid var(--text-gray-300);
}

.searchArea table tr:last-child td {
    border-bottom: 1px solid var(--text-gray-300);
}

/* 챗봇 */
.chatbotButton {
    cursor: pointer;
    position: fixed;
    z-index: 999;
    bottom: 25px;
    right: 80px;
    display: flex;
    align-items: center;
    gap: 6px;
    background: var(--bg-primary-100);
    padding: 12px 18px;
    border-radius: 50px;
    transition: all 0.3s;
    box-shadow: 2px 3px 10px 0 rgba(0, 0, 0, 0.15);
}

.chatbotButton .icon {
    width: 32px;
    height: 32px;
    background: url("https://img.seoul.co.kr/img/recruit/chatBtnIcon.png") no-repeat;
    background-size: 30px;
    background-position: 0 3px;
}

.chatbotButton .img {
    margin-bottom: -8px;
}

.chatbotAI {
    z-index: 9999;
    position: fixed;
    bottom: 136px;
    right: 80px;
    border-radius: 12px;
    box-shadow: 0px 6px 30px 0px rgba(0, 0, 0, 0.3);
    opacity: 0.1;
    transition: all 0.3s;
}

.chatbotAI.show {
    opacity: 1;
    bottom: 103px;
}

.chatbotAI.closed {
    opacity: 0;
    bottom: 136px;
    visibility: hidden;
}

.chatbotAI iframe {
    display: none;
    width: 495px;
    height: 700px;
    border-radius: 10px;
}

.inputSubInfo {
    padding-left: 100px;
}

.select-box.is-disabled {
    background-color: #f5f5f5 !important;
    cursor: not-allowed !important;
    pointer-events: none;
    border-radius: 5px;
    border: 1px solid #f1f1f1;
}

.select-box.is-disabled .select-trigger {
    background: #f5f5f5 !important;
}

@media screen and (max-width: 1440px) {
    .layoutWrap {
        width: calc(100% - 37px);
    }

    .btn-large {
        display: none;
    }
}

@media screen and (max-width: 1024px) {
    .sideBoxWrap {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        flex-direction: column;
    }

    .sideBoxWrap {
        gap: 60px;
    }

    .sideBox {
        width: 100%;
        max-width: 880px;
    }

    .giftTopSide .topTit {
        box-sizing: border-box;
        padding: 20px 30px;
        min-width: 398px;
    }
}

@media screen and (max-width: 768px) {
    .select-box.is-disabled {
        opacity: 0.7;
    }

    .pt20 {
        padding-top: 20px;
    }

    .chatbotAI {
        width: 200px;
        right: 50%;
        bottom: 50%;
        transform: translate(50%, 50%);
    }

    .chatbotAI.show {
        right: 50%;
        bottom: 50%;
        width: 360px;
        height: 630px;
    }

    .chatbotAI iframe {
        box-sizing: border-box;
        border: 0;
        display: none;
        /* width: 100%;
        width: 0; */
        width: 100%;
        height: 630px;
        border-radius: 10px;
    }

    #ui-datepicker-div {
        top: 50% !important;
        left: 50% !important;
        transform: translate(-50%, -50%) !important;
        position: fixed !important;
        z-index: 9999 !important;
    }

    .popupBox {
        width: 92vw;
    }

    .popupBox .topSide {
        padding: 15px 20px 3px;
    }

    .popupBox .contentSide .scrollbar {
        height: 300px;
    }

    .popupBox .contentSide .agreeChkBox {
        margin: 0 0 32px;
    }

    .onlyMo {
        display: block;
    }

    header {
        padding: 62px 0 54px;
        background-position: -930px 0;
        background-size: inherit;
    }

    header .headerWrap {
        gap: 24px;
    }

    .header-top {
        gap: 6px;
    }

    .header-logo {
        width: 90px;
    }

    .header-title {
        width: 236px;
    }

    .header-bottom {
        font-size: 18px;
        font-style: normal;
        line-height: 26px;
        letter-spacing: -0.18px;
    }

    .sideBoxWrap {
        gap: 60px;
    }

    .priceBox .rightSide {
        padding: 0;
    }

    .rightSide {
        padding: 30px 40px 40px;
    }

    .tabBox {
        margin: 0 -18px 0 -19px;
        overflow: hidden;
    }

    section.tabBoxWrap {
        margin: 24px 0 27px 0;
    }

    .tabBoxWrap h3 {
        font-size: 20px;
        font-style: normal;
        font-weight: 700;
        line-height: 30px;
        /* 150% */
        letter-spacing: -0.2px;
    }

    .tabMenu {
        gap: 0;
        justify-content: space-between;
        padding: 0 18px 0 19px;
        margin: 24px -18px 60px -19px;
    }

    .tabMenu li {
        padding: 0 0 7px;
        font-size: 16px;
        font-style: normal;
        font-weight: 700;
        line-height: 26px;
        /* 162.5% */
        letter-spacing: -0.16px;
    }

    .tabContent {
        margin-bottom: 85px;
    }

    .sideBox {
        width: 100%;
        border-left: 0;
        border-right: 0;
        padding: 20px 18px 30px 19px;
    }

    .subscribeBtn {
        height: 46px;
        font-size: 16px;
        font-style: normal;
        font-weight: 700;
        line-height: 26px;
        /* 162.5% */
        letter-spacing: -0.16px;
    }

    .priceBox .priceTit {
        font-size: 16px;
        font-style: normal;
        font-weight: 500;
        line-height: 28px;
        /* 175% */
        letter-spacing: -0.16px;
    }

    .priceBox .price {
        font-size: 24px;
        font-style: normal;
        font-weight: 700;
        line-height: 34px;
        /* 141.667% */
        letter-spacing: -0.24px;
    }

    .priceBox .won {
        font-size: 14px;
        font-style: normal;
        font-weight: 500;
        line-height: 24px;
        /* 171.429% */
        letter-spacing: -0.14px;
    }

    .tabContent .scrollbar {
        height: 208px !important;
    }

    section.gift {
        padding: 0 0 80px;
    }

    .giftTopSide {
        top: -26px;
    }

    .giftTopSide .topTit {
        font-size: 20px;
        font-style: normal;
        font-weight: 700;
        line-height: 30px;
        /* 150% */
        letter-spacing: -0.2px;
        padding: 11px 0;
        gap: 6px;
        width: 271px;
        min-width: auto;
    }

    section.gift {
        margin: 0 0 0;
        border-top-left-radius: 16px;
        border-top-right-radius: 16px;
    }

    .giftTopSide .icon {
        width: 24px;
        height: 24px;
        background-position: -248px -13px;
    }

    .giftInfo {
        padding: 60px 0 0;
        font-size: 16px;
        font-style: normal;
        font-weight: 500;
        line-height: 26px;
        /* 162.5% */
        letter-spacing: -0.16px;
    }

    .slide-gift {
        padding: 30px 0 10px;
    }

    .slide-gift .owl-stage-outer {
        margin: -24px 0;
    }

    .slide-gift .owl-stage {
        margin: 24px 0;
    }

    .slide-gift li .box {
        margin: 12px;
    }

    .slide-gift li {
        transform: scale(1);
        transition: all 1.5s;
    }

    .slide-gift .owl-dots {
        margin-top: 20px;
    }

    .slide-gift .center {
        transform: scale(1.05);
        transition: all 1.5s;
    }

    .noticeText {
        font-size: 13px;
        font-style: normal;
        font-weight: 500;
        line-height: 20px;
        /* 153.846% */
        letter-spacing: -0.13px;
    }

    .chatbotButton {
        bottom: 20px;
        right: 20px;
    }

    .searchArea {
        gap: 30px;
    }

    .tabContent:nth-child(3) .sideBox {
        padding: 30px 18px 40px 19px;
    }

    .infoText .body16 {
        font-size: 14px;
        font-style: normal;
        font-weight: 500;
        line-height: 145%;
        /* 20.3px */
        letter-spacing: -0.35px;
    }

    .search-result {
        font-size: 15px;
        font-style: normal;
        font-weight: 700;
        line-height: 22px;
        /* 146.667% */
        letter-spacing: -0.15px;
    }

    .result-table table {
        font-size: 14px;
        font-style: normal;
        font-weight: 500;
        line-height: 145%;
        letter-spacing: -0.35px;
    }

    .searchArea .h16 {
        font-size: 15px;
        font-style: normal;
        font-weight: 700;
        line-height: 22px;
        /* 146.667% */
        letter-spacing: -0.15px;
    }

    .searchArea .body16 {
        font-size: 14px;
        font-style: normal;
        font-weight: 500;
        line-height: 145%;
        /* 20.3px */
        letter-spacing: -0.35px;
    }

    .searchArea th {
        padding: 14px 24px;
    }

    .searchArea td {
        padding: 14px 32px;
    }

    .no-result .h16 {
        font-size: 15px;
        font-style: normal;
        font-weight: 700;
        line-height: 22px;
        /* 146.667% */
        letter-spacing: -0.15px;
    }

    .no-result .body16 {
        font-size: 15px;
        font-style: normal;
        font-weight: 500;
        line-height: 22px;
        /* 146.667% */
        letter-spacing: -0.15px;
    }

    /* .form-row .labelBox.minWidth100 {
        min-width: 80px;
    } */

    /* .form-flex-row .form-row .labelBox {
        min-width: 80px;
    } */

    .dash {
        padding: 0 4px;
    }

    .select-trigger:after {
        right: 0;
    }

    .select-trigger.smallSelect:after {
        right: -6px;
    }

    .input_calendar {
        margin-left: 20px;
    }
}

@media screen and (max-width: 430px) {
    .payWrapper {
        align-items: flex-start;
    }

    .payWrap {
        flex-wrap: wrap;
        gap: 6px 20px;
    }

    .pay-1 .labelBox,
    .pay-2 .labelBox {
        padding-right: 4px;
    }

    .select-trigger {
        padding: 12px 8px;
    }

    .formInputBox input:not([type="checkbox"]):not([type="radio"]):not([type="file"]) {
        padding: 0 8px;
    }
}

.lineclamp1 {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.4em;
}

.lineclamp2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    /* 라인수 */
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    /* max-height: 2.8em; */
    /* text-align:left; */
}

.lineclamp3 {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    /* 라인수 */
    -webkit-box-orient: vertical;
    white-space: normal;
    overflow: hidden;
    /* max-height: 4.2em; */
    text-overflow: ellipsis;
}

.lineclamp4 {
    display: -webkit-box;
    -webkit-line-clamp: 4;
    /* 라인수 */
    -webkit-box-orient: vertical;
    white-space: normal;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lineclamp5 {
    display: -webkit-box;
    -webkit-line-clamp: 5;
    /* 라인수 */
    -webkit-box-orient: vertical;
    white-space: normal;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lineclamp6 {
    display: -webkit-box;
    -webkit-line-clamp: 6;
    /* 라인수 */
    -webkit-box-orient: vertical;
    white-space: normal;
    overflow: hidden;
    text-overflow: ellipsis;
}

.scrollbar {
    width: 100%;
    height: 156px;
    overflow-y: scroll;
}

/* 스크롤바의 폭 너비 */
.scrollbar::-webkit-scrollbar {
    width: 11px;
}

.scrollbar::-webkit-scrollbar-thumb {
    background: #cacbd5;
    background-clip: padding-box;
    border: 3px solid transparent;
    border-radius: 10px;
}

.scrollbar::-webkit-scrollbar-track {
    background: transparent;
}

/* 달력 */
.calendar_wrap {
    /* padding-top: 20px; */
    position: relative;
    display: flex;
    gap: 12px;
}

.input_calendar {
    width: 100%;
    height: 40px;
    text-align: right;
    font-family: "Pretendard";
    font-size: 14px;
    font-weight: 500;
    letter-spacing: -0.14px;
    border: 0;
    background: transparent;
    border-radius: 5px;
    color: #444;
    box-sizing: border-box;
    outline: none;
}

.input_calendar::placeholder {
    color: #444;
    font-family: Pretendard;
    font-size: 14px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
    /* 171.429% */
    letter-spacing: -0.14px;
}

.ui-datepicker {
    width: auto;
}

.ui-datepicker-trigger {
    position: absolute;
    top: 50%;
    right: 8px;
    transform: translateY(-50%);
    cursor: pointer;
    width: 40px;
    height: 40px;
    padding: 8px;
    border-radius: 30px;
    box-sizing: border-box;
}

/* .ui-datepicker-trigger:hover {
    transition: all 0.3s;
    background-color: #ddd;
} */

.ui-datepicker {
    position: fixed;
    /* margin-top: -12px; */
    /* margin-left: -82px; */
    /* top: 0; */
    /* left: auto; */
    /* right: 296px; */
    /* width: 296px; */
    padding: 32px 24px 20px;
    background-color: #fff;
    border-radius: 12px;
    box-shadow: 0px 0px 60px 0px rgba(0, 0, 0, 0.05);
    z-index: 200 !important;
    display: none;
    font-family: "Pretendard";
    border: 1px solid #ddd;
}

.ui-datepicker .ui-datepicker-header {
    padding: 0;
}

.ui-datepicker-header {
    background: 0;
    border: 0;
    position: relative;
    width: 100%;
    height: 30px;
    display: flex;
    justify-content: center;
}

.ui-datepicker .ui-datepicker-title {
    margin: 0;
    max-width: 100%;
    font-family: Pretendard;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 30px;
    letter-spacing: -0.18px;
    align-items: center;
    justify-content: center;
}

.ui-datepicker .ui-datepicker-prev {
    position: absolute;
    background: url("https://img.seoul.co.kr/img/n24/seoulIcon.png") no-repeat center;
    left: 0;
    background-position: -1px -9px;
}

.ui-datepicker .ui-datepicker-next {
    position: absolute;
    background: url("https://img.seoul.co.kr/img/n24/seoulIcon.png") no-repeat center;
    background-position: -45px -9px;
    left: auto;
    right: 0;
}

.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next {
    width: 32px;
    height: 32px;
    /* background-color: #eee; */
    top: 50%;
    transform: translateY(-50%);
}

.ui-datepicker .ui-datepicker-prev-hover {
    cursor: pointer;
    width: 32px;
    height: 32px;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    border: 0;
    background: url("https://img.seoul.co.kr/img/n24/seoulIcon.png") no-repeat center;
    background-position: -213px -9px;
}

.ui-datepicker .ui-datepicker-next-hover {
    cursor: pointer;
    width: 32px;
    height: 32px;
    top: 50%;
    left: auto;
    right: 0;
    transform: translateY(-50%);
    border: 0;
    background: url("https://img.seoul.co.kr/img/n24/seoulIcon.png") no-repeat center;
    left: auto;
    background-position: -257px -9px;
}

.ui-datepicker .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-next span {
    display: none;
}

.ui-datepicker .ui-datepicker-prev {
    margin-left: 24px;
}

.ui-datepicker .ui-datepicker-next {
    margin-right: 24px;
}

.ui-datepicker-prev span,
.ui-datepicker-next span {
    font-size: 0;
    display: none;
}

.ui-datepicker-prev {
    left: 10px;
    transform: translateY(-50%) rotate(180deg);
}

.ui-datepicker-next {
    right: 10px;
}

.ui-datepicker-title {
    width: 100%;
    max-width: 160px;
    display: flex;
}

.ui-datepicker-year,
.ui-datepicker-month {
    font-family: "Pretendard";
    font-size: 18px;
    color: #111;
    letter-spacing: -0.18px;
    font-weight: 700;
    text-align: center;
    border: none;
    background: transparent;
}

.ui-datepicker-year {
    background-position: center right 0;
}

.ui-datepicker-calendar {
    width: 100%;
    text-align: center;
    font-size: 18px;
}

.ui-datepicker table {
    margin: 24px 0;
}

.ui-datepicker-calendar thead {
    margin-bottom: 4px;
}

.ui-datepicker-calendar thead th {
    padding: 0;
    height: 42px;
    font-weight: 500;
}

.ui-datepicker-calendar thead th span {
    display: flex;
    width: 42px;
    height: 42px;
    align-items: center;
    justify-content: center;
}

.ui-datepicker-calendar td {
    position: relative;
    width: 42px;
    height: 42px;
    vertical-align: middle;
}

.ui-datepicker-calendar a {
    display: flex;
    width: 42px;
    align-items: center;
    justify-content: center;
    line-height: 1.4;
}

.ui-datepicker-calendar .ui-datepicker-other-month {
    background-color: 0;
}

.datepicker-layer {
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0 !important;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 200 !important;
    display: none;
}

.datepicker-layer.show {
    display: block;
}

.ui-datepicker td {
    padding: 0;
}

.ui-datepicker td span,
.ui-datepicker td a {
    text-align: center;
}

.ui-state-default,
.ui-widget-content .ui-state-default,
.ui-widget-header .ui-state-default,
.ui-button,
html .ui-button.ui-state-disabled:hover,
html .ui-button.ui-state-disabled:active {
    border: 0;
    background: 0;
    color: #666;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: -0.16px;
}

.ui-datepicker .ui-datepicker-buttonpane {
    display: flex;
    width: 100%;
    justify-content: space-between;
    border-top: 1px solid #eee;
}

.ui-datepicker .ui-datepicker-buttonpane button {
    font-family: "Pretendard";
    padding: 8px 16px;
    border-radius: 8px;
    margin: 20px 0 0;
}

.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current {
    background-color: #f4f4f4;
    color: #111;
    opacity: 1;
    cursor: pointer;
    font-family: Pretendard;
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 26px;
    letter-spacing: -0.16px;
}

.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-close {
    background-color: #262323;
    color: #fff;
    opacity: 1;
    cursor: pointer;
    font-family: Pretendard;
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 26px;
    /* 162.5% */
    letter-spacing: -0.16px;
}

.blockState {
    color: #ddd !important;
    /* opacity: .7;
    filter: Alpha(Opacity=70); */
    background: #f4f4f4 !important;
}

/* today */

.ui-datepicker-today .ui-state-highlight {
    position: relative;
    color: #111;
    font-weight: 700;
}

.ui-datepicker-today .ui-state-highlight:after {
    content: "";
    position: absolute;
    display: block;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 17px;
    height: 2px;
    background-color: #111;
}

.ui-datepicker .ui-datepicker-calendar .ui-state-hover::before {
    /* 
    z-index: -1;
    content: '';
    position: absolute;
    display: block;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 42px;
    height: 42px;
    border-radius: 30px;
    background: #eee;
    */
}

/* active */

.ui-state-active,
.ui-widget-content .ui-state-active {
    position: relative;
}

.ui-state-active,
.ui-widget-content .ui-state-active {
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}

.ui-state-active,
.ui-widget-content .ui-state-active:after {
    z-index: -1;
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #f26930;
    border-radius: 30px;
    width: 42px;
    height: 42px;
}

.flex-1 { flex: 1; }