/* ============================================================
   six2026 — Custom CSS
   Alshamel Tech Billing Portal
   Design inspired by https://alshamel.tech
   ============================================================ */

/* ── Google Fonts ────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@300;400;600;700;800&family=Rubik:wght@300;400;500;700&display=swap');

/* ── CSS Variables ───────────────────────────────────────── */
:root {
    --brand-blue: #0d6efd;
    --brand-blue-dark: #0a58ca;
    --brand-blue-deep: #1a2a4a;
    --brand-red: #dc3545;
    --nav-bg: #0d6efd;
    --nav-text: #ffffff;
    --header-bg: #ffffff;
    --body-bg: #f4f6fb;
    --card-bg: #ffffff;
    --card-radius: 14px;
    --card-shadow: 0 4px 18px rgba(13, 110, 253, 0.08);
    --footer-bg: #1a2a4a;
    --footer-text: #c9d9f0;
    --font-ar: 'Cairo', 'Segoe UI', Tahoma, sans-serif;
    --font-en: 'Rubik', 'Segoe UI', Arial, sans-serif;
    --transition: 0.25s ease;
}

/* ── Base / Body ─────────────────────────────────────────── */
html,
body {
    background-color: var(--body-bg) !important;
}

body,
input,
button,
select,
textarea {
    font-family: var(--font-ar) !important;
    color: #232323;
}

[dir="rtl"] body,
[dir="rtl"] input,
[dir="rtl"] button,
[dir="rtl"] select,
[dir="rtl"] textarea {
    font-family: var(--font-ar) !important;
}

[dir="ltr"] body,
[dir="ltr"] input,
[dir="ltr"] button,
[dir="ltr"] select,
[dir="ltr"] textarea {
    font-family: var(--font-en) !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font-ar) !important;
    font-weight: 700;
}

[dir="ltr"] h1,
[dir="ltr"] h2,
[dir="ltr"] h3,
[dir="ltr"] h4,
[dir="ltr"] h5,
[dir="ltr"] h6 {
    font-family: var(--font-en) !important;
}

a {
    color: var(--brand-blue);
    transition: color var(--transition);
}

a:hover {
    color: var(--brand-blue-dark);
}

/* ── Top Header Bar ──────────────────────────────────────── */
section#header {
    background-color: var(--header-bg) !important;
    border-bottom: 1px solid #e8eef7;
    padding: 12px 0;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    border-radius: 0 !important;
}

section#header .top-nav {
    list-style: none;
    margin: 0 0 8px 0;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

[dir="rtl"] section#header .top-nav {
    justify-content: flex-start;
}

section#header .top-nav li a {
    color: #555;
    font-size: 0.82rem;
    font-weight: 500;
    padding: 3px 10px;
    border-radius: 20px;
    text-decoration: none;
    transition: all var(--transition);
}

section#header .top-nav li a:hover {
    color: var(--brand-blue);
    background: #eef3ff;
}

section#header .top-nav .primary-action a.btn {
    background-color: var(--brand-blue) !important;
    border-color: var(--brand-blue) !important;
    color: #fff !important;
    border-radius: 50px !important;
    padding: 5px 18px !important;
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.2px;
    transition: background var(--transition), box-shadow var(--transition);
}

section#header .top-nav .primary-action a.btn:hover {
    background-color: var(--brand-blue-dark) !important;
    border-color: var(--brand-blue-dark) !important;
    box-shadow: 0 4px 14px rgba(13, 110, 253, 0.3);
}

section#header .logo img {
    max-height: 46px !important;
    transition: opacity var(--transition);
}

section#header .logo-text {
    font-family: var(--font-ar) !important;
    font-weight: 800 !important;
    color: var(--brand-blue) !important;
    font-size: 1.7em !important;
}

/* ── Main Navigation Bar ─────────────────────────────────── */
section#main-menu {
    background-color: var(--nav-bg) !important;
    box-shadow: 0 3px 12px rgba(13, 110, 253, 0.2);
}

.navbar-main {
    background-color: var(--nav-bg) !important;
    border: 0 !important;
    min-height: 44px !important;
    border-radius: 0 !important;
    font-family: var(--font-ar) !important;
    font-size: 0.9rem !important;
}

[dir="ltr"] .navbar-main {
    font-family: var(--font-en) !important;
}

.navbar-main li.account {
    background-color: rgba(0, 0, 0, 0.15) !important;
}

.navbar-main .navbar-nav>li>a {
    color: rgba(255, 255, 255, 0.92) !important;
    font-weight: 600;
    padding-top: 12px !important;
    padding-bottom: 12px !important;
    position: relative;
    letter-spacing: 0.2px;
}

.navbar-main .navbar-nav>li>a::after {
    content: '';
    position: absolute;
    bottom: 6px;
    left: 50%;
    width: 0;
    height: 2px;
    background: rgba(255, 255, 255, 0.75);
    transition: all 0.25s ease;
    transform: translateX(-50%);
    border-radius: 2px;
}

[dir="rtl"] .navbar-main .navbar-nav>li>a::after {
    left: auto;
    right: 50%;
    transform: translateX(50%);
}

.navbar-main .navbar-nav>li>a:hover::after,
.navbar-main .navbar-nav>li.active>a::after {
    width: 70%;
}

.navbar-main .navbar-nav>li>a:hover,
.navbar-main .navbar-nav>li>a:focus,
.navbar-main .navbar-nav>.active>a,
.navbar-main .navbar-nav>.active>a:hover,
.navbar-main .navbar-nav>.open>a,
.navbar-main .navbar-nav>.open>a:hover {
    color: #fff !important;
    background-color: rgba(0, 0, 0, 0.12) !important;
}

.navbar-main .dropdown-menu {
    border-radius: 10px !important;
    border: 0 !important;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12) !important;
    padding: 6px 0 !important;
    margin-top: 4px !important;
    min-width: 180px;
}

.navbar-main .dropdown-menu>li>a {
    color: #333 !important;
    padding: 8px 18px !important;
    font-size: 0.88rem;
    transition: background var(--transition);
}

.navbar-main .dropdown-menu>li>a:hover,
.navbar-main .dropdown-menu>li>a:focus,
.navbar-main .navbar-nav .dropdown-menu>.active>a {
    background-color: #eef3ff !important;
    color: var(--brand-blue) !important;
}

.navbar-main .navbar-toggle {
    border-color: rgba(255, 255, 255, 0.4) !important;
}

.navbar-main .navbar-toggle .icon-bar {
    background-color: #fff !important;
}

/* ── Home Banner (domain search) ─────────────────────────── */
section#home-banner {
    background: linear-gradient(135deg, #0a58ca 0%, #0d6efd 60%, #3d8bfd 100%) !important;
    padding: 55px 0 65px !important;
    color: #fff !important;
    position: relative;
    overflow: hidden;
}

section#home-banner::before {
    content: '';
    position: absolute;
    top: -60px;
    right: -80px;
    width: 320px;
    height: 320px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 50%;
}

section#home-banner::after {
    content: '';
    position: absolute;
    bottom: -80px;
    left: -60px;
    width: 260px;
    height: 260px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 50%;
}

section#home-banner h2 {
    font-size: 1.9rem !important;
    font-weight: 800 !important;
    margin-bottom: 24px !important;
    padding: 0 !important;
    letter-spacing: -0.3px;
}

section#home-banner .form-control {
    border-radius: 50px 0 0 50px !important;
    border: 0 !important;
    height: 48px !important;
    padding: 0 22px !important;
    font-size: 1rem !important;
    box-shadow: none !important;
    font-family: var(--font-ar) !important;
}

[dir="rtl"] section#home-banner .form-control {
    border-radius: 0 50px 50px 0 !important;
}

section#home-banner .input-group-btn {
    display: flex;
}

section#home-banner .btn.search {
    background-color: #fff !important;
    color: var(--brand-blue) !important;
    border-radius: 0 50px 50px 0 !important;
    height: 48px !important;
    padding: 0 26px !important;
    font-weight: 700 !important;
    font-size: 0.95rem !important;
    border: 0 !important;
    transition: all var(--transition);
}

[dir="rtl"] section#home-banner .btn.search {
    border-radius: 50px 0 0 50px !important;
}

section#home-banner .btn.search:hover {
    background-color: #e8f0ff !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

section#home-banner .btn.transfer {
    background-color: rgba(255, 255, 255, 0.18) !important;
    color: #fff !important;
    border-radius: 50px !important;
    height: 44px !important;
    padding: 0 22px !important;
    font-weight: 600 !important;
    border: 1px solid rgba(255, 255, 255, 0.4) !important;
    margin-right: 8px;
    transition: all var(--transition);
}

section#home-banner .btn.transfer:hover {
    background-color: rgba(255, 255, 255, 0.28) !important;
}

/* ── Home Shortcuts Bar ──────────────────────────────────── */
.home-shortcuts {
    background: linear-gradient(135deg, #0a4a9e 0%, #1565c0 100%) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    position: relative;
    z-index: 1;
}

.home-shortcuts ul {
    display: flex;
    align-items: stretch;
    margin: 0;
    padding: 0;
}

.home-shortcuts li {
    display: flex !important;
    align-items: center;
    justify-content: center;
    padding: 14px 10px !important;
    border-right: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-left: 0 !important;
    border-bottom: 0 !important;
    width: auto;
    flex: 1 1 0;
    transition: background var(--transition);
    cursor: pointer;
}

[dir="rtl"] .home-shortcuts li {
    border-right: 0 !important;
    border-left: 1px solid rgba(255, 255, 255, 0.12) !important;
}

.home-shortcuts li:hover {
    background-color: rgba(255, 255, 255, 0.08) !important;
}

.home-shortcuts li a {
    color: #fff !important;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.home-shortcuts li i {
    font-size: 20px !important;
    margin-bottom: 2px;
}

.home-shortcuts li p {
    font-size: 0.78rem !important;
    margin: 0 !important;
    font-weight: 600;
    text-transform: none !important;
    letter-spacing: 0.2px;
    opacity: 0.92;
}

.home-shortcuts .lead {
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.95rem !important;
    font-weight: 600;
    margin: 0;
    line-height: 1.4 !important;
}

/* ── Main Body ───────────────────────────────────────────── */
section#main-body {
    background-color: var(--body-bg) !important;
    padding: 28px 0 !important;
    min-height: 400px;
}

/* ── Cards / Panels ──────────────────────────────────────── */
.panel {
    border-radius: var(--card-radius) !important;
    border: 1px solid #e4ecf7 !important;
    box-shadow: var(--card-shadow) !important;
    background-color: var(--card-bg) !important;
    overflow: hidden;
}

.panel-heading {
    border-radius: calc(var(--card-radius) - 1px) calc(var(--card-radius) - 1px) 0 0 !important;
    font-weight: 700;
}

.panel-primary>.panel-heading {
    background-color: var(--brand-blue) !important;
    border-color: var(--brand-blue) !important;
    color: #fff !important;
}

.panel-default>.panel-heading {
    background-color: #f5f8ff !important;
    border-color: #e4ecf7 !important;
    color: #1a2a4a;
}

/* ── List Groups (sidebar) ───────────────────────────────── */
a.list-group-item.active,
a.list-group-item.active:hover,
a.list-group-item.active:focus {
    background-color: var(--brand-blue) !important;
    border-color: var(--brand-blue) !important;
    color: #fff !important;
}

.list-group-item {
    border-color: #eef0f6 !important;
    transition: background var(--transition);
}

a.list-group-item:hover {
    background-color: #f0f4ff !important;
    color: var(--brand-blue) !important;
}

/* ── Buttons ─────────────────────────────────────────────── */
.btn {
    border-radius: 50px !important;
    font-weight: 600 !important;
    transition: all var(--transition) !important;
    letter-spacing: 0.2px;
}

.btn-primary {
    background-color: var(--brand-blue) !important;
    border-color: var(--brand-blue) !important;
    color: #fff !important;
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--brand-blue-dark) !important;
    border-color: var(--brand-blue-dark) !important;
    box-shadow: 0 4px 14px rgba(13, 110, 253, 0.35) !important;
}

.btn-default {
    background-color: #f4f6fb !important;
    border-color: #dce5f3 !important;
    color: #444 !important;
}

.btn-default:hover {
    background-color: #e8eef9 !important;
    border-color: var(--brand-blue) !important;
    color: var(--brand-blue) !important;
}

.btn-success {
    background-color: #198754 !important;
    border-color: #198754 !important;
    border-radius: 50px !important;
}

.btn-danger {
    background-color: var(--brand-red) !important;
    border-color: var(--brand-red) !important;
    border-radius: 50px !important;
}

/* ── Pagination ──────────────────────────────────────────── */
.pagination>.active>a,
.pagination>.active>span,
.pagination>.active>a:hover,
.pagination>.active>span:hover {
    background-color: var(--brand-blue) !important;
    border-color: var(--brand-blue) !important;
    color: #fff !important;
}

.pagination>li>a {
    color: var(--brand-blue) !important;
    border-radius: 6px !important;
    margin: 0 2px;
}

/* ── Alerts ──────────────────────────────────────────────── */
.alert {
    border-radius: 10px !important;
    border: 0 !important;
    font-size: 0.9rem;
}

.alert-info {
    background-color: #dbeafe !important;
    color: #1e40af !important;
}

.alert-success {
    background-color: #d1fae5 !important;
    color: #065f46 !important;
}

.alert-danger,
.alert-error {
    background-color: #fee2e2 !important;
    color: #991b1b !important;
}

.alert-warning {
    background-color: #fef3c7 !important;
    color: #92400e !important;
}

/* ── Tables ──────────────────────────────────────────────── */
.table>thead>tr>th {
    background-color: #f0f4ff;
    color: #1a2a4a;
    border-bottom: 2px solid #dce4f5;
    font-weight: 700;
    font-size: 0.85rem;
    letter-spacing: 0.3px;
}

.table-hover>tbody>tr:hover {
    background-color: #f5f8ff;
}

/* ── Breadcrumb ──────────────────────────────────────────── */
.breadcrumb {
    background-color: transparent !important;
    font-size: 0.82rem;
    padding: 4px 0 !important;
}

.breadcrumb>.active {
    color: var(--brand-blue) !important;
}

/* ── Section Page Header ─────────────────────────────────── */
div.header-lined h1 {
    color: var(--brand-blue) !important;
    border-bottom: 2px solid #dce4f5 !important;
    font-weight: 700;
}

/* ── Login Page ──────────────────────────────────────────── */
.logincontainer {
    background: var(--card-bg);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    padding: 36px 32px !important;
    margin-top: 48px !important;
}

/* ── Form Controls ───────────────────────────────────────── */
.form-control {
    border-radius: 8px !important;
    border-color: #dce5f3 !important;
    font-family: var(--font-ar) !important;
    transition: border-color var(--transition), box-shadow var(--transition);
}

[dir="ltr"] .form-control {
    font-family: var(--font-en) !important;
}

.form-control:focus {
    border-color: var(--brand-blue) !important;
    box-shadow: 0 0 0 3px rgba(13, 110, 253, 0.15) !important;
}

/* ── Back to Top ─────────────────────────────────────────── */
section#footer .back-to-top i {
    background-color: var(--brand-blue) !important;
    color: #fff !important;
    border-radius: 50% !important;
    padding: 10px !important;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition);
    opacity: 1 !important;
}

section#footer .back-to-top:hover i {
    background-color: var(--brand-blue-dark) !important;
    box-shadow: 0 4px 12px rgba(13, 110, 253, 0.35);
}

/* ── Footer ──────────────────────────────────────────────── */
section#footer {
    background-color: var(--footer-bg) !important;
    border-top: 0 !important;
    color: var(--footer-text) !important;
    padding: 24px 0 !important;
    font-size: 0.88rem;
}

section#footer p {
    color: var(--footer-text) !important;
    margin: 0;
    font-weight: 400;
}

section#footer a {
    color: #90b8f8 !important;
    transition: color var(--transition);
}

section#footer a:hover {
    color: #fff !important;
}

/* ── Tiles (Dashboard overview) ──────────────────────────── */
.tiles .tile {
    background-color: var(--card-bg) !important;
    border-right-color: #e4ecf7 !important;
    border-radius: 10px;
    margin: 4px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.tiles .tile:hover {
    background-color: #f0f5ff !important;
}

.tile .icon {
    color: #c6d6f5 !important;
}

/* ── Announcements / News ────────────────────────────────── */
.text-domain {
    color: var(--brand-blue) !important;
}

/* ── Overlay spinner ─────────────────────────────────────── */
#fullpage-overlay {
    background-color: rgba(26, 42, 74, 0.85) !important;
}

/* ── Modal ───────────────────────────────────────────────── */
.modal-content {
    border-radius: var(--card-radius) !important;
    border: 0 !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.18) !important;
}

.modal-header {
    border-radius: var(--card-radius) var(--card-radius) 0 0 !important;
    background-color: var(--brand-blue);
    color: #fff;
    border-bottom: 0 !important;
}

.modal-header .close {
    color: #fff !important;
    opacity: 0.8;
    text-shadow: none;
}

.modal-footer {
    border-radius: 0 0 var(--card-radius) var(--card-radius) !important;
    border-top: 1px solid #eef0f6 !important;
    background: #f8faff;
}

/* ── Badge / Label ───────────────────────────────────────── */
.label-primary,
.label-default {
    background-color: var(--brand-blue) !important;
    border-radius: 10px !important;
}

.label-success {
    border-radius: 10px !important;
}

/* ── RTL (Arabic) specific fixes ─────────────────────────── */
[dir="rtl"] .text-right {
    text-align: left !important;
}

[dir="rtl"] .text-left {
    text-align: right !important;
}

[dir="rtl"] .pull-right {
    float: left !important;
}

[dir="rtl"] .pull-left {
    float: right !important;
}

[dir="rtl"] .back-to-top {
    float: left !important;
}

[dir="rtl"] section#home-banner .input-group .form-control {
    border-radius: 0 50px 50px 0 !important;
}

[dir="rtl"] section#home-banner .btn.search {
    border-radius: 50px 0 0 50px !important;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 767px) {
    section#home-banner h2 {
        font-size: 1.4rem !important;
    }

    .home-shortcuts li {
        padding: 10px !important;
        border-right: 0 !important;
        border-left: 0 !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.12) !important;
        width: 100%;
    }

    .panel {
        border-radius: 10px !important;
    }

    .logincontainer {
        padding: 24px 16px !important;
    }
}


/* ============================================================
   PRODUCT GROUPS — 3D Flip Cards (alshamel.tech portal style)
   Targets WHMCS cart product listing pages
   ============================================================ */

/* ── Cart Page Layout ────────────────────────────────────── */
#products {
    padding: 10px 0;
}

/* Each product card column */
#products .row>div[class*='col-'] {
    margin-bottom: 24px;
}

/* ── 3D Flip Card Base ───────────────────────────────────── */
#products .product {
    perspective: 1000px;
    height: 320px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    cursor: pointer;
    position: relative;
}

/* Inner wrapper — transforms on hover */
#products .product .flip-inner {
    position: relative;
    width: 100%;
    height: 100%;
    text-align: center;
    transition: transform 0.7s cubic-bezier(0.4, 0.0, 0.2, 1);
    transform-style: preserve-3d;
}

#products .product:hover .flip-inner {
    transform: rotateY(180deg);
}

[dir="rtl"] #products .product:hover .flip-inner {
    transform: rotateY(-180deg);
}

#products .product.flipped .flip-inner {
    transform: rotateY(180deg);
}

[dir="rtl"] #products .product.flipped .flip-inner {
    transform: rotateY(-180deg);
}

/* ── Front Face ──────────────────────────────────────────── */
.flip-front,
.flip-back {
    position: absolute;
    width: 100%;
    height: 100%;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.flip-front {
    background: white;
    border: 2px solid #e4ecf7;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.flip-front img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    padding: 20px;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    transition: transform 0.5s ease;
}

#products .product:hover .flip-front img {
    transform: scale(1.05);
}

/* Front icon fallback (no image) */
.flip-front .flip-icon-fallback {
    font-size: 4rem;
    color: #c6d6f5;
    padding: 30px 0 10px;
}

/* Front overlay — title + price badge */
.flip-front .flip-title-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.88) 0%, rgba(0, 0, 0, 0.5) 55%, transparent 100%);
    color: white;
    padding: 48px 14px 14px;
    font-weight: 700;
    font-size: 1.15rem;
    line-height: 1.3;
}

.flip-front .flip-price-badge {
    display: inline-block;
    background: rgba(25, 135, 84, 0.88);
    color: #fff;
    font-size: 0.85rem;
    font-weight: 700;
    padding: 3px 14px;
    border-radius: 20px;
    margin-top: 5px;
    backdrop-filter: blur(4px);
}

.flip-front .flip-hint {
    font-size: 0.8rem;
    opacity: 0.82;
    margin-top: 5px;
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}

/* ── Back Face ───────────────────────────────────────────── */
.flip-back {
    background: white;
    transform: rotateY(180deg);
    display: flex;
    flex-direction: column;
    padding: 20px 18px;
    border: 3px solid var(--brand-blue);
    text-align: center;
}

[dir="rtl"] .flip-back {
    transform: rotateY(-180deg);
}

.flip-back h4 {
    color: #1a2a4a;
    font-weight: 700;
    font-size: 1.05rem;
    margin: 0 0 8px;
    padding-bottom: 8px;
    border-bottom: 1px solid #f0f0f0;
    line-height: 1.25;
}

.flip-back .flip-desc {
    color: #555;
    font-size: 0.88rem;
    line-height: 1.55;
    flex-grow: 1;
    overflow-y: auto;
    text-align: start;
    margin: 0 0 8px;
    padding: 2px 0;
}

.flip-back .flip-desc::-webkit-scrollbar {
    width: 3px;
}

.flip-back .flip-desc::-webkit-scrollbar-thumb {
    background: #dee2e6;
    border-radius: 4px;
}

/* Price tag (back face) */
.flip-back .flip-price-tag {
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
    background: linear-gradient(135deg, #28a745 0%, #20c997 100%);
    color: white;
    padding: 7px 18px;
    border-radius: 25px;
    font-weight: 800;
    box-shadow: 0 4px 15px rgba(40, 167, 69, 0.3);
    margin-bottom: 10px;
}

.flip-price-amount {
    font-size: 1.4rem;
    font-weight: 900;
    line-height: 1;
}

.flip-price-currency {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    opacity: 0.9;
    align-self: flex-end;
    margin-bottom: 2px;
}

.flip-price-period {
    font-size: 0.72rem;
    font-weight: 600;
    opacity: 0.85;
    align-self: flex-end;
    margin-bottom: 2px;
}

/* Order button (back face) */
.flip-back .btn-flip-order {
    background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-blue-dark) 100%);
    color: white !important;
    border: none !important;
    padding: 10px 20px;
    border-radius: 50px !important;
    font-weight: 700;
    font-size: 0.92rem;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    margin-top: auto;
    box-shadow: 0 4px 14px rgba(13, 110, 253, 0.25);
    transition: all 0.25s ease;
}

.flip-back .btn-flip-order:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(13, 110, 253, 0.4);
    color: white !important;
}

/* ── Feature Icon Grid (hosting plans) ──────────────────── */
.flip-feat-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 5px;
    width: 100%;
    flex: 1;
    align-content: start;
    margin: 4px 0 8px;
}

.flip-feat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: #f8f9fa;
    border-radius: 9px;
    padding: 6px 4px 5px;
    transition: background 0.2s;
    font-size: 0.7rem;
}

.flip-feat-item:hover {
    background: #eef3ff;
}

.flip-feat-icon {
    font-size: 0.85rem;
    color: var(--brand-blue);
    margin-bottom: 3px;
}

.flip-feat-val {
    font-size: 0.75rem;
    font-weight: 800;
    color: #212529;
    line-height: 1.1;
}

.flip-feat-lbl {
    font-size: 0.58rem;
    color: #888;
    text-align: center;
    margin-top: 2px;
}

/* ── Product Group Sidebar (category nav) ────────────────── */
.whmcs-group-sidebar {
    background: white;
    border-radius: 16px;
    padding: 20px 16px;
    box-shadow: 0 4px 18px rgba(13, 110, 253, 0.08);
    border: 1px solid #e4ecf7;
    position: sticky;
    top: 20px;
}

.whmcs-group-sidebar .group-nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 12px;
    text-decoration: none;
    color: #333;
    font-weight: 600;
    font-size: 0.88rem;
    margin-bottom: 6px;
    transition: all 0.25s ease;
}

.whmcs-group-sidebar .group-nav-item:hover {
    background: #f0f4ff;
    color: var(--brand-blue);
    transform: translateX(4px);
}

[dir="rtl"] .whmcs-group-sidebar .group-nav-item:hover {
    transform: translateX(-4px);
}

.whmcs-group-sidebar .group-nav-item.active {
    background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-blue-dark) 100%);
    color: white;
    box-shadow: 0 4px 14px rgba(13, 110, 253, 0.3);
}

.whmcs-group-sidebar .group-nav-icon {
    width: 36px;
    height: 36px;
    background: rgba(13, 110, 253, 0.1);
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    color: var(--brand-blue);
    flex-shrink: 0;
}

.whmcs-group-sidebar .group-nav-item.active .group-nav-icon {
    background: rgba(255, 255, 255, 0.2);
    color: white;
}

/* ── Store product group header ──────────────────────────── */
.whmcs-group-header {
    background: white;
    padding: 18px 22px;
    border-radius: 14px;
    box-shadow: 0 4px 18px rgba(13, 110, 253, 0.06);
    border: 1px solid #e4ecf7;
    margin-bottom: 22px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
}

.whmcs-group-header h4 {
    margin: 0;
    font-weight: 700;
    color: #1a2a4a;
}

/* ── Mobile Touch Support ────────────────────────────────── */
@media (hover: none) {
    #products .product:hover .flip-inner {
        transform: none;
    }

    #products .product.flipped .flip-inner {
        transform: rotateY(180deg);
    }

    [dir="rtl"] #products .product.flipped .flip-inner {
        transform: rotateY(-180deg);
    }
}

/* ── Responsive cards ────────────────────────────────────── */
@media (max-width: 767px) {
    #products .product {
        height: 270px !important;
    }

    .flip-front .flip-title-overlay {
        font-size: 0.9rem;
    }
}