/* ==========================================================
   Glasshouse Hosting — Nexus Template Rebrand
   Dark theme · Orange accent · system-ui font
   ========================================================== */

html {
    font-size: 14px;
}

/* ----------------------------------------------------------
   DESIGN TOKENS
   ---------------------------------------------------------- */
:root {
    /* Glasshouse brand */
    --gh-orange:      #ff6a00;
    --gh-orange-deep: #c2410c;
    --gh-gold:        #f59e0b;
    --gh-glow:        rgba(255, 106, 0, 0.28);

    --white: #f4f4f5;

    /* Neutral → dark zinc scale */
    --neutral-50:  #18181b;
    --neutral-100: #1c1c1f;
    --neutral-200: #27272a;
    --neutral-300: #3f3f46;
    --neutral-400: #52525b;
    --neutral-500: #71717a;
    --neutral-600: #a1a1aa;
    --neutral-700: #d4d4d8;
    --neutral-800: #e4e4e7;
    --neutral-900: #f4f4f5;
    --neutral-950: #fafafa;

    /* Primary → Glasshouse orange */
    --primary-50:  rgba(255, 106, 0, 0.06);
    --primary-100: rgba(255, 106, 0, 0.10);
    --primary-200: rgba(255, 106, 0, 0.18);
    --primary-300: rgba(255, 106, 0, 0.30);
    --primary-400: #ff6a00;
    --primary-500: #ff6a00;
    --primary-600: #ea5a00;
    --primary-700: #c2410c;
    --primary-800: #9a3412;
    --primary-900: #7c2d12;
    --primary-950: #431407;

    --primary:          #ff6a00;
    --primary-lifted:   #ea5a00;
    --primary-accented: #c2410c;

    /* Secondary */
    --secondary:          #71717a;
    --secondary-lifted:   #a1a1aa;
    --secondary-accented: #52525b;

    /* Semantic */
    --success:          #16a34a;
    --success-lifted:   #15803d;
    --success-accented: #166534;

    --info:          #2563eb;
    --info-lifted:   #1d4ed8;
    --info-accented: #1e40af;

    --notice:          #7c3aed;
    --notice-lifted:   #6d28d9;
    --notice-accented: #5b21b6;

    --warning:          #d97706;
    --warning-lifted:   #b45309;
    --warning-accented: #92400e;

    --error:          #dc2626;
    --error-lifted:   #b91c1c;
    --error-accented: #991b1b;

    --grayscale:          #27272a;
    --grayscale-lifted:   #3f3f46;
    --grayscale-accented: #52525b;

    --neutral:          #3f3f46;
    --neutral-lifted:   #52525b;
    --neutral-accented: #71717a;

    /* Text → light on dark */
    --text-inverted: #0b0b0d;
    --text-muted:    #71717a;
    --text-lifted:   #a1a1aa;
    --text-accented: #d4d4d8;
    --text:          #f4f4f5;

    /* Borders → subtle white opacity */
    --border-muted:    rgba(255, 255, 255, 0.04);
    --border:          rgba(255, 255, 255, 0.07);
    --border-lifted:   rgba(255, 255, 255, 0.12);
    --border-accented: rgba(255, 255, 255, 0.20);

    /* Backgrounds */
    --bg:          #0b0b0d;
    --bg-muted:    #0e0e11;
    --bg-lifted:   #111113;
    --bg-accented: #17171a;
    --bg-inverted: #f4f4f5;

    /* Type scale */
    --text-xs: 0.625rem;
    --text-sm: 0.75rem;
    --text-md: 0.875rem;
    --text-lg: 1rem;

    /* Spacing / rounding */
    --outline-sm: 1px;
    --outline-md: 2px;
    --outline-lg: 3px;
    --rounding-sm: 0.375rem;
    --rounding-md: 0.625rem;
    --rounding-lg: 0.875rem;

    --letter-spacing:   0em;
    --disabled-opacity: 30%;
}

/* ----------------------------------------------------------
   BASE
   ---------------------------------------------------------- */
html, body {
    background-color: var(--bg) !important;
    color: var(--text) !important;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
}

a { color: var(--gh-orange); transition: color .2s; }
a:hover { color: var(--gh-gold); }

::selection { background: rgba(255, 106, 0, 0.3); color: #fff; }

hr { border-color: var(--border) !important; }

code, pre {
    background: var(--bg-accented) !important;
    color: var(--gh-gold) !important;
    border-radius: 8px !important;
}

.text-muted { color: var(--text-muted) !important; }
.bg-light,
.bg-white   { background: var(--bg-lifted) !important; }
.border     { border-color: var(--border) !important; }

/* ----------------------------------------------------------
   SITE-RETURN STRIP (links back to marketing site)
   ---------------------------------------------------------- */
.gh-site-strip {
    background: rgba(11, 11, 13, 0.98);
    border-bottom: 1px solid rgba(255, 106, 0, 0.12);
    padding: 6px 0;
    font-size: 12px;
}

.gh-site-strip-inner {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1rem;
}

.gh-site-strip a {
    color: var(--text-muted) !important;
    font-weight: 500;
    padding: 2px 10px;
    border-radius: 20px;
    transition: color .2s, background .2s;
}

.gh-site-strip a:hover {
    color: var(--gh-orange) !important;
    background: rgba(255, 106, 0, 0.08);
}

.gh-site-strip .gh-strip-home {
    color: var(--gh-orange) !important;
    font-weight: 700;
    background: rgba(255, 106, 0, 0.10);
    border: 1px solid rgba(255, 106, 0, 0.20);
}

.gh-site-strip .gh-strip-home:hover {
    background: rgba(255, 106, 0, 0.18) !important;
}

.gh-strip-sep {
    color: var(--border-accented);
    font-size: 10px;
}

/* ----------------------------------------------------------
   HEADER
   ---------------------------------------------------------- */
.header {
    background: transparent;
    position: sticky;
    top: 0;
    z-index: 900;
}

/* Top notifications bar (logged in) */
.topbar {
    background: rgba(11, 11, 13, 0.96) !important;
    border-bottom: 1px solid var(--border) !important;
    color: var(--text-lifted) !important;
    font-size: 13px;
}

.topbar .btn {
    color: var(--text-lifted) !important;
    font-size: 13px;
}

.topbar .btn:hover { color: var(--gh-orange) !important; }

.topbar .btn-active-client,
.topbar .btn-active-client span { color: var(--text) !important; }

.topbar .input-group-text {
    background: transparent !important;
    border-color: var(--border) !important;
    color: var(--text-muted) !important;
}

.topbar .btn-return-to-admin {
    background: rgba(220, 38, 38, 0.15) !important;
    border: 1px solid rgba(220, 38, 38, 0.30) !important;
    color: #f87171 !important;
    border-radius: 8px !important;
    font-size: 13px;
}

/* Brand/logo navbar */
.navbar.navbar-light {
    background: rgba(11, 11, 13, 0.94) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border-bottom: 1px solid var(--border) !important;
    box-shadow: none !important;
    padding: 10px 0;
}

/* Main navigation bar */
.navbar.main-navbar-wrapper,
.navbar.navbar-expand-xl.main-navbar-wrapper {
    background: rgba(11, 11, 13, 0.96) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border-bottom: 1px solid var(--border) !important;
    box-shadow: none !important;
}

/* Logo */
.navbar-brand { color: var(--text) !important; }
.navbar-brand .logo-img { max-height: 40px; width: auto; display: block; }

/* KB search */
.navbar .search .btn,
.navbar .search .btn-default { background: var(--bg-lifted) !important; border-color: var(--border) !important; color: var(--text-muted) !important; }
.navbar .search input { background: var(--bg-lifted) !important; border-color: var(--border) !important; color: var(--text) !important; border-radius: 0 10px 10px 0 !important; }
.navbar .search input::placeholder { color: var(--text-muted) !important; }
.navbar .search input:focus { border-color: var(--gh-orange) !important; box-shadow: 0 0 0 2px rgba(255, 106, 0, 0.15) !important; }

/* Nav links */
.navbar-nav .nav-link,
#nav .nav-link {
    color: var(--text-lifted) !important;
    font-weight: 500;
    transition: color .2s !important;
}

.navbar-nav .nav-link:hover,
#nav .nav-link:hover { color: var(--gh-orange) !important; }

.navbar-nav .nav-item.active > .nav-link,
.navbar-nav .nav-link.active { color: var(--gh-orange) !important; font-weight: 600 !important; }

/* Cart */
.cart-btn .badge { background: var(--gh-orange) !important; }

/* Mobile nav toggle */
.navbar .btn[data-toggle="collapse"] { color: var(--text) !important; border: 1px solid var(--border); border-radius: 8px; }

/* Dropdown menus */
.dropdown-menu {
    background: var(--bg-lifted) !important;
    border: 1px solid var(--border) !important;
    border-radius: 12px !important;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5) !important;
    padding: 8px !important;
}

.dropdown-item {
    color: var(--text-lifted) !important;
    font-size: 13px;
    border-radius: 8px;
    transition: background .15s, color .15s;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background: rgba(255, 106, 0, 0.10) !important;
    color: var(--text) !important;
}

.dropdown-divider { border-color: var(--border) !important; margin: 6px 0 !important; }

/* Breadcrumb */
.master-breadcrumb {
    background: var(--bg-muted) !important;
    border-bottom: 1px solid var(--border) !important;
    padding: 6px 0;
}

.breadcrumb { background: transparent !important; margin: 0; padding: 6px 0; }
.breadcrumb-item a { color: var(--gh-orange) !important; }
.breadcrumb-item.active { color: var(--text-muted) !important; }
.breadcrumb-item + .breadcrumb-item::before { color: var(--text-muted) !important; }

/* ----------------------------------------------------------
   CARDS / PANELS
   ---------------------------------------------------------- */
.card,
.panel {
    background: var(--bg-lifted) !important;
    border: 1px solid var(--border) !important;
    border-radius: 14px !important;
    box-shadow: none !important;
    color: var(--text) !important;
    transition: border-color .2s;
}

.card-header,
.panel-heading {
    background: var(--bg-accented) !important;
    border-bottom: 1px solid var(--border) !important;
    color: var(--text) !important;
    font-weight: 600;
    border-radius: 14px 14px 0 0 !important;
}

.card-footer,
.panel-footer {
    background: var(--bg-accented) !important;
    border-top: 1px solid var(--border) !important;
    border-radius: 0 0 14px 14px !important;
}

/* Card accent colours (client home panels) */
.card-accent-blue   { border-top: 3px solid #2563eb !important; }
.card-accent-green  { border-top: 3px solid #16a34a !important; }
.card-accent-orange { border-top: 3px solid var(--gh-orange) !important; }
.card-accent-red    { border-top: 3px solid #dc2626 !important; }
.card-accent-purple { border-top: 3px solid #7c3aed !important; }
.card-accent-gold   { border-top: 3px solid var(--gh-gold) !important; }

/* ----------------------------------------------------------
   BUTTONS
   ---------------------------------------------------------- */
.btn-primary,
.btn-success {
    background: linear-gradient(135deg, var(--gh-orange), var(--gh-gold)) !important;
    border: none !important;
    color: #fff !important;
    font-weight: 600 !important;
    border-radius: 10px !important;
    transition: transform .15s ease, box-shadow .15s ease !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-success:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 22px var(--gh-glow) !important;
    background: linear-gradient(135deg, var(--gh-orange-deep), var(--gh-orange)) !important;
    color: #fff !important;
}

.btn-default,
.btn-secondary,
.btn-outline-secondary,
.btn-outline-light {
    background: transparent !important;
    border: 1px solid var(--border-lifted) !important;
    color: var(--text-lifted) !important;
    border-radius: 10px !important;
    font-weight: 600 !important;
    transition: border-color .2s, color .2s !important;
}

.btn-default:hover,
.btn-secondary:hover,
.btn-outline-secondary:hover,
.btn-outline-light:hover {
    border-color: rgba(255, 106, 0, 0.5) !important;
    color: var(--gh-orange) !important;
    background: transparent !important;
}

.btn-danger {
    background: var(--error) !important;
    border-color: var(--error) !important;
    border-radius: 10px !important;
    font-weight: 600 !important;
    color: #fff !important;
}

.btn-xs { font-size: 11px !important; padding: 3px 10px !important; }

/* ----------------------------------------------------------
   FORMS
   ---------------------------------------------------------- */
.form-control,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
select,
textarea {
    background: var(--bg-accented) !important;
    border: 1px solid var(--border) !important;
    color: var(--text) !important;
    border-radius: 10px !important;
    transition: border-color .2s, box-shadow .2s;
}

.form-control:focus,
input:focus,
select:focus,
textarea:focus {
    border-color: var(--gh-orange) !important;
    box-shadow: 0 0 0 3px rgba(255, 106, 0, 0.15) !important;
    background: var(--bg-accented) !important;
    outline: none !important;
    color: var(--text) !important;
}

.form-control::placeholder,
input::placeholder { color: var(--text-muted) !important; }

label,
.form-label,
.form-control-label,
.control-label {
    color: var(--text-lifted) !important;
    font-size: 13px;
    font-weight: 500;
}

.input-group-text {
    background: var(--bg-accented) !important;
    border-color: var(--border) !important;
    color: var(--text-muted) !important;
}

/* Reveal-password button */
.btn-reveal-pw {
    background: var(--bg-accented) !important;
    border: 1px solid var(--border) !important;
    border-left: none !important;
    color: var(--text-muted) !important;
    border-radius: 0 10px 10px 0 !important;
}

/* ----------------------------------------------------------
   TABLES
   ---------------------------------------------------------- */
.table { color: var(--text) !important; }

.table thead th {
    background: var(--bg-accented) !important;
    border-bottom: 1px solid var(--border) !important;
    border-color: var(--border) !important;
    color: var(--text-muted) !important;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
}

.table tbody tr { border-bottom: 1px solid var(--border) !important; transition: background .15s; }
.table tbody tr:hover { background: rgba(255, 106, 0, 0.04) !important; }
.table td, .table th { border-color: var(--border) !important; vertical-align: middle; }
.table-striped tbody tr:nth-of-type(odd) { background: rgba(255, 255, 255, 0.02) !important; }
.table-bordered { border-color: var(--border) !important; }

/* ----------------------------------------------------------
   ALERTS / NOTICES
   ---------------------------------------------------------- */
.alert { border-radius: 12px !important; border: 1px solid !important; font-size: 14px; }

.alert-success { background: rgba(22, 163, 74, 0.12) !important; border-color: rgba(22, 163, 74, 0.30) !important; color: #4ade80 !important; }
.alert-info    { background: rgba(37, 99, 235, 0.12) !important; border-color: rgba(37, 99, 235, 0.30) !important; color: #93c5fd !important; }
.alert-warning { background: rgba(217, 119, 6, 0.12) !important; border-color: rgba(217, 119, 6, 0.30) !important; color: #fbbf24 !important; }
.alert-danger  { background: rgba(220, 38, 38, 0.12) !important; border-color: rgba(220, 38, 38, 0.30) !important; color: #f87171 !important; }

/* ----------------------------------------------------------
   BADGES
   ---------------------------------------------------------- */
.badge { border-radius: 20px !important; font-weight: 700; font-size: 11px; padding: 3px 10px !important; }

.badge-primary   { background: rgba(255, 106, 0, 0.18) !important; color: var(--gh-orange) !important; }
.badge-success   { background: rgba(22, 163, 74, 0.18) !important; color: #4ade80 !important; }
.badge-danger    { background: rgba(220, 38, 38, 0.18) !important; color: #f87171 !important; }
.badge-warning   { background: rgba(217, 119, 6, 0.18) !important; color: #fbbf24 !important; }
.badge-info      { background: rgba(37, 99, 235, 0.18) !important; color: #93c5fd !important; }
.badge-dark,
.badge-secondary { background: var(--bg-accented) !important; color: var(--text-muted) !important; }
.badge-pill      { border-radius: 20px !important; }

/* ----------------------------------------------------------
   PAGINATION
   ---------------------------------------------------------- */
.page-link {
    background: var(--bg-lifted) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-muted) !important;
}

.page-link:hover { border-color: var(--gh-orange) !important; color: var(--gh-orange) !important; background: var(--bg-lifted) !important; }
.page-item.active .page-link { background: linear-gradient(135deg, var(--gh-orange), var(--gh-gold)) !important; border-color: transparent !important; color: #fff !important; }
.page-item.disabled .page-link { opacity: 0.4; }

/* ----------------------------------------------------------
   MODALS
   ---------------------------------------------------------- */
.modal-content {
    background: var(--bg-lifted) !important;
    border: 1px solid var(--border) !important;
    border-radius: 18px !important;
    color: var(--text) !important;
}

.modal-header { border-bottom: 1px solid var(--border) !important; }
.modal-footer { border-top: 1px solid var(--border) !important; }
.modal-backdrop { background: rgba(0, 0, 0, 0.7) !important; }

.close {
    color: var(--text-muted) !important;
    opacity: 1 !important;
    text-shadow: none !important;
}
.close:hover { color: var(--text) !important; }

/* Language/currency modal */
.modal-localisation .modal-content {
    background: var(--bg-lifted) !important;
}

.modal-localisation .item {
    background: var(--bg-accented) !important;
    border: 1px solid var(--border) !important;
    border-radius: 8px;
    color: var(--text-lifted) !important;
    display: block;
    padding: 8px 12px;
    transition: border-color .15s, color .15s;
}

.modal-localisation .item.active,
.modal-localisation .item:hover {
    border-color: rgba(255, 106, 0, 0.40) !important;
    color: var(--gh-orange) !important;
    background: rgba(255, 106, 0, 0.08) !important;
}

/* ----------------------------------------------------------
   NAV TABS / PILLS
   ---------------------------------------------------------- */
.nav-tabs { border-bottom: 1px solid var(--border) !important; }
.nav-tabs .nav-link { color: var(--text-muted) !important; border: 1px solid transparent !important; border-radius: 10px 10px 0 0 !important; }
.nav-tabs .nav-link:hover { color: var(--text) !important; border-color: var(--border) var(--border) transparent !important; background: var(--bg-accented) !important; }
.nav-tabs .nav-link.active { background: var(--bg-lifted) !important; border-color: var(--border) var(--border) var(--bg-lifted) !important; color: var(--gh-orange) !important; font-weight: 600 !important; }

.nav-pills .nav-link { border-radius: 10px !important; color: var(--text-muted) !important; }
.nav-pills .nav-link:hover { background: var(--bg-accented) !important; color: var(--text) !important; }
.nav-pills .nav-link.active { background: linear-gradient(135deg, var(--gh-orange), var(--gh-gold)) !important; color: #fff !important; }

/* ----------------------------------------------------------
   LIST GROUP (sidebar)
   ---------------------------------------------------------- */
.list-group-item {
    background: var(--bg-lifted) !important;
    border-color: var(--border) !important;
    color: var(--text) !important;
}

.list-group-item-action {
    color: var(--text-lifted) !important;
    transition: background .15s, color .15s;
}

.list-group-item-action:hover,
.list-group-item-action:focus {
    background: rgba(255, 106, 0, 0.08) !important;
    color: var(--text) !important;
}

.list-group-item.active {
    background: rgba(255, 106, 0, 0.15) !important;
    border-color: rgba(255, 106, 0, 0.35) !important;
    color: var(--gh-orange) !important;
    font-weight: 600 !important;
}

.list-group-item.disabled {
    background: var(--bg-lifted) !important;
    color: var(--text-subtle) !important;
    opacity: 0.5;
}

/* ----------------------------------------------------------
   SIDEBAR
   ---------------------------------------------------------- */
.sidebar .card { border-color: var(--border) !important; }

.sidebar .card-header {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--text-muted) !important;
}

/* ----------------------------------------------------------
   CLIENT HOME TILES
   ---------------------------------------------------------- */
.tiles .tile {
    background: var(--bg-lifted) !important;
    border: 1px solid var(--border) !important;
    border-radius: 14px !important;
    color: var(--text-muted) !important;
    transition: border-color .2s, color .2s, transform .15s;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 1.5rem 1rem;
    text-decoration: none !important;
}

.tiles .tile:hover {
    border-color: rgba(255, 106, 0, 0.35) !important;
    color: var(--gh-orange) !important;
    transform: translateY(-2px);
}

.tiles .tile i { font-size: 1.5rem; color: var(--gh-orange); margin-bottom: 0.5rem; }
.tiles .tile .stat { font-size: 1.8rem; font-weight: 800; color: var(--text) !important; line-height: 1.2; }
.tiles .tile .title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; color: var(--text-muted) !important; }

.tiles .tile .highlight { border-radius: 0 0 14px 14px; height: 3px; width: 100%; margin-top: auto; }
.tiles .tile .highlight.bg-color-blue   { background: #2563eb !important; }
.tiles .tile .highlight.bg-color-green  { background: #16a34a !important; }
.tiles .tile .highlight.bg-color-red    { background: #dc2626 !important; }
.tiles .tile .highlight.bg-color-gold   { background: var(--gh-gold) !important; }
.tiles .tile .highlight.bg-color-orange { background: var(--gh-orange) !important; }

.tiles { margin-bottom: 1.5rem; }
.tiles .row { gap: 0; }
.tiles .col-6,
.tiles .col-xl-3 { padding: 6px; }

/* ----------------------------------------------------------
   POPOVERS (notifications)
   ---------------------------------------------------------- */
.popover {
    background: var(--bg-lifted) !important;
    border: 1px solid var(--border) !important;
    border-radius: 12px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5) !important;
}

.popover-header { background: var(--bg-accented) !important; border-bottom: 1px solid var(--border) !important; color: var(--text) !important; border-radius: 12px 12px 0 0 !important; }
.popover-body { color: var(--text-lifted) !important; }
.bs-popover-bottom > .arrow::after { border-bottom-color: var(--bg-lifted) !important; }
.bs-popover-top    > .arrow::after { border-top-color:    var(--bg-lifted) !important; }

.client-alerts { list-style: none; padding: 0; margin: 0; min-width: 280px; }
.client-alerts li a { color: var(--text-lifted) !important; display: flex; gap: 10px; padding: 8px 12px; border-radius: 8px; }
.client-alerts li a:hover { color: var(--gh-orange) !important; background: rgba(255, 106, 0, 0.08); }
.client-alerts li.none { color: var(--text-muted) !important; font-size: 13px; padding: 8px 12px; }

/* ----------------------------------------------------------
   DOMAIN SEARCH (public homepage)
   ---------------------------------------------------------- */
.domain-lookup-section,
.jumbotron {
    background: linear-gradient(135deg, var(--bg-lifted), var(--bg-accented)) !important;
    border-bottom: 1px solid var(--border) !important;
}

/* ----------------------------------------------------------
   STORE / DYNAMIC STORE
   ---------------------------------------------------------- */
.pricing-card,
.table-wrapper,
.buy-row {
    background: var(--bg-lifted) !important;
    color: var(--text) !important;
    border-color: var(--border) !important;
}

.background-gradient {
    background: linear-gradient(135deg, var(--bg-lifted), var(--bg-accented)) !important;
}

.cta-primary-button,
.plan-button,
.faq-contact-button,
.table-cta-button {
    background: linear-gradient(135deg, var(--gh-orange), var(--gh-gold)) !important;
    color: #fff !important;
    border: none !important;
}

/* ----------------------------------------------------------
   PRODUCT CARDS (cart)
   ---------------------------------------------------------- */
.product-list .product,
.package-list .package {
    background: var(--bg-lifted) !important;
    border: 1px solid var(--border) !important;
    border-radius: 14px !important;
    transition: border-color .2s, transform .2s;
}

.product-list .product:hover,
.package-list .package:hover {
    border-color: rgba(255, 106, 0, 0.35) !important;
    transform: translateY(-2px);
}

/* ----------------------------------------------------------
   SCROLLBAR
   ---------------------------------------------------------- */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border-lifted); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255, 255, 255, 0.15); }

/* ----------------------------------------------------------
   FULLPAGE OVERLAY SPINNER
   ---------------------------------------------------------- */
#fullpage-overlay { background: rgba(11, 11, 13, 0.85) !important; }

/* ----------------------------------------------------------
   FOOTER
   ---------------------------------------------------------- */
.footer,
#footer {
    background: var(--bg-lifted) !important;
    border-top: 1px solid var(--border) !important;
}

.footer .nav-link {
    color: var(--text-muted) !important;
    font-size: 13px;
    transition: color .2s;
    padding: 4px 8px;
}
.footer .nav-link:hover { color: var(--gh-orange) !important; }

.footer .copyright { color: var(--text-muted) !important; font-size: 12px; }

/* Branded footer columns */
.gh-footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 2.5rem;
    padding: 2.5rem 0;
    border-bottom: 1px solid var(--border);
}

@media (max-width: 768px) {
    .gh-footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
    .gh-footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 480px) {
    .gh-footer-grid { grid-template-columns: 1fr; }
}

.gh-footer-logo { max-height: 34px; width: auto; display: block; margin-bottom: 0.75rem; }

.gh-footer-brand p {
    color: var(--text-muted);
    font-size: 13px;
    line-height: 1.65;
    margin: 0;
    max-width: 300px;
}

.gh-footer-col h6 {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: var(--gh-orange);
    margin: 0 0 0.75rem;
}

.gh-footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.5rem; }
.gh-footer-col li a { color: var(--text-muted) !important; font-size: 13px; transition: color .2s; }
.gh-footer-col li a:hover { color: var(--text) !important; }

.gh-footer-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 1.25rem 0;
    font-size: 12px;
    color: var(--text-muted);
}

.gh-footer-bar a { color: var(--text-muted) !important; transition: color .2s; }
.gh-footer-bar a:hover { color: var(--gh-orange) !important; }

/* Return-to-admin button (fixed) */
.btn-return-to-admin {
    background: rgba(220, 38, 38, 0.15) !important;
    border: 1px solid rgba(220, 38, 38, 0.30) !important;
    color: #f87171 !important;
    border-radius: 10px !important;
    font-size: 13px;
}
