:root {
    --app-width: 580px;
}

/* Start Root */
html {
    overflow-x: hidden;
}

body {
    background-color: black;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    overflow: hidden;
}

.app {
    min-height: 100dvh;
    height: 100%;
    overflow: scroll;
    background-position: center;
    object-fit: cover;
    background-repeat: no-repeat;
    background-size: cover;
    scrollbar-color: transparent transparent;
    scrollbar-width: thin;
}

button,
a {
    outline: none !important;
    box-shadow: none !important;
}

a:hover {
    text-decoration: none;
}

select,
textarea,
input {
    outline: none !important;
    box-shadow: none !important;
}

/* End Root */

/* Start Var */
.standard {
    border-radius: 6px !important;
}

.pill {
    border-radius: 999px !important;
}

.square {
    border-radius: 0 !important;
}

.corner_split {
    border-radius: 20px 0 20px 0 !important;
}

.btn_outline {
    border-radius: 30px !important;
    background: transparent !important;
}

.accented_corners {
    border-radius: 0 20px 0 15px !important;
}

.tick {
    width: 1.5rem;
}

.with_animation {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity .45s ease, transform .45s ease;
}

.with_animation.show {
    opacity: 1;
    transform: translateY(0);
}

.modal-backdrop {
    opacity: .6;
    --aous-aw-backdrop-bg: #07090f;
}

.auto_hidden.hidden {
    display: none;
}

.modal-body h2 {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}

.calendar_btn {
    position: fixed;
    bottom: 0.5rem;
    left: 0.5rem;
    padding: 0.5rem;
    border-radius: 50%;
    z-index: 99;
}

html[dir="rtl"] .calendar_btn {
    left: unset;
    right: 1rem;
}

.calendar_btn svg {
    --aous-aw-icon-size: 1.75rem;
}

html[dir="rtl"] .form-control.is-invalid {
    background-position: left calc(.3571428572em + .21875rem) center;
}

html[dir="rtl"] .form-floating>.form-control-plaintext~label,
html[dir="rtl"] .form-floating>.form-control:focus~label,
html[dir="rtl"] .form-floating>.form-control:not(:placeholder-shown)~label,
html[dir="rtl"] .form-floating>.form-select~label {
    transform: scale(.85) translateY(-.5rem) translateX(3.25rem);
}

html[dir="rtl"] .arrow_right {
    rotate: 180deg;
}

/* End Var */

/* Start Global Model */

.title_content {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.title_content .title_value {
    font-size: 1.1rem;
    font-weight: 500;
}

.title_content img {
    width: 1.5rem;
}

.avatar_content {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.avatar_content span {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--rt-surface-bg-color, hsla(0, 0%, 100%, 0.3));
    color: var(--rt-surface-text-color, #ffffff);
    border: 1px solid var(--rt-border-color, transparent);
    width: 4rem;
    height: 4rem;
    font-weight: 600;
    font-size: 1.4rem;
    border-radius: 50%;
    text-transform: uppercase;
}

.avatar_content img {
    width: 4.25rem;
    height: 4.25rem;
    object-fit: contain;
    border-radius: 50%;
}

/* Start Global Model */

/* Start App Content */
.app_content {
    min-height: 100vh;
    width: var(--app-width);
    margin: auto;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
}

.app_content .app_body {
    z-index: 1;
}

.app_content.with_background_image .app_body {
    z-index: 999;
}

.app_content .app_body .app_bar {
    position: relative;
    display: flex;
    justify-content: space-between;
    padding-top: 1rem;
    z-index: 99;
}

.app_content .app_body .app_bar.with_cover {
    width: 100%;
    padding-inline: 1rem;
    transition: all 0.75s ease-in-out;
}

.app_content .app_body .app_bar.with_cover a {
    background: hsla(0, 0%, 100%, 0.2);
    border-color: hsla(0, 0%, 100%, 0.25);
    backdrop-filter: blur(12px) saturate(1.5);
    -webkit-backdrop-filter: blur(12px) saturate(1.5);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    color: #111827 !important;
}

.app_content .app_body .app_bar.with_cover.hidden {
    top: -100%;
}

.app_content .app_body .app_bar a {
    display: inline-block;
    padding-block: 0.4rem;
    padding-inline: 0.6rem;
    background: var(--rt-surface-bg-color, hsla(0, 0%, 100%, 0.3));
    border: 1px solid var(--rt-border-color, transparent);
    border-radius: 30px;
    font-weight: 500;
    box-shadow: rgba(10, 11, 13, 0.08) 0px 2px 4px 0px;
}

.app_content .app_body .app_bar .just_icon {
    border-radius: 50%;
    padding-block: 0.4rem;
    padding-inline: 0.4rem;
}

.app_content .app_body .app_bar svg {
    --aous-aw-icon-size: 1.35rem;
}

.app_content .app_body .app_bar .right {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

/* End App Content */

/* Start Image Cover */
.app_content .conver_area {
    position: absolute;
    top: -4.5rem;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.app_content.type_spotlight .conver_area {
    filter: blur(4px);
    opacity: 0.3 !important;
}

.app_content .cover_overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0);
    transition: all 0.2s linear;
    pointer-events: none;
}

.app_content .conver_area .cover_img {
    mask: radial-gradient(110.26% 96% at 50% 0%, rgb(0, 0, 0) 50%, rgba(0, 0, 0, 0.99) 54.68%, rgba(0, 0, 0, 0.97) 58.79%, rgba(0, 0, 0, 0.94) 62.4%, rgba(0, 0, 0, 0.9) 65.61%, rgba(0, 0, 0, 0.85) 68.52%, rgba(0, 0, 0, 0.79) 71.2%, rgba(0, 0, 0, 0.72) 73.75%, rgba(0, 0, 0, 0.65) 76.25%, rgba(0, 0, 0, 0.57) 78.8%, rgba(0, 0, 0, 0.48) 81.48%, rgba(0, 0, 0, 0.39) 84.39%, rgba(0, 0, 0, 0.3) 87.6%, rgba(0, 0, 0, 0.2) 91.21%, rgba(0, 0, 0, 0.1) 95.32%, rgba(0, 0, 0, 0) 100%);
    height: 35rem;
    width: var(--app-width);
    background-position: top;
    background-size: contain;
    background-repeat: no-repeat;
}

/* End Image Cover */

/* Start App title */

.app_title {
    text-align: center;
    margin-top: 1.5rem;
}

.type_cover .app_title.with_cover {
    margin-top: 22rem;
}

.type_spotlight .app_title.with_cover {
    margin-top: 5rem;
}

.app_title .avatar_content {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.app_title .avatar_content span {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--rt-surface-bg-color, hsla(0, 0%, 100%, 0.3));
    color: var(--rt-surface-text-color, #ffffff);
    border: 1px solid var(--rt-border-color, transparent);
    box-shadow: rgba(10, 11, 13, 0.08) 0px 2px 4px 0px;
    width: 4rem;
    height: 4rem;
    font-weight: 600;
    font-size: 1.4rem;
    border-radius: 50%;
    text-transform: uppercase;
}

.app_title .avatar_content img {
    width: 5rem;
    height: 5rem;
    object-fit: contain;
    border-radius: 50%;
}

.type_spotlight .app_title .avatar_content img {
    width: 6rem;
    height: 6rem;
}

.app_title .title_area {
    padding-top: 0.7rem;
}

.app_title .title_area span {
    display: block;
}

.app_title .title_area .title_content {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.app_title .title_area .title_content .title_value {
    font-size: 1.25rem;
    font-weight: 600;
}

.app_title .title_area .title_content img {
    width: 1.5rem;
    box-shadow: 1px 5px 10px #dddddd45;
    backdrop-filter: drop-shadow(2px 20px 20px black);
    border-radius: 50%;
}

.app_title .bio_content {
    width: 75%;
    margin: 0.5rem auto;
    font-size: 0.9rem;
}

.app_title .bio_content .bio_value {
    opacity: .8;
}

/* End App title */

/* Start App Links */
.app_links_area .links {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-top: 2rem;
}

.app_links_area .links .type_content_link {
    display: block;
    text-align: center;
    opacity: 0;
    transform: translateY(14px);
    transition:
        opacity .45s ease-out,
        transform .45s ease-out;
    will-change: opacity, transform;
}

.app_links_area .links .type_content_link.show {
    opacity: 1;
    transform: translateY(0);
}

.app_links_area .links .type_content_link.btn_outline {
    border: 1px solid;
}

.app_links_area .links .type_content_link .title {
    position: relative;
    font-size: 1rem;
    font-weight: bold;
    padding-block: 1rem;
    white-space: normal;
    background: none;
    color: inherit;
    transition: box-shadow 0.25s cubic-bezier(0.08, 0.59, 0.29, 0.99) 0s, border-color 0.25s cubic-bezier(0.08, 0.59, 0.29, 0.99) 0s, transform 0.25s cubic-bezier(0.08, 0.59, 0.29, 0.99) 0s, background-color 0.25s cubic-bezier(0.08, 0.59, 0.29, 0.99) 0s;
    overflow-wrap: break-word;
    word-break: break-word;
    display: block;
    width: 100%;
}

.app_links_area .links .type_content_link .title svg {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
}

.app_links_area .rt-segmented {
    position: relative;
    display: flex;
    background: var(--rt-surface-bg-color, rgba(255, 255, 255, 0.15));
    border: 1px solid var(--rt-border-color, transparent);
    box-shadow: rgba(10, 11, 13, 0.08) 0px 2px 4px 0px;
    padding: 5px;
    border-radius: 40px;
    width: 220px;
    backdrop-filter: blur(10px);
    margin: auto;
    margin-top: 2rem;
    margin-bottom: 4rem;
}

.app_links_area .rt-segment-bg {
    position: absolute;
    top: 5px;
    left: 5px;
    width: 50%;
    height: calc(100% - 10px);
    background: var(--rt-segment-active-bg, white);
    border-radius: 35px;
    transition: 0.3s ease;
}

.app_links_area .rt-segment-btn {
    position: relative;
    z-index: 2;
    flex: 1;
    padding: 10px 0;
    background: transparent;
    border: none;
    font-weight: 600;
    border-radius: 35px;
    cursor: pointer;
    color: var(--rt-page-text-color, white);
}

.app_links_area .rt-segment-btn.active {
    color: var(--rt-segment-active-text, black);
}

.app_links_area .rt-section {
    opacity: 0;
    transform: translateY(10px);
    visibility: hidden;
    height: 0;
    overflow: hidden;
    transition: opacity .25s ease, transform .25s ease, height .25s ease;
}

.app_links_area .rt-section.rt-show {
    opacity: 1;
    transform: translateY(0);
    visibility: visible;
    height: auto;
    padding-inline: 0.75rem;
    padding-bottom: 2rem;
}

/* End App Links */

/* Start Shop */
.categories {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: scroll;
    scrollbar-width: thin;
    gap: 0.5rem;
}

.categories a {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.6rem;
    border-radius: 30px;
    border: 1px solid;
    width: 100%;
    font-weight: 500;
    opacity: .5;
    white-space: nowrap;
}

.categories a.active {
    opacity: 1;
    background: var(--rt-surface-bg-color, rgba(255, 255, 255, 0.15));
    border-color: var(--rt-border-color, transparent);
    box-shadow: rgba(10, 11, 13, 0.08) 0px 2px 4px 0px;
}

.tools_product_area {
    margin-top: 0.25rem;
    display: grid;
    align-items: center;
    grid-template-columns: 1fr 3%;
    gap: 0.5rem;
}

html[dir="rtl"] .tools_product_area {
    grid-template-columns: 1fr 8%;
}

.tools_product_area input {
    padding-block: 0.6rem;
    padding-inline: 1.25rem;
}

.tools_product_area .custom_filter svg {
    --aous-aw-icon-size: 1.5rem;
}

.products {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
    margin-top: 2rem;
}

.products .product_content {
    display: flex;
    flex-direction: column;
    background: rgba(255, 255, 255, 0.15);
    border-radius: 12px;
}

.products .product_content .product_img {
    padding-block: 1rem;
    text-align: center;
    height: 12rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.products .product_content .product_img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 12px;
    box-shadow: 2px 17px 10px #0000001c;
    margin-inline: 0.5rem;
}

.products .product_content .product_text {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    padding: 0.5rem;
}

.products .product_content .product_text .product_title {
    font-size: 0.9rem;
    font-weight: 700;
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    height: 3rem;
    text-align: center;
}

.products .product_content .product_text .product_price {
    font-size: 0.8rem;
    background: var(--rt-surface-bg-color, rgba(255, 255, 255, 0.15));
    border: 1px solid var(--rt-border-color, transparent);
    padding: 3px 10px;
    border-radius: 12px;
    font-weight: 700;
    mix-blend-mode: normal;
}

.products .product_content .product_text .product_status .badge {
    border-radius: 30px;
    overflow: hidden;
    padding-inline: 0.75rem;
}

.products .product_content .product_img {
    position: relative;
    overflow: hidden;
}

.products .product_content .product_img img {
    transition: transform 0.25s ease, opacity 0.2s ease;
}

.products .product_content:hover .product_img img {
    transform: scale(1.03);
}

.products .product_content .product_img img.img-fade-out {
    opacity: 0 !important;
    transform: scale(0.97) !important;
    transition: opacity 0.15s ease, transform 0.15s ease !important;
}

.product_gallery_badge {
    position: absolute;
    bottom: 4px;
    inset-inline-end: 0.25rem;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    backdrop-filter: blur(10px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.16);
}

.product_gallery_badge_icon {
    width: 17px;
    height: 17px;
}

.product_gallery_nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 26px;
    height: 26px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.14);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    backdrop-filter: blur(10px);
    opacity: 0;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.product_gallery_prev {
    inset-inline-start: 0.35rem;
}

.product_gallery_next {
    inset-inline-end: 0.35rem;
}

.products .product_content:hover .product_gallery_nav,
.products .product_content:focus-visible .product_gallery_nav {
    opacity: 1;
}

/* Start Product Info Modal */
#get_product_info {
    backdrop-filter: blur(10px);
    background: rgba(10, 18, 34, 0.28);
}

#get_product_info .modal-dialog {
    position: relative;
    inset: auto;
    bottom: auto;
    margin: 1.5rem auto;
    width: min(100% - 2.5rem, 620px);
    max-width: 620px;
    max-height: calc(100dvh - 3rem);
    display: flex;
    align-items: center;
}

#get_product_info.fade .modal-dialog {
    transform: translateY(56px) scale(0.985);
    transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1);
}

#get_product_info.show .modal-dialog {
    transform: translateY(0) scale(1);
}

.pi_modal {
    border: none !important;
    border-radius: 30px !important;
    width: 100%;
    max-height: calc(100dvh - 3rem);
    overflow: hidden;
    background:
        radial-gradient(circle at top right, rgba(99, 102, 241, 0.08), transparent 18rem),
        linear-gradient(180deg, #ffffff 0%, #fbfcff 100%);
    box-shadow: 0 24px 64px rgba(15, 23, 42, 0.2);
}

.pi_modal .modal-body {
    scrollbar-width: thin;
    scrollbar-color: transparent transparent;
    overscroll-behavior: contain;
}

.pi_topbar {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 14px 20px 8px;
    min-height: 54px;
    position: relative;
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.94) 0%, rgba(255, 255, 255, 0.84) 100%);
    border-bottom: 1px solid rgba(148, 163, 184, 0.12);
    backdrop-filter: blur(8px);
}

.pi_handle_bar {
    width: 40px;
    height: 5px;
    border-radius: 999px;
    background: linear-gradient(90deg, #cbd5e1 0%, #94a3b8 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.pi_close_btn {
    position: absolute !important;
    inset-inline-end: 18px !important;
    right: 18px !important;
    left: auto !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 42px !important;
    height: 42px !important;
    margin: 0 !important;
    padding: 0 !important;
    z-index: 10 !important;
    box-sizing: border-box;
    border-radius: 50%;
    border: 1px solid 1px solid rgb(200 200 200 / 57%);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.16);
    opacity: 1;
    transition: transform 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.pi_close_btn:hover,
.pi_close_btn:focus {
    transform: translateY(-50%) scale(1.04);
    background: rgba(255, 255, 255, 0.72) !important;
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.2);
}

.pi_close_btn:focus {
    outline: none;
}

.pi_close_btn::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.34), rgba(255, 255, 255, 0.08));
    pointer-events: none;
}

#get_product_info .frontend_product_slider {
    gap: 0.8rem;
}

#get_product_info .frontend_product_slider_stage {
    border-radius: 0;
    min-height: 13.5rem;
    max-height: 18rem;
}

#get_product_info .frontend_product_thumbs {
    padding: 0 1rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
}

#get_product_info .frontend_product_slide_img {
    height: clamp(13.5rem, 30vw, 18rem);
    object-fit: contain;
    background: #eef3fb;
}

#get_product_info .frontend_product_thumb img {
    height: 92px;
}

.pi_body {
    padding: 0.95rem 1.1rem 1.35rem;
}

.pi_title {
    font-size: 1.15rem;
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 0.35rem;
}

.pi_chips {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 0.2rem;
}

.pi_price_chip {
    display: inline-block;
    font-size: 0.88rem;
    font-weight: 700;
    padding: 3px 12px;
    border-radius: 99px;
    background: rgba(0, 0, 0, 0.06);
}

.pi_desc {
    font-size: 0.875rem;
    line-height: 1.65;
    opacity: 0.7;
    margin: 0.55rem 0 0.75rem;
    white-space: pre-wrap;
    word-break: break-word;
}

.pi_cta_btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    padding: 0.75rem 1.25rem;
    border-radius: 99px;
    font-weight: 600;
    font-size: 0.95rem;
    background: var(--aous-aw-bg-custom, #0069ff);
    color: #fff !important;
    text-decoration: none;
    margin: 0.75rem 0 1rem;
    transition: filter 0.2s ease;
}

.pi_cta_btn:hover {
    filter: brightness(0.88);
}

html[dir="rtl"] .pi_cta_btn svg {
    rotate: 180deg;
}

.pi_share_row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.pi_share_btn {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff !important;
    text-decoration: none !important;
    transition: opacity 0.2s ease, transform 0.15s ease;
}

.pi_share_btn:hover {
    opacity: 0.82;
    transform: scale(1.08);
}

.pi_share_fb {
    background: #1877F2;
}

.pi_share_wa {
    background: #25D366;
}

.pi_share_email {
    background: rgba(0, 0, 0, 0.1);
    color: inherit !important;
}

/* End Product Info Modal */

.frontend_product_slider {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.frontend_product_slider_stage {
    position: relative;
    border-radius: 18px;
    overflow: hidden;
    background: rgba(0, 0, 0, 0.04);
    min-height: 20rem;
}

.frontend_product_slide {
    display: none;
    width: 100%;
    height: 100%;
}

.frontend_product_slide.is-active {
    display: block;
}

.frontend_product_slide_img {
    width: 100%;
    height: 24rem;
    object-fit: cover;
    display: block;
}

.frontend_product_slider_nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 42px;
    height: 42px;
    border: 0;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.48);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 3;
    backdrop-filter: blur(10px);
}

.frontend_product_slider_prev {
    inset-inline-start: 0.85rem;
}

.frontend_product_slider_next {
    inset-inline-end: 0.85rem;
}

html[dir="rtl"] .product_gallery_nav svg,
html[dir="rtl"] .frontend_product_slider_nav svg {
    rotate: 180deg;
}

.frontend_product_slider_count {
    position: absolute;
    bottom: 0.85rem;
    inset-inline-end: 0.85rem;
    padding: 0.35rem 0.65rem;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.55);
    color: #fff;
    font-size: 0.76rem;
    font-weight: 700;
    z-index: 3;
}

.frontend_product_thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(72px, 1fr));
    gap: 0.55rem;
}

.frontend_product_thumb {
    padding: 0;
    border: 2px solid transparent;
    border-radius: 12px;
    background: transparent;
    overflow: hidden;
}

.frontend_product_thumb.is-active {
    border-color: var(--aous-aw-bg-custom);
}

.frontend_product_thumb img {
    width: 100%;
    height: 130px;
    object-fit: cover;
    display: block;
    border-radius: 10px;
}

/* End Shop */

/* Start App Footer */
.app_footer {
    text-align: center;
    padding-bottom: 0.5rem;
    padding-top: 2rem;
}

.app_footer a {
    font-size: 1rem;
    font-weight: 500;
}

/* End App Footer */

/* Start App Qr */
.app_qr {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    text-align: center;
}

.app_qr img {
    border-radius: 10px;
    padding: 6px;
    box-shadow: 0 3px 12px rgba(0, 0, 0, 0.25);
}

.app_qr span {
    display: block;
    font-size: 0.9rem;
    margin-bottom: 0.25rem;
}

/* End App Qr */

/* Start Animate Show  */

.animate {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity .45s ease, transform .45s ease;
}

.animate.show {
    opacity: 1;
    transform: translateY(0);
}

/* End Animate Show  */
/* Star Sweet Alerts */

#toast-container {
    z-index: 99999999999;
}

#toast-container.toast-top-center {
    top: 0.5rem;
    text-align: center;
}

#toast-container.toast-top-center .toast-success {
    color: white;
    background-color: var(--aous-aw-success) !important;
    border: unset !important;
}

#toast-container .toast {
    min-width: 280px;
    border-radius: 7px;
    z-index: 99999999999;
    padding-left: 1rem;
}

#toast-container .toast .toast-message {
    font-size: 14px;
    font-weight: 400;
}

#toast-container>.toast-error {
    background-color: var(--aous-aw-danger);
    box-shadow: none;
    opacity: 1;
    font-size: 0.9rem;
}

#toast-container>.toast-success {
    background-color: var(--aous-aw-success);
    box-shadow: none;
    opacity: 1;
    font-size: 0.9rem;
}

#toast-container>.toast-warning {
    background-color: var(--aous-aw-warning);
    box-shadow: none;
    opacity: 1;
    font-size: 0.9rem;
}

#toast-container>.toast-primary {
    background-color: var(--aous-aw-primary);
    box-shadow: none;
    opacity: 1;
    font-size: 0.9rem;
}

#toast-container>.toast-info {
    background-color: var(--aous-aw-bg-custom);
    box-shadow: none;
    opacity: 1;
    font-size: 0.9rem;
}

#toast-container>.toast-success,
#toast-container>.toast-info,
#toast-container>.toast-primary,
#toast-container>.toast-warning,
#toast-container>.toast-error {
    background-image: unset !important;
}

/* End Sweet Alerts */

.sensitive_material_area {
    mix-blend-mode: difference;
}

/* Start vCard Modal */

/* ── dialog sizing ── */
#vcard .modal-dialog.fvc_dialog {
    max-width: 520px;
    width: 100%;
    margin-inline: auto;
}

#vcard .fvc_modal {
    border-radius: 28px;
    overflow: hidden;
    border: none;
    padding: 0;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

/* ── header ── */
#vcard .fvc_header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 20px 14px;
}

#vcard .fvc_title {
    font-size: 1rem;
    font-weight: 700;
    color: #111;
    letter-spacing: -.2px;
}

/* ── card canvas ── */
#vcard .fvc_canvas_wrap {
    padding: 0 18px;
}

#vcard .fvc_card_canvas {
    width: 100%;
    aspect-ratio: 9/5;
    min-height: 180px;
    border-radius: 22px;
    overflow: hidden;
    position: relative;
    box-shadow: 0 12px 40px rgba(0, 0, 0, .18);
}

/* always show the single card (no layout switching) */
#vcard .fvc_card_canvas .vcp_card {
    display: flex !important;
    flex-direction: column;
}

/* ── QR section ── */
#vcard .fvc_qr_section {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    margin-top: 1rem;
    gap: 10px;
    padding: 18px 18px 4px;
}

#vcard .fvc_qr_inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 8px;
}

#vcard .fvc_qr_label {
    font-size: .78rem;
    font-weight: 600;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: .5px;
    margin: 0;
}

#vcard .fvc_qr_canvas {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 16px rgba(0, 0, 0, .12);
}

#vcard .fvc_qr_canvas canvas,
#vcard .fvc_qr_canvas img {
    display: block !important;
    border-radius: 8px;
}

#vcard .fvc_qr_name {
    font-size: .82rem;
    color: #64748b;
    text-align: center;
    margin: 0;
}

/* ── footer ── */
#vcard .fvc_footer {
    display: flex;
    gap: 10px;
    padding: 16px 18px 20px;
}

#vcard .fvc_btn {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    height: 46px;
    border-radius: 999px;
    font-size: .85rem;
    font-weight: 600;
    cursor: pointer;
    border: none;
    transition: opacity .2s;
}

#vcard .fvc_btn:disabled {
    opacity: .55;
    cursor: default;
}

#vcard .fvc_btn_outline {
    background: #f1f5f9;
    color: #334155;
    border: 1.5px solid #e2e8f0;
}

#vcard .fvc_btn_accent {
    background: var(--rt-single-color, #1e293b);
    color: var(--rt-single-color-text, #fff);
}

/* ══ CARD BASE ══ */
#vcard .vcp_card {
    width: 100%;
    height: 100%;
    position: relative;
    overflow: hidden;
    border-radius: 22px;
    display: none;
    font-family: inherit;
}

#vcard .vcp_card.active {
    display: flex;
    flex-direction: column;
}

#vcard .vcp_card.split.active {
    flex-direction: row !important;
}

#vcard .vcp_card_bg {
    position: absolute;
    inset: 0;
    border-radius: 22px;
    z-index: 0;
}

#vcard .vcp_card>* {
    position: relative;
    z-index: 1;
}

#vcard .vcp_card .vcp_card_bg {
    position: absolute;
    z-index: 0;
}

#vcard .vc_brand {
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 2px;
    opacity: .4 !important;
}

#vcard .vc_name {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.2;
}

#vcard .vc_role {
    font-size: 14px;
    line-height: 1.3;
}

#vcard .vc_contact {
    font-size: 14px;
    line-height: 1.5;
    opacity: 1 !important;
}

#vcard .nfc_icon {
    opacity: .55;
    width: 20px;
    height: 20px;
}

#vcard .vcc_card_qr canvas {
    display: block !important;
    border-radius: 4px;
}

#vcard .vcc_card_qr img {
    display: none !important;
}

/* ── CLASSIC ── */
#vcard .vcp_card.classic {
    padding: 12px 14px 10px;
    justify-content: space-between;
}

#vcard .classic_watermark {
    position: absolute;
    right: -10px;
    top: 6px;
    font-size: 80px;
    font-weight: 600;
    opacity: .05;
    z-index: 0;
    line-height: 1;
    pointer-events: none;
    user-select: none;
}

#vcard .classic_header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#vcard .classic_body {
    display: flex;
    flex-direction: column;
    gap: 3px;
    margin-top: 5px;
}

#vcard .classic_divider {
    width: 30px;
    height: 1.5px;
    border-radius: 1px;
    margin: 3px 0;
}

#vcard .classic_footer {
    display: flex;
    flex-direction: column;
    gap: 1px;
    max-width: 60%;
}

#vcard .classic_qr_corner {
    position: absolute;
    bottom: 8px;
    right: 8px;
    border: 1px solid;
    border-radius: 6px;
    padding: 3px;
}

html[dir="rtl"] #vcard .classic_qr_corner {
    right: unset;
    left: 8px;
}

/* ── CIRCLE ── */
#vcard .vcp_card.circle {
    padding: 0;
}

#vcard .circle_ring_lg,
#vcard .circle_ring_sm {
    position: absolute;
    border-radius: 50%;
    border: 1px solid;
    pointer-events: none;
    z-index: 0;
}

#vcard .circle_ring_lg {
    width: 140px;
    height: 140px;
    right: -42px;
    top: -42px;
}

#vcard .circle_ring_sm {
    width: 90px;
    height: 90px;
    right: -14px;
    top: -14px;
}

#vcard .circle_header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 11px 14px 0;
}

#vcard .circle_center {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 14px;
}

#vcard .circle_avatar_ring {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 2px solid;
    padding: 2px;
    flex-shrink: 0;
}

#vcard .circle_avatar_inner {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

#vcard .circle_initials {
    font-size: 13px;
    font-weight: 700;
}

#vcard .circle_info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding-right: 44px;
}

html[dir="rtl"] #vcard .circle_info {
    padding-right: unset;
    padding-left: 44px;
}

#vcard .circle_dot {
    width: 40px;
    height: 1.5px;
    border-radius: 1px;
    margin: 2px 0;
}

#vcard .circle_qr {
    position: absolute;
    bottom: 7px;
    right: 7px;
    border: 1px solid;
    border-radius: 6px;
    padding: 2px;
}

html[dir="rtl"] #vcard .circle_qr {
    right: unset;
    left: 7px;
}

/* ── SPLIT ── */
#vcard .split_strip {
    width: 32%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 11px 7px;
}

#vcard .split_avatar_ring {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, .5);
    display: flex;
    align-items: center;
    justify-content: center;
}

#vcard .split_initials {
    font-size: 13px;
    font-weight: 600;
    color: #fff;
}

#vcard .split_brand_label {
    font-size: 6px;
    font-weight: 700;
    letter-spacing: 3px;
    color: rgba(255, 255, 255, .6);
}

#vcard .split_right {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 10px 11px;
    position: relative;
}

#vcard .split_header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#vcard .split_body {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

#vcard .split_divider {
    width: 16px;
    height: 1.5px;
    border-radius: 1px;
    margin: 2px 0;
}

#vcard .split_footer {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

#vcard .split_contacts {
    display: flex;
    flex-direction: column;
    gap: 1px;
}

#vcard .split_qr {
    border: 1px solid;
    border-radius: 6px;
    padding: 2px;
}

/* ── MINIMAL ── */
#vcard .vcp_card.minimal {
    justify-content: flex-start;
}

#vcard .minimal_bar {
    height: 2px;
    width: 40%;
    border-radius: 0 2px 2px 0;
}

#vcard .minimal_inner {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 8px 14px 10px;
}

#vcard .minimal_header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#vcard .minimal_center {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

#vcard .minimal_name {
    font-size: 14px;
    font-weight: 700;
    letter-spacing: -.3px;
}

#vcard .minimal_line {
    width: 22px;
    height: 2px;
    border-radius: 1px;
    margin: 2px 0;
}

#vcard .minimal_footer {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

#vcard .minimal_contacts {
    display: flex;
    flex-direction: column;
    gap: 1px;
}

#vcard .minimal_qr {
    border: 1px solid;
    border-radius: 6px;
    padding: 2px;
}

/* ── HORIZON ── */
#vcard .vcp_card.horizon {
    justify-content: flex-start;
}

#vcard .horizon_top {
    display: flex;
    align-items: center;
    gap: 9px;
    flex: 1;
    padding: 10px 11px 7px;
}

#vcard .horizon_avatar_ring {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1.5px solid;
    padding: 2px;
    flex-shrink: 0;
}

#vcard .horizon_avatar_inner {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

#vcard .horizon_info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

#vcard .horizon_accent_line {
    width: 14px;
    height: 1.5px;
    border-radius: 1px;
    margin: 1px 0;
}

#vcard .horizon_brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

#vcard .horizon_sep {
    height: 1px;
    margin: 0 11px;
}

#vcard .horizon_bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 7px 11px 10px;
}

#vcard .horizon_contacts {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
    padding-right: 7px;
}

#vcard .horizon_contact_row {
    display: flex;
    align-items: center;
    gap: 4px;
}

#vcard .horizon_qr {
    border: 1px solid;
    border-radius: 6px;
    padding: 2px;
}

/* ── RETRO ── */
#vcard .vcp_card.retro {
    padding: 7px;
}

#vcard .retro_frame {
    flex: 1;
    border: 1px solid;
    border-radius: 9px;
    padding: 7px 9px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
}

#vcard .retro_dot {
    position: absolute;
    width: 4px;
    height: 4px;
    border-radius: 50%;
}

#vcard .retro_dot_tl {
    top: -2px;
    left: -2px;
}

#vcard .retro_dot_tr {
    top: -2px;
    right: -2px;
}

#vcard .retro_dot_bl {
    bottom: -2px;
    left: -2px;
}

#vcard .retro_dot_br {
    bottom: -2px;
    right: -2px;
}

#vcard .retro_header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#vcard .retro_brand {
    font-size: 6px;
    font-weight: 600;
    letter-spacing: 3px;
    opacity: .75;
}

#vcard .retro_rule {
    border: none;
    border-bottom: 1px dashed;
    margin: 4px 0;
}

#vcard .retro_center {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 1px 0;
}

#vcard .retro_footer {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

#vcard .retro_contacts {
    display: flex;
    flex-direction: column;
    gap: 1px;
    flex: 1;
    padding-right: 6px;
}

#vcard .retro_qr {
    border: 1px solid;
    border-radius: 5px;
    padding: 2px;
}

/* ── NEON ── */
#vcard .vcp_card.neon {
    padding: 0;
}

#vcard .neon_scanline {
    position: absolute;
    left: 0;
    right: 0;
    height: 1px;
    pointer-events: none;
    z-index: 0;
}

#vcard .neon_glow_blob {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

#vcard .neon_corner {
    position: absolute;
    z-index: 2;
    width: 13px;
    height: 13px;
}

#vcard .neon_corner_tl {
    top: 7px;
    left: 7px;
    border-top: 2px solid;
    border-left: 2px solid;
    border-radius: 4px 0 0 0;
}

#vcard .neon_corner_br {
    bottom: 7px;
    right: 7px;
    border-bottom: 2px solid;
    border-right: 2px solid;
    border-radius: 0 0 4px 4px;
}

#vcard .neon_inner {
    flex: 1;
    display: flex;
    flex-direction: column;
    position: relative;
    z-index: 1;
}

#vcard .neon_header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 13px 0;
}

#vcard .neon_rt {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 4px;
    text-shadow: 0 0 8px currentColor;
}

#vcard .neon_center {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 6px 13px;
}

#vcard .neon_avatar_outer {
    width: 36px;
    height: 36px;
    border-radius: 9px;
    border: 1.5px solid;
    padding: 2px;
    flex-shrink: 0;
    box-shadow: 0 0 8px currentColor;
}

#vcard .neon_avatar_inner {
    width: 100%;
    height: 100%;
    border-radius: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
}

#vcard .neon_name_block {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

#vcard .neon_name {
    font-size: 12px;
    font-weight: 700;
}

#vcard .neon_underline {
    width: 20px;
    height: 1.5px;
    border-radius: 1px;
    box-shadow: 0 0 6px currentColor;
    margin: 1px 0;
}

#vcard .neon_role {
    font-size: 8px;
    font-weight: 600;
    letter-spacing: .5px;
}

#vcard .neon_footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 13px 10px;
}

#vcard .neon_contacts {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding-right: 7px;
}

#vcard .neon_contact_row {
    display: flex;
    align-items: center;
    gap: 4px;
}

#vcard .neon_qr {
    border: 1px solid;
    border-radius: 6px;
    padding: 2px;
    box-shadow: 0 0 8px currentColor;
}

/* End vCard Modal */

/* Start Calendar */

#appointment_calendar .calendly_modal {
    border-radius: 28px;
    padding-block: 0;
    min-width: 26rem;
    overflow: hidden;
    border: none;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.14);
}

#appointment_calendar .modal-header {
    margin-top: 0;
    padding: 1.35rem 1.5rem 1.1rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    background: #fff;
}

#appointment_calendar .modal-header h3 {
    font-size: 1.15rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 0.2rem;
}

#appointment_calendar .modal-header p {
    font-size: 0.8rem;
    color: #64748b;
    margin: 0;
}

#appointment_calendar .calendly_body {
    padding: 1.25rem 1.35rem 1.35rem;
    background: #f8fafc;
}

#appointment_calendar .calendly_body .wizard_steps .wizard_step {
    opacity: 1;
    transform: translateX(0);
    transition: all .3s ease;
    position: relative;
}

#appointment_calendar .calendly_body .wizard_steps .wizard_step.d-none {
    display: none !important;
}

#appointment_calendar .calendly_body .wizard_steps .wizard_step .preview_date_content {
    margin-bottom: 1.1rem;
    padding: 0.85rem 1rem;
    background: #fff;
    border-radius: 14px;
    border: 1px solid rgba(0, 0, 0, 0.07);
}

#appointment_calendar .calendly_body .wizard_steps .wizard_step .preview_date_content .preview_date {
    font-size: 0.95rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 0.2rem;
    display: block;
}

#appointment_calendar .calendly_body .wizard_steps .wizard_step .preview_date_content .preview_time {
    font-size: 0.82rem;
    color: #64748b;
    display: block;
}

#appointment_calendar .calendly_body .wizard_steps .wizard_step .is-invalid {
    border: 1px solid #dc3545 !important;
}

#appointment_calendar .calendly_body .wizard_steps .wizard_step button {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding-block: 0.75rem;
    border-radius: 30px;
}

/* Primary action buttons use the design system accent */
#appointment_calendar .btn-primary {
    background: var(--rt-single-color, #0f172a);
    border-color: var(--rt-single-color, #0f172a);
    color: var(--rt-single-color-text, #fff);
}

#appointment_calendar .btn-primary:hover,
#appointment_calendar .btn-primary:focus {
    background: var(--rt-single-color, #0f172a);
    border-color: var(--rt-single-color, #0f172a);
    color: var(--rt-single-color-text, #fff);
    filter: brightness(0.9);
}

/* Calendar card container */
#appointment_calendar .calendly_body .wizard_steps .wizard_step .calendly-calendar {
    width: 100%;
    padding: 1rem;
    background: #fff;
    border-radius: 18px;
    border: 1px solid rgba(0, 0, 0, 0.07);
}

/* Calendar header */
#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-header .month-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: #0f172a;
    letter-spacing: -0.01em;
}

#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-header .nav-btn-calendar {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 1px solid rgba(0, 0, 0, 0.1);
    background: #fff;
    cursor: pointer;
    color: #334155;
    transition: background 0.18s, border-color 0.18s;
}

#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-header .nav-btn-calendar#prevMonth {
    background: #fff;
    color: #334155;
}

#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-header .nav-btn-calendar:hover {
    background: #f1f5f9;
    border-color: rgba(0, 0, 0, 0.18);
}

/* Weekday labels */
#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    font-size: 0.68rem;
    font-weight: 600;
    color: #94a3b8;
    margin-bottom: 8px;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* Calendar grid */
#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 3px;
}

#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-day {
    width: 100%;
    aspect-ratio: 1/1;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    font-weight: 400;
    font-size: 0.84rem;
    cursor: default;
    color: #cbd5e1;
    position: relative;
}

/* Available days */
#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-day.enabled {
    cursor: pointer;
    color: var(--rt-single-color, #0f172a);
    font-weight: 700;
    transition: background 0.18s ease, transform 0.15s ease;
}

#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-day.enabled::after {
    content: '';
    position: absolute;
    bottom: 2px;
    left: 50%;
    transform: translateX(-50%);
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--rt-single-color, #0f172a);
    opacity: 0.45;
}

#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-day.enabled:hover {
    background: rgba(0, 0, 0, 0.05);
    transform: scale(1.1);
}

#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-day.disabled {
    color: #595a5a;
    opacity: 0.55;
}

#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-day.selected {
    background: var(--rt-single-color, #0f172a) !important;
    color: var(--rt-single-color-text, #fff) !important;
    font-weight: 700 !important;
    transform: scale(1.12) !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18) !important;
}

#appointment_calendar .wizard_steps .wizard_step .calendly-calendar .calendar-day.selected::after {
    display: none;
}

/* Time slot heading */
#appointment_calendar .wizard_steps .wizard_step .available_times_area h4 {
    font-size: 0.88rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 0.85rem;
}

/* Slot grid — 2 columns */
#appointment_calendar .wizard_steps .wizard_step .available_times_area .slots_grid {
    overflow-y: auto;
    max-height: 22rem;
    scrollbar-width: thin;
    scrollbar-color: transparent transparent;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
    align-content: start;
    padding-block: 0.5rem;
}

#appointment_calendar .wizard_steps .wizard_step .available_times_area .slots_grid .slot_item {
    padding: 0.65rem 0.75rem;
    border: 1.5px solid rgba(0, 0, 0, 0.09);
    display: flex;
    border-radius: 12px;
    align-items: center;
    justify-content: center;
    gap: 6px;
    cursor: pointer;
    background: #fff;
    transition: border-color 0.18s, background 0.18s, transform 0.15s;
}

#appointment_calendar .wizard_steps .wizard_step .available_times_area .slots_grid .slot_item.disabled {
    opacity: 0.35;
    pointer-events: none;
    background: #f8fafc;
}

#appointment_calendar .wizard_steps .wizard_step .available_times_area .slots_grid .slot_item:hover {
    border-color: var(--rt-single-color, #0f172a);
    background: #f8fafc;
    transform: translateY(-1px);
}

#appointment_calendar .wizard_steps .wizard_step .available_times_area .slots_grid .slot_item.active {
    border-color: var(--rt-single-color, #0f172a) !important;
    background: var(--rt-single-color, #0f172a) !important;
    color: var(--rt-single-color-text, #fff) !important;
    transform: translateY(-1px);
}

#appointment_calendar .wizard_steps .wizard_step .available_times_area .slots_grid .slot_icon {
    font-size: 16px;
    opacity: 0.6;
}

#appointment_calendar .wizard_steps .wizard_step .available_times_area .slots_grid .slot_text {
    font-size: 0.83rem;
    font-weight: 600;
}

/* Booking form */
#appointment_calendar .wizard_steps .wizard_step .info_form_content .summary_box {
    margin-bottom: 1rem;
}

#appointment_calendar .wizard_steps .wizard_step .info_form_content .ts-control {
    margin-bottom: 0.75rem;
    padding-block: 1rem;
}

html[dir="rtl"] #appointment_calendar .wizard_steps .wizard_step .info_form_content .ts-control {
    padding-right: 0.5rem !important;
}

#appointment_calendar .wizard_steps .wizard_step .info_form_content .ts-control,
#appointment_calendar .wizard_steps .wizard_step .info_form_content .form-control {
    border: 1.5px solid rgba(0, 0, 0, 0.09);
    border-radius: 12px;
    background: #fff;
}

#appointment_calendar .wizard_steps .wizard_step .info_form_content .form-control:focus {
    border-color: var(--rt-single-color, #0f172a);
    box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.06);
}

#appointment_calendar .wizard_steps .wizard_step .info_form_content textarea {
    min-height: 6rem;
}

#appointment_calendar .wizard_steps .wizard_step .info_form_content .ts-dropdown {
    border: 1.5px solid rgba(0, 0, 0, 0.09) !important;
    border-radius: 12px;
}

#appointment_calendar .wizard_steps .wizard_step .info_form_content #confirm_booking_btn {
    margin-top: 0.5rem;
    width: 100%;
    padding-block: 0.8rem;
    font-size: 0.9rem;
    border-radius: 30px;
    background: var(--rt-single-color, #0f172a);
    border-color: var(--rt-single-color, #0f172a);
    color: var(--rt-single-color-text, #fff);
}

.ts-dropdown [data-selectable].option {
    padding-block: 0.6rem;
}

.tom_select .ts-control::after {
    content: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg'  viewBox='0 0 24 24'><path fill-rule='evenodd' d='M11.341 4.747a1 1 0 0 1 1.318 0l4 3.5a1 1 0 1 1-1.317 1.506L12 6.829 8.659 9.753a1 1 0 0 1-1.317-1.506l4-3.5Zm-4.095 9.61a1 1 0 0 1 1.41-.096L12 17.174l3.343-2.913a1 1 0 1 1 1.314 1.508l-4 3.485a1 1 0 0 1-1.314 0l-4-3.485a1 1 0 0 1-.097-1.411Z' clip-rule='evenodd'></path></svg>");
    position: absolute;
    top: 50%;
    right: 5px;
    width: 1.09rem;
    height: 1rem;
    pointer-events: none;
    transform: translate(0, -50%);
    opacity: .5;
}

.theme-dark .tom_select .ts-control::after {
    content: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg'  viewBox='0 0 24 24'><path fill-rule='evenodd' fill='white' d='M11.341 4.747a1 1 0 0 1 1.318 0l4 3.5a1 1 0 1 1-1.317 1.506L12 6.829 8.659 9.753a1 1 0 0 1-1.317-1.506l4-3.5Zm-4.095 9.61a1 1 0 0 1 1.41-.096L12 17.174l3.343-2.913a1 1 0 1 1 1.314 1.508l-4 3.485a1 1 0 0 1-1.314 0l-4-3.485a1 1 0 0 1-.097-1.411Z' clip-rule='evenodd'></path></svg>");
}

html[dir="rtl"] .tom_select .ts-control::after {
    left: 5px;
    right: unset;
}

/* End Calendar */

/* Start Share Modal */

#share_link .sl_modal {
    border-radius: 28px;
    border: none;
    overflow: hidden;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.14);
}

#share_link .sl_header {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem 1.5rem 0.85rem;
    position: relative;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

#share_link .sl_title {
    font-size: 1rem;
    font-weight: 700;
    color: #0f172a;
}

#share_link .sl_close {
    position: absolute !important;
    inset-inline-end: 1rem;
    top: 50%;
    transform: translateY(-50%);
}

#share_link .sl_qr_area {
    text-align: center;
    padding: 1.25rem 1.5rem 1rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

#share_link .qr_content_link {
    display: inline-block;
    margin-bottom: 0.6rem;
    margin: 0 auto 0.6rem;
}

#share_link .qr_content_link img {
    padding: 8px;
    box-shadow: 0 4px 18px rgba(0, 0, 0, 0.12);
    border-radius: 16px;
    display: block;
    background: #fff;
}

#share_link .sl_url_preview {
    font-size: 0.74rem;
    color: #94a3b8;
    margin: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
    padding-inline: 0.5rem;
}

#share_link .sl_actions {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    padding: 1.1rem 1rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

#share_link .sl_action_item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.45rem;
    text-decoration: none !important;
    color: #0f172a !important;
    padding: 0.25rem;
}

#share_link .sl_action_icon {
    width: 52px;
    height: 52px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    transition: transform 0.18s ease, opacity 0.18s ease;
}

#share_link .sl_action_item:hover .sl_action_icon {
    transform: scale(1.09);
    opacity: 0.88;
}

#share_link .sl_action_icon svg {
    --aous-aw-icon-size: 1.45rem;
    width: 1.45rem;
    height: 1.45rem;
}

#share_link .sl_action_label {
    font-size: 0.69rem;
    font-weight: 500;
    color: #475569;
    text-align: center;
    max-width: 60px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#share_link .sl_fb {
    background: #1877F2;
}

#share_link .sl_wa {
    background: #25D366;
}

#share_link .sl_mail {
    background: #64748b;
}

#share_link .sl_more {
    background: var(--rt-single-color, #1e293b);
}

#share_link .sl_copy_bar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.85rem 1rem 1.1rem;
}

#share_link .sl_copy_url {
    flex: 1;
    min-width: 0;
    font-size: 0.76rem;
    color: #64748b;
    background: #f1f5f9;
    border-radius: 10px;
    padding: 0.55rem 0.75rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: block;
}

#share_link .sl_copy_btn {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.55rem 1rem;
    border-radius: 10px;
    border: none;
    background: var(--rt-single-color, #1e293b);
    color: var(--rt-single-color-text, #fff);
    font-size: 0.8rem;
    font-weight: 600;
    white-space: nowrap;
    cursor: pointer;
    flex-shrink: 0;
    transition: filter 0.18s ease;
}

#share_link .sl_copy_btn:hover {
    filter: brightness(0.9);
}

#share_link .sl_copy_btn svg {
    width: 14px;
    height: 14px;
}

/* End Share Modal */

/* Start Background Image */
.background_image_area .background_image_template {
    height: 100%;
    width: 100%;
    position: absolute;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.background_image_area .background_image_template_overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 999;
}

.with_background_image .app_body .app_bar {
    position: absolute;
    top: 0;
    right: 0.5rem;
    width: 100%;
}

html[dir="rtl"] .with_background_image .app_body .app_bar {
    right: unset;
    left: unset;
}

.with_background_image .app_title,
.with_background_image .rt-segmented {
    display: none;
}

.background_image_area .message_text_area,
.background_image_area .names_area {
    z-index: 999;
    position: relative;
    text-align: center;
    margin-top: 5.5rem;
    padding-inline: 2rem;
}

.background_image_area .names_area span {
    display: block;
    margin-bottom: 0.5rem;
}

.background_image_area .message_text_area h2 {
    font-size: 1.3rem;
    margin-bottom: 2rem;
}

.background_image_area .message_text_area h3 {
    font-size: 1.3rem;
    line-height: 1.3;
    margin-bottom: 1rem;
}

html[dir="rtl"] .background_image_area .message_text_area h3 {
    line-height: 2;
}

.background_image_area .names_area .names_content {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-top: 1.5rem;
}

.background_image_area .names_area .names_content h3 {
    font-size: 1.5rem;
    border-radius: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    font-weight: 500;
    box-shadow: rgba(10, 11, 13, 0.08) 0px 2px 4px 0px;
    border-radius: 50%;
    padding-block: 4rem;
}

.background_image_area .names_area .large_text {
    font-size: 2.4rem;
    line-height: 1.25;
    font-weight: 700;
    margin-top: 2rem;
}

.with_background_image #rt-shop {
    display: none;
}

/* End Background Image */

.search_product_input::placeholder {
    color: var(--placeholder-color);
    opacity: 1;
}

.search_product_input::-webkit-input-placeholder {
    color: var(--placeholder-color);
}

.search_product_input::-moz-placeholder {
    color: var(--placeholder-color);
}

.search_product_input:-ms-input-placeholder {
    color: var(--placeholder-color);
}


/* Start Custom Filter Modal */

#custom_filter .cf_modal {
    border-radius: 28px;
    border: none;
    overflow: hidden;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.14);
}

/* Header */
#custom_filter .cf_header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.1rem 1.25rem 0.95rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

#custom_filter .cf_title {
    font-size: 1rem;
    font-weight: 700;
    color: #0f172a;
}

#custom_filter .cf_header_right {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-right: 2rem;
}

html[dir="rtl"] #custom_filter .cf_header_right {
    margin-right: unset;
    margin-left: 2rem;
}

#custom_filter .cf_reset_btn {
    font-size: 0.78rem;
    font-weight: 600;
    color: #94a3b8;
    background: none;
    border: 1px solid rgba(0, 0, 0, 0.1);
    cursor: pointer;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    transition: color 0.15s, border-color 0.15s;
    line-height: 1.5;
}

#custom_filter .cf_reset_btn:hover {
    color: #475569;
    border-color: rgba(0, 0, 0, 0.2);
}

/* Section */
#custom_filter .cf_section {
    padding: 0.9rem 1.25rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

#custom_filter .cf_section_label {
    display: block;
    font-size: 0.7rem;
    font-weight: 700;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    margin-bottom: 0.5rem;
}

/* Sort list — radio style */
#custom_filter .cf_sort_list {
    display: flex;
    flex-direction: column;
    gap: 0;
}

#custom_filter .cf_sort_item {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    width: 100%;
    padding: 0.6rem 0;
    background: none;
    border: none;
    border-bottom: 1px solid rgba(0, 0, 0, 0.04);
    cursor: pointer;
    text-align: start;
    transition: background 0.15s;
}

#custom_filter .cf_sort_item:last-child {
    border-bottom: none;
}

#custom_filter .cf_sort_icon {
    width: 32px;
    height: 32px;
    border-radius: 10px;
    background: #f1f5f9;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background 0.18s;
}

#custom_filter .cf_sort_item.active .cf_sort_icon {
    background: var(--rt-single-color, #1e293b);
    color: var(--rt-single-color-text, #fff);
}

#custom_filter .cf_sort_icon svg {
    width: 15px;
    height: 15px;
}

#custom_filter .cf_sort_text {
    flex: 1;
    font-size: 0.85rem;
    font-weight: 500;
    color: #334155;
}

#custom_filter .cf_sort_item.active .cf_sort_text {
    color: #0f172a;
    font-weight: 700;
}

#custom_filter .cf_sort_check {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 1.5px solid #e2e8f0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background 0.18s, border-color 0.18s;
}

#custom_filter .cf_sort_item.active .cf_sort_check {
    background: var(--rt-single-color, #1e293b);
    border-color: var(--rt-single-color, #1e293b);
}

#custom_filter .cf_sort_check svg {
    width: 10px;
    height: 10px;
    color: var(--rt-single-color-text, #fff);
    opacity: 0;
    transition: opacity 0.15s;
}

#custom_filter .cf_sort_item.active .cf_sort_check svg {
    opacity: 1;
}

/* Price range */
#custom_filter .cf_price_header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

#custom_filter .cf_price_vals {
    font-size: 0.8rem;
    font-weight: 700;
    color: #0f172a;
    background: #f1f5f9;
    padding: 0.2rem 0.6rem;
    border-radius: 8px;
}

/* Range wrap — track + sliders overlaid */
#custom_filter .cf_range_wrap {
    position: relative;
    height: 24px;
}

#custom_filter .cf_range_track {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 4px;
    transform: translateY(-50%);
    border-radius: 999px;
    background: #e2e8f0;
    pointer-events: none;
}

#custom_filter .cf_range_fill {
    position: absolute;
    height: 100%;
    border-radius: 999px;
    background: var(--rt-single-color, #1e293b);
    left: 0%;
    right: 0%;
}

/* Footer */
#custom_filter .cf_footer {
    padding: 0.85rem 1.25rem 1.1rem;
}

#custom_filter .cf_apply_btn {
    width: 100%;
    padding: 0.8rem;
    border-radius: 999px;
    border: none;
    background: var(--rt-single-color, #1e293b);
    color: var(--rt-single-color-text, #fff);
    font-size: 0.88rem;
    font-weight: 700;
    cursor: pointer;
    transition: filter 0.18s ease;
}

#custom_filter .cf_apply_btn:hover {
    filter: brightness(0.9);
}

#custom_filter .cf_apply_btn.no_results {
    opacity: 0.45;
    cursor: not-allowed;
}

/* End Custom Filter Modal */

/* Start Range Slider */

.range-slider {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 100%;
}

.range-slider input[type=range] {
    position: absolute;
    width: 100%;
    top: 3px;
    transform: translateY(-50%);
    height: 24px;
    margin: 0;
    padding: 0;
    pointer-events: none;
    -webkit-appearance: none;
    appearance: none;
    background: transparent;
}

.range-slider input[type=range]::-webkit-slider-thumb {
    pointer-events: all;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--rt-single-color, #1e293b);
    border: 3px solid #fff;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.22);
    -webkit-appearance: none;
    cursor: pointer;
    transition: transform 0.15s ease;
}

.range-slider input[type=range]::-webkit-slider-thumb:hover {
    transform: scale(1.12);
}

.range-slider input[type=range]::-webkit-slider-runnable-track {
    height: 4px;
    background: transparent;
    border-radius: 999px;
}

.range-slider input[type=range]:nth-child(2)::-webkit-slider-runnable-track {
    background: transparent;
}

/* End Range Slider */
