@charset "UTF-8";
/* ────────────────────────────────
    reset
──────────────────────────────── */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
*::after, *::before {
    box-sizing: border-box;
}

html {
    height: 100%;
    font-family: var(--font-base);
    font-size: var(--font-size);
    color: var(--color-text);
    background-color: var(--color-background);
}

body {
    height: 100%;
    font-size: var(--font-base-size);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    background-color: var(--color-background);
    overflow-x: hidden;
}

ol,
ul {
    list-style: none;
}
ol::after,
ul::after {
    content: "";
    display: block;
    clear: both;
}

button {
    all: unset;
    cursor: pointer;
    box-sizing: border-box;
}

img,
svg,
picture,
video,
canvas,
iframe,
textarea {
    display: block;
    max-width: 100%;
}

img {
    vertical-align: top;
}

input,
button,
textarea,
select {
    font: inherit;
}

input {
    appearance: none;
    border-radius: none;
    outline: none;
    border-radius: 0;
    border: none;
}
input::-ms-clear {
    display: none;
}

input {
    color: var(--color-text);
    background-color: var(--color-background);
}
input::-webkit-search-decoration, input::-webkit-search-cancel-button, input::-webkit-search-results-button, input::-webkit-search-results-decoration {
    display: none;
}

input[type=text],
input[type=password],
input[type=submit],
input[type=search],
input[type=tel],
input[type=email],
html input[type=button],
input[type=reset] {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    border-radius: 0;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    outline: 0;
}

input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

input[type=number] {
    -moz-appearance: textfield;
}

select {
    appearance: none;
    outline: none;
    border-radius: 0;
    color: var(--color-text);
    background-color: var(--color-background);
}
select::-ms-expand {
    display: none;
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
    overflow-wrap: break-word;
}

a {
    color: inherit;
    text-decoration: none;
    display: inline-block;
}

[onclick] {
    cursor: pointer;
}

span {
    display: inline-block;
}

/* ────────────────────────────────
    variable
──────────────────────────────── */
/* ────────────────────────────────
    mixins
──────────────────────────────── */
/* ────────────────────────────────
    root
──────────────────────────────── */
:root {
    --font-size: 62.5%;
    --font-base: "Pretendard";
    --font-base-size: 1.5rem;
    --color-border: #d9d9d9;
    --color-border-light: #e9e9e9;
    --color-border-gray: #c9c9c9;
    --color-background: #ffffff;
    --color-background-contrast: 0, 0, 0;
    --color-background-light: #f9f9f9;
    --color-background-light-active: #f6f6f6;
    --color-text: #202020;
    --color-text-dark: #606060;
    --color-text-light: #909090;
    --color-icon: #606060;
    --color-icon-light: #909090;
    --color-primary: #3677f1;
    --color-primary-rgb: 54, 119, 241;
    --color-primary-hover: #276cee;
    --color-primary-active: #2363da;
    --color-primary-light: #f4f7ff;
    --color-primary-light-active: #ebf1ff;
    --color-primary-contrast: #ffffff;
    --color-primary-text: #4c546e;
    --color-white: #ffffff;
    --color-gray: #f9f9f9;
    --color-label: #808080;
    --color-link: #3182f6;
    --color-excel: #1d6f42;
    --color-excel-background: #f0fff6;
    --color-excel-active-background: #e4ffef;
    --color-delete: #fe2323;
    --color-delete-background: #fff6f6;
    --color-delete-active-background: #fdecec;
    --color-danger: #fe2323;
    --color-danger-background: #fff6f6;
    --color-danger-active-background: #fdecec;
    --color-info: #1e66c8;
    --color-info-background: #e6f0fb;
    --color-success: #267337;
    --color-success-background: #e4f6ea;
    --color-warning: #b78103;
    --color-warning-background: #fff4d6;
    --color-error: #bd2c0f;
    --color-error-background: #fdecea;
    --color-total: #276cee;
    --color-cancel: #ee4343;
    --badge-green: #198754;
    --badge-green-background: #d1f7d6;
    --badge-green-border: #b2e9b9;
    --badge-red: #c82333;
    --badge-red-background: #fcebea;
    --badge-red-border: #e9d0cf;
    --badge-blue: #0d6efd;
    --badge-blue-background: #e7f1fc;
    --badge-blue-border: #d0dff0;
    --badge-yellow: #856404;
    --badge-yellow-background: #fff3cd;
    --badge-darkred: #721c24;
    --badge-darkred-background: #f8d7da;
    --badge-purple: #6f42c1;
    --badge-purple-background: #f2e8fb;
    --badge-cyan: #0dcaf0;
    --badge-cyan-background: #e0f7fb;
    --badge-teal: #20c997;
    --badge-teal-background: #e0f9f3;
    --badge-orange: #fd7e14;
    --badge-orange-background: #fff0e5;
    --badge-brown: #795548;
    --badge-brown-background: #f1e7e3;
    --badge-indigo: #6610f2;
    --badge-indigo-background: #ede7fb;
    --badge-pink: #d63384;
    --badge-pink-background: #fde7f1;
    --badge-positive: #065f46;
    --badge-positive-background: #d1fae5;
    --badge-negative: #991b1b;
    --badge-negative-background: #fee2e2;
    --badge-warning: #92400e;
    --badge-warning-background: #fef3c7;
    --badge-info: #1e40af;
    --badge-info-background: #dbeafe;
    --badge-neutral: #374151;
    --badge-neutral-background: #e5e7eb;
    --radius: 0.6rem;
    --radius-snb: 0.6rem;
    --radius-card: 0.4rem;
    --radius-form: 0.6rem;
    --size-icon: 2.4rem;
    --size-icon-small: 2rem;
    --size-icon-xsmall: 1.6rem;
    --size-snb-icon: 2rem;
    --size-snb-width: 28rem;
    --size-snb-collapsed-width: 8rem;
    --size-logo-height: 4.8rem;
    --size-header-height: 7rem;
    --size-container-width: 120rem;
    --size-panel: 36rem;
    --gap-layout: 2rem;
    --gap-component: 1rem;
    --gap-main-container: 3rem;
    --gap-section: 4rem;
    --color-text-snb: #5c667b;
    --color-icon-snb: #5c667b;
    --color-border-snb: #e9e9e9;
    --size-form: 4.8rem;
    --size-table-form: 4rem;
    --padding-form: 1.2rem;
    --color-background-form: #ffffff;
    --color-background-form-readonly: #f6f6f6;
    --transition-duration: 0.15s;
    --blur-background: rgba(255, 255, 255, 0.7);
    --blur-shadow: rgba(255, 255, 255, 0.5);
    --chart-red: rgba(255, 99, 132, 0.2);
    --chart-blue: rgba(54, 162, 235, 0.2);
    --chart-yellow: rgba(255, 206, 86, 0.2);
    --chart-green: rgba(75, 192, 192, 0.2);
    --chart-purple: rgba(153, 102, 255, 0.2);
    --chart-orange: rgba(255, 159, 64, 0.2);
    --chart-black: rgba(0, 0, 0, 0.2);
    --chart-red-border: rgba(255, 99, 132, 1);
    --chart-blue-border: rgba(54, 162, 235, 1);
    --chart-yellow-border: rgba(255, 206, 86, 1);
    --chart-green-border: rgba(75, 192, 192, 1);
    --chart-purple-border: rgba(153, 102, 255, 1);
    --chart-orange-border: rgba(255, 159, 64, 1);
    --chart-black-border: rgba(0, 0, 0, 0.4);
    --z-index-loading: 102;
    --z-index-popover: 101;
    --z-index-modal: 100;
    --z-index-snb: 99;
    --z-index-header: 98;
    --z-index-panel: 97;
}
@media screen and (max-width: 767px) {
    :root {
        --font-size: 50%;
    }
}

/* ────────────────────────────────
    theme/dark
──────────────────────────────── */
:root.theme-dark {
    --color-border: #3c4a5e;
    --color-border-light: #4a5b72;
    --color-border-gray: #56677d;
    --color-background: #1f2a38;
    --color-background-contrast: 90, 100, 140;
    --color-background-light: #263445;
    --color-background-light-active: #2e3c50;
    --color-text: #e0e6f0;
    --color-text-dark: #b8c1d1;
    --color-text-light: #8f9bb2;
    --color-icon: #b0bed1;
    --color-icon-light: #8896ad;
    --color-primary: #4d84f1;
    --color-primary-hover: #3f75e6;
    --color-primary-active: #3669d4;
    --color-primary-light: #2e3f66;
    --color-primary-light-active: #36476f;
    --color-primary-contrast: #ffffff;
    --color-primary-text: #a6c4ff;
    --color-white: #ffffff;
    --color-gray: #2b3544;
    --color-label: #a3afc3;
    --color-link: #7aaeff;
    --color-excel: #34c187;
    --color-excel-background: #1a3d2e;
    --color-excel-active-background: #225342;
    --color-delete: #ff6b6b;
    --color-delete-background: #3a2525;
    --color-delete-active-background: #4d2c2c;
    --color-danger: #ff6b6b;
    --color-danger-background: #3a2525;
    --color-danger-active-background: #4d2c2c;
    --color-info: #4d9bff;
    --color-info-background: #25384d;
    --color-success: #36d18f;
    --color-success-background: #1f3f32;
    --color-warning: #ffba4d;
    --color-warning-background: #4a3a25;
    --color-error: #f96868;
    --color-error-background: #4a2c2c;
    --color-cancel: #df485f;
    --badge-green: #22c55e;
    --badge-green-background: #1e3a29;
    --badge-green-border: #1e3a29;
    --badge-red: #ef4444;
    --badge-red-background: #3b1e1e;
    --badge-red-border: #3b1e1e;
    --badge-blue: #3b82f6;
    --badge-blue-background: #1e3a5f;
    --badge-blue-border: #1e3a5f;
    --badge-yellow: #eab308;
    --badge-yellow-background: #4a3a1a;
    --badge-darkred: #dc2626;
    --badge-darkred-background: #4b1e1e;
    --badge-purple: #c8a9f1;
    --badge-purple-background: #3a2753;
    --badge-cyan: #6fe3f7;
    --badge-cyan-background: #113c47;
    --badge-teal: #7decc9;
    --badge-teal-background: #153f35;
    --badge-orange: #ffb66e;
    --badge-orange-background: #4a2e16;
    --badge-brown: #d2b1a4;
    --badge-brown-background: #3a2b28;
    --badge-indigo: #b699fc;
    --badge-indigo-background: #2f2260;
    --badge-pink: #f28fb7;
    --badge-pink-background: #4b2439;
    --badge-positive: #10b981;
    --badge-positive-background: #134e4a;
    --badge-negative: #f87171;
    --badge-negative-background: #4a1e1e;
    --badge-warning: #f59e0b;
    --badge-warning-background: #4a3a1f;
    --badge-info: #60a5fa;
    --badge-info-background: #1e3a5f;
    --badge-neutral: #9ca3af;
    --badge-neutral-background: #2e3340;
    --color-text-snb: #b4c0d3;
    --color-icon-snb: #b4c0d3;
    --color-border-snb: #3c4a5e;
    --color-background-form: #2c394d;
    --color-background-form-readonly: #151e2a;
    --blur-background: rgba(31, 42, 56, 0.8);
    --blur-shadow: rgba(0, 0, 0, 0.5);
    --chart-red: rgba(255, 99, 132, 0.15);
    --chart-blue: rgba(54, 162, 235, 0.15);
    --chart-yellow: rgba(255, 206, 86, 0.15);
    --chart-green: rgba(75, 192, 192, 0.15);
    --chart-purple: rgba(153, 102, 255, 0.15);
    --chart-orange: rgba(255, 159, 64, 0.15);
    --chart-black: rgba(255, 255, 255, 0.15);
    --chart-red-border: rgba(255, 99, 132, 0.9);
    --chart-blue-border: rgba(54, 162, 235, 0.9);
    --chart-yellow-border: rgba(255, 206, 86, 0.9);
    --chart-green-border: rgba(75, 192, 192, 0.9);
    --chart-purple-border: rgba(153, 102, 255, 0.9);
    --chart-orange-border: rgba(255, 159, 64, 0.9);
    --chart-black-border: rgba(255, 255, 255, 0.4);
}

/* ────────────────────────────────
    fonts
──────────────────────────────── */
@font-face {
    font-family: "Pretendard";
    src: url("../fonts/Pretendard/Pretendard-Thin.woff2") format("woff2");
    font-weight: 100;
    font-display: swap;
}
@font-face {
    font-family: "Pretendard";
    src: url("../fonts/Pretendard/Pretendard-ExtraLight.woff2") format("woff2");
    font-weight: 200;
    font-display: swap;
}
@font-face {
    font-family: "Pretendard";
    src: url("../fonts/Pretendard/Pretendard-Light.woff2") format("woff2");
    font-weight: 300;
    font-display: swap;
}
@font-face {
    font-family: "Pretendard";
    src: url("../fonts/Pretendard/Pretendard-Regular.woff2") format("woff2");
    font-weight: 400;
    font-display: swap;
}
@font-face {
    font-family: "Pretendard";
    src: url("../fonts/Pretendard/Pretendard-Medium.woff2") format("woff2");
    font-weight: 500;
    font-display: swap;
}
@font-face {
    font-family: "Pretendard";
    src: url("../fonts/Pretendard/Pretendard-SemiBold.woff2") format("woff2");
    font-weight: 600;
    font-display: swap;
}
@font-face {
    font-family: "Pretendard";
    src: url("../fonts/Pretendard/Pretendard-Bold.woff2") format("woff2");
    font-weight: 700;
    font-display: swap;
}
@font-face {
    font-family: "Pretendard";
    src: url("../fonts/Pretendard/Pretendard-ExtraBold.woff2") format("woff2");
    font-weight: 800;
    font-display: swap;
}
@font-face {
    font-family: "Pretendard";
    src: url("../fonts/Pretendard/Pretendard-Black.woff2") format("woff2");
    font-weight: 900;
    font-display: swap;
}
@font-face {
    font-family: "Paperlogy";
    src: url("../fonts/Paperlogy/Paperlogy-8ExtraBold.woff2") format("woff2"), url("../fonts/Paperlogy/Paperlogy-8ExtraBold.woff") format("woff");
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Paperlogy";
    src: url("../fonts/Paperlogy/Paperlogy-6SemiBold.woff2") format("woff2"), url("../fonts/Paperlogy/Paperlogy-6SemiBold.woff") format("woff");
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}
/* ────────────────────────────────
    color
──────────────────────────────── */
.color-primary {
    color: var(--color-primary);
}

/* ────────────────────────────────
    icon
──────────────────────────────── */
/* ────────────────────────────────
    common
──────────────────────────────── */
body.modal-open {
    overflow-y: hidden;
}

.logo {
    width: fit-content;
    display: block;
    font-size: 1.8rem;
    font-weight: 700;
}
.logo img {
    height: var(--size-logo-height);
    min-height: var(--size-logo-height);
}

.key-value-box {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-form);
    padding: var(--gap-layout);
}
.key-value-box .key-value-item ~ .key-value-item {
    margin-top: 0.6rem;
}

.key-value-item {
    display: flex;
    justify-content: space-between;
    gap: 0 var(--gap-layout);
    white-space: nowrap;
}
.key-value-item .key {
    color: var(--color-text-dark);
}
.key-value-item .accent {
    font-size: 1.6rem;
    font-weight: 600;
}
.key-value-item .separator {
    color: var(--color-text-dark);
}

.line-clamp {
    display: -webkit-box !important;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    word-break: break-all;
    text-align: left;
}
.line-clamp.show {
    max-width: none !important;
}
.line-clamp.line-2 {
    -webkit-line-clamp: 2;
}

.ratio-img {
    overflow: hidden;
    position: relative;
}
.ratio-img::after {
    content: "";
    display: block;
    padding-bottom: 100%;
}
.ratio-img.ratio-3-4::after {
    padding-bottom: 133.33%;
}
.ratio-img img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.info-box {
    color: var(--color-primary);
    border: 1px solid var(--color-primary);
    background-color: var(--color-primary-light);
    border-radius: 0.4rem;
    padding: 2rem;
    margin-top: 1rem;
}

.file-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.file-list input[type=file] {
    display: none;
}
.file-list label {
    width: fit-content;
    cursor: pointer;
}
.file-list ul li ~ li {
    margin-top: 1rem;
}
.file-list a {
    width: fit-content;
    display: flex;
    gap: 1rem;
    color: var(--color-link);
}
.file-list a::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    color: var(--color-link);
}
.file-list a:hover, .file-list a:focus {
    text-decoration: underline;
}

.terms-list li {
    display: flex;
    justify-content: space-between;
    gap: 2rem;
}
.terms-list li ~ li {
    margin-top: 1.2rem;
}
.terms-list li button {
    color: var(--color-text-light);
}
.terms-list li button:hover {
    color: var(--color-text);
}
.terms-list.border {
    border: 1px solid var(--color-border);
    border-radius: 0.4rem;
    padding: 2rem;
}

code {
    font-size: 1.4rem;
    font-family: var(--font-base);
    background-color: var(--color-primary-light);
    color: var(--color-primary);
    border-radius: 0.4rem;
    padding: 0.25rem 0.5rem;
    transition: var(--transition-duration);
}

.text-container {
    color: var(--color-text-dark);
}

.text-link {
    color: var(--color-link);
}
.text-link:hover, .text-link:focus {
    text-decoration: underline;
}

.theme-change-button .icon {
    width: var(--size-icon);
    height: var(--size-icon);
    background-repeat: no-repeat;
    background-size: var(--size-icon);
    background-position: center;
    transition: var(--transition-duration);
    position: relative;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23606060' stroke-linejoin='round' stroke-width='2' d='M12 16a4 4 0 1 0 0-8 4 4 0 0 0 0 8Z'/%3E%3Cpath stroke='%23606060' stroke-linecap='round' stroke-width='2' d='M20 12h1M3 12h1m8 8v1m0-18v1m5.657 13.657.707.707M5.636 5.636l.707.707m0 11.314-.707.707M18.364 5.636l-.707.707'/%3E%3C/svg%3E");
}
.theme-change-button:hover .icon, .theme-change-button:focus .icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%233677f1' stroke-linejoin='round' stroke-width='2' d='M12 16a4 4 0 1 0 0-8 4 4 0 0 0 0 8Z'/%3E%3Cpath stroke='%233677f1' stroke-linecap='round' stroke-width='2' d='M20 12h1M3 12h1m8 8v1m0-18v1m5.657 13.657.707.707M5.636 5.636l.707.707m0 11.314-.707.707M18.364 5.636l-.707.707'/%3E%3C/svg%3E");
}

.text-total {
    color: var(--color-total);
    font-weight: 700;
}

.text-cancel {
    color: var(--color-cancel);
}

.animated-number {
    min-width: 10rem;
    min-height: 2.6rem;
    text-align: right;
    white-space: nowrap;
}

.menu-search-list {
    display: flex;
    flex-direction: column;
}
.menu-search-list a,
.menu-search-list button {
    width: 100%;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    gap: var(--gap-component);
    padding: var(--gap-component);
    transition: var(--transition-duration);
}
.menu-search-list a .icon,
.menu-search-list button .icon {
    font-size: 1.8rem;
}
.menu-search-list a:hover, .menu-search-list a:focus,
.menu-search-list button:hover,
.menu-search-list button:focus {
    color: var(--color-primary);
    border-color: var(--color-primary);
    background-color: var(--color-primary-light);
    outline: none;
}
.menu-search-list a:hover::before, .menu-search-list a:focus::before,
.menu-search-list button:hover::before,
.menu-search-list button:focus::before {
    color: var(--color-primary) !important;
}
.menu-search-list > li ~ li {
    margin-top: var(--gap-component);
}
.menu-search-list > li > a {
    border: 1px solid var(--color-border);
}
.menu-search-list > li .menu-depth2 {
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    transition: var(--transition-duration);
}
.menu-search-list > li .menu-depth2:hover, .menu-search-list > li .menu-depth2:focus {
    border-color: var(--color-primary);
    outline: none;
}
.menu-search-list > li .menu-depth2 > button::after {
    content: "";
    display: block;
    width: var(--size-snb-icon);
    min-width: var(--size-snb-icon);
    height: var(--size-snb-icon);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23909090' d='m12 10.8-3.9 3.9a.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275.948.948 0 0 1-.275-.7c0-.283.092-.517.275-.7l4.6-4.6c.2-.2.433-.3.7-.3.267 0 .5.1.7.3l4.6 4.6a.948.948 0 0 1 .275.7.948.948 0 0 1-.275.7.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275L12 10.8Z'/%3E%3C/svg%3E");
    background-size: var(--size-snb-icon);
    background-repeat: no-repeat;
    background-position: center;
    color: var(--color-icon-snb);
    margin-left: auto;
}
.menu-search-list > li .menu-depth2 > button ~ ul {
    display: none;
}
.menu-search-list > li .menu-depth2 > button.is-open::after {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23909090' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E");
}
.menu-search-list > li .menu-depth2 > button.is-open ~ ul {
    display: block;
}
.menu-search-list > li .menu-depth2 > ul {
    padding-left: calc(var(--gap-component) + var(--size-icon));
    padding-right: var(--gap-component);
    padding-bottom: var(--gap-component);
}
.menu-search-list > li .menu-depth2 > ul > li > button::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    color: var(--color-icon-light);
    transition: var(--transition-duration);
}
.menu-search-list > li .menu-depth2 > ul > li > button::after {
    content: "";
    display: block;
    width: var(--size-snb-icon);
    min-width: var(--size-snb-icon);
    height: var(--size-snb-icon);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23909090' d='m12 10.8-3.9 3.9a.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275.948.948 0 0 1-.275-.7c0-.283.092-.517.275-.7l4.6-4.6c.2-.2.433-.3.7-.3.267 0 .5.1.7.3l4.6 4.6a.948.948 0 0 1 .275.7.948.948 0 0 1-.275.7.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275L12 10.8Z'/%3E%3C/svg%3E");
    background-size: var(--size-snb-icon);
    background-repeat: no-repeat;
    background-position: center;
    color: var(--color-icon-snb);
    margin-left: auto;
}
.menu-search-list > li .menu-depth2 > ul > li > button ~ ul {
    display: none;
}
.menu-search-list > li .menu-depth2 > ul > li > button.is-open::after {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23909090' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E");
}
.menu-search-list > li .menu-depth2 > ul > li > button.is-open ~ ul {
    display: block;
}
.menu-search-list > li .menu-depth2 > ul > li > a::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    color: var(--color-icon-light);
    transition: var(--transition-duration);
}
.menu-search-list > li .menu-depth2 > ul > li > ul {
    padding-left: var(--gap-layout);
}
.menu-search-list > li .menu-depth2 > ul > li > ul a::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    color: var(--color-icon-light);
    transition: var(--transition-duration);
}
.menu-search-list .nodata {
    padding: var(--gap-component);
    color: var(--color-text-light);
}

.img-preview-container {
    width: 100%;
    height: auto;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
.img-preview-container img {
    margin: auto;
}

.cke_notifications_area {
    display: none !important;
}

.cke_contents {
    padding: 1rem !important;
}

.cke_top,
.cke_bottom {
    background-color: #fff !important;
}

/* ────────────────────────────────
    common/theme/dark
──────────────────────────────── */
:root.theme-dark .theme-change-button .icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23b0bed1' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12 21a9 9 0 0 0 8.997-9.252 7 7 0 0 1-10.371-8.643A9 9 0 0 0 12 21Z'/%3E%3C/svg%3E");
}
:root.theme-dark .theme-change-button:hover .icon, :root.theme-dark .theme-change-button:focus .icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%234d84f1' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12 21a9 9 0 0 0 8.997-9.252 7 7 0 0 1-10.371-8.643A9 9 0 0 0 12 21Z'/%3E%3C/svg%3E");
}

/* ────────────────────────────────
    animation
──────────────────────────────── */
@keyframes spin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}
/* ────────────────────────────────
    section
──────────────────────────────── */
.section {
    position: relative;
}
.section ~ .section {
    margin-top: 8rem;
}

.section-head {
    display: flex;
    justify-content: space-between;
    gap: var(--gap-layout);
}
@media screen and (max-width: 767px) {
    .section-head {
        flex-direction: column;
    }
    .section-head .button-group {
        flex-wrap: wrap !important;
    }
    .section-head .button-group .button {
        flex: 1;
    }
}

.section-title {
    font-size: 2.4rem;
    font-weight: 700;
}
.section-title ~ .section-sub-title, .section-title ~ .text-container {
    margin-top: var(--gap-component);
}

.section-sub-title {
    font-size: 1.6rem;
    color: var(--color-text-dark);
}

.section-tab {
    width: 100%;
    height: auto;
    position: relative;
    overflow: auto;
    display: flex;
    margin-top: var(--gap-layout);
    border-bottom: 1px solid var(--color-border-light);
}
.section-tab::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.section-tab::-webkit-scrollbar-track {
    border-radius: var(--radius);
    background-color: #78788030;
}
.section-tab::-webkit-scrollbar-thumb {
    border-radius: var(--radius);
    background: #78788030;
}
.section-tab::-webkit-scrollbar-thumb:hover {
    background: #78788050;
}
.section-tab::-webkit-scrollbar-thumb:active {
    background: #78788070;
}
.section-tab::-webkit-scrollbar-button {
    display: none;
}
.section-tab a,
.section-tab button {
    padding: 0 var(--gap-layout) var(--gap-component) var(--gap-layout);
    font-size: 1.8rem;
    color: var(--color-text-light);
    text-align: center;
    position: relative;
    transition: var(--transition-duration);
}
.section-tab a::after,
.section-tab button::after {
    content: "";
    display: block;
    width: 0;
    height: 2px;
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    background-color: var(--color-primary);
    opacity: 0;
    transition: var(--transition-duration);
}
.section-tab a:hover,
.section-tab button:hover {
    color: var(--color-primary);
}
.section-tab a.active,
.section-tab button.active {
    color: var(--color-primary);
    font-weight: 600;
}
.section-tab a.active::after,
.section-tab button.active::after {
    width: 100%;
    opacity: 1;
}

.section-content {
    display: flex;
    flex-direction: column;
    margin-top: var(--gap-section);
}

/* ────────────────────────────────
    app
──────────────────────────────── */
.app-container {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    padding: var(--gap-layout);
    max-width: 52rem;
    margin: 0 auto;
}

.app-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap-layout);
}
.app-head .app-title {
    display: flex;
    align-items: center;
}
.app-head .app-title h2 {
    font-size: 1.8rem;
    font-weight: 600;
}

.app-content {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.app-bottom .button-group .button {
    flex: 1;
}

.result {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: var(--gap-layout);
    padding: var(--gap-layout) 0;
}
.result .result-icon {
    width: 4.8rem;
    height: 4.8rem;
    background-color: var(--color-primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}
.result .result-icon .icon {
    color: var(--color-primary-contrast);
}
.result .result-msg h2 {
    font-size: 2.4rem;
    font-weight: 700;
}
.result .result-content {
    width: 100%;
    height: auto;
    position: relative;
}
.result.fail .result-icon {
    background-color: var(--color-border-gray);
}

/* ────────────────────────────────
    grid
──────────────────────────────── */
.grid-container {
    display: grid;
    gap: var(--gap-layout);
    grid-template-columns: repeat(12, minmax(0, 1fr));
}
.grid-container .grid-item.grid-item-row-1 {
    grid-row: span 1;
}
.grid-container .grid-item.grid-item-row-2 {
    grid-row: span 2;
}
.grid-container .grid-item.grid-item-row-3 {
    grid-row: span 3;
}
.grid-container .grid-item.grid-item-row-4 {
    grid-row: span 4;
}
.grid-container .grid-item.grid-item-row-5 {
    grid-row: span 5;
}
.grid-container .grid-item.grid-item-row-6 {
    grid-row: span 6;
}
.grid-container .grid-item.grid-item-row-7 {
    grid-row: span 7;
}
.grid-container .grid-item.grid-item-row-8 {
    grid-row: span 8;
}
.grid-container .grid-item.grid-item-row-9 {
    grid-row: span 9;
}
.grid-container .grid-item.grid-item-row-10 {
    grid-row: span 10;
}
.grid-container .grid-item.grid-item-row-11 {
    grid-row: span 11;
}
.grid-container .grid-item.grid-item-row-12 {
    grid-row: span 12;
}
.grid-container .grid-item.grid-item-column-1 {
    grid-column: span 1;
}
.grid-container .grid-item.grid-item-column-2 {
    grid-column: span 2;
}
.grid-container .grid-item.grid-item-column-3 {
    grid-column: span 3;
}
.grid-container .grid-item.grid-item-column-4 {
    grid-column: span 4;
}
.grid-container .grid-item.grid-item-column-5 {
    grid-column: span 5;
}
.grid-container .grid-item.grid-item-column-6 {
    grid-column: span 6;
}
.grid-container .grid-item.grid-item-column-7 {
    grid-column: span 7;
}
.grid-container .grid-item.grid-item-column-8 {
    grid-column: span 8;
}
.grid-container .grid-item.grid-item-column-9 {
    grid-column: span 9;
}
.grid-container .grid-item.grid-item-column-10 {
    grid-column: span 10;
}
.grid-container .grid-item.grid-item-column-11 {
    grid-column: span 11;
}
.grid-container .grid-item.grid-item-column-12 {
    grid-column: span 12;
}
.grid-container .grid-item .card {
    height: 100%;
}
@media screen and (max-width: 767px) {
    .grid-container .grid-item.grid-item-column-1, .grid-container .grid-item.grid-item-column-2, .grid-container .grid-item.grid-item-column-3, .grid-container .grid-item.grid-item-column-4, .grid-container .grid-item.grid-item-column-5 {
        grid-column: span 6;
    }
    .grid-container .grid-item.grid-item-column-6, .grid-container .grid-item.grid-item-column-7, .grid-container .grid-item.grid-item-column-8, .grid-container .grid-item.grid-item-column-9, .grid-container .grid-item.grid-item-column-10, .grid-container .grid-item.grid-item-column-11, .grid-container .grid-item.grid-item-column-12 {
        grid-column: span 12;
    }
    .grid-container .grid-item.grid-item-column-mobile-1 {
        grid-column: span 1;
    }
    .grid-container .grid-item.grid-item-column-mobile-2 {
        grid-column: span 2;
    }
    .grid-container .grid-item.grid-item-column-mobile-3 {
        grid-column: span 3;
    }
    .grid-container .grid-item.grid-item-column-mobile-4 {
        grid-column: span 4;
    }
    .grid-container .grid-item.grid-item-column-mobile-5 {
        grid-column: span 5;
    }
    .grid-container .grid-item.grid-item-column-mobile-6 {
        grid-column: span 6;
    }
    .grid-container .grid-item.grid-item-column-mobile-7 {
        grid-column: span 7;
    }
    .grid-container .grid-item.grid-item-column-mobile-8 {
        grid-column: span 8;
    }
    .grid-container .grid-item.grid-item-column-mobile-9 {
        grid-column: span 9;
    }
    .grid-container .grid-item.grid-item-column-mobile-10 {
        grid-column: span 10;
    }
    .grid-container .grid-item.grid-item-column-mobile-11 {
        grid-column: span 11;
    }
    .grid-container .grid-item.grid-item-column-mobile-12 {
        grid-column: span 12;
    }
}

/* ────────────────────────────────
    header
──────────────────────────────── */
.header {
    width: 100%;
    height: var(--size-header-height);
    position: fixed;
    left: 0;
    top: 0;
    z-index: var(--z-index-header);
    background-color: var(--color-background);
    padding-left: var(--size-snb-width);
    border-bottom: 1px solid var(--color-border-snb);
    transition: var(--transition-duration);
}
@media screen and (max-width: 1239px) {
    .header {
        padding-left: 0;
    }
}
@media screen and (min-width: 1240px) {
    .header .logo {
        display: none;
    }
}

.header-container {
    width: 100%;
    height: 100%;
    position: relative;
    padding: 0 var(--gap-layout);
    display: flex;
    align-items: center;
}

.header-util {
    display: flex;
    gap: var(--gap-component);
    margin-left: auto;
}
.header-util .button-group {
    gap: 0.1rem;
}
@media screen and (max-width: 1239px) {
    .header-util {
        display: none;
    }
}

@media screen and (max-width: 1239px) {
    .snb-toggle-button {
        display: none !important;
    }
}

.mobile-snb-toggle-button {
    margin-left: auto;
}
@media screen and (min-width: 1240px) {
    .mobile-snb-toggle-button {
        display: none !important;
    }
}

.header-top-button {
    width: 5rem;
    height: 5rem;
    position: fixed;
    right: var(--gap-layout);
    bottom: 0;
    border: 1px solid var(--color-border);
    border-radius: 50%;
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23909090' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 20V4m0 0 6 6m-6-6-6 6'/%3E%3C/svg%3E");
    background-size: var(--size-icon-small);
    background-position: center;
    background-repeat: no-repeat;
    background-color: var(--color-background);
    transition: var(--transition-duration);
    opacity: 0;
    pointer-events: none;
}
.header-top-button.active {
    opacity: 1;
    pointer-events: auto;
    bottom: var(--gap-layout);
}
.header-top-button:hover, .header-top-button:focus {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%233677f1' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 20V4m0 0 6 6m-6-6-6 6'/%3E%3C/svg%3E");
    border-color: var(--color-primary);
    background-color: var(--color-primary-light);
}
.header-top-button:active {
    background-color: var(--color-primary-light-active);
}

/* ────────────────────────────────
    header/snb/collapsed
──────────────────────────────── */
@media screen and (min-width: 1240px) {
    body.snb-collapsed .header {
        padding-left: var(--size-snb-collapsed-width);
    }
}
body.panel-open .header-top-button {
    right: calc(var(--size-panel) + var(--gap-layout));
}

/* ────────────────────────────────
    header/theme/dark
──────────────────────────────── */
:root.theme-dark .header-top-button {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%238896ad' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 20V4m0 0 6 6m-6-6-6 6'/%3E%3C/svg%3E");
}
:root.theme-dark .header-top-button:hover, :root.theme-dark .header-top-button:focus {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%234d84f1' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 20V4m0 0 6 6m-6-6-6 6'/%3E%3C/svg%3E");
}

/* ────────────────────────────────
    snb
──────────────────────────────── */
.snb {
    width: var(--size-snb-width);
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: var(--z-index-snb);
    background-color: var(--color-background);
    border-right: 1px solid var(--color-border-snb);
    white-space: nowrap;
    transition: var(--transition-duration);
    pointer-events: none;
}
@media screen and (max-width: 1239px) {
    .snb {
        left: auto;
        right: calc(var(--size-snb-width) * -1);
        border-right: none;
        border-left: 1px solid var(--color-border-snb);
    }
    .snb.active {
        right: 0;
    }
    .snb.active .snb-layer {
        opacity: 1;
        pointer-events: auto;
    }
}

.snb-layer {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    background-color: rgba(var(--color-background-contrast), 0.2);
    opacity: 0;
    pointer-events: none;
    z-index: -1;
    transition: var(--transition-duration);
}
@media screen and (min-width: 1240px) {
    .snb-layer {
        display: none !important;
    }
}

.snb-head {
    height: var(--size-header-height);
    display: flex;
    align-items: center;
    padding: var(--gap-layout) calc(var(--gap-layout) + (var(--gap-layout) / 2));
    border-bottom: 1px solid var(--color-border-snb);
    background-color: var(--color-background);
    transition: var(--transition-duration);
}
.snb-head .symbol {
    width: var(--size-icon);
    min-width: var(--size-icon);
    height: var(--size-icon);
    min-height: var(--size-icon);
    display: flex;
    align-items: center;
    justify-content: center;
    display: none;
}
.snb-head .snb-util {
    margin-left: auto;
}
@media screen and (min-width: 1240px) {
    .snb-head .snb-util {
        display: none !important;
    }
}
@media screen and (max-width: 1239px) {
    .snb-head {
        padding: var(--gap-layout);
    }
    .snb-head .logo,
.snb-head .symbol {
        display: none;
    }
}

.snb-body {
    position: relative;
    height: calc(100% - var(--size-header-height));
    background-color: var(--color-background);
    padding: var(--gap-layout);
    overflow: auto;
    overflow-x: hidden;
    transition: var(--transition-duration);
    display: flex;
    flex-direction: column;
}
.snb-body::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.snb-body::-webkit-scrollbar-track {
    border-radius: var(--radius);
    background-color: #78788030;
}
.snb-body::-webkit-scrollbar-thumb {
    border-radius: var(--radius);
    background: #78788030;
}
.snb-body::-webkit-scrollbar-thumb:hover {
    background: #78788050;
}
.snb-body::-webkit-scrollbar-thumb:active {
    background: #78788070;
}
.snb-body::-webkit-scrollbar-button {
    display: none;
}
.snb-body .snb-util {
    width: calc(100% + var(--gap-layout) * 2);
    position: sticky;
    left: 0;
    bottom: 0;
    background-color: var(--color-background);
    border-top: 1px solid var(--color-border-snb);
    padding: var(--gap-layout);
    padding-bottom: 0;
    margin-left: calc(var(--gap-layout) * -1);
}
.snb-body .snb-util::after {
    content: "";
    width: 100%;
    height: var(--gap-layout);
    background-color: var(--color-background);
    position: absolute;
    left: 0;
    bottom: calc(var(--gap-layout) * -1);
}
@media screen and (max-width: 1239px) {
    .snb-body {
        height: calc(100% - var(--size-header-height) - var(--size-header-height));
    }
}

.snb-bottom {
    height: var(--size-header-height);
    background-color: var(--color-background);
    border-top: 1px solid var(--color-border-snb);
    display: flex;
    align-items: center;
    padding: var(--gap-layout);
    transition: var(--transition-duration);
}
.snb-bottom .snb-util {
    width: 100%;
}
.snb-bottom .snb-util .button-group {
    gap: 0.1rem;
    flex-direction: row;
}
.snb-bottom .snb-util .button-group .button {
    width: auto;
    flex: 0;
}
.snb-bottom .snb-util .button-group .logout-button {
    margin-left: auto;
}
@media screen and (min-width: 1240px) {
    .snb-bottom {
        display: none !important;
    }
}

.snb-menu {
    flex: 1;
}
.snb-menu .snb-menu-item button::after {
    content: "";
    display: block;
    width: var(--size-snb-icon);
    min-width: var(--size-snb-icon);
    height: var(--size-snb-icon);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23909090' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E");
    background-size: var(--size-snb-icon);
    background-repeat: no-repeat;
    background-position: center;
    color: var(--color-icon-snb);
    margin-left: auto;
}
.snb-menu .snb-menu-item button.is-current::after, .snb-menu .snb-menu-item button.is-open::after {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%233677f1' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E");
}
.snb-menu .snb-menu-item .snb-menu-button {
    width: 100%;
    height: 4.2rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 1.5rem;
    color: var(--color-text-snb);
    border-radius: var(--radius-snb);
    transition: var(--transition-duration);
    padding: 0 calc(var(--gap-layout) / 2);
}
.snb-menu .snb-menu-item .snb-menu-button .text {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}
.snb-menu .snb-menu-item .snb-menu-button:hover, .snb-menu .snb-menu-item .snb-menu-button:focus {
    background-color: var(--color-primary-light);
}
.snb-menu .snb-menu-item .snb-menu-button:active {
    background-color: var(--color-primary-light-active);
}
.snb-menu .snb-menu-item .snb-menu-button.is-open::after {
    transform: rotate(180deg);
}
.snb-menu .snb-menu-item .snb-menu-button.is-open, .snb-menu .snb-menu-item .snb-menu-button.is-current {
    font-weight: 500;
    color: var(--color-primary);
}
.snb-menu .snb-menu-item .snb-menu-button.is-open .icon, .snb-menu .snb-menu-item .snb-menu-button.is-current .icon {
    color: var(--color-primary);
}
.snb-menu .snb-menu-item .snb-menu-button.active {
    font-weight: 500;
    color: var(--color-primary);
    background-color: var(--color-primary-light);
}
.snb-menu .snb-menu-item .snb-menu-button.active .icon {
    color: var(--color-primary);
}
.snb-menu .snb-menu-item .snb-menu-button .icon {
    width: var(--size-snb-icon);
    min-width: var(--size-snb-icon);
    height: var(--size-snb-icon);
    min-height: var(--size-snb-icon);
    color: var(--color-icon-snb);
    font-size: 1.8rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.snb-menu .snb-menu-item ~ .snb-menu-item {
    margin-top: 0.8rem;
}

.snb-menu-depth2 {
    margin-top: 0.6rem;
    display: none;
}
.snb-menu-depth2.is-current {
    display: block;
}
.snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button {
    width: 100%;
    height: 4.2rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 1.5rem;
    color: var(--color-text-snb);
    border-radius: var(--radius-snb);
    transition: var(--transition-duration);
    padding-left: calc(var(--size-snb-icon) + (var(--gap-layout) / 2) + 1rem);
    padding-right: calc(var(--gap-layout) / 2);
}
.snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button .text {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}
.snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button:hover, .snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button:focus {
    background-color: var(--color-primary-light);
}
.snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button:active {
    background-color: var(--color-primary-light-active);
}
.snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button.is-open::after {
    transform: rotate(180deg);
}
.snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button.is-open, .snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button.is-current {
    font-weight: 500;
    color: var(--color-primary);
}
.snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button.is-open .icon, .snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button.is-current .icon {
    color: var(--color-primary);
}
.snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button.active {
    font-weight: 500;
    color: var(--color-primary);
    background-color: var(--color-primary-light);
}
.snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button.active .icon {
    color: var(--color-primary);
}
.snb-menu-depth2 .snb-menu-depth2-item ~ .snb-menu-depth2-item {
    margin-top: 0.6rem;
}

.snb-menu-depth3 {
    margin-top: 0.4rem;
    display: none;
}
.snb-menu-depth3.is-current {
    display: block;
}
.snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button {
    width: 100%;
    height: 4.2rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 1.5rem;
    color: var(--color-text-snb);
    border-radius: var(--radius-snb);
    transition: var(--transition-duration);
    padding-left: calc(var(--size-snb-icon) + (var(--gap-layout) / 2) + 1rem + 1rem + 1rem);
    padding-right: var(--gap-component);
}
.snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button .text {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}
.snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button:hover, .snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button:focus {
    background-color: var(--color-primary-light);
}
.snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button:active {
    background-color: var(--color-primary-light-active);
}
.snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button.is-open::after {
    transform: rotate(180deg);
}
.snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button.is-open, .snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button.is-current {
    font-weight: 500;
    color: var(--color-primary);
}
.snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button.is-open .icon, .snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button.is-current .icon {
    color: var(--color-primary);
}
.snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button.active {
    font-weight: 500;
    color: var(--color-primary);
    background-color: var(--color-primary-light);
}
.snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button.active .icon {
    color: var(--color-primary);
}
.snb-menu-depth3 .snb-menu-depth3-item ~ .snb-menu-depth3-item {
    margin-top: 0.4rem;
}

/* ────────────────────────────────
    snb/snb/collapsed
──────────────────────────────── */
@media screen and (min-width: 1240px) {
    body.snb-collapsed .snb {
        width: var(--size-snb-collapsed-width);
    }
    body.snb-collapsed .snb ul li {
        position: relative;
    }
    body.snb-collapsed .snb-head {
        justify-content: center;
        padding: 0 calc(var(--gap-layout) + var(--gap-component));
    }
    body.snb-collapsed .snb-head .symbol {
        display: flex;
    }
    body.snb-collapsed .snb-head .logo {
        display: none;
    }
    body.snb-collapsed .snb-body {
        padding: var(--gap-layout) 0;
    }
    body.snb-collapsed .snb-menu .snb-menu-item .snb-menu-button {
        width: 4.2rem;
        margin: 0 auto;
    }
    body.snb-collapsed .snb-menu .snb-menu-item .snb-menu-button::after {
        display: none;
    }
    body.snb-collapsed .snb-menu .snb-menu-item .snb-menu-button .text {
        display: none;
    }
    body.snb-collapsed .snb-menu .snb-menu-item .snb-menu-button:hover ~ .snb-menu-depth2 {
        display: block !important;
    }
    body.snb-collapsed .snb-menu-depth2 {
        position: fixed;
        top: auto;
        left: calc(var(--size-snb-collapsed-width) + var(--gap-component));
        transform: translateY(-4.2rem);
        background-color: var(--color-background);
        border: 1px solid var(--color-border);
        border-color: var(--color-border-snb);
        box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
        border-radius: var(--radius-form);
        padding: var(--gap-component);
    }
    body.snb-collapsed .snb-menu-depth2::before {
        content: "";
        display: block;
        width: calc(var(--size-snb-collapsed-width) - var(--gap-layout) - var(--gap-layout));
        height: 100%;
        position: absolute;
        left: calc(-1 * (var(--size-snb-collapsed-width) - var(--gap-layout) - var(--gap-layout)));
        top: 0;
        background-color: transparent;
    }
    body.snb-collapsed .snb-menu-depth2 .snb-menu-depth2-item .snb-menu-depth2-button {
        padding: var(--gap-component);
    }
    body.snb-collapsed .snb-menu-depth2.is-current, body.snb-collapsed .snb-menu-depth2.is-open {
        display: none !important;
    }
    body.snb-collapsed .snb-menu-depth2:hover {
        display: block !important;
    }
    body.snb-collapsed .snb-menu-depth3 .snb-menu-depth3-item .snb-menu-depth3-button {
        padding: var(--gap-component);
        padding-left: calc(var(--gap-component) + var(--size-snb-icon));
    }
}

/* ────────────────────────────────
    datepicker/theme/dark
──────────────────────────────── */
:root.theme-dark .snb-menu .snb-menu-item button::after {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%238896ad' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E");
}
:root.theme-dark .snb-menu .snb-menu-item button.is-current::after, :root.theme-dark .snb-menu .snb-menu-item button.is-open::after {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%234d84f1' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E");
}

/* ────────────────────────────────
    main
──────────────────────────────── */
.main {
    min-height: 100%;
    position: relative;
    padding: var(--size-header-height) var(--gap-layout) var(--gap-layout) var(--size-snb-width);
    background-color: var(--color-background);
    transition: var(--transition-duration);
}
@media screen and (max-width: 1239px) {
    .main {
        padding-left: 0;
        padding-right: 0;
    }
}

.main-container {
    padding: var(--gap-main-container);
    padding-right: calc(var(--gap-main-container) - var(--gap-layout));
}
@media screen and (max-width: 1239px) {
    .main-container {
        padding: var(--gap-layout);
    }
}

/* ────────────────────────────────
    main/snb/collapsed
──────────────────────────────── */
@media screen and (min-width: 1240px) {
    body.snb-collapsed .main {
        padding-left: var(--size-snb-collapsed-width);
    }
}

/* ────────────────────────────────
    footer
──────────────────────────────── */
/* ────────────────────────────────
    popup
──────────────────────────────── */
.popup-container {
    width: 100%;
    height: auto;
    position: relative;
    min-height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--gap-layout);
}
@media screen and (max-width: 767px) {
    .popup-container {
        align-items: flex-start;
    }
}

.popup-content {
    width: 100%;
    height: auto;
    position: relative;
    max-width: var(--size-container-width);
    background-color: var(--color-background);
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
    border-radius: var(--radius-form);
    padding: var(--gap-section);
}
@media screen and (max-width: 767px) {
    .popup-content {
        box-shadow: none;
        padding: 0;
    }
}

/* ────────────────────────────────
    error
──────────────────────────────── */
.error-container {
    width: 100%;
    height: auto;
    position: relative;
    min-height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--gap-section);
    padding: var(--gap-layout);
    text-align: center;
}
.error-container .error-code {
    width: 20rem;
    height: 20rem;
    border-radius: 50%;
    background-color: var(--color-background-light);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 6rem;
    font-weight: 900;
    color: var(--color-text-light);
}
.error-container .error-title {
    font-size: 2.4rem;
    font-weight: 700;
}
.error-container .error-text {
    font-size: 1.8rem;
}

/* ────────────────────────────────
    result
──────────────────────────────── */
.result-container {
    width: 100%;
    height: auto;
    position: relative;
    min-height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--gap-section);
    padding: var(--gap-layout);
    text-align: center;
}
.result-container .result-code {
    width: 20rem;
    height: 20rem;
    border-radius: 50%;
    background-color: var(--color-background-light);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 6rem;
    font-weight: 900;
    color: var(--color-text-light);
}
.result-container .result-code::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    font-size: 7rem !important;
    color: var(--color-white);
}
.result-container .result-code.success {
    background-color: var(--color-success-background);
}
.result-container .result-code.success::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    color: var(--color-white);
}
.result-container .result-title {
    font-size: 2.4rem;
    font-weight: 700;
}
.result-container .result-text {
    font-size: 1.8rem;
}

/* ────────────────────────────────
    icon
──────────────────────────────── */
.icon {
    width: var(--size-icon);
    min-width: var(--size-icon);
    height: var(--size-icon);
    min-height: var(--size-icon);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-icon);
    font-size: 1.6rem;
}
.icon .fa-thumbtack {
    transform: rotate(45deg);
}
.icon.icon-small {
    width: var(--size-icon-small);
    min-width: var(--size-icon-small);
    height: var(--size-icon-small);
    min-height: var(--size-icon-small);
}
.icon.icon-xsmall {
    width: var(--size-icon-xsmall);
    min-width: var(--size-icon-xsmall);
    height: var(--size-icon-xsmall);
    min-height: var(--size-icon-xsmall);
}
.icon.icon-close {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cg clip-path='url(%23a)'%3E%3Cpath fill='%23606060' fill-rule='evenodd' d='m12.01 13.142 4.61 4.61a.815.815 0 0 0 1.151-1.153l-4.609-4.609 4.61-4.61a.815.815 0 0 0-1.153-1.151l-4.609 4.609-4.61-4.61a.815.815 0 0 0-1.15 1.153l4.608 4.609-4.61 4.61a.814.814 0 1 0 1.153 1.151l4.609-4.609Z' clip-rule='evenodd'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='a'%3E%3Cpath fill='%23fff' d='M0 0h24v24H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");
}
.icon.icon-check {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23606060' d='m9.55 15.15 8.475-8.475c.2-.2.433-.3.7-.3.267 0 .5.1.7.3.2.2.3.438.3.713a.97.97 0 0 1-.3.712l-9.175 9.2c-.2.2-.433.3-.7.3a.96.96 0 0 1-.7-.3L4.55 13a.932.932 0 0 1-.288-.712c.008-.275.112-.512.313-.713.2-.2.438-.3.713-.3.275 0 .512.1.712.3l3.55 3.575Z'/%3E%3C/svg%3E");
}
.icon.icon-date {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cg clip-path='url(%23a)'%3E%3Cpath fill='%23606060' d='M6.808 0a.84.84 0 0 1 .84.84v1.57h9.02V.85a.84.84 0 0 1 1.68 0v1.56H21.6a2.4 2.4 0 0 1 2.4 2.4V21.6A2.4 2.4 0 0 1 21.6 24H2.4A2.4 2.4 0 0 1 0 21.601V4.81a2.4 2.4 0 0 1 2.4-2.4h3.568V.84A.84.84 0 0 1 6.808 0ZM1.68 9.29v12.311a.72.72 0 0 0 .72.72h19.2a.72.72 0 0 0 .72-.72V9.307L1.68 9.29ZM8 17.543v1.999H6v-2h2Zm5 0v1.999h-2v-2h2Zm5 0v1.999h-2v-2h2ZM8 12.77v2H6v-2h2Zm5 0v2h-2v-2h2Zm5 0v2h-2v-2h2ZM5.968 4.09H2.4a.72.72 0 0 0-.72.72v2.802l20.64.016V4.81a.72.72 0 0 0-.72-.72h-3.252v1.114a.84.84 0 0 1-1.68 0V4.09h-9.02v1.104a.84.84 0 0 1-1.68 0V4.09Z'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='a'%3E%3Cpath fill='%23fff' d='M0 0h24v24H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");
}
.icon.icon-chevron-up {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23606060' d='m12 10.8-3.9 3.9a.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275.948.948 0 0 1-.275-.7c0-.283.092-.517.275-.7l4.6-4.6c.2-.2.433-.3.7-.3.267 0 .5.1.7.3l4.6 4.6a.948.948 0 0 1 .275.7.948.948 0 0 1-.275.7.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275L12 10.8Z'/%3E%3C/svg%3E");
}
.icon.icon-chevron-down {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23606060' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E");
}
.icon.icon-chevron-left {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23606060' d='M14.71 15.88 10.83 12l3.88-3.88a.997.997 0 1 0-1.41-1.41L8.71 11.3a.996.996 0 0 0 0 1.41l4.59 4.59c.39.39 1.02.39 1.41 0 .38-.39.39-1.03 0-1.42Z'/%3E%3C/svg%3E");
}
.icon.icon-chevron-right {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23606060' d='M9.29 15.88 13.17 12 9.29 8.12a.997.997 0 0 1 1.41-1.41l4.59 4.59c.39.39.39 1.02 0 1.41L10.7 17.3a.994.994 0 0 1-1.41 0c-.38-.39-.39-1.03 0-1.42Z'/%3E%3C/svg%3E");
}
.icon.icon-arrow-up {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23606060' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 20V4m0 0 6 6m-6-6-6 6'/%3E%3C/svg%3E");
}
.icon.icon-mode-light {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23606060' stroke-linejoin='round' stroke-width='2' d='M12 16a4 4 0 1 0 0-8 4 4 0 0 0 0 8Z'/%3E%3Cpath stroke='%23606060' stroke-linecap='round' stroke-width='2' d='M20 12h1M3 12h1m8 8v1m0-18v1m5.657 13.657.707.707M5.636 5.636l.707.707m0 11.314-.707.707M18.364 5.636l-.707.707'/%3E%3C/svg%3E");
}
.icon.icon-mode-dark {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23606060' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12 21a9 9 0 0 0 8.997-9.252 7 7 0 0 1-10.371-8.643A9 9 0 0 0 12 21Z'/%3E%3C/svg%3E");
}

/* ────────────────────────────────
    loading
──────────────────────────────── */
.loading-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(var(--color-background-contrast), 0.2);
    z-index: var(--z-index-loading);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: var(--gap-layout);
    opacity: 0;
    pointer-events: none;
    transition: var(--transition-duration);
}
.loading-container.active {
    opacity: 1;
    pointer-events: auto;
}
.loading-container.hidden-title .loading-title {
    display: none;
}
.loading-container.hidden-sub-title .loading-sub-title {
    display: none;
}

.loading-spinner {
    width: 4rem;
    height: 4rem;
    border: 0.4rem solid var(--color-background-light);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin 0.8s ease-in-out infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0);
    }
    100% {
        transform: rotate(360deg);
    }
}
.loading-title-container {
    text-align: center;
    color: var(--color-primary-contrast);
}

.loading-title {
    font-size: 1.8rem;
    font-weight: 500;
}

.loading-sub-title {
    white-space: pre-line;
}

/* ────────────────────────────────
    button
──────────────────────────────── */
.button-group {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--gap-component);
    /*
    @include mq-custom(max, '519px') {
        flex-direction: column;

        .button-group {
            width: 100%;
        }

        .left,
        .right {
            flex: 1;
            margin: 0;
        }

        .button {
            width: 100%;
            flex: 1;
        }
    }
    */
}
.button-group.gap-half {
    gap: calc(var(--gap-component) / 2);
}
.button-group.left {
    justify-content: flex-start;
}
.button-group.center {
    justify-content: center;
}
.button-group.right {
    justify-content: flex-end;
}
.button-group.between {
    justify-content: space-between;
}
.button-group.nowrap {
    flex-wrap: nowrap;
}
.button-group.full .button {
    flex: 1;
}

.button {
    min-height: var(--size-form);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    text-align: center;
    white-space: nowrap;
    padding: 1rem 2rem;
    border-radius: var(--radius-form);
    border: 1px solid var(--color-border);
    transition: var(--transition-duration);
}
.button:disabled {
    cursor: no-drop;
    opacity: 0.5;
}
.button i,
.button .icon {
    width: var(--size-icon-small);
    min-width: var(--size-icon-small);
    height: var(--size-icon-small);
    min-height: var(--size-icon-small);
    color: var(--color-icon);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.button:hover, .button:focus {
    color: var(--color-primary);
    border-color: var(--color-primary);
    background-color: var(--color-primary-light);
    outline: none;
}
.button:hover i,
.button:hover .icon, .button:focus i,
.button:focus .icon {
    color: var(--color-primary);
}
.button:active {
    background-color: var(--color-primary-light-active);
}
.button.button-small {
    min-height: auto;
    padding: 0.6rem 1.2rem;
    font-size: 1.4rem;
}
.button.button-small i,
.button.button-small .icon {
    width: var(--size-icon-xsmall);
    min-width: var(--size-icon-xsmall);
    height: var(--size-icon-xsmall);
    min-height: var(--size-icon-xsmall);
    font-size: 1.4rem;
}
.button.button-xsmall {
    min-height: auto;
    padding: 0.4rem 0.8rem;
    font-size: 1.2rem;
}
.button.button-loading {
    pointer-events: none;
}
.button.button-loading .text,
.button.button-loading .icon {
    opacity: 0;
}
.button.button-loading::after {
    content: "";
    display: block;
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid var(--color-border);
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}
.button.button-util {
    min-width: var(--size-form);
    padding: 0;
}
.button.button-primary {
    color: var(--color-primary-contrast);
    background-color: var(--color-primary);
    border-color: transparent;
}
.button.button-primary i,
.button.button-primary .icon {
    color: var(--color-primary-contrast);
}
.button.button-primary.button-loading::after {
    display: block;
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid var(--color-primary-contrast);
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}
.button.button-primary:hover, .button.button-primary:focus {
    background-color: var(--color-primary-hover);
}
.button.button-primary:active {
    background-color: var(--color-primary-active);
}
.button.button-primary-border {
    color: var(--color-primary);
    border-color: var(--color-primary);
}
.button.button-primary-border i,
.button.button-primary-border .icon {
    color: var(--color-primary);
}
.button.button-primary-border.button-loading::after {
    display: block;
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid var(--color-primary);
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}
.button.button-primary-light {
    color: var(--color-primary);
    border-color: transparent;
    background-color: var(--color-primary-light);
}
.button.button-primary-light i,
.button.button-primary-light .icon {
    color: var(--color-primary);
}
.button.button-primary-light.button-loading::after {
    display: block;
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid var(--color-primary);
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}
.button.button-primary-light:hover, .button.button-primary-light:focus {
    border-color: var(--color-primary);
}
.button.button-primary-light:active {
    background-color: var(--color-primary-light-active);
}
.button.button-primary-light-border {
    color: var(--color-primary);
    border-color: var(--color-primary);
    background-color: var(--color-primary-light);
}
.button.button-primary-light-border i,
.button.button-primary-light-border .icon {
    color: var(--color-primary);
}
.button.button-primary-light-border.button-loading::after {
    display: block;
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid var(--color-primary);
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}
.button.button-primary-light-border:active {
    background-color: var(--color-primary-light-active);
}
.button.button-text {
    min-height: auto;
    color: var(--color-text);
    border-color: transparent;
    background-color: var(--color-background);
    padding: 1rem;
}
.button.button-text i,
.button.button-text .icon,
.button.button-text .icon::after {
    color: var(--color-icon);
}
.button.button-text:hover, .button.button-text:focus {
    color: var(--color-primary);
    border-color: var(--color-primary);
    background-color: var(--color-primary-light);
    outline: none;
    border-color: transparent;
}
.button.button-text:hover i,
.button.button-text:hover .icon,
.button.button-text:hover .icon::after, .button.button-text:focus i,
.button.button-text:focus .icon,
.button.button-text:focus .icon::after {
    color: var(--color-primary) !important;
}
.button.button-text:active {
    background-color: var(--color-primary-light-active);
}
.button.button-list {
    color: var(--color-text-dark);
    border-color: var(--color-border);
    background-color: var(--color-background);
}
.button.button-list i,
.button.button-list .icon {
    color: var(--color-text-dark);
}
.button.button-list:hover, .button.button-list:focus {
    background-color: var(--color-background-light);
}
.button.button-list:active {
    background-color: var(--color-background-light-active);
}
.button.button-cancel {
    color: var(--color-text-dark);
    border-color: var(--color-border-gray);
    background-color: var(--color-background);
}
.button.button-cancel i,
.button.button-cancel .icon {
    color: var(--color-text-dark);
}
.button.button-cancel:hover, .button.button-cancel:focus {
    background-color: var(--color-background-light);
}
.button.button-cancel:active {
    background-color: var(--color-background-light-active);
}
.button.button-delete {
    color: var(--color-delete);
    border-color: var(--color-delete);
}
.button.button-delete i,
.button.button-delete .icon {
    color: var(--color-delete);
}
.button.button-delete.button-loading::after {
    display: block;
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid var(--color-delete);
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}
.button.button-delete:hover, .button.button-delete:focus {
    background-color: var(--color-delete-background);
}
.button.button-delete:active {
    background-color: var(--color-delete-active-background);
}
.button.button-danger {
    color: var(--color-danger);
    border-color: var(--color-danger);
}
.button.button-danger i,
.button.button-danger .icon {
    color: var(--color-danger);
}
.button.button-danger.button-loading::after {
    display: block;
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid var(--color-danger);
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}
.button.button-danger:hover, .button.button-danger:focus {
    background-color: var(--color-danger-background);
}
.button.button-danger:active {
    background-color: var(--color-danger-active-background);
}
.button.button-excel {
    color: var(--color-excel);
    border-color: var(--color-excel);
}
.button.button-excel i,
.button.button-excel .icon {
    color: var(--color-excel);
}
.button.button-excel.button-loading::after {
    display: block;
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid var(--color-excel);
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}
.button.button-excel:hover, .button.button-excel:focus {
    background-color: var(--color-excel-background);
}
.button.button-excel:active {
    background-color: var(--color-excel-active-background);
}
.button.button-hover-excel.button-loading::after {
    display: block;
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid var(--color-excel);
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}
.button.button-hover-excel:hover, .button.button-hover-excel:focus {
    color: var(--color-excel);
    border-color: var(--color-excel);
    background-color: var(--color-excel-background);
}
.button.button-hover-excel:hover i,
.button.button-hover-excel:hover .icon, .button.button-hover-excel:focus i,
.button.button-hover-excel:focus .icon {
    color: var(--color-excel);
}
.button.button-hover-excel:active {
    background-color: var(--color-excel-active-background);
}
.button.button-copy {
    padding: 0 !important;
    border: none !important;
    background-color: transparent !important;
    text-decoration: underline;
}
.button.button-copy::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    transition: var(--transition-duration);
    font-size: inherit;
}
.button.button-copy:hover, .button.button-copy:focus {
    color: var(--color-link);
}
.button.button-copy:hover::before, .button.button-copy:focus::before {
    color: var(--color-link);
}
.button.button-detail {
    padding: 0 !important;
    border: none !important;
    background-color: transparent !important;
}
.button.button-detail i {
    font-size: inherit;
    text-decoration: none;
    width: auto;
    min-width: auto;
    height: auto;
    min-height: auto;
}
.button.button-detail:hover, .button.button-detail:focus {
    color: var(--color-link);
}
.button.button-detail:hover span, .button.button-detail:focus span {
    text-decoration: underline;
}
.button.button-view {
    padding: 0 !important;
    border: none !important;
    background-color: transparent !important;
    margin-left: 0.6rem;
}
.button.button-view::before {
    content: "자세히보기";
    transition: var(--transition-duration);
    font-size: inherit;
}
.button.button-view:hover, .button.button-view:focus {
    color: var(--color-link);
}
.button.button-view:hover::before, .button.button-view:focus::before {
    color: var(--color-link);
}
.button.button-view.show::before {
    content: "간략히보기";
}
.button.button-333 {
    color: #fff;
    background-color: #333;
    border-color: transparent;
}
.button.button-333 i,
.button.button-333 .icon {
    color: var(--color-primary-contrast);
}
.button.button-333:hover, .button.button-333:focus {
    background-color: #222;
}
.button.button-333:active {
    background-color: #111;
}
.button.hidden {
    display: none;
}

/* ────────────────────────────────
    badge
──────────────────────────────── */
.badge {
    font-size: 1.2rem;
    font-weight: 500;
    color: var(--color-text-dark);
    background-color: var(--color-background-light);
    padding: 0.5rem 1rem;
    border-radius: var(--radius-form);
    white-space: nowrap;
    transition: var(--transition-duration);
}
.badge.badge-border {
    border: 1px solid var(--color-border);
}
.badge.badge-primary {
    color: var(--color-primary-contrast);
    background-color: var(--color-primary);
}
.badge.badge-primary-border {
    color: var(--color-primary);
    border: 1px solid var(--color-border);
    border-color: var(--color-primary);
    background-color: var(--color-background);
}
.badge.badge-primary-light {
    color: var(--color-primary);
    background-color: var(--color-primary-light);
}
.badge.badge-primary-light-border {
    color: var(--color-primary);
    border: 1px solid var(--color-border);
    border-color: var(--color-primary);
    background-color: var(--color-primary-light);
}
.badge.badge-green {
    color: var(--badge-green);
    background-color: var(--badge-green-background);
}
.badge.badge-green.border {
    border: 1px solid var(--color-border);
    border-color: var(--badge-green-border);
}
.badge.badge-red {
    color: var(--badge-red);
    background-color: var(--badge-red-background);
}
.badge.badge-red.border {
    border: 1px solid var(--color-border);
    border-color: var(--badge-red-border);
}
.badge.badge-blue {
    color: var(--badge-blue);
    background-color: var(--badge-blue-background);
}
.badge.badge-blue.border {
    border: 1px solid var(--color-border);
    border-color: var(--badge-blue-border);
}
.badge.badge-yellow {
    color: var(--badge-yellow);
    background-color: var(--badge-yellow-background);
}
.badge.badge-darkred {
    color: var(--badge-darkred);
    background-color: var(--badge-darkred-background);
}
.badge.badge-purple {
    color: var(--badge-purple);
    background-color: var(--badge-purple-background);
}
.badge.badge-cyan {
    color: var(--badge-cyan);
    background-color: var(--badge-cyan-background);
}
.badge.badge-teal {
    color: var(--badge-teal);
    background-color: var(--badge-teal-background);
}
.badge.badge-orange {
    color: var(--badge-orange);
    background-color: var(--badge-orange-background);
}
.badge.badge-brown {
    color: var(--badge-brown);
    background-color: var(--badge-brown-background);
}
.badge.badge-indigo {
    color: var(--badge-indigo);
    background-color: var(--badge-indigo-background);
}
.badge.badge-pink {
    color: var(--badge-pink);
    background-color: var(--badge-pink-background);
}
.badge.badge-positive {
    color: var(--badge-positive);
    background-color: var(--badge-positive-background);
}
.badge.badge-negative {
    color: var(--badge-negative);
    background-color: var(--badge-negative-background);
}
.badge.badge-warning {
    color: var(--badge-warning);
    background-color: var(--badge-warning-background);
}
.badge.badge-info {
    color: var(--badge-info);
    background-color: var(--badge-info-background);
}
.badge.badge-neutral {
    color: var(--badge-neutral);
    background-color: var(--badge-neutral-background);
}
.badge.badge-approved {
    color: var(--badge-green);
    background-color: var(--badge-green-background);
}
.badge.badge-canceled {
    color: var(--badge-red);
    background-color: var(--badge-red-background);
}
.badge.badge-total {
    color: var(--badge-blue);
    background-color: var(--badge-blue-background);
}
.badge.badge-pending {
    color: var(--badge-yellow);
    background-color: var(--badge-yellow-background);
}
.badge.badge-timeout {
    color: var(--badge-darkred);
    background-color: var(--badge-darkred-background);
}

/* ────────────────────────────────
    popover
──────────────────────────────── */
.popover-wrapper {
    display: flex;
    align-items: center;
    gap: 0.4rem;
}
@media screen and (max-width: 767px) {
    .popover-wrapper {
        position: relative;
    }
}

.popover-container {
    position: relative;
    margin-top: -0.4rem;
}
@media screen and (max-width: 767px) {
    .popover-container {
        position: static;
    }
}

.popover-button::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--size-icon-xsmall);
    height: var(--size-icon-xsmall);
    font-size: 0.8rem;
    border: 1px solid var(--color-border);
    border-color: var(--color-primary);
    border-radius: 50%;
    color: var(--color-primary);
}

.popover {
    width: max-content;
    min-width: 24rem;
    max-width: 36rem;
    position: absolute;
    left: calc(100% - 2.4rem - 1.6rem);
    bottom: 100%;
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-form);
    padding: 2rem;
    margin-bottom: 1rem;
    display: none;
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
    z-index: var(--z-index-popover);
}
.popover::before {
    content: "";
    width: var(--size-icon-xsmall);
    height: var(--size-icon-xsmall);
    display: block;
    position: absolute;
    transform: rotate(45deg);
    border: 0.1rem solid var(--color-border);
    border-top-color: transparent;
    border-left-color: transparent;
    background-color: var(--color-background);
    position: absolute;
    bottom: -0.8rem;
    left: 2.4rem;
}
.popover.active {
    display: block;
}
.popover .popover-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
}
.popover .popover-head .popover-title {
    font-size: 1.7rem;
    font-weight: 700;
}
.popover .popover-head .popover-close {
    width: var(--size-icon);
    height: var(--size-icon);
    background-repeat: no-repeat;
    background-size: var(--size-icon);
    background-position: center;
    background-image: url(../images/icon/close.svg);
}
.popover .popover-head ~ .popover-content {
    margin-top: 1rem;
}
.popover .popover-content {
    font-size: 1.5rem;
}
.popover.popover-left {
    left: auto;
    right: calc(100% - 2.4rem - 1.6rem);
}
.popover.popover-left::before {
    left: auto;
    right: 2.4rem;
}
.popover.popover-center {
    left: 50%;
    transform: translateX(-50%);
}
.popover.popover-center::before {
    left: calc(50% - .8rem);
}
@media screen and (max-width: 767px) {
    .popover {
        width: calc(100vw - 6rem);
        min-width: auto;
        max-width: none;
        left: 0 !important;
        transform: none !important;
    }
    .popover::before {
        display: none;
    }
}

/* ────────────────────────────────
    input
──────────────────────────────── */
.input[type=text], .input[type=password] {
    font-size: var(--font-base-size);
    color: var(--color-text);
    height: var(--size-form);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-form);
    background-color: var(--color-background-form);
    padding: 0 var(--padding-form);
    transition: var(--transition-duration);
}
.input[type=text]::placeholder, .input[type=password]::placeholder {
    color: var(--color-text-light);
}
.input[type=text]:focus, .input[type=password]:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 1px var(--color-primary);
}
.input[type=text]:read-only, .input[type=password]:read-only {
    color: var(--color-text-light);
    background-color: var(--color-background-form-readonly);
}

/* ────────────────────────────────
    input/range
──────────────────────────────── */
input[type=range] {
    width: 100%;
    -webkit-appearance: none;
}
input[type=range]:focus {
    outline: none;
}
input[type=range]:active::-webkit-slider-runnable-track {
    background-color: var(--color-border);
}
input[type=range]::-webkit-slider-runnable-track {
    width: 100%;
    height: 4px;
    cursor: pointer;
    background-color: var(--color-border-light);
    transition: var(--transition-duration);
    border-radius: 4px;
}
input[type=range]::-webkit-slider-thumb {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    cursor: pointer;
    -webkit-appearance: none;
    background-color: var(--color-primary);
    margin-top: -5px;
}
input[type=range]::-webkit-slider-thumb:hover, input[type=range]::-webkit-slider-thumb:focus {
    background-color: var(--color-primary-active);
}

/* ────────────────────────────────
    select
──────────────────────────────── */
.select {
    font-size: var(--font-base-size);
    color: var(--color-text);
    height: var(--size-form);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-form);
    background-color: var(--color-background-form);
    padding: 0 calc(var(--padding-form) + (var(--padding-form) / 2) + var(--size-icon)) 0 var(--padding-form);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23909090' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E");
    background-position: center right var(--padding-form);
    background-repeat: no-repeat;
    background-size: var(--size-icon-small);
    transition: var(--transition-duration);
}
.select:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 1px var(--color-primary);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23909090' d='m12 10.8-3.9 3.9a.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275.948.948 0 0 1-.275-.7c0-.283.092-.517.275-.7l4.6-4.6c.2-.2.433-.3.7-.3.267 0 .5.1.7.3l4.6 4.6a.948.948 0 0 1 .275.7.948.948 0 0 1-.275.7.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275L12 10.8Z'/%3E%3C/svg%3E");
}

/* ────────────────────────────────
    select/theme/dark
──────────────────────────────── */
:root.theme-dark .select {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%238896ad' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E");
}
:root.theme-dark .select:focus {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%238896ad' d='m12 10.8-3.9 3.9a.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275.948.948 0 0 1-.275-.7c0-.283.092-.517.275-.7l4.6-4.6c.2-.2.433-.3.7-.3.267 0 .5.1.7.3l4.6 4.6a.948.948 0 0 1 .275.7.948.948 0 0 1-.275.7.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275L12 10.8Z'/%3E%3C/svg%3E");
}

/* ────────────────────────────────
    select2
──────────────────────────────── */
.select2 {
    width: 100% !important;
    height: var(--size-form);
    text-align: left;
}
.select2 .selection {
    width: 100% !important;
}
.select2 .selection .select2-selection {
    height: var(--size-form);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-form);
    position: relative;
    outline: none;
    background-color: var(--color-background-form);
    transition: var(--transition-duration);
}
.select2 .selection .select2-selection .select2-selection__rendered {
    color: var(--color-text);
    line-height: var(--size-form);
    padding: 0 var(--padding-form);
}
.select2 .selection .select2-selection .select2-selection__arrow {
    width: var(--size-icon-small);
    height: var(--size-icon-small);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23909090' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E");
    background-position: center;
    background-repeat: no-repeat;
    background-size: var(--size-icon-small);
    right: var(--padding-form);
    top: 50%;
    transform: translateY(-50%);
}
.select2 .selection .select2-selection .select2-selection__arrow b {
    display: none;
}
.select2.select2-container--focus .selection .select2-selection {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 1px var(--color-primary);
}
.select2.select2-container--open .selection .select2-selection .select2-selection__arrow {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23909090' d='m12 10.8-3.9 3.9a.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275.948.948 0 0 1-.275-.7c0-.283.092-.517.275-.7l4.6-4.6c.2-.2.433-.3.7-.3.267 0 .5.1.7.3l4.6 4.6a.948.948 0 0 1 .275.7.948.948 0 0 1-.275.7.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275L12 10.8Z'/%3E%3C/svg%3E");
}

.select2-dropdown {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-form);
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
    background-color: var(--color-background-form);
}
.select2-dropdown .select2-search {
    padding: 0;
}
.select2-dropdown .select2-search .select2-search__field {
    height: var(--size-form);
    border: none;
    border-bottom: 1px solid var(--color-border);
    padding: 0 var(--padding-form);
    background-color: transparent;
}
.select2-dropdown .select2-results__option {
    padding: var(--padding-form);
}
.select2-dropdown .select2-results__message {
    background-color: var(--color-background-form-readonly);
    border-radius: 0 0 var(--radius-form) var(--radius-form);
}
.select2-dropdown .select2-results__options {
    overflow: auto;
    border-radius: 0 0 var(--radius-form) var(--radius-form);
}
.select2-dropdown .select2-results__options::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.select2-dropdown .select2-results__options::-webkit-scrollbar-track {
    border-radius: var(--radius);
    background-color: #78788030;
}
.select2-dropdown .select2-results__options::-webkit-scrollbar-thumb {
    border-radius: var(--radius);
    background: #78788030;
}
.select2-dropdown .select2-results__options::-webkit-scrollbar-thumb:hover {
    background: #78788050;
}
.select2-dropdown .select2-results__options::-webkit-scrollbar-thumb:active {
    background: #78788070;
}
.select2-dropdown .select2-results__options::-webkit-scrollbar-button {
    display: none;
}
.select2-dropdown .select2-results__options .select2-results__option--selected {
    background-color: var(--color-background-form-readonly);
}
.select2-dropdown .select2-results__options .select2-results__option--highlighted {
    background-color: var(--color-primary);
}

/* ────────────────────────────────
    select2/theme/dark
──────────────────────────────── */
:root.theme-dark .select2 .selection .select2-selection .select2-selection__arrow {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%238896ad' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E");
}
:root.theme-dark .select2.select2-container--open .selection .select2-selection .select2-selection__arrow {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%238896ad' d='m12 10.8-3.9 3.9a.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275.948.948 0 0 1-.275-.7c0-.283.092-.517.275-.7l4.6-4.6c.2-.2.433-.3.7-.3.267 0 .5.1.7.3l4.6 4.6a.948.948 0 0 1 .275.7.948.948 0 0 1-.275.7.948.948 0 0 1-.7.275.948.948 0 0 1-.7-.275L12 10.8Z'/%3E%3C/svg%3E");
}

/* ────────────────────────────────
    checkbox
──────────────────────────────── */
.checkbox {
    width: fit-content;
    cursor: pointer;
    background-color: var(--color-background);
    position: relative;
    /*
    &.ui-sortable-handle {
        &::after {
            @include fontAwesome5("\f142");
            position: absolute;
            right: var(--gap-component);
            top: 50%;
            transform: translateY(-50%);
        }
    }
    */
}
.checkbox input[type=checkbox] {
    display: none;
}
.checkbox input[type=checkbox]:checked ~ label {
    color: var(--color-text);
}
.checkbox input[type=checkbox]:checked ~ label::before {
    border-color: transparent;
    background-color: var(--color-primary);
}
.checkbox input[type=checkbox]:checked ~ label::after {
    opacity: 1;
    transform: scale(1);
}
.checkbox label {
    position: relative;
    font-size: var(--font-base-size);
    display: flex;
    align-items: center;
    gap: calc(var(--gap-component) / 2);
    transition: var(--transition-duration);
    cursor: pointer;
    color: var(--color-text-light);
}
.checkbox label::before, .checkbox label::after {
    content: "";
    display: flex;
    width: var(--size-icon-small);
    height: var(--size-icon-small);
    text-align: center;
    align-items: center;
    justify-content: center;
    transition: var(--transition-duration);
}
.checkbox label::before {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-form);
}
.checkbox label::after {
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0;
    color: var(--color-primary-contrast);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23FFFFFF' d='m9.55 15.15 8.475-8.475c.2-.2.433-.3.7-.3.267 0 .5.1.7.3.2.2.3.438.3.713a.97.97 0 0 1-.3.712l-9.175 9.2c-.2.2-.433.3-.7.3a.96.96 0 0 1-.7-.3L4.55 13a.932.932 0 0 1-.288-.712c.008-.275.112-.512.313-.713.2-.2.438-.3.713-.3.275 0 .512.1.712.3l3.55 3.575Z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: var(--size-icon-xsmall);
    background-position: center calc(50% + 0.1rem);
}
.checkbox label:hover::before, .checkbox label:focus::before {
    background-color: var(--color-primary-light);
}
.checkbox label:active::before {
    background-color: var(--color-primary-light-active);
}
.checkbox label .required {
    color: var(--color-primary);
    margin-right: -0.6rem;
}
.checkbox .drag-handle {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    padding: 0 calc(var(--gap-component) * 1.5);
}
.checkbox .drag-handle::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
}

.checkbox-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-component);
    overflow-x: hidden;
}
.checkbox-group.column {
    flex-direction: column;
}
.checkbox-group.border .checkbox {
    width: 100%;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-form);
    transition: background color var(--transition-duration);
}
.checkbox-group.border .checkbox:hover {
    background-color: var(--color-background-light);
}
.checkbox-group.border .checkbox label {
    padding: var(--gap-component);
}
.checkbox-group.border .checkbox label::after {
    top: var(--gap-component);
    left: var(--gap-component);
}

/* ────────────────────────────────
    switch
──────────────────────────────── */
.switch {
    width: fit-content;
    position: relative;
}
.switch input[type=checkbox] {
    display: none;
}
.switch input[type=checkbox]:checked ~ label {
    background-color: var(--color-primary);
}
.switch input[type=checkbox]:checked ~ label::before {
    left: 3.8rem;
}
.switch label {
    width: 6.4rem;
    height: 3.2rem;
    display: flex;
    align-items: center;
    border-radius: 2.4rem;
    background-color: var(--color-border-light);
    cursor: pointer;
    transition: var(--transition-duration);
}
.switch label::before {
    content: "";
    display: block;
    width: 2rem;
    height: 2rem;
    background-color: var(--color-primary-contrast);
    border-radius: 50%;
    position: absolute;
    left: 0.6rem;
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
    transition: var(--transition-duration);
}
.switch.switch-small input[type=checkbox]:checked ~ label::before {
    left: 2.7rem;
}
.switch.switch-small label {
    width: 4.8rem;
    height: 2.4rem;
}
.switch.switch-small label::before {
    width: 1.5rem;
    height: 1.5rem;
}

/* ────────────────────────────────
    radio
──────────────────────────────── */
.radio {
    width: fit-content;
}
.radio * {
    cursor: pointer;
}
.radio input[type=radio] {
    display: none;
}
.radio input[type=radio]:checked ~ label {
    color: var(--color-text);
}
.radio input[type=radio]:checked ~ label::before {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 1px var(--color-primary);
}
.radio input[type=radio]:checked ~ label::after {
    opacity: 1;
}
.radio label {
    font-size: var(--font-base-size);
    display: flex;
    align-items: center;
    gap: calc(var(--gap-component) / 2);
    position: relative;
    transition: var(--transition-duration);
    color: var(--color-label);
}
.radio label::before {
    content: "";
    display: flex;
    width: var(--size-icon-small);
    height: var(--size-icon-small);
    text-align: center;
    align-items: center;
    justify-content: center;
    transition: var(--transition-duration);
    border: 1px solid var(--color-border);
    border-radius: 50%;
}
.radio label:hover::before, .radio label:focus::before {
    background-color: var(--color-primary-light);
}
.radio label:active::before {
    background-color: var(--color-primary-light-active);
}

.radio-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-component);
}
.radio-group.ui-tab {
    width: fit-content;
    max-width: 100%;
    flex-wrap: nowrap;
    gap: 0;
    border-radius: var(--radius-form);
    overflow: hidden;
}
.radio-group.ui-tab input[type=radio]:checked ~ label {
    font-weight: 600;
    color: var(--color-primary-contrast);
    background-color: var(--color-primary);
    border-color: transparent;
}
.radio-group.ui-tab .radio label {
    min-height: var(--size-form);
    padding: 0 var(--gap-layout);
    border: 1px solid var(--color-border);
    margin-left: -1px;
}
.radio-group.ui-tab .radio label::before {
    display: none;
}
.radio-group.ui-tab .radio:first-child label {
    margin-left: 0;
    border-radius: var(--radius-form) 0 0 var(--radius-form);
}
.radio-group.ui-tab .radio:last-child label {
    border-radius: 0 var(--radius-form) var(--radius-form) 0;
}
.radio-group.ui-tab-shadow {
    width: fit-content;
    max-width: 100%;
    flex-wrap: nowrap;
    gap: 0;
    border-radius: var(--radius-form);
    background-color: var(--color-primary-light);
}
.radio-group.ui-tab-shadow input[type=radio]:checked ~ label {
    font-weight: 600;
    color: var(--color-primary);
    background-color: var(--color-primary-contrast);
    border-color: transparent;
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
    border-radius: var(--radius-form);
}
.radio-group.ui-tab-shadow .radio label {
    min-height: var(--size-form);
    padding: 0 var(--gap-layout);
}
.radio-group.ui-tab-shadow .radio label::before {
    display: none;
}
.radio-group.ui-tab-shadow .radio:first-child label {
    margin-left: 0;
}

/* ────────────────────────────────
    textarea
──────────────────────────────── */
.textarea {
    width: 100%;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-form);
    padding: var(--padding-form);
    font-size: var(--font-base-size);
    resize: none;
    outline: none;
    overflow: auto;
    background-color: var(--background-color-form);
    color: var(--color-text);
}
.textarea::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.textarea::-webkit-scrollbar-track {
    border-radius: var(--radius);
    background-color: #78788030;
}
.textarea::-webkit-scrollbar-thumb {
    border-radius: var(--radius);
    background: #78788030;
}
.textarea::-webkit-scrollbar-thumb:hover {
    background: #78788050;
}
.textarea::-webkit-scrollbar-thumb:active {
    background: #78788070;
}
.textarea::-webkit-scrollbar-button {
    display: none;
}
.textarea::placeholder {
    color: var(--color-text-light);
}
.textarea:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 1px var(--color-primary);
}
.textarea:read-only {
    color: var(--color-text-light);
    background-color: var(--color-background-form-readonly);
}

/* ────────────────────────────────
    modal
──────────────────────────────── */
.modal {
    width: 100%;
    max-width: 100%;
    height: 100%;
    max-height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: var(--z-index-modal);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--gap-layout);
    opacity: 0;
    pointer-events: none;
    transition: var(--transition-duration);
}
.modal .form-title {
    font-size: 1.8rem;
}
.modal.active {
    opacity: 1;
    pointer-events: auto;
}
.modal.full {
    padding: 0;
}
.modal.full .modal-inner {
    border-radius: 0;
    max-width: none;
}
.modal.modal-small .modal-container {
    max-width: 40rem;
}
.modal.modal-medium .modal-container {
    max-width: 56rem;
}
.modal.modal-large .modal-container {
    max-width: 72rem;
}
.modal.modal-xlarge .modal-container {
    max-width: 88rem;
}
.modal.modal-xxlarge .modal-container {
    max-width: 104rem;
}
.modal.modal-xxxlarge .modal-container {
    max-width: 120rem;
}
.modal.modal-xxxxlarge .modal-container {
    max-width: 136rem;
}
.modal.modal-full .modal-container {
    max-width: 100%;
}
.modal.modal-confirm .modal-container .modal-content {
    margin-top: var(--gap-component);
}

.modal-layer {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    display: block;
    background-color: rgba(var(--color-background-contrast), 0.2);
}

.modal-container {
    width: 100%;
    height: auto;
    position: relative;
    overflow: auto;
    overflow-x: hidden;
    overscroll-behavior: none;
    max-height: 100%;
    max-width: 56rem;
    background-color: var(--color-background);
    border-radius: var(--radius-form);
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
}
.modal-container::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.modal-container::-webkit-scrollbar-track {
    border-radius: var(--radius);
    background-color: #78788030;
}
.modal-container::-webkit-scrollbar-thumb {
    border-radius: var(--radius);
    background: #78788030;
}
.modal-container::-webkit-scrollbar-thumb:hover {
    background: #78788050;
}
.modal-container::-webkit-scrollbar-thumb:active {
    background: #78788070;
}
.modal-container::-webkit-scrollbar-button {
    display: none;
}

.modal-head {
    width: 100%;
    position: sticky;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap-layout);
    padding: var(--gap-layout);
    border-bottom: 1px solid var(--color-border-light);
    background-color: var(--color-background);
    z-index: 1;
    border-radius: var(--radius-form) var(--radius-form) 0 0;
}
.modal-head.no-border {
    border: none;
}

.modal-title {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-size: 1.8rem;
    font-weight: 700;
}

.modal-close-button {
    width: var(--size-icon);
    height: var(--size-icon);
    background-repeat: no-repeat;
    background-size: var(--size-icon);
    background-position: center;
    transition: var(--transition-duration);
    position: relative;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cg clip-path='url(%23a)'%3E%3Cpath fill='%23606060' fill-rule='evenodd' d='m12.01 13.142 4.61 4.61a.815.815 0 0 0 1.151-1.153l-4.609-4.609 4.61-4.61a.815.815 0 0 0-1.153-1.151l-4.609 4.609-4.61-4.61a.815.815 0 0 0-1.15 1.153l4.608 4.609-4.61 4.61a.814.814 0 1 0 1.153 1.151l4.609-4.609Z' clip-rule='evenodd'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='a'%3E%3Cpath fill='%23fff' d='M0 0h24v24H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");
}
.modal-close-button::after {
    content: "";
    display: block;
    width: calc(100% + var(--padding-form));
    height: calc(100% + var(--padding-form));
    background-color: var(--color-primary-light);
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    border-radius: var(--radius-form);
    z-index: -1;
    opacity: 0;
    transition: var(--transition-duration);
}
.modal-close-button:hover, .modal-close-button:focus {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cg clip-path='url(%23a)'%3E%3Cpath fill='%233677f1' fill-rule='evenodd' d='m12.01 13.142 4.61 4.61a.815.815 0 0 0 1.151-1.153l-4.609-4.609 4.61-4.61a.815.815 0 0 0-1.153-1.151l-4.609 4.609-4.61-4.61a.815.815 0 0 0-1.15 1.153l4.608 4.609-4.61 4.61a.814.814 0 1 0 1.153 1.151l4.609-4.609Z' clip-rule='evenodd'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='a'%3E%3Cpath fill='%23fff' d='M0 0h24v24H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");
}
.modal-close-button:hover::after, .modal-close-button:focus::after {
    opacity: 1;
}
.modal-close-button:active::after {
    background-color: var(--color-primary-light-active);
}

.modal-content {
    width: 100%;
    height: auto;
    position: relative;
    padding: 2rem;
}

.modal-bottom {
    width: 100%;
    position: sticky;
    left: 0;
    bottom: 0;
    display: flex;
    justify-content: flex-end;
    background-color: var(--color-background);
    z-index: 1;
    padding: 2rem;
    gap: 1rem;
}
.modal-bottom.between {
    justify-content: space-between;
}

/* ────────────────────────────────
    modal/theme/dark
──────────────────────────────── */
:root.theme-dark .modal-close-button {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cg clip-path='url(%23a)'%3E%3Cpath fill='%23b0bed1' fill-rule='evenodd' d='m12.01 13.142 4.61 4.61a.815.815 0 0 0 1.151-1.153l-4.609-4.609 4.61-4.61a.815.815 0 0 0-1.153-1.151l-4.609 4.609-4.61-4.61a.815.815 0 0 0-1.15 1.153l4.608 4.609-4.61 4.61a.814.814 0 1 0 1.153 1.151l4.609-4.609Z' clip-rule='evenodd'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='a'%3E%3Cpath fill='%23fff' d='M0 0h24v24H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");
}
:root.theme-dark .modal-close-button:hover, :root.theme-dark .modal-close-button:focus {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cg clip-path='url(%23a)'%3E%3Cpath fill='%234d84f1' fill-rule='evenodd' d='m12.01 13.142 4.61 4.61a.815.815 0 0 0 1.151-1.153l-4.609-4.609 4.61-4.61a.815.815 0 0 0-1.153-1.151l-4.609 4.609-4.61-4.61a.815.815 0 0 0-1.15 1.153l4.608 4.609-4.61 4.61a.814.814 0 1 0 1.153 1.151l4.609-4.609Z' clip-rule='evenodd'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='a'%3E%3Cpath fill='%23fff' d='M0 0h24v24H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");
}

/* ────────────────────────────────
    table
──────────────────────────────── */
.table-container {
    width: 100%;
    height: auto;
    position: relative;
}

.table {
    width: 100%;
    height: auto;
    position: relative;
    border-collapse: collapse;
    text-align: left;
    font-size: 1.4rem;
}
.table thead th[data-sort] {
    position: relative;
    padding-right: calc(var(--padding-form) + var(--gap-component) + 0.75rem);
    cursor: pointer;
}
.table thead th[data-sort]::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    margin-top: -0.1rem;
}
.table thead th[data-sort]::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    margin-top: 0.1rem;
}
.table thead th[data-sort]::before, .table thead th[data-sort]::after {
    position: absolute;
    right: var(--padding-form);
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.2rem;
    color: var(--color-icon);
    opacity: 0.4;
}
.table thead th[data-direction=asc]::before {
    opacity: 1;
}
.table thead th[data-direction=desc]::after {
    opacity: 1;
}
.table tr {
    border-top: 1px solid var(--color-border-light);
    border-bottom: 1px solid var(--color-border-light);
    transition: var(--transition-duration);
}
.table tr:hover, .table tr:focus {
    background-color: var(--color-background-light);
}
.table th,
.table td {
    padding: var(--padding-form);
    transition: var(--transition-duration);
}
.table th {
    white-space: nowrap;
    font-weight: 500;
    color: var(--color-label);
    background-color: var(--color-background-light);
}
.table .button-group {
    flex-wrap: nowrap;
    flex-direction: row;
}
.table .button-group .button {
    flex: 0;
}
.table .button {
    min-height: auto;
    font-size: 1.3rem;
    padding: 0.5rem 1rem;
}
.table .nodata {
    color: var(--color-text-light);
    text-align: center;
}
.table .checkbox label::before, .table .checkbox label::after {
    width: var(--size-icon-small);
    height: var(--size-icon-small);
}
.table .checkbox label::after {
    background-size: var(--size-icon-xsmall);
}
.table .input[type=text], .table .input[type=password] {
    width: 100%;
    min-width: 12rem;
    height: var(--size-table-form);
}
.table .select {
    width: 100%;
    min-width: 12rem;
    height: var(--size-table-form);
    font-size: 1.4rem;
}
.table .select2 {
    min-width: 12rem;
    height: var(--size-table-form);
    font-size: 1.4rem;
}
.table .select2 .selection {
    width: 100% !important;
}
.table .select2 .selection .select2-selection {
    height: var(--size-table-form);
}
.table .select2 .selection .select2-selection .select2-selection__rendered {
    line-height: var(--size-table-form);
}
.table .select2-dropdown .select2-search .select2-search__field {
    height: var(--size-table-form);
}
.table.table-align-left {
    text-align: left;
}
.table.table-align-left .button-group {
    justify-content: flex-start;
}
.table.table-align-center {
    text-align: center;
}
.table.table-align-center .button-group {
    justify-content: center;
}
.table.table-nowrap * {
    white-space: nowrap;
}
.table.table-border th,
.table.table-border td {
    border: 1px solid var(--color-border);
}
.table ~ .table-bottom .table-button-group {
    margin: 0 auto;
}
.table.table-card thead {
    display: none;
}
.table.table-card tbody {
    display: flex;
    flex-direction: column;
    gap: var(--gap-component);
}
.table.table-card tr {
    display: flex;
    flex-direction: column;
    gap: var(--gap-component);
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-form);
    padding: var(--gap-layout);
}
.table.table-card td {
    padding: 0;
}
.table.table-card td[data-label]::before {
    content: attr(data-label);
    display: inline-block;
    margin-right: var(--gap-component);
    font-weight: 500;
    color: var(--color-label);
}
.table.table-card .button-group {
    justify-content: flex-end;
}
@media screen and (max-width: 767px) {
    .table.table-card-mobile thead {
        display: none;
    }
    .table.table-card-mobile tbody {
        display: flex;
        flex-direction: column;
        gap: var(--gap-component);
    }
    .table.table-card-mobile tr {
        display: flex;
        flex-direction: column;
        gap: var(--gap-component);
        border: 1px solid var(--color-border) !important;
        border-radius: var(--radius-form);
        padding: var(--gap-layout);
    }
    .table.table-card-mobile td {
        padding: 0;
    }
    .table.table-card-mobile td[data-label]::before {
        content: attr(data-label);
        display: inline-block;
        margin-right: var(--gap-component);
        font-weight: 500;
        color: var(--color-label);
    }
    .table.table-card-mobile .button-group {
        justify-content: flex-end;
    }
}

.table-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap-layout);
    margin-bottom: var(--gap-layout);
}
.table-head .table-title-container .table-title {
    font-size: 1.6rem;
    font-weight: 500;
    white-space: nowrap;
}
.table-head .table-title-container .table-title .table-count {
    color: var(--color-primary);
    font-weight: 700;
}
@media screen and (max-width: 767px) {
    .table-head {
        flex-direction: column;
        justify-content: flex-start;
        align-items: flex-start;
    }
}

.table-search {
    margin-bottom: var(--gap-layout);
}

.table-filter {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: var(--gap-component);
    margin-left: auto;
}
@media screen and (max-width: 767px) {
    .table-filter {
        width: 100%;
        flex-direction: column;
        margin: 0;
    }
    .table-filter .button {
        justify-content: space-between;
        padding: 0 var(--padding-form);
    }
    .table-filter .button .icon {
        order: 1;
    }
}

.table-total {
    margin-bottom: var(--gap-layout);
    display: flex;
    gap: var(--gap-layout);
    overflow: auto;
}
.table-total::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.table-total::-webkit-scrollbar-track {
    border-radius: var(--radius);
    background-color: #78788030;
}
.table-total::-webkit-scrollbar-thumb {
    border-radius: var(--radius);
    background: #78788030;
}
.table-total::-webkit-scrollbar-thumb:hover {
    background: #78788050;
}
.table-total::-webkit-scrollbar-thumb:active {
    background: #78788070;
}
.table-total::-webkit-scrollbar-button {
    display: none;
}
.table-total .card {
    flex: 1;
}

.table-body {
    overflow: auto;
    position: relative;
}
.table-body::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.table-body::-webkit-scrollbar-track {
    border-radius: var(--radius);
    background-color: #78788030;
}
.table-body::-webkit-scrollbar-thumb {
    border-radius: var(--radius);
    background: #78788030;
}
.table-body::-webkit-scrollbar-thumb:hover {
    background: #78788050;
}
.table-body::-webkit-scrollbar-thumb:active {
    background: #78788070;
}
.table-body::-webkit-scrollbar-button {
    display: none;
}
.table-body.thead-sticky {
    max-height: 63rem;
}
.table-body.thead-sticky .table thead {
    position: sticky;
    top: 0;
    left: 0;
    z-index: 1;
}
.table-body.thead-sticky .table thead::before, .table-body.thead-sticky .table thead::after {
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: var(--color-border-light);
    position: absolute;
    left: 0;
    transition: var(--transition-duration);
}
.table-body.thead-sticky .table thead::before {
    top: 0;
}
.table-body.thead-sticky .table thead::after {
    bottom: 0;
}
.table-body.thead-sticky .table tbody tr:first-child {
    border-top: none;
}

.table-bottom {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--gap-layout);
    margin-top: var(--gap-section);
}
.table-bottom .button-group {
    flex: 1;
}
@media screen and (max-width: 767px) {
    .table-bottom .button-group .button {
        flex: 1;
    }
}

/* ────────────────────────────────
    pagination
──────────────────────────────── */
.pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: calc(var(--gap-component) / 2);
}
.pagination .button-group {
    gap: calc(var(--gap-component) / 2);
    flex-direction: row;
    justify-content: center;
}
.pagination button {
    min-width: 4rem;
    min-height: 4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: var(--color-text-dark);
    border-radius: var(--radius-form);
    transition: var(--transition-duration);
}
.pagination button.active {
    color: var(--color-primary);
    background-color: var(--color-primary-light);
    font-weight: 700;
}
.pagination button:hover, .pagination button:focus {
    background-color: var(--color-primary-light);
}
.pagination button:active {
    color: var(--color-primary);
    background-color: var(--color-primary-light-active);
}
.pagination .prev::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
}
.pagination .next::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
}
.pagination .prev,
.pagination .next {
    display: flex;
    align-items: center;
    justify-content: center;
}
.pagination .prev::before,
.pagination .next::before {
    color: var(--color-icon-light);
}
.pagination .prev:hover, .pagination .prev:focus,
.pagination .next:hover,
.pagination .next:focus {
    background-color: var(--color-primary-light);
}
.pagination .prev:active,
.pagination .next:active {
    color: var(--color-primary);
    background-color: var(--color-primary-light-active);
}
.pagination .prev:active::before,
.pagination .next:active::before {
    color: var(--color-primary);
}

/* ────────────────────────────────
    form
──────────────────────────────── */
.form-container {
    background-color: var(--color-background);
    position: relative;
}
.form-container.border {
    border: 1px solid var(--color-border);
    padding: var(--gap-section);
}
.form-container.border-top {
    border-top: 1px solid var(--color-border);
    padding-top: var(--gap-section);
}
.form-container.border-radius {
    border: 1px solid var(--color-border);
    padding: var(--gap-section);
    border-radius: var(--radius-form);
}
.form-container ~ .form-container {
    margin-top: var(--gap-section);
}
.form-container.sticky {
    position: sticky;
    bottom: 0;
    background-color: var(--color-background);
    padding-bottom: var(--gap-layout);
    margin-bottom: calc(var(--gap-layout) * -1);
}
.form-container.sticky::before {
    content: "";
    display: block;
    width: 100%;
    height: var(--gap-section);
    background-color: var(--blur-background);
    box-shadow: 0 0 40px rgba(var(--blur-shadow)) inset;
    position: absolute;
    left: 0;
    top: calc(var(--gap-section) * -1);
}

.form-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--gap-component);
}
.form-head .button {
    min-height: auto;
    font-size: 1.4rem;
    padding: 0.6rem 1.2rem;
}
.form-head ~ .form-content {
    margin-top: var(--gap-layout);
}
.form-head .drag-handle {
    width: 100%;
    height: var(--gap-section);
    position: absolute;
    top: 0;
    left: 0;
    cursor: move;
    display: flex;
    align-items: center;
    justify-content: center;
}
.form-head .drag-handle::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    color: var(--color-icon-light);
}

.form-title {
    font-size: 2rem;
    font-weight: 700;
}
.form-title ~ .form-sub-title {
    margin-top: 1rem;
}

.form-sub-title {
    font-size: 1.6rem;
    color: var(--color-text-dark);
}

.form-content {
    display: flex;
    flex-direction: column;
    gap: var(--gap-layout);
}

.form-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-layout);
}
.form-row .form-col {
    flex: 1;
    min-width: 20rem;
}

.form-col {
    display: flex;
    flex-direction: column;
    gap: var(--gap-component);
}

.form-group {
    display: flex;
    align-items: center;
    gap: var(--gap-component);
    background-color: var(--color-background);
}
.form-group.between {
    justify-content: space-between;
}
.form-group .input,
.form-group .select {
    flex: 1;
    width: 100%;
}
.form-group .drag-handle {
    cursor: move;
}
.form-group .drag-handle::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    color: var(--color-icon-light);
}

.form-label {
    font-size: 1.4rem;
    color: var(--color-label);
}
.form-label.required::before {
    content: "";
    display: inline-block;
    vertical-align: middle;
    width: 0.6rem;
    height: 0.6rem;
    border-radius: 50%;
    background-color: var(--color-primary);
    margin-right: 0.4rem;
}

.form-msg {
    font-size: 1.3rem;
    color: var(--color-text-light);
    position: relative;
    padding-left: var(--size-icon);
}
.form-msg::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: var(--size-icon-xsmall);
    height: var(--size-icon-xsmall);
    position: absolute;
    left: 0;
    top: 0.15rem;
    font-size: 0.8rem !important;
    border: 1px solid var(--color-border);
    border-radius: 50%;
    color: var(--color-text-light);
}
.form-msg.info {
    color: var(--color-info);
}
.form-msg.info::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    border-color: transparent;
    background-color: var(--color-info);
    color: var(--color-white);
}
.form-msg.success {
    color: var(--color-success);
}
.form-msg.success::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    border-color: transparent;
    background-color: var(--color-success);
    color: var(--color-white);
}
.form-msg.warning {
    color: var(--color-warning);
}
.form-msg.warning::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    border-color: transparent;
    background-color: var(--color-warning);
    color: var(--color-white);
}
.form-msg.error {
    color: var(--color-error);
}
.form-msg.error::before {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    border-color: transparent;
    background-color: var(--color-error);
    color: var(--color-white);
}

.form-count {
    display: flex;
    font-size: 1.4rem;
    color: var(--color-text-light);
    margin-left: auto;
}
.form-count .current {
    color: var(--color-info);
}

.form-box {
    width: 100%;
    color: var(--color-text-dark);
    border: 1px solid var(--color-border);
    background-color: var(--color-background-light);
    border-radius: var(--radius-form);
    padding: var(--padding-form);
    font-size: 1.3rem;
}
.form-box .form-box-title {
    font-size: 1.4rem;
    font-weight: 700;
    margin-bottom: var(--gap-component);
}
.form-box.info {
    color: var(--color-info);
    border-color: var(--color-info);
    background-color: var(--color-info-background);
}
.form-box.success {
    color: var(--color-success);
    border-color: var(--color-success);
    background-color: var(--color-success-background);
}
.form-box.warning {
    color: var(--color-warning);
    border-color: var(--color-warning);
    background-color: var(--color-warning-background);
}
.form-box.error {
    color: var(--color-error);
    border-color: var(--color-error);
    background-color: var(--color-error-background);
}

.form-pair {
    height: var(--size-form);
    display: flex;
    align-items: center;
    border-radius: var(--radius-form);
}
.form-pair .pair-label {
    height: 100%;
    background-color: var(--color-background-light);
    border-radius: var(--radius-form) 0 0 var(--radius-form);
    padding: var(--padding-form);
    white-space: nowrap;
    border: 1px solid var(--color-border);
    border-right-width: 0;
    color: var(--color-label);
    transition: var(--transition-duration);
}
.form-pair .pair-label.select {
    padding: 0 calc(var(--padding-form) + (var(--padding-form) / 2) + var(--size-icon)) 0 var(--padding-form);
}
.form-pair .pair-label:focus {
    border-right-width: 1px;
    border-radius: var(--radius-form);
    border-color: var(--color-primary);
    z-index: 1;
    color: var(--color-text);
}
.form-pair .pair-label:focus ~ .pair-item:first-child {
    border-left: none;
}
.form-pair .pair-text {
    height: var(--size-form);
    border: 1px solid var(--color-border);
    padding: 0 var(--padding-form);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}
.form-pair .pair-item {
    border-radius: 0;
    border-right-width: 0;
}
.form-pair .pair-item:last-child {
    border-right-width: 1px;
    border-radius: 0 var(--radius-form) var(--radius-form) 0;
}
.form-pair .pair-item:focus {
    border-right-width: 1px;
    border-radius: var(--radius-form);
    z-index: 1;
}
.form-pair .input {
    max-width: 18rem;
}
@media screen and (max-width: 767px) {
    .form-pair {
        height: auto;
    }
    .form-pair .pair-label {
        height: var(--size-form);
        min-width: 12rem;
    }
    .form-pair .pair-item {
        flex: 1;
    }
    .form-pair .input {
        max-width: 100%;
    }
    .form-pair.datepicker-group {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .form-pair.datepicker-group .select {
        grid-column: span 2;
    }
    .form-pair.datepicker-group .select.pair-label {
        border-width: 1px;
        border-radius: var(--radius-form) var(--radius-form) 0 0;
    }
    .form-pair.datepicker-group .select.pair-item {
        margin-top: -1px;
        border-radius: 0 0 var(--radius-form) var(--radius-form);
    }
    .form-pair.datepicker-group .input {
        margin-top: -1px;
    }
    .form-pair.datepicker-group .input:nth-of-type(2) {
        border-right-width: 1px;
    }
}

.form-separator {
    color: var(--color-text-light);
}

.file-upload {
    border-radius: var(--radius-form);
    background-color: var(--color-background-light);
    padding: var(--gap-section);
    border: 1px solid var(--color-border);
    border-color: var(--color-border);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--gap-layout);
    text-align: center;
    transition: var(--transition-duration);
}
.file-upload input[type=file] {
    display: none;
}
.file-upload .button {
    width: fit-content;
    cursor: pointer;
}
.file-upload .file-upload-text {
    color: var(--color-text-dark);
    transition: var(--transition-duration);
    word-break: keep-all;
}
.file-upload.drag-over {
    background-color: var(--color-primary-light);
    border-color: var(--color-primary);
    border-style: dashed;
}
.file-upload.drag-over .file-upload-text {
    color: var(--color-primary);
}

.file-list .file-list-head .file-list-count {
    font-weight: 500;
}
.file-list .file-list-head .file-list-count .current {
    font-weight: 700;
    color: var(--color-primary);
}
.file-list .file-list-content ul li {
    border: 1px solid var(--color-border);
    padding: var(--gap-layout);
    border-radius: var(--radius-form);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap-layout);
}
.file-list .file-list-content ul li .file-info {
    display: -webkit-box !important;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    word-break: break-all;
}

.form-toggle-button {
    display: inline-flex;
}
.form-toggle-button .icon::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
}

.ui-sortable-helper {
    opacity: 0.7;
}

/* ────────────────────────────────
    card
──────────────────────────────── */
.card {
    padding: var(--gap-layout);
    border-radius: var(--radius-card);
    border: 1px solid var(--color-border);
    display: flex;
    flex-direction: column;
    gap: var(--gap-layout);
    position: relative;
    transition: var(--transition-duration);
}
.card > * {
    transition: var(--transition-duration);
}
.card.loading {
    align-items: center;
    justify-content: center;
}
.card.loading > * {
    opacity: 0;
    pointer-events: none;
}
.card.loading::after {
    content: "";
    display: block;
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid var(--color-border);
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

.card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--gap-component);
}

.card-title {
    font-size: 1.8rem;
    font-weight: 600;
}
.card-title ~ .card-sub-title {
    margin-top: var(--gap-component);
}

.card-sub-title {
    color: var(--color-text-dark);
}

.card-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--gap-component);
}

/* ────────────────────────────────
    breadcrumb
──────────────────────────────── */
.breadcrumb {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-bottom: var(--gap-layout);
}
.breadcrumb li {
    font-size: 1.5rem;
    display: flex;
    align-items: center;
    gap: 0.8rem;
}
.breadcrumb li::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    font-size: 1.3rem;
    color: var(--color-text-light);
}
.breadcrumb li:last-child::after {
    display: none;
}
.breadcrumb li a {
    text-decoration: underline;
}
.breadcrumb li a:hover, .breadcrumb li a:focus {
    color: var(--color-primary);
}
.breadcrumb li span {
    color: var(--color-text-dark);
}
.breadcrumb li .icon {
    color: var(--color-text-dark);
    margin-right: -0.4rem;
}

.datepicker {
    cursor: pointer;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cg clip-path='url(%23a)'%3E%3Cpath fill='%23606060' d='M6.808 0a.84.84 0 0 1 .84.84v1.57h9.02V.85a.84.84 0 0 1 1.68 0v1.56H21.6a2.4 2.4 0 0 1 2.4 2.4V21.6A2.4 2.4 0 0 1 21.6 24H2.4A2.4 2.4 0 0 1 0 21.601V4.81a2.4 2.4 0 0 1 2.4-2.4h3.568V.84A.84.84 0 0 1 6.808 0ZM1.68 9.29v12.311a.72.72 0 0 0 .72.72h19.2a.72.72 0 0 0 .72-.72V9.307L1.68 9.29ZM8 17.543v1.999H6v-2h2Zm5 0v1.999h-2v-2h2Zm5 0v1.999h-2v-2h2ZM8 12.77v2H6v-2h2Zm5 0v2h-2v-2h2Zm5 0v2h-2v-2h2ZM5.968 4.09H2.4a.72.72 0 0 0-.72.72v2.802l20.64.016V4.81a.72.72 0 0 0-.72-.72h-3.252v1.114a.84.84 0 0 1-1.68 0V4.09h-9.02v1.104a.84.84 0 0 1-1.68 0V4.09Z'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='a'%3E%3Cpath fill='%23fff' d='M0 0h24v24H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");
    background-size: var(--size-icon-xsmall);
    background-position: center right 1.2rem;
    background-repeat: no-repeat;
    padding-right: 4rem !important;
}

.ui-datepicker {
    width: 100%;
    height: auto;
    position: relative;
    max-width: 28rem;
    background-color: var(--color-background);
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
    border-radius: var(--radius-form);
    padding: var(--gap-component);
    display: none;
}
.ui-datepicker .ui-datepicker-header {
    height: 4.8rem;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-title {
    width: 100%;
    text-align: center;
    order: 2;
    font-size: 1.5rem;
    font-weight: 500;
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-header .ui-datepicker-next {
    width: var(--size-icon) !important;
    height: var(--size-icon) !important;
    min-width: var(--size-icon) !important;
    min-height: var(--size-icon) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    overflow: hidden;
    border-radius: var(--radius-form);
    transition: var(--transition-duration);
    cursor: pointer;
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-header .ui-datepicker-next span {
    display: none;
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-prev::after,
.ui-datepicker .ui-datepicker-header .ui-datepicker-next::after {
    content: "" !important;
    display: block;
    width: var(--size-icon);
    height: var(--size-icon);
    background-repeat: no-repeat;
    background-size: var(--size-icon-small);
    background-position: center;
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-prev:hover, .ui-datepicker .ui-datepicker-header .ui-datepicker-prev:focus,
.ui-datepicker .ui-datepicker-header .ui-datepicker-next:hover,
.ui-datepicker .ui-datepicker-header .ui-datepicker-next:focus {
    background-color: var(--color-background-light);
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-prev:active,
.ui-datepicker .ui-datepicker-header .ui-datepicker-next:active {
    background-color: var(--color-background-light-active);
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-prev {
    order: 1;
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-prev::after {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23606060' d='M14.71 15.88 10.83 12l3.88-3.88a.997.997 0 1 0-1.41-1.41L8.71 11.3a.996.996 0 0 0 0 1.41l4.59 4.59c.39.39 1.02.39 1.41 0 .38-.39.39-1.03 0-1.42Z'/%3E%3C/svg%3E");
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-next {
    order: 3;
}
.ui-datepicker .ui-datepicker-header .ui-datepicker-next::after {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath fill='%23606060' d='M9.29 15.88 13.17 12 9.29 8.12a.997.997 0 0 1 1.41-1.41l4.59 4.59c.39.39.39 1.02 0 1.41L10.7 17.3a.994.994 0 0 1-1.41 0c-.38-.39-.39-1.03 0-1.42Z'/%3E%3C/svg%3E");
}

.ui-datepicker-calendar {
    width: 100%;
    position: relative;
}
.ui-datepicker-calendar tr {
    display: flex;
}
.ui-datepicker-calendar td {
    cursor: pointer;
    transition: var(--transition-duration);
}
.ui-datepicker-calendar td:hover, .ui-datepicker-calendar td:focus {
    background-color: var(--color-background-light);
}
.ui-datepicker-calendar td:active {
    background-color: var(--color-background-light-active);
}
.ui-datepicker-calendar th,
.ui-datepicker-calendar td {
    width: calc(100% / 7) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 1.5rem;
    font-weight: 400;
    border-radius: var(--radius-form);
}
.ui-datepicker-calendar th::after,
.ui-datepicker-calendar td::after {
    content: "";
    display: block;
    padding-bottom: 100%;
}
.ui-datepicker-calendar .ui-datepicker-other-month {
    pointer-events: none;
}

/* 일요일 */
.ui-datepicker-calendar > thead > tr > th:first-child,
.ui-datepicker-calendar > tbody > tr > td:first-child a {
    color: #e42d15 !important;
}

/* 토요일 */
.ui-datepicker-calendar > thead > tr > th:last-child,
.ui-datepicker-calendar > tbody > tr > td:last-child a {
    color: #0091ff !important;
}

/* ────────────────────────────────
    datepicker/theme/dark
──────────────────────────────── */
:root.theme-dark .datepicker {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cg clip-path='url(%23a)'%3E%3Cpath fill='%23b0bed1' d='M6.808 0a.84.84 0 0 1 .84.84v1.57h9.02V.85a.84.84 0 0 1 1.68 0v1.56H21.6a2.4 2.4 0 0 1 2.4 2.4V21.6A2.4 2.4 0 0 1 21.6 24H2.4A2.4 2.4 0 0 1 0 21.601V4.81a2.4 2.4 0 0 1 2.4-2.4h3.568V.84A.84.84 0 0 1 6.808 0ZM1.68 9.29v12.311a.72.72 0 0 0 .72.72h19.2a.72.72 0 0 0 .72-.72V9.307L1.68 9.29ZM8 17.543v1.999H6v-2h2Zm5 0v1.999h-2v-2h2Zm5 0v1.999h-2v-2h2ZM8 12.77v2H6v-2h2Zm5 0v2h-2v-2h2Zm5 0v2h-2v-2h2ZM5.968 4.09H2.4a.72.72 0 0 0-.72.72v2.802l20.64.016V4.81a.72.72 0 0 0-.72-.72h-3.252v1.114a.84.84 0 0 1-1.68 0V4.09h-9.02v1.104a.84.84 0 0 1-1.68 0V4.09Z'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='a'%3E%3Cpath fill='%23fff' d='M0 0h24v24H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");
}

.flatpickr {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cg clip-path='url(%23a)'%3E%3Cpath fill='%23606060' d='M6.808 0a.84.84 0 0 1 .84.84v1.57h9.02V.85a.84.84 0 0 1 1.68 0v1.56H21.6a2.4 2.4 0 0 1 2.4 2.4V21.6A2.4 2.4 0 0 1 21.6 24H2.4A2.4 2.4 0 0 1 0 21.601V4.81a2.4 2.4 0 0 1 2.4-2.4h3.568V.84A.84.84 0 0 1 6.808 0ZM1.68 9.29v12.311a.72.72 0 0 0 .72.72h19.2a.72.72 0 0 0 .72-.72V9.307L1.68 9.29ZM8 17.543v1.999H6v-2h2Zm5 0v1.999h-2v-2h2Zm5 0v1.999h-2v-2h2ZM8 12.77v2H6v-2h2Zm5 0v2h-2v-2h2Zm5 0v2h-2v-2h2ZM5.968 4.09H2.4a.72.72 0 0 0-.72.72v2.802l20.64.016V4.81a.72.72 0 0 0-.72-.72h-3.252v1.114a.84.84 0 0 1-1.68 0V4.09h-9.02v1.104a.84.84 0 0 1-1.68 0V4.09Z'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='a'%3E%3Cpath fill='%23fff' d='M0 0h24v24H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");
    background-size: var(--size-icon-xsmall);
    background-position: center right 1.2rem;
    background-repeat: no-repeat;
    padding-right: 4rem !important;
}

.flatpickr-calendar {
    color: var(--color-text);
    background-color: var(--color-background);
    font-size: 1.4rem;
    line-height: 2.4rem;
    -webkit-box-shadow: 1px 0 0 var(--color-border), -1px 0 0 var(--color-border), 0 1px 0 var(--color-border), 0 -1px 0 var(--color-border), 0 3px 13px rgba(0, 0, 0, 0.08);
    box-shadow: 1px 0 0 var(--color-border), -1px 0 0 var(--color-border), 0 1px 0 var(--color-border), 0 -1px 0 var(--color-border), 0 3px 13px rgba(0, 0, 0, 0.08);
    max-width: calc(100% - var(--gap-layout) * 2);
    margin-top: 0.4rem;
}

span.flatpickr-weekday {
    color: var(--color-text);
}

.flatpickr-months {
    align-items: center;
}

.flatpickr-months .flatpickr-month {
    color: var(--color-text);
    align-items: center;
    display: flex;
    height: 6rem;
}

.flatpickr-day {
    color: var(--color-text);
}

.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
    top: auto;
}

.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg {
    width: 1.4rem;
    height: 1.4rem;
}

.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay,
.flatpickr-day.notAllowed,
.flatpickr-day.notAllowed.prevMonthDay,
.flatpickr-day.notAllowed.nextMonthDay {
    color: var(--color-text-light);
}

.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
    color: var(--color-text);
    fill: var(--color-text);
}

.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
    fill: var(--color-primary);
}

.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.inRange,
.flatpickr-day.startRange.inRange,
.flatpickr-day.endRange.inRange,
.flatpickr-day.selected:focus,
.flatpickr-day.startRange:focus,
.flatpickr-day.endRange:focus,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover,
.flatpickr-day.selected.prevMonthDay,
.flatpickr-day.startRange.prevMonthDay,
.flatpickr-day.endRange.prevMonthDay,
.flatpickr-day.selected.nextMonthDay,
.flatpickr-day.startRange.nextMonthDay,
.flatpickr-day.endRange.nextMonthDay {
    color: var(--color-primary-contrast);
    background-color: var(--color-primary);
}

.flatpickr-current-month {
    font-size: 1.6rem;
    height: auto;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.6rem;
}

.flatpickr-month .numInputWrapper span.arrowUp {
    top: 50%;
    transform: translateY(-50%);
}

.flatpickr-month .numInputWrapper span.arrowDown {
    top: 50%;
    transform: translateY(-50%);
}

.flatpickr-current-month .numInputWrapper span.arrowUp:after {
    border-bottom-color: var(--color-icon);
    top: -0.15rem;
}

.flatpickr-current-month .numInputWrapper span.arrowDown:after {
    border-top-color: var(--color-icon);
    top: auto;
    bottom: -0.125rem;
}

.flatpickr-monthDropdown-months {
    background-color: var(--color-background) !important;
}

.flatpickr-day.inRange,
.flatpickr-day.prevMonthDay.inRange,
.flatpickr-day.nextMonthDay.inRange,
.flatpickr-day.today.inRange,
.flatpickr-day.prevMonthDay.today.inRange,
.flatpickr-day.nextMonthDay.today.inRange,
.flatpickr-day:hover,
.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover,
.flatpickr-day:focus,
.flatpickr-day.prevMonthDay:focus,
.flatpickr-day.nextMonthDay:focus {
    background: var(--color-background-light-active);
    border-color: var(--color-background-light-active);
}

.flatpickr-day.today {
    border-color: var(--color-primary);
}

.flatpickr-day.today:hover,
.flatpickr-day.today:focus {
    border-color: var(--color-primary);
    background: var(--color-primary);
}

.flatpickr-rContainer,
.flatpickr-days,
.dayContainer {
    width: 100%;
    min-width: auto;
    background-color: var(--color-background);
}

.flatpickr-calendar.arrowTop:before {
    border-bottom-color: var(--color-border);
}

.flatpickr-calendar.arrowTop:after {
    border-bottom-color: var(--color-background);
}

.flatpickr-current-month .flatpickr-monthDropdown-months {
    font-weight: 400;
    appearance: none;
    outline: none;
    border-radius: 0;
    color: var(--color-text);
    background-color: var(--color-background);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23606060' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E") !important;
    background-position: center right !important;
    background-repeat: no-repeat !important;
    background-size: var(--size-icon-small) !important;
    padding-right: 2rem;
}
.flatpickr-current-month .flatpickr-monthDropdown-months::-ms-expand {
    display: none;
}

.flatpickr-current-month .numInputWrapper {
    width: 6rem;
    display: flex;
    align-items: center;
    order: -1;
    background-color: var(--color-background) !important;
}
.flatpickr-current-month .numInputWrapper::after {
    content: "년";
    display: inline-block;
    position: absolute;
    left: 4rem;
}

.flatpickr-current-month input.cur-year {
    width: 4rem;
    background-color: var(--color-background);
    padding: 0;
    font-weight: 400;
}

.flatpickr-month .numInputWrapper span {
    border: none;
    opacity: 1;
    padding: 0;
    width: auto;
}

.flatpickr-month .numInputWrapper span:hover {
    background-color: transparent;
}

.flatpickr-day.inRange {
    box-shadow: -5px 0 0 var(--color-background-light-active), 5px 0 0 var(--color-background-light-active);
}

.flatpickr-day.selected.startRange + .endRange:not(:nth-child(7n+1)),
.flatpickr-day.startRange.startRange + .endRange:not(:nth-child(7n+1)),
.flatpickr-day.endRange.startRange + .endRange:not(:nth-child(7n+1)) {
    box-shadow: -10px 0 0 var(--color-primary);
}

.timepicker {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' viewBox='0 0 24 24'%3E%3Cg clip-path='url(%23a)'%3E%3Cpath stroke='%23606060' stroke-width='1.5' d='M12 5.23V12l5.077 5.077M23 12a11 11 0 1 1-22 0 11 11 0 0 1 22 0Z'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='a'%3E%3Cpath fill='%23fff' d='M0 0h24v24H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");
    background-size: var(--size-icon-xsmall);
    background-position: center right 1.2rem;
    background-repeat: no-repeat;
    padding-right: 4rem !important;
}
.timepicker:read-only {
    background-color: var(--color-background) !important;
}

/* ────────────────────────────────
    flatpickr/theme/dark
──────────────────────────────── */
:root.theme-dark .flatpickr {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cg clip-path='url(%23a)'%3E%3Cpath fill='%23b0bed1' d='M6.808 0a.84.84 0 0 1 .84.84v1.57h9.02V.85a.84.84 0 0 1 1.68 0v1.56H21.6a2.4 2.4 0 0 1 2.4 2.4V21.6A2.4 2.4 0 0 1 21.6 24H2.4A2.4 2.4 0 0 1 0 21.601V4.81a2.4 2.4 0 0 1 2.4-2.4h3.568V.84A.84.84 0 0 1 6.808 0ZM1.68 9.29v12.311a.72.72 0 0 0 .72.72h19.2a.72.72 0 0 0 .72-.72V9.307L1.68 9.29ZM8 17.543v1.999H6v-2h2Zm5 0v1.999h-2v-2h2Zm5 0v1.999h-2v-2h2ZM8 12.77v2H6v-2h2Zm5 0v2h-2v-2h2Zm5 0v2h-2v-2h2ZM5.968 4.09H2.4a.72.72 0 0 0-.72.72v2.802l20.64.016V4.81a.72.72 0 0 0-.72-.72h-3.252v1.114a.84.84 0 0 1-1.68 0V4.09h-9.02v1.104a.84.84 0 0 1-1.68 0V4.09Z'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='a'%3E%3Cpath fill='%23fff' d='M0 0h24v24H0z'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E") !important;
}
:root.theme-dark .flatpickr-current-month .flatpickr-monthDropdown-months {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23b0bed1' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 10 5 5 5-5'/%3E%3C/svg%3E") !important;
}

/* ────────────────────────────────
    chart
──────────────────────────────── */
.chart-container {
    width: 100%;
    height: auto;
    position: relative;
    height: 100%;
    overflow: auto;
}
.chart-container::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.chart-container::-webkit-scrollbar-track {
    border-radius: var(--radius);
    background-color: #78788030;
}
.chart-container::-webkit-scrollbar-thumb {
    border-radius: var(--radius);
    background: #78788030;
}
.chart-container::-webkit-scrollbar-thumb:hover {
    background: #78788050;
}
.chart-container::-webkit-scrollbar-thumb:active {
    background: #78788070;
}
.chart-container::-webkit-scrollbar-button {
    display: none;
}

.chart-canvas {
    width: 100%;
    height: 100%;
    position: relative;
}
.chart-canvas.doughnut {
    width: 100% !important;
    max-height: none;
    height: auto;
}
.chart-canvas.doughnut::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    padding-bottom: 100%;
}
.chart-canvas.doughnut .chart {
    position: absolute;
    left: 0;
    top: 0;
}
@media screen and (max-width: 767px) {
    .chart-canvas {
        width: 701px !important;
    }
}
@media screen and (max-width: 519px) {
    .chart-canvas {
        width: 453px !important;
    }
}

.chart {
    width: 100% !important;
    height: 100% !important;
}

/* ────────────────────────────────
    toast
──────────────────────────────── */
.toast-container {
    position: fixed;
    top: 0;
    right: 0;
    z-index: var(--z-index-loading);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: var(--gap-component);
}
.toast-container .toast {
    width: 32rem;
    min-height: calc(var(--size-icon) + var(--gap-layout) + var(--gap-layout));
    background-color: var(--color-background);
    transition: var(--transition-duration);
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
    padding: var(--gap-layout);
    border-radius: var(--radius);
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: var(--transition-duration);
    transform: translateX(32rem);
    margin-right: var(--gap-layout);
}
.toast-container .toast:first-child {
    margin-top: var(--gap-layout);
}
.toast-container .toast .toast-icon {
    width: calc(var(--size-icon));
    height: calc(var(--size-icon));
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    position: absolute;
    left: var(--gap-layout);
    background-color: var(--color-background-light);
}
.toast-container .toast .toast-icon::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
    font-size: 1rem;
}
.toast-container .toast .toast-title {
    font-size: 1.5rem;
    font-weight: 700;
    padding-left: calc(var(--size-icon) + var(--gap-layout));
}
.toast-container .toast .toast-sub-title {
    font-size: 1.4rem;
    padding-left: calc(var(--size-icon) + var(--gap-layout));
}
.toast-container .toast.info .toast-icon {
    background-color: var(--color-info);
}
.toast-container .toast.info .toast-icon::after {
    content: "";
    color: var(--color-white);
}
.toast-container .toast.success .toast-icon {
    background-color: var(--color-success);
}
.toast-container .toast.success .toast-icon::after {
    content: "";
    color: var(--color-white);
}
.toast-container .toast.warning .toast-icon {
    background-color: var(--color-warning);
}
.toast-container .toast.warning .toast-icon::after {
    content: "";
    color: var(--color-white);
}
.toast-container .toast.error .toast-icon {
    background-color: var(--color-error);
}
.toast-container .toast.error .toast-icon::after {
    content: "";
    color: var(--color-white);
}
.toast-container .toast.active {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0);
}
.toast-container .toast.hidden {
    opacity: 0;
    pointer-events: none;
    transform: translateX(32rem);
}

/* ────────────────────────────────
    panel
──────────────────────────────── */
.panel {
    width: 100%;
    max-width: var(--size-panel);
    height: 100%;
    position: fixed;
    right: calc(var(--size-panel) * -1);
    top: 0;
    background-color: var(--color-background);
    border-left: 1px solid var(--color-border-snb);
    padding-top: var(--size-header-height);
    opacity: 0;
    pointer-events: none;
    transition: var(--transition-duration);
    z-index: var(--z-index-panel);
}
.panel .panel-layer {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    display: block;
    background-color: rgba(var(--color-background-contrast), 0.2);
    opacity: 0;
    pointer-events: none;
    transition: var(--transition-duration);
}
.panel .panel-container {
    height: 100%;
    display: flex;
    flex-direction: column;
    overflow: auto;
}
.panel .panel-container::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.panel .panel-container::-webkit-scrollbar-track {
    border-radius: var(--radius);
    background-color: #78788030;
}
.panel .panel-container::-webkit-scrollbar-thumb {
    border-radius: var(--radius);
    background: #78788030;
}
.panel .panel-container::-webkit-scrollbar-thumb:hover {
    background: #78788050;
}
.panel .panel-container::-webkit-scrollbar-thumb:active {
    background: #78788070;
}
.panel .panel-container::-webkit-scrollbar-button {
    display: none;
}
.panel .panel-container::-webkit-scrollbar {
    width: 0;
    height: 0;
}
.panel .panel-head {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap-layout);
    position: sticky;
    left: 0;
    top: 0;
    background-color: var(--color-background);
    padding: var(--gap-component) var(--gap-layout);
    border-bottom: 1px solid var(--color-border-light);
    transition: var(--transition-duration);
}
.panel .panel-head .button-group {
    gap: 0.1rem;
}
.panel .panel-head .panel-view-change-button .icon::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
}
.panel .panel-head .panel-close-button .icon::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
}
.panel .panel-title {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-size: 1.6rem;
    font-weight: 700;
}
.panel .panel-body {
    flex: 1;
    padding: var(--gap-layout);
    background-color: var(--color-background);
}
.panel .panel-footer {
    position: sticky;
    left: 0;
    bottom: 0;
    background-color: var(--color-background);
    padding: var(--gap-layout);
    display: flex;
    flex-direction: column;
    gap: var(--gap-component);
    border-top: 1px solid var(--color-border-light);
    transition: var(--transition-duration);
}

/* ────────────────────────────────
    body/panel-open/panel
──────────────────────────────── */
body.panel-open .panel {
    right: 0;
    opacity: 1;
    pointer-events: auto;
}
body.panel-overlay .panel {
    max-width: 100%;
    right: 50%;
    transform: translateX(50%);
    z-index: var(--z-index-modal);
    padding: var(--gap-layout);
    background-color: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 1;
    pointer-events: auto;
    transition: none;
}
body.panel-overlay .panel .panel-container {
    width: 100%;
    height: auto;
    position: relative;
    overflow: auto;
    overflow-x: hidden;
    overscroll-behavior: none;
    max-height: 100%;
    max-width: 56rem;
    background-color: var(--color-background);
    border-radius: var(--radius-form);
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
}
body.panel-overlay .panel .panel-container::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
body.panel-overlay .panel .panel-container::-webkit-scrollbar-track {
    border-radius: var(--radius);
    background-color: #78788030;
}
body.panel-overlay .panel .panel-container::-webkit-scrollbar-thumb {
    border-radius: var(--radius);
    background: #78788030;
}
body.panel-overlay .panel .panel-container::-webkit-scrollbar-thumb:hover {
    background: #78788050;
}
body.panel-overlay .panel .panel-container::-webkit-scrollbar-thumb:active {
    background: #78788070;
}
body.panel-overlay .panel .panel-container::-webkit-scrollbar-button {
    display: none;
}
body.panel-overlay .panel .panel-head .panel-view-change-button .icon::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
}
body.panel-overlay .panel .panel-head .panel-close-button .icon::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
}
body.panel-overlay .panel .panel-layer {
    opacity: 1;
    pointer-events: auto;
}
body.panel-overlay .panel .panel-footer .button-group {
    justify-content: flex-end;
}
body.panel-overlay .panel .panel-footer .button-group .button {
    flex: 0;
}
body.panel-overlay .panel .panel-control {
    display: none;
}

/* ────────────────────────────────
    body/mq-laptop(min)/panel
──────────────────────────────── */
@media screen and (min-width: 1240px) {
    body.panel-open .main {
        padding-right: calc(var(--size-panel) + var(--gap-component));
    }
}

/* ────────────────────────────────
    calendar
──────────────────────────────── */
.card-calendar {
    padding-bottom: 0;
    gap: 0;
}
.card-calendar .card-head {
    align-items: center;
}

.calendar {
    width: calc(100% + calc(var(--gap-layout) * 2));
    margin-left: calc(-1 * var(--gap-layout));
    font-size: 1.3rem;
    margin-top: 1rem;
    display: flex;
    flex-direction: column;
    position: relative;
}
.calendar.border-none .calendar-head .day,
.calendar.border-none .calendar-grid .day {
    border: none;
}
.calendar.border-none .calendar-head .day:hover,
.calendar.border-none .calendar-grid .day:hover {
    background-color: transparent;
}
.calendar.border-none .calendar-head .day:hover .day-content .date,
.calendar.border-none .calendar-grid .day:hover .day-content .date {
    background-color: transparent;
}
.calendar.border-none .calendar-head .day.day-other,
.calendar.border-none .calendar-grid .day.day-other {
    background-color: transparent;
}
.calendar.border-none .calendar-head .day.day-other .date,
.calendar.border-none .calendar-grid .day.day-other .date {
    background-color: transparent;
}
.calendar.border-none .calendar-head .day .day-content .date::before,
.calendar.border-none .calendar-grid .day .day-content .date::before {
    display: none;
}
.calendar.border-none .calendar-head {
    border-top: 1px solid var(--color-border-light);
    border-bottom: 1px solid var(--color-border-light);
}
.calendar.list .calendar-head {
    display: none;
}
.calendar.list .calendar-grid {
    grid-template-columns: none;
}
.calendar.list .calendar-grid .day::after {
    display: none;
}
.calendar.list .calendar-grid .day .day-content {
    height: auto;
    position: relative;
    left: auto;
    top: auto;
    overflow: hidden;
}
.calendar.full .calendar-grid {
    flex: auto;
    min-height: 50rem;
}
.calendar.full .calendar-grid .day::after {
    display: none;
}
.calendar.full .calendar-grid .day .day-content {
    position: relative;
    left: auto;
    top: auto;
    overflow: hidden;
}
.calendar.full .calendar-grid .day .day-content .event {
    position: relative;
    height: 100%;
    gap: 0.4rem;
}
.calendar.full .calendar-grid .day .day-content .event .badge {
    padding: 0.4rem 0.6rem;
}
.calendar.full .calendar-grid .day .day-content .more {
    color: var(--color-text-light);
}
.calendar.full .calendar-grid .day .day-content .more:hover {
    color: var(--color-primary);
}

.calendar-head,
.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.calendar-head {
    border-top: 1px solid var(--color-border);
}
.calendar-head .day {
    text-align: center;
    border-left: 1px solid var(--color-border);
    padding: var(--gap-component);
    font-weight: 500;
    color: var(--color-text-dark);
}
.calendar-head .day:first-child {
    border-left-width: 0;
}
@media screen and (max-width: 767px) {
    .calendar-head {
        border-top-width: 0;
    }
    .calendar-head .day {
        border: none;
    }
}

.calendar-grid {
    flex: 1;
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    grid-auto-rows: 1fr;
    /* 각 행 균등 */
}
.calendar-grid .day {
    width: 100%;
    position: relative;
    border: 1px solid var(--color-border);
    border-bottom-width: 0;
    border-right-width: 0;
    cursor: pointer;
    overflow: hidden;
}
.calendar-grid .day:nth-of-type(7n + 1) {
    border-left-width: 0;
}
.calendar-grid .day::after {
    content: "";
    display: block;
    padding-bottom: 100%;
}
.calendar-grid .day .day-content {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    overflow: auto;
    overflow-y: auto;
    padding: var(--gap-component);
}
.calendar-grid .day .day-content::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.calendar-grid .day .day-content::-webkit-scrollbar-track {
    border-radius: var(--radius);
    background-color: #78788030;
}
.calendar-grid .day .day-content::-webkit-scrollbar-thumb {
    border-radius: var(--radius);
    background: #78788030;
}
.calendar-grid .day .day-content::-webkit-scrollbar-thumb:hover {
    background: #78788050;
}
.calendar-grid .day .day-content::-webkit-scrollbar-thumb:active {
    background: #78788070;
}
.calendar-grid .day .day-content::-webkit-scrollbar-button {
    display: none;
}
.calendar-grid .day .day-content::-webkit-scrollbar {
    display: none;
}
.calendar-grid .day .day-content .date {
    position: sticky;
    left: 0;
    top: 0;
    background-color: var(--color-background);
    margin-bottom: calc(var(--gap-component) / 2);
    font-weight: 500;
    color: var(--color-text-dark);
}
.calendar-grid .day .day-content .date::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-color: var(--color-background);
    position: absolute;
    left: 0;
    top: -100%;
    z-index: -1;
}
.calendar-grid .day .day-content .date.today span {
    width: 2.4rem;
    text-align: center;
    color: var(--color-background);
    z-index: 1;
}
.calendar-grid .day .day-content .date.today span::after {
    content: "";
    display: block;
    width: 2.4rem;
    height: 2.4rem;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: var(--color-text);
    border-radius: 50%;
    z-index: -1;
}
.calendar-grid .day .day-content .event {
    display: flex;
    flex-direction: column;
    gap: calc(var(--gap-component) / 2);
}
.calendar-grid .day .day-content .event .badge {
    white-space: normal;
    word-break: break-all;
}
.calendar-grid .day .day-content .event .badge.start {
    width: calc(100% + calc(var(--gap-component) * 2));
}
.calendar-grid .day .day-content .event .badge.middle {
    width: calc(100% + calc(var(--gap-component) * 2));
    transform: translateX(calc(-1 * var(--gap-component)));
    border-left: none;
    border-right: none;
    border-radius: 0;
    text-indent: -9999px;
}
.calendar-grid .day .day-content .event .badge.end {
    width: calc(100% + calc(var(--gap-component) * 2));
    transform: translateX(calc(-2 * var(--gap-component)));
    text-indent: -9999px;
}
.calendar-grid .day:hover {
    background-color: var(--color-background-light);
}
.calendar-grid .day:hover .day-content .date {
    background-color: var(--color-background-light);
}
.calendar-grid .day:hover .day-content .date::before {
    background-color: var(--color-background-light);
}
.calendar-grid .day.day-other {
    background-color: var(--color-background-light);
}
.calendar-grid .day.day-other .day-content .date {
    opacity: 0.5;
    background-color: var(--color-background-light);
}
.calendar-grid .day.day-other .day-content .date::before {
    background-color: var(--color-background-light);
}
@media screen and (max-width: 767px) {
    .calendar-grid .day {
        border-color: var(--color-border-light);
        border-left-width: 0;
    }
    .calendar-grid .day .day-content {
        padding-top: var(--gap-component);
        padding-bottom: 0;
    }
    .calendar-grid .day .day-content .date {
        text-align: center;
    }
    .calendar-grid .day .day-content .date.today span::after {
        left: 50%;
        transform: translate(-50%, -50%);
    }
    .calendar-grid .day .day-content .event {
        flex-direction: row;
        align-items: center;
        justify-content: center;
        gap: 0.3rem;
    }
    .calendar-grid .day .day-content .event .badge {
        width: 1rem;
        height: 1rem;
        padding: 0;
        font-size: 0;
    }
    .calendar-grid .day.day-other {
        background-color: var(--color-background);
    }
    .calendar-grid .day.day-other .day-content .date {
        background-color: var(--color-background);
    }
    .calendar-grid .day.day-other .day-content .date::before {
        display: none;
    }
}

.calendar-button-group .prev::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon-light) !important;
    display: inline-block;
}
.calendar-button-group .next::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon-light) !important;
    display: inline-block;
}

/* ────────────────────────────────
    fullCalendar
──────────────────────────────── */
.full-calendar {
    width: calc(100% + calc(var(--gap-layout) * 2));
    height: 100%;
    margin-left: calc(-1 * var(--gap-layout));
    position: relative;
}
.full-calendar table {
    width: 100%;
    height: 100%;
    table-layout: fixed;
}
.full-calendar table.table2 {
    position: absolute;
    left: 0;
    top: 0;
}
.full-calendar td {
    vertical-align: top;
    overflow: hidden;
    padding: var(--gap-component);
}

/* ────────────────────────────────
    ckeditor
──────────────────────────────── */
.cke_notifications_area {
    display: none !important;
}

.cke_contents {
    padding: 1rem !important;
}

.cke_top,
.cke_bottom {
    background-color: #fff !important;
}

/* ────────────────────────────────
    universepay/login
──────────────────────────────── */
.login-container {
    width: 100%;
    height: auto;
    position: relative;
    min-height: 100%;
    padding: var(--gap-layout);
    background-color: var(--color-primary-light);
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-content {
    width: 100%;
    height: auto;
    position: relative;
    max-width: 60rem;
    background-color: var(--color-background);
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
    border-radius: 1.2rem;
    padding: 6rem;
}
.login-content .logo {
    font-size: 2rem;
    margin: 0 auto;
}
.login-content .input,
.login-content .button {
    height: 5.6rem;
}
@media screen and (max-width: 767px) {
    .login-content {
        padding: 6rem 4rem;
    }
}

/* ────────────────────────────────
    universepay/dashboard
──────────────────────────────── */
@media screen and (max-width: 1499px) {
    .dashboard-container .grid-item.grid-item-column-3 {
        grid-column: span 6;
    }
    .dashboard-container .grid-item.grid-item-column-6 {
        grid-column: span 12;
    }
}
@media screen and (max-width: 519px) {
    .dashboard-container .grid-item.grid-item-column-3 {
        grid-column: span 12;
    }
}

/* ────────────────────────────────
    achimnara
──────────────────────────────── */
.ac-header {
    width: 100%;
    position: fixed;
    left: 0;
    top: 0;
    background-color: #fff;
    border-bottom: 1px solid #e8e8e8;
    z-index: 10;
}
.ac-header .ac-header-container {
    width: 100%;
    max-width: 1720px;
    height: 9rem;
    position: relative;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 2rem;
}
.ac-header .ac-logo img {
    width: 10rem;
    min-width: 10rem;
}
.ac-header .ac-gnb {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}
.ac-header .ac-gnb ul {
    display: flex;
    align-items: center;
    gap: 60px;
}
.ac-header .ac-gnb ul::after {
    display: none;
}
.ac-header .ac-gnb ul li a {
    font-size: 18px;
    font-weight: 500;
    color: #333;
}
.ac-header .ac-gnb ul li a:hover {
    color: #38dc8e;
}
@media screen and (max-width: 1239px) {
    .ac-header .ac-gnb {
        display: none;
    }
}
.ac-header .ac-header-util {
    display: flex;
    align-items: center;
    gap: var(--gap-component);
}
.ac-header .ac-header-util a {
    font-size: 16px;
    color: #666;
    display: flex;
    align-items: center;
    gap: var(--gap-component);
}
.ac-header .ac-header-util a::after {
    content: "|";
    display: block;
    color: #ddd;
    font-size: 14px;
}
.ac-header .ac-header-util a:last-child::after {
    display: none;
}
.ac-header .ac-header-util a:hover {
    color: #333;
}
@media screen and (max-width: 1239px) {
    .ac-header .ac-header-util {
        display: none;
    }
}
@media screen and (min-width: 1240px) {
    .ac-header .menu-toggle-button {
        display: none;
    }
}

.ac-main {
    padding-top: 9rem;
    margin-top: -1px;
}

@media screen and (min-width: 1240px) {
    .ac-snb {
        left: auto;
        right: calc(var(--size-snb-width) * -1);
    }
}

.ac-event-container .ac-event-head img {
    width: 100%;
    margin: 0 auto;
}
.ac-event-container .ac-event-head .ac-event-banner .ac-event-banner-img.mo {
    display: none;
}
@media screen and (max-width: 767px) {
    .ac-event-container .ac-event-head .ac-event-banner .ac-event-banner-img.pc {
        display: none;
    }
    .ac-event-container .ac-event-head .ac-event-banner .ac-event-banner-img.mo {
        display: block;
    }
}
.ac-event-container .ac-event-body {
    margin-bottom: -46px;
    background-color: #074f5e;
}
@media screen and (max-width: 1679px) {
    .ac-event-container .ac-event-body {
        margin-bottom: -166px;
    }
}
@media screen and (max-width: 1239px) {
    .ac-event-container .ac-event-body {
        margin-bottom: -60px;
    }
}
@media screen and (max-width: 767px) {
    .ac-event-container .ac-event-body {
        margin-bottom: 0;
        background-color: #fff !important;
    }
}
.ac-event-container .ac-event-wrap {
    transform: translateY(-166px);
}
@media screen and (max-width: 1239px) {
    .ac-event-container .ac-event-wrap {
        transform: translateY(-60px);
    }
}
@media screen and (max-width: 767px) {
    .ac-event-container .ac-event-wrap {
        transform: translateY(0);
    }
}
.ac-event-container .ac-event-tab {
    width: 100%;
    max-width: 1680px;
    margin: 0 auto;
    display: flex;
    gap: clamp(0px, 0.417vw, 8px);
}
.ac-event-container .ac-event-tab a {
    height: clamp(50px, 4.688vw, 90px);
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-family: "Paperlogy";
    font-size: clamp(12px, 1.146vw, 22px);
    font-weight: 600;
    color: #787878;
    background-color: #fff;
    border-radius: 2rem 2rem 0 0;
    padding: 0 1rem;
    transition: all 0.4s;
}
.ac-event-container .ac-event-tab a span {
    display: -webkit-box !important;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    word-break: break-all;
    word-break: keep-all;
}
.ac-event-container .ac-event-tab a:hover {
    color: #fff;
    background-color: #265b43;
}
.ac-event-container .ac-event-tab a.active {
    font-weight: 800;
    color: #fff;
    background-color: #265b43;
}
@media screen and (max-width: 767px) {
    .ac-event-container .ac-event-tab {
        gap: 0;
    }
    .ac-event-container .ac-event-tab a {
        border-radius: 0;
        border-right: 1px solid #eee;
    }
    .ac-event-container .ac-event-tab a:last-child, .ac-event-container .ac-event-tab a:hover, .ac-event-container .ac-event-tab a.active {
        border-color: transparent;
    }
}
.ac-event-container .ac-event-content {
    width: 100%;
    max-width: 1680px;
    margin: 0 auto;
}
.ac-event-container .ac-event-content .ac-event-content-img {
    width: 100%;
    height: auto;
    position: relative;
}
.ac-event-container .ac-event-content .ac-event-content-img img {
    width: 100%;
}
.ac-event-container .ac-event-content .ac-event-content-img.mo {
    display: none;
}
@media screen and (max-width: 767px) {
    .ac-event-container .ac-event-content .ac-event-content-img.pc {
        display: none;
    }
    .ac-event-container .ac-event-content .ac-event-content-img.mo {
        display: block;
    }
}
.ac-event-container .ac-event-notice {
    width: 100%;
    max-width: 1680px;
    margin: 0 auto;
    padding: 6.85rem 2rem;
    color: #fff;
    background-color: #0eba6d;
    display: flex;
    align-items: center;
    justify-content: center;
}
.ac-event-container .ac-event-notice .ac-event-notice-title {
    width: 169px;
    text-align: center;
    font-size: clamp(14.4px, 0.938vw, 18px);
    font-weight: 600;
}
.ac-event-container .ac-event-notice .ac-event-notice-content {
    font-size: clamp(12.8px, 0.833vw, 16px);
    font-weight: 500;
    border-left: 1px solid #ffffff20;
    padding-left: 4rem;
}
@media screen and (max-width: 767px) {
    .ac-event-container .ac-event-notice {
        flex-direction: column;
        gap: 2rem;
        padding: 5rem 2rem;
    }
    .ac-event-container .ac-event-notice .ac-event-notice-title {
        width: auto;
    }
    .ac-event-container .ac-event-notice .ac-event-notice-content {
        padding-left: 0;
        border-left: none;
    }
}

.ac-footer {
    width: 100%;
    position: relative;
    padding: 11rem 0;
    background: linear-gradient(90deg, #e72718, #ef3b24, #f18a5f);
}
.ac-footer .ac-footer-container {
    width: 100%;
    max-width: 1720px;
    margin: 0 auto;
    padding: 0 2rem;
    display: flex;
    flex-direction: column;
}
.ac-footer .ac-footer-container .ac-footer-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
}
.ac-footer .ac-footer-container .ac-footer-link .ac-footer-site-link {
    display: flex;
    gap: 2.3rem;
}
.ac-footer .ac-footer-container .ac-footer-link .ac-footer-site-link a {
    font-size: 1.5rem;
    color: #fff;
}
.ac-footer .ac-footer-container .ac-footer-link .ac-footer-sns-link {
    display: flex;
    align-items: center;
    gap: 2rem;
}
.ac-footer .ac-footer-container .ac-footer-link .ac-footer-sns-link a {
    width: 4rem;
    height: 4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-color: #fff;
    border-radius: 50%;
}
.ac-footer .ac-footer-container .ac-footer-link .ac-footer-sns-link a img {
    width: 2.6rem;
    height: 2.6rem;
}
.ac-footer .ac-footer-container .ac-footer-content {
    margin-top: 5rem;
    display: flex;
    gap: 5rem;
}
.ac-footer .ac-footer-container .ac-footer-content .ac-footer-logo img {
    width: 10rem;
    min-width: 10rem;
}
.ac-footer .ac-footer-container .ac-footer-content .ac-footer-info p {
    line-height: 2;
    font-size: 1.5rem;
    color: #333;
}
.ac-footer .ac-footer-container .ac-footer-content .ac-footer-info p span {
    font-size: 1.2rem;
    margin: 0 0.5rem 0.5rem;
    vertical-align: middle;
    line-height: 1.5;
}
@media screen and (max-width: 767px) {
    .ac-footer {
        padding: 8rem 0;
    }
    .ac-footer .ac-footer-container {
        gap: 5rem;
    }
    .ac-footer .ac-footer-container .ac-footer-link {
        order: 2;
        flex-direction: column;
        align-items: flex-start;
    }
    .ac-footer .ac-footer-container .ac-footer-content {
        order: 1;
        margin-top: 0;
        flex-direction: column;
    }
}

.ac-header-fixed-item-group {
    position: fixed;
    right: var(--gap-layout);
    bottom: 0;
    opacity: 0;
    pointer-events: none;
    display: flex;
    flex-direction: column;
    gap: var(--gap-component);
    transition: var(--transition-duration);
}
.ac-header-fixed-item-group button {
    width: 5rem;
    height: 5rem;
    border-radius: 50%;
    box-shadow: 0 0 10px rgba(var(--color-background-contrast), 0.1);
    transition: var(--transition-duration);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-color: var(--color-background);
}
.ac-header-fixed-item-group button.top-button::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
}
.ac-header-fixed-item-group button.link-button::after {
    content: "";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: var(--font-base-size);
    color: var(--color-icon);
    display: inline-block;
}
.ac-header-fixed-item-group button::after {
    font-size: 1.8rem !important;
    color: #333 !important;
    transition: var(--transition-duration);
}
.ac-header-fixed-item-group button:hover {
    border-color: transparent;
    background-color: #f18a5f;
}
.ac-header-fixed-item-group button:hover::after {
    color: #fff !important;
}
.ac-header-fixed-item-group.active {
    opacity: 1;
    pointer-events: auto;
    bottom: var(--gap-layout);
}

.ac-mypage-container {
    width: 100%;
    max-width: 110rem;
    margin: 10rem auto 20rem;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10rem;
}
@media screen and (max-width: 1239px) {
    .ac-mypage-container {
        max-width: none;
        padding: 0 2rem;
    }
}
@media screen and (max-width: 767px) {
    .ac-mypage-container {
        flex-direction: column;
        margin: 4rem auto 12rem;
        gap: 6rem;
    }
    .ac-mypage-container .ac-mypage-nav {
        width: 100%;
        min-width: auto;
    }
    .ac-mypage-container .ac-mypage-content .ac-mypage-content-body {
        margin-top: 2rem;
    }
}

.ac-mypage-nav {
    width: 25rem;
    min-width: 25rem;
    border-radius: 1rem;
    overflow: hidden;
}
.ac-mypage-nav .ac-mypage-nav-head {
    padding: 3rem 2rem 5rem;
    background: url("../images/projects/achimnara/bg_symbol.png") no-repeat #39db8e right -3rem top 4rem;
    color: #fff;
}
.ac-mypage-nav .ac-mypage-nav-head p {
    font-size: 1.3rem;
}
.ac-mypage-nav .ac-mypage-nav-head h1 {
    font-size: 2.4rem;
    font-weight: 700;
}
.ac-mypage-nav .ac-mypage-nav-body {
    padding: 3rem 2rem;
    border: 1px solid #eee;
}
.ac-mypage-nav .ac-mypage-nav-body ul li a {
    color: #666;
    display: block;
    padding: 1rem 0;
    font-size: 1.6rem;
}
.ac-mypage-nav .ac-mypage-nav-body ul li a:hover {
    color: #333;
}
.ac-mypage-nav .ac-mypage-nav-body ul li a.active {
    color: #39db8e;
    font-weight: 800;
}

.ac-mypage-content {
    width: 100%;
}
.ac-mypage-content .ac-mypage-content-head {
    display: flex;
    justify-content: space-between;
    gap: 2rem;
}
.ac-mypage-content .ac-mypage-content-head h2 {
    font-size: 3.4rem;
    font-weight: 700;
    color: #333;
}
.ac-mypage-content .ac-mypage-content-head .button {
    width: 12rem;
    height: 5.6rem;
    font-size: 1.6rem;
}
.ac-mypage-content .ac-mypage-content-body {
    border-top: 2px solid #333;
    margin-top: 5rem;
}
.ac-mypage-content .ac-mypage-content-body .table {
    font-size: 1.6rem;
    color: #666;
    text-align: center;
}
.ac-mypage-content .ac-mypage-content-body .table th,
.ac-mypage-content .ac-mypage-content-body .table td {
    padding: 2.4rem 1.2rem;
}
.ac-mypage-content .ac-mypage-content-body .table th {
    background-color: var(--color-background);
}
.ac-mypage-content .ac-mypage-content-body .table td a:hover {
    color: #333;
    text-decoration: underline;
}
.ac-mypage-content .ac-mypage-content-body .table .badge {
    font-size: 1.4rem;
}
.ac-mypage-content .ac-mypage-content-body .table-bottom {
    margin-top: 6rem;
}
.ac-mypage-content .ac-mypage-content-body .pagination button {
    color: #666;
}
.ac-mypage-content .ac-mypage-content-body .pagination button:hover, .ac-mypage-content .ac-mypage-content-body .pagination button:focus {
    background-color: #38dc8e10;
}
.ac-mypage-content .ac-mypage-content-body .pagination button:active {
    color: #38dc8e;
}
.ac-mypage-content .ac-mypage-content-body .pagination button.active {
    color: #fff;
    background-color: #38dc8e;
}
.ac-mypage-content .ac-mypage-content-body .pagination .prev:active::before,
.ac-mypage-content .ac-mypage-content-body .pagination .next:active::before {
    color: #38dc8e;
}
.ac-mypage-content .ac-mypage-content-body .form-container {
    margin-top: var(--gap-section);
}
.ac-mypage-content .ac-mypage-content-body .form-container ~ .form-container {
    margin-top: 6rem;
}
.ac-mypage-content .ac-mypage-content-body .form-container .form-label {
    font-size: 1.6rem;
}
.ac-mypage-content .ac-mypage-content-body .form-container .form-label.required::before {
    background-color: #39db8e;
}
.ac-mypage-content .ac-mypage-content-body .form-container .input[type=text],
.ac-mypage-content .ac-mypage-content-body .form-container .select {
    height: 5.6rem;
    font-size: 1.6rem;
}
.ac-mypage-content .ac-mypage-content-body .form-container .input[type=text]:focus {
    border-color: #39db8e;
    box-shadow: 0 0 0 1px #39db8e;
}
.ac-mypage-content .ac-mypage-content-body .form-container .select:focus {
    border-color: #39db8e;
    box-shadow: 0 0 0 1px #39db8e;
}
.ac-mypage-content .ac-mypage-content-body .form-container .textarea:focus {
    border-color: #39db8e;
    box-shadow: 0 0 0 1px #39db8e;
}
.ac-mypage-content .ac-mypage-content-body .form-container .button-333 {
    width: 20rem;
    height: 5.6rem;
    font-size: 1.6rem;
}
.ac-mypage-content .ac-mypage-content-body .form-container .file-list .file-list-head .file-list-count .current {
    color: #39db8e;
}

.ac-board .ac-board-head {
    border-bottom: 1px solid #ddd;
    padding: 0 1rem;
    padding-bottom: 3rem;
    margin-bottom: 3rem;
}
.ac-board .ac-board-body {
    border-bottom: 1px solid #ddd;
    padding: 0 1rem;
    padding-bottom: 3rem;
}
.ac-board .ac-board-type {
    font-size: 1.6rem;
    color: #666;
    margin-bottom: 1rem;
}
.ac-board .ac-board-title-group {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 2rem;
}
.ac-board .ac-board-title {
    font-size: 2.4rem;
    font-weight: 600;
    color: #333;
}
.ac-board .ac-board-date {
    font-size: 1.6rem;
    color: #666;
}
.ac-board .ac-board-cn {
    font-size: 1.6rem;
}
.ac-board .ac-board-answer {
    background-color: var(--color-background-light);
    padding: 3rem;
    border-radius: var(--radius-form);
    margin-top: 3rem;
    font-size: 1.6rem;
    font-weight: 500;
    border: 1px solid var(--color-border);
}