/*!
 * gifthani Common CSS
 */

/* @import url(https://fonts.googleapis.com/earlyaccess/notosanskr.css); */
/* @import url(//fonts.googleapis.com/earlyaccess/nanumgothic.css); */

/**
 * Variables
 */
:root {
    /* FF1493 */
    --point-color: #ff7200;
    --point-color-slide-indicator: #ff8a1d;
    --point-color-dark: #FF1493;
    --point-color-side-off: #FE99CD;
    --point-color-side-on: #FF1493;
    --point-color-header-bar-bg: #FF1493;
    --point-color-header-bar-text: #222;
    --point-color-header-bar-over-text: #FF1493;
    --point-color-header-bar-over-bottom-border: #FF1493;
    --point-color-side-menu-over-text: #FF1493;
    --point-color-table-bg: #faf7fb;
    --point-color-bg-light: #f0f8f5;

    /* text Color */
    --color-text-gray-1: #1d1d1d;
    --color-text-gray-6: #666;
    --color-text-gray-9: #999;
    --color-text-gray-a: #A3A3A3;
    --color-text-gray-b: #b6b6b6;
    --color-text-gray-e: #e5e5e5;

    /* fontSize */
    --font-size-small: 0.8rem;
    --font-size-normal: 0.9rem;
    --font-size-large: 1.1rem;
    --font-size-xlarge: 1.3rem;
    --font-size-xlarge1: 1.6rem;
    --font-size-xlarge2: 2rem;
}

/*
 * default
 */
html,
body {
    height: 100%;
}

body {
	-webkit-font-smoothing: antialiased;
	-ms-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-stroke: 0.45px rgba(0, 0, 0, 0.2);
}

/* width/height */
.w-10 {
    width: 10%;
}

.w-15 {
    width: 15%;
}

.w-20 {
    width: 20%;
}

.w-30 {
    width: 30%;
}

.w-40 {
    width: 40%;
}

.w-45 {
    width: 45%;
}

.w-55 {
    width: 55%;
}

.w-60 {
    width: 60%;
}

.w-65 {
    width: 65%;
}

.w-70 {
    width: 70%;
}

.w-80 {
    width: 80%;
}

.w-85 {
    width: 85%;
}

.w-90 {
    width: 90%;
}

.mw-10 {
    max-width: 10%;
}

.mw-15 {
    max-width: 15%;
}

.mw-20 {
    max-width: 20%;
}

.mw-25 {
    max-width: 25%;
}

.mw-30 {
    max-width: 30%;
}

.mw-40 {
    max-width: 40%;
}

.mw-50 {
    max-width: 50%;
}

.mw-60 {
    max-width: 60%;
}

.mw-70 {
    max-width: 70%;
}

.mw-75 {
    max-width: 75%;
}

.mw-80 {
    max-width: 80%;
}

.mw-90 {
    max-width: 90%;
}

.minw-0 {
    min-width: 0 !important;
}

.minw-10 {
    min-width: 10%;
}

.minw-15 {
    min-width: 15%;
}

.minw-20 {
    min-width: 20%;
}

.minw-25 {
    min-width: 25%;
}

.minw-30 {
    min-width: 30%;
}

.minw-40 {
    min-width: 40%;
}

.minw-50 {
    min-width: 50%;
}

.minw-60 {
    min-width: 60%;
}

.minw-70 {
    min-width: 70%;
}

.minw-75 {
    min-width: 75%;
}

.minw-80 {
    min-width: 80%;
}

.minw-90 {
    min-width: 90%;
}

/* margin/padding */
.m--0 {
    margin: 0 !important;
}

.mt--0,
.my--0 {
    margin-top: 0 !important;
}

.mr--0,
.mx--0 {
    margin-right: 0 !important;
}

.mb--0,
.my--0 {
    margin-bottom: 0 !important;
}

.ml--0,
.mx--0 {
    margin-left: 0 !important;
}

.m--1 {
    margin: -0.25rem !important;
}

.mt--1,
.my--1 {
    margin-top: -0.25rem !important;
}

.mr--1,
.mx--1 {
    margin-right: -0.25rem !important;
}

.mb--1,
.my--1 {
    margin-bottom: -0.25rem !important;
}

.ml--1,
.mx--1 {
    margin-left: -0.25rem !important;
}

.m--2 {
    margin: -0.5rem !important;
}

.mt--2,
.my--2 {
    margin-top: -0.5rem !important;
}

.mr--2,
.mx--2 {
    margin-right: -0.5rem !important;
}

.mb--2,
.my--2 {
    margin-bottom: -0.5rem !important;
}

.ml--2,
.mx--2 {
    margin-left: -0.5rem !important;
}

.m--3 {
    margin: -1rem !important;
}

.mt--3,
.my--3 {
    margin-top: -1rem !important;
}

.mr--3,
.mx--3 {
    margin-right: -1rem !important;
}

.mb--3,
.my--3 {
    margin-bottom: -1rem !important;
}

.ml--3,
.mx--3 {
    margin-left: -1rem !important;
}

.m--4 {
    margin: -1.5rem !important;
}

.mt--4,
.my--4 {
    margin-top: -1.5rem !important;
}

.mr--4,
.mx--4 {
    margin-right: -1.5rem !important;
}

.mb--4,
.my--4 {
    margin-bottom: -1.5rem !important;
}

.ml--4,
.mx--4 {
    margin-left: -1.5rem !important;
}

.m--5 {
    margin: -3rem !important;
}

.mt--5,
.my--5 {
    margin-top: -3rem !important;
}

.mr--5,
.mx--5 {
    margin-right: -3rem !important;
}

.mb--5,
.my--5 {
    margin-bottom: -3rem !important;
}

.ml--5,
.mx--5 {
    margin-left: -3rem !important;
}

.p--0 {
    padding: 0 !important;
}

.pt--0,
.py--0 {
    padding-top: 0 !important;
}

.pr--0,
.px--0 {
    padding-right: 0 !important;
}

.pb--0,
.py--0 {
    padding-bottom: 0 !important;
}

.pl--0,
.px--0 {
    padding-left: 0 !important;
}

.p--1 {
    padding: -0.25rem !important;
}

.pt--1,
.py--1 {
    padding-top: -0.25rem !important;
}

.pr--1,
.px--1 {
    padding-right: -0.25rem !important;
}

.pb--1,
.py--1 {
    padding-bottom: -0.25rem !important;
}

.pl--1,
.px--1 {
    padding-left: -0.25rem !important;
}

.p--2 {
    padding: -0.5rem !important;
}

.pt--2,
.py--2 {
    padding-top: -0.5rem !important;
}

.pr--2,
.px--2 {
    padding-right: -0.5rem !important;
}

.pb--2,
.py--2 {
    padding-bottom: -0.5rem !important;
}

.pl--2,
.px--2 {
    padding-left: -0.5rem !important;
}

.p--3 {
    padding: -1rem !important;
}

.pt--3,
.py--3 {
    padding-top: -1rem !important;
}

.pr--3,
.px--3 {
    padding-right: -1rem !important;
}

.pb--3,
.py--3 {
    padding-bottom: -1rem !important;
}

.pl--3,
.px--3 {
    padding-left: -1rem !important;
}

.p--4 {
    padding: -1.5rem !important;
}

.pt--4,
.py--4 {
    padding-top: -1.5rem !important;
}

.pr--4,
.px--4 {
    padding-right: -1.5rem !important;
}

.pb--4,
.py--4 {
    padding-bottom: -1.5rem !important;
}

.pl--4,
.px--4 {
    padding-left: -1.5rem !important;
}

.p--5 {
    padding: -3rem !important;
}

.pt--5,
.py--5 {
    padding-top: -3rem !important;
}

.pr--5,
.px--5 {
    padding-right: -3rem !important;
}

.pb--5,
.py--5 {
    padding-bottom: -3rem !important;
}

.pl--5,
.px--5 {
    padding-left: -3rem !important;
}

/*
 * Font Size
 */
.font-size-sm {
    font-size: var(--font-size-small) !important;
}

.font-size {
    font-size: var(--font-size-normal) !important;
}

.font-size-lg {
    font-size: var(--font-size-large) !important;
}

.font-size-xlg {
    font-size: var(--font-size-xlarge) !important;
}
.font-size-xlg1 {
    font-size: var(--font-size-xlarge1) !important;
}
.font-size-xlg2 {
    font-size: var(--font-size-xlarge2) !important;
}

/*
 * Background
 */
.back-cover {
    background-repeat: no-repeat;
    background-size: cover;
    background-position-x: center;
}

.back-contain {
    background-repeat: no-repeat;
    background-size: contain;
    background-position-x: center;
}

.back-center-x {
    background-repeat: no-repeat;
    background-position-x: center;
}

.back-center-y {
    background-repeat: no-repeat;
    background-position-y: center;
}

/*
 * Color
 */
.text-red {
    color: #e9221c !important;
}

.text-yellow {
    color: #fffc1d !important;
}

.text-orange-light {
    color: #ffd8a9 !important;
}

.text-dark-cyan {
    color: #00b6c4 !important;
}

.text-dark-green {
    color: #0b8e00 !important;
}

.text-dark-pink {
    color: #ff2c67 !important;
}

.text-black {
    color: #111 !important;
}

.text-gray {
    color: #6c757d !important;
}

.text-gray-1 {
    color: var(--color-text-gray-1) !important;
}
.text-gray-6 {
    color: var(--color-text-gray-6) !important;
}
.text-gray-a {
    color: var(--color-text-gray-a) !important;
}
.text-gray-b {
    color: var(--color-text-gray-b) !important;
}
.text-gray-e {
    color: var(--color-text-gray-e) !important;
}

.text-graphite {
    color: #4e5d7c !important;
}

.text-point {
    color: var(--point-color) !important;
}

.text-point-dark {
    color: #F43540 !important;
}

.text-orange {
    color: #F76F4E !important;
}

.bg-red {
    background-color: #e9221c !important;
}

.bg-dark-cyan {
    background-color: #00b6c4 !important;
}

.bg-dark-green {
    background-color: #0b8e00 !important;
}

.bg-dark-pink {
    background-color: #ff2c67 !important;
}

.bg-orange {
    background-color: var(--point-color) !important;
}

.bg-orange-light {
    background-color: #ffeddf !important;
}

.bg-gray {
    background-color: #6c757d !important;
}

.bg-graphite {
    background-color: #6c757d !important;
}

.bg-light-gray {
    background-color: #F8F9FD !important;
}

.bg-point {
    background-color: var(--point-color) !important;
}

.border-gray {
    border-color: #dee2e6 !important;
}

.border-light {
    border-color: #EFEFEF !important;
}

.badge-point {
    color: #fff;
    background-color: #F56B42 !important
}

/**
 * Cusrsor
 */
.cursor-default {
    cursor: default !important;
}
.cursor-pointer {
    cursor: pointer !important;
}

/**
 * Text whitespace
 */
.text-pre-line {
    white-space: pre-line;
}

/*
 * border
 */
.border-1 {
    border: 1px solid #dee2e6 !important;
}

.border-top-2 {
    border-top-width: 2px;
    border-top-style: solid;
}

.border-bottom-2 {
    border-bottom-width: 2px;
    border-bottom-style: solid;
}

.border-bottom-3 {
    border-bottom-width: 3px;
    border-bottom-style: solid;
}

.border-dark {
    border-color: #505152 !important;
}

.border-orange {
    border-color: #E74322 !important;
}

/*
 * UL Reset
 */
.ul-reset,
.ul-reset > li {
    list-style: none;
}

.ul-reset {
    padding-left: 0;
    margin-bottom: 0;
}

/**
 * List Dot Item's
 */
.list-dot-item > li {
    position : relative;
    display: flex;
    margin-top: 0.4rem;
    color: var(--color-text-gray-b);
}
.list-dot-item > li:first-child {
    margin-top: 0;
}
.list-dot-item > li:before {
    content: "•";
    display: block;
    padding-right: 2px;
    margin-top: -1px;
}
.dot {
    display: inline-block;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background-color: var(--color-text-gray-b);
    opacity: 0.2;
}


/**
 * Form (Custom)
 */
.custom-control-label::before {
    border-color: #e8eaee;
    background-color: #fff;
}
.custom-control-input:checked~.custom-control-label::before {
    border-color: var(--point-color);
    background-color: var(--point-color);
}
.custom-control-input:focus~.custom-control-label::before {
    box-shadow: 0 0 0 .2rem rgba(255,114,1,.5);
}
.custom-control-input:focus:not(:checked)~.custom-control-label::before {
    border-color: rgba(255,114,1,.7);
}

.custom-control.custom-control-lg {
    padding-left: 2.2rem;
}
.custom-control.custom-control-lg .custom-control-label::after,
.custom-control.custom-control-lg .custom-control-label::before
{
    top: 0;
    left: -2.2rem;
    width: 1.5rem !important;
    height: 1.5rem !important;
}
.custom-control.custom-control-lg .custom-control-label {
    font-size: var(--font-size-large);
}
.custom-control.custom-control-lg .custom-control-label.font-size::before,
.custom-control.custom-control-lg .custom-control-label.font-size::after
{
    top: -2px;
}

/**
 * Custom Box Checkbox (Boxed)
 */
.custom-checkbox-boxed.custom-control {
    padding: 0;
}
.custom-checkbox-boxed.custom-control .custom-control-label::after,
.custom-checkbox-boxed.custom-control .custom-control-label::before {
    top: .8rem;
    left: 1rem;
}
.custom-checkbox-boxed.custom-control .custom-control-label {
    display: block;
    border: 1px solid #e0e0e0;
    background-color: #f5f5f5;
    padding: .8rem .8rem .8rem 3.2rem;
    border-radius: .4rem;
}
.custom-checkbox-boxed .custom-control-input:checked~.custom-control-label {
    border-color: var(--point-color);
    background-color: #ffebdb;
}

/**
 * Custom Box Radio
 */
.custom-box-radio .custom-form-input {
    position: absolute;
    left: 0;
    z-index: 1;
    width: 1rem;
    height: 1rem;
    opacity: 0;
}
.custom-box-radio .custom-form-label {
    position: relative;
    margin-bottom: 0;
}
.custom-box-radio .custom-form-label::before  {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 1.5rem;
    opacity: 0;
    border: 3px solid var(--point-color);
    transition: opacity .3s;
}
.custom-box-radio .custom-form-input:checked~.custom-form-label::before {
    opacity: 1;
}

.box-round-shadow {
    display: block;
    border-radius: 1.5rem;
    box-shadow: 0 0 1rem rgba(0, 0, 0, .15);
    padding: 1rem;
    text-align: center;
}


.order-pay-items {
    flex-wrap: wrap;
    margin-left: -1rem;
    margin-right: -1rem;
}
.order-pay-items .item {
    -ms-flex: 0 0 33.333333%;
    flex: 0 0 33.333333%;
    max-width: 33.333333%;
    padding: 1rem;
}

@media (max-width: 768px) {
    .order-pay-items {
        margin-left: -.5rem !important;
        margin-right: -.5rem !important;
    }
    .order-pay-items .item {
        padding: .5rem !important;
    }
    .order-pay-items .box-round-shadow {
        padding: 1rem .5rem !important;
    }
    .order-pay-items .custom-form-label {
        font-size: .8rem;
    }
}


/*
 * etc
 */
.resize-none {
    resize: none;
}

.exp-line {
    width: 0;
    height: 10px;
    margin: 0 10px;
    display: inline-block;
    text-align: center;
    border-left: 1px solid #aaa;
}

.text-deco-underline {
    text-decoration: underline;
}

.text-deco-through {
    text-decoration: line-through;
}

.display-5 {
    font-size: 2.5rem;
    font-weight: 300;
    line-height: 1.2;
}

/*
 * card
 */
.card-body.card-point-line {
    border-top: 3px solid #E74322;
}

/*
 * button
 */
.btn {
    font-size: 0.9rem;
    border-radius: 0.4rem;
}

.btn.btn-lg {
    font-size: 1rem;
}

.btn.btn-sm {
    font-size: 0.8rem;
}

.btn-graphite {
    color: #fff;
    background-color: #4e5d7c;
    border-color: #4e5d7c;
}

.btn-graphite:hover {
    color: #fff;
    background-color: #4e5d7c;
    border-color: #4e5d7c;
}

.btn-graphite:focus,
.btn-graphite.focus {
    color: #fff;
    background-color: #4e5d7c;
    border-color: #4e5d7c;
    box-shadow: 0 0 0 0.2rem rgba(38, 143, 255, 0.5);
}

.btn-graphite.disabled,
.btn-graphite:disabled {
    color: #fff;
    background-color: rgba(109, 2, 223, 0.8);
    border-color: rgba(109, 2, 223, 0.8);
}

.btn-graphite:not(:disabled):not(.disabled):active,
.btn-graphite:not(:disabled):not(.disabled).active,
.show > .btn-graphite.dropdown-toggle {
    color: #fff;
    background-color: #6d02df;
    border-color: #6d02df;
}

.btn-graphite:not(:disabled):not(.disabled):active:focus,
.btn-graphite:not(:disabled):not(.disabled).active:focus,
.show > .btn-graphite.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem rgba(109, 2, 223, 0.5);
}

.btn-orange {
    color: #fff;
    background-color: var(--point-color);
    border-color: var(--point-color);
}

.btn-orange:not([class*="cursor-default"]):hover {
    color: #fff;
    background-color: #FF8E33;
    border-color: #FF8E33;
}

.btn-orange:not([class*="cursor-default"]):focus,
.btn-orange:not([class*="cursor-default"]).focus
{
    color: #fff;
    background-color: #FF8E33;
    border-color: #FF8E33;
    box-shadow: 0 0 0 0.2rem rgba(38, 143, 255, 0.5);
}

.btn-orange.disabled,
.btn-orange:disabled {
    color: #fff;
    background-color: rgba(109, 2, 223, 0.8);
    border-color: rgba(109, 2, 223, 0.8);
}

.btn-orange:not(:disabled):not(.disabled):not([class*="cursor-default"]):active,
.btn-orange:not(:disabled):not(.disabled):not([class*="cursor-default"]).active,
.show > .btn-orange.dropdown-toggle {
    color: #fff;
    background-color: #CC5B00;
    border-color: #CC5B00;
}

.btn-orange:not(:disabled):not(.disabled):active:focus,
.btn-orange:not(:disabled):not(.disabled).active:focus,
.show > .btn-orange.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem rgba(109, 2, 223, 0.5);
}

.btn-outline-orange {
    color: #F26B4E;
    border-color: #F26B4E;
}

.btn-outline-orange:hover {
    color: #fff;
    background-color: #F26B4E;
    border-color: #F26B4E;
}

.btn-outline-orange:focus,
.btn-outline-orange.focus {
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
}

.btn-outline-orange.disabled,
.btn-outline-orange:disabled {
    color: #F26B4E;
    background-color: transparent;
}

.btn-outline-orange:not(:disabled):not(.disabled):active,
.btn-outline-orange:not(:disabled):not(.disabled).active,
.show > .btn-outline-orange.dropdown-toggle {
    color: #fff;
    background-color: #F26B4E;
    border-color: #F26B4E;
}

.btn-outline-orange:not(:disabled):not(.disabled):active:focus,
.btn-outline-orange:not(:disabled):not(.disabled).active:focus,
.show > .btn-outline-orange.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
}

.btn-green {
    color: #fff;
    background-color: #2CA8A1;
    border-color: #2CA8A1;
}

.btn-green:hover {
    color: #fff;
    background-color: #1F7B73;
    border-color: #1F7B73;
}

.btn-green:focus,
.btn-green.focus {
    color: #fff;
    background-color: #1F7B73;
    border-color: #1F7B73;
    box-shadow: 0 0 0 0.2rem rgba(38, 143, 255, 0.5);
}

.btn-green.disabled,
.btn-green:disabled {
    color: #fff;
    background-color: rgba(44, 168, 161, 0.8);
    border-color: rgba(44, 168, 161, 0.8);
}

.btn-green:not(:disabled):not(.disabled):active,
.btn-green:not(:disabled):not(.disabled).active,
.show > .btn-green.dropdown-toggle {
    color: #fff;
    background-color: #1F7B73;
    border-color: #1F7B73;
}

.btn-green:not(:disabled):not(.disabled):active:focus,
.btn-green:not(:disabled):not(.disabled).active:focus,
.show > .btn-green.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem rgba(109, 2, 223, 0.5);
}

.btn-outline-green {
    color: #2CA8A1;
    border-color: #2CA8A1;
}

.btn-outline-green:hover {
    color: #fff;
    background-color: #1F7B73;
    border-color: #1F7B73;
}

.btn-outline-green:focus,
.btn-outline-green.focus {
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
}

.btn-outline-green.disabled,
.btn-outline-green:disabled {
    color: #1F7B73;
    background-color: transparent;
}

.btn-outline-green:not(:disabled):not(.disabled):active,
.btn-outline-green:not(:disabled):not(.disabled).active,
.show > .btn-outline-green.dropdown-toggle {
    color: #fff;
    background-color: #1F7B73;
    border-color: #1F7B73;
}

.btn-outline-green:not(:disabled):not(.disabled):active:focus,
.btn-outline-green:not(:disabled):not(.disabled).active:focus,
.show > .btn-outline-green.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
}

.btn-grade-viewer {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
    color: #fff !important;
    border-color: #fff !important;
    text-decoration: none !important;
    border-radius: 1rem;
}

/**
 * Grade Info
 */
.content-grade-header {
    padding: 1.5rem 1rem;
    text-align: center;
    background-color: #ffebdb;
}
.content-grade-header h3 {
    font-weight: bold;
    color: var(--point-color);
}

/*
 * label
 */
.label {
    display: inline-block;
    font-weight: 400;
    color: #212529;
    text-align: center;
    vertical-align: middle;
    background-color: transparent;
    border: 1px solid transparent;
    padding: 0.42rem 0.75rem 0.3rem;
    font-size: 1rem;
    line-height: 1.5;
}

.label.bg-orange,
.label.bg-primary,
.label.bg-secondary,
.label.bg-dark-pink {
    color: white;
}

/*
 * table
 */
.table-custom {
    border-top: 0;
}
.table-custom tbody td.border-top,
.table-custom tbody td.border-left,
.table-custom tbody td.border-right,
.table-custom tbody td.border-bottom
{
    border-color: #ededed !important;
}

.table-custom thead th {
    border-top: 0;
    border-bottom: 0;
    font-weight: bold;
}

.table.align-middle td {
    vertical-align: middle;
}

.table-custom thead th,
.table-custom tbody th {
    background-color: #FBFBFB;
}

.table-custom tbody th {
    border-bottom: 0;
}

.table-custom tbody td {
    border-top-color: #eaebec;
    background-color: #fff;
}

.table-custom .table-row-collapse {
    padding: 0;
    border: 0 !important;
    background-color: #f9f9f9;
}

.table-custom [data-toggle='collapse'][aria-expanded='true'] {
    border-bottom: 1px solid #eaebec;
}

.table-custom .form-control[readonly] {
    background-color: transparent !important;
}
.table.table-form tbody th,
.table.table-form tbody td {
    padding: 1rem 0.75rem;
    /* color: #6c757d; */
    /* font-size: 1.1rem; */
    vertical-align: middle;
    border-top-color: #ededed;
}

.table-custom.table-bordered td,
.table-custom.table-bordered th {
    border-color: #ededed !important;
}
.table.table-form tbody th.bg-light,
.table.table-form tbody td.bg-light {
    background-color: #f8f8f8;
}

.table.table-form tbody th {
    font-weight: normal;
    vertical-align: middle;
    border-right: 1px solid #e5e6e7;
}

.table.table-form tbody tr:first-child th,
.table.table-form tbody tr:first-child td {
    border-top: 0;
}

.table-responsive-md .table th,
.table-responsive-md .table td {
    white-space: nowrap;
}

@media (max-width: 768px) {
    .table.table-form tbody th {
        white-space: nowrap;
    }
    .table-responsive-md .text-subject {
        max-width: 200px;
    }
}

/*
 * pagination
 */
.pagination-sm .page-item:first-child .page-link,
.pagination-sm .page-item:last-child .page-link {
    color: var(--color-text-gray-b);
    margin: 0 0.4rem;
}

.page-link,
.page-link:hover {
    border: 0;
    color: #656565;
}

.page-item.active .page-link {
    color: #333;
    font-weight: bold;
    background-color: transparent;
}

/*
 * form
 */
.form-control {
    border-color: #F0F0F0;
}

.form-control::-webkit-input-placeholder, .form-control-plaintext::-webkit-input-placeholder {
    color: #aaa;
}

.form-control::-moz-placeholder, .form-control-plaintext::-moz-placeholder {
    color: #aaa;
}

.form-control:-ms-input-placeholder, .form-control-plaintext:-ms-input-placeholder {
    color: #aaa;
}

.form-control::-ms-input-placeholder, .form-control-plaintext::-ms-input-placeholder {
    color: #aaa;
}

.form-control::placeholder, .form-control-plaintext::placeholder {
    color: #aaa;
}

.form-control-plaintext {
    outline: none;
}

.form-inline.form-inline-fix > * {
    width: auto;
    display: inline-block;
}

.form-inline .form-control-plaintext {
    display: inline-block;
}

/*
 * input group
 */
.input-group-union .form-control,
.input-group-union .form-control-plaintext,
.input-group-union .input-group-text {
    border: 0;
    border-radius: 0;
    outline: none;
}

.input-group-union .input-group-text {
    background-color: #fff;
}

.input-group-union {
    padding: 0.3rem;
}

.input-group-inner .input-group-text {
    border-color: #F0F0F0;
    background-color: #fff;
}
.input-group-inner>.custom-select:not(:last-child),
.input-group>.form-control:not(:last-child) {
    border-right: 0;
}
.input-group-inner>.custom-select:not(:first-child),
.input-group>.form-control:not(:first-child) {
    border-left: 0;
}

/* ul dot list */
.ul-dot-list {
    color: #6c757d;
    font-size: 12px;
    padding-left: 0;
}

.ul-dot-list li {
    position: relative;
    list-style: none;
    padding-left: 15px;
}

.ul-dot-list li::before {
    content: '•';
    position: absolute;
    top: -1px;
    left: 0;
}

.container-max-width {
    max-width: 470px;
    margin: 0 auto;
}
.container-max-width-content {
    max-width: 980px;
    margin: 0 auto;
}
.container-mypage {
    padding: 3rem 0;
    color: #fff;
    background: #F64210;
    background: linear-gradient(90deg, rgba(246, 66, 16, 1) 0%, rgba(255, 114, 1, 1) 100%);
}

@media (max-width : 768px) {
    .container-mypage {
        padding: 1.5rem 0;
    }
    .container-mypage h4 {
        font-size: 1.2rem !important;
    }
}

/*
 * Header (PC)
 */
.header .header-logo {
    position: relative;
    top: -.3rem;
}
.header .header-logo img {
    max-height: 30px;
}

.header .container {
    position: relative;
}

.header .position-absolute {
    top: 1rem;
    right: 0;
}

.header.header-top-bar {
    padding: 30px 0 0;
    position: relative;
    z-index: 10;
}

.header.header-nav {
    border-bottom: 1px solid #eee;
}

.header.header-nav button.btn {
    padding: 0.9rem 1rem;
    display: flex !important;
    align-items: center !important;
}

.header.header-nav.fixed {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10;
}

.header .header-menu a {
    position: relative;
    display: inline-block;
    color: #111;
    text-align: center;
    padding: 1.6rem 0;
    font-weight: bold;
    font-size: 1.1rem;
}
.header .header-menu a:after {
    content: "";
    display: block;
    position: absolute;
    width: 0;
    left: 50%;
    bottom: -2px;
    transition: all 0.3s;
    border-bottom: 4px solid var(--point-color);
}

.header .header-menu .item.active a,
.header .header-menu .item:hover a,
.header .header-menu .item:focus a:after {
    color: var(--point-color);
}

.header .header-menu .item.active a:after,
.header .header-menu .item:hover a:after,
.header .header-menu .itme:focus a:after
{
    left: 0;
    width: 100%;
}

.header .header-menu a,
.header-util-menu a {
    text-decoration: none;
}

.header-util-menu a {
    color: #343a40;
}

.header-util-menu .item {
    display: inline-block;
    position: relative;
    margin: 0 0 0 15px;
    padding-left: 15px;
    font-weight: 600;
}

.header-util-menu .item-icon,
.header-util-menu .item:first-child {
    padding-left: 0;
}

.header-util-menu .item-icon {
    margin-right: -15px;
}

.header-util-menu .item:first-child:before {
    display: none;
}

.header .header-menu-sub {
    position: absolute;
    left: 0;
    right: 0;
    z-index: 0;
    overflow: hidden;
}
.header .header-menu-sub .container {
    position: relative;
    z-index: 10;
    opacity: 0;
    transition: opacity .4s;
}
.header .header-menu-sub:after {
    content: "";
    display: block;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    right: 0;
    height: 0;
    transition: all .2s;
    background-color: #f7f7f7;
}

.header .header-menu-sub .item {
    padding-top: 1rem;
    padding-bottom: 1rem;
}
.header .header-menu-sub a {
    display: block;
    color: #777;
    text-decoration: none;
    margin-top: 10px;
}
.header .header-menu-sub a:hover,
.header .header-menu-sub a.active {
    color : var(--point-color);
}

.header .header-menu-sub.active {
    z-index: 10;
}
.header .header-menu-sub.active .container {
    opacity: 1;
}
.header .header-menu-sub.active:after {
    height: 100%;
}

@media (max-width: 1200px) {
    .header .header-menu-sub a {
        font-size: .8rem;
        letter-spacing: -1px;
    }
}

@media (max-width: 990px) {
    .header .header-container {
        max-width: 100% !important;
    }

    .header .header-menu a {
        font-size: .9rem;
    }

    .header .header-menu-sub a {
        font-size: .75rem;
        letter-spacing: -1px;
    }

    .header-util-menu .item {
        font-size: .9rem;
    }
}


/*
 * Header (Mobile)
 */
#wrapper {
    position: relative;
    overflow: hidden;
}
.header-vertical-space {
    height: 56px;
}
.header-mobile {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 101;
}
body.header-menu-mb-active .header-mobile {
}

.header-mobile .header-bar {
    position: relative;
    padding: 0.8rem 0;
    z-index: 2;
    background-color: #fff;
}
.header-mobile .header-logo img {
    height: 25px;
}

.header-mobile .btn-header-menu {
    position: relative;
    background-color: #fff !important;
    border: 0 !important;
    min-width: 36px;
    min-height: 30px;
    text-align: center;
    box-shadow: none !important;
}
.header-mobile .btn-header-menu:before {
    content: " ";
    display: block;
}
.header-mobile .btn-header-menu > i {
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -6px;
    margin-left: -5px;
    transition: opacity 0.6s;
    width: 12px;
    text-align: center;
}

body:not(.header-menu-mb-active) .header-mobile .btn-header-menu > i:first-child {
    opacity: 1;
}
body:not(.header-menu-mb-active) .header-mobile .btn-header-menu > i:last-child {
    opacity: 0;
}
body.header-menu-mb-active .header-mobile .btn-header-menu > i:first-child {
    opacity: 0;
}
body.header-menu-mb-active .header-mobile .btn-header-menu > i:last-child {
    opacity: 1;
}
body.header-menu-mb-active {
    overflow: hidden;
}

.header-mobile-menu-container {
    position: fixed;
    top: 56px;
    left: 100%;
    min-width: 100%;
    right: 0;
    bottom: 0;
    z-index: 100;
    overflow: hidden;
    overflow-y: auto;
    opacity: 0;
    pointer-events: none;
    transition: left 0.4s ease, opacity 0.4s ease;
}
.header-mobile-menu-container .header-mobile-menu {
    position: relative;
    padding-top: 1rem;
    background-color: #fff;
    z-index: 2;
}
.header-mobile-menu-container .header-mobile-menu-bg {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    background-color: rgba(0, 0, 0, 0.7);
}
.header-mobile-menu-container .header-mobile-menu-user {
    margin: 0 1rem;
}
.header-mobile-menu-container .header-mobile-menu-user a {
    text-decoration: none !important;
    font-size: .9rem;
    color: var(--color-text-gray-6);
}

body.header-menu-mb-active .header-mobile-menu-container {
    left: 0;
    opacity: 1;
    pointer-events: auto;
}

/* Main */
.main-content .text-main-ment {
    font-size: 2.8rem;
    font-weight: bold;
}
.main-content .btn-groups {
    width: 90%;
}

.btn-main-gift {
    font-size: 1rem;
    display: block;
    text-align: center;
    color: var(--point-color) !important;
    border: 1px solid var(--point-color);
    padding: 1rem;
    line-height: 1rem;
    border-radius: 1.5rem;
    text-decoration: none !important;
}

@media (max-width: 1200px) {
    .main-content .text-main-ment {
        font-size: 2rem;
    }
}

@media (max-width: 990px) {
    .main-content .text-main-ment {
        font-size: 1.5rem;
    }

    .btn-main-gift {
        font-size: .8rem;
    }
}

@media (max-width: 768px) {
    .main-content {
        text-align: center;
    }
    .main-content .text-main-ment {
        font-size: 2rem;
    }
    .main-content .font-size-xlg {
        font-size: 1rem !important;
    }
    .main-content .btn-groups {
        width: 100%;
    }
}

/* Signup */
.step-signup {
    max-width: 300px;
    margin: 1rem auto;
    text-align: center;
    position: relative;
}
.step-signup:before {
    content: "";
    display: block;
    position: absolute;
    border-bottom: 1px solid #dfdfdf;
    top: 24px;
    left: 0;
    right: 0;
}
.step-signup .item {
    color: #b6b6b6;
}
.step-signup .item .item-icon {
    position: relative;
    text-align: center;
    line-height: 50px;
    width: 50px;
    height: 50px;
    background-color: #dfdfdf;
    border-radius: 50%;
    margin-bottom: .4rem;
}
.step-signup .item.active {
    color: #333;
    font-weight: bold;
}
.step-signup .item.active .item-icon {
    background-color: var(--point-color);
}

.nav-menu-text {
    color: #787878;
    padding: 1.5rem 0 0;
    font-size: 0.9rem;
    /* border-bottom: 1px solid #dee2e6; */
    background-color: #f9f9f9;
}

.nav-menu-text i {
    margin-right: 5px;
}

/* Tab */
.nav-tabs .nav-link {
    color: #888;
    padding: 1rem 0;
    font-size: 1.2rem;
}

.nav-tabs .nav-link.active {
    font-weight: 600;;
    color: var(--point-color);
    border-color: transparent transparent var(--point-color) transparent;
}

.nav-tabs .nav-link:focus, .nav-tabs .nav-link:hover {
    color: var(--point-color);
    border-top-color: transparent;
    border-left-color: transparent;
    border-right-color: transparent;
}

.tab-pane-box {
    padding: 0.8rem;
    border-left: 1px solid #dee2e6;
    border-right: 1px solid #dee2e6;
    border-bottom: 1px solid #dee2e6;
    background-color: #fff;
}

.carousel-main {
    margin-top: -1px;
    z-index: 15;
}

.carousel-main .carousel-item {
    width: 100%;
}

.carousel-main .carousel-item a.link {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.carousel-main .carousel-item .d-md-block,
.carousel-main .carousel-indicators-container {
    height: 400px;
}

.carousel-main .carousel-item .d-md-block {
    background-position: center;
}

.carousel-main .carousel-indicators-container {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.carousel-indicators {
    justify-content: flex-start;
    margin-left: 2rem;
    margin-bottom: 1.5rem;
}

.carousel-indicators .active {
    background-color: var(--point-color-slide-indicator);
}
.carousel-indicators li {
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background-color: #9f9f9f;
}

/*
 * 메뉴전체보기
 */
.modal-nav-sitemap .sitemap-container {
    margin: 15px 0;
}

.modal-nav-sitemap .sitemap-container > div {
    padding: 10px 10px;
}

.modal-nav-sitemap .sitemap-container a {
    display: block;
    color: #343a40 !important;
    padding: 2px 0;
}

.modal-nav-sitemap .explode-item a {
    float: left;
    color: #343a40 !important;
    position: relative;
    margin-left: 18px;
    padding-left: 18px;
}

.modal-nav-sitemap .explode-item a:before {
    content: '';
    position: absolute;
    top: 5px;
    left: 0;
    height: 10px;
    border-left: 1px solid #aaa;
}

.modal-nav-sitemap .explode-item a:first-child {
    margin-left: 0;
    padding-left: 0;
}

.modal-nav-sitemap .explode-item a:first-child:before {
    display: none;
}

/*
 * 상품목록
 */
.item-product,
.item-product .card-image {
    border-top-right-radius: 1.5rem;
}

.item-product {
    position: relative;
    margin-bottom: 30px;
    border-width: 0;
    border-radius: 1.5rem;
    box-shadow: 0 0 1rem rgba(0, 0, 0, .15) !important;
}

.item-product .card-image {
    padding: 4rem 2rem 0 2rem;

    display: -webkit-flexbox !important;
    display: flex !important;

    -webkit-flex-align: center !important;
    align-items: center !important;

    -webkit-flex-pack: center !important;
    justify-content: center !important;
}

.item-product .text-title {
    text-align: center;
    font-weight: bold;
    font-size: 1rem;
}

.item-product .card-image img {
    max-width: 100%;
    max-height: 140px;
}

/*
 * Main Notice
 *
 * @date 2021.10.10
 */
.card-footer-box.card-footer-talk {
    /* background-color: #f5f6f7; */
    padding: 0 1rem;
}

.card-footer-box .card-title,
.card-footer-box .card-ment {
    text-align: center;
}

.card-footer-box .card-body {
    min-height: 400px;
}

.card-footer-box .card-title {
    text-align: center;
    font-weight: bold;
    font-size: 1.4rem;
    padding: 10px 15px 0;
}

.card-footer-box .ul-reset {
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.card-footer-box .ul-reset > li {
    padding: 10px 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.card-footer-box .ul-reset a {
    color: #92989cef !important;
}

/* 주문싱세 상품목록 */
.order-items > li {
    padding: 8px 0;
    border-top: 1px solid #dee2e6;
}

.order-items > li:first-child {
    border-top: 0;
}

/* 사이드 메뉴 (모바일) */
.side-menu-mobile a {
    color: var(--color-text-gray-1);
    display: block;
    padding: 1rem 1rem;
    border-top: 1px solid #e2e2e2;
    border-bottom: 1px solid #e2e2e2;
    margin-top: -1px;
    position: relative;
    text-decoration: none;
    transition: all 0.4s ease;
}
.side-menu-mobile > li > a::after {
    content: "\f078";
    display: block;
    color: var(--color-text-gray-b);
    position: absolute;
    right: 1rem;
    margin-top: 0.2rem;
    font-family: "Font Awesome 5 Free";
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    font-weight: 900;
    line-height: 1;
}
.side-menu-mobile > li.mm-active > a {
    z-index: 1;
    color: #fff;
    background-color: var(--point-color);
    border-color: var(--point-color) !important;
}
.side-menu-mobile > li.mm-active > a::after {
    content: "\f077";
    color: #fff;
}
.side-menu-mobile > li > ul > li > a {
    color: #5b5b5b;
    padding-left: 2rem;
    background-color: #f6f6f6;
}
.side-menu-mobile > li > ul > li.mm-active > a {
    color: var(--point-color);
}

/**
 * 사이드 메뉴 (PC)
 */
.side-menu a {
    border-top: 1px solid #eaeaea;
    border-left: 2px solid transparent;
    color: #404141;
    display: block;
    padding: .5rem 1rem .5rem 0;
    text-decoration: none;
}

.side-menu a:first-child {
    margin-top: 0;
    border-top: 0;
}

.side-menu a.active {
    color: var(--point-color);
    font-weight: 600;
    /* border-left: 2px solid var(--point-color-dark); */
}

/*
 * footer fishing
 */
.footer-fishing-ment {
    color: #fff;
    background-color: #20a28e;
}
.footer-fishing-ment .item-cops {
    padding: 5rem 0;
    min-width: 300px;
    background: url("/assets/images/img-cops-fishing.png") no-repeat bottom;
    background-size: contain;
}
.footer-fishing-ment .item-content {
    background : url("/assets/images/img-logo-sm-white.png") no-repeat right 10px;
}
.footer-fishing-ment .item-ment {
    padding-left: 2rem;
    font-size: 1.5rem;
    font-weight: bold;
}
.footer-fishing-ment .item-ment > span {
    color: #fff66a;
}

@media (max-width: 992px) {
    .footer-fishing-ment .item-cops {
        padding: 4rem 0;
        min-width: 220px;
    }
    .footer-fishing-ment .item-ment {
        padding-left: 2rem;
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .footer-fishing-ment .item-cops {
        padding: 3rem 0;
        min-width: 140px;
    }
    .footer-fishing-ment .item-ment {
        padding-left: 2rem;
        font-size: .9rem;
    }
    .footer-fishing-ment .item-content {
        background-size: 20%;
    }
}

@media (max-width: 575px) {
    .footer-fishing-ment .d-flex {
        flex-wrap: wrap !important;
    }
    .footer-fishing-ment .item-cops {
        margin-top: 1rem;
        padding: 1.5rem 0;
        width: 100%;
        background-position: 1rem;
    }
    .footer-fishing-ment .item-ment {
        margin-top: 1.2rem;
        padding-left: 0rem;
        font-size: .9rem;
    }
    .footer-fishing-ment .item-content {
        background-size: 15%;
    }
}

/*
 * footer
 */
.footer {
    background-color: #fff;
    padding-bottom: 1.5rem;
}

.footer .footer-menu-bar {
    padding: 1rem;
}

.footer .footer-logo {
    padding: 0 40px;
}

.footer .footer-logo img {
    max-width: 90%;
}

.footer .footer-menu a {
    float: left;
    color: #343a40;
    position: relative;
    margin-left: 18px;
    padding-left: 18px;
    text-decoration: none;
}

.footer .footer-menu a:first-child {
    margin-left: 0;
    padding-left: 0;
}

.footer .footer-menu a:first-child:before {
    display: none;
}

.footer .footer-copyright {
    margin-top: 15px;
    color: #6c757d;
    font-size: 0.8rem;
}

.footer .footer-copyright .text-item {
    display: inline-block;
    margin-right: 5px;
}

.footer .text-copyright {
    display: inline-block;
    margin-top: 10px;
}

.footer-mobile {
    text-align: center;
    padding: 15px;
    font-size: 0.8rem;
}

.footer-mobile .footer-menu {
    margin-bottom: 10px;
}

.footer-mobile .footer-menu a {
    display: inline-block;
    font-weight: 600;
    color: #343a40;
    margin-right: 15px;
}

.footer-mobile .footer-copyright {
    font-size: 0.8rem;
    color: #6c757d;
}

.footer-mobile .text-copyright {
    color: #6c757d;
    margin-top: 10px;
}

.footer-customer {
    padding: 1.4rem 0;
    text-align: center;
    background-color: #f5f5f5;
    font-weight: bold;
}


/* Main Notice */
.main-notice {
    padding: 1rem 0;
    color: #fff;
    background-color: #363636;
}

.main-notice a {
    color: #fff;
}

/* 카카오톡 상담 */
.customer-kakao {
    position: fixed;
    right: 5%;
    bottom: 30px;
    z-index: 99;
}

.customer-kakao .d-none {
    height: 60%;
}

.customer-kakao .d-block {
    height: 50px;
}

/* Badge */
.badge-line {
    display: inline-block;
    padding: .4em .5em .2rem;
    font-size: 85%;
    font-weight: 700;
    line-height: 1;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-top-left-radius: .25rem;
    border-top-right-radius: .25rem;
    border: 1px solid #404140;
    border-bottom: 0;
}

a.badge {
    color: inherit;
   text-decoration: none;
}
.badge-outline-point {
    background-color: #fff;
    color: var(--point-color) !important;
    border: 1px solid var(--point-color);
}

/* Product Detail */
.item-product-detail .item-product-photo {
    border-top-right-radius: 1.5rem;
    border-top-left-radius: 1.5rem;
    box-shadow: 0 0 2rem rgba(0, 0, 0, .15);
    padding: 2rem;
    text-align: center;
}

.item-product-detail .item-product-photo-ment {
    position: relative;
    padding: .7rem 2rem;
    text-align: center;
    color: #fff;
    font-size: 1.5rem;
    font-weight: bold;
    background-color: #F76F4E;
}

.item-product-detail .item-product-title {
    font-weight: bold;
    font-size: 2.5rem;
    margin-bottom: 2rem;
}

.item-product-detail .item-list-box {
    border-bottom: 1px solid #EFEFEF;
    padding: 1rem;
}

.input-group-count {
    display: inline-flex;
    max-width: 130px;
}

.input-group-count .form-control {
    text-align: center;
    border-color: #e8eaee;
}
.input-group-count .btn {
    border-color: #e8eaee;
}
.input-group-count .input-group-btn .btn {
    border-radius: .2rem !important;
}

.input-group-count .btn {
    min-width: 2.2rem;
}

@media (max-width: 768px) {
    .item-product-detail .item-list-box {
        padding: .5rem 0;
    }

    .item-product-detail .w-30 {
        width: 35% !important;
    }

    .customer-kakao {
        right: 15px;
        bottom: 15px;
    }
}
