/* =====================================================================
   BRIDGE — restyles the product's dashboard/storefront/auth components
   (which use WHMLAB classes: .btn--base, .form--control, .card, .table,
   .list-group, .custom--card, etc.) into the CPHost template look.
   CPHost palette: --theme #384BFF, --theme2 #FFA31A, --header #0F0D1D,
   --text #445375, --bg #F3F7FB, font "Jost".
   ===================================================================== */

:root {
    --bx-theme: #384BFF;
    --bx-theme-2: #FFA31A;
    --bx-header: #0F0D1D;
    --bx-text: #445375;
    --bx-border: #D4DCED;
    --bx-bg: #F3F7FB;
    --bx-white: #fff;
    --bx-radius: 12px;
    --bx-shadow: 0px 4px 25px 0px rgba(0, 0, 0, 0.06);
}

/* =====================================================================
   STOREFRONT PLAN / PRICING CARDS
   ===================================================================== */
.plan-intro { margin-bottom: 26px; }
.plan-intro h3 { color: var(--bx-header); font-weight: 700; margin: 0 0 6px; }
.plan-intro p { color: var(--bx-text); margin: 0; max-width: 640px; }

.plan-card {
    position: relative;
    background: #fff;
    border: 1px solid var(--bx-border);
    border-radius: 16px;
    box-shadow: var(--bx-shadow);
    padding: 30px 26px 28px;
    display: flex;
    flex-direction: column;
    transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.plan-card:hover { transform: translateY(-6px); box-shadow: 0 18px 40px rgba(56,75,255,.14); border-color: var(--bx-theme); }

.plan-card--popular { border-color: var(--bx-theme); box-shadow: 0 18px 44px rgba(56,75,255,.18); }
.plan-card--popular::before {
    content: "";
    position: absolute; inset: 0;
    border-radius: 16px;
    padding: 2px;
    background: linear-gradient(135deg, var(--bx-theme), var(--bx-theme-2));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor; mask-composite: exclude;
    pointer-events: none;
}
.plan-card__badge {
    position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
    background: linear-gradient(135deg, var(--bx-theme), var(--bx-theme-2));
    color: #fff; font-size: .72rem; font-weight: 700; letter-spacing: .04em;
    text-transform: uppercase; padding: 6px 16px; border-radius: 30px;
    white-space: nowrap; box-shadow: 0 6px 16px rgba(56,75,255,.3);
}

.plan-card__head { text-align: center; padding-bottom: 16px; border-bottom: 1px dashed var(--bx-border); }
.plan-card__name { color: var(--bx-header); font-weight: 700; font-size: 1.25rem; margin: 0; font-family: "Jost", sans-serif; }
.plan-card__stock { display: inline-block; margin-top: 8px; font-size: .76rem; font-weight: 600; color: #157347; background: #e7f8ee; padding: .3em .8em; border-radius: 30px; }

.plan-card__price { text-align: center; margin: 20px 0 0; }
.plan-card__price .amount { font-size: 2.3rem; font-weight: 800; color: var(--bx-theme); font-family: "Jost", sans-serif; line-height: 1; }
.plan-card__price .cycle { display: block; color: var(--bx-text); font-size: .9rem; margin-top: 6px; text-transform: capitalize; }
.plan-card__setup { text-align: center; color: #8893ad; font-size: .8rem; margin: 6px 0 0; }

.plan-card__features { list-style: none; margin: 22px 0 24px; padding: 0; flex: 1 1 auto; }
.plan-card__features li { display: flex; align-items: flex-start; gap: 10px; padding: 7px 0; color: var(--bx-text); font-size: .92rem; border-bottom: 1px solid #f1f4fa; }
.plan-card__features li:last-child { border-bottom: none; }
.plan-card__features li i { color: var(--bx-theme); margin-top: 4px; font-size: .9rem; }
.plan-card--popular .plan-card__features li i { color: var(--bx-theme-2); }

.plan-card__cta { margin-top: auto; }
.plan-card__cta .theme-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; }

.plan-empty { text-align: center; background: #fff; border: 1px dashed var(--bx-border); border-radius: 16px; padding: 50px 20px; color: var(--bx-text); }
.plan-empty i { font-size: 2.4rem; color: var(--bx-border); display: block; margin-bottom: 12px; }
.plan-empty p { margin: 0; }

/* =====================================================================
   DROPDOWNS — professional styling for native <select> and select2
   ===================================================================== */
select.form-control, select.form--control, select.form-select, select.custom-select,
.form-group select, .select2-parent select {
    -webkit-appearance: none; -moz-appearance: none; appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23445375' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 15px center; background-size: 13px;
    padding-right: 40px !important;
    border: 1px solid var(--bx-border) !important; border-radius: 10px !important;
    color: var(--bx-header) !important; background-color: #fff !important;
    font-weight: 500; cursor: pointer; transition: border-color .2s ease, box-shadow .2s ease;
}
select.form-control:focus, select.form--control:focus, select.form-select:focus,
select.custom-select:focus, .form-group select:focus {
    border-color: var(--bx-theme) !important; box-shadow: 0 0 0 3px rgba(56,75,255,.12) !important; outline: none;
}
select option { color: #0F0D1D; padding: 8px; }

/* select2 single — match the native look */
.select2-container { width: 100% !important; }
.select2-container--default .select2-selection--single {
    height: 45px !important; border: 1px solid var(--bx-border) !important; border-radius: 10px !important;
    background: #fff !important; transition: border-color .2s ease, box-shadow .2s ease;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 43px !important; padding-left: 15px !important; padding-right: 38px !important; color: #0F0D1D !important; font-weight: 500;
}
.select2-container--default .select2-selection--single .select2-selection__placeholder { color: #8893ad !important; }
.select2-container--default .select2-selection--single .select2-selection__arrow { height: 43px !important; right: 12px !important; }
.select2-container--open .select2-selection--single { border-color: var(--bx-theme) !important; box-shadow: 0 0 0 3px rgba(56,75,255,.12) !important; }
.select2-dropdown { border: 1px solid var(--bx-border) !important; border-radius: 10px !important; box-shadow: var(--bx-shadow); overflow: hidden; }
.select2-search--dropdown .select2-search__field { border: 1px solid var(--bx-border) !important; border-radius: 8px !important; padding: 8px 10px !important; }
.select2-container--default .select2-results__option { padding: 9px 14px; font-size: .92rem; color: #445375; }
.select2-container--default .select2-results__option--highlighted[aria-selected] { background: var(--bx-theme) !important; color: #fff !important; }
.select2-container--default .select2-results__option[aria-selected=true] { background: #eef1ff !important; color: var(--bx-theme) !important; }

/* ---- Generic surfaces on product pages ---- */
.bg--light { background: var(--bx-bg) !important; }
.section-full, .service-category { background: var(--bx-bg) !important; }
/* User inner pages (lists, details, transactions, payments, tickets):
   .pt-60/.pb-60 utilities live in an unloaded stylesheet, so give these
   sections real vertical breathing room (was touching breadcrumb/footer). */
.section-full.bg--light { padding-top: 80px !important; padding-bottom: 95px !important; }
/* Dashboard wrapper (master_side_bar) — service-category without section-full */
.service-category.bg--light { padding-top: 70px !important; padding-bottom: 85px !important; }
/* storefront (cart / service category) keeps its own tighter rhythm */
.service-category.section-full, .service-category.section-full.bg--light { padding: 55px 0 75px !important; }
@media (max-width: 575px) {
    .section-full.bg--light { padding-top: 48px !important; padding-bottom: 56px !important; }
    .service-category.bg--light { padding-top: 42px !important; padding-bottom: 50px !important; }
    .service-category.section-full, .service-category.section-full.bg--light { padding: 36px 0 52px !important; }
}
.bg-dark-two { background: var(--bx-header) !important; color: #fff; }
.text--base { color: var(--bx-theme) !important; }
.bg--base { background: var(--bx-theme) !important; }

/* ---- Buttons (product) -> CPHost theme-btn feel ---- */
.btn--base, .btn.btn--base {
    background: var(--bx-theme) !important;
    border: none !important;
    color: #fff !important;
    border-radius: 30px !important;
    font-weight: 500;
    padding: .7rem 1.6rem;
    transition: all .3s ease;
}
.btn--base:hover, .btn.btn--base:hover { background: var(--bx-header) !important; color: #fff !important; }
.btn--base.btn--sm, .btn--xs { padding: .4rem 1.1rem; }
.btn--base-outline {
    border: 2px solid var(--bx-theme) !important; color: var(--bx-theme) !important;
    border-radius: 30px !important; background: transparent !important; font-weight: 500;
}
.btn--base-outline:hover { background: var(--bx-theme) !important; color: #fff !important; }
.btn.border { border-radius: 30px !important; }

/* ---- Forms ---- */
.form-control, .form--control, textarea, select,
.input-group-text, .select2-container--default .select2-selection {
    background-color: #fff !important;
    border: 1px solid var(--bx-border) !important;
    border-radius: 8px !important;
    color: var(--bx-header) !important;
}
.form--control, .form-control.h-45, .form--control.h-45 { height: 50px; }
.form-control:focus, .form--control:focus,
.select2-container--default.select2-container--focus .select2-selection {
    border-color: var(--bx-theme) !important;
    box-shadow: 0 0 0 .2rem rgba(56, 75, 255, .12) !important;
}
label.required::after, .required > label::after { color: var(--bx-theme2); }

/* ---- Cards ---- */
.card, .custom--card {
    background: #fff !important;
    border: 1px solid var(--bx-border) !important;
    border-radius: var(--bx-radius) !important;
    box-shadow: var(--bx-shadow);
    overflow: hidden;
}
.card .card-header, .custom--card .card-header,
.card .card-header.bg-dark-two, .service-card .card-header.bg-dark-two {
    background: #fff !important; color: var(--bx-header) !important;
    border-bottom: 1px solid var(--bx-border) !important; font-weight: 600;
}
.card .card-footer, .custom--card .card-footer { background: #fff !important; border-top: 1px solid var(--bx-border) !important; }

/* ---- Sidebar / list groups ---- */
nav.sidebar { border-radius: var(--bx-radius) !important; overflow: hidden; border: 1px solid var(--bx-border) !important; box-shadow: var(--bx-shadow); }
nav.sidebar > span.bg-dark-two, .list-group .bg-dark-two, .collapable-sidebar span.bg-dark-two {
    background: #fff !important; color: var(--bx-header) !important;
    border-bottom: 1px solid var(--bx-border) !important; display: block; padding: 14px !important; font-weight: 600;
}
.list-group-item { border-color: var(--bx-border) !important; color: var(--bx-header); }
.list-group-item-action:hover { background: #eef1ff !important; color: var(--bx-theme) !important; }
.list-group-item.bg--base, .list-group-item.text-white { background: var(--bx-theme) !important; color: #fff !important; }

/* ---- Dashboard stat icons ---- */
.widgets-icons-2 { width: 58px; height: 58px; border-radius: 14px; display: grid; place-items: center; font-size: 1.4rem; color: #fff !important; }
.widgets-icons-2 i { color: #fff !important; }
.bg-gradient-blooker { background: linear-gradient(135deg, #5566ff, #384BFF) !important; }
.bg-gradient-scooter { background: linear-gradient(135deg, #36d1dc, #2f80ff) !important; }
.bg-gradient-bloody  { background: linear-gradient(135deg, #f857a6, #ff5858) !important; }
.bg-gradient-ohhappiness { background: linear-gradient(135deg, #ffb347, #FFA31A) !important; }
.border-left-primary { border-left: 4px solid var(--bx-theme) !important; }
.custom-border-top-dark { border-top: 3px solid var(--bx-theme) !important; }

/* ---- Tables ---- */
.table {
    background: #fff !important; border-collapse: separate !important; border-spacing: 0 !important;
    border-radius: var(--bx-radius); overflow: hidden; box-shadow: var(--bx-shadow);
    border: 1px solid var(--bx-border); margin-bottom: 0;
}
.table thead tr { background: #f5f7ff !important; }
.table thead tr th { color: var(--bx-header) !important; font-weight: 600 !important; border: 0 !important; padding: 15px 18px !important; }
.table tbody td { padding: 15px 18px !important; border: 0 !important; border-top: 1px solid var(--bx-border) !important; vertical-align: middle; color: var(--bx-text); }
.table tbody tr:hover { background: #fafbff; }
.table a.fw-bold { color: var(--bx-theme); }

/* ---- Badges ---- */
.badge--fill-base, .badge.badge--fill-base { background: var(--bx-theme) !important; color: #fff !important; }

/* ---- Empty state ---- */
.nc-empty { text-align: center; padding: 50px 24px; }
.nc-empty__icon { width: 74px; height: 74px; margin: 0 auto 16px; border-radius: 50%; display: grid; place-items: center; font-size: 2rem; background: #eef1ff; color: var(--bx-theme); }
.nc-empty__title { color: var(--bx-header); font-weight: 600; margin-bottom: .3rem; }
.nc-empty__text { color: var(--bx-text); margin: 0; }
td.not-found, .not-found { color: var(--bx-text); padding: 40px 0 !important; }

/* ---- Pagination ---- */
.pagination .page-link { color: var(--bx-header); border-radius: 8px !important; margin: 0 3px; border: 1px solid var(--bx-border); }
.pagination .page-item.active .page-link { background: var(--bx-theme); border-color: var(--bx-theme); color: #fff; }

/* ---- Policy / content pages ---- */
.policy-section .policy-content { background: #fff; border: 1px solid var(--bx-border); border-radius: var(--bx-radius); box-shadow: var(--bx-shadow); padding: 44px; }
.policy-content h1 { font-size: 2rem; margin: 0 0 .4rem; color: var(--bx-header); }
.policy-content .lead { font-size: 1.08rem; color: var(--bx-text); margin-bottom: 1.4rem; }
.policy-content h2 { font-size: 1.35rem; margin: 1.8rem 0 .7rem; color: var(--bx-header); }
.policy-content h3, .policy-content h4 { color: var(--bx-header); }
.policy-content p, .policy-content li { color: var(--bx-text); line-height: 1.8; }
.policy-content a { color: var(--bx-theme); font-weight: 600; }

/* ---- Subscribe floating widget + cookie card: keep tidy ---- */
.subscribe { background: transparent !important; }
.subscribe-box { background: #fff !important; border: 1px solid var(--bx-border); border-radius: var(--bx-radius); box-shadow: var(--bx-shadow); }
.cookies-card { border-radius: var(--bx-radius); }
.cookies-card__icon { background: var(--bx-theme) !important; }

/* =====================================================================
   CPHost template tweaks (logo sizing for our PNG logo, language switcher)
   ===================================================================== */
.header-logo img, .header-logo-2 img { max-height: 46px !important; width: auto !important; }
.offcanvas__logo img { max-height: 42px !important; width: auto !important; }
.single-footer-widget .widget-head img { max-height: 46px !important; width: auto !important; }

/* Language switcher: keep compact inside the CPHost header */
.header-right .language-form, .header-right form[action*="language"] { margin-left: 14px; }
.header-right select.language__switch, .header-right .lang-switch select { background:#fff; border:1px solid #D4DCED; border-radius:30px; padding:6px 12px; color:#0F0D1D; }

/* Fallback: if JS/WOW fails, never leave content invisible */
.no-js .wow { visibility: visible !important; }

/* Auth pages (login/register) logo + card */
.account-section .logo img, .account-form .logo img { max-height: 50px !important; width: auto !important; }
.account-section { padding: 60px 0 80px; }
.social-login-btn { border-radius: 30px !important; }
.social-login-btn img { max-height: 20px; }

/* Preloader fully disabled (markup removed; this is a safety net) */
#preloader, .preloader { display: none !important; }

/* ---- CPHost footer polish ---- */
.footer-bottom .footer-wrapper p { color: rgba(255,255,255,.85); }
.footer-bottom .footer-wrapper p a { color: #FFA31A !important; font-weight: 600; }
.footer-bottom .footer-wrapper p a:hover { color: #fff !important; }
.single-footer-widget .social-icon { gap: 10px; }
.single-footer-widget .social-icon a {
    width: 38px; height: 38px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,.12); color: #fff !important; transition: all .3s ease;
}
.single-footer-widget .social-icon a:hover { background: #FFA31A; color: #fff !important; }
.single-footer-widget .list-area a { color: rgba(255,255,255,.8); }
.single-footer-widget .list-area a:hover { color: #FFA31A; }

/* Footer must never depend on scroll-reveal — always show its content */
.footer-section .wow { visibility: visible !important; opacity: 1 !important; animation: none !important; }

/* ---- Legal pages (Privacy / Terms) professional layout ---- */
.policy-sidebar { position: sticky; top: 110px; }
.policy-nav-card {
    background: #fff; border: 1px solid var(--bx-border); border-radius: 16px;
    box-shadow: var(--bx-shadow); padding: 26px 22px; margin-bottom: 24px;
}
.policy-nav-card h5 {
    color: var(--bx-header); font-weight: 700; font-size: 1.05rem;
    margin: 0 0 16px; padding-bottom: 14px; border-bottom: 1px solid var(--bx-border);
}
.policy-nav-card ul { list-style: none; margin: 0; padding: 0; }
.policy-nav-card li { margin-bottom: 8px; }
.policy-nav-card li:last-child { margin-bottom: 0; }
.policy-nav-card li a {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 14px; border-radius: 10px;
    color: var(--bx-text); font-weight: 500; transition: all .25s ease;
}
.policy-nav-card li a i { color: var(--bx-theme); width: 18px; text-align: center; }
.policy-nav-card li a:hover { background: #eef1ff; color: var(--bx-theme); }
.policy-nav-card li a.active { background: var(--bx-theme); color: #fff; }
.policy-nav-card li a.active i { color: #fff; }

.policy-help-card {
    background: var(--bx-theme); color: #fff; border-radius: 16px;
    padding: 30px 26px; text-align: center; box-shadow: var(--bx-shadow);
}
.policy-help-icon {
    width: 60px; height: 60px; margin: 0 auto 16px; border-radius: 50%;
    background: rgba(255,255,255,.15); display: grid; place-items: center; font-size: 1.6rem;
}
.policy-help-card h5 { color: #fff; font-weight: 700; margin-bottom: 8px; }
.policy-help-card p { color: rgba(255,255,255,.85); font-size: .92rem; margin-bottom: 20px; }
.policy-help-card .theme-btn { background: #fff !important; color: var(--bx-theme) !important; }
.policy-help-card .theme-btn:hover { background: var(--bx-header) !important; color: #fff !important; }

/* content card refinements for legal pages */
.policy-section .policy-content { padding: 40px 44px; }
.policy-content h1 { font-size: 1.9rem; padding-bottom: 18px; border-bottom: 2px solid var(--bx-border); margin-bottom: 20px; }
.policy-content em { color: var(--bx-theme); font-style: normal; font-weight: 600; font-size: .9rem; display: inline-block; background: #eef1ff; padding: 4px 12px; border-radius: 20px; margin-bottom: 8px; }
.policy-content h2 { font-size: 1.25rem; }
@media (max-width: 991px) { .policy-sidebar { position: static; margin-bottom: 8px; } .policy-section .policy-content { padding: 28px 24px; } }

/* ---- Announcements (dynamic) ---- */
.announcement-card {
    display: flex; gap: 20px; background: #fff; border: 1px solid var(--bx-border);
    border-radius: 16px; box-shadow: var(--bx-shadow); padding: 26px; height: 100%;
    transition: transform .25s ease, box-shadow .25s ease;
}
.announcement-card:hover { transform: translateY(-5px); box-shadow: 0 18px 40px -18px rgba(56,75,255,.35); }
.announcement-date {
    flex-shrink: 0; width: 70px; height: 78px; border-radius: 12px;
    background: var(--bx-theme); color: #fff; display: flex; flex-direction: column;
    align-items: center; justify-content: center; line-height: 1;
}
.announcement-date .day { font-size: 1.7rem; font-weight: 800; }
.announcement-date .mon { font-size: .8rem; text-transform: uppercase; margin-top: 4px; opacity: .9; }
.announcement-body { flex: 1; min-width: 0; }
.announcement-meta { display: flex; align-items: center; gap: 12px; font-size: .82rem; color: var(--bx-text); margin-bottom: 8px; }
.announcement-meta i { color: var(--bx-theme); margin-right: 4px; }
.announcement-tag { background: #fff3e6; color: #c97a12; font-weight: 600; padding: 2px 10px; border-radius: 20px; font-size: .72rem; }
.announcement-body h3 { font-size: 1.18rem; margin: 0 0 8px; line-height: 1.4; }
.announcement-body h3 a { color: var(--bx-header); }
.announcement-body h3 a:hover { color: var(--bx-theme); }
.announcement-body p { color: var(--bx-text); font-size: .93rem; margin-bottom: 14px; }
.announcement-link { color: var(--bx-theme); font-weight: 600; font-size: .9rem; }
.announcement-link i { transition: transform .2s ease; }
.announcement-link:hover i { transform: translateX(4px); }

/* ---- Announcement article (details) ---- */
.announcement-article { background: #fff; border: 1px solid var(--bx-border); border-radius: 18px; box-shadow: var(--bx-shadow); padding: 44px 48px; }
.announcement-article-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 16px; color: var(--bx-text); font-size: .85rem; margin-bottom: 16px; }
.announcement-article-meta i { color: var(--bx-theme); margin-right: 5px; }
.announcement-article-title { font-size: 2rem; line-height: 1.25; margin-bottom: 24px; padding-bottom: 22px; border-bottom: 1px solid var(--bx-border); }
.announcement-article-body { color: var(--bx-text); line-height: 1.85; }
.announcement-article-body p { margin-bottom: 1rem; }
.announcement-article-body img { max-width: 100%; border-radius: 12px; }
@media (max-width: 575px) { .announcement-article { padding: 26px 22px; } .announcement-card { flex-direction: column; } }

/* ---- FAQ page ---- */
.faq-group { margin-bottom: 40px; scroll-margin-top: 110px; }
.faq-group:last-child { margin-bottom: 0; }
.faq-group-title { font-size: 1.4rem; color: var(--bx-header); margin-bottom: 18px; padding-left: 14px; border-left: 4px solid var(--bx-theme); }
.faq-group .accordion-item { background: #fff; border: 1px solid var(--bx-border) !important; border-radius: 12px !important; margin-bottom: 14px; overflow: hidden; }
.faq-group .accordion-button { font-family: "Jost", sans-serif; font-weight: 600; color: var(--bx-header); background: #fff; padding: 18px 22px; box-shadow: none; }
.faq-group .accordion-button:not(.collapsed) { color: var(--bx-theme); background: #f5f7ff; box-shadow: none; }
.faq-group .accordion-button:focus { box-shadow: none; border: 0; }
.faq-group .accordion-button::after { background-size: 1rem; }
.faq-group .accordion-body { color: var(--bx-text); line-height: 1.8; padding: 4px 22px 22px; }

/* ---- Contact / support cards: equal height ---- */
.choose-us-card-items { height: 100%; }

/* ---- Emails always lowercase (template capitalizes headings) ---- */
a[href^="mailto"], .choose-us-card-items .content h3 a[href^="mailto"],
.contact-list a, .nc-foot-contact a, .footer .contact-info a[href^="mailto"] { text-transform: lowercase !important; }

/* ---- Auth pages (login / register) two-panel design ---- */
.auth-section { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 48px 16px; background: var(--bx-bg) !important; }
.auth-card {
    width: 100%; max-width: 1040px; display: grid; grid-template-columns: 0.92fr 1.08fr;
    background: #fff; border-radius: 22px; overflow: hidden;
    box-shadow: 0 34px 70px -34px rgba(20,20,60,.35); border: 1px solid var(--bx-border);
}
.auth-brand {
    background: linear-gradient(160deg, #4a5bff 0%, #2230b8 100%);
    color: #fff; padding: 52px 44px; display: flex; flex-direction: column; justify-content: center;
    position: relative; overflow: hidden;
}
.auth-brand::after { content: ""; position: absolute; right: -60px; bottom: -60px; width: 220px; height: 220px; background: radial-gradient(circle, rgba(255,163,26,.35), transparent 70%); }
.auth-brand > * { position: relative; z-index: 1; }
.auth-brand-logo img { max-height: 46px; width: auto; margin-bottom: 30px; }
.auth-brand h2 { color: #fff; font-size: 1.75rem; line-height: 1.25; margin-bottom: 12px; }
.auth-brand p { color: rgba(255,255,255,.85); margin-bottom: 26px; font-size: .96rem; }
.auth-benefits { list-style: none; padding: 0; margin: 0; }
.auth-benefits li { display: flex; align-items: center; gap: 12px; color: #fff; margin-bottom: 14px; font-size: .95rem; }
.auth-benefits li i { flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%; background: rgba(255,255,255,.18); display: grid; place-items: center; font-size: .72rem; }
.auth-form-panel { padding: 50px 46px; display: flex; flex-direction: column; justify-content: center; }
/* neutralize the inner card so it's not a card-in-card */
.auth-form-panel .account-form { background: transparent !important; border: 0 !important; box-shadow: none !important; padding: 0 !important; border-radius: 0 !important; }
.auth-form-panel .account-form h4 { font-weight: 800; color: var(--bx-header); }
.auth-form-panel .account-form label { color: var(--bx-header); font-weight: 500; }
.auth-form-panel .btn--base { border-radius: 10px !important; padding: .8rem; font-weight: 600; }
@media (max-width: 991px) {
    .auth-card { grid-template-columns: 1fr; max-width: 520px; }
    .auth-brand { display: none; }
    .auth-form-panel { padding: 38px 30px; }
}

/* ---- Domain search / register page ---- */
.domain-search-box {
    background: #fff; border: 1px solid var(--bx-border); border-radius: 22px;
    box-shadow: var(--bx-shadow); padding: 48px 44px; max-width: 880px; margin: 0 auto 36px;
}
.domain-search-box .style-border { color: var(--bx-theme); }
.domain-search-box h2 { color: var(--bx-header); }
.domain-search-box p { color: var(--bx-text); }
.domain-search-form { max-width: 720px; margin: 0 auto; }
.domain-tld-chips { list-style: none; padding: 0; margin: 22px 0 0; display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.domain-tld-chips li { background: #f5f7ff; border: 1px solid var(--bx-border); border-radius: 30px; padding: 7px 16px; font-size: .85rem; color: var(--bx-text); }
.domain-tld-chips li span { font-weight: 700; color: var(--bx-theme); margin-right: 4px; }

.domain-status {
    max-width: 880px; margin: 0 auto 24px; display: flex; align-items: center; gap: 12px;
    padding: 16px 22px; border-radius: 12px; font-size: 1rem;
}
.domain-status i { font-size: 1.3rem; }
.domain-status--ok { background: #e7f8ee; color: #157347; border: 1px solid #b6e7ca; }
.domain-status--taken { background: #fdeaea; color: #c0392b; border: 1px solid #f5c6c6; }
.domain-status--warn { background: #fff5e6; color: #b8860b; border: 1px solid #ffe2ab; }
.domain-status strong { font-weight: 700; }

.domain-results { max-width: 880px; margin: 0 auto; display: flex; flex-direction: column; gap: 14px; }
.domain-result-item {
    display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 14px;
    background: #fff; border: 1px solid var(--bx-border); border-radius: 14px; padding: 18px 24px;
    transition: box-shadow .2s ease, border-color .2s ease;
}
.domain-result-item:hover { box-shadow: var(--bx-shadow); }
.domain-result-item.is-available { border-left: 4px solid #16b364; }
.domain-result-item.is-taken { border-left: 4px solid #d0d5e3; opacity: .85; }
.domain-name { display: flex; align-items: center; gap: 12px; font-family: "Jost", sans-serif; font-weight: 700; font-size: 1.15rem; color: var(--bx-header); }
.domain-name i { color: var(--bx-theme); }
.domain-best { background: #eef1ff; color: var(--bx-theme); font-size: .68rem; font-weight: 600; padding: 3px 10px; border-radius: 20px; text-transform: uppercase; letter-spacing: .04em; }
.domain-action { display: flex; align-items: center; gap: 16px; }
.domain-price { font-family: "Jost", sans-serif; font-weight: 800; font-size: 1.2rem; color: var(--bx-header); }
.domain-price small { font-size: .8rem; font-weight: 500; color: var(--bx-text); }
.domain-action .theme-btn { min-width: auto; padding: 12px 24px; }
.domain-unavailable { color: #c0392b; font-weight: 600; }
@media (max-width: 575px) {
    .domain-search-box { padding: 30px 22px; }
    .domain-result-item { flex-direction: column; align-items: flex-start; }
}

/* ---- Domain page: unified search-bar styling for .doming-input ---- */
.domain-search-form .doming-input {
    position: relative; max-width: 640px; margin: 0 auto;
    background: #fff; border: 1.5px solid var(--bx-border); border-radius: 12px;
    box-shadow: 0 10px 30px -16px rgba(56,75,255,.25); transition: border-color .2s ease, box-shadow .2s ease;
}
.domain-search-form .doming-input:focus-within { border-color: var(--bx-theme); box-shadow: 0 12px 34px -14px rgba(56,75,255,.45); }
.domain-search-form .doming-input input {
    width: 100%; border: 0 !important; outline: none !important; background: transparent !important;
    height: 64px; padding: 0 168px 0 22px; font-size: 1.05rem; color: var(--bx-header) !important;
    border-radius: 12px; box-shadow: none !important;
}
.domain-search-form .doming-input input::placeholder { color: #9aa1b9; }
.domain-search-form .doming-input .theme-btn {
    position: absolute; top: 7px; right: 7px; bottom: 7px;
    min-width: auto; padding: 0 30px; border-radius: 9px; font-weight: 600; line-height: 1;
}
@media (max-width: 575px) {
    .domain-search-form .doming-input { background: transparent; border: 0; box-shadow: none; }
    .domain-search-form .doming-input input { background: #fff !important; border: 1.5px solid var(--bx-border) !important; padding: 0 22px; margin-bottom: 12px; }
    .domain-search-form .doming-input .theme-btn { position: static; width: 100%; height: 54px; }
}

/* ---- Breadcrumb / page-heading ---- */
.breadcrumb-wrapper .page-heading { padding: 130px 0 60px !important; align-items: center !important; }
.breadcrumb-wrapper .page-heading h1 { font-size: 36px !important; margin-bottom: 6px !important; }
.breadcrumb-wrapper .breadcrumb-image img { max-height: 150px; width: auto; }
@media (max-width: 991px) { .breadcrumb-wrapper .page-heading { padding: 110px 0 48px !important; } .breadcrumb-wrapper .page-heading h1 { font-size: 28px !important; } .breadcrumb-wrapper .breadcrumb-image { display: none; } }
@media (max-width: 575px) { .breadcrumb-wrapper .page-heading { padding: 96px 16px 40px !important; gap: 0 !important; } .breadcrumb-wrapper .page-heading h1 { font-size: 24px !important; } }

/* ---- Domain configuration page ---- */
.domain-config-card {
    background: #fff; border: 1px solid var(--bx-border); border-radius: 18px;
    box-shadow: var(--bx-shadow); padding: 40px 44px; max-width: 900px; margin: 0 auto;
}
.domain-config-head { text-align: center; margin-bottom: 28px; }
.domain-config-head .dc-domain {
    display: inline-flex; align-items: center; gap: 10px; background: #eef1ff; color: var(--bx-theme);
    font-family: "Jost", sans-serif; font-weight: 700; font-size: 1.15rem; padding: 8px 20px; border-radius: 30px; margin-bottom: 14px;
}
.domain-config-head h3 { color: var(--bx-header); margin-bottom: 6px; }
.domain-config-head p { color: var(--bx-text); margin: 0; }
.dc-subtitle { color: var(--bx-header); font-weight: 700; font-size: 1.05rem; padding-bottom: 12px; margin-bottom: 18px; border-bottom: 1px solid var(--bx-border); }

.domain-period-card { border: 1.5px solid var(--bx-border) !important; border-radius: 12px !important; box-shadow: none !important; transition: border-color .2s ease, box-shadow .2s ease; height: 100%; }
.domain-period-card:has(input[name=reg_period]:checked) { border-color: var(--bx-theme) !important; box-shadow: 0 0 0 3px rgba(56,75,255,.1) !important; }
.domain-period-card .card-body { padding: 18px 20px; }
.dc-opt { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.dc-opt input[type=radio] { width: 18px; height: 18px; accent-color: var(--bx-theme); cursor: pointer; }
.dc-opt label { font-family: "Jost", sans-serif; font-weight: 600; color: var(--bx-header); margin: 0; cursor: pointer; }
.dc-opt small { color: var(--bx-theme); font-weight: 600; }
.dc-opt--sub { margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--bx-border); }
.dc-opt--sub label { font-weight: 500; color: var(--bx-text); }
.dc-opt--sub small { color: var(--bx-text); }
@media (max-width: 575px) { .domain-config-card { padding: 26px 22px; } }

/* ---- Cart page ---- */
.cart-panel { background: #fff; border: 1px solid var(--bx-border); border-radius: 16px; box-shadow: var(--bx-shadow); padding: 24px 26px; }
.cart-panel-head { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; padding-bottom: 16px; margin-bottom: 8px; border-bottom: 1px solid var(--bx-border); }
.cart-panel-head h4 { margin: 0; color: var(--bx-header); font-size: 1.25rem; display: flex; align-items: center; gap: 10px; }
.cart-panel-head h4 i { color: var(--bx-theme); }
.cart-count { background: var(--bx-theme); color: #fff; font-size: .8rem; font-weight: 700; padding: 1px 10px; border-radius: 20px; }
.cart-empty-btn { color: #c0392b; font-weight: 500; font-size: .88rem; }
.cart-empty-btn:hover { color: #a02b1f; }

.cart-line { display: flex; align-items: center; gap: 16px; padding: 18px 4px; border-bottom: 1px solid var(--bx-line, #eef1f6); }
.cart-line:last-of-type { border-bottom: 0; }
.cart-line-icon { flex-shrink: 0; width: 48px; height: 48px; border-radius: 12px; background: #eef1ff; color: var(--bx-theme); display: grid; place-items: center; font-size: 1.2rem; }
.cart-line-info { flex: 1; min-width: 0; }
.cart-line-info h6 { margin: 0 0 4px; color: var(--bx-header); font-size: 1.02rem; }
.cart-edit { font-size: .78rem; font-weight: 500; color: var(--bx-theme); margin-left: 8px; }
.cart-line-sub { display: block; color: var(--bx-text); font-size: .9rem; }
.cart-line-meta { display: block; color: var(--bx-faint, #8a8fa8); font-size: .82rem; margin-top: 2px; }
.cart-line-price { text-align: right; white-space: nowrap; }
.cart-line-price strong { display: block; font-family: "Jost", sans-serif; font-weight: 800; font-size: 1.15rem; color: var(--bx-header); }
.cart-line-price small { color: var(--bx-text); font-size: .75rem; }
.cart-remove { flex-shrink: 0; width: 32px; height: 32px; border-radius: 50%; display: grid; place-items: center; color: #b6bccb; background: #f5f6fb; transition: all .2s ease; }
.cart-remove:hover { background: #fdeaea; color: #c0392b; }

.cart-empty { text-align: center; padding: 40px 20px; }
.cart-empty-icon { width: 80px; height: 80px; margin: 0 auto 18px; border-radius: 50%; background: #eef1ff; color: var(--bx-theme); display: grid; place-items: center; font-size: 2rem; }
.cart-empty h5 { color: var(--bx-header); margin-bottom: 6px; }
.cart-empty p { color: var(--bx-text); }

.cart-coupon { margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--bx-border); }
.cart-coupon-form { display: flex; gap: 10px; }
.cart-coupon-form input { flex: 1; }
.cart-coupon-form .theme-btn { min-width: auto; padding: 0 26px; border-radius: 8px; }
.cart-coupon-applied { display: flex; align-items: center; justify-content: space-between; gap: 10px; background: #e7f8ee; border: 1px solid #b6e7ca; border-radius: 10px; padding: 12px 16px; color: #157347; font-weight: 600; }
.cart-coupon-remove { background: none; border: 0; color: #c0392b; font-weight: 600; }

.order-summary-card { background: #fff; border: 1px solid var(--bx-border); border-radius: 16px; box-shadow: var(--bx-shadow); padding: 26px; position: sticky; top: 110px; }
.order-summary-title { color: var(--bx-header); font-weight: 700; padding-bottom: 16px; margin-bottom: 16px; border-bottom: 1px solid var(--bx-border); }
.order-summary-row { display: flex; justify-content: space-between; margin-bottom: 12px; color: var(--bx-text); font-size: .95rem; }
.order-summary-row--discount { color: #157347; }
.order-summary-total { display: flex; justify-content: space-between; align-items: center; padding-top: 16px; margin-top: 4px; border-top: 1px solid var(--bx-border); }
.order-summary-total span:first-child { font-family: "Jost", sans-serif; font-weight: 700; color: var(--bx-header); font-size: 1.1rem; }
.order-summary-total span:last-child { font-family: "Jost", sans-serif; font-weight: 800; color: var(--bx-theme); font-size: 1.3rem; }
.order-summary-continue { display: block; text-align: center; margin-top: 14px; color: var(--bx-text); font-size: .9rem; }
.order-summary-continue:hover { color: var(--bx-theme); }

/* ---- Navbar cart button (replaces language selector) ---- */
.nav-cart-btn {
    position: relative; display: inline-flex; align-items: center; justify-content: center;
    width: 46px; height: 46px; border-radius: 50%; margin-left: 16px;
    background: rgba(255,255,255,.12); color: #fff; font-size: 1.1rem; transition: all .25s ease;
}
.nav-cart-btn:hover { background: #FFA31A; color: #fff; }
.nav-cart-count {
    position: absolute; top: -4px; right: -4px; min-width: 20px; height: 20px; padding: 0 5px;
    background: #FFA31A; color: #fff; border-radius: 20px; font-size: .72rem; font-weight: 700;
    display: inline-flex; align-items: center; justify-content: center; line-height: 1;
}
/* When header is sticky/scrolled (white bg), make the cart icon dark for contrast */
.header-1.sticky .nav-cart-btn, .header-sticky.sticky .nav-cart-btn { background: #eef1ff; color: var(--bx-theme); }
.header-1.sticky .nav-cart-btn:hover, .header-sticky.sticky .nav-cart-btn:hover { background: var(--bx-theme); color: #fff; }

/* ---- Checkout / order confirmation page ---- */
.checkout-steps { display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; margin-bottom: 8px; }
.checkout-steps span:not(.line) { display: inline-flex; align-items: center; gap: 8px; font-weight: 600; font-size: .92rem; color: var(--bx-faint, #8a8fa8); }
.checkout-steps .done { color: var(--bx-theme); }
.checkout-steps .active { color: var(--bx-header); }
.checkout-steps .active i, .checkout-steps .done i { color: var(--bx-theme); }
.checkout-steps .line { width: 40px; height: 2px; background: var(--bx-border); display: inline-block; }
.checkout-card { background: #fff; border: 1px solid var(--bx-border); border-radius: 16px; box-shadow: var(--bx-shadow); padding: 24px 26px; margin-bottom: 24px; }
.checkout-card-head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 14px; margin-bottom: 8px; border-bottom: 1px solid var(--bx-border); }
.checkout-card-head h5 { margin: 0; color: var(--bx-header); font-size: 1.08rem; display: flex; align-items: center; gap: 10px; }
.checkout-card-head h5 i { color: var(--bx-theme); }
.checkout-edit { font-size: .82rem; font-weight: 500; color: var(--bx-theme); }
.checkout-billing { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 24px; }
.checkout-billing > div { display: flex; flex-direction: column; }
.checkout-billing span { color: var(--bx-faint, #8a8fa8); font-size: .8rem; text-transform: uppercase; letter-spacing: .03em; }
.checkout-billing strong { color: var(--bx-header); font-weight: 600; }
.checkout-note { color: var(--bx-faint, #8a8fa8); font-size: .82rem; text-align: center; margin: 12px 0 0; }
@media (max-width: 575px) { .checkout-billing { grid-template-columns: 1fr; } }

/* ---- Account settings pages (profile / password / 2fa) ---- */
.account-profile-card { background: var(--bx-theme); color: #fff; border-radius: 16px; box-shadow: var(--bx-shadow); padding: 30px 24px; text-align: center; margin-bottom: 24px; }
.account-avatar { width: 76px; height: 76px; margin: 0 auto 14px; border-radius: 50%; background: rgba(255,255,255,.18); display: grid; place-items: center; font-family: "Jost", sans-serif; font-weight: 800; font-size: 1.9rem; }
.account-profile-card h5 { color: #fff; margin-bottom: 4px; }
.account-profile-card p { color: rgba(255,255,255,.85); margin: 0; font-size: .9rem; word-break: break-word; }
.account-nav-card { background: #fff; border: 1px solid var(--bx-border); border-radius: 16px; box-shadow: var(--bx-shadow); padding: 14px; }
.account-nav-card a { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border-radius: 10px; color: var(--bx-header); font-weight: 500; transition: all .2s ease; }
.account-nav-card a i { width: 18px; text-align: center; color: var(--bx-theme); }
.account-nav-card a:hover { background: #eef1ff; color: var(--bx-theme); }
.account-nav-card a.active { background: var(--bx-theme); color: #fff; }
.account-nav-card a.active i { color: #fff; }
.account-nav-card a.account-nav-logout { color: #c0392b; }
.account-nav-card a.account-nav-logout i { color: #c0392b; }
.account-nav-card a.account-nav-logout:hover { background: #fdeaea; }
.account-form-card { background: #fff; border: 1px solid var(--bx-border); border-radius: 16px; box-shadow: var(--bx-shadow); padding: 28px 30px; }
.account-form-head { padding-bottom: 16px; margin-bottom: 20px; border-bottom: 1px solid var(--bx-border); }
.account-form-head h5 { margin: 0; color: var(--bx-header); display: flex; align-items: center; gap: 10px; }
.account-form-head h5 i { color: var(--bx-theme); }
.account-form-card label { color: var(--bx-header); font-weight: 500; }
@media (max-width: 575px) { .account-form-card { padding: 22px; } }

/* ---- 2FA page extras ---- */
.twofa-status { display: flex; align-items: center; gap: 10px; padding: 14px 18px; border-radius: 10px; font-weight: 500; }
.twofa-status i { font-size: 1.2rem; }
.twofa-status--on { background: #e7f8ee; color: #157347; border: 1px solid #b6e7ca; }
.twofa-status--off { background: #fff5e6; color: #b8860b; border: 1px solid #ffe2ab; }
.twofa-help, .twofa-download { color: var(--bx-text); font-size: .92rem; }
.twofa-qr { text-align: center; margin: 18px 0; }
.twofa-qr img { width: 180px; height: 180px; border: 1px solid var(--bx-border); border-radius: 12px; padding: 8px; background: #fff; }

/* =====================================================================
   DASHBOARD + LIST PAGES (services, domains, invoices, tickets)
   ===================================================================== */

/* ---- Page header bar above content panels ---- */
.dash-head { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 14px; margin-bottom: 22px; }
.dash-head h4 { margin: 0; color: var(--bx-header); font-family: "Jost", sans-serif; font-weight: 700; font-size: 1.4rem; display: flex; align-items: center; gap: 10px; }
.dash-head h4 i { color: var(--bx-theme); }
.dash-head .theme-btn, .dash-head .btn--base { white-space: nowrap; }

/* ---- Welcome banner (dashboard top) ---- */
.dash-welcome { background: linear-gradient(110deg, var(--bx-theme) 0%, #2c3bd6 100%); border-radius: 16px; color: #fff; padding: 28px 32px; margin-bottom: 24px; position: relative; overflow: hidden; box-shadow: var(--bx-shadow); }
.dash-welcome::after { content: ""; position: absolute; right: -40px; top: -40px; width: 180px; height: 180px; border-radius: 50%; background: rgba(255,255,255,.08); }
.dash-welcome::before { content: ""; position: absolute; right: 70px; bottom: -60px; width: 140px; height: 140px; border-radius: 50%; background: rgba(255,163,26,.18); }
.dash-welcome h3 { color: #fff; margin: 0 0 6px; font-weight: 700; position: relative; z-index: 1; }
.dash-welcome p { color: rgba(255,255,255,.85); margin: 0; position: relative; z-index: 1; }
.dash-welcome .dash-welcome-actions { position: relative; z-index: 1; margin-top: 16px; display: flex; gap: 10px; flex-wrap: wrap; }
.dash-welcome .dash-welcome-actions a { background: #fff; color: var(--bx-theme); border-radius: 30px; padding: .55rem 1.3rem; font-weight: 600; font-size: .9rem; transition: all .25s ease; }
.dash-welcome .dash-welcome-actions a.alt { background: var(--bx-theme-2); color: #fff; }
.dash-welcome .dash-welcome-actions a:hover { transform: translateY(-2px); box-shadow: 0 8px 18px rgba(0,0,0,.18); }

/* ---- Stat cards ---- */
.dash-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-bottom: 24px; }
@media (max-width: 991px) { .dash-stats { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .dash-stats { grid-template-columns: 1fr; } }
.dash-stat { background: #fff; border: 1px solid var(--bx-border); border-radius: 14px; box-shadow: var(--bx-shadow); padding: 22px 22px; display: flex; align-items: center; gap: 16px; position: relative; transition: all .25s ease; }
.dash-stat:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(56,75,255,.12); border-color: var(--bx-theme); }
.dash-stat .dash-stat-icon { width: 54px; height: 54px; min-width: 54px; border-radius: 14px; display: grid; place-items: center; font-size: 1.5rem; color: #fff; }
.dash-stat .dash-stat-icon.i1 { background: linear-gradient(135deg,#384BFF,#5b6bff); }
.dash-stat .dash-stat-icon.i2 { background: linear-gradient(135deg,#FFA31A,#ffbd55); }
.dash-stat .dash-stat-icon.i3 { background: linear-gradient(135deg,#10b981,#34d399); }
.dash-stat .dash-stat-icon.i4 { background: linear-gradient(135deg,#8b5cf6,#a78bfa); }
.dash-stat .dash-stat-icon.i5 { background: linear-gradient(135deg,#ec4899,#f472b6); }
.dash-stat .dash-stat-icon.i6 { background: linear-gradient(135deg,#0ea5e9,#38bdf8); }
.dash-stat .dash-stat-meta p { margin: 0 0 2px; color: var(--bx-text); font-size: .88rem; }
.dash-stat .dash-stat-meta h4 { margin: 0; color: var(--bx-header); font-weight: 700; font-family: "Jost", sans-serif; }
.dash-stat .dash-stat-link { position: absolute; inset: 0; }

/* ---- Generic info card (dashboard lower row) ---- */
.dash-info-card { background: #fff; border: 1px solid var(--bx-border); border-radius: 14px; box-shadow: var(--bx-shadow); padding: 22px 24px; height: 100%; }
.dash-info-card .dash-info-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 14px; padding-bottom: 14px; border-bottom: 1px solid var(--bx-border); }
.dash-info-card .dash-info-head span.title { color: var(--bx-header); font-weight: 600; display: flex; align-items: center; gap: 8px; }
.dash-info-card .dash-info-head span.title i { color: var(--bx-theme); }
.dash-info-card .dash-info-body { color: var(--bx-text); font-size: .94rem; }
.dash-info-card .dash-info-body a { color: var(--bx-theme); font-weight: 500; }

/* KYC alert card */
.dash-alert { background: #fff5e6; border: 1px solid #ffe2ab; border-radius: 14px; padding: 20px 24px; margin-bottom: 22px; }
.dash-alert h6 { color: #b8860b; margin: 0; }

/* ---- List panel wrapping product tables ---- */
.dash-panel { background: #fff; border: 1px solid var(--bx-border); border-radius: 16px; box-shadow: var(--bx-shadow); overflow: hidden; }
.dash-panel .dash-panel-head { padding: 18px 24px; border-bottom: 1px solid var(--bx-border); display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.dash-panel .dash-panel-head h5 { margin: 0; color: var(--bx-header); font-weight: 600; font-size: 1.05rem; display: flex; align-items: center; gap: 9px; }
.dash-panel .dash-panel-head h5 i { color: var(--bx-theme); }
.dash-panel .dash-panel-body { padding: 8px 10px 4px; }
.dash-panel .table { margin: 0; }
.dash-panel .table thead th { background: var(--bx-bg); color: var(--bx-header); font-weight: 600; border: none; padding: 14px 18px; font-size: .9rem; }
.dash-panel .table tbody td { vertical-align: middle; padding: 16px 18px; border-color: #eef1f8; color: var(--bx-text); }
.dash-panel .table tbody tr:last-child td { border-bottom: none; }
.dash-panel .table tbody tr:hover td { background: #f7f9ff; }
.dash-panel .table a.fw-bold { color: var(--bx-header); }
.dash-panel .table a.fw-bold:hover { color: var(--bx-theme); }

/* round icon action button in tables */
.dash-action-btn { width: 38px; height: 38px; display: inline-grid; place-items: center; border-radius: 10px; background: #eef1ff; color: var(--bx-theme) !important; transition: all .2s ease; }
.dash-action-btn:hover { background: var(--bx-theme); color: #fff !important; }

/* key/value info list (KYC submission, service meta, etc.) */
.dash-info-list { list-style: none; margin: 0; padding: 0; }
.dash-info-list li { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 4px; border-bottom: 1px solid #eef1f8; }
.dash-info-list li:last-child { border-bottom: none; }
.dash-info-list li .label { color: var(--bx-text); font-weight: 500; }
.dash-info-list li .value { color: var(--bx-header); font-weight: 600; text-align: right; word-break: break-word; }

/* KYC form intro note */
.kyc-intro { background: #eef1ff; border: 1px solid var(--bx-border); border-radius: 12px; padding: 14px 18px; color: var(--bx-text); display: flex; align-items: center; gap: 9px; }
.kyc-intro i { color: var(--bx-theme); font-size: 1.1rem; }
.kyc-form .form-group label, .kyc-form label.form-label { color: var(--bx-header); font-weight: 600; margin-bottom: 6px; }

/* ===== Service details ===== */
.service-hero { display: flex; align-items: center; gap: 20px; background: #fff; border: 1px solid var(--bx-border); border-radius: 16px; box-shadow: var(--bx-shadow); padding: 24px; }
.service-hero-icon { width: 70px; height: 70px; flex: 0 0 70px; border-radius: 16px; display: grid; place-items: center; background: linear-gradient(135deg, var(--bx-theme), #5b6bff); color: #fff; font-size: 2rem; }
.service-hero-info { flex: 1 1 auto; min-width: 0; }
.service-hero-info .cat { display: inline-block; font-size: .8rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; color: var(--bx-theme); }
.service-hero-info h3 { margin: 2px 0 4px; color: var(--bx-header); font-weight: 700; font-size: 1.4rem; }
.service-hero-info .dom { color: var(--bx-text); font-weight: 500; display: inline-flex; align-items: center; gap: 6px; }
.service-hero-info .dom:hover { color: var(--bx-theme); }
.service-hero-status { flex: 0 0 auto; }

.service-actions { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 14px; }
.svc-btn { display: flex; align-items: center; gap: 14px; padding: 16px 18px; border-radius: 14px; border: 1px solid var(--bx-border); background: #fff; text-align: left; cursor: pointer; transition: all .22s ease; box-shadow: var(--bx-shadow); width: 100%; }
.svc-btn:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(56, 75, 255, .14); }
.svc-btn-ic { width: 46px; height: 46px; flex: 0 0 46px; border-radius: 12px; display: grid; place-items: center; font-size: 1.4rem; color: #fff; }
.svc-btn-tx { display: flex; flex-direction: column; line-height: 1.25; min-width: 0; }
.svc-btn-tx strong { color: var(--bx-header); font-weight: 600; font-size: .98rem; }
.svc-btn-tx small { color: var(--bx-text); font-size: .8rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.svc-btn--visit .svc-btn-ic { background: linear-gradient(135deg, #1aa85b, #34c97a); }
.svc-btn--visit:hover { border-color: #34c97a; }
.svc-btn--login .svc-btn-ic { background: linear-gradient(135deg, var(--bx-theme), #5b6bff); }
.svc-btn--login:hover { border-color: var(--bx-theme); }
.svc-btn--cancel .svc-btn-ic { background: linear-gradient(135deg, #e23744, #ff5a66); }
.svc-btn--cancel:hover { border-color: #ff5a66; }

.service-notice { display: flex; align-items: flex-start; gap: 14px; border-radius: 14px; padding: 18px 20px; border: 1px solid; }
.service-notice i { font-size: 1.6rem; line-height: 1; margin-top: 2px; }
.service-notice h6 { margin: 0 0 3px; font-weight: 700; }
.service-notice p { margin: 0; font-size: .92rem; }
.service-notice--warning { background: #fff7e8; border-color: #ffe2b0; color: #8a5a00; }
.service-notice--danger { background: #fdeced; border-color: #f7c4c8; color: #a32430; }

/* usage meters */
.usage-meter { background: var(--bx-bg); border: 1px solid var(--bx-border); border-radius: 14px; padding: 18px 20px; }
.usage-meter-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.usage-meter-title { font-weight: 600; color: var(--bx-header); display: inline-flex; align-items: center; gap: 8px; }
.usage-meter-title i { color: var(--bx-theme); }
.usage-meter-pct { font-weight: 700; color: var(--bx-header); }
.usage-bar { height: 10px; border-radius: 20px; background: #e3e8f5; overflow: hidden; }
.usage-bar > span { display: block; height: 100%; border-radius: 20px; background: linear-gradient(90deg, var(--bx-theme), #5b6bff); transition: width .6s ease; }
.usage-bar--alt > span { background: linear-gradient(90deg, var(--bx-theme-2), #ffc05a); }
.usage-meter-foot { margin-top: 10px; font-size: .85rem; color: var(--bx-text); }

@media (max-width: 575px) {
    .service-hero { flex-direction: column; text-align: center; }
}

/* status pills (used where product prints raw badges) */
.dash-panel .badge { border-radius: 30px; padding: .42em .9em; font-weight: 500; font-size: .76rem; }

/* ---- Status badge variants (product prints badge--success/danger/etc.;
   none were defined in the loaded CSS, so statuses rendered invisible) ---- */
.badge--success, .badge.badge--success, .badge-success {
    display: inline-block; padding: .42em .9em; border-radius: 30px;
    font-size: .76rem; font-weight: 600; line-height: 1.2;
    color: #157347 !important; background: #e7f8ee !important;
}
.badge--danger, .badge.badge--danger, .badge-danger {
    display: inline-block; padding: .42em .9em; border-radius: 30px;
    font-size: .76rem; font-weight: 600; line-height: 1.2;
    color: #c0392b !important; background: #fdeaea !important;
}
.badge--warning, .badge.badge--warning, .badge-warning {
    display: inline-block; padding: .42em .9em; border-radius: 30px;
    font-size: .76rem; font-weight: 600; line-height: 1.2;
    color: #b8860b !important; background: #fff5e6 !important;
}
.badge--primary, .badge.badge--primary, .badge-primary {
    display: inline-block; padding: .42em .9em; border-radius: 30px;
    font-size: .76rem; font-weight: 600; line-height: 1.2;
    color: var(--bx-theme) !important; background: #eef1ff !important;
}
.badge--dark, .badge.badge--dark, .badge-dark, .badge--secondary, .badge-secondary {
    display: inline-block; padding: .42em .9em; border-radius: 30px;
    font-size: .76rem; font-weight: 600; line-height: 1.2;
    color: #4b5563 !important; background: #eef0f4 !important;
}
.badge--info, .badge.badge--info, .badge-info {
    display: inline-block; padding: .42em .9em; border-radius: 30px;
    font-size: .76rem; font-weight: 600; line-height: 1.2;
    color: #0e7490 !important; background: #e0f5fb !important;
}

/* small inline domain search on dashboard */
.dash-domain-form { position: relative; }
.dash-domain-form .form--control { padding-right: 110px; }
.dash-domain-form .dash-domain-btn { position: absolute; right: 5px; top: 5px; bottom: 5px; border-radius: 30px; padding: 0 18px; }

/* =====================================================================
   DEPOSIT / ADD FUNDS
   ===================================================================== */
.deposit-amount-field .form-label { color: var(--bx-header); font-weight: 600; }
.deposit-amount-input { position: relative; }
.deposit-amount-input .cur {
    position: absolute; left: 0; top: 0; bottom: 0; width: 54px;
    display: grid; place-items: center; font-weight: 700; color: var(--bx-theme);
    background: #eef1ff; border-radius: 12px 0 0 12px; font-size: 1.1rem;
}
.deposit-amount-input .amount {
    height: 64px; padding-left: 70px; font-size: 1.6rem; font-weight: 700;
    color: var(--bx-header); border: 1px solid var(--bx-border); border-radius: 12px;
    width: 100%; background: #fff;
}
.deposit-amount-input .amount:focus { border-color: var(--bx-theme); box-shadow: 0 0 0 3px rgba(56,75,255,.12); outline: none; }
.deposit-limit-hint { color: var(--bx-text); font-size: .85rem; }
.deposit-limit-hint i { color: var(--bx-theme); }

.deposit-section-label { color: var(--bx-header); font-weight: 600; margin: 26px 0 14px; font-size: 1rem; }
.deposit-method-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (max-width: 575px) { .deposit-method-grid { grid-template-columns: 1fr; } }
.deposit-method {
    position: relative; display: flex; align-items: center; gap: 12px;
    border: 1px solid var(--bx-border); border-radius: 12px; padding: 12px 14px;
    cursor: pointer; transition: all .2s ease; background: #fff; margin: 0;
}
.deposit-method:hover { border-color: var(--bx-theme); background: #f7f9ff; }
.deposit-method__thumb { width: 54px; height: 38px; flex: 0 0 54px; display: grid; place-items: center; background: #f5f7fb; border-radius: 8px; overflow: hidden; }
.deposit-method__thumb img { max-width: 100%; max-height: 100%; object-fit: contain; }
.deposit-method__name { font-weight: 600; color: var(--bx-header); font-size: .92rem; flex: 1 1 auto; }
.deposit-method__check { color: var(--bx-theme); font-size: 1.15rem; opacity: 0; transition: opacity .2s ease; }
.deposit-method input.gateway-input:checked + .deposit-method__thumb { } /* no-op for clarity */
.deposit-method:has(input.gateway-input:checked) {
    border-color: var(--bx-theme); background: #eef1ff;
    box-shadow: 0 6px 18px rgba(56,75,255,.12);
}
.deposit-method:has(input.gateway-input:checked) .deposit-method__check { opacity: 1; }
.deposit-more {
    display: inline-flex; align-items: center; gap: 8px; margin-top: 14px;
    background: transparent; border: 1px dashed var(--bx-border); color: var(--bx-theme);
    border-radius: 30px; padding: 8px 18px; font-weight: 600; font-size: .88rem; transition: all .2s ease;
}
.deposit-more:hover { background: #eef1ff; border-color: var(--bx-theme); }

.deposit-summary-card {
    background: #fff; border: 1px solid var(--bx-border); border-radius: 16px;
    box-shadow: var(--bx-shadow); padding: 26px 24px; position: sticky; top: 20px;
}
.deposit-summary-title { color: var(--bx-header); font-weight: 700; margin: 0 0 20px; display: flex; align-items: center; gap: 9px; font-size: 1.1rem; }
.deposit-summary-title i { color: var(--bx-theme); }
.deposit-summary-row { display: flex; justify-content: space-between; align-items: center; gap: 10px; padding: 9px 0; color: var(--bx-text); font-size: .92rem; }
.deposit-summary-row .val { font-weight: 600; color: var(--bx-header); text-align: right; }
.deposit-summary-row.total { font-size: 1.05rem; }
.deposit-summary-row.total .val { color: var(--bx-theme); font-weight: 800; font-size: 1.2rem; }
.deposit-summary-card hr { border-color: var(--bx-border); opacity: 1; margin: 6px 0; }
.proccessing-fee-info { color: var(--bx-theme); cursor: help; }
.deposit-crypto-note { background: #fff5e6; color: #b8860b; border-radius: 10px; padding: 10px 14px; font-size: .85rem; }
.deposit-secure-note { margin: 16px 0 0; text-align: center; color: #8893ad; font-size: .82rem; }
.deposit-secure-note i { color: #157347; margin-right: 4px; }

/* =====================================================================
   PROFESSIONAL INVOICE DOCUMENT (web view)
   ===================================================================== */
.invoice-doc { max-width: 880px; margin: 0 auto; background: #fff; border: 1px solid var(--bx-border); border-radius: 16px; box-shadow: var(--bx-shadow); overflow: hidden; }
.invoice-doc .invoice-doc-top { background: var(--bx-header); color: #fff; padding: 32px 40px; display: flex; justify-content: space-between; align-items: flex-start; gap: 20px; flex-wrap: wrap; }
.invoice-doc .invoice-doc-top .inv-brand img { max-height: 46px; }
.invoice-doc .invoice-doc-top .inv-brand p { color: rgba(255,255,255,.7); margin: 12px 0 0; font-size: .85rem; max-width: 260px; }
.invoice-doc .invoice-doc-top .inv-meta { text-align: right; }
.invoice-doc .invoice-doc-top .inv-meta .inv-label { font-size: 1.7rem; font-weight: 700; letter-spacing: .04em; font-family: "Jost", sans-serif; }
.invoice-doc .invoice-doc-top .inv-meta .inv-no { color: rgba(255,255,255,.8); margin-top: 4px; font-size: .92rem; }
.invoice-doc .invoice-doc-top .inv-meta .inv-status { display: inline-block; margin-top: 12px; }
.invoice-doc .invoice-doc-body { padding: 32px 40px; }
.invoice-status-pill { display: inline-block; padding: .35em 1em; border-radius: 30px; font-size: .78rem; font-weight: 600; }
.invoice-status-pill.paid { background: #e7f8ee; color: #157347; }
.invoice-status-pill.unpaid { background: #fdeaea; color: #c0392b; }
.invoice-status-pill.partial { background: #eef1ff; color: #384BFF; }
.invoice-status-pill.cancelled { background: #eef0f4; color: #6b7280; }
.invoice-parties { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 28px; }
@media (max-width: 575px) { .invoice-parties { grid-template-columns: 1fr; } }
.invoice-parties .inv-party-label { color: var(--bx-theme); font-weight: 600; font-size: .8rem; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 8px; }
.invoice-parties h6 { color: var(--bx-header); margin: 0 0 8px; font-weight: 700; }
.invoice-parties ul { list-style: none; margin: 0; padding: 0; }
.invoice-parties li { color: var(--bx-text); font-size: .9rem; margin-bottom: 3px; }
.invoice-parties .text-end ul, .invoice-parties .text-end { text-align: right; }
.invoice-doc .table { border: 1px solid var(--bx-border); border-radius: 12px; overflow: hidden; margin: 0; }
.invoice-doc .table thead th { background: var(--bx-bg); color: var(--bx-header); font-weight: 600; border: none; padding: 14px 18px; }
.invoice-doc .table tbody td { padding: 14px 18px; border-color: #eef1f8; color: var(--bx-text); vertical-align: middle; }
.invoice-doc .table tfoot td { padding: 16px 18px; }
.invoice-doc .inv-total-row td { background: var(--bx-bg); font-weight: 700; color: var(--bx-header); font-size: 1.05rem; }
.invoice-doc .invoice-doc-foot { padding: 24px 40px 34px; border-top: 1px solid var(--bx-border); }
.invoice-pay-card { background: var(--bx-bg); border: 1px solid var(--bx-border); border-radius: 14px; padding: 22px 24px; margin-top: 26px; }
.invoice-pay-card h6 { color: var(--bx-header); margin: 0; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.invoice-pay-card h6 i { color: var(--bx-theme); }
.invoice-pay-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.invoice-pay-due { text-align: right; }
.invoice-pay-due span { display: block; font-size: .76rem; color: var(--bx-text); text-transform: uppercase; letter-spacing: .04em; }
.invoice-pay-due strong { font-size: 1.3rem; color: var(--bx-theme); font-family: "Jost", sans-serif; font-weight: 800; }
.invoice-pay-card .form-label { color: var(--bx-header); font-weight: 600; font-size: .85rem; margin-bottom: 6px; }
.invoice-pay-card select.form-select {
    height: 50px; border: 1px solid var(--bx-border); border-radius: 10px; background-color: #fff;
    color: var(--bx-header); font-weight: 500; padding: 0 16px; width: 100%; transition: all .2s ease;
}
.invoice-pay-card select.form-select:focus { border-color: var(--bx-theme); box-shadow: 0 0 0 3px rgba(56,75,255,.12); outline: none; }
.invoice-pay-card .payBtn { height: 50px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; }
.invoice-pay-card .payBtn:disabled { opacity: .55; cursor: not-allowed; }
.h-50 { height: 50px !important; }

/* Invoice pay — payment method tiles */
.pay-methods { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 6px; }
@media (max-width: 767px) { .pay-methods { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 420px) { .pay-methods { grid-template-columns: 1fr; } }
.pay-method {
    position: relative; display: flex; align-items: center; gap: 10px; margin: 0; cursor: pointer;
    background: #fff; border: 1px solid var(--bx-border); border-radius: 12px; padding: 12px 14px; transition: all .2s ease;
}
.pay-method:hover { border-color: var(--bx-theme); background: #f7f9ff; }
.pay-method__thumb { width: 46px; height: 32px; flex: 0 0 46px; display: grid; place-items: center; background: #f5f7fb; border-radius: 7px; overflow: hidden; }
.pay-method__thumb img { max-width: 100%; max-height: 100%; object-fit: contain; }
.pay-method__icon { width: 46px; height: 32px; flex: 0 0 46px; display: grid; place-items: center; background: #eef1ff; color: var(--bx-theme); border-radius: 7px; font-size: 1.05rem; }
.pay-method__name { font-weight: 600; color: var(--bx-header); font-size: .86rem; line-height: 1.25; flex: 1 1 auto; }
.pay-method__name small { display: block; font-weight: 500; color: var(--bx-text); font-size: .76rem; }
.pay-method__check { position: absolute; top: 8px; right: 9px; color: var(--bx-theme); font-size: .95rem; opacity: 0; transition: opacity .2s ease; }
.pay-method:has(input:checked) { border-color: var(--bx-theme); background: #eef1ff; box-shadow: 0 6px 16px rgba(56,75,255,.12); }
.pay-method:has(input:checked) .pay-method__check { opacity: 1; }

/* Invoice footer action buttons */
.invoice-foot-btns { display: flex; gap: 12px; flex-wrap: wrap; }
.invoice-foot-btns .invoice-btn {
    flex: 1 1 0; min-width: 150px; display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    height: 48px; border-radius: 30px; font-weight: 600; font-size: .92rem; transition: all .25s ease; border: 1.5px solid transparent;
}
.invoice-btn--solid { background: var(--bx-theme); color: #fff; }
.invoice-btn--solid:hover { background: #2c3bd6; color: #fff; transform: translateY(-2px); box-shadow: 0 8px 18px rgba(56,75,255,.25); }
.invoice-btn--outline { background: #fff; color: var(--bx-theme); border-color: var(--bx-theme); }
.invoice-btn--outline:hover { background: var(--bx-theme); color: #fff; transform: translateY(-2px); }
.invoice-btn--ghost { background: #fff; color: var(--bx-header); border-color: var(--bx-border); }
.invoice-btn--ghost:hover { background: var(--bx-bg); color: var(--bx-theme); border-color: var(--bx-theme); }
@media (max-width: 575px) { .invoice-foot-btns .invoice-btn { flex: 1 1 100%; } }
@media (max-width: 767px) { .invoice-doc .invoice-doc-top, .invoice-doc .invoice-doc-body, .invoice-doc .invoice-doc-foot { padding-left: 22px; padding-right: 22px; } }

/* =====================================================================
   TICKETS
   ===================================================================== */
.ticket-priority { display: inline-block; padding: .4em .9em; border-radius: 30px; font-size: .75rem; font-weight: 600; }
.ticket-priority.low { background: #eef0f4; color: #6b7280; }
.ticket-priority.medium { background: #fff5e6; color: #b8860b; }
.ticket-priority.high { background: #fdeaea; color: #c0392b; }
.ticket-attach-card { border: 1px dashed var(--bx-border); border-radius: 12px; padding: 18px 20px; background: var(--bx-bg); }

/* =====================================================================
   FOOTER — compact & professional (template default was very tall)
   ===================================================================== */
.footer-widgets-wrapper { padding: 56px 0 28px !important; }
@media (max-width: 991px) { .footer-widgets-wrapper { padding: 44px 0 22px !important; } }
.footer-widgets-wrapper .single-footer-widget { margin-top: 0 !important; }
@media (max-width: 767px) { .footer-widgets-wrapper .single-footer-widget { margin-top: 26px !important; } }
.footer-widgets-wrapper .single-footer-widget .ml-50,
.footer-widgets-wrapper .single-footer-widget.style-margin { margin-left: 0 !important; }
.footer-widgets-wrapper .single-footer-widget .widget-head { margin-bottom: 16px !important; }
.footer-widgets-wrapper .single-footer-widget .widget-head img { max-height: 42px; width: auto; }
.footer-widgets-wrapper .single-footer-widget .widget-head h3 { font-size: 18px !important; padding-bottom: 10px !important; border-bottom-width: 2px !important; }
.footer-widgets-wrapper .single-footer-widget .footer-content p { font-size: .9rem; line-height: 1.6; margin-bottom: 14px; opacity: .92; }
.footer-widgets-wrapper .single-footer-widget .footer-content .contact-info li:not(:last-child) { margin-bottom: 10px !important; }
.footer-widgets-wrapper .single-footer-widget .footer-content .social-icon { margin-top: 18px !important; }
.footer-widgets-wrapper .single-footer-widget .list-area li:not(:last-child) { margin-bottom: 11px !important; }
.footer-widgets-wrapper .single-footer-widget .list-area li a { font-size: .92rem; }
.footer-widgets-wrapper .single-footer-widget .list-area.mb-4 { margin-bottom: 18px !important; }
.footer-bottom { margin-bottom: 22px !important; }
.footer-bottom .footer-wrapper { padding: 16px 26px !important; border-radius: 12px !important; }
.footer-bottom .footer-wrapper p { font-size: .88rem; margin: 0; }
.footer-bottom .footer-wrapper .brand-logo li { padding: 4px 6px !important; }
.footer-bottom .footer-wrapper .brand-logo li img { max-height: 22px; width: auto; }
