/* ==========================================================================
   Rowan Cloud portal theme
   Self-contained chrome (header, sidebar, footer, layout) wrapped around the
   WHMCS client area. Everything is namespaced (.rc-*) and uses px values so it
   renders identically to the public site regardless of the WHMCS 14px root.
   Loaded after the WHMCS theme CSS, so it wins on the elements it targets.
   ========================================================================== */

.rc-portal {
    --rc-green: #2cac61;
    --rc-green-dark: #1a7a45;
    --rc-green-mid: #4dc47a;
    --rc-green-light: #e5f7ee;
    --rc-green-pale: #f0faf5;
    --rc-green-soft: #c8ebd8;

    --rc-bg: #ffffff;
    --rc-bg-alt: #f5faf7;
    --rc-border: #d6eade;
    --rc-border-lt: #eaf4ee;

    --rc-text-h: #0d1f18;
    --rc-text-b: #2a4a3e;
    --rc-text-s: #547a6b;
    --rc-text-m: #90b0a4;

    --rc-ink: #0d2118;
    --rc-ink-2: #143326;

    --rc-nav-h: 62px;
    --rc-sidebar-w: 270px;
    --rc-font: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* Never underline links inside the chrome (overrides Bootstrap's a:hover) */
.rc-topnav a, .rc-topnav a:hover, .rc-topnav a:focus,
.rc-sidebar a, .rc-sidebar a:hover, .rc-sidebar a:focus,
.rc-footer a, .rc-footer a:hover, .rc-footer a:focus { text-decoration: none; }

/* ==========================================================================
   1. Top navbar (mirrors the public site header)
   ========================================================================== */
.rc-topnav {
    position: sticky;
    top: 0;
    z-index: 1030;
    background: #fff;
    font-family: var(--rc-font);
    box-shadow: 0 1px 0 var(--rc-border), 0 4px 24px rgba(13, 31, 24, .07);
}
.rc-topnav-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 11px 28px;
    display: flex;
    align-items: center;
    gap: 16px;
}
.rc-topnav-brand { display: flex; align-items: center; margin-right: auto; }
.rc-topnav-logo { height: 34px; width: auto; display: block; }

.rc-topnav-links {
    display: flex;
    align-items: center;
    gap: 2px;
    list-style: none;
    margin: 0;
    padding: 0;
}
.rc-topnav-links > li { position: relative; }
.rc-topnav-links > li > a {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--rc-text-s);
    font-size: 14px;
    font-weight: 500;
    line-height: 1.4;
    padding: 8px 14px;
    border-radius: 8px;
    text-decoration: none;
    transition: color .2s, background .2s;
}
.rc-topnav-links > li > a:hover { color: var(--rc-green); background: var(--rc-green-pale); }

.rc-chev { font-size: 9px; transition: transform .25s; }
.rc-topnav-dd:hover .rc-chev { transform: rotate(180deg); }

.rc-topnav-dd-menu {
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%) translateY(-6px);
    background: #fff;
    border: 1px solid var(--rc-border);
    border-radius: 14px;
    padding: 6px;
    min-width: 212px;
    opacity: 0;
    visibility: hidden;
    transition: opacity .22s, visibility .22s, transform .22s;
    box-shadow: 0 12px 48px rgba(13, 31, 24, .13);
    z-index: 1031;
}
.rc-topnav-dd:hover .rc-topnav-dd-menu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.rc-topnav-dd-menu a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 8px;
    color: var(--rc-text-s);
    font-size: 13.5px;
    font-weight: 500;
    text-decoration: none;
    white-space: nowrap;
}
.rc-topnav-dd-menu a:hover { color: var(--rc-green); background: var(--rc-green-pale); }
.rc-topnav-dd-menu a i { width: 16px; text-align: center; color: var(--rc-green); }

.rc-topnav-cta {
    background: var(--rc-green);
    color: #fff !important;
    padding: 9px 22px !important;
    border-radius: 8px;
    font-weight: 600;
    margin-left: 8px;
    transition: background .2s, box-shadow .2s, transform .2s;
}
.rc-topnav-cta:hover {
    background: var(--rc-green-dark);
    box-shadow: 0 4px 16px rgba(44, 172, 97, .35);
    transform: translateY(-1px);
}

.rc-sidebar-toggle {
    display: none;
    background: none;
    border: 1px solid var(--rc-border);
    border-radius: 9px;
    width: 40px;
    height: 40px;
    color: var(--rc-text-h);
    font-size: 16px;
    cursor: pointer;
    align-items: center;
    justify-content: center;
}
.rc-sidebar-toggle:hover { background: var(--rc-green-pale); color: var(--rc-green); border-color: var(--rc-green-soft); }

/* ==========================================================================
   2. Shell layout
   ========================================================================== */
.rc-shell {
    display: flex;
    align-items: flex-start;
    min-height: calc(100vh - var(--rc-nav-h));
    background: var(--rc-bg);
}
.rc-content { flex: 1 1 auto; min-width: 0; background: #fff; }
.rc-content .container { max-width: 1240px; width: 100%; padding-left: 32px; padding-right: 32px; }
#main-body { padding: 28px 0 60px; }

/* ==========================================================================
   3. Sidebar (WHMCS navigation)
   ========================================================================== */
.rc-sidebar {
    flex: 0 0 var(--rc-sidebar-w);
    width: var(--rc-sidebar-w);
    position: sticky;
    top: var(--rc-nav-h);
    height: calc(100vh - var(--rc-nav-h));
    overflow-y: auto;
    background: linear-gradient(180deg, var(--rc-ink) 0%, var(--rc-ink-2) 100%);
    color: rgba(255, 255, 255, .72);
    font-family: var(--rc-font);
    padding: 18px 14px 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.rc-sidebar::-webkit-scrollbar { width: 8px; }
.rc-sidebar::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, .14); border-radius: 8px; }

.rc-sidebar-close {
    display: none;
    align-self: flex-end;
    background: none;
    border: none;
    color: rgba(255, 255, 255, .7);
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    padding: 2px 6px;
}

/* --- Account block --- */
.rc-account {
    background: rgba(255, 255, 255, .05);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 14px;
    padding: 12px;
}
.rc-account-head { display: flex; align-items: center; gap: 8px; }
.rc-account-main { display: flex; align-items: center; gap: 11px; text-decoration: none; flex: 1 1 auto; min-width: 0; }
.rc-account-toggle {
    flex: 0 0 auto;
    width: 30px; height: 30px;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(255, 255, 255, .06); border: none; border-radius: 8px;
    color: rgba(255, 255, 255, .65); cursor: pointer;
    transition: background .18s, color .18s;
}
.rc-account-toggle:hover { background: var(--rc-green); color: #fff; }
.rc-account-toggle i { font-size: 12px; transition: transform .22s; }
.rc-account.open .rc-account-toggle i { transform: rotate(180deg); }

/* "Hello, Name!" menu (expanded from the toggle) */
.rc-account-menu { display: none; flex-direction: column; gap: 1px; margin-top: 10px; padding-top: 10px; border-top: 1px solid rgba(255, 255, 255, .1); }
.rc-account.open .rc-account-menu { display: flex; }
.rc-account-menu-link {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 10px; border-radius: 8px;
    color: rgba(255, 255, 255, .72); font-size: 13px; font-weight: 500; text-decoration: none;
    transition: background .18s, color .18s;
}
.rc-account-menu-link:hover { background: rgba(255, 255, 255, .09); color: #fff; }
.rc-account-menu-link i { width: 16px; text-align: center; font-size: 12px; color: var(--rc-green); flex: 0 0 16px; }
.rc-account-menu-link .rc-badge { margin-left: auto; }
.rc-account-menu-divider { height: 1px; background: rgba(255, 255, 255, .09); margin: 5px 4px; }
.rc-account-avatar {
    width: 38px; height: 38px; flex: 0 0 38px;
    display: flex; align-items: center; justify-content: center;
    background: var(--rc-green); border-radius: 50%; color: #fff; font-size: 15px;
}
.rc-account-meta { display: flex; flex-direction: column; min-width: 0; }
.rc-account-label { font-size: 10px; text-transform: uppercase; letter-spacing: .06em; color: rgba(255, 255, 255, .5); }
.rc-account-name { font-size: 14px; font-weight: 600; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rc-account-actions { display: flex; gap: 6px; margin-top: 11px; }
.rc-account-btn {
    flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 5px;
    background: rgba(255, 255, 255, .07); border: none; border-radius: 9px;
    color: rgba(255, 255, 255, .8); padding: 8px 0; font-size: 13px; text-decoration: none; cursor: pointer;
    transition: background .2s, color .2s;
}
.rc-account-btn:hover { background: var(--rc-green); color: #fff; }
.rc-account-btn .rc-badge { position: static; }
.rc-account-guest { display: flex; }
.rc-login-btn {
    flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    background: var(--rc-green); color: #fff; text-decoration: none;
    padding: 11px 0; border-radius: 10px; font-size: 14px; font-weight: 600;
    transition: background .2s;
}
.rc-login-btn:hover { background: var(--rc-green-dark); color: #fff; }

/* --- Search --- */
.rc-search { position: relative; display: flex; }
.rc-search-input {
    width: 100%; background: rgba(255, 255, 255, .06);
    border: 1px solid rgba(255, 255, 255, .1); border-radius: 10px;
    color: #fff; padding: 10px 40px 10px 14px; font-size: 13px; outline: none;
    font-family: var(--rc-font);
}
.rc-search-input::placeholder { color: rgba(255, 255, 255, .4); }
.rc-search-input:focus { border-color: var(--rc-green); background: rgba(255, 255, 255, .1); }
.rc-search-btn {
    position: absolute; right: 4px; top: 50%; transform: translateY(-50%);
    background: none; border: none; color: rgba(255, 255, 255, .55); width: 34px; height: 34px; cursor: pointer;
}
.rc-search-btn:hover { color: var(--rc-green); }

/* --- Nav --- */
.rc-sidebar-nav { margin: 0; }
.rc-sidebar-nav-secondary { margin-top: 2px; padding-top: 10px; border-top: 1px solid rgba(255, 255, 255, .08); }
.rc-nav, .rc-subnav { list-style: none; margin: 0; padding: 0; }
.rc-nav-item { margin: 1px 0; }

.rc-nav-link {
    display: flex; align-items: center; gap: 11px;
    padding: 10px 14px; border-radius: 10px;
    color: rgba(255, 255, 255, .74);
    font-size: 14px; font-weight: 500; line-height: 1.3;
    text-decoration: none; cursor: pointer;
    transition: background .18s, color .18s;
}
.rc-nav-link:hover { background: rgba(255, 255, 255, .08); color: #fff; }
.rc-nav-item.active > .rc-nav-link,
.rc-nav-item.current > .rc-nav-link {
    background: rgba(44, 172, 97, .16); color: #fff;
    box-shadow: inset 3px 0 0 var(--rc-green);
}
.rc-nav-icon { width: 18px; text-align: center; font-size: 14px; color: var(--rc-green); flex: 0 0 18px; }
.rc-nav-label { flex: 1 1 auto; min-width: 0; }
.rc-caret { font-size: 10px; transition: transform .2s; color: rgba(255, 255, 255, .45); flex: 0 0 auto; }
.rc-nav-item.open > .rc-nav-link .rc-caret { transform: rotate(180deg); }

.rc-badge {
    background: var(--rc-green); color: #fff; font-size: 10px; font-weight: 700;
    border-radius: 100px; padding: 1px 7px; line-height: 1.6;
}

/* Sub-nav (collapsible) */
.rc-subnav { display: none; margin: 2px 0 6px 22px; padding-left: 12px; border-left: 1px solid rgba(255, 255, 255, .1); }
.rc-nav-item.open > .rc-subnav { display: block; }
.rc-subnav-link {
    display: flex; align-items: center; gap: 9px;
    padding: 7px 12px; border-radius: 8px;
    color: rgba(255, 255, 255, .6); font-size: 13px; font-weight: 500;
    text-decoration: none; transition: background .18s, color .18s;
}
.rc-subnav-link:hover { background: rgba(255, 255, 255, .07); color: #fff; }
.rc-subnav-item.active > .rc-subnav-link { color: var(--rc-green); }
.rc-subnav-icon { width: 15px; text-align: center; font-size: 12px; opacity: .8; }
.rc-subnav-divider { height: 1px; background: rgba(255, 255, 255, .08); margin: 6px 4px; }

/* --- Sidebar footer --- */
.rc-sidebar-foot { margin-top: auto; padding-top: 12px; display: flex; flex-direction: column; gap: 8px; }
.rc-cart-link {
    display: flex; align-items: center; gap: 11px;
    background: rgba(255, 255, 255, .06); border: 1px solid rgba(255, 255, 255, .1);
    border-radius: 10px; padding: 11px 14px; color: rgba(255, 255, 255, .85);
    font-size: 14px; font-weight: 500; text-decoration: none;
    transition: background .18s, color .18s;
}
.rc-cart-link:hover { background: rgba(44, 172, 97, .16); color: #fff; }
.rc-cart-link .rc-badge { margin-left: auto; }
.rc-locale-btn {
    display: flex; align-items: center; gap: 9px; width: 100%;
    background: none; border: none; color: rgba(255, 255, 255, .55);
    font-size: 12.5px; padding: 6px 14px; cursor: pointer; font-family: var(--rc-font);
}
.rc-locale-btn:hover { color: #fff; }

/* ==========================================================================
   4. Breadcrumb (override WHMCS grey bar)
   ========================================================================== */
.rc-content .master-breadcrumb { background: var(--rc-bg-alt); border-bottom: 1px solid var(--rc-border); }
.rc-content .master-breadcrumb .breadcrumb {
    background: transparent; margin: 0; padding: 13px 0; border-radius: 0;
    font-family: var(--rc-font); font-size: 13px;
}
.rc-content .master-breadcrumb .breadcrumb-item a { color: var(--rc-green-dark); text-decoration: none; }
.rc-content .master-breadcrumb .breadcrumb-item a:hover { color: var(--rc-green); text-decoration: underline; }
.rc-content .master-breadcrumb .breadcrumb-item.active { color: var(--rc-text-s); }
.rc-content .master-breadcrumb .breadcrumb-item + .breadcrumb-item::before { color: var(--rc-text-m); }

/* ==========================================================================
   5. Footer (mirrors the public site footer)
   ========================================================================== */
.rc-footer { background: var(--rc-ink); padding: 60px 0 30px; font-family: var(--rc-font); }
.rc-footer-inner { max-width: 1200px; margin: 0 auto; padding: 0 28px; }
.rc-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 44px; }
.rc-footer-logo { height: 30px; filter: brightness(0) invert(1); margin-bottom: 14px; display: block; }
.rc-footer-tagline { color: rgba(255, 255, 255, .45); font-size: 13.5px; line-height: 1.72; margin: 0 0 20px; max-width: 240px; }
.rc-footer-social { display: flex; gap: 8px; list-style: none; margin: 0; padding: 0; }
.rc-footer-social li { list-style: none; }
.rc-footer-social a {
    width: 34px; height: 34px; padding: 0;
    background: rgba(255, 255, 255, .07); border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 8px; display: flex; align-items: center; justify-content: center;
    color: rgba(255, 255, 255, .5); font-size: 13px; text-decoration: none;
    transition: background .2s, border-color .2s, color .2s;
}
.rc-footer-social a:hover { background: rgba(44, 172, 97, .2); border-color: var(--rc-green); color: var(--rc-green); }
.rc-footer-col-title { font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; margin: 0 0 16px; color: rgba(255, 255, 255, .5); }
.rc-footer-links { list-style: none; display: flex; flex-direction: column; gap: 10px; margin: 0; padding: 0; }
.rc-footer-links a { color: rgba(255, 255, 255, .45); font-size: 13.5px; text-decoration: none; transition: color .2s; }
.rc-footer-links a:hover { color: var(--rc-green); }
.rc-footer-bottom { padding-top: 26px; border-top: 1px solid rgba(255, 255, 255, .08); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.rc-footer-copy { color: rgba(255, 255, 255, .35); font-size: 12.5px; margin: 0; }
.rc-footer-copy a { color: var(--rc-green); }
.rc-footer-legal { display: flex; gap: 20px; }
.rc-footer-legal a { color: rgba(255, 255, 255, .35); font-size: 12.5px; text-decoration: none; transition: color .2s; }
.rc-footer-legal a:hover { color: rgba(255, 255, 255, .65); }

/* ==========================================================================
   6. Responsive — sidebar becomes an off-canvas drawer
   ========================================================================== */
.rc-sidebar-backdrop { display: none; position: fixed; inset: 0; background: rgba(13, 31, 24, .5); z-index: 1040; }

@media (max-width: 991.98px) {
    .rc-sidebar-toggle { display: inline-flex; }
    .rc-topnav-links { display: none; }
    .rc-topnav-brand { margin-right: 0; }

    .rc-shell { display: block; }
    .rc-sidebar {
        position: fixed; top: 0; left: 0; bottom: 0; height: 100%;
        width: 86%; max-width: 320px; z-index: 1050;
        transform: translateX(-100%);
        transition: transform .28s cubic-bezier(.4, 0, .2, 1);
        box-shadow: 0 0 40px rgba(0, 0, 0, .4);
    }
    .rc-sidebar-close { display: block; }
    body.rc-sidebar-open .rc-sidebar { transform: translateX(0); }
    body.rc-sidebar-open .rc-sidebar-backdrop { display: block; }
    body.rc-sidebar-open { overflow: hidden; }

    .rc-content .container { padding-left: 18px; padding-right: 18px; }
    .rc-footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
    .rc-footer-bottom { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 575.98px) {
    .rc-footer-grid { grid-template-columns: 1fr; gap: 28px; }
}

/* ==========================================================================
   7. WHMCS CONTENT RE-SKIN
   Inter typography + brand palette applied to the WHMCS content area, and a
   full sweep replacing the theme's #369 blue with Rowan Cloud green.
   ========================================================================== */

/* --- Base typography --- */
body.rc-portal { font-family: var(--rc-font); color: var(--rc-text-b); }
.rc-content { color: var(--rc-text-b); font-size: 14px; line-height: 1.6; }
.rc-content h1, .rc-content h2, .rc-content h3, .rc-content h4, .rc-content h5, .rc-content h6,
.rc-content .h1, .rc-content .h2, .rc-content .h3, .rc-content .h4, .rc-content .h5, .rc-content .h6 {
    font-family: var(--rc-font); color: var(--rc-text-h); font-weight: 700; letter-spacing: -.01em;
}
.rc-content h1, .rc-content .h1 { font-weight: 800; }
.rc-content .text-muted { color: var(--rc-text-m) !important; }
.rc-content hr { border-top-color: var(--rc-border); }

/* --- Links --- */
.rc-content a { color: var(--rc-green-dark); }
.rc-content a:hover { color: var(--rc-green); }

/* --- Buttons --- */
.rc-portal .btn { border-radius: 9px; font-weight: 600; }
.rc-portal .btn-primary,
.rc-portal .btn-primary.disabled, .rc-portal .btn-primary:disabled {
    background-color: var(--rc-green); border-color: var(--rc-green); color: #fff;
}
.rc-portal .btn-primary:hover { background-color: var(--rc-green-dark); border-color: var(--rc-green-dark); color: #fff; }
.rc-portal .btn-primary:focus, .rc-portal .btn-primary.focus {
    background-color: var(--rc-green-dark); border-color: var(--rc-green-dark);
    box-shadow: 0 0 0 .2rem rgba(44, 172, 97, .4);
}
.rc-portal .btn-primary:not(:disabled):not(.disabled):active,
.rc-portal .btn-primary:not(:disabled):not(.disabled).active,
.rc-portal .show > .btn-primary.dropdown-toggle { background-color: #166639; border-color: #145e34; color: #fff; }
.rc-portal .btn-primary:not(:disabled):not(.disabled):active:focus { box-shadow: 0 0 0 .2rem rgba(44, 172, 97, .4); }

.rc-portal .btn-outline-primary { color: var(--rc-green-dark); border-color: var(--rc-green); }
.rc-portal .btn-outline-primary:hover { background-color: var(--rc-green); border-color: var(--rc-green); color: #fff; }
.rc-portal .btn-outline-primary:focus, .rc-portal .btn-outline-primary.focus { box-shadow: 0 0 0 .2rem rgba(44, 172, 97, .4); }
.rc-portal .btn-link { color: var(--rc-green-dark); }
.rc-portal .btn-link:hover { color: var(--rc-green); }

.rc-portal .btn-default {
    background-color: #fff; border-color: var(--rc-border); color: var(--rc-text-b);
}
.rc-portal .btn-default:hover {
    background-color: var(--rc-green-pale) !important; border-color: var(--rc-green-soft) !important; color: var(--rc-green-dark);
}
.rc-portal .btn-secondary { background-color: #5b7468; border-color: #5b7468; }
.rc-portal .btn-secondary:hover { background-color: #4a5f55; border-color: #4a5f55; }
.rc-portal .btn:focus, .rc-portal .btn.focus { box-shadow: 0 0 0 .2rem rgba(44, 172, 97, .25); }

/* --- Primary utility classes --- */
.rc-portal .bg-primary { background-color: var(--rc-green) !important; }
.rc-portal .text-primary { color: var(--rc-green-dark) !important; }
.rc-portal .border-primary { border-color: var(--rc-green) !important; }
.rc-portal .badge-primary { background-color: var(--rc-green); color: #fff; }
.rc-portal .progress-bar { background-color: var(--rc-green); }
.rc-portal .dropdown-item.active, .rc-portal .dropdown-item:active { background-color: var(--rc-green); }

/* --- Pagination --- */
.rc-portal .page-link { color: var(--rc-green-dark); }
.rc-portal .page-link:hover { color: var(--rc-green); }
.rc-portal .page-item.active .page-link { background-color: var(--rc-green); border-color: var(--rc-green); }
.rc-portal .page-link:focus { box-shadow: 0 0 0 .2rem rgba(44, 172, 97, .25); }

/* --- Tabs & pills --- */
.rc-portal .nav-pills .nav-link.active, .rc-portal .nav-pills .show > .nav-link { background-color: var(--rc-green); color: #fff; }
.rc-portal .nav-tabs .nav-link.active { color: var(--rc-green-dark); border-bottom-color: #fff; }
.rc-portal .nav-tabs .nav-link:hover { border-color: var(--rc-border) var(--rc-border) transparent; }

/* --- Forms --- */
.rc-portal .form-control { border-radius: 9px; border-color: var(--rc-border); color: var(--rc-text-b); }
.rc-portal .form-control:focus { border-color: var(--rc-green-mid); box-shadow: 0 0 0 .2rem rgba(44, 172, 97, .2); color: var(--rc-text-b); }
.rc-portal .custom-control-input:checked ~ .custom-control-label::before { background-color: var(--rc-green); border-color: var(--rc-green); }
.rc-portal .custom-control-input:focus ~ .custom-control-label::before { box-shadow: 0 0 0 .2rem rgba(44, 172, 97, .25); }
.rc-portal .custom-control-input:focus:not(:checked) ~ .custom-control-label::before { border-color: var(--rc-green-mid); }
.rc-portal .custom-range::-webkit-slider-thumb { background-color: var(--rc-green); }
.rc-portal .custom-range::-moz-range-thumb { background-color: var(--rc-green); }
.rc-portal .custom-range::-ms-thumb { background-color: var(--rc-green); }
.rc-portal .custom-select:focus { border-color: var(--rc-green-mid); box-shadow: 0 0 0 .2rem rgba(44, 172, 97, .2); }

/* --- Cards & panels --- */
.rc-content .card {
    border: 1px solid var(--rc-border); border-radius: 16px;
    box-shadow: 0 2px 14px rgba(13, 31, 24, .05); overflow: hidden;
}
.rc-content .card-header { background: var(--rc-bg-alt); border-bottom: 1px solid var(--rc-border); padding: 14px 18px; }
.rc-content .card-title { font-family: var(--rc-font); color: var(--rc-text-h); font-weight: 600; font-size: 15px; }
.rc-content .card-body { padding: 22px; }
.rc-content .card-footer { background: var(--rc-bg-alt); border-top: 1px solid var(--rc-border); }

/* Secondary sidebar panels (e.g. By Month / Support) */
.rc-content .card-sidebar .card-header { padding: 12px 16px; }
.rc-content .card-sidebar .card-title { font-size: 14px; }
.rc-content .card-sidebar .card-title > i:first-child { color: var(--rc-green); }
.rc-content .card-sidebar .card-minimise { color: var(--rc-text-m); }
.rc-content .list-group-item-action { color: var(--rc-text-b); }
.rc-content .list-group-item-action:hover { background-color: var(--rc-green-pale); color: var(--rc-green-dark); }
.rc-content .list-group-item.active { background-color: var(--rc-green); border-color: var(--rc-green); color: #fff; }
.rc-content .card-sidebar .sidebar-menu-item-icon { color: var(--rc-green); width: 16px; text-align: center; }
.rc-content .card-sidebar .list-group-item.active .sidebar-menu-item-icon { color: #fff; }

/* --- Tables --- */
.rc-content .table thead th { background: var(--rc-bg-alt); color: var(--rc-text-h); border-bottom: 2px solid var(--rc-border); font-weight: 600; }
.rc-content .table td, .rc-content .table th { border-top: 1px solid var(--rc-border-lt); }
.rc-content .table-hover tbody tr:hover { background-color: var(--rc-green-pale); }

/* --- Alerts --- */
.rc-portal .alert-primary { background-color: var(--rc-green-light); border-color: var(--rc-green-soft); color: var(--rc-green-dark); }
.rc-portal .alert-success { background-color: var(--rc-green-light); border-color: var(--rc-green-soft); color: var(--rc-green-dark); }

/* --- Misc brand accents --- */
.rc-content .well, .rc-content .panel { border-radius: 14px; }
.rc-portal ::selection { background: var(--rc-green-light); }

/* ==========================================================================
   8. FULL PORTAL REDESIGN
   Component-level restyling so the client area reads as a bespoke dashboard.
   ========================================================================== */
.rc-portal { --rc-page: #f6faf8; }

/* App-style tinted page background with white cards floating on top */
.rc-content { background: var(--rc-page); }
.rc-content .master-breadcrumb { background: var(--rc-page); }

/* Section headings used across WHMCS pages */
.rc-content h2.text-center { font-size: 26px; font-weight: 800; margin: 36px 0 24px; color: var(--rc-text-h); }
.rc-content .page-header { border-bottom: 1px solid var(--rc-border); margin-bottom: 24px; }

/* --- Dashboard stat tiles (clientareahome) --- */
.rc-content .tiles { margin-bottom: 26px; }
.rc-content .tiles .row.no-gutters { margin: -8px; }
.rc-content .tiles .row.no-gutters > [class*="col-"] { padding: 8px; }
.rc-content .tiles .tile {
    height: 100%;
    background: #fff;
    border: 1px solid var(--rc-border);
    border-radius: 16px;
    padding: 20px 22px;
    box-shadow: 0 2px 14px rgba(13, 31, 24, .05);
    transition: transform .2s, box-shadow .2s, border-color .2s;
}
.rc-content .tiles .tile:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(13, 31, 24, .1); border-color: var(--rc-green-soft); background: #fff; }
.rc-content .tiles .tile .stat { margin-top: 4px; font-size: 34px; font-weight: 800; color: var(--rc-text-h); line-height: 1.1; }
.rc-content .tiles .tile .title { color: var(--rc-text-s); font-weight: 600; font-size: 11.5px; letter-spacing: .05em; }
.rc-content .tiles .tile i { top: 18px; right: 20px; font-size: 44px; color: var(--rc-green); opacity: .16; transition: transform .2s, opacity .2s; }
.rc-content .tiles .tile:hover i { font-size: 44px; transform: scale(1.12); opacity: .26; color: var(--rc-green); }
.rc-content .tiles .tile .highlight { margin-top: 12px; width: 42px; height: 3px; border-radius: 3px; }

/* --- Homepage product cards --- */
.rc-content .card-columns.home .card { transition: transform .2s, box-shadow .2s, border-color .2s; }
.rc-content .card-columns.home .card:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(13, 31, 24, .1); border-color: var(--rc-green-soft); }
.rc-content .pricing-card-title { font-weight: 800; }

/* --- Homepage action tiles --- */
.rc-content .action-icon-btns a {
    background: #fff;
    border: 1px solid var(--rc-border);
    border-radius: 16px;
    box-shadow: 0 2px 12px rgba(13, 31, 24, .04);
    padding: 22px 10px 20px;
    color: var(--rc-text-b);
    font-weight: 600;
    font-size: 13px;
    transition: transform .2s, box-shadow .2s, border-color .2s, color .2s;
}
.rc-content .action-icon-btns a[class*="card-accent-"] { border-top: 1px solid var(--rc-border); }
.rc-content .action-icon-btns a:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(13, 31, 24, .1); border-color: var(--rc-green-soft); color: var(--rc-green-dark); }
.rc-content .action-icon-btns a .ico-container { margin: 6px auto 12px; line-height: 1; font-size: 2.4em; }
.rc-content .action-icon-btns a:hover .ico-container { font-size: 2.4em; }
.rc-content .action-icon-btns a .ico-container i { color: var(--rc-green); transition: transform .2s; }
.rc-content .action-icon-btns a:hover .ico-container i { color: var(--rc-green); transform: scale(1.1); }

/* --- Homepage domain search --- */
.rc-content .home-domain-search { background: transparent !important; }
.rc-content .home-domain-search .p-5 { padding: 0 0 8px !important; }
.rc-content .home-domain-search h2 { font-size: 26px; font-weight: 800; color: var(--rc-text-h); margin-bottom: 4px !important; }
.rc-content .home-domain-search .input-group-wrapper {
    border: 1px solid var(--rc-border); border-radius: 14px;
    box-shadow: 0 2px 16px rgba(13, 31, 24, .05); padding: 8px; background: #fff;
}
.rc-content .home-domain-search .input-group-wrapper .form-control { font-size: 15px; }

/* --- Status labels & badges --- */
.rc-portal .label, .rc-portal .badge { font-weight: 600; border-radius: 100px; padding: .36em .72em; font-size: 11px; letter-spacing: .02em; }
.rc-portal .label-success, .rc-portal .badge-success,
.rc-portal .status-open, .rc-portal .status-paid, .rc-portal .status-active, .rc-portal .status-delivered { background-color: var(--rc-green) !important; color: #fff; }
.rc-portal .status-onhold { background-color: #5b7468 !important; color: #fff; }
.rc-portal .status-payment-pending { background-color: #5b7468 !important; color: #fff; }

/* --- Buttons: success variant (kept green but distinct from primary) --- */
.rc-portal .btn-success, .rc-portal .btn-success.disabled, .rc-portal .btn-success:disabled { background-color: var(--rc-green-dark); border-color: var(--rc-green-dark); color: #fff; }
.rc-portal .btn-success:hover { background-color: #166639; border-color: #166639; color: #fff; }
.rc-portal .btn-success:focus, .rc-portal .btn-success.focus { box-shadow: 0 0 0 .2rem rgba(26, 122, 69, .4); }
.rc-portal .btn-success:not(:disabled):not(.disabled):active { background-color: #12552f; border-color: #12552f; }

/* --- Modals --- */
.rc-portal .modal-content { border: none; border-radius: 18px; box-shadow: 0 24px 70px rgba(13, 31, 24, .28); overflow: hidden; }
.rc-portal .modal-header { background: var(--rc-bg-alt); border-bottom: 1px solid var(--rc-border); padding: 16px 20px; }
.rc-portal .modal-title { font-family: var(--rc-font); font-weight: 700; color: var(--rc-text-h); }
.rc-portal .modal-body { padding: 22px; }
.rc-portal .modal-footer { background: var(--rc-bg-alt); border-top: 1px solid var(--rc-border); }

/* --- Dropdowns (content) --- */
.rc-portal .primary-content .dropdown-menu,
.rc-portal #main-body .dropdown-menu { border: 1px solid var(--rc-border); border-radius: 12px; box-shadow: 0 12px 40px rgba(13, 31, 24, .12); padding: 6px; }
.rc-portal #main-body .dropdown-item { border-radius: 8px; padding: .5rem .75rem; font-size: 13.5px; }
.rc-portal #main-body .dropdown-item:hover { background: var(--rc-green-pale); color: var(--rc-green-dark); }

/* --- Alerts (rounded) --- */
.rc-portal .alert { border-radius: 12px; }

/* --- Tables --- */
.rc-content .table { font-size: 13.5px; }
.rc-content .table-striped tbody tr:nth-of-type(odd) { background-color: rgba(44, 172, 97, .035); }

/* --- Input groups & selects --- */
.rc-portal .input-group-text { background: var(--rc-bg-alt); border-color: var(--rc-border); color: var(--rc-text-s); }
.rc-portal .custom-select { border-radius: 9px; border-color: var(--rc-border); }

/* --- Wells / jumbotron --- */
.rc-content .well { background: var(--rc-bg-alt); border: 1px solid var(--rc-border); }
.rc-content .jumbotron { background: var(--rc-bg-alt); border-radius: 18px; }

/* --- Hide WHMCS attribution (requires an owned/branded WHMCS licence) --- */
.rc-content p:has(> a[href*="whmcs.com"]) { display: none; }
.rc-footer a[href*="whmcs.com"], .rc-content a[href*="whmcs.com"] { display: none; }

/* ==========================================================================
   9. LIST TABLES → CARD ROWS  (services, domains, tickets, invoices, …)
   Keeps the underlying <table> (so DataTables paging/search/sort still work)
   but renders each row as a separated, rounded, clickable card.
   ========================================================================== */
.rc-content table.table-list {
    border-collapse: separate !important;
    border-spacing: 0 12px !important;
    background: transparent;
    margin: 0;
    width: 100% !important;
}
/* Drop the table header — these read as a list of cards, not a grid */
.rc-content table.table-list > thead { display: none; }

.rc-content table.table-list > tbody > tr {
    cursor: pointer;
    box-shadow: 0 2px 12px rgba(13, 31, 24, .05);
    transition: box-shadow .2s;
}
.rc-content table.table-list > tbody > tr > td {
    background: #fff;
    border-top: 1px solid var(--rc-border);
    border-bottom: 1px solid var(--rc-border);
    border-left: 0;
    border-right: 0;
    padding: 16px 12px;
    vertical-align: middle;
    font-size: 13.5px;
    color: var(--rc-text-b);
}
.rc-content table.table-list > tbody > tr > td:first-child {
    border-left: 1px solid var(--rc-border);
    border-top-left-radius: 14px;
    border-bottom-left-radius: 14px;
    padding-left: 18px;
}
.rc-content table.table-list > tbody > tr > td:last-child {
    border-right: 1px solid var(--rc-border);
    border-top-right-radius: 14px;
    border-bottom-right-radius: 14px;
    padding-right: 18px;
}
.rc-content table.table-list > tbody > tr:hover > td { border-color: var(--rc-green-soft); }
.rc-content table.table-list > tbody > tr:hover { box-shadow: 0 8px 26px rgba(13, 31, 24, .1); }
.rc-content table.table-list td strong { color: var(--rc-text-h); font-weight: 700; font-size: 14.5px; }
.rc-content table.table-list td a { color: var(--rc-green-dark); }
.rc-content table.table-list td small { color: var(--rc-text-m); }
/* "No records" row shouldn't look clickable */
.rc-content table.table-list > tbody > tr.odd > td.dataTables_empty,
.rc-content table.table-list > tbody > tr > td.dataTables_empty { text-align: center; color: var(--rc-text-s); cursor: default; border-radius: 14px; border: 1px solid var(--rc-border); }

/* --- DataTables controls (search / info / pagination / length) --- */
.rc-content .dataTables_wrapper { padding: 0; }
.rc-content .listtable { margin-bottom: 6px; }
.rc-content .dataTables_filter { margin-bottom: 10px; }
.rc-content .dataTables_filter input {
    border: 1px solid var(--rc-border); border-radius: 10px;
    padding: 9px 14px; font-size: 13px; margin-left: 8px; min-width: 220px;
    background: #fff;
}
.rc-content .dataTables_filter input:focus { border-color: var(--rc-green-mid); box-shadow: 0 0 0 .2rem rgba(44, 172, 97, .2); outline: 0; }
.rc-content .dataTables_length select { border: 1px solid var(--rc-border); border-radius: 8px; padding: 5px 8px; margin: 0 6px; }
.rc-content .dataTables_info { color: var(--rc-text-s); font-size: 12.5px; padding-top: 12px; }
.rc-content .dataTables_paginate { margin-top: 10px; }
.rc-content .dataTables_paginate .paginate_button {
    border: 1px solid var(--rc-border) !important;
    border-radius: 8px !important;
    margin: 0 3px !important;
    padding: 6px 13px !important;
    background: #fff !important;
    color: var(--rc-text-b) !important;
}
.rc-content .dataTables_paginate .paginate_button.current,
.rc-content .dataTables_paginate .paginate_button.current:hover {
    background: var(--rc-green) !important; border-color: var(--rc-green) !important; color: #fff !important;
}
.rc-content .dataTables_paginate .paginate_button:hover { background: var(--rc-green-pale) !important; border-color: var(--rc-green-soft) !important; color: var(--rc-green-dark) !important; }
.rc-content .dataTables_paginate .paginate_button.disabled,
.rc-content .dataTables_paginate .paginate_button.disabled:hover { opacity: .4; background: #fff !important; color: var(--rc-text-m) !important; border-color: var(--rc-border) !important; }

/* Generic (non-list) tables: soften into a clean card too */
.rc-content .table-container { background: transparent; border: 0; padding: 0; }

/* ==========================================================================
   10. AUTH PAGES, TOOLTIPS/POPOVERS & FINAL POLISH
   ========================================================================== */

/* --- Login / register / auth cards: centered & premium --- */
.rc-content .login-form,
.rc-content .password-reset-form,
.rc-content .register-form { max-width: 540px; margin: 36px auto; }
.rc-content .login-form .card,
.rc-content .password-reset-container .card { margin: 0 auto; border-radius: 20px; box-shadow: 0 18px 60px rgba(13, 31, 24, .12); }
.rc-content .login-form .card-body { padding: 40px !important; }
.rc-content .login-form h6.h3 { font-weight: 800; font-size: 24px; color: var(--rc-text-h); }
.rc-content .login-form .card-footer { background: var(--rc-bg-alt); text-align: center; padding: 18px; }
.rc-content .login-form .card-footer a { color: var(--rc-green-dark); }
.rc-content .input-group-merge .input-group-text { background: var(--rc-bg-alt); color: var(--rc-text-s); border-right: 0; }
.rc-content .input-group-merge .form-control { border-left: 0; }
.rc-content .input-group-merge .form-control:focus { border-color: var(--rc-border); box-shadow: none; }
.rc-content .form-control-label, .rc-content .control-label, .rc-content label.form-label { font-weight: 600; color: var(--rc-text-h); font-size: 13px; }

/* --- Tooltips & popovers (kill WHMCS's brown, go brand ink) --- */
.rc-portal .tooltip { font-family: var(--rc-font); }
.rc-portal .tooltip.show { opacity: 1; }
.rc-portal .tooltip-inner { background-color: var(--rc-ink) !important; color: #fff; border-radius: 8px; font-size: 12px; padding: 7px 11px; box-shadow: 0 6px 20px rgba(13, 31, 24, .2); }
.rc-portal .bs-tooltip-top .arrow::before, .rc-portal .tooltip.top .tooltip-arrow { border-top-color: var(--rc-ink) !important; }
.rc-portal .bs-tooltip-bottom .arrow::before, .rc-portal .tooltip.bottom .tooltip-arrow { border-bottom-color: var(--rc-ink) !important; }
.rc-portal .bs-tooltip-left .arrow::before, .rc-portal .tooltip.left .tooltip-arrow { border-left-color: var(--rc-ink) !important; }
.rc-portal .bs-tooltip-right .arrow::before, .rc-portal .tooltip.right .tooltip-arrow { border-right-color: var(--rc-ink) !important; }
.rc-portal .popover { border: 1px solid var(--rc-border); border-radius: 14px; box-shadow: 0 14px 48px rgba(13, 31, 24, .16); font-family: var(--rc-font); }
.rc-portal .popover-header { background: var(--rc-bg-alt); border-bottom: 1px solid var(--rc-border); font-weight: 700; color: var(--rc-text-h); border-radius: 14px 14px 0 0; }
.rc-portal .popover-body { color: var(--rc-text-b); }

/* --- Notifications popover list (sidebar flag button) --- */
.rc-portal .client-alerts { list-style: none; margin: 0; padding: 0; }

/* --- Close buttons, misc --- */
.rc-portal .modal .close { color: var(--rc-text-s); text-shadow: none; opacity: .7; }
.rc-portal .modal .close:hover { color: var(--rc-text-h); opacity: 1; }

/* --- Page-level scrollbar (subtle brand) --- */
.rc-content ::-webkit-scrollbar { width: 10px; height: 10px; }
.rc-content ::-webkit-scrollbar-thumb { background: var(--rc-border); border-radius: 8px; }
.rc-content ::-webkit-scrollbar-thumb:hover { background: var(--rc-green-soft); }

/* --- Breadcrumb spacing tidy --- */
.rc-content .master-breadcrumb .breadcrumb { display: flex; align-items: center; }

/* --- Definition/info tables on detail pages stay readable --- */
.rc-content table:not(.table-list) a { color: var(--rc-green-dark); }
