/* DiamondPlus Custom Styles */

/* ===== EXACT LIVE SITE - Marquee Styles ===== */
.breadcrumb-marquee {
    overflow: hidden;
    padding: 8px 6px;
}

.marquee {
    display: flex;
    overflow: hidden;
    user-select: none;
    gap: 0.75rem;
}

.marquee--hover-pause:hover .marquee__content {
    animation-play-state: paused;
}

.marquee__content {
    flex-shrink: 0;
    display: flex;
    justify-content: space-around;
    gap: 0.75rem;
    align-items: center;
    min-width: 75%;
    animation: scroll 30s linear infinite;
}

.marquee__content > div {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background-color: #1f2544;
    border-radius: 0.4rem;
    padding: 0.4rem 0.75rem;
    margin-right: 0.5rem;
    flex-shrink: 0;
}
.currency-badge {
    font-weight: 700 !important;
    font-size: 0.875rem !important;
    padding: 0.25em 0.5em !important;
    letter-spacing: 0.3px;
    background-color: transparent !important;
    color: #fff !important;
    border-radius: 0.25rem;
}

.marquee__content > div > .fs-6 {
    color: #fff !important;
    font-weight: 500;
    font-size: 0.875rem !important;
    white-space: nowrap;
}

@keyframes scroll {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(-100%);
    }
}

/* Enable animation class */
.enable-animation .marquee__content {
    animation: scroll 30s linear infinite;
}

.dir-ltr {
    direction: ltr;
}

/* ===== Color Scheme ===== */

body {
    background-color: #f3f6f9 !important;
}

.text-muted {
    color: #6c757d !important;
}

p, span, div, li, td, th, label, a:not(.btn) {
    color: inherit;
}

.justify-items-center {
    justify-items: center !important;
}

.pagination {
    --vz-pagination-active-bg: #0ab39c;
    --vz-pagination-active-border-color: #0ab39c;
}

.select2-container .select2-selection--multiple .select2-selection__choice,
.select2-container--default .select2-results__option[aria-selected="true"]:hover {
    background-color: #0ab39c;
}

.select2-container .select2-selection--multiple .select2-selection__rendered {
    display: contents !important;
}

.form-select {
    height: calc(1.5em + 1rem + 2px);
}

[data-control="select2"].dropup .dropdown-menu {
    bottom: auto !important;
}

.select2-container--default .select2-selection--single .select2-selection__clear {
    height: 35px;
    padding-right: 20px;
}

.text-webkit-center {
    text-align: -webkit-center;
}

/* ===== Root Variables - Exact from Live Site ===== */
:root {
    --vz-primary: #1f2544;
    --vz-primary-rgb: 31, 37, 68;
    --vz-primary-hover: #363b5d;
    --vz-navbar-hover-color: var(--vz-primary-hover);
    --vz-vertical-menu-item-active-color: var(--vz-primary);
    --vz-link-color: var(--vz-primary);
}

/* ===== Buttons ===== */
.btn-primary {
    --vz-btn-color: #fff;
    --vz-btn-bg: var(--vz-primary);
    --vz-btn-border-color: var(--vz-primary);
    --vz-btn-hover-color: #fff;
    --vz-btn-hover-bg: var(--vz-primary-hover);
    --vz-btn-hover-border-color: #33416e;
    --vz-btn-focus-shadow-rgb: 93, 107, 155;
    --vz-btn-active-color: #fff;
    --vz-btn-active-bg: #33416e;
    --vz-btn-active-border-color: #303d67;
    --vz-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --vz-btn-disabled-color: #fff;
    --vz-btn-disabled-bg: var(--vz-primary);
    --vz-btn-disabled-border-color: var(--vz-primary);
}

.btn-navy {
    background-color: #405189;
    border-color: #405189;
    color: #fff;
    --vz-btn-color: #fff;
    --vz-btn-bg: #405189;
    --vz-btn-border-color: #405189;
    --vz-btn-hover-bg: #3a4a7d;
    --vz-btn-hover-border-color: #3a4a7d;
}
.btn-navy:hover { background-color: #3a4a7d; border-color: #3a4a7d; color: #fff; }

.btn-ghost-primary {
    --vz-btn-color: #0ab39c;
    --vz-btn-bg: transparent;
    --vz-btn-border-color: transparent;
    --vz-btn-hover-bg: rgba(10, 179, 156, 0.1);
    --vz-btn-active-bg: rgba(10, 179, 156, 0.1);
}

.btn-outline-primary {
    --vz-btn-color: #0ab39c;
    --vz-btn-border-color: #0ab39c;
    --vz-btn-hover-color: #fff;
    --vz-btn-hover-bg: #0ab39c;
    --vz-btn-hover-border-color: #0ab39c;
    --vz-btn-active-color: #fff;
    --vz-btn-active-bg: #0ab39c;
    --vz-btn-active-border-color: #0ab39c;
    --vz-btn-disabled-color: #0ab39c;
    --vz-btn-disabled-border-color: #0ab39c;
}

.bg-soft-primary { background-color: rgba(64, 81, 137, 0.18) !important; }
.bg-soft-navy    { background-color: rgba(64, 81, 137, 0.18) !important; }
.btn-soft-primary { background-color: rgba(64,81,137,.1); color: #405189; border-color: transparent; }
.btn-soft-primary:hover { background-color: #405189; color: #fff; }

/* ===== Font: Nunito Sans (matches live site inline style) ===== */
body,
.btn,
.navbar-menu .navbar-nav .nav-link,
.navbar-menu .navbar-nav .nav-sm .nav-link,
.ff-secondary,
.leaflet-map.leaflet-container,
.chat-list > li a,
.contact-list li,
.h1, .h2, .h3, .h4, .h5, .h6,
h1, h2, h3, h4, h5, h6 {
    font-family: 'Nunito Sans', sans-serif;
}

/* Headings need explicit weight — Bootstrap default 500 looks too light with Nunito Sans */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-weight: 600;
}

b, strong {
    font-weight: 700;
}

/* ===== Cards ===== */
.card {
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
    border: 1px solid #f0f0f0;
    border-radius: 0.5rem;
}
.card-animate {
    transition: box-shadow 0.2s ease;
}
.card-animate:hover {
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}
.card-header {
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* ===== Tables ===== */
.table > :not(caption) > * > * {
    padding: 0.65rem 0.75rem;
}
.table thead th {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
    color: #878a99;
    border-bottom-width: 1px !important;
}
.table-primary thead th,
.table-primary thead tr th {
    background-color: #fff !important;
    color: #6c757d !important;
    border-color: #dee2e6 !important;
    border-bottom: 2px solid #dee2e6 !important;
}
.table-card .table {
    margin-bottom: 0;
}
.table tbody tr {
    transition: background-color 0.15s ease;
}
.table tbody tr:hover {
    background-color: rgba(64, 81, 137, 0.03);
}
.table-responsive {
    border-radius: 0 0 0.5rem 0.5rem;
}

/* ===== Avatar ===== */
.avatar-title {
    font-weight: 600;
    letter-spacing: 0.5px;
}

/* Colored initials avatars matching live site */
.avatar-initials {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    font-size: 13px;
    font-weight: 600;
    color: #fff;
    flex-shrink: 0;
    letter-spacing: 0.5px;
}
.avatar-initials-teal   { background-color: #0ab39c; }
.avatar-initials-navy   { background-color: #405189; }
.avatar-initials-orange { background-color: #f06548; }
.avatar-initials-blue   { background-color: #299cdb; }
.avatar-initials-purple { background-color: #7c6fcd; }
.avatar-initials-pink   { background-color: #e83e8c; }
.avatar-initials-yellow { background-color: #f7b84b; }

/* ===== Badges ===== */
.badge {
    font-weight: 500;
    padding: 0.3em 0.65em;
    border-radius: 0.35rem;
    font-size: 11px;
    letter-spacing: 0.3px;
}

/* Soft badge variants */
.btn-soft-primary { background-color: rgba(64,81,137,.1); color: #405189; border-color: transparent; }
.btn-soft-primary:hover { background-color: #405189; color: #fff; }
.btn-soft-secondary { background-color: rgba(108,117,125,.1); color: #6c757d; border-color: transparent; }
.btn-soft-secondary:hover { background-color: #6c757d; color: #fff; }
.btn-soft-success { background-color: rgba(34, 197, 94, 0.12); color: #34c759; border-color: transparent; }
.btn-soft-success:hover { background-color: #34c759; color: #fff; }
.btn-soft-danger { background-color: rgba(240,101,72,.1); color: #f06548; border-color: transparent; }
.btn-soft-danger:hover { background-color: #f06548; color: #fff; }
.btn-soft-warning { background-color: rgba(247,184,75,.1); color: #e6a817; border-color: transparent; }
.btn-soft-warning:hover { background-color: #f7b84b; color: #fff; }
.btn-soft-info { background-color: rgba(41,156,219,.1); color: #299cdb; border-color: transparent; }
.btn-soft-info:hover { background-color: #299cdb; color: #fff; }
.btn-soft-dark { background-color: rgba(33,37,41,.1); color: #343a40; border-color: transparent; }
.btn-soft-dark:hover { background-color: #343a40; color: #fff; }

/* ===== Links ===== */
a.text-decoration-underline {
    text-decoration: none !important;
    color: var(--vz-primary);
}

/* ===== Progress ===== */
.progress {
    border-radius: 10px;
    background-color: #f3f3f9;
}
.progress-bar {
    border-radius: 10px;
}

/* ===== Dropdowns ===== */
.dropdown-menu {
    box-shadow: 0 5px 25px rgba(0, 0, 0, 0.1);
    border: 1px solid #f0f0f0;
    border-radius: 0.4rem;
}
.dropdown-item {
    font-size: 13px;
    padding: 0.4rem 1rem;
}

/* ===== Modals ===== */
.modal-content {
    border: none;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    border-radius: 0.5rem;
}
.modal-header {
    border-bottom: 1px solid #f0f0f0;
}
.modal-footer {
    border-top: 1px solid #f0f0f0;
}

/* ===== Forms ===== */
.form-control:focus,
.form-select:focus {
    border-color: #0ab39c;
    box-shadow: 0 0 0 0.15rem rgba(10, 179, 156, 0.15);
}

.form-label {
    margin-bottom: 0.35rem;
    font-size: 13px;
    font-weight: 500;
    color: #495057;
}

.required:after {
    content: " *";
    color: red;
}

/* ===== Scrollbar ===== */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}
::-webkit-scrollbar-thumb {
    background: #099885;
    border-radius: 10px;
}
::-webkit-scrollbar-track {
    background: transparent;
}

/* ===== Sidebar User Profile ===== */
.sidebar-topbar-user {
    background-color: var(--vz-topbar-user-bg);
}

.sidebar-topbar-user .badge {
    background: rgba(64, 81, 137, 0.12) !important;
    color: #405189 !important;
    font-size: 10px !important;
    font-weight: 600 !important;
}

html[data-sidebar-size='lg'] #scrollbar .user-name-text,
html[data-sidebar-size='lg'] #scrollbar .user-name-sub-text {
    display: block !important;
}

html[data-sidebar-size='sm'] #scrollbar .user-name-text,
html[data-sidebar-size='sm'] #scrollbar .user-name-sub-text {
    display: none !important;
}

/* ===== Currency Banner ===== */
.breadcrumb-marquee {
    background-color: #fff !important;
    padding: 8px 6px !important;
    overflow: hidden;
    border-radius: 0.4rem;
}

.breadcrumb-marquee .marquee {
    gap: 0.75rem;
}

.breadcrumb-marquee .marquee__content {
    gap: 0.75rem !important;
    align-items: center;
}

.breadcrumb-marquee .marquee__content > div {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background-color: #1f2544 !important;
    border-radius: 0.4rem;
    padding: 0.4rem 0.75rem;
    margin-right: 0.5rem;
    flex-shrink: 0;
}

.currency-badge {
    font-weight: 700 !important;
    font-size: 0.875rem !important;
    padding: 0.25em 0.5em !important;
    letter-spacing: 0.3px;
    background-color: transparent !important;
    color: #fff !important;
    border-radius: 0.25rem;
}

.breadcrumb-marquee .marquee__content > div > .fs-6 {
    color: #fff !important;
    font-weight: 500;
    font-size: 0.875rem !important;
    white-space: nowrap;
}

/* ===== Marquee ===== */
.marquee {
    --gap: 0.5rem;
    position: relative;
    display: flex;
    overflow: hidden;
    user-select: none;
    gap: var(--gap);
}

.marquee__content {
    flex-shrink: 0;
    display: flex;
    justify-content: space-around;
    gap: var(--gap);
    min-width: 75%;
}

@keyframes scroll {
    from { transform: translateX(0); }
    to { transform: translateX(calc(-100% - var(--gap))); }
}

.enable-animation .marquee__content {
    animation: scroll 20s linear infinite;
}

.marquee--hover-pause:hover .marquee__content {
    animation-play-state: paused;
}

/* ===== Utility ===== */
.ellipsis {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.font-11px {
    font-size: 11px;
}

.h-50px {
    height: 50px;
}

.img-cover {
    object-fit: cover;
}

.h-40px {
    height: 40px;
}

/* ===== Status Circle ===== */
.status-circle {
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background-color: #25e83c;
    border: 2px solid white;
    bottom: 0;
    right: 0;
    position: absolute;
}

.icon-container {
    width: 50px;
    height: 50px;
    position: relative;
}

/* ===== Web Pages Item ===== */
.web-pages-item i {
    font-size: 35px;
}

.web-pages-item span {
    line-height: 15px;
}

/* ===== Ellipsis Variants ===== */
.ellipsis-2-line {
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 2;
    line-clamp: 2;
}

.ellipsis-1-line {
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 1;
    line-clamp: 1;
}

/* ===== SVG Icon ===== */
.svg-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
}
.svg-icon svg {
    height: 1.15rem;
    width: 1.15rem;
    fill: currentColor;
}
.svg-icon-1 svg { height: 1.75rem; width: 1.75rem; }
.svg-icon-2 svg { height: 1.5rem; width: 1.5rem; }
.svg-icon-3 svg { height: 1.35rem; width: 1.35rem; }
.svg-icon-4 svg { height: 1.15rem; width: 1.15rem; }
.svg-icon-5 svg { height: 1rem; width: 1rem; }
.svg-icon-sm svg { height: 0.85rem; width: 0.85rem; }

/* ===== ps-10 (padding-start) utility ===== */
.ps-10 { padding-left: 2.5rem !important; }
.mw-500px { max-width: 500px; }
.w-sm-1px { min-width: 1px; }

/* ===== Timeline ===== */
.timeline::after {
    bottom: 110px;
}

/* ===== Print Styles ===== */
@media all {
    .page-break {
        display: none;
    }
}

@media print {
    .page-break {
        page-break-before: always;
        display: block;
    }

    body {
        background: white !important;
    }
}

/* ===== Vertical Align Helpers ===== */
.vertical-align-text-top {
    vertical-align: text-top;
}

.vertical-align-middle {
    vertical-align: middle;
}

.white-space-inherit {
    white-space: inherit !important;
}

/* ===== Card Toolbar ===== */
.card .card-header .card-toolbar {
    display: flex;
    align-items: center;
    margin: 0.5rem 0;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.card-header .card-title {
    margin-bottom: 0;
    font-size: 15px;
    font-weight: 600;
    color: #343a40;
}

.card-header.border-0 {
    padding-bottom: 0 !important;
}

/* ===== DataTables Padding Fix ===== */
.dataTables_info,
.dataTables_length {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button {
    border-radius: 0.35rem !important;
    padding: 0.25rem 0.6rem !important;
    font-size: 13px !important;
}

.dataTables_wrapper .dataTables_filter label,
.dataTables_wrapper .dataTables_length label {
    font-size: 13px;
    font-weight: 400;
    color: #6c757d;
}

.dataTables_wrapper .dataTables_filter input {
    border: 1px solid #dee2e6;
    border-radius: 0.35rem;
    padding: 0.25rem 0.6rem;
    font-size: 13px;
    margin-left: 0.4rem;
}

.dt-toolbar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid #f0f0f0;
}

/* ===== Air Datepicker Z-Index ===== */
.air-datepicker-global-container {
    z-index: 1111;
}

/* ===== Responsive: Confirm/Cancel Order Buttons ===== */
@media (max-width: 767.98px) {
    .confirm-order-button,
    .cancel-order-button {
        width: 47%;
        margin-top: 25px;
    }
}

/* ===== Widget Stat Responsive ===== */
@media only screen and (max-width: 1440px) {
    .widget-stat .media > span {
        height: 70px;
        width: 70px;
        min-width: 70px;
    }

    .widget-stat .media .media-body p {
        font-size: 12px;
    }

    .widget-stat .media .media-body h4,
    .widget-stat .media .media-body .h4 {
        font-size: 20px;
    }

    .widget-stat .card-body {
        padding: 1rem;
    }
}

@media only screen and (max-width: 425px) {
    .widget-stat .media > span {
        height: 40px;
        width: 40px;
        min-width: 40px;
        font-size: 22px;
    }

    .widget-stat .media .media-body p {
        font-size: 8px;
    }

    .widget-stat .media .media-body h4,
    .widget-stat .media .media-body .h4 {
        font-size: 16px;
    }

    .widget-stat .card-body {
        padding: 0.5rem;
    }
}

/* ===== Hamburger Icon Open State ===== */
.hamburger-icon.open span:nth-child(1) {
    left: 1px;
    top: 5px;
    width: 20px;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    -webkit-transition-delay: 150ms;
    transition-delay: 150ms;
}

.hamburger-icon.open span:nth-child(2) {
    left: -4px;
    top: 5px;
    width: 20px;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    -webkit-transition-delay: 150ms;
    transition-delay: 150ms;
}

.hamburger-icon.open span:nth-child(3) {
    left: -10px;
    top: 5px;
    width: 20px;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    -webkit-transition-delay: 150ms;
    transition-delay: 150ms;
}

/* ===== Sidebar Size Helpers ===== */
html[data-sidebar-size=''] #scrollbar .user-name-text,
html[data-sidebar-size=''] #scrollbar .user-name-sub-text {
    display: block !important;
}

@media (max-width: 767.98px) {
    [data-layout=vertical] .app-menu {
        padding-top: 0;
    }
}

/* ===== May Order Widget Responsive ===== */
@media (max-width: 400px) {
    .may-order-widget .avatar-sm {
        height: 2rem;
        width: 2rem;
    }

    .may-order-widget .fw-medium {
        font-size: 12px;
    }

    .may-order-widget .counter-value {
        font-size: 20px;
    }
}

/* ===== Custom Scroll ===== */
.custom-scroll {
    max-width: 100vw;
    overflow-x: scroll;
    overflow-y: hidden;
}

.custom-scroll::-webkit-scrollbar {
    width: 5px;
    height: 5px;
}

.custom-scroll::-webkit-scrollbar-thumb {
    background: #099885;
    border-radius: 10px;
}

/* ===== Custom List ===== */
.custom-list {
    display: flex;
    flex-wrap: nowrap;
    width: max-content;
    align-items: center;
    padding-bottom: 4px;
}

.custom-list div {
    display: inline-flex;
    padding-left: 8px;
    flex-shrink: 0;
}

.float-left-box {
    float: left;
    padding: 15px 0 0 45px;
}

/* ===== Symbol ===== */
.symbol {
    display: inline-block;
    flex-shrink: 0;
    position: relative;
    border-radius: .475rem;
}

.symbol.symbol-30px > img {
    width: 30px;
    height: 30px;
}

.symbol img {
    border-radius: .475rem;
}

/* ===== Marquee Extras ===== */
@media (prefers-reduced-motion: reduce) {
    .marquee__content {
        animation-play-state: paused !important;
    }
}

.marquee--reverse .marquee__content {
    animation-direction: reverse;
}

.marquee--fit-content {
    max-width: fit-content;
}

.marquee--pos-absolute .marquee__content:last-child {
    position: absolute;
    top: 0;
    left: 0;
}

.enable-animation .marquee--pos-absolute .marquee__content:last-child {
    animation-name: scroll-abs;
}

@keyframes scroll-abs {
    from {
        transform: translateX(calc(100% + var(--gap)));
    }
    to {
        transform: translateX(0);
    }
}

/* ================================================================
   UNIFIED DESIGN SYSTEM — Brandi App × Wardrobe App
   Clean · Warm · Polished | v4.0
   ================================================================ */

/* ── 1. PAGE BACKGROUND — warm cream-gray ── */
.page-content {
    background-color: #f5f3ef !important;
}

/* ── 2. CARD — rounder, softer, cleaner ── */
.card {
    border-radius: 18px !important;
    border: 1px solid rgba(0, 0, 0, 0.045) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 4px 14px rgba(0, 0, 0, 0.05) !important;
    background-color: #ffffff !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease !important;
    overflow: visible !important;
}
.card:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05), 0 12px 28px rgba(0, 0, 0, 0.08) !important;
}
.card-body {
    padding: 1.35rem 1.5rem !important;
}
.card-header {
    background-color: #ffffff !important;
    border-bottom: 1px solid #f0ede8 !important;
    border-radius: 18px 18px 0 0 !important;
    padding: 1rem 1.5rem !important;
}
.card-title {
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    color: #1a1c2e !important;
}

/* ── 3. STAT CARD LEFT ACCENT (card-animate) ── */
.card.card-animate {
    border-left: 4px solid #0ab39c !important;
    border-radius: 18px !important;
}
.card.card-animate.accent-amber  { border-left-color: #c8956c !important; }
.card.card-animate.accent-blue   { border-left-color: #299cdb !important; }
.card.card-animate.accent-purple { border-left-color: #667eea !important; }
.card.card-animate.accent-rose   { border-left-color: #f43f5e !important; }
.card.card-animate.accent-orange { border-left-color: #f59e0b !important; }
.card.card-animate.accent-green  { border-left-color: #10b981 !important; }

/* Enhance the icon squares */
.avatar-sm { width: 52px !important; height: 52px !important; }
.avatar-title.bg-soft-primary {
    border-radius: 14px !important;
    background-color: rgba(10,179,156,0.1) !important;
    font-size: 1.3rem !important;
}
.avatar-title.bg-soft-amber  { background-color: rgba(200,149,108,0.12) !important; color: #c8956c !important; border-radius: 14px !important; }
.avatar-title.bg-soft-blue   { background-color: rgba(41,156,219,0.1) !important;  color: #299cdb !important; border-radius: 14px !important; }
.avatar-title.bg-soft-purple { background-color: rgba(102,126,234,0.12) !important; color: #667eea !important; border-radius: 14px !important; }
.avatar-title.bg-soft-rose   { background-color: rgba(244,63,94,0.1) !important;   color: #f43f5e !important; border-radius: 14px !important; }
.avatar-title.bg-soft-orange { background-color: rgba(245,158,11,0.12) !important; color: #f59e0b !important; border-radius: 14px !important; }
.avatar-title.bg-soft-green  { background-color: rgba(16,185,129,0.1) !important;  color: #10b981 !important; border-radius: 14px !important; }

/* ── 4. BUTTONS ── */
.btn { border-radius: 12px !important; font-weight: 500 !important; }
.btn-primary  { background-color: #0ab39c !important; border-color: #0ab39c !important; }
.btn-primary:hover  { background-color: #089c87 !important; border-color: #089c87 !important; }

/* ── 5. FORM CONTROLS ── */
.form-control, .form-select {
    border-radius: 12px !important;
    border-color: rgba(0, 0, 0, 0.1) !important;
    background-color: #faf9f7 !important;
    font-size: 0.875rem !important;
}
.form-control:focus, .form-select:focus {
    border-color: #0ab39c !important;
    box-shadow: 0 0 0 3px rgba(10, 179, 156, 0.12) !important;
    background-color: #ffffff !important;
}

/* ── 6. NAV PILLS ── */
.nav-pills .nav-link {
    border-radius: 12px !important;
    font-size: 0.875rem !important;
    color: #6b7280 !important;
}
.nav-pills .nav-link.active {
    background-color: #0ab39c !important;
    color: #ffffff !important;
}

/* ── 7. BADGES ── */
.badge { border-radius: 50px !important; }
.badge-soft-success { background-color: rgba(10,179,156,0.12) !important; color: #0ab39c !important; }
.badge-soft-primary { background-color: rgba(10,179,156,0.12) !important; color: #0ab39c !important; }

/* ── 8. DROPDOWN ── */
.dropdown-menu {
    border-radius: 16px !important;
    border: 1px solid rgba(0,0,0,0.06) !important;
    box-shadow: 0 8px 32px rgba(0,0,0,0.12) !important;
    padding: 0.4rem !important;
}
.dropdown-item {
    border-radius: 10px !important;
    padding: 0.5rem 0.9rem !important;
    font-size: 0.875rem !important;
}
.dropdown-item:hover { background-color: #f5f3ef !important; }

/* ── 9. MODAL ── */
.modal-content {
    border-radius: 22px !important;
    border: none !important;
    box-shadow: 0 24px 64px rgba(0,0,0,0.18) !important;
}
.modal-header {
    border-bottom: 1px solid #f0ede8 !important;
    padding: 1.25rem 1.5rem !important;
    border-radius: 22px 22px 0 0 !important;
}
.modal-footer {
    border-top: 1px solid #f0ede8 !important;
    padding: 1rem 1.5rem !important;
}

/* ── 10. TABLE ── */
.table thead th {
    background-color: #faf9f7 !important;
    border-bottom: 1px solid #f0ede8 !important;
    font-size: 0.7rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    color: #9ca3af !important;
    font-weight: 600 !important;
    padding: 0.85rem 1rem !important;
}
.table td { padding: 0.85rem 1rem !important; vertical-align: middle !important; }

/* ── 11. EXCHANGE RATE MARQUEE ── */
.breadcrumb-marquee {
    background: #ffffff;
    border-radius: 50px;
    padding: 0.45rem 1.25rem;
    margin: 0.5rem 0 1rem;
    box-shadow: 0 1px 4px rgba(0,0,0,0.05);
    border: 1px solid rgba(0,0,0,0.04);
}
.breadcrumb-marquee .currency-badge.bg-primary {
    background-color: rgba(10,179,156,0.12) !important;
    color: #0ab39c !important;
    border-radius: 50px !important;
    font-weight: 600 !important;
}

/* ── 12. DASHBOARD GREETING CARD ── */
.dash-greeting {
    background: linear-gradient(135deg, #1a1c2e 0%, #2c3468 100%);
    border-radius: 20px;
    padding: 1.5rem 2rem;
    margin-bottom: 1.5rem;
    position: relative;
    overflow: hidden;
    border: none !important;
    box-shadow: 0 8px 32px rgba(26,28,46,0.25) !important;
}
.dash-greeting::after {
    content: '';
    position: absolute;
    right: -30px; top: -30px;
    width: 180px; height: 180px;
    border-radius: 50%;
    background: rgba(10,179,156,0.15);
    pointer-events: none;
}
.dash-greeting::before {
    content: '';
    position: absolute;
    right: 80px; bottom: -40px;
    width: 120px; height: 120px;
    border-radius: 50%;
    background: rgba(10,179,156,0.08);
    pointer-events: none;
}
.dash-greeting-time {
    font-size: 0.72rem;
    color: rgba(255,255,255,0.5);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 500;
    display: block;
    margin-bottom: 3px;
}
.dash-greeting-name {
    font-size: 1.5rem;
    font-weight: 700;
    color: #ffffff;
    margin: 0 0 4px;
    line-height: 1.2;
}
.dash-greeting-sub {
    font-size: 0.8rem;
    color: rgba(255,255,255,0.5);
    margin: 0;
}
.dash-greeting-stat {
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 14px;
    padding: 0.6rem 1rem;
    text-align: center;
    min-width: 90px;
}
.dash-greeting-stat-val {
    display: block;
    font-size: 1.15rem;
    font-weight: 700;
    color: #ffffff;
    line-height: 1;
    margin-bottom: 3px;
}
.dash-greeting-stat-lbl {
    font-size: 0.68rem;
    color: rgba(255,255,255,0.5);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

/* ── 13. SECTION HEADERS ── */
.brandi-section {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.85rem;
    margin-top: 0.5rem;
}
.brandi-section-lbl {
    font-size: 0.68rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #9ca3af;
    font-weight: 600;
    display: block;
    margin-bottom: 2px;
}
.brandi-section-title {
    font-size: 1rem;
    font-weight: 700;
    color: #1a1c2e;
    margin: 0;
}
.brandi-section-link {
    font-size: 0.78rem;
    color: #0ab39c;
    font-weight: 500;
    text-decoration: none;
}
.brandi-section-link:hover { color: #089c87; }

/* ── 14. MARKET FILTER TABS (Brandi) ── */
.market-tabs {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    background: rgba(0,0,0,0.04);
    border-radius: 50px;
    padding: 4px;
    width: fit-content;
    margin-bottom: 1.25rem;
    overflow-x: auto;
    max-width: 100%;
}
.market-tab {
    padding: 0.35rem 1rem;
    border-radius: 50px;
    font-size: 0.8rem;
    font-weight: 500;
    color: #6b7280;
    background: transparent;
    border: none;
    cursor: pointer;
    white-space: nowrap;
    text-decoration: none;
    transition: all 0.15s ease;
    line-height: 1.5;
    display: inline-block;
}
.market-tab.active {
    background: #0ab39c;
    color: #ffffff;
    box-shadow: 0 2px 8px rgba(10,179,156,0.28);
}
.market-tab:hover:not(.active) { background: rgba(0,0,0,0.06); color: #1a1c2e; }

/* ── 15. BRANDI PROFILE QUICK MENU ── */
.brandi-group { margin-bottom: 1.5rem; }
.brandi-group-lbl {
    font-size: 0.68rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #9ca3af;
    font-weight: 600;
    padding: 0 0.25rem;
    margin-bottom: 0.55rem;
    display: block;
}
.brandi-menu-card {
    background: #ffffff;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 4px 14px rgba(0,0,0,0.05);
    border: 1px solid rgba(0,0,0,0.04);
}
.brandi-menu-row {
    display: flex;
    align-items: center;
    padding: 0.85rem 1.15rem;
    color: #1a1c2e;
    text-decoration: none !important;
    border-bottom: 1px solid #f5f3ef;
    transition: background 0.15s ease;
    cursor: pointer;
}
.brandi-menu-row:last-child { border-bottom: none; }
.brandi-menu-row:hover { background: #faf9f7; }
.brandi-menu-icon {
    width: 36px; height: 36px;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.9rem;
    margin-right: 0.85rem;
    flex-shrink: 0;
}
.brandi-menu-text { flex: 1; font-size: 0.875rem; font-weight: 500; color: #1a1c2e; }
.brandi-menu-arrow { color: #d1d5db; font-size: 0.8rem; }
.brandi-menu-badge { font-size: 0.7rem; margin-right: 0.5rem; }

/* Icon colour helpers */
.bic-teal   { background: rgba(10,179,156,0.1);   color: #0ab39c; }
.bic-amber  { background: rgba(200,149,108,0.12);  color: #c8956c; }
.bic-blue   { background: rgba(41,156,219,0.1);    color: #299cdb; }
.bic-purple { background: rgba(102,126,234,0.12);  color: #667eea; }
.bic-rose   { background: rgba(244,63,94,0.1);     color: #f43f5e; }
.bic-orange { background: rgba(245,158,11,0.12);   color: #f59e0b; }
.bic-green  { background: rgba(16,185,129,0.1);    color: #10b981; }
.bic-dark   { background: rgba(26,28,46,0.07);     color: #1a1c2e; }

/* ── 16. PAGE TITLE ── */
.page-title-box h4 {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: #1a1c2e !important;
}

/* ── 17. INPUT GROUPS ── */
.input-group .input-group-text {
    background-color: #faf9f7 !important;
    border-color: rgba(0,0,0,0.1) !important;
    border-radius: 12px 0 0 12px !important;
}
.input-group .form-control { border-radius: 0 12px 12px 0 !important; }

/* ── 18. PROFILE HEADER OVERLAY ── */
.profile-wid-bg {
    border-radius: 0 0 24px 24px;
    overflow: hidden;
}
.profile-wid-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(26,28,46,0.25) 0%, rgba(26,28,46,0.65) 100%);
    border-radius: 0 0 24px 24px;
}

/* ── 19. SIDEBAR ITEM RADII ── */
.app-menu .nav-item .nav-link { border-radius: 10px !important; }

/* ── 20. ALERT ── */
.alert { border-radius: 14px !important; border: none !important; }

/* ── 21. PROGRESS BAR ── */
.progress { border-radius: 50px !important; height: 6px !important; background-color: #f0ede8 !important; }
.progress-bar { border-radius: 50px !important; background-color: #0ab39c !important; }

/* ================================================================
   22. SIDEBAR — Light Beige Design
   ================================================================ */

/* Sidebar shell */
.app-menu.navbar-menu,
[data-layout=vertical] .app-menu {
    background: #f5f3ef !important;
    border-right: 1px solid #ede9e3 !important;
    box-shadow: 4px 0 20px rgba(0,0,0,0.06) !important;
}

/* Logo box */
.navbar-brand-box {
    background: #f5f3ef !important;
    border-bottom: 1px solid #ede9e3 !important;
    padding: 0 20px !important;
}
.navbar-brand-box .logo-lg span,
.navbar-brand-box .logo-dark .logo-lg span,
.navbar-brand-box .logo-light .logo-lg span {
    color: #1a1c2e !important;
    font-size: 22px !important;
    font-weight: 800 !important;
    font-style: italic !important;
    letter-spacing: -0.5px !important;
}

/* Scrollbar area */
#scrollbar { background: #f5f3ef !important; }
.sidebar-background { background: #f5f3ef !important; }

/* ── Section labels (menu-title) ── */
.navbar-nav .menu-title {
    padding: 18px 20px 6px !important;
    font-size: 9.5px !important;
    font-weight: 700 !important;
    letter-spacing: 1.6px !important;
    text-transform: uppercase !important;
    color: #b0a99e !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}
.navbar-nav .menu-title > i { display: none !important; }
.navbar-nav .menu-title::before {
    content: '';
    display: inline-block;
    width: 16px; height: 1.5px;
    background: rgba(10,179,156,0.5);
    border-radius: 2px;
    flex-shrink: 0;
}

/* ── Nav links ── */
.navbar-menu .navbar-nav .nav-link.menu-link {
    color: #6b7280 !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    padding: 9px 16px !important;
    margin: 1px 12px !important;
    border-radius: 10px !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    transition: background .18s, color .18s, padding-left .18s !important;
    position: relative !important;
    border-left: 3px solid transparent !important;
}
.navbar-menu .navbar-nav .nav-link.menu-link i {
    font-size: 16px !important;
    width: 20px !important;
    text-align: center !important;
    flex-shrink: 0 !important;
    color: #b0a99e !important;
    transition: color .18s !important;
}

/* Hover */
.navbar-menu .navbar-nav .nav-link.menu-link:hover {
    color: #1a1c2e !important;
    background: rgba(0,0,0,0.05) !important;
    padding-left: 20px !important;
    border-left-color: rgba(10,179,156,0.5) !important;
}
.navbar-menu .navbar-nav .nav-link.menu-link:hover i { color: #0ab39c !important; }

/* Active */
.navbar-menu .navbar-nav .nav-link.menu-link.active,
[data-layout=vertical] .navbar-menu .navbar-nav .nav-item.active > .menu-link {
    color: #fff !important;
    background: #0ab39c !important;
    border-left-color: #089c87 !important;
    font-weight: 600 !important;
    padding-left: 20px !important;
    box-shadow: 0 4px 12px rgba(10,179,156,0.25) !important;
}
.navbar-menu .navbar-nav .nav-link.menu-link.active i,
[data-layout=vertical] .navbar-menu .navbar-nav .nav-item.active > .menu-link i {
    color: #fff !important;
}

/* ── Dropdown sub-items ── */
.navbar-menu .navbar-nav .nav-sm .nav-link {
    color: #9ca3af !important;
    font-size: 12.5px !important;
    padding: 7px 14px 7px 50px !important;
    border-radius: 8px !important;
    margin: 0 12px !important;
    transition: color .15s, background .15s !important;
    border-left: none !important;
    position: relative !important;
}
.navbar-menu .navbar-nav .nav-sm .nav-link::before {
    content: '';
    position: absolute;
    left: 36px; top: 50%;
    transform: translateY(-50%);
    width: 5px; height: 5px;
    border-radius: 50%;
    background: #d1cdc7;
    transition: background .15s;
}
.navbar-menu .navbar-nav .nav-sm .nav-link:hover {
    color: #1a1c2e !important;
    background: rgba(0,0,0,0.04) !important;
}
.navbar-menu .navbar-nav .nav-sm .nav-link:hover::before,
.navbar-menu .navbar-nav .nav-sm .nav-link.active::before { background: #0ab39c !important; }
.navbar-menu .navbar-nav .nav-sm .nav-link.active {
    color: #0ab39c !important;
    background: rgba(10,179,156,0.08) !important;
    font-weight: 600 !important;
}

/* ── Sidebar User Profile Card ── */
.sidebar-topbar-user {
    background: #1a1c2e !important;
    border-radius: 14px !important;
    margin: 10px 14px 4px !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    height: auto !important;
    overflow: visible !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.18) !important;
}
.sidebar-topbar-user > .btn {
    width: 100% !important;
    padding: 12px 14px !important;
}
.sidebar-topbar-user .header-profile-user {
    width: 38px !important; height: 38px !important;
    border-radius: 10px !important;
    border: 2px solid rgba(10,179,156,0.50) !important;
    object-fit: cover !important;
}
.sidebar-topbar-user .user-name-text {
    color: #ffffff !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
}
.sidebar-topbar-user .user-name-sub-text {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    color: rgba(255,255,255,0.45) !important;
    font-size: 11px !important;
    margin-top: 4px !important;
}
.sidebar-topbar-user .badge {
    background: rgba(10,179,156,0.20) !important;
    color: #0ab39c !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 0.4px !important;
    padding: 3px 8px !important;
    border-radius: 6px !important;
}
.sidebar-topbar-user .float-end {
    color: rgba(255,255,255,0.60) !important;
}

/* ── Dropdown menu from sidebar user ── */
.sidebar-topbar-user .dropdown-menu {
    background: #fff !important;
    border: 1px solid #ede9e3 !important;
    border-radius: 14px !important;
    box-shadow: 0 8px 28px rgba(0,0,0,0.12) !important;
    padding: 6px !important;
    min-width: 200px !important;
}
.sidebar-topbar-user .dropdown-item {
    color: #4b5563 !important;
    font-size: 13px !important;
    border-radius: 8px !important;
    padding: 9px 14px !important;
    transition: background .15s, color .15s !important;
}
.sidebar-topbar-user .dropdown-item:hover {
    background: rgba(10,179,156,0.10) !important;
    color: #0ab39c !important;
}
.sidebar-topbar-user .dropdown-item i { color: #b0a99e !important; }
.sidebar-topbar-user .dropdown-item:hover i { color: #0ab39c !important; }
.sidebar-topbar-user .dropdown-divider {
    border-color: #f0ede8 !important;
    margin: 4px 8px !important;
}

/* ── Hamburger toggle button ── */
#vertical-hover { color: #b0a99e !important; }
#vertical-hover:hover { color: #0ab39c !important; }

/* ================================================================
   TOPBAR — Beige Design (matches sidebar)
   ================================================================ */
#page-topbar {
    background: #f5f3ef !important;
    border-bottom: 1px solid #ede9e3 !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05) !important;
}
#page-topbar .navbar-header { background: transparent !important; }
#page-topbar .header-item,
#page-topbar .header-item button {
    color: #6b7280 !important;
    background: transparent !important;
}
#page-topbar .header-item:hover,
#page-topbar .header-item button:hover {
    color: #1a1c2e !important;
    background: rgba(0,0,0,0.05) !important;
}
#page-topbar .topbar-user {
    background: rgba(0,0,0,0.04) !important;
    border-radius: 10px !important;
}
#page-topbar .topbar-user .text-start span {
    color: #1a1c2e !important;
}
#page-topbar .topbar-user .text-start small {
    color: #9ca3af !important;
}
#page-topbar .app-search .form-control {
    background: #fff !important;
    border: 1px solid #ede9e3 !important;
    color: #1a1c2e !important;
}
#page-topbar .app-search .form-control::placeholder { color: #b0a99e !important; }
#page-topbar .app-search .search-widget-icon { color: #b0a99e !important; }
#page-topbar .notification-item .notification-text { color: #1a1c2e !important; }

/* ── Collapsed sidebar ── */
[data-sidebar-size=sm] .app-menu.navbar-menu,
[data-sidebar-size=sm-hover] .app-menu.navbar-menu { background: #f5f3ef !important; }

/* ── Scrollbar ── */
#scrollbar::-webkit-scrollbar { width: 3px; }
#scrollbar::-webkit-scrollbar-track { background: transparent; }
#scrollbar::-webkit-scrollbar-thumb { background: #ddd8d0; border-radius: 3px; }
#scrollbar::-webkit-scrollbar-thumb:hover { background: #0ab39c; }

/* ================================================================
   23. SHARED AUTH PAGE STYLES (pwy-*)
   ================================================================ */
.pwy-login-wrap { min-height:100vh; display:flex; background:#f5f3ef; }
.pwy-login-brand {
    width:42%; background:#1a1c2e;
    display:flex; flex-direction:column; justify-content:center;
    padding:60px 56px; position:relative; overflow:hidden;
}
.pwy-login-brand::before {
    content:''; position:absolute; top:-80px; right:-80px;
    width:320px; height:320px; border-radius:50%;
    background:rgba(10,179,156,0.12);
}
.pwy-login-brand::after {
    content:''; position:absolute; bottom:-60px; left:-60px;
    width:220px; height:220px; border-radius:50%;
    background:rgba(10,179,156,0.07);
}
.pwy-brand-logo { font-size:36px; font-weight:800; font-style:italic; color:#fff; letter-spacing:-0.5px; margin-bottom:8px; position:relative; z-index:1; }
.pwy-brand-logo span { color:#0ab39c; }
.pwy-brand-tagline { font-size:13px; color:rgba(255,255,255,0.35); letter-spacing:0.6px; margin-bottom:48px; position:relative; z-index:1; }
.pwy-brand-feature { display:flex; align-items:center; gap:14px; margin-bottom:20px; position:relative; z-index:1; }
.pwy-brand-feature-icon { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.pwy-brand-feature-text strong { display:block; font-size:13px; font-weight:600; color:#fff; margin-bottom:2px; }
.pwy-brand-feature-text span { font-size:11px; color:rgba(255,255,255,0.35); }
.pwy-brand-dots { display:flex; gap:6px; margin-top:48px; position:relative; z-index:1; }
.pwy-brand-dots span { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,0.2); }
.pwy-brand-dots span:first-child { background:#0ab39c; width:20px; border-radius:3px; }
.pwy-login-form { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:60px 48px; overflow-y:auto; }
.pwy-login-form-inner { width:100%; max-width:420px; }
.pwy-form-label-top { font-size:10px; letter-spacing:1.3px; text-transform:uppercase; color:#0ab39c; font-weight:600; margin-bottom:8px; display:block; }
.pwy-form-title { font-size:26px; font-weight:800; color:#1a1c2e; margin-bottom:6px; }
.pwy-form-sub { font-size:13px; color:#9ca3af; margin-bottom:28px; }
.pwy-input-group {
    display:flex; align-items:center;
    background:#fff; border-radius:12px; border:1px solid #f0ede8;
    padding:0 14px; margin-bottom:12px; height:52px;
    box-shadow:0 1px 4px rgba(0,0,0,0.04);
    transition:border-color .2s, box-shadow .2s;
}
.pwy-input-group:focus-within { border-color:#0ab39c; box-shadow:0 0 0 3px rgba(10,179,156,0.12); }
.pwy-input-icon {
    width:32px; height:32px; border-radius:8px;
    background:rgba(10,179,156,0.10);
    display:flex; align-items:center; justify-content:center;
    margin-right:12px; flex-shrink:0; color:#0ab39c; font-size:15px;
}
.pwy-input-group input { flex:1; border:none; background:transparent; font-size:14px; color:#1a1c2e; outline:none; padding:0; }
.pwy-input-group input::placeholder { color:#9ca3af; }
.pwy-eye-btn { background:none; border:none; color:#9ca3af; cursor:pointer; padding:4px; font-size:16px; line-height:1; }
.pwy-form-row { display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; font-size:13px; }
.pwy-form-row label { color:#6b7280; cursor:pointer; }
.pwy-form-row a { color:#0ab39c; font-weight:600; text-decoration:none; }
.pwy-submit-btn {
    width:100%; height:52px; background:#0ab39c; color:#fff;
    border:none; border-radius:12px; font-size:15px; font-weight:700;
    cursor:pointer; display:flex; align-items:center; justify-content:center; gap:8px;
    box-shadow:0 4px 14px rgba(10,179,156,0.30);
    transition:opacity .2s, transform .1s;
}
.pwy-submit-btn:hover { opacity:.92; transform:translateY(-1px); }
.pwy-submit-btn:active { transform:translateY(0); }
.pwy-divider { display:flex; align-items:center; gap:14px; margin:22px 0; font-size:12px; color:#9ca3af; }
.pwy-divider::before, .pwy-divider::after { content:''; flex:1; height:1px; background:#f0ede8; }
.pwy-social-row { display:flex; justify-content:center; gap:12px; }
.pwy-social-btn { width:48px; height:48px; border-radius:10px; border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:18px; transition:opacity .2s; }
.pwy-social-btn:hover { opacity:.8; }
.pwy-login-footer { text-align:center; margin-top:24px; font-size:13px; color:#9ca3af; }
.pwy-login-footer a { color:#0ab39c; font-weight:700; text-decoration:none; }
.pwy-back-link { display:inline-flex; align-items:center; gap:6px; font-size:13px; color:#9ca3af; text-decoration:none; margin-bottom:20px; transition:color .15s; }
.pwy-back-link:hover { color:#0ab39c; }
.pwy-info-box { background:rgba(10,179,156,0.08); border:1px solid rgba(10,179,156,0.18); border-radius:12px; padding:12px 16px; margin-bottom:22px; font-size:13px; color:#0ab39c; display:flex; align-items:center; gap:10px; }
@media (max-width:991px) {
    .pwy-login-brand { display:none; }
    .pwy-login-form { padding:40px 24px; }
}